Unsupervised Learning

advertisement
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
Download