滑動模式控制

来自testwiki
跳转到导航 跳转到搜索

滑動模式控制(sliding mode)簡稱SMC,是一種非線性控制的技術,利用不連續的控制信號來調整非線性系統的特性,強迫系統在二個系統的正常狀態之間滑動,最後進入穩態。其狀態-反饋控制律不是時間的連續函數。相反的,控制律會依目前在狀態空間中的位置不同,可能從一個連續的控制系統切換到另一個連續的控制系統。因此滑動模型控制屬於變結構控制。已針對滑動模型控制設計了許多的控制結構,目的是讓相空間圖中的軌跡可以前往和另一個控制結構之間相鄰的區域,因此最終的軌跡不會完全脫離某個控制結構。相反的,軌跡會在控制結構的邊界上「滑動」。這種沿著控制結構之間邊界滑動的行為稱為「滑動模式」[1]而包括邊界在內的幾何轨迹稱為滑動曲面(sliding surface)。在現代控制理論的範圍中,任何變結構系統(例如滑動模式控制)都可以視為是併合系統的特例,因為系統有些時候會在連續的狀態空間中移動,也時也會在幾個離散的控制模式中切換。

簡介

圖1:利用滑動模式控制器控制之系統的相平面軌跡。在一開始的接觸階段後,系統沿著s=0的曲線滑行,s=0曲面是特別設計過的,系統在曲面上會有較理想的降階動態特性。此例中,s=x1+x˙1=0對應一階的線性時不變系統x˙1=x1,在原點處為指數穩定

滑動模式控制中存在滑動曲面s=0,一開始時,系統會在有限時間內到達滑動曲面,之後就會沿著滑動曲面移動。在滑動模式的理論敘述中,系統會約束在滑動曲面上,因此只需將系統視為在滑動曲面上滑動。不過實際系統的實現是用高頻切換來讓系統近似在滑動曲面上滑動,高頻切換的控制信號讓系統在很鄰近滑動曲面的範圍內切跳(chatter),而且其頻率是不固定的。雖然整體系統是非線性的,不過圖1中,當系統到達滑動曲面後,理想(沒有切跳)系統會限制在s=0的滑動曲面上,滑動曲面是線性時不變系統,在原點處指數穩定

