GA-BP神經(jīng)網(wǎng)絡(luò)應(yīng)用實(shí)例之MATLAB程序_第1頁(yè)
GA-BP神經(jīng)網(wǎng)絡(luò)應(yīng)用實(shí)例之MATLAB程序_第2頁(yè)
GA-BP神經(jīng)網(wǎng)絡(luò)應(yīng)用實(shí)例之MATLAB程序_第3頁(yè)
GA-BP神經(jīng)網(wǎng)絡(luò)應(yīng)用實(shí)例之MATLAB程序_第4頁(yè)
GA-BP神經(jīng)網(wǎng)絡(luò)應(yīng)用實(shí)例之MATLAB程序_第5頁(yè)
已閱讀5頁(yè),還剩6頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

GA-BP神經(jīng)網(wǎng)絡(luò)應(yīng)用實(shí)例之MATLAB程序%gap.xls中存儲(chǔ)訓(xùn)練樣本的原始輸入數(shù)據(jù)37組%gat.xls中存儲(chǔ)訓(xùn)練樣本的原始輸出數(shù)據(jù)37組%p_test.xls中存儲(chǔ)測(cè)試樣本的原始輸入數(shù)據(jù)12組%t_test.xls中存儲(chǔ)測(cè)試樣本的原始輸出數(shù)據(jù)12組%其中g(shù)abpEval.m適應(yīng)度值計(jì)算函數(shù),gadecod.m解碼函數(shù)%--------------------------------------------------------------------------nntwarnoff;%nntwarn函數(shù)可以臨時(shí)關(guān)閉神經(jīng)網(wǎng)絡(luò)工具箱的警告功能,當(dāng)代碼使用到神經(jīng)%網(wǎng)絡(luò)工具箱的函數(shù)時(shí)會(huì)產(chǎn)生大量的警告而這個(gè)函數(shù)可以跳過(guò)這些警告但%是,為了保證代碼可以在新版本的工具箱下運(yùn)行,我們不鼓勵(lì)這么做pc=xlsread('gap.xls');tc=xlsread('gat.xls');p_test=xlsread('p_test.xls');t_test=xlsread('t_test.xls');p=pc';t=tc';p_test=p_test';t_test=t_test';%歸一化處理fori=1:2P(i,:)=(p(i,:)-min(p(i,:)))/(max(p(i,:))-min(p(i,:)));endfori=1:4T(i,:)=(t(i,:)-min(t(i,:)))/(max(t(i,:))-min(t(i,:)));endfori=1:2P_test(i,:)=(p_test(i,:)-min(p_test(i,:)))/(max(p_test(i,:))-min(p_test(i,:)));end%--------------------------------------------------------------------------%創(chuàng)建BP神經(jīng)網(wǎng)絡(luò),隱含層節(jié)點(diǎn)數(shù)為12net=newff(minmax(P),[12,4],{'tansig','purelin'},'trainlm');%--------------------------------------------------------------------------%下面使用遺傳算法對(duì)網(wǎng)絡(luò)進(jìn)行優(yōu)化R=size(P,1);%BP神經(jīng)網(wǎng)絡(luò)輸入層節(jié)點(diǎn)數(shù)S2=size(T,1);%BP神經(jīng)網(wǎng)絡(luò)輸出層節(jié)點(diǎn)數(shù)S1=12;%隱含層節(jié)點(diǎn)數(shù)S=R*S1+S1*S2+S1+S2;%遺傳算法編碼長(zhǎng)度aa=ones(S,1)*[-1,1];popu=100;%種群規(guī)模initPop=initializega(popu,aa,'gabpEval');%初始化種群gen=500;%遺傳代數(shù)%下面調(diào)用gaot工具箱,其中目標(biāo)函數(shù)定義為gabpEval[x,endPop,bPop,trace]=ga(aa,'gabpEval',[],initPop,[1e-611],'maxGenTerm',...gen,'normGeomSelect',[0.09],['arithXover'],[2],'nonUnifMutation',[2gen3]);%--------------------------------------------------------------------------%繪收斂曲線圖figure;plot(trace(:,1),1./trace(:,3),'r-');holdon;plot(trace(:,1),1./trace(:,2),'b-');xlabel('遺傳代數(shù)');ylabel('平方和誤差');figure;plot(trace(:,1),trace(:,3),'r-');holdon;plot(trace(:,1),trace(:,2),'b-');xlabel('遺傳代數(shù)');ylabel('適應(yīng)度');legend('平均適應(yīng)度值','最優(yōu)適應(yīng)度值');%--------------------------------------------------------------------------%下面將初步得到的權(quán)值矩陣賦給尚未開(kāi)始訓(xùn)練的BP網(wǎng)絡(luò)[W1,B1,W2,B2,P,T,A1,A2,SE,val]=gadecod(x);net.IW{1,1}=W1;net.LW{2,1}=W2;net.b{1}=B1;net.b{2}=B2;%設(shè)置訓(xùn)練參數(shù)net.trainParam.epochs=3000;net.trainParam.goal=1e-6;%訓(xùn)練網(wǎng)絡(luò)net=train(net,P,T);w1=net.IW{1,1};w2=net.LW{2,1};b1=net.b{1};b2=net.b{2};%測(cè)試網(wǎng)絡(luò)性能temp=sim(net,P_test);yuce1=[temp(1,:);temp(2,:),;temp(3,:);temp(4,:)];fori=1:4yuce(i,:)=yuce1(i,:)*(max(t_test(i,:))-min(t_test(i,:)))+min(t_test(i,:));end%--------------------------------------------------------------------------%測(cè)試輸出結(jié)果之一figure;plot(1:12,yuce(1,:),'bo-');ylabel('切口外徑mm');holdon;plot(1:12,t_test(1,:),'r*-');legend('測(cè)試結(jié)果','測(cè)試樣本');figure;plot(1:12,yuce(1,:)-t_test(1,:),'b-');ylabel('誤差mm');title('測(cè)試結(jié)果與測(cè)試樣本誤差');figure;plot(1:12,((yuce(1,:)-t_test(1,:))/t_test(1,:))*100,'b*');ylabel('百分比');title('測(cè)試結(jié)果與測(cè)試樣本誤差');%測(cè)試輸出結(jié)果之二figure;plot(1:12,yuce(2,:),'bo-');ylabel('切口內(nèi)徑mm');holdon;plot(1:12,t_test(2,:),'r*-');legend('測(cè)試結(jié)果','測(cè)試樣本');figure;plot(1:12,yuce(2,:)-t_test(2,:),'b-');ylabel('誤差mm');title('測(cè)試結(jié)果與測(cè)試樣本誤差');figure;plot(1:12,((yuce(2,:)-t_test(2,:))/t_test(2,:))*100,'b*');ylabel('百分比');title('測(cè)試結(jié)果與測(cè)試樣本誤差');%測(cè)試輸出結(jié)果之三figure;plot(1:12,yuce(3,:),'bo-');ylabel('最大滾切力N');holdon;plot(1:12,t_test(3,:),'r*-');legend('測(cè)試結(jié)果','測(cè)試樣本');figure;plot(1:12,yuce(3,:)-t_test(3,:),'b-');ylabel('誤差N');title('測(cè)試結(jié)果與測(cè)試樣本誤差');figure;plot(1:12,((yuce(3,:)-t_test(3,:))/t_test(3,:))*100,'b*');ylabel('百分比');title('測(cè)試結(jié)果與測(cè)試樣本誤差');%測(cè)試輸出結(jié)果之四figure;plot(1:12,yuce(4,:),'bo-');ylabel('切斷時(shí)間s');holdon;plot(1:12,t_test(4,:),'r*-');legend('測(cè)試結(jié)果','測(cè)試樣本');figure;plot(1:12,yuce(4,:)-t_test(4,:),'b-');ylabel('誤差s');title('測(cè)試結(jié)果與測(cè)試樣本誤差

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論