卡尔曼滤波器及其简matlab仿真_第1页
卡尔曼滤波器及其简matlab仿真_第2页
卡尔曼滤波器及其简matlab仿真_第3页
卡尔曼滤波器及其简matlab仿真_第4页
卡尔曼滤波器及其简matlab仿真_第5页
已阅读5页,还剩7页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、卡尔曼滤波器及其简matlab仿真一、卡尔曼滤波的起源谈到信号的分析与处理,就离不开滤波两个字。通常,信号的频谱处于有限的频率范围内,而噪声的频谱则散布在很广的频率范围内,为了消除噪声,可以进行频域滤波。但在许多应用场合,需要直接进行时域滤波,从带噪声的信号中提取有用信号。虽然这样的过程其实也算是对信号的滤波,但其所依据的理论,即针对随机信号的估计理论,是自成体系的。人们对于随机信号干扰下的有用信号不能“确知”,只能“估计”。为了“估计”,要事先确定某种准则以评定估计的好坏程度。I960年卡尔曼发表了用递归方法解决离散数据线性滤波问题的论文ANewApproachtoLinearFilteri

2、ngandPredictionProblems(线性滤波与预测问题的新方法),在这篇文章里一种克服了维纳滤波缺点的新方法被提出来,这就是我们今天称之为卡尔曼滤波的方法。卡尔曼滤波应用广泛且功能强大,它可以估计信号的过去和当前状态甚至能估计将来的状态即使并不知道模型的确切性质。其基本思想是以最小均方误差为最佳估计准则,采用信号与噪声的状态空间模型利用前一时刻的估计值和当前时刻的观测值来更新对状态变量的估计,求出当前时刻的估计值。算法根据建立的系统方程和观测方程对需要处理的信号做出满足最小均方误差的估计。对于解决很大部分的问题,它是最优,效率最高甚至是最有用的。它的广泛应用已经超过30年,包括机器

3、人导航,控制,传感器数据融合甚至在军事方面的雷达系统以及导弹追踪等等。近年来更被应用于计算机图像处理,例如头脸识别,图像分割,图像边缘检测等等。卡尔曼滤波不要求保存过去的测量数据,当新的数据到来时,根据新的数据和前一时刻的储值的估计,借助于系统本身的状态转移方程,按照一套递推公式,即可算出新的估值。卡尔曼递推算法大大减少了滤波装置的存储量和计算量,并且突破了平稳随机过程的限制,使卡尔曼滤波器适用于对时变信号的实时处理。卡尔曼滤波的原理卡尔曼滤波思想的来源是在海图作业中,航海长通常以前一时刻的船位为基准,根据航向、船速和海流等一系列因素推算下一个船位,但是他并不轻易认为船位就一定在推算船位上,还

4、要选择适当的方法,通过仪器得到另一个推算船位。观测和推算这两个船位一般不重合,航海长需要通过分析和判断选择一个可靠的船位,作为船舰当前的位置。就是以现时刻的最佳估计为在前一时刻的最佳估计的基础上根据现时刻的观测值作线性修正。卡尔曼滤波在数学上是一种线性最小方差统计估算方法,它是通过处理一系列带有误差的实际测量数据而得到物理参数的最佳估算。其实质要解决的问题是八要寻找在最小均方误差下Xk的估计值Xko它的特点是可以用递推的方法计算Xk,其所需数据存储量较小,便于进行实时处理。具体来说,卡尔曼滤波就是要用预测方程和测量方程对系统状态进行估计。设动态系统的状态方程和测量方程分别为:XK="

5、)K,KXK1-K,KWk1ZK-HKXKVK上两式子中,Xk是k时刻的系统状态,Gk,k和K'K是k-1时刻到k时刻的状态转移矩阵,ZK是k时刻的测量值,Hk是测量系统的参数,Wk和VK分别表示过程和测量的噪声,他们被假设成高斯白噪声。如果被估计状态和观测量是满足上述第一式,系统过程噪声和观测噪声满足第二式的假设,k时刻的观测Xk的估计X可按下述方程求解。状态的一步预测:丸/k-1=k(1k-19k-1均方误差进一步预测:PL=熊,k*ph怙u+kQkJL滤波增益矩阵:K=Pk/k4-HT_HkP3LHTRk"滤波估计方程:乂卜二_1-KIZk-(4)k?k/均方误差更新矩

6、阵(K时刻的最优均方误差):Pk=_I-K_他卜P?”上述就是卡尔曼滤波器的5条基本公式,只有给定初值Xo和R,根据k时刻的观测值ZK,就可以递推计算得k时刻的状态估计Xk卜面论述卡尔曼五个公式的推导过程:设系统(1)Zk = %Xk vkk>=1(2)Xk:k,kXk,-kJ-k其中,动态噪声%与量测噪声vk是互不相关的零均值白噪声序列,对任意k,j其基本统计性质为:Ek=0Cov(k,j)=EkT=Q'kjEvk=0Cov(vk,vj)=EvkvjT=RkkjCov(k,vj)=EkvT=0其中均是克罗内克6函数,即:又设初始状态的统计特征为Exo=:VarXo=E(Xo-:

7、)(xo-:)T=Po且Xo与M,vk都不相关,即Cov(Xo,k)=oCov(Xo,vk)=o在量测(k-1)次之后,已经有一个"k=的估计值,要推测k状态的状态值,因为E°k-1=o,可定义功/J为由k-1次量测值所估计信心的一步预测合理数值,即眼/k=6k,k/Xk(3)同样,考虑到Evk=o,因而量测的期望值为Hk*k也是合适的。考虑到这两点以后利用第k次的量测数据zk来估计眼的递推形式,其应该为:必k=xk/k=xk/kI'Kk(zk-Hk)?k/kJ)(4)这里的是一个待定的增益矩阵,其应使误差矩阵极小。接下来推导误差方差公式。定义Xk/k-*k/kJ-

8、xk(5)冷/k=格=xk/k-xk(6)表示误差,式(5)表示先验(没有测量值)的误差,式(6)表示后验的误差(经测量值校正)。则,根据式(6),将式(4),式(5)带入,得k=xk-xk=xk/k'Kk(Hkxkvk-Hk?k/k_1)-xk-xk/k_1xkKkHkxxKkvk-KkHkxk/k-KkHkxk-xk=(I-KkHk)/kKkvk估计误差矩阵Pk=EKkXTKkVkT/k(I二印I一KkHk)Xk/jxT/k(I-KkHk)TvTKT-KkHk)TvkKT(7)定义Pk/k=EkT./kxk/k_1J(8)这就是一步预测误差矩阵。由模型的统计性质可知EvkvT=R(

9、9)而且,预测误差与测量噪声不相关,即:Etxk/k_1vk=EtvkKk/k=0(10)将式(8),式(9),式(10)带入式(7),得Pk=(I-KkHk)Pk/k_1(I-KkHk)TKkRkKT(11)现寻找一个使式(11)最小。将式(11)右端展开后,加减同一项Pk/kHT(HkPk/kHTR)HkPk/k再把有关&的项归在平方项里,即Pk=Pk/kj-Pk/kHT(HkPk/kHTR),HkPk/j&-Pk/k,HT(HkPk/kHTRk)(HkPk/jHkRJKk-Pk/k,H:(HkPk/kHTRQ(12)在式(12)中,欲使R极小,则Kk=Pk/kH:(HkP

10、k/kHTR),(13)此时Pk=Pk/k-Pk/kH:(HkPk/kHT=I-KkHkPk/kjR)HkPk/j(14)这就是误差迭代公式。由此可见,卡尔曼滤波的递推公式即可得到滤波的估计值,又可得到误差的方差阵。由式(3)两边同时减去xk得:xV/k-Xk=k,k_1xk-Xk(15)将式(1),式(5)带入式(15)Xk/k_J=:Jk,k-1k-1一k-1'k因此(20)Pk/k=k,kk,k'-k_1Q-k_1式(20)即一步预测估计误差矩阵。到此,卡尔曼滤波公式推导完毕。三、卡尔曼滤波的实例一一以温度检测滤波为例假设我们要研究一个房间的温度,这个房间的真实温度是25

11、度,以一分钟为时间单位。根据我们的经验判断,这个房间的温度是恒定的(A=1),但是对我们的经验不是完全相信,可能存在上下几度的偏差,我们把该偏差看做是高斯白噪声(系统噪声W)。另外,我们在房间里放一个温度计(H=1),温度计也不准确,测量值会与实际值存在偏差,我们也把这偏差看做是高斯白噪声(测量噪声V)现在我们用卡尔曼滤波,过滤掉噪声,估算出房间的实际温度。系统参数名称解释如下:xk系统状态实际温度系统矩阵温度不变,为1B、uk状态的控制量无控制量,为0Zk观测值温度计读数H观测矩阵直接读出,为1wk过程噪声温度艾化偏差,常量1e-1vk测量噪声读数误差,常量1e-6假如我们要估算2时刻房间的

12、实际温度值。首先你要根据1时刻温度的估计值(就假设为1),来算出2时刻温度的估计值,即:X=4印?,-,公式1),然后由给出的1时刻的均方差P1(假设为10)进一步更新均方差,有P2,1=如P1”归101009屋公式2)。有方差P2,1之后,根1据卡尔曼增益方程计算出增益:K=P州HT1H州P0aHT+Rvv(*公式3)。现在,我们可以通过增益和测量值(Z=26.676,温度计有测量误差)来估计2时刻的温度了,&=&1+KZ=-H*X2,1124.763(*公式4)。得到了2时刻的估计温度,下一步就是对3时刻的温度值进行最优估算,需要得到K时刻的最优温度(24.56)的偏差,算

13、法如下:P2=E0.751*H】*邑1公式5)就这样,再进入3时刻的滤波循环,卡尔曼滤波器就不断的把均方误差递归,从而估算出最优的温度值,运行速度快。以下是matlab程序:clearall;clc;closeall;%系统方程X(k)=AX(k-1)+BU(k)+W(k)%系统测量值Z(k)=HX(k)+V(k)N=200;w=0.1*randn(1,N);%产生随机高斯分布x(1)=0;%赋值与否无所谓a=1;%系统状态矩阵V=randn(1,N);%产生随机高斯分布q1=std(V);Rvv=q1A2;%Rq2=std(w);Qww=q2.A2;%Qh=1;%观测矩阵Y=25+V;%测量

14、误差值p(1)=10;X(1)=0;%kalmanfilter%x(k)=x(k|k-1),X(k)=x(k|k),p1(k)=p(k|k-1),p(k)=p(k|k)fork=2:N;x(k)=a*X(k-1);%X(k|k-1)=AX(k-1|k-1)+BU(k),(1)p1(k)=a*p(k-1)*a'+Qww;%P(k|k-1)=AP(k-1|k-1)A+Q,(2)Kg(k)=p1(k)*h'/(h*p1(k)*h'+Rvv);%Kg(k)=P(k|k-1)H/(HP(k|k-1)H+R),(4)% X(k|k)=X(k|k-1)+Kg(k)% P(k|k)= ( I-Kg(k) H )X(k)=x(k)+Kg(k)*(Y(k)-h*x(k);(Z(k)-HX(k|k-1),(3)p(k)=p1(k)-Kg(k)*h*p1(k);P(k|k-1),(5)endfori=1:NexpValue(i)=25;endk=1:N;plot(k,X,'r',k,Y,'g',k,expValue,'b');legend('真实值','估计值','测量值');axis(0N1030)xlabel('时间');ylabel

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论