直觀來說,滑動模式控制會配合很大的增益(理想上可視為是無限大),強迫動態系統的軌跡無法離開滑動模式子空間太遠,必須沿著此子空間滑動。在降階滑動模式上的軌跡會有理想的動態特性(例如,系統會自然沿著此軌跡滑行,最後會停在理想的駐點。滑動模式控制的主要優點是其強健性。因為控制很簡單,是在二個狀態之間(例如開/關或是正轉/反轉)切換,控制法則不需要精確,而且不會受到控制系統中參數的變異所影響。而且因為控制律不是連續函數,滑動模式控制可以在有限時間內到達滑動曲面(比漸進到達的特性要好)在一些常見的條件下,最优控制需要用到起停式控制,而滑動模式控制中也有用到起停式控制的特性,有些滑動模式控制也是某些控制系統下的最優控制。

有些交換式電源供應器驅動的電機就是利用滑動模式控制[2]Template:Rp。這類轉換器本身就有不連續的特性,和不連續輸出的滑動模式控制器在本質上是一致的。使用連續性的控制器,還需要透過脈衝寬度調變或是其他類似的技術[nb 1]來將連續性的輸出轉換為可用離散狀態表示的輸出。滑動模式控制在機器人學有許多的應用。此控制演算法特別已用在無人水面載具模擬在有大風大浪海面下的運作,其成功率相當高[3][4]

相較於其他有較多適度控制行為的非線性控制,滑動模式控制因為其不連續的輸出,在應用上需要更謹慎的應用。特別是因為致動器本身的延遲以及其他實務上的限制,硬切換的滑動模式控制會產生顫動、能量損失、設備損壞,或是激發一些系統中的未建模動態[5]Template:Rp。連續性的控制器設計比較不會有上述的問題,而且也可以設計一些接近滑動模式控制器的特性[5]Template:Rp

控制架構

考慮以下的非線性系統

𝐱˙(t)=f(𝐱,t)+B(𝐱,t)𝐮(t)
(1)

其中

𝐱(t)[x1(t)x2(t)xn1(t)xn(t)]n

n維的状态向量以及

𝐮(t)[u1(t)u2(t)um1(t)um(t)]m

為表示狀態反馈m維的輸入向量。函数f:n×nB:n×n×m假設是連續函數,而且有相當程度的光滑性,因此可以用柯西-利普希茨定理確保方程 (1)的解𝐱(t)存在唯一

常見的作法是設計一個狀態回授的控制律𝐮(𝐱(t))(也就是可以將時間t時的狀態𝐱(t),映射到輸入𝐮的映射),這個控制律要可以穩定方程式(1)的动力系统原點𝐱=[0,0,,0]T附近的行為。也就是說,在此控制律下,只要系統從原點開始往任意方向前進,最後都會回到原點。例如,狀態向量𝐱中的分量x1表示輸出和已知訊號(例如某個希望出現的弦波)之間的差,若控制𝐮可以讓x1快速的回到x1=0,也代表輸出會追隨理想的弦波信號。在滑動模式控制中,只要系統是限制在其組態空間的子空間內,設計者可以確定系統有理想的行為(有穩定的平衡點)。滑動模式控制會強迫系統軌跡進入子空間,並且讓軌跡維持在子空間內,因此可以在子空間內滑動。這個降階的子空間稱為「滑動(超)曲面」,若透過閉迴路回授,使得軌跡在滑動曲面上滑動,則稱為閉回路系統的「滑動模式」。沿著這個子空間的軌跡可以類比沿著LTI系統特徵向量的軌跡,不過滑動模式是透過此向量場上加上高增益回授來實現。就像彈珠會沿著裂縫滾動一樣,系統的軌跡也會限制在滑動模式上。

滑動模式的控制架構包括以下幾項:

  1. 選擇超曲面或是流形(滑動曲面)讓系統軌跡限制在此流形上時,可以有理想的特性。
  2. 選擇回授增益,讓系統軌跡可以和流形相交,而且之後可以維持在流形上。

因為滑動模式控制是不連續的,控制器可以在有限時間內將軌跡帶到滑動模式上(若偏離滑動平面時,回到滑動平面上的穩定性會比漸近穩定要好)。不過,只要軌跡接觸到滑動平面後,系統的特性會依照滑動模式的特性(也就是滑動平面上,在原點𝐱=𝟎附近只有漸近穩定性)。

在設計滑動模式時,會選擇一個切換函數σ:nm,表示狀態 <matmathbf{x}</math>遠離滑動曲面的程度。

  • 在滑動平面外的狀態𝐱會有σ(𝐱)0
  • 在滑動平面上的狀態𝐱會有σ(𝐱)=0

滑動模式控制律會依照上述距離的正負號在二種不同的狀態之間進行切換。因此滑動模式控制就類似一個硬的壓力,將系統軌跡移到σ(𝐱)=0的滑動模式上。理想的𝐱(t)會接觸到滑動平面,而且因為控制律不連續(當軌跡越過滑動曲面時,控制律會由一個狀態切換到另一個狀態),軌跡會在有限時間內到達滑動平面。只要軌跡踫到平面之後,會沿著滑動平面滑動,而且會往原點𝐱=𝟎移動。因此切換函數類似地形图,有恒定高度的轮廓,而軌跡會限制在恒定高度的轮廓上移動。

滑動(超)曲面的維度是n×m,其中n是狀態𝐱的個數,而m是輸入信號(也就是控制信號)𝐮的個數。針對每個1km,有n×1的滑動曲面,方程式為

{𝐱n:σk(𝐱)=0}
(2)

滑動模式控制主要關鍵是選擇控制律,使得滑動模式(也就是σ(𝐱)=𝟎曲面)存在,而且其他的系統軌跡可以進入滑動模式。滑動模式控制的原則是透過適當的控制策略,強迫性的限制系統在滑動曲面上,讓系統可以有理想的特性。當系統受滑動控制所限制,維持在滑動曲面上時,系統的動態特性可以用方程式(2)所得的降階系統所描述。

為了強迫系統狀態𝐱滿足σ(𝐱)=𝟎,需要:

  1. 確認系統可以從任意的初始條件到達σ(𝐱)=𝟎
  2. 在到達σ(𝐱)=𝟎後,可以透過控制行為讓系統維持在σ(𝐱)=𝟎

閉迴路解的存在

此控制律不是連續函數,也不會是利普希茨連續,因此無法用柯西-利普希茨定理確保閉迴路解的存在及唯一性。這個解需要用Template:Le的架構來理解。[1][6]。 大致上,沿著σ(𝐱)=𝟎的閉迴路系統可以用會平滑的動態σ˙(𝐱)=𝟎; 來近似,不過實際上不一定有這樣平滑的特性。高速的脈波振幅調變ΔΣ調變產生的輸出是兩個狀態組成而成,但其有效的輸出會在連續的運動範圍內擺動。若是使用其他具有連續特性的非線性控制設計可以避免這類的問題。有些情形下,滑動模式控制的設計可以用其他連續控制器來近似。[5]

理論基礎

以下定理是滑動模式控制的基礎。

定理1:滑動模式的存在

考慮以下的李亞普諾夫候選函數

V(σ(𝐱))=12σT(𝐱)σ(𝐱)=12σ(𝐱)22
(3)

其中

欧几里德范数(也就是說,σ(𝐱)2是距離滑動流形σ(𝐱)=𝟎的距離)。

針對由方程式(1)及方程式(1)的滑動曲面組成的系統,滑動模式存在的充份條件是

σTVσσ˙dσdtdVdt<0(i.e., dVdt<0)

σ(𝐱)=0曲面的邻域都成立。

簡單來說(例如針對m=1純量控制應用),為了要使σTσ˙<0,需選擇回授控制律u(𝐱)使σσ˙有相反的符號,因此

  • σ(𝐱)為正時,u(𝐱)會使σ˙(𝐱)為負。
  • σ(𝐱)為負時,u(𝐱)會使σ˙(𝐱)為正。

注意

σ˙=σ𝐱𝐱˙d𝐱dt=σ𝐱(f(𝐱,t)+B(𝐱,t)𝐮)𝐱˙

因此回授控制律𝐮(𝐱)會直接影響σ˙

可達性:可以在有限時間內到達滑動流形

為了要確保可以在有限時間內進入滑動模式σ(𝐱)=𝟎dV/dt需要比零小很多。若此數值很快的就歸零,就只能以漸近收斂的方式進入到滑動模式。若要在有限時間內進入滑動模式[7]

dVdtμ(V)α

其中μ>00<α1均為常數。

比較引理的說明

引理的條件確認在滑動模式V[0,1]的鄰域,下式成立

dVdtμ(V)αμV.

因此,針對V(0,1],下式成立

1VdVdtμ,

根據链式法则(也就是dW/dt,而W2V),下式也會成立

D+(2Vσ2W)D+WUpper right-hand W˙=1VdVdtμ

其中

D+2VTemplate:Le
代表比例

因此將上式和曲線z(t)=z0μt比較(初始條件 z(0)=z0微分方程z˙=μ的對應曲線)。可得2V(t)V0μt在所有t下成立。而且,因為V0V必需在有限時間達到V=0,表示V必需在有限時間達到V=0(也就是進入滑動模式)[5]。因為V和切換函數σ的欧几里德范数2成正比,因此接近滑動模式的速率比定大於零。

定理2:吸引區域

針對方程式 (1)的系統,以及方程式 (2)的滑動曲面,{𝐱n:σ(𝐱)=𝟎}表面的子空間有可達性的條件是

{𝐱n:σT(𝐱)σ˙(𝐱)<0}

也就是說,當初始條件完全由這個空間出發時,李亞普諾夫候選函數V(σ)李亞普諾夫函數,而且𝐱軌跡確定會往滑動模式表面σ(𝐱)=𝟎前進。而且,若定理1的可達性條件滿足,滑動模式會完全進入V˙在有限時間遠離0的區域。因此會在有限時間內進入滑動模式σ=0

定理3:滑動運動

σ𝐱B(𝐱,t)

非奇异的,也就是說,系統有某種可控制性使得永遠存在一種控制方式可以讓軌跡更靠近滑動模式。只要達到了滑動模式σ(𝐱)=𝟎,系統會維持在滑動模式上。沿著滑動模式軌跡,σ(𝐱)為定值,因此滑動模式軌跡可以用以下的微分方程來描述

σ˙=𝟎.

若相對微分方程在𝐱-平衡稳定的,則系統會沿著滑動模式表面往平衡點移動。

滑動模式下的「等效控制律」可以透過求解下式求得

σ˙(𝐱)=0

等效控制律為𝐮(𝐱),也就是說

σ𝐱(f(𝐱,t)+B(𝐱,t)𝐮)𝐱˙=𝟎

因此等效控制

𝐮=(σ𝐱B(𝐱,t))1σ𝐱f(𝐱,t)

也就是說,就算實際的控制𝐮連續,在滑動模式 σ(𝐱)=𝟎兩側的快速切換會強迫系統的行為類似在連續模式下驅動的行為。

類似的,在滑動模式上的系統軌跡類似

𝐱˙=f(𝐱,t)B(𝐱,t)(σ𝐱B(𝐱,t))1σ𝐱f(𝐱,t)f(𝐱,t)+B(𝐱,t)u=f(𝐱,t)(𝐈B(𝐱,t)(σ𝐱B(𝐱,t))1σ𝐱)

所得的系統符合滑動模式的微分方程

σ˙(𝐱)=𝟎

只要滑動模式表面σ(𝐱)=𝟎李雅普诺夫稳定性,從到達相位的軌跡條件可以簡化為上述較簡單的條件。因此系統在找到滑動模式後,會經過一些初始的暫態,之後就可以假定為符合較簡單的σ˙=0條件。若等式σ(𝐱)=𝟎只是近似成立,系統的動態仍可以近似為上述的特性。

依照上述定理,滑動運動對於由進入系統時足夠小的擾動是不敏感的,只要控制項大到足以滿足σTσ˙<0 ,而且σ˙均勻有界的遠離0,滑動模式的運作就如同系統沒有擾動時一樣。滑動模式控制對特定擾動及模型不確定性的不敏感是很具吸引力的特點,滿足鲁棒控制

如同以上提到的,滑動模式控制律會維持以下的限制

x˙+x=0

目的是為了讓以下型態的任意系統可以漸近的穩定

x¨=a(t,x,x˙)+u

其中a()為有限的上界,此例中,滑動模式為

x˙=x

(也就是說,x˙+x=0)。若系統限制在此條件下,會類似一個穩定線性系統,因此在(x,x˙)=(0,0))位置是全域指數穩定的平衡點。

