MATLAB基于BP神經(jīng)網(wǎng)絡(luò)PID控制程序_第1頁
MATLAB基于BP神經(jīng)網(wǎng)絡(luò)PID控制程序_第2頁
MATLAB基于BP神經(jīng)網(wǎng)絡(luò)PID控制程序_第3頁
MATLAB基于BP神經(jīng)網(wǎng)絡(luò)PID控制程序_第4頁
免費預(yù)覽已結(jié)束,剩余1頁可下載查看

下載本文檔

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

文檔簡介

1、.MATLAB基于BP神經(jīng)網(wǎng)絡(luò)PID控制程序 %BP based PID Control clear all; close all; xite=0.20; %學(xué)習(xí)速率alfa=0.01; %慣性因子IN=4;H=5;Out=3; %NN Structure wi=-0.6394 -0.2696 -0.3756 -0.7023; -0.8603 -0.2013 -0.5024 -0.2596; -1.0749 0.5543 -1.6820 -0.5437; -0.3625 -0.0724 -0.6463 -0.2859; 0.1425 0.0279 -0.5406 -0.7660; %wi=0.

2、50*rands(H,IN); %隱含層加權(quán)系數(shù)wi初始化wi_1=wi;wi_2=wi;wi_3=wi; wo=0.7576 0.2616 0.5820 -0.1416 -0.1325; -0.1146 0.2949 0.8352 0.2205 0.4508; 0.7201 0.4566 0.7672 0.4962 0.3632; %wo=0.50*rands(Out,H); %輸出層加權(quán)系數(shù)wo初始化wo_1=wo;wo_2=wo;wo_3=wo; ts=20; %采樣周期取值x=0,0,0; %比例,積分,微分賦初值u_1=0;u_2=0;u_3=0;u_4=0;u_5=0; y_1=0

3、;y_2=0;y_3=0; Oh=zeros(H,1); %Output from NN middle layer 隱含層的輸出I=Oh; %Input to NN middle layer 隱含層輸入error_2=0; error_1=0; for k=1:1:500 %仿真開始,共500步time(k)=k*ts; rin(k)=1.0; %Delay plantsys=tf(1.2,208 1,inputdelay,80); %建立被控對象傳遞函數(shù)?dsys=c2d(sys,ts,zoh); %把傳遞函數(shù)離散化?num,den=tfdata(dsys,v); %離散化后提取分子、分母y

4、out(k)=-den(2)*y_1+num(2)*u_5;error(k)=rin(k)-yout(k); xi=rin(k),yout(k),error(k),1; %經(jīng)典增量式數(shù)字PID的控制算式為: BP神經(jīng)網(wǎng)絡(luò)PID的控制算式為:x(1)=error(k)-error_1; %比例輸出x(2)=error(k); %積分輸出x(3)=error(k)-2*error_1+error_2; %微分輸出epid=x(1);x(2);x(3); I=xi*wi;% 隱含層的輸入,即:輸入層輸入*權(quán)值for j=1:1:H Oh(j)=(exp(I(j)-exp(-I(j)/(exp(I(j

5、)+exp(-I(j); %Middle Layer在激活函數(shù)作用下隱含層的輸出end K=wo*Oh; %Output Layer 輸出層的輸入,即:隱含層的輸出*權(quán)值for l=1:1:Out K(l)=exp(K(l)/(exp(K(l)+exp(-K(l); %Getting kp,ki,kd 輸出層的輸出,即三個pid控制器的參數(shù)end kp(k)=K(1);ki(k)=K(2);kd(k)=K(3); Kpid=kp(k),ki(k),kd(k); du(k)=Kpid*epid; u(k)=u_1+du(k); if u(k)=10 % Restricting the outpu

6、t of controller 控制器飽和環(huán)節(jié)u(k)=10; end if u(k)=-10 u(k)=-10; end %以下為權(quán)值wi、wo的在線調(diào)整,參考劉金琨的先進PID控制dyu(k)=sign(yout(k)-y_1)/(u(k)-u_1+0.0000001); %Output layer 輸出層for j=1:1:Out dK(j)=2/(exp(K(j)+exp(-K(j)2; end for l=1:1:Out delta3(l)=error(k)*dyu(k)*epid(l)*dK(l); end for l=1:1:Out for i=1:1:H d_wo=xite*d

7、elta3(l)*Oh(i)+alfa*(wo_1-wo_2); end end wo=wo_1+d_wo+alfa*(wo_1-wo_2); %Hidden layer for i=1:1:H dO(i)=4/(exp(I(i)+exp(-I(i)2; end segma=delta3*wo; for i=1:1:H delta2(i)=dO(i)*segma(i); end d_wi=xite*delta2*xi; wi=wi_1+d_wi+alfa*(wi_1-wi_2); %Parameters Update 參數(shù)更新u_5=u_4;u_4=u_3;u_3=u_2;u_2=u_1;u_

8、1=u(k); y_2=y_1;y_1=yout(k); wo_3=wo_2; wo_2=wo_1; wo_1=wo; wi_3=wi_2; wi_2=wi_1; wi_1=wi; error_2=error_1; error_1=error(k); end %仿真結(jié)束,繪圖figure(1); plot(time,rin,r,time,yout,b); xlabel(time(s);ylabel(rin,yout); figure(2); plot(time,error,r); xlabel(time(s);ylabel(error); figure(3); plot(time,u,r); xlabel(time(s);ylabel(u); figure(4); subplot(311); plot(time,kp,r); xlabel(time(s

溫馨提示

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

評論

0/150

提交評論