QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 10230|回复: 15
打印 上一主题 下一主题

在MATLAB中如何将神经网络和遗传算法联系起来

[复制链接]
字体大小: 正常 放大
trok_2005        

3

主题

2

听众

61

积分

升级  58.95%

该用户从未签到

新人进步奖

跳转到指定楼层
1#
发表于 2005-1-22 22:42 |只看该作者 |倒序浏览
|招呼Ta 关注Ta

我因科研需要刚开始接触MATLAB,发现确实如各位大侠所说是个好东西,目前我在处理一组实验数据,希望用神经网络对其进行训练,可以实现仿真,另外我还希望采用遗传算法寻优,如何将神经网络的输出转化成遗传算法需要适应度函数呢?请各位大侠多多指点,先这里谢过了。

zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
retin        

25

主题

5

听众

679

积分

升级  19.75%

该用户从未签到

新人进步奖

回复

使用道具 举报

ilikenba 实名认证       

1万

主题

49

听众

2万

积分

  • TA的每日心情
    奋斗
    2024-6-23 05:14
  • 签到天数: 1043 天

    [LV.10]以坛为家III

    社区QQ达人 新人进步奖 优秀斑竹奖 发帖功臣

    群组万里江山

    群组sas讨论小组

    群组长盛证券理财有限公司

    群组C 语言讨论组

    群组Matlab讨论组

    希望你能将如何用神经网络做的仿真说清楚,既然已经仿真成功了,那所说的寻优又是指的对什么寻优呀?神经网络又作了怎样的仿真?问题不清楚,这个很难回答!

    回复

    使用道具 举报

    trok_2005        

    3

    主题

    2

    听众

    61

    积分

    升级  58.95%

    该用户从未签到

    新人进步奖

    以下是引用ilikenba在2005-1-23 12:26:35的发言:2 H: D" n/ T) B, \4 `. m3 k 9 V- s8 }6 T# E2 t. y" R% p

    希望你能将如何用神经网络做的仿真说清楚,既然已经仿真成功了,那所说的寻优又是指的对什么寻优呀?神经网络又作了怎样的仿真?问题不清楚,这个很难回答!

    6 e. b5 ?. d3 h8 n& a' [# `

    谢谢您的关注,是这样,比如说我利用正交设计获得18组实验数据,我用BP神经网络建立了网络模型,我还希望能利用这个模型求解最优,即寻找合适的网络输入,以使网络输出值达到最大。但由于神经网络模型的建立是通过神经元间的连接权值和阈值来实现的,很难用简单的函数形式表达,因此我希望采用遗传算法来寻找最优的实验条件。但我不知道怎样将神经网络的输出转化为遗传算法所需要的适应度函数。 % }! r* S8 K9 I# T1 b! ~$ ?% y

    我是用NET=NEWFF(MINMAX(P),[20,1],{'TANSIG','PURELIN'},'TRAINLM');进行建立网络,用NET=TRAIN(NET,P,T)对网络进行训练,用ANEW=SIM(NET,P)对网络进行仿真。 * ] E; t: f2 Y

    不知我的问题说清楚了没有,希望您或其他大侠帮忙看一下,小妹这里谢过了!

    回复

    使用道具 举报

    ilikenba 实名认证       

    1万

    主题

    49

    听众

    2万

    积分

  • TA的每日心情
    奋斗
    2024-6-23 05:14
  • 签到天数: 1043 天

    [LV.10]以坛为家III

    社区QQ达人 新人进步奖 优秀斑竹奖 发帖功臣

    群组万里江山

    群组sas讨论小组

    群组长盛证券理财有限公司

    群组C 语言讨论组

    群组Matlab讨论组

    按照你的说法,你可以完全利用遗传算法寻优,并不一定要和神经网络结合的,这里只要找到一种合适的编码规则就行。对于遗传算法你完全可以随意地利用一种选择、交叉、变异规则,因为它是按照概率1收敛的,所以这些规则的选择好坏只影响收敛速度,我想你所说的适应度函数就是表示每个种群的概率密度函数吧!你完全可以按照网络输出值的数值大小计算每个种群所占的概率!
    回复

    使用道具 举报

    trok_2005        

    3

    主题

    2

    听众

    61

    积分

    升级  58.95%

    该用户从未签到

    新人进步奖

    谢谢 ilikenba 的回复,我是新手,不太明白,研究了半天,编了一点东西,可运行出了问题,帮忙看看是怎么回事,如何修改,谢谢!

    p=[ 40 21 2.5 6. 5 , _3 g% F& m' X. P/ {" @, v 40 25 3. 6.5 10 ' K1 l/ ^ Q* s 40 30 3.5 7. 20 8 G; S9 s; c$ M 45 21 2.5 6.5 10 * d4 C! W4 ^5 G" d 45 25 3. 7. 20 9 F& Y( S5 y) `3 K2 ~8 U 45 30 3.5 6. 5 5 v6 v* A5 d8 Q3 G7 ^- ^ 50 21 3. 6. 20 ) w, p% ~% }3 z5 C! ^" I6 [6 g 50 25 3.5 6.5 5 1 Q+ H0 x# z/ P+ h& W) e! }$ C6 r 50 30 2.5 7. 10 . s: J0 u U0 k" o 40 21 3.5 7. 10 + U1 P6 s9 j* _6 I ~ 40 25 2.5 6. 20 a, s; u; V% ?! H! g 40 30 3. 6.5 5 9 K2 ^9 ]3 @9 s& O. w 45 21 3. 7. 5 + H) C' d8 w# e 45 25 3.5 6. 10 6 h5 ?. x7 R% k 45 30 2.5 6.5 20 , Y0 C* O( g6 h; r 50 21 3.5 6.5 20 8 o, O: x* G# x0 @: ?+ y/ `* q# ?! a 50 25 2.5 7. 5 8 V) p2 t, c8 _, x 50 30 3. 6. 10];

    t=[2.673;3.412;1.315;2.019;1.996;0.885;9.317;4.484;1.768;5.720;2.316;0.678;1.042;1.492;0.765;8.812;1.204;3.130];1 d6 b% @7 z6 r9 v0 m T=t'; 1 O" Q/ f, _) ?4 h/ q& o8 s( ?P=p'; 1 l o4 d5 `7 s# Unet=newff(minmax(P),[12,1],{'tansig','purelin'},'trainlm'); j2 G( H$ ?! f# V%训练网络

    net.trainParam.show=10; ! g1 Y% ?3 a5 }%net.trainParam.lr=0.05; % y, _! k# B9 P o. }* j9 ?%net.trainParam.lr_inc=1.05; 5 ~( G a& I) h5 y9 \5 j' Gnet.trainParam.epochs=10000;6 |' B, T3 u; q6 T( Q net.trainParam.goal=1e-5; , c+ t! H; G& \0 e% randn('seed',192736547); 9 c* z* M( x1 U j, m. O% net=init(net);# A) ] W6 ?% ?: |3 g# a; r. I [net,tr]=train(net,P,T);; P" i2 i1 l2 w" f6 ^ r minmax_var=minmax(P); 8 A* r! j8 n# g( G( i9 [7 U/ A) Yminmax_target=minmax(T);3 m- |2 D$ j) _) o save('result','net','minmax_var','minmax_target');

    % 将网络输 转换成7 M4 ^. [# b+ p; _ % C) _3 t, q1 ^' B3 r load('result');% ~& _0 L- O0 A& q' J [Pnew,endPop,bestSols,trace]=ga(minmax(P),'fitness'); e8 y) z- W8 k7 _6 j e + }( B% M' K2 ?% X' v- t) y7 C. D: I %性能跟踪 ! D0 @5 ^+ [8 {. e6 [ plot(trace(:,1),trace(:,3),'y-'); c1 B& X$ l+ q5 p* l# ^ hold on 1 J! {. H) P/ m8 X plot(trace(:,1),trace(:,2),'r-'); & e( r0 q a" F6 l# X8 w xlabel('Generation'); 8 r/ ~1 r3 J. K9 o- o5 H# e1 Y ylabel('Fitness');# I! r2 X1 b/ |. y, A legend('change of solution','average change of population');* U/ Y3 C# w+ A N6 \; L' t1 t+ M TRAINLM, Epoch 0/10000, MSE 12.2801/1e-005, Gradient 1739.63/1e-010% G4 B4 Z5 `8 @- D+ y& h" s& @ TRAINLM, Epoch 10/10000, MSE 0.694955/1e-005, Gradient 93.6508/1e-010& I3 S! v; t+ s) q" O$ G+ Z TRAINLM, Epoch 20/10000, MSE 0.0242391/1e-005, Gradient 2.89095/1e-010 + v ~2 @ M5 W1 D, M5 MTRAINLM, Epoch 30/10000, MSE 0.0206875/1e-005, Gradient 4.2655/1e-010 : Z2 k( q: f; x: y7 b" X5 fTRAINLM, Epoch 40/10000, MSE 0.0185878/1e-005, Gradient 18.249/1e-010/ r( @# ?; l5 G* `8 E# e7 @, M TRAINLM, Epoch 50/10000, MSE 0.00947447/1e-005, Gradient 55.0854/1e-010, f. u+ n0 G& o. {+ ~- B$ d1 Q TRAINLM, Epoch 53/10000, MSE 1.24279e-006/1e-005, Gradient 0.504667/1e-010 . e1 z" b" f" y# @! }& k, O" `* FTRAINLM, Performance goal met.

    ??? Undefined function or variable 'minmax_target'.

    Error in ==> D:\MATLAB6p5p1\work\fitness.m / U$ i7 h5 M5 J) s; c+ yOn line 2 ==> min_target=minmax_target(1);

    Error in ==> D:\MATLAB6p5p1\work\initializega.m 3 d' m% @: o) [3 @5 z+ AOn line 41 ==> eval(estr);

    Error in ==> D:\MATLAB6p5p1\work\ga.m5 R* o* i+ F& s' H/ Z) n On line 148 ==> startPop=initializega(80,bounds,evalFN,evalOps,opts(1:2));& M! o/ }, _/ A 所使用的适应度函数是

    function [sol,eval]=fitness(P,options)7 u8 R# S0 H2 ~8 p% l t1 w min_target=minmax_target(1); 3 @% C/ ]: _$ W max_target=minmax_target(2);$ t3 A" Z# @: C# J eval=sim(net,P) + p9 C* v' b. l( \3 \. Y2 E3 _: L+ v if isformax 6 S6 [- A9 ^7 F: o0 } eval=eval-min_target+(max_target-min_target);' I# t; t. `. s8 R; C; ^ else/ W2 ~. q% H) r$ R ^9 m6 t eval=-eval+max_target+(max_target-min_target);) B9 d8 F5 N* S end

    回复

    使用道具 举报

    cdqxc        

    0

    主题

    0

    听众

    4

    积分

    升级  80%

    该用户从未签到

    回复

    使用道具 举报

    lzh0601        

    2

    主题

    3

    听众

    89

    积分

    升级  88.42%

    该用户从未签到

    回复

    使用道具 举报

    dsh1001        

    0

    主题

    1

    听众

    2

    积分

    升级  40%

    该用户从未签到

    我也是你这种问题,就是通过实验获得数据,然后建立模型进行训练、仿真和预测,这些都可以4 \2 B7 V! U6 a, C( ?
    就是最后如何实现参数的优化,就是给定了输出如何确定最优的输入5 @( ]" y$ U( A" x# z7 s
    好像是用模拟退火算法之类的可以实现,目前还没有解决,期待你解决以后多交流
    回复

    使用道具 举报

    0

    主题

    4

    听众

    5

    积分

    升级  0%

    该用户从未签到

    新人进步奖

    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-4-13 21:33 , Processed in 0.537526 second(s), 106 queries .

    回顶部