利用matlab實現(xiàn)H-infinity魯棒控制_第1頁
利用matlab實現(xiàn)H-infinity魯棒控制_第2頁
已閱讀5頁,還剩14頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、利用Matlab實現(xiàn)H8控制Prof.Dr.-Ing.F.AllgwerInstituteforSystemsTheoryandAutomaticControlhttp:/www.ist.uni-stuttgart.de/education/courses/robust1引言控制器設計原理容易理解,難點在于編程。這里簡單介紹Matlab里面幾個相關函數(shù)的用法,希望能幫助你設計第一個控制器。Matlab提供了很多設計函數(shù),與設計相關的幾個重要的工具箱有:ControlSystemToolbox,mu-AnalysisandSynthesisToolbox(mu-tools),RobustCont

2、rolToolbox(RCT)和LMIControlToolbox。Matlab7.0之后的版本中,LMI和mu-tools都包含在RCTv3.0.1中,Matlab7.0之前的版本中這些工具箱是獨立的。本文中用到的函數(shù)都寫在了一個m文件中(見附錄),也可以從網(wǎng)站下載。利用混合S/KS問題說明相關函數(shù)的用法。首先回顧這個問題。2回路成形傳遞函數(shù)混合S/KS問題可用圖1來說明。wI<sKS從w到Z的閉環(huán)傳遞函數(shù)=可以表示為廣義過程模型P(s)(見圖2)可以表示為原文:ControlinMatlab.2011/12/8譯假設上面幾個狀態(tài)空間變量具有如下的形式:于是可以得到P(s)的一個可能的

3、狀態(tài)空間實現(xiàn)形式:比0-BSCBs-BSD0Aks00ks00A0B0-DSCDs-DSD0Cks00D曉00-CI-Dws和wks為調整參數(shù)。一種選擇方法為:拆/'Z+TTr丄;=;=const,s+其中Avl為允許的最大穩(wěn)態(tài)誤差,為期望帶寬,M為靈敏度峰值(一般情況下A=0.01,M=2)。從控制器設計的方面來說,“t的倒數(shù)為回路成形期望靈敏度的上限,'二影響控制器的輸出u。有些情況下希望對補靈敏度函數(shù)丁=GI'(I+GI')1進行回路成形設計(在圖1中增加一個輸出3=丁)。一種選擇方法為:Wt=s+/M乂4s+此函數(shù)與'涵數(shù)成山=",軸對

4、稱,見圖3所示。圖中參數(shù)設置為A=0.01(=-40dB),M=2(=6dB),5=1iad/tie<?.-4-JD2410101D101DFrequencyrad/secFigure3:InverseofweightingfunctionsWsandWt3子系統(tǒng)的實現(xiàn)在Matlab中有幾種方式得到G,WS和W。例如ControlSystemToolbox提SKS供的ss,tf和zpk等函數(shù)。Mu-tools也提供了諸如pck,nd2sys,zp2sys等函數(shù),也可以用mksys和tree等方法。需要注意的是,Mu-tools提供了一種與ControlSystemToolbox不一樣的表

5、達方式:系統(tǒng)矩陣(systemmatrix)。ControlSystemToolbox里面可以寫成W:;IA,E八,D),對mu-tools則不適用。Mu-tools:AJBJCJD=ssdata(Gcst):Gmu=pck(AJBC,D).A,BjC,D=unpck(Gmu):Gcst=ss(A3B,C?D).4廣義系統(tǒng)P的實現(xiàn)廣義系統(tǒng)P也有多種產生方式。下面我列舉了五種:(1) 直接寫出傳遞函數(shù)矩陣,見2節(jié)。我傾向于利用mu-tools。如果后面需要轉化為狀態(tài)空間模型,需要利用minreal之類的函數(shù)得到最小化實現(xiàn)。重要的函數(shù)有:sbs(side-by-side),abv(above),m

6、mult(multiply),minv(inverse)。(2) 寫出狀態(tài)空間系數(shù)矩陣A,B,C,D,然后利用3節(jié)中的指令:P=pck(A,B,C,D)。(3) 利用sysic函數(shù)(systeminterconnect)o先在一個m文件中利用mu-tools設置了子系統(tǒng),然后利用該函數(shù)將子系統(tǒng)互連起來。(4) 利用sconnect函數(shù),這是LMI-tools提供的函數(shù)。子系統(tǒng)、輸入、輸出以參數(shù)的形式傳遞,sconnect返回互連的系統(tǒng)(5) 利用RCTv3.0.1提供的iconnect函數(shù),該函數(shù)功能與sysic類似這些方法中,我傾向于sysic和iconnect函數(shù),因為它們使用靈活,能夠搭

7、建方法1和方法2難于搭建的復雜系統(tǒng)。一般情況下,得到均衡實現(xiàn)形式以避免數(shù)值計算問題是一個很好的想法,均衡實現(xiàn)形式可以利用ControlSystemToolbox提供的balreal實現(xiàn)。5控制器設計用、.設計問題是尋找一控制器K,使之穩(wěn)定系統(tǒng)G,并使下列的范數(shù)最?。簗舊(只K)|g=|WkSsKS有很多種得到Hw控制器的方法,例如hinfsyn,hinfric,hinflmi,這些函數(shù)將P作為輸入,并以系統(tǒng)矩陣(mu-tools)方式表達。RCTv3.0.1提供了mixsyn函數(shù),耳將二作為輸入(H'F為補靈敏度函數(shù)權重),并不需要事先得到廣義系統(tǒng)模型P。這些方法的主要區(qū)別在于是否用到

8、Riccati方程和Y迭代或者線性矩陣不等式來求解最優(yōu)化問題。LMI方法不需要求解Riccati時設定的假設條件。另外還有些指令:ncfsyn和loopsyn(對開環(huán)傳遞函數(shù)L=GK進行Hw回路成形設計),hinfmix和msfsyn(多目標)。具體請查閱手冊。6結果分析當控制器設計好后,需要對結果進行分析,這時可以利用ControlSystemToolbox提供的函數(shù),例如利用lsim,step(階躍響應),bode(伯德圖),sigma(奇異值),freqresp(頻域響應)等函數(shù)對傳遞函數(shù)S,KS,T,K,GK進行分析。Mu-tools提供的函數(shù)有:trsp(時域響應),frsp(頻域響

9、應),vsvd(奇異值),vplot。7結論從前面可見,有很多種進行Hw控制器設計的方法。為了避免混淆,我建議盡可能使用mu-tools和RCT。如果你知道ControlSystemToolbox存在某個函數(shù),那么mu-tools也很可能存在具有相同功能的函數(shù),只不過名稱稍有些不同。如果你清楚自己的目的,但不知道函數(shù)的名字,那么建議你瀏覽幫助手冊中的函數(shù)索引。希望此處簡短的介紹能夠幫助你進行Hw控制器的設計。好運!附錄%下面的代碼展示了如何在Matlab中進行H-infinity控制器的設計。此處舉的例子與混合%S/KS問題有些不同。此處用到的模型和權重函數(shù)見Skogestad和Postlet

10、hwaite,1996,%ed.1,p.6O.權重函數(shù)并不是“最優(yōu)”的。%大部分函數(shù)來自mu-tools,一些來自lmi-tools。mu-tools和lmi-tools均包含在RCT%v3.0.1中。%-JorgenJohnsen14.12.06%建立子系統(tǒng)%Plant:G=200/(10s+l)(0.05s+l)A2)%方法1:直接方法,利用mu-toolsG=nd2sys(1,conv(10,1,conv(0.05,1,0.051),200);%方法2:controlsystemtoolboxs=tf('s');Gcst=200/(10*s+1)*(0.05*s+1)A2

11、);a,b,c,d=ssdata(balreal(Gcst);G=pck(a,b,c,d);%權重:Ws=(s/M+wO)/(s+wO*A),Wks=1M=1.5;w0=10;A=1.e-4;Ws=nd2sys(1/Mw0,1w0*A);Wks=1;%建立廣義系統(tǒng)P%方法0:直接方法%/z1/Ws-Ws*G/r%|z2|=|0Wks|%v/I-G/u/%傳遞函數(shù)表達方法Z1=sbs(Ws,mmult(-1,Ws,G);Z2=sbs(0,Wks);V=sbs(1,mmult(-1,G);P0=abv(Z1,Z2,V);%通常情況下P0并不是最小實現(xiàn),所以需要降階a,b,c,d=unpck(P0)

12、;ab,bb,cb,db=ssdata(balreal(minreal(ss(a,b,c,d);P0=pck(ab,bb,cb,db);%此時得到變量為System類型%建立廣義系統(tǒng)P%方法1:直接方法%/z1/W1-W1*G/r%|z2|=|0W2|%v/I-G/u/%子系統(tǒng)的ss實現(xiàn)A,B,C,D=unpck(G);A1,B1,C1,D1=unpck(Ws);A2,B2,C2,D2=unpck(Wks);%計算不同子系統(tǒng)的輸入、輸出變量的個數(shù)n1=size(A1,1);q1,p1=size(D1);n2=size(A2,1);q2,p2=size(D2);n=size(A,l);q,p=s

13、ize(D);%原文此處為p,q=size(D);%全系統(tǒng)的ss實現(xiàn)Ap=Alzeros(nl,n2)-Bl*C;zeros(n2,nl)A2zeros(n2,n);zeros(n,nl)zeros(n,n2)A;Bp=Bl-Bl*D;zeros(n2,p)B2;zeros(n,p)B;Cp=Clzeros(ql,n2)-Dl*C;zeros(q2,nl)C2zeros(q2,n);zeros(q,nl)zeros(q,n2)-C;Dp=Dl-Dl*D;zeros(q2,p)D2;eye(p)-D;%得到均衡實現(xiàn)形式,以減少可能產生的計算問題Apb,Bpb,Cpb,Dpb=ssdata(bal

14、real(ss(Ap,Bp,Cp,Dp);Pl=pck(Apb,Bpb,Cpb,Dpb);%Pl與P0數(shù)值相近,但符號有差別%建立廣義系統(tǒng)P%方法2:利用sysic函數(shù)systemnames='GWsWks'inputvar='r(1);u(1)'%所有輸入均為標量,r(2)為兩維信號outputvar='Ws;Wks;r-G'input_to_G='u'input_to_Ws='r-G'input_to_Wks='u'sysoutname='P2'cleanupsysic='

15、;yes'sysic%建立廣義系統(tǒng)P%方法3:利用sconnect函數(shù)inputs='r(1);u(1)'outputs='Ws;Wks;e=r-G'K_in=;%無控制器G_in='G:u'Ws_in='Ws:e'Wks_in='Wks:u'P3,r=sconnect(inputs,outputs,K_in,G_in,G,Ws_in,Ws,Wks_in,Wks);%建立廣義系統(tǒng)P%方法4:利用iconnect函數(shù)%注意1:不再使用mu-toolsSystem表達形式%注意2:iconnet函數(shù)僅適用于Ro

16、bustControlToolboxv3.0.1及以上版本r=icsignal(1);u=icsignal(1);ws=icsignal(1);wks=icsignal(1);e=icsignal(1);y=icsignal(1);M=iconnect;M.Input=r;u;M.Output=ws;wks;e;M.Equation1=equate(e,r-y);M.Equation2=equate(y,ss(A,B,C,D)*u);M.Equation3=equate(ws,ss(A1,B1,C1,D1)*e);M.Equation4=equate(wks,ss(A2,B2,C2,D2)*u

17、);ab,bb,cb,db=ssdata(balreal(M.System);P4=pck(ab,bb,cb,db);%控制器的設計%下面使用的方法均基于廣義系統(tǒng)P的System矩陣表達形式%選擇你喜歡的控制器設計方法和廣義系統(tǒng)P%選擇廣義系統(tǒng)PP=P1;%P=P0;P=P1;P=P2;P=P3;P=P4;%然后設置一些參數(shù)(測量變量個數(shù),輸入變量個數(shù),gamma限制)nmeas=1;nu=1;gmn=0.5;gmx=20;tol=0.001;%控制器設計:選擇你喜歡的設計方法,不需要的注釋掉K,CL,gopt=hinfsyn(P,nmeas,nu,gmn,gmx,tol);gopt,K=hi

18、nflmi(P,nmeas,nu,0,tol);CL=starp(P,K,nmeas,nu);gopt,K=hinfric(P,nmeas,nu,gmn,gmx);CL=starp(P,K,nmeas,nu);%利用RCTv3.0.1進行控制器的設計%通常不需要系統(tǒng)的傳遞函數(shù)表達式,但更需要ss類型a,b,c,d=unpck(G);Gcst=ss(a,b,c,d);a,b,c,d=unpck(Ws);Wscst=ss(a,b,c,d);a,b,c,d=unpck(Wks);Wkscst=ss(a,b,c,d);K,CL,gopt=mixsyn(Gcst,Wscst,Wkscst,);a,b,c

19、,d=ssdata(balreal(K);K=pck(a,b,c,d);a,b,c,d=ssdata(balreal(CL);CL=pck(a,b,c,d);%分析結果%注意:此處使用mu-tools函數(shù)。也可以使用controltoolbox指令,例如用series和%feedback進行子系統(tǒng)連接,sigma或freqresp,svd和bode畫奇異值,step和lsim分析%時域響應%畫(Weighted)閉環(huán)系統(tǒng)的奇異值w=logspace(-4,6,50);CLw=vsvd(frsp(CL,w);figure(1)vplot('liv,m',CLw)title(

20、9;singularvaluesofweightedclosedloopsystem')%得到傳遞函數(shù)矩陣type,out,in,n=minfo(G);I=eye(out);S=minv(madd(I,mmult(G,K);%靈敏度函數(shù)T=msub(I,S);%補靈敏度函數(shù)KS=mmult(K,S);%G的輸入GK=mmult(G,K);%回路傳遞函數(shù)%頻域的奇異值Sw=vsvd(frsp(S,w);Tw=vsvd(frsp(T,w);Kw=vsvd(frsp(K,w);KSw=vsvd(frsp(KS,w);GKw=vsvd(frsp(GK,w);%畫奇異值%注意:如果愿意的話,可以

21、將vplot用plot代替,單位是dB。figure(2)vplot('liv,lm',Sw,'-',Tw,'-',GKw,'-.');title('sigma(S(jw)(solid),sigma(T(jw)(dashed)andsigma(GK(jw)(dashdot),')xlabel('Frequencyrad/sec');ylabel('Amplitude')figure(3)vplot('liv,lm',Kw)title('sigma(K(jw)&

22、#39;)xlabel('Frequencyrad/sec');ylabel('Amplitude')%是否滿足設計要求?Sd=minv(Ws);Sdw=vsvd(frsp(Sd,w);%期望的靈敏度KSd=minv(Wks);KSdw=vsvd(frsp(KSd,w);%期望的輸出figure(4)vplot('liv,lm',Sw,'-',Sdw,'-');title('sigma(S(jw)(solid)andsigma(WsA-1(jw)(dashed),')xlabel('Freq

23、uencyrad/sec');ylabel('Amplitude')figure(5)vplot('liv,lm',KSw,'-',KSdw,'-');title('sigma(KS(jw)(solid)andsigma(WksA-1(jw)(dashed),')xlabel('Frequencyrad/sec');ylabel('Amplitude')%最后,階躍響應reference=1;tfinal=1;step=0.01;y=trsp(T,reference,tfinal,step);u=trsp(KS,reference,tfinal,step);figure(6)

溫馨提示

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

評論

0/150

提交評論