24小时热门版块排行榜    

Znn3bq.jpeg
查看: 296  |  回复: 0
当前主题已经存档。

107288

铜虫 (小有名气)

[交流] 【求助】Matlab中bp 和 遗传算法问题

%  程序一:GA训练BP权值的主函数
function net=GABPNET(XX,YY)
%--------------------------------------------------------------------------
%  GABPNET.m
%  使用遗传算法对BP网络权值阈值进行优化,再用BP算法训练网络
%--------------------------------------------------------------------------
%数据归一化预处理
nntwarn off
p=[
80 12 8.0  1.05  0 3  ;
80 16 10.0  0.70  0 3  ;
90 8 8.0  0.70  0 3  ;
90 12 10.0  1.40  0 3  ;
90 16 6.0  1.05  0 3  ;
100 8 10.0  1.05  0 3  ;
100 12 6.0  0.70  0 3  ;
80 8 6.0  1.40  54 3  ;
80 12 8.0  1.05  54 3  ;
80 16 10.0  0.70  54 3  ;
90 12 10.0  1.40  54 3  ;
90 16 6.0  1.05  54 3  ;
100 12 6.0  0.70  54 3  ;
100 16 8.0  1.40  54 3  ;
80 8 6.0  1.40  0 0  ;
80 12 8.0  1.05  0 0  ;
80 16 10.0  0.70  0 0  ;
90 8 8.0  0.70  0 0  ;
100 8 10.0  1.05  0 0  ;
100 12 6.0  0.70  0 0  ;
100 16 8.0  1.40  0 0  ;
100 8 20.0  1.40  54 3  ;
100 8 12.5  1.40  54 3  ;
100 8 10.0  1.40  54 3  ;
100 8 6.0  1.40  54 3  ;
60 8 10.0  1.40  54 3  ;
70 8 10.0  1.40  54 3  ;
90 8 10.0  1.40  54 3  ;
100 8 10.0  1.40  54 3  ;
100 8 10.0  1.40  33 3  ;
100 8 10.0  1.40  40 3  ;
100 8 10.0  1.40  48 3  ;
100 8 10.0  1.40  54 3  ;
80 8 6.0  1.40  0 3  ;
100 16 8.0  1.40  0 3  ;
90 8 8.0  0.70  54 3  ;
100 8 10.0  1.05  54 3  ;
90 12 10.0  1.40  0 0  ;
90 16 6.0  1.05  0 0  ;
100 8 10.0  1.40  16 3  ;
100 8 8.0  1.40  54 3  ;
80 8 10.0  1.40  54 3  ;
]';
for  i=1:6
p(i,= (p(i,-mean(p(i,))/std(p(i,);
   end
p1=p(:,1:33);
p_test=p(:,34:42);
t1=[
0.2491  ;
0.3600  ;
0.4110  ;
0.2953  ;
0.4061  ;
0.4224  ;
0.3920  ;
0.4784  ;
0.6081  ;
0.5438  ;
0.5481  ;
0.6396  ;
0.6492  ;
0.7724  ;
0.0929  ;
0.1638  ;
0.2390  ;
0.1406  ;
0.3080  ;
0.2766  ;
0.4398  ;
0.9010  ;
0.8390  ;
0.7750  ;
0.5300  ;
0.4607  ;
0.5300  ;
0.6204  ;
0.7720  ;
0.5780  ;
0.6870  ;
0.7750  ;
0.7830  ;
]';
t_test=[
0.2672  ;
0.5967  ;
0.6204  ;
0.6779  ;
0.1627  ;
0.3047  ;
0.5000  ;
0.5779  ;
0.5881  ;
]';

%输入向量


%创建网络
net=newff(minmax(p1),[8,1],{'tansig','logsig'},'trainlm');
%下面使用遗传算法对网络进行优化
P=p1;
T=t1;
[R,Q]=size(P);
[S2,Q]=size(T);
S1=8;%隐含层节点数
S=R*S1+S1*S2+S1+S2; % 遗传算法编码长度
aa=ones(S,1)*[-1,1];
popu=50;%种群规模
initPop=initializega(popu,aa,'mygabpEval');%初始化种群
gen=100;%遗传代数
%下面调用gaot工具箱,其中目标函数定义为gabpEval
[x,endPop,bPop,trace]=ga(aa,'mygabpEval',[],initPop,[1e-6 1 1],'maxGenTerm',gen,...
  'normGeomSelect',[0.09],['arithXover'],[2],'nonUnifMutation',[2 gen 3]);

%绘收敛曲线图
figure(1)
plot(trace(:,1),1./trace(:,3),'r-');
hold on
plot(trace(:,1),1./trace(:,2),'b-');
xlabel('Generation');
ylabel('Sum-Squared Error');
figure(2)
plot(trace(:,1),trace(:,3),'r-');
hold on
plot(trace(:,1),trace(:,2),'b-');
xlabel('Generation');
ylabel('Fittness');
%下面将初步得到的权值矩阵赋给尚未开始训练的BP网络
[W1,B1,W2,B2,P,T,A1,A2,SE,val]=mygadecod(x);
net.LW{2,1}=W1;
net.LW{3,2}=W2;

%设置训练参数
net.trainParam.show=10;
net.trainParam.lr=0.06;
net.trainParam.epochs=500;
net.trainParam.goal=0.00000001;
%训练网络
% 程序二:适应值函数
function [sol, val] = mygabpEval(sol,options)
% val - the fittness of this individual
% sol - the individual, returned to allow for Lamarckian evolution
% options - [current_generation]
nntwarn off
p=[
80 12 8.0  1.05  0 3  ;
80 16 10.0  0.70  0 3  ;
90 8 8.0  0.70  0 3  ;
90 12 10.0  1.40  0 3  ;
90 16 6.0  1.05  0 3  ;
100 8 10.0  1.05  0 3  ;
100 12 6.0  0.70  0 3  ;
80 8 6.0  1.40  54 3  ;
80 12 8.0  1.05  54 3  ;
80 16 10.0  0.70  54 3  ;
90 12 10.0  1.40  54 3  ;
90 16 6.0  1.05  54 3  ;
100 12 6.0  0.70  54 3  ;
100 16 8.0  1.40  54 3  ;
80 8 6.0  1.40  0 0  ;
80 12 8.0  1.05  0 0  ;
80 16 10.0  0.70  0 0  ;
90 8 8.0  0.70  0 0  ;
100 8 10.0  1.05  0 0  ;
100 12 6.0  0.70  0 0  ;
100 16 8.0  1.40  0 0  ;
100 8 20.0  1.40  54 3  ;
100 8 12.5  1.40  54 3  ;
100 8 10.0  1.40  54 3  ;
100 8 6.0  1.40  54 3  ;
60 8 10.0  1.40  54 3  ;
70 8 10.0  1.40  54 3  ;
90 8 10.0  1.40  54 3  ;
100 8 10.0  1.40  54 3  ;
100 8 10.0  1.40  33 3  ;
100 8 10.0  1.40  40 3  ;
100 8 10.0  1.40  48 3  ;
100 8 10.0  1.40  54 3  ;
80 8 6.0  1.40  0 3  ;
100 16 8.0  1.40  0 3  ;
90 8 8.0  0.70  54 3  ;
100 8 10.0  1.05  54 3  ;
90 12 10.0  1.40  0 0  ;
90 16 6.0  1.05  0 0  ;
100 8 10.0  1.40  16 3  ;
100 8 8.0  1.40  54 3  ;
80 8 10.0  1.40  54 3  ;
]';
for  i=1:6
p(i,= (p(i,-mean(p(i,))/std(p(i,);
   end
p1=p(:,1:33);
p_test=p(:,34:42);
t1=[
0.2491  ;
0.3600  ;
0.4110  ;
0.2953  ;
0.4061  ;
0.4224  ;
0.3920  ;
0.4784  ;
0.6081  ;
0.5438  ;
0.5481  ;
0.6396  ;
0.6492  ;
0.7724  ;
0.0929  ;
0.1638  ;
0.2390  ;
0.1406  ;
0.3080  ;
0.2766  ;
0.4398  ;
0.9010  ;
0.8390  ;
0.7750  ;
0.5300  ;
0.4607  ;
0.5300  ;
0.6204  ;
0.7720  ;
0.5780  ;
0.6870  ;
0.7750  ;
0.7830  ;
]';
t_test=[
0.2672  ;
0.5967  ;
0.6204  ;
0.6779  ;
0.1627  ;
0.3047  ;
0.5000  ;
0.5779  ;
0.5881  ;
]';
P=p1;
T=t1;
[R,Q]=size(P);
[S2,Q]=size(T);
S1=8;%隐含层节点数
S=R*S1+S1*S2+S1+S2;%遗传算法编码长度
for i=1:S,
   x(i)=sol(i);
end;
[W1, B1, W2, B2, P, T, A1, A2, SE, val]=mygadecod(x);

% 程序三:编解码函数
function [W1, B1, W2, B2, P, T, A1, A2, SE, val]=mygadecod(x)
nntwarn off
p=[
80 12 8.0  1.05  0 3  ;
80 16 10.0  0.70  0 3  ;
90 8 8.0  0.70  0 3  ;
90 12 10.0  1.40  0 3  ;
90 16 6.0  1.05  0 3  ;
100 8 10.0  1.05  0 3  ;
100 12 6.0  0.70  0 3  ;
80 8 6.0  1.40  54 3  ;
80 12 8.0  1.05  54 3  ;
80 16 10.0  0.70  54 3  ;
90 12 10.0  1.40  54 3  ;
90 16 6.0  1.05  54 3  ;
100 12 6.0  0.70  54 3  ;
100 16 8.0  1.40  54 3  ;
80 8 6.0  1.40  0 0  ;
80 12 8.0  1.05  0 0  ;
80 16 10.0  0.70  0 0  ;
90 8 8.0  0.70  0 0  ;
100 8 10.0  1.05  0 0  ;
100 12 6.0  0.70  0 0  ;
100 16 8.0  1.40  0 0  ;
100 8 20.0  1.40  54 3  ;
100 8 12.5  1.40  54 3  ;
100 8 10.0  1.40  54 3  ;
100 8 6.0  1.40  54 3  ;
60 8 10.0  1.40  54 3  ;
70 8 10.0  1.40  54 3  ;
90 8 10.0  1.40  54 3  ;
100 8 10.0  1.40  54 3  ;
100 8 10.0  1.40  33 3  ;
100 8 10.0  1.40  40 3  ;
100 8 10.0  1.40  48 3  ;
100 8 10.0  1.40  54 3  ;
80 8 6.0  1.40  0 3  ;
100 16 8.0  1.40  0 3  ;
90 8 8.0  0.70  54 3  ;
100 8 10.0  1.05  54 3  ;
90 12 10.0  1.40  0 0  ;
90 16 6.0  1.05  0 0  ;
100 8 10.0  1.40  16 3  ;
100 8 8.0  1.40  54 3  ;
80 8 10.0  1.40  54 3  ;
]';
for  i=1:6
p(i,= (p(i,-mean(p(i,))/std(p(i,);
   end
p1=p(:,1:33);
p_test=p(:,34:42);
t1=[
0.2491  ;
0.3600  ;
0.4110  ;
0.2953  ;
0.4061  ;
0.4224  ;
0.3920  ;
0.4784  ;
0.6081  ;
0.5438  ;
0.5481  ;
0.6396  ;
0.6492  ;
0.7724  ;
0.0929  ;
0.1638  ;
0.2390  ;
0.1406  ;
0.3080  ;
0.2766  ;
0.4398  ;
0.9010  ;
0.8390  ;
0.7750  ;
0.5300  ;
0.4607  ;
0.5300  ;
0.6204  ;
0.7720  ;
0.5780  ;
0.6870  ;
0.7750  ;
0.7830  ;
]';
t_test=[
0.2672  ;
0.5967  ;
0.6204  ;
0.6779  ;
0.1627  ;
0.3047  ;
0.5000  ;
0.5779  ;
0.5881  ;
]';
P=p1;
T=t1;
[R,Q]=size(P);
[S2,Q]=size(T);
S1=8;%隐含层节点数
S=R*S1+S1*S2+S1+S2;%遗传算法编码长度
% 前R*S1个编码为W1
for i=1:S1,
    for k=1:R,
      W1(i,k)=x(R*(i-1)+k);
    end
end
% 接着的S1*S2个编码(即第R*S1个后的编码)为W2
for i=1:S2,
   for k=1:S1,
      W2(i,k)=x(S1*(i-1)+k+R*S1);
   end
end

% 接着的S1个编码(即第R*S1+S1*S2个后的编码)为B1
for i=1:S1,
   B1(i,1)=x((R*S1+S1*S2)+i);
end
% 接着的S2个编码(即第R*S1+S1*S2+S1个后的编码)为B2
for i=1:S2,
   B2(i,1)=x((R*S1+S1*S2+S1)+i);
end
% 计算S1与S2层的输出
A1=tansig(W1*P,B1);
A2=logsig(W2*A1,B2);
% 计算误差平方和
SE=sumsqr(T-A2);
val=1/SE; % 遗传算法的适应值

本人依照网上的一个程序,自己编写了一个,但是运行时老是出现Error using ==> network.subsasgn
net.LW{2,1} must be a 1-by-8 matrix.
Error in ==> GABPNET at 147
net.LW{2,1}=W1;

恳请各位高手指点一下,不胜感激。
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 107288 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[论文投稿] Sci. Bull. 悲剧经验 +4 jyang1999 2026-05-16 4/200 2026-05-19 10:56 by maolC
[基金申请] 评审有感 +10 popular289 2026-05-18 15/750 2026-05-19 09:18 by jurkat.1640
[考博] 26/27博士推荐 +4 1木头人13949 2026-05-13 4/200 2026-05-19 08:29 by zhyzzh
[硕博家园] 考博自荐 +5 科研狗111 2026-05-13 6/300 2026-05-18 11:22 by 糊糊涂涂好
[基金申请] 青C资助名额大幅增加! +12 西葫芦炒鸡蛋 2026-05-13 16/800 2026-05-18 10:02 by Equinoxhua
[找工作] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +4 ky2p12rrjj 2026-05-15 4/200 2026-05-17 19:47 by Equinoxhua
[考研] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +6 cjf4bx70cj 2026-05-14 7/350 2026-05-17 18:49 by Equinoxhua
[考博] 光量子物理方向 博士招生 1人(2026.09) +3 sandyworld 2026-05-15 4/200 2026-05-17 14:38 by sandyworld
[考研] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +4 v9tggjlwd0 2026-05-15 4/200 2026-05-17 08:11 by 11n4dfd8yn
[找工作] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +3 l7k6xnh0yc 2026-05-14 6/300 2026-05-17 07:31 by 11n4dfd8yn
[考研] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +4 l7k6xnh0yc 2026-05-14 8/400 2026-05-17 07:26 by 11n4dfd8yn
[考博] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +6 l7k6xnh0yc 2026-05-14 6/300 2026-05-17 07:11 by 11n4dfd8yn
[找工作] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +3 k37jurhrau 2026-05-16 3/150 2026-05-17 01:37 by ue3ir18jc3
[硕博家园] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +4 x0mp7owy2b 2026-05-15 4/200 2026-05-16 17:45 by j6b2pdz07o
[有机交流] 求有机合成大神指点三硫酸乙烯酯(CAS:2793408-99-6)的合成路线 30+3 Leekmid 2026-05-13 10/500 2026-05-16 16:37 by czyzsu
[硕博家园] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +3 k37jurhrau 2026-05-16 3/150 2026-05-16 13:57 by vcdazktkjx
[硕博家园] 申请博士 +3 呃?呃 2026-05-15 3/150 2026-05-16 11:01 by a4742549
[文学芳草园] 风把牡丹吹跑了 +5 myrtle 2026-05-12 9/450 2026-05-15 15:27 by myrtle
[考博] 26应届毕业生考博求助 +3 wo一定上岸 2026-05-13 3/150 2026-05-14 21:47 by 明海天涯
[考博] 材料类只有一篇综述能申博么 +4 乐逍遥谷 2026-05-13 4/200 2026-05-14 12:05 by zhyzzh
信息提示
请填处理意见