分类: C/C++
2008-08-05 13:56:38
3.2 算法描述
(1)学习
设输入层为n个输入,隐层是m个输入,输出层是p个输出
1.初始化V,W,α,ε //给V,W赋初值,这里用随机值,有经验的话可以给V和W
//赋一个近似的初值,这样的话可以加快收敛速度。
// 是学习因子,可以根据学习的进度来动态改变,这里自始
//至终取0.7, 是精度系数,
2.循环学习直到误差小于精度
e=(I,T) //对每一个样本取样放到集合e中 ,I代表输入样本,T代表输出样板
求a[j]=g(in[j])=g(//求隐层的值,其中V是各个权值的向量,
//I是样板值
o[i]=g(in[i])=g(//求输出层的值,其中W是各个隐层输入的
//权值,a[j]是输入的隐层的值
Err[i]=T[i]-O[i] (1<=i<=p) //Err是误差值 求 Δ[i]=Err[i]*g`(in[i]) (1<=i<=p) //g`(in[i])是g(in[i])函数的求导 W[j,i]=W[j,i] *a[j]*Err[i]*g`(in[i]) //权值调整,即训练学习, 是学习因子,用 //来反映学习的频率,可以自己根据程序需要来定
这里遇到一个难题是隐层的误差值怎么求,因为输出层有准确的输出值作参考,所以能够求到误差值,但是隐层没有相应的准确值。我们可以观察输出层的误差值,这个值其实蕴涵了隐层的误差值所在,经过证明可以用下面公式获取误差值。
Err[j]= //Err(1<=j<=P)是输出层的误差,这里 //利用这个误差蕴涵的信息来获取隐 //层的误差 V[k,j]=V[k,j] *I[k]*Err[j]*g`(in[j]) //隐层权值修正
3.返回V,W,学习完成
可能有些人不明白函数g(x)是如何选取,根据我们识别的特性来看,我们应该选择,S型函数(关于函数的类型请参阅其他书籍),考虑函数的导数在内,应该选择一个比较好导的函数。所以我们选择。
y=f(A)=1/(1 Exp(-A)) y`=f`(A)=y(1-y)
(2)实现识别
1.获取输入层的各个值 a
a[j]=g(in[j])=g(
把P改成m //求隐层的值,其中V是各个权值
//的向量,
o[i]=g(in[i])=g(
//求输出层的值,其中W是各个隐层输入的
Err[i]=(T[i]-O[i])2 /2 // 为精度,如果全局误差都小于精度就//证明输出的矩阵O是合法的。
//
ε为精度,如果全局误差都小于精度就//证明输出的矩阵O是合法的。
3.3算法实现
设输入层为n个输入,隐层是m个输入,输出层是p个输出。
*这里是一次训练的算法,程序可以根据自己需要实现。
INPUT W,V,P,A //输入权值W,V,精度P,和学习系数A INPUT i[1],...,i[n],t[1],...,t[p] //输入和输出样板集 Step 1 Set v_sum=0. //设定累加器 Step 2 Set in_i[m],in_j[p] Step 3 For j=1,...,m do Step 4 and Step 5,Step 7 Step 4 Set in_j[j]=0; //初始化 Step 5 For k=1,...,n do Step6 and Step7 Step 6 Set in_j[j]=a[j] (v[k,j]*i[k]); Step 7 Set a[j]=1/(1-Exp(-in_j[j])); Step 8 For i=1,...,p do Step9 and Step 10,Step 12 Step 9 Set in_i[i]=0; Step 10 For j=1,...,m do Step 11 Step 11 Set in_i[i]=in_i[i] (w[j,i]*a[j]) Step 12 Set o[i]=1/(1-Exp(-in_i[i]); Step 13 For i=1,...,p do Step 14 Step 14 Set Err[i]=t[i]-o[i] //误差 Step 15 For j=1,...,m do Step 16 Step 16 For i=1,...,p do Step 17 Step 17 Set w[j,i]=w[j,i] A*a[j]*Err[i]* 1/(1-Exp(-in_j[j]))(1-1/(1-Exp(-in_j[j])));//输出层权 //值修正 Step 18 For k=1,...,n do Step 19 Step 19 For j=1,...,m do Step 20 Step 20 Set v[k,j]=v[k,j]*A*i[k]*Err[j]* 1/(1-Exp(-in_j[j]))(1-1/(1-Exp(-in_j[j])));//隐层权值 //修正 Step 21 OUTPUT (Err[1],...,Err[p]) STOP重复训练过程来对准确权值的收敛,识别过程是学习过程的一部分,所以这里不再重复