控制設計的例子

  • 考慮一個由方程(1)描述的受控體,有單一輸入u(也就是說,m=1)。其切換函數選擇為以下的線性組合
σ(𝐱)s1x1+s2x2++sn1xn1+snxn
(4)
其中的加權si>0,對所有的1in都成立。滑動曲面是单纯形σ(𝐱)=0。若軌跡強迫在曲面上滑行,
σ˙(𝐱)=0
因此
s1x˙1+s2x˙2++sn1x˙n1+snx˙n=0
這是降階系統(新系統的階數為n1,因為會限制在(n1)-維的滑動模式单纯形上)。這個表面有理想的性質(當受控體被強制在滑動曲面上滑動,會趨向原點𝐱=𝟎)。取方程(3)中李亞普諾夫函數的導數,可得
V˙(σ(𝐱))=σ(𝐱)Tσ𝐱σ˙(𝐱)dσdt
為了要確保V˙負定函數(也就是V˙<0,在σ=0表面上有李雅普诺夫稳定性),需選擇回授控制律u(𝐱)使下式成立
{σ˙<0if σ>0σ˙>0if σ<0
因此σσ˙<0因為是一個正數及負數的累積。注意到
σ˙(𝐱)=σ(𝐱)𝐱𝐱˙σ˙(𝐱)=σ(𝐱)𝐱(f(𝐱,t)+B(𝐱,t)u)𝐱˙=[s1,s2,,sn]σ(𝐱)𝐱(f(𝐱,t)+B(𝐱,t)u)𝐱˙( i.e., an n×1 vector )
(5)
控制律u(𝐱)可以選擇使下式成立
u(𝐱)={u+(𝐱)if σ(𝐱)>0u(𝐱)if σ(𝐱)<0
其中
  • u+(𝐱)是某種極端的控制(正轉或是打開),使得方程(5)σ˙𝐱為負值。
  • u(𝐱)是另一種極端的控制(反轉或是關閉),使得方程(5)σ˙𝐱為正值。
所得的軌跡會往滑動曲面σ(𝐱)=0前進。因為實際系統會有時間延遲,滑動模式的軌跡不會是平滑的沿著滑動曲面滑動,而會在滑動曲面兩側反覆的切跳(chatter),不過若離開滑動曲面,會很快又回到滑動曲面。
x¨=a(t,x,x˙)+u
可以用二維的状态空间(其中with x1=xx2=x˙)表示:
{x˙1=x2x˙2=a(t,x1,x2)+u
也假設sup{|a()|}k(也就是說|a|有一個已知有限的上限k),對於此系統,選擇切換函數
σ(x1,x2)=x1+x2=x+x˙
在之前的例子中,必須選擇回授控制律u(x,x˙)使得σσ˙<0,在此處
σ˙=x˙1+x˙2=x˙+x¨=x˙+a(t,x,x˙)+ux¨
  • x+x˙<0(也就是σ<0),要讓σ˙>0,需選擇控制律使u>|x˙+a(t,x,x˙)|成立
  • x+x˙>0(也就是σ>0),要讓σ˙<0,需選擇控制律使u<|x˙+a(t,x,x˙)|成立
不過,因為三角不等式
|x˙|+|a(t,x,x˙)||x˙+a(t,x,x˙)|
依照|a|的假設,
|x˙|+k+1>|x˙|+|a(t,x,x˙)|
因此系統可以利用以下的控制律進行回授穩定(回到滑動模式)
u(x,x˙)={|x˙|+k+1if x+x˙<0,(|x˙|+k+1)if x+x˙σ>0
可以表示為以下的解析解
u(x,x˙)=(|x˙|+k+1)sgn(x˙+xσ)(i.e., tests σ>0)
假設系統軌跡會受限制,因此σ(𝐱)=0,則
x˙=x(i.e., σ(x,x˙)=x+x˙=0)
因此只要系統進入滑動模式,系統的二維動態特性會像一維的系統,而且在(x,x˙)=(0,0)會有一個全域指數穩定的驻点

自動化設計的解

在設計滑動模式的控制系統時,雖然有許多不同的理論,不過沒有一個高效率的設計方法論,原因因為解析方法及數值方法實務上的困難。像是基因演算法之類可復用的方式,可以用來將Template:Le中不可解的問題,轉換成實務上可解的非確定性多項式問題。這有助於滑動模式控制的電腦自動化設計[8]

相關條目

註解

Template:Reflist

參考資料

Template:Reflist


引用错误:名称为“nb”的group(分组)存在<ref>标签,但未找到对应的<references group="nb"/>标签