欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 科技 > IT业 > MATLAB 控制系统设计与仿真 - 33

MATLAB 控制系统设计与仿真 - 33

2025/4/5 16:55:56 来源:https://blog.csdn.net/weixin_46185665/article/details/146822229  浏览:    关键词:MATLAB 控制系统设计与仿真 - 33

状态反馈控制系统 -全维状态观测器的实现

状态观测器的建立解决了受控系统不能测量的状态重构问题,使得状态反馈的工程实现成为可能。

考虑到系统的状态方程表达式,如果{A,B}可控,{A,C}可观,且安装系统的性能指标,可以确定状况反馈控制律u=-Kx+v。为了实现状态反馈,还需要引入状态观测器以重构系统的状态。引入状态观测器之后的系统方框图如下所示:

所以观测器的状态方程为:

\dot{\hat{x}}=(A-LC)\hat{x}+\begin{bmatrix} B & L \end{bmatrix}\begin{bmatrix} u\\ y \end{bmatrix} \\ y_{\hat{x}}=\hat{x}

上述状态方程中L为未知数,如果能够确定L的参数,我们就可以得到状态的观测值。

根据系统方程:

\dot{x}=Ax+Bu \\ y=Cx

观测器方程:

\dot{\hat{x}}=A\hat{x}+Bu+L(y-\hat{y}) \\ \hat{y}=C\hat{x}

结合上述两个方程可知:

\dot{e}=\dot{x}-\dot{\hat{x}}=(A-LC)e \\ e=x-\hat{x}

如果观测器的极点在复平面的左半平面,那么e渐进稳定。这样估算的状态变量就会无限逼近真实的状态变量。通常来讲,观测器的极点要比状态控制器的极点大2~6倍,这样观测器会更快的收敛。

例如

\left\{\begin{matrix} \dot{x}(t)=\begin{bmatrix} 0 &1 \\ 0 & 0 \end{bmatrix} x(t)+ \begin{bmatrix} 0\\ 1 \end{bmatrix}u(t)\\ y(t)=\begin{bmatrix} 1 & 0\displaystyle \displaystyle \end{bmatrix}x(t)\displaystyle \end{matrix}\right.

试用全维状态观测器和极点配置设计闭环系统。

MATLAB代码如下:

clear all;clc;
A=[0 1;0 0];
B=[0;1];
C=[1 0];
D=0;
C0=[1 0 ;0 1];
D0=[0 ; 0];Po=[-10 -20];
Px=[-2 -5];
K=place(A,B,Px);
L=(place(A',C',Po))';Ao=A-L*C;
Bo=[B L];
Co=[1 0 ;0 1];
Do=[0 0; 0 0];

Simulink如下所示,文件下载这里

程序运行结果如下:

由上图可知:左边系统状态量和右手边估算的系统系统状态量一样。

所以状态观测器的建立解决了受控系统不能测量的状态重构问题,使得状态反馈的工程实现成为可能。

最后,欢迎大家有问题给我留言。

非常感谢小伙伴们的-点赞-收藏-关注

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词