- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
遗传算法优化的BP神经网络建模
遗传算法优化的BP神经网络建模十一月匆匆过去,每天依然在忙碌着与文档相关的东西,在寒假前一个多月里,努力做好手头上的事的前提下多学习专业知识,依然是坚持学习与素质提高并重,依然是坚持锻炼身体,为明年找工作打下基础。?遗传算法优化的BP神经网络建模借鉴别人的程序做出的仿真,最近才有时间整理。目标:?对y=x1^2+x2^2非线性系统进行建模,用1500组数据对网络进行构建网络,500组数据测试网络。由于BP神经网络初始神经元之间的权值和阈值一般随机选择,因此容易陷入局部最小值。本方法使用遗传算法优化初始神经元之间的权值和阈值,并对比使用遗传算法前后的效果。步骤:未经遗传算法优化的BP神经网络建模1、?随机生成2000组两维随机数(x1,x2),并计算对应的输出y=x1^2+x2^2,前1500组数据作为训练数据input_train,后500组数据作为测试数据input_test。并将数据存储在data中待遗传算法中使用相同的数据。2、?数据预处理:归一化处理。3、?构建BP神经网络的隐层数,次数,步长,目标。4、?使用训练数据input_train训练BP神经网络net。5、?用测试数据input_test测试神经网络,并将预测的数据反归一化处理。6、?分析预测数据与期望数据之间的误差。遗传算法优化的BP神经网络建模1、?读取前面步骤中保存的数据data;2、?对数据进行归一化处理;3、?设置隐层数目;4、?初始化进化次数,种群规模,交叉概率,变异概率5、?对种群进行实数编码,并将预测数据与期望数据之间的误差作为适应度函数;6、?循环进行选择、交叉、变异、计算适应度操作,直到达到进化次数,得到最优的初始权值和阈值;7、?将得到最佳初始权值和阈值来构建BP神经网络;8、?使用训练数据input_train训练BP神经网络net;9、?用测试数据input_test测试神经网络,并将预测的数据反归一化处理;10、?分析预测数据与期望数据之间的误差。算法流程图如下:运行后使用遗传算法改进前后误差的对比图:程序:1、未经遗传算法优化的BP神经网络建模clear;clc;%%%%%%%%%%%%%输入参数%%%%%%%%%%%%%%N=2000;????????????%数据总个数M=1500;????????????%训练数据%%%%%%%%%%%%%训练数据%%%%%%%%%%%%%%for i=1:N?input(i,1)=-5+rand*10;?input(i,2)=-5+rand*10;endoutput=input(:,1).^2+input(:,2).^2;save data input output?load data.mat?%从1到N随机排序k=rand(1,N);[m,n]=sort(k);%找出训练数据和预测数据input_train=input(n(1:M),:);output_train=output(n(1:M),:);input_test=input(n((M+1):N),:);output_test=output(n((M+1):N),:);%数据归一化[inputn,inputs]=mapminmax(input_train);[outputn,outputs]=mapminmax(output_train);%构建BP神经网络net=newff(inputn,outputn,5);net.trainParam.epochs=100;net.trainParam.lr=0.1;net.trainParam.goal=0.0000004;%BP神经网络训练net=train(net,inputn,outputn);%测试样本归一化inputn_test=mapminmax(apply,input_test,inputs);%BP神经网络预测an=sim(net,inputn_test);%%网络得到数据反归一化BPoutput=mapminmax(reverse,an,outputs);?figure(1)%plot(BPoutput,:og);scatter(1:(N-M),BPoutput,rx);hold on;%plot(output_test,-*);scatter(1:(N-M),output_test,o);legend(预测输出,期望输出,fontsize,12);title(BP网络预测输出,fontsize,12);xlabel(样本,fontsize,12);xlabel(优化前输出的误差,fontsize,12);?figure(2)error=BPoutput-output_test;plot(1:(N-M),error);xlabel(样本,fontsize,12);ylab
文档评论(0)