一、什么是稳定点 二、什么是李雅普诺夫稳定 三、李雅普诺夫第一法 四、李雅普诺夫第二法 五、MATLAB代码
一个控制系统就和一个社会一样,稳定性是首先要解决的重要问题,是其他一切工作的基础。稳定性问题的字面意思很好理解了,那就是系统在受到扰动后,能否能有能力在平衡态继续工作。大家都知道,历史上社会改革成本很高,且以失败者居多,从控制论的角度来看,就是对社会这个大系统的稳定性研究不够,导致扰动发生后,社会发散了。
要研究稳定,首先要研究稳定点,那什么是稳定点呢?我们以发射火箭为例:
火箭的简化模型可以看成是一个倒立摆,如下图所示,在最低端施加控制力,来保持其在竖直方向的角度可控。
其状态方程如下:
其中 为旋转摩擦系数, , 为施加的外力。现在我们要开始做实验了,假设对火箭不做任何控制,即 ,这时火箭的状态方程可进一步简化:
不失一般性,假设我们自己也造了一个火箭,其 ,则上述方程变为:
注意,这个方程虽然看著简单,但确是一个非线性方程,解起来还是费点力气的,我们要借助MATLAB帮我们算一下,并画个图出来看一下,把 作为横坐标, 作为纵坐标,然后随机选择一些初始点,看看向量 是怎么运动的,轨迹如下图所示:
可见,这个图形是比较有意思的,其中有三个比较明显的点,貌似是旋涡中心,无论初始条件是什么,最终都要稳定在这三个点上(实际很多,我们只计算了三个),这三个点的坐标目测是 。
我们从数学上再分析一下,什么是稳定点呢?——就是不再变化的点,那什么是不再变化呢?——导数为零呗,怎么样才能让导数为零呢?——状态方程的左边就是导数啊,让右边为零就可以了。
解这个方程还是比较容易的,它的解就是:
但是,如果你仔细看,还有一个点, 肯定是数学解,但是似乎在图上并没有明显的显示出来,这是什么原因呢?——这代表著火箭竖直放置,且没有扰动,常识告诉我们这是一个极不稳定的点,就像你把铅笔立在桌子上,稍微风吹草动就倒了,而数值求解的时候,几乎寻找不到这个点。
那其他的稳定点又代表什么呢?——火箭水平躺著, ,而且不再变化, ,这和我们的常识也是一致的。
可见稳定点就是系统状态不再发生变化的点,它可能不止一个,它也可能很脆弱,稍微有个扰动,就不稳定了。
早在1892年,俄国有一个叫李雅普诺夫的学者发表了一篇著名的文章《运动稳定性一般》问题,建立了关于运动稳定的一般理论,光看这个文章的名字就不一般,也确实,在尔后百余年,这个理论在数学、力学和控制理论中全面开花,已经成为稳定性研究方向的基础性理论,俄罗斯人对于数学上和工程上的直觉确实令人赞叹。
李雅普诺夫稳定性理论研究的是在扰动下稳定点的稳定性问题。
简单来说,如果稳定状态 受到扰动后,仍然停留在 附近,我们就称 在李雅普诺夫意义下是稳定的(Lyapunov stable)。
如果更进一步,如果稳定状态 受到扰动后,最终都会收敛到 ,我们就称 在李雅普诺夫意义下是渐进稳定的(Asymptotically stable)。
再进一步,如果稳定状态 受到任何扰动后,最终都会收敛到 ,我们就称 在李雅普诺夫意义下是大范围内渐进稳定的(Asymptotically stable in large)。
相反,如果稳定状态 受到某种扰动后,状态开始偏离 ,我们就称 在李雅普诺夫意义下是不稳定的(Unstable)。
示意图如下:
下面我们就分别具体看一下。
请看状态方程:
很容易得到其时域的解为;
且稳定点为 ,我们随机取一些很小的扰动,比如 , 以及 ,把 在初始条件下的轨迹画出来,结果如下:
可以看出,如果初始扰动小,其状态轨迹的区间也小;相反,当初始扰动大的时候,状态轨迹的区间也变大;但是无论如何,状态轨迹的区间都是有限的,而且,如果想减小轨迹的区间,只要保证扰动在某范围内即可。比如对于本范例,要想 ,只要保证初始扰动 即可。
翻译成严谨的数学语言就是:对于任意的 ,存在 ,使得如果 ,则对于所有的 ,都有 。
我们再举个例子看一下:
求解稍微复杂一点,我们直接画出轨迹图如下:
显然 是其稳定点。从轨迹图中可以看出,无论是小扰动(初始点在稳定零点附近),还是大扰动,状态轨迹最终都趋向一个固定的圆。我们套用一下李雅普诺夫稳定定义看一下,该系统是否稳定。我们不妨取 ,即在零点周围画个半径为1的圆,看看能否存在 ,使得 ,则对于所有的 ,都有 。显然, 是不存在的,因此,该系统是不稳定的。
请看如下方程:
令 ,很容易计算该系统的稳定点为: , , ,其轨迹图为:
可见,对于稳定点 , ,存在 ,比如图中的 ,在 的区间内,状态轨迹最终都收敛到这两个稳定点上,因此是渐进稳定的。
而对于点 ,我们在其周围添加小扰动,发现无论扰动多么小,轨迹线都会偏离该稳定点,因此属于不稳定点。
通过前面的例子,我们发现,同一个系统里面,可能有渐进稳定点,也可能有不稳定点,我们还不容易确定系统是否稳定。再来看一个简单的例子:
其轨迹图为:
可见,对于任何扰动,最后都会收敛到一个稳定点,这就是大范围内渐进稳定。对于线性系统来说,很容易证明,如果平衡态是渐进稳定的,也必然是大范围渐进稳定的。
前面我们的文章说了,对于线性时不变系统,只要矩阵 的特征值具有负实部,那系统就是大范围渐进稳定的。
假设有一个系统,状态方程如下:
同样随机布置一些初始点,看看状态的轨迹如何:
很明显,所有初始状态的轨迹都呈现螺旋发散状,从数学上看,特征值 ,具有共轭根,但是实部是正的,因此发散。
再来看另外一个例子,状态方程为
状态量的轨迹为:
貌似也呈现发散状,但是和前面的例子有所不同,轨迹貌似呈现指数形式,计算状态方程特征值为 ,有一个不稳定的实根,导致系统发散。由以上两例可以看出,发散的轨迹可以有多种多样。
前面我们把稳定点分了几类,我们会发现,还是线性系统比较好计算,而且性能比较好,只要保证矩阵 具有负实部,就是大范围一致稳定的。因此,我们如果把方程的形式由
改成
就会带来很多方便。这就需要将非线性系统在平衡态附近线性化,然后讨论线性化系统的特征值分布来研究原非线性系统的稳定性问题。这种方法,就是李雅普诺夫在他论文中提到的第一种方法,称之为第一法,也叫间接法。
我们再来分析一下前面所说的倒立摆的例子:
这是一个典型的非线性方程,我们前面计算过了,其有多个稳定点 ,我们不妨来研究一下 这个点,其附件的状态轨迹为:
现在将原来的非线性方程线性化,为方便起见,我们定义 以及 ,于是可以得到:
于是,原非线性方程就变为:
在新的坐标系下,稳定变为 ,其轨迹为:
可见,与原轨迹还是比较接近的。一般的书上,对于李雅普诺夫第一法都是一笔带过,其实在工程实践中,第一法应用非常多,比如复杂的飞机飞行控制,就是将飞机模型线性化成多个线性化模型进行设计,感兴趣的可参见Design an LQR Servo Controller in Simulink。
第二法就比较天才了,来源于一个朴素的想法:稳定的系统能量总是不断被耗散的,李雅普诺夫通过定义一个标量函数 (通常能代表广义能量)来分析稳定性。这种方法的避免了直接求解方程,也没有进行近似线性化,所以也一般称之为直接法。如果 标量函数 满足:
则称系统在李雅普诺夫意义下是稳定的,特别的,若 时,有 ,则系统是渐进稳定的。举个例子:
如果我们定义李雅普诺夫函数
则有
可见,如果能合理的选定李雅普诺夫函数,则非常容易的判断系统的稳定性。不过遗憾的是,对于复杂的系统,李雅普诺夫函数的选择可以称得上一门玄学,所以,对于工程师而言,笔者还是喜欢李雅普诺夫第一法。
鉴于很多知友对文章中插图的MATLAB代码感兴趣,先将部分代码附录如下,其余按格式更改即可。
首先是定义状态方程函数:
function d=dxdt(t,x) d=[ x(2)+x(1)*(2-x(1)^2-x(2)^2); -x(1)+x(2)*(2-x(1)^2-x(2)^2) ];
根据状态方程,画出变数轨迹:
figure(color,w); hold on for theta=[0:20]*pi/10 x0=3*[cos(theta);sin(theta)];%定义初始值数组 [t,x]=ode45(@dxdt,[0:0.1:8],x0); plot(x(:,1),x(:,2),linewidth,0.5) quiver(x(:,1),x(:,2),gradient(x(:,1)),gradient(x(:,2)),linewidth,3.0);%增加轨迹方向箭头 end for theta=[0:2:20]*pi/10 x0=1e-5*[cos(theta);sin(theta)]; [t,x]=ode45(@dxdt3,[0:0.2:20],x0); plot(x(:,1),x(:,2),linewidth,0.5) quiver(x(:,1),x(:,2),gradient(x(:,1)),gradient(x(:,2)),linewidth,1.5) xlabel(x1,FontSize,18,FontWeight,bold,Color,r); ylabel(x2,FontSize,18,FontWeight,bold,Color,r) title(Made by J PAN) end
推荐阅读: