MSc/MEng Data Mining and Machine Learning (2019)
Lab 4 – Neural Networks
Problem
The challenge is to implement the Error Back-Propagation (EBP) training algorithm for a multilayer
perceptron (MLP) 4-2-4 encoder [1] using MatLab (or your language of choice). Intuitively
the structure of the encoder is as shown in Figure 1.
The MLP has an input layer with 4 units, a single hidden layer with 2 hidden units, and an output
layer with 4 units. Each unit has a sigmoid activation function. The task of the encoder is to map
the following inputs onto outputs:
Input pattern Output pattern
1,0,0,0 1,0,0,0
0,1,0,0 0,1,0,0
0,0,1,0 0,0,1,0
0,0,0,1 0,0,0,1
The problem is that this has to be achieved through the 2-unit “bottle-neck” hidden layer.
Rumelhart, Hinton and Williams demonstrate that to achieve this, the MLP learns binary
encoding in the hidden layer.
Input (and target) pattern
There are 4 input patterns, and the targets are equal to the inputs (Table 1). Recall that the
output 𝑜j of the j
th unit in the network is given by:
𝑜𝑗 = 𝜑(𝑛𝑒𝑡𝑗) =1(1 + 𝑒−𝑛𝑒𝑡𝑗)
where 𝑛𝑒𝑡j
is the input to the j
th unit. The values of 𝑜j converge towards 0 and 1 as the
magnitude of 𝑛𝑒𝑡j becomes large, but the values 0 and 1 are never realised. Hence for practical
purposes it is better to replace, for example, 1, 0, 0, 0 in Table 1 with 0.9, 0.1, 0.1, 0.1.
Since there are only these 4 input/output pairs, the training set consists of just 4 input/output
pairs.
Structure of the program
The program needs to run the EBP weight updating process multiple times. So you will need a
variable N for the number of iterations and an outer loop (for n=1:1:N). You could
Figure 1: MLP structure for 4-2-4 encoder
Table 1: Input-output pairs for the 4-2-4 encoder
2
terminate the process when the change in error drops below a threshold but this is simpler for
the moment. In addition you will need a second inner loop (for d=1:1:4) to cycle through
the 4 input patterns in each iteration. But before you do this you need to set up some basic
structures:
You will need two arrays W1 and W2 to store the weights between the input and hidden,
and hidden and output layers, respectively. I suggest that you make W1 4x2 and W2 2x4.
You will need to initialize these arrays (randomly?). Given an output 𝑥 from the input layer,
the input 𝑦 to the hidden layer is given by:
y = W1’*x;
Note the transpose!
The output from the hidden layer is obtained by applying the sigmoid function to y, so you
will need to write a function to implement this function.
Once you have propagated the input to the output layer you can calculate the error. In fact
the only use you have for the error is to plot it to help confirm that your code is working.
Now you need to back-propagate to calculate 𝛿j
for every unit 𝑗 in the output and hidden
layers. First you need to calculate 𝛿j
for every output unit (see equation (12) in the slides).
Then you need to apply back-propagation to calculate 𝛿j
for every hidden unit (again see
equation (12) in the slides). To back-propagate the vector of 𝛿j
s from the output layer to
the hidden layer you just need to multiply by W2 (no transpose this time):
deltaH = W2*deltaO;
where deltaO and deltaH are the deltas in the output and hidden layers, respectively.
Once you have calculated the 𝛿𝑗
s for the output and hidden layers you can calculate
∆𝑤ij = −𝜗𝛿j𝑜i
(see slide 12 from the lecture).
Finally, you can update the weights: 𝑤ij → 𝑤ij + ∆𝑤ij
I suggest you do all this about 1,000 times (n=1:1:N, N=1000) and plot the error as a
function of n.
Practical considerations
If you implement all of this properly you will see that the error decreases as a function of n. You
should play with the learning rate, different initialisations of the weight matrices, different
numbers of iterations etc. However, you will find that whatever you do you cannot get the error
to reduce to zero. To do this I think you need to add bias units to the input and hidden layers.
Lab-Report Submission
Submit your source code and comments on experimental evaluations and results obtained.
References
[1] D. E. Rumelhart, G. E. Hinton, and R. J. Williams (1986), “Learning Internal Representations
by Error Propagation”, In: Rumelhart, D.E., McClelland, J.L. and the PDP Research Group, Eds.,
Parallel Distributed Processing: Explorations in the Microstructure of Cognition, Vol. 1:
Foundations, MIT Press, Cambridge, MA, 318-362.
版权所有:编程辅导网 2021 All Rights Reserved 联系方式:QQ:99515681 微信:codinghelp 电子信箱:99515681@qq.com
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。