状态观测控制器设计与仿真验证
创始人
2024-05-27 11:32:57
0

【无限嚣张(菜菜)】:hello您好,我是菜菜,很高兴您能来访我的博客,我是一名爱好编程学习研究的菜菜,每天分享自己的学习,想法,博客来源与自己的学习项目以及编程中遇到问题的总结。

座右铭:尽人事,听天命

个人主页:无限嚣张(菜菜)

目录

  • 状态观测器的提出
  • 状态观测器定义
  • 状态观测器的设计原理
  • 状态观测器的设计
  • 状态观测器的仿真验证

状态观测器的提出

        并不是所有系统的状态变量都是很容易能直接检测得到的,大多系统的状态变量都是不容易直接检测到的,有些状态变量甚至根本无法检测。这样,就提出了所谓的状态观测和状态重构问题,由龙伯格(Luenberger)提出的状态观测器理论,所以也叫Luenberger观测器。通过系统的输入和输出来估计状态,从而解决了在确定性条件下受控系统的重构问题,从而使状态反馈成为一种可实现的控制率。

状态观测器定义

        设线性定常系统\sum =(A,B,C)的状态矢量x不能直接检测。如果动态系统\hat{\sum }\sum的输入u和输出y作为其输入量,能产生一组输出量\hat{x}渐近于x,即\lim\limits_{t\to+\infty} |x-\hat{x}|=0,则称\hat{\sum }\sum的一个状态观测器。

        根据状态观测器的的定义,我们可以知道构造观测器的原则是:

        (1)观测器\hat{\sum }应以观测器\hat{\sum }的输入u和输出y作为输入量。

        (2)为了满足\lim\limits_{t\to+\infty} |x-\hat{x}|=0\hat{\sum }必须完全能观,或其不能观子系统是渐进稳定的。

        (3)\hat{\sum }的输出\hat{x}应以足够的速度渐进与x,即\hat{\sum }应有足够宽的频带。但从抑制干扰角度看,又希望频带不要太宽。因此,要根据具体情况予以兼顾。

        (4)\hat{\sum }在结构上要尽量简单。即具有尽可能低的维数,以便于物理实现。

状态观测器的设计原理

        给出单输入单输出系统如下,假设给出的系统是能观(rank(C,CA,...,CA^{n-1})^T)=n)的,如果不能观,我们设计降阶观测器,观测他一部分状态。

                                               \begin{cases}\dot{x}=Ax+Bu\\ y = Cx \end{cases}                                                              

        根据观测器的设计原则,闭环观测器的的状态方程设计如下:

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

      我们可以很容易知道闭环观测器的误差状态 

                                                    ​​​​​​ ​​​​​   \begin{cases} e = x-\hat{x}\\ \dot{e} = \dot{x}-\dot{\hat{x}} =(A-GC)e\end{cases}                                            

        证明确定使\hat{x}渐进与x的条件:

对误差求导,我们可以得到如下解:

e = e^{(A-GC)t}e(0)=e^{(A-GC)t}[\dot{x}_{0}-x_{0}]

由上式可知,当(A-GC)的特征值均为负实部,才能满足\lim\limits_{t\to+\infty} |x-\hat{x}|=0

状态观测器的设计

        假设一个线性系统如下:

\begin{cases} \dot{x}_{1} = x_{2}\\ \dot{x}_{2}=m_{1}x_{1}+m_{2}x_{2}+5u\\y=5x_{1} \end{cases}       

将上式写成状态空间的形式如下,设x = [x_{1},x_{2}]^{T}

                                                                                                                

其中A=(\begin{matrix} 0& 1 \\ m_{1} & m_{2} \\ \end{matrix}) ,\quad B=(\begin{matrix} 0 \\ 5 \\ \end{matrix}),\quad C=(\begin{matrix} 5 &0 \\ \end{matrix}),

        判断系统是否能观:R=(\begin{matrix} C \\ CA \\ \end{matrix})=(\begin{matrix} 5&0 \\ 0&5 \\ \end{matrix})=2,由此可知,此系统是满秩,所以能观,根据状态观测器的构造原则可知,可以构造观测器。

        原系统构建:若原系统渐进稳定,那么矩阵A满足Hurwitz条件,即系统A的所有特征值全部小于0.即

|\lambda I-A|=\lambda^{2}-\lambda m_{2}-m_{1}=0

因此特征值和积需满足:\lambda_{1}+\lambda_{2}=m_{2}<0,\lambda_{1}\lambda_{2}=-m_{1}>0,取m_{2}=-2,m_{1}=-1

        观测器构建:

\begin{cases} \dot{\hat{x}} = A\hat{x}+Bu+G(y-C\hat{x}) \\ y = C{x} \end{cases}

观测器的误差为:

\begin{cases} e = x-\hat{x}\\ \dot{e} = \dot{x}-\dot{\hat{x}} =(A-GC)e\end{cases}

我们最初目的是为了让\lim\limits_{t\to+\infty} |x-\hat{x}|=0,也就是目的让误差趋于0。此时我们需要让矩阵A-GC满足Hurwitz条件,即:

A-GC=(\begin{matrix} 0& 1 \\ m_{1} & m_{2} \\ \end{matrix}) -(\begin{matrix} 5g_{1}& 0 \\5g_{2} & 0 \\ \end{matrix})=(\begin{matrix} -5g_{1}& 1 \\ m_{1}-5g_2 & m_{2} \\ \end{matrix})

m_{2}=-2,m_{1}=-1带入上式中,我们并求det(\lambdaI-(A-GC)),使其满足Hurwitz条件

