Unsupervised Learning G.Anuradha Contents • • • • • Introduction Competitive Learning networks Kohenen self-organizing networks Learning vector quantization Hebbian learning Introduction The main property of a neural network is an ability to learn from its environment, and to improve its performance through learning. So far we have considered supervised or active learning - learning with an external “teacher” or a supervisor who presents a training set to the network. But another type of learning also exists: unsupervised learning. 4/13/2015 3 In contrast to supervised learning, unsupervised or self-organised learning does not require an external teacher. During the training session, the neural network receives a number of different input patterns, discovers significant features in these patterns and learns how to classify input data into appropriate categories. Unsupervised learning tends to follow the neuro-biological organisation of the brain. Unsupervised learning algorithms aim to learn rapidly and can be used in real-time. 4/13/2015 4 Hebbian learning In 1949, Donald Hebb proposed one of the key ideas in biological learning, commonly known as Hebb’s Law. Hebb’s Law states that if neuron i is near enough to excite neuron j and repeatedly participates in its activation, the synaptic connection between these two neurons is strengthened and neuron j becomes more sensitive to stimuli from neuron i. 4/13/2015 5 Hebb’s Law can be represented in the form of two rules: 1. If two neurons on either side of a connection are activated synchronously, then the weight of that connection is increased. 2. If two neurons on either side of a connection are activated asynchronously, then the weight of that connection is decreased. Hebb’s Law provides the basis for learning without a teacher. Learning here is a local phenomenon occurring without feedback from the environment. 4/13/2015 6 Competitive learning In competitive learning, neurons compete among themselves to be activated. While in Hebbian learning, several output neurons can be activated simultaneously, in competitive learning, only a single output neuron is active at any time. The output neuron that wins the “competition” is called the winner-takes-all neuron. 4/13/2015 7 The basic idea of competitive learning was introduced in the early 1970s. In the late 1980s, Teuvo Kohonen introduced a special class of artificial neural networks called self-organizing feature maps. These maps are based on competitive learning. 4/13/2015 Intelligent Systems and Soft Computing 8 What is a self-organizing feature map? Our brain is dominated by the cerebral cortex, a very complex structure of billions of neurons and hundreds of billions of synapses. The cortex includes areas that are responsible for different human activities (motor, visual, auditory, somatosensory, etc.), and associated with different sensory inputs. We can say that each sensory input is mapped into a corresponding area of the cerebral cortex. The cortex is a self-organizing computational map in the human brain. 4/13/2015 Intelligent Systems and Soft Computing 9 Kohenen Self-Organizing Feature Maps • Feature mapping converts a wide pattern space into a typical feature space • Apart from reducing higher dimensionality it has to preserve the neighborhood relations of input patterns Feature-mapping Kohonen model Kohonen layer Kohonen layer Input layer 1 4/13/2015 0 (a) Input layer 1 0 Intelligent Systems and Soft Computing (b) 11 The Kohonen network The Kohonen model provides a topological mapping. It places a fixed number of input patterns from the input layer into a higherdimensional output or Kohonen layer. Training in the Kohonen network begins with the winner’s neighborhood of a fairly large size. Then, as training proceeds, the neighborhood size gradually decreases. 4/13/2015 12 Model: Horizontal & Vertical lines Rumelhart & Zipser, 1985 • Problem – identify vertical or horizontal signals • Inputs are 6 x 6 arrays • Intermediate layer with 8 units • Output layer with 2 units • Cannot work with one layer Rumelhart & Zipser, Cntd H V Geometrical Interpretation • So far the ordering of the output units themselves was not necessarily informative • The location of the winning unit can give us information regarding similarities in the data • We are looking for an input output mapping that conserves the topologic properties of the inputs feature mapping • Given any two spaces, it is not guaranteed that such a mapping exits! In the Kohonen network, a neuron learns by shifting its weights from inactive connections to active ones. Only the winning neuron and its neighbourhood are allowed to learn. If a neuron does not respond to a given input pattern, then learning cannot occur in that particular neuron. The competitive learning rule defines the change Dwij applied to synaptic weight wij as a ( xi - wij ), if neuron j wins the competition D wij 0, if neuron j loses the competition where xi is the input signal and a is the learning rate parameter. 4/13/2015 Intelligent Systems and Soft Computing 19 The overall effect of the competitive learning rule resides in moving the synaptic weight vector Wj of the winning neuron j towards the input pattern X. The matching criterion is equivalent to the minimum Euclidean distance between vectors. The Euclidean distance between a pair of n-by-1 vectors X and Wj is defined by 1/ 2 2 d X - W j ( xi - wij ) i 1 n where xi and wij are the ith elements of the vectors X and Wj, respectively. 4/13/2015 Intelligent Systems and Soft Computing 20 To identify the winning neuron, jX, that best matches the input vector X, we may apply the following condition: j X min X - W j , j j = 1, 2, . . ., m where m is the number of neurons in the Kohonen layer. 4/13/2015 Intelligent Systems and Soft Computing 21 Suppose, for instance, that the 2-dimensional input vector X is presented to the three-neuron Kohonen network, 0.52 X 0 . 12 The initial weight vectors, Wj, are given by 0.27 W1 0 . 81 4/13/2015 0.42 W2 0 . 70 Intelligent Systems and Soft Computing 0.43 W3 0 . 21 22 We find the winning (best-matching) neuron jX using the minimum-distance Euclidean criterion: d1 ( x1 - w11) 2 ( x2 - w21) 2 (0.52 - 0.27) 2 (0.12 - 0.81) 2 0.73 d2 ( x1 - w12) 2 ( x2 - w22) 2 (0.52 - 0.42) 2 (0.12 - 0.70) 2 0.59 d3 ( x1 - w13) 2 ( x2 - w23) 2 (0.52 - 0.43) 2 (0.12 - 0.21) 2 0.13 Neuron 3 is the winner and its weight vector W3 is updated according to the competitive learning rule. 4/13/2015 Dw13 ( x1 - w13) 0.1 (0.52 - 0.43) 0.01 Dw23 ( x2 - w23) 0.1(0.12 - 0.21) - 0.01 Intelligent Systems and Soft Computing 23 The updated weight vector W3 at iteration (p + 1) is determined as: 0.43 0.01 0.44 W3( p 1) W3 ( p) DW3 ( p) 0 . 21 0 . 01 0 . 20 The weight vector W3 of the wining neuron 3 becomes closer to the input vector X with each iteration. 4/13/2015 Intelligent Systems and Soft Computing 24 Measures of similarity Distance Normalized scalar product Kohenen Self-Organizing networks • Also known as Kohenen Feature maps or topology-preserving maps • Learning procedure of Kohenen feature maps is similar to that of competitive learning networks. • Similarity (dissimilarity) measure is selected and the winning unit is considered to be the one with the largest (smallest) activation • The weights of the winning neuron as well as the neighborhood around the winning units are adjusted. • Neighborhood size decreases slowly with every iteration. Training of kohenon self organizing network 1. Select the winning output unit as the one with the largest similarity measure between all wi and xi . The winning unit c satisfies the equation ||x-wc||=min||x-wi|| where the index c refers to the winning unit (Euclidean distance) 2. Let NBc denote a set of index corresponding to a neighborhood around winner c. The weights of the winner and it neighboring units are updated by Δwi=ɳ(x-wi) iεNBc Start Initialize Weights, Learning rate Initialize Topological Neighborhood params For Each i/p X For i=1 to n For j=1 to m D(j)=Ʃ(xi-wij)2 Winning unit index J is computed D(J)=minimum Weights of winning unit continue Stop Test (t+1) Is reduced continue Reduce radius Of network Reduce learning rate Problem • Construct a kohenen self-organizing map to cluster the four given vectors [0 0 1 1], [1 0 0 0], [0 1 1 0],[0 0 01]. The number of cluster to be formed is two. Initial learning rate is 0.5 0 .2 0 .9 0 .4 0 .7 • Initial weights = 0.6 0.5 0 . 8 0 .3 Solution to the problem Input vector Winner weights [0 0 1 1] D(1) [0.1 0.2 0.8 0.9] [1 0 0 0] D(2) [0.95 0.35 0.25 0.15] [0 1 1 0] D(1) [0.05 0.6 0.9 0.95] [0 0 0 1] D(1) [0.025 0.3 0.45 0.975] Inference Initial random weights Network after 100 iterations 1 0.8 0.6 0.4 W(2,j) 0.2 0 -0.2 -0.4 -0.6 -0.8 -1 -1 4/13/2015 -0.8 -0.6 -0.4 -0.2 0 0.2 W(1,j) Intelligent Systems and Soft Computing 0.4 0.6 0.8 1 36 Network after 1000 iterations 1 0.8 0.6 0.4 W(2,j) 0.2 0 -0.2 -0.4 -0.6 -0.8 -1 -1 4/13/2015 -0.8 -0.6 -0.4 -0.2 0 0.2 W(1,j) Intelligent Systems and Soft Computing 0.4 0.6 0.8 1 37 Network after 10,000 iterations 1 0.8 0.6 0.4 W(2,j) 0.2 0 -0.2 -0.4 -0.6 -0.8 -1 -1 4/13/2015 -0.8 -0.6 -0.4 -0.2 0 W(1,j) 0.2 Intelligent Systems and Soft Computing 0.4 0.6 0.8 1 38 Training occurs in several steps and over many iterations: Each node's weights are initialized. A vector is chosen at random from the set of training data and presented to the lattice. Every node is examined to calculate which one's weights are most like the input vector. The winning node is commonly known as the Best Matching Unit (BMU). The radius of the neighbourhood of the BMU is now calculated. This is a value that starts large, typically set to the 'radius' of the lattice, but diminishes each time-step. Any nodes found within this radius are deemed to be inside the BMU's neighbourhood. Each neighbouring node's (the nodes found in step 4) weights are adjusted to make them more like the input vector. The closer a node is to the BMU, the more its weights get altered. Repeat step 2 for N iterations. Determining Neighbourhood • A neighborhood function around the winning unit can be used instead of defining the neighborhood of a winning unit. • A Gaussian function can be used as neighborhood function - || pi - pc ||2 c(i ) exp( ) 2 2 Where pi and pc are the positions of the output units i and c respectively and σ reflects the scope of the neighborhood. The update formula using neighborhood function is given by Dwi c(i)(x - wi ) Applications of SOM-World Poverty Map What happens in a dot product method? • In the case of a dot product finding a minimum of x-wi is nothing but finding the maximum among the m scalar products • Competitive learning network performs an on-line clustering process on the input patterns • When process is complete the input data is divided into disjoint clusters • With euclidean distance the update formula is actually an online gradient descent that minimizes the objective function Competitive learning with unitlength vectors The dots represent the input vectors and the crosses denote the weight vectors for the four output units As the learning continues, the four weight vectors rotate toward the centers of the four input clusters Limitations of competitive learning • Weights are initialized to random values which might be far from any input vector and it never gets updated – Can be prevented by initializing the weights to samples from the input data itself, thereby ensuring that all weights get updated when all the input patterns are presented – Or else the weights of winning as well as losing neurons can be updated by tuning the learning constant by using a significantly smaller learning rate for the losers. This is called as leaky learning – Note:- Changing η is generally desired. An initial value of η explores the data space widely. Later on progressively smaller value refines the weights. Similar to the cooling schedule in simulated annealing. Limitations of competitive learning • Lacks the capability to add new clusters when deemed necessary • If ɳ is constant –no stability of clusters • If ɳ is decreasing with time may become too small to update cluster centers • This is called as stability-plasticity dilemma (Solved using adaptive resonance theory (ART)) • If the output units are arranged in the form of a vector or matrix then the weights of winners as well as neighbouring losers can be updated. (Kohenen feature maps) • After learning the input space is divided into a number of disjoint clusters. These cluster centers are known as template or code book • For any input pattern presented we can use an appropriate code book vector (Vector Quantization) • This vector quantization is used in data compression in IP and communication systems. Learning Vector Quantization LVQ LVQ • Recall that a Kohonen SOM is a clustering technique, which can be used to provide insight into the nature of data. We can transform this unsupervised neural network into a supervised LVQ neural network. • The network architecture is just like a SOM, but without a topological structure. • Each output neuron represents a known category (e.g. apple, pear, orange). • Input vector = x=(x1,x2…..xn) • Weight vector for the jth output neuron wj=( w1j,w2j,….wnj) • Cj= Category represented by the jth neuron. This is pre-assigned. • T = Correct category for input • Define Euclidean distance between the input vector and the weight vector of the jth neuron as: Ʃ(xi-wij)2 • It is an adaptive data classification method based on training data with desired class information • It is actually a supervised training method but employs unsupervised data-clustering techniques to preprocess the data set and obtain cluster centers • Resembles a competitive learning network except that each output unit is associated with a class. Network representation of LVQ Possible data distributions and decision boundaries LVQ learning algorithm • Step 1: Initialize the cluster centers by a clustering method • Step 2: Label each cluster by the voting method • Step 3: Randomly select a training input vector x and find k such that ||x-wk|| is a minimum • Step 4: If x and wk belong to the same class update wk by Dwk ( x - wk ) else Dwk - ( x - wk ) • The parameters used for the training process of a LVQ include the following – x=training vector (x1,x2,……xn) – T=category or class for the training vector x – wj= weight vector for j th output unit (w1j,…wij….wnj) – cj= cluster or class or category associated with jth output unit – The Euclidean distance of jth output unit is D(j)=Ʃ(xi-wij)2 For each i/p x Initialize weight Learning rate Start Y Calculate winner Winner = min D(j) Input T A B If T=Cj Y wj(n)=wj(o) + ɳ[x-wj(o)] A Y Stop B If ɳ reduces negligible Reduce ɳ ɳ(t+1)=0.5 ɳ(t) N wj(n)=wj(o) ɳ[x-wj(o)] Problem • Construct and test and LVQ net with five vectors assigned to two classes. The given vectors along with the classes are as shown in the table below Vector Class [0 0 1 1] 1 [1 0 0 0] 2 [0 0 0 1] 2 [1 1 0 0] 1 [0 1 1 0] 1