登 录
註 冊
论坛
微波仿真网
注册
登录论坛可查看更多信息
微波仿真论坛
>
程序
>
遗传算法优化BP神经网络权值和阈值的通用MAT ..
发帖
回复
3889
阅读
0
回复
[
资料共享
]
遗传算法优化BP神经网络权值和阈值的通用MATLAB源码
离线
greensim
UID :63869
注册:
2010-07-25
登录:
2011-09-15
发帖:
10
等级:
仿真新人
0楼
发表于: 2011-08-29 16:08:02
题目:遗传算法优化BP神经网络权值和阈值的通用MATLAB源码
SG@E*yT1
遗传算法优化神经网络有两种情况,一种是把训练好的神经网络作为黑箱函数,用遗传算法搜索该黑箱函数的最大值,另外一种情况,则是把遗传算法用于神经网络的训练,充分利用遗传算法全局搜索的特性,得到一个初始的权值矩阵和初始的阈值向量,再用其它训练算法(如BP算法),得到最终的神经网络结构。经过GreenSim团队大量实践表明,这种GA和BP网络相结合的方法,能显著地提高BP神经网络的性能,基本上和支持向量机的性能相当,有时甚至优于支持向量机。由于BP网络的权值优化是一个无约束优化问题,而且权值要采用实数编码,所以直接利用Matlab遗传算法工具箱。以下贴出的代码是为一个19输入变量,1个输出变量情况下的非线性回归而设计的,如果要应用于其它情况,只需改动编解码函数即可。此文章首次发表是在simwe论坛,属于GreenSim团队原创作品,转载请注明,有意购买源码或代写相关程序,请与GreenSim团队联系,QQ:761222791
Ake$M^Bz
图片:010附图1.jpg
miUjpXt
程序一:GA训练BP权值的主函数
P`L, eYc
function net=GABPNET(XX,YY)
K3^2;j1F Q
%--------------------------------------------------------------------------
LEd@""h
% GABPNET.m
Gp0yRT.
% 使用遗传算法对BP网络权值阈值进行优化,再用BP算法训练网络
zP8rW5/
% GreenSim团队原创作品,转载请注明
ja&S^B^@
% Email:greensim@163.com
/5Tp)h|
QQ:761222791
PiJ>gDx
%--------------------------------------------------------------------------
\C kb:
%数据归一化预处理
VmON}bb[zz
nntwarn off
Z8I0v$LjR
XX=premnmx(XX);
E?(:9#02
YY=premnmx(YY);
E_H.!pr
%创建网络
3of0f{ZTj
net=newff(minmax(XX),[19,25,1],{'tansig','tansig','purelin'},'trainlm');
, Y^GQ`~#
%下面使用遗传算法对网络进行优化
LMRq.wxbbB
P=XX;
PUEEfq!%
T=YY;
J'C%
R=size(P,1);
;m~%57.;\
S2=size(T,1);
s x2\
S1=25;%隐含层节点数
+[":W?j
aa=ones(S,1)*[-1,1];
7|DPevrk
popu=50;%种群规模
glomwny
initPpp=initializega(popu,aa,'gabpEval');%初始化种群
:Izdj*HL;A
gen=100;%遗传代数
h\/T b8
%下面调用gaot工具箱,其中目标函数定义为gabpEval
`s8!zy+
[x,endPop,bPop,trace]=ga(aa,'gabpEval',[],initPpp,[1e-6 1 1],'maxGenTerm',gen,...
vAqVs5 j
'normGeomSelect',[0.09],['arithXover'],[2],'nonUnifMutation',[2 gen 3]);
6&KcO:}-
%绘收敛曲线图
'3]M1EP
figure(1)
k;f%OQsF_
plot(trace(:,1),1./trace(:,3),'r-');
cH`ziZ<&m1
hold on
c,Yd#nokC
plot(trace(:,1),1./trace(:,2),'b-');
jm0v=m7
xlabel('Generation');
|$D`*
ylabel('Sum-Squared Error');
&~"e["gF=
figure(2)
jJ3dZ<#
plot(trace(:,1),trace(:,3),'r-');
_i2guhRs*Q
hold on
}K|40oO5
plot(trace(:,1),trace(:,2),'b-');
o)+Uyl
xlabel('Generation');
W3A9uk6
ylabel('Fittness');
Rg7~?b-
%下面将初步得到的权值矩阵赋给尚未开始训练的BP网络
\<%?=C'w~
[W1,B1,W2,B2,P,T,A1,A2,SE,val]=gadecod(x);
s:*" b'
net.LW{2,1}=W1;
%b>Ee>rdD
net.b{2,1}=B1;
lbm ,#
net.b{3,1}=B2;
j4+kL4M@H
XX=P;
O^r,H,3S
YY=T;
!Q=xIS
%设置训练参数
?sclOOh
net.trainParam.show=1;
64l(ru<
net.trainParam.lr=1;
#\&64
net.trainParam.epochs=50;
4||dc}I"E
net.trainParam.goal=0.001;
K?6#jT6#
%训练网络
Qq<+QL |
net=train(net,XX,YY);
cIg+^Tl
程序二:适应值函数
w">-r}HnJ
function [sol, val] = gabpEval(sol,options)
v4VP7h6uD)
% val - the fittness of this individual
QBLha']'%
% sol - the individual, returned to allow for Lamarckian evolution
"f4atuuXa
% options - [current_generation]
&6^QFqqW`-
load data2
PDhoCAh !
nntwarn off
1? Im"
XX=premnmx(XX);
"p"~fN /I9
YY=premnmx(YY);
B8NMo5a
P=XX;
j'q Iq;y
T=YY;
dCO)"]
R=size(P,1);
sW0<f&3
S2=size(T,1);
;mSJZYnT
S1=25;%隐含层节点数
L)3JTNiB
S=R*S1+S1*S2+S1+S2;%遗传算法编码长度
HB9|AQ4K
for i=1:S,
L~HL*~#d
x(i)=sol(i);
Qn`Fq,uvL
end;
Yl"l|2 :
[W1, B1, W2, B2, P, T, A1, A2, SE, val]=gadecod(x);
frUO+
图片:010附图2.jpg
TSUT3'&~p
程序三:编解码函数
c3C<P
function [W1, B1, W2, B2, P, T, A1, A2, SE, val]=gadecod(x)
MXrh[QCU)
load data2
n0opb [ ?
nntwarn off
0l2@3}e
YY=premnmx(YY);
%Iv*u sXP
P=XX;
/yFs$t>9
T=YY;
BL H~`N3U
R=size(P,1);
wD5fm5r=
S2=size(T,1);
,7ZV;f81
S1=25;%隐含层节点数
M6H#Y2!ZbC
S=R*S1+S1*S2+S1+S2;%遗传算法编码长度
lR0WDJv
% 前R*S1个编码为W1
CQ:38l\`gd
for i=1:S1,
>_SqM! ^v
for k=1:R,
TgvBy
W1(i,k)=x(R*(i-1)+k);
Kd;)E 9Ti
end
zA*I=3E(
end
e<r}{=1w
% 接着的S1*S2个编码(即第R*S1个后的编码)为W2
tlcNGPa
for i=1:S2,
Qb?eA
for k=1:S1,
ev9ltl{
W2(i,k)=x(S1*(i-1)+k+R*S1);
@<C<rB8R
end
M7\yEi"*
end
j S<."a/n
% 接着的S1个编码(即第R*S1+S1*S2个后的编码)为B1
Q$8K-5U%
for i=1: ..
HD153M,
OpFm:j3
未注册仅能浏览
部分内容
,查看
全部内容及附件
请先
登录
或
注册
共
条评分
发帖
回复