A-GC=(\begin{matrix} -5g_{1}& 1 \\ m_{1}-5g_2 & m_{2} \\ \end{matrix})=(\begin{matrix} -5g_{1}& 1 \\ -1-5g_2 & -2 \\ \end{matrix})

det(\lambdaI-(A-GC))=\lambda^{2}+(5g_{1}+2)\lambda +5g_{2}+2=0,

因此特征值和积需满足,\lambda_{1}+\lambda_{2}=-(5g_{1}+2)<0,\lambda_{1}\lambda_{2}=5g_{2}+2>0,取g_{2}=2,g_{1}=1

状态观测器的仿真验证

控制输入,也就是控制器,我们输入一个正弦函数

x1的状态,以及x1的状态观测

 x2的状态,以及x2的状态观测

 

代码:

clc 
clear all
close allstepLength = 0.002;                               
N = 100000;                                        
timeStart = 0;                                     
timeEnd = N * stepLength;                          
t = timeStart:stepLength:timeEnd ; 
u = sin(t);
k = 1;  % 迭代起始步数
x1 = zeros(size(t));
x2 = zeros(size(t));
x1(:,1) = 1;
x2(:,1) = 1;
x1_hat = zeros(size(t));
x2_hat = zeros(size(t));
x1_hat(:,1) = 0.2;
x2_hat(:,1) = 0.2;
for tt = timeStart : stepLength: (N-1)*stepLengthk% 原系统dx1 = x2(:,k);dx2 = -x1(:,k)-2*x2(:,k)+5*u(:,k);% 观测器dx1_hat = x2_hat(:,k)+5*(x1(:,k)-x1_hat(:,k));dx2_hat = -x1_hat(:,k)-2*x2_hat(:,k)+5*u(:,k)+2*5*(x1(:,k)-x1_hat(:,k));%% 更新坐标x1(:,k+1) = x1(:,k) + dx1 * stepLength;                                            x2(:,k+1) = x2(:,k) + dx2 * stepLength;  x1_hat(:,k+1) = x1_hat(:,k) + dx1_hat * stepLength;                                            x2_hat(:,k+1) = x2_hat(:,k) + dx2_hat * stepLength;  k = k+1;  
end
figure
plot(t,x1,'linewidth',1.5)
hold on
plot(t,x1_hat,'--red','linewidth',1.5)
hold on
xlabel('Time(Sec)')
legend('x_{1}','observe x_{1}')figure
plot(t,x2,'linewidth',1.5)
hold on
plot(t,x2_hat,'--green','linewidth',1.5)
hold on
xlabel('Time(Sec)')
legend('x_{2}','observe x_{2}')

        

相关内容

热门资讯

常用商务英语口语   商务英语是以适应职场生活的语言要求为目的,内容涉及到商务活动的方方面面。下面是小编收集的常用商务...
六年级上册英语第一单元练习题   一、根据要求写单词。  1.dry(反义词)__________________  2.writ...
复活节英文怎么说 复活节英文怎么说?复活节的英语翻译是什么?复活节:Easter;"Easter,anniversar...
2008年北京奥运会主题曲 2008年北京奥运会(第29届夏季奥林匹克运动会),2008年8月8日到2008年8月24日在中华人...
英语道歉信 英语道歉信15篇  在日常生活中,道歉信的使用频率越来越高,通过道歉信,我们可以更好地解释事情发生的...
六年级英语专题训练(连词成句... 六年级英语专题训练(连词成句30题)  1. have,playhouse,many,I,toy,i...
上班迟到情况说明英语   每个人都或多或少的迟到过那么几次,因为各种原因,可能生病,可能因为交通堵车,可能是因为天气冷,有...
小学英语教学论文 小学英语教学论文范文  引导语:英语教育一直都是每个家长所器重的,那么有关小学英语教学论文要怎么写呢...
英语口语学习必看的方法技巧 英语口语学习必看的方法技巧如何才能说流利的英语? 说外语时,我们主要应做到四件事:理解、回答、提问、...
四级英语作文选:Birth ... 四级英语作文范文选:Birth controlSince the Chinese Governmen...
金融专业英语面试自我介绍 金融专业英语面试自我介绍3篇  金融专业的学生面试时,面试官要求用英语做自我介绍该怎么说。下面是小编...
我的李老师走了四年级英语日记... 我的李老师走了四年级英语日记带翻译  我上了五个学期的小学却换了六任老师,李老师是带我们班最长的语文...
小学三年级英语日记带翻译捡玉... 小学三年级英语日记带翻译捡玉米  今天,我和妈妈去外婆家,外婆家有刚剥的`玉米棒上带有玉米籽,好大的...
七年级英语优秀教学设计 七年级英语优秀教学设计  作为一位兢兢业业的人民教师,常常要写一份优秀的教学设计,教学设计是把教学原...
我的英语老师作文 我的英语老师作文(通用21篇)  在日常生活或是工作学习中,大家都有写作文的经历,对作文很是熟悉吧,...
英语老师教学经验总结 英语老师教学经验总结(通用19篇)  总结是指社会团体、企业单位和个人对某一阶段的学习、工作或其完成...
初一英语暑假作业答案 初一英语暑假作业答案  英语练习一(基础训练)第一题1.D2.H3.E4.F5.I6.A7.J8.C...
大学生的英语演讲稿 大学生的英语演讲稿范文(精选10篇)  使用正确的写作思路书写演讲稿会更加事半功倍。在现实社会中,越...
VOA美国之音英语学习网址 VOA美国之音英语学习推荐网址 美国之音网站已经成为语言学习最重要的资源站点,在互联网上还有若干网站...
商务英语期末试卷 Part I Term Translation (20%)Section A: Translate ...