- 多传感器数据智能融合理论与应用
- 戴亚平 马俊杰 王笑涵编著
- 18字
- 2021-10-27 15:10:10
2.3 多传感器数据融合中的卡尔曼滤波理论
2.3.1 卡尔曼滤波简介
针对传感器信息的跟踪滤波算法,大多数工程技术人员会选用卡尔曼滤波算法。卡尔曼滤波算法是R.E.Kalman在1960年发表的一篇著名论文中所阐述的一种递归解算法。该算法在解决离散数据的线性滤波问题方面有着广泛的应用,特别是随着计算机技术的发展,给卡尔曼滤波提供了广泛的研究空间。卡尔曼滤波器是由一组数学方程所构成,它以最小化均方根的方式,来获得系统的状态估计值。滤波器可以依据过去状态变量的数值,对当前的状态值进行滤波估计,对未来值进行预测估计。
一个离散的线性状态方程和观测方程如下式所示:
data:image/s3,"s3://crabby-images/abdac/abdac570042eb7da7cc3dc7a49d0f050fa2db45c" alt=""
其中,X(k)为状态向量,Y(k)为观测向量;W(k)为状态噪声,或称为系统噪声;V(k)为观测噪声。假定W(k)和V(k)为互不相关的白噪声序列,分别符合N(0,Q)和N(0,R)的正态分布。
系统噪声的协方差矩阵为
data:image/s3,"s3://crabby-images/fc235/fc23513d4acb500e9770977052de568c92b9a195" alt=""
观测噪声的协方差矩阵为
data:image/s3,"s3://crabby-images/34a1a/34a1a8693858f9d50b805f49206f0899501cb5be" alt=""
卡尔曼滤波器就是在已知观测序列{Y(0),Y(1),…,Y(k)}的前提条件下,要求解X(k)的估计值,使得后验误差估计的协方差矩阵P(k/k)最小。其中
data:image/s3,"s3://crabby-images/ee73e/ee73e96e9b0dacd19e27515c6430224b86c07123" alt=""
在式(2.5)中,e(k/k)为后验误差估计,它可以由下式求得:
data:image/s3,"s3://crabby-images/61492/61492057d16d7e0fb251f3b0bddec67d2b8dfe54" alt=""
定义先验误差估计如下式所示:
data:image/s3,"s3://crabby-images/739f1/739f1904cf51c6ea485c81dacaf20caf2036eebb" alt=""
可以得到先验误差估计的协方差矩阵为
data:image/s3,"s3://crabby-images/5b853/5b8531fae5fc1965477b268492d10fb2031c362d" alt=""
假定卡尔曼滤波的后验估计如下式所示:
data:image/s3,"s3://crabby-images/63473/63473aa04bedcf4408663cb7d3be21c0ff08a4aa" alt=""
将式(2.9)代入到式(2.6)中,得到
data:image/s3,"s3://crabby-images/d5d20/d5d20dc02be94dfdcaf7f51a0eb9b83042241210" alt=""
将式(2.10)代入到式(2.5),可得
data:image/s3,"s3://crabby-images/7f238/7f238638065a8c7052052b8a03f3b486dbf9798d" alt=""
data:image/s3,"s3://crabby-images/8a5a5/8a5a59dec6c76c5a83287b013bbeb966e3f578b9" alt=""
假设:随机信号W(k)与V(k)与已知的观测序列{Y(0),Y(1),…,Y(k)}是正交的,则有E[W(k-1)Y(k-1)]=0,E[V(k-1)Y(k-1)]=0。
式(2.11)可以化简为
data:image/s3,"s3://crabby-images/b1c5e/b1c5e6e4a8335e78697890b2e9fee4d17fa55864" alt=""
对式(2.12)求导,并令其为零,可得到
data:image/s3,"s3://crabby-images/673c1/673c172ee5b3c001bedea91a563ca56102d9f851" alt=""
同理,可得到
data:image/s3,"s3://crabby-images/fa4d4/fa4d44f3795cae7d0e1c5a1a68a1ef3e95396d6f" alt=""
因此,可以得到状态估计如下式所示:
data:image/s3,"s3://crabby-images/6f965/6f96527e2f55fda539f62dbb50df9200b8ff5ce2" alt=""
状态预测估计为
data:image/s3,"s3://crabby-images/abdf9/abdf97b635b30d086750bfc9894408b27d2e1cfd" alt=""
进一步计算得出误差的协方差矩阵如下式所示:
data:image/s3,"s3://crabby-images/eee6e/eee6e5e192e2d3d34e216a50c671df78ca9fc84d" alt=""
由此可以获得卡尔曼滤波的递推公式如图2.7所示。
data:image/s3,"s3://crabby-images/04480/04480e8e6193b4fecf9c77e020a529c083cbddc6" alt=""
图2.7 卡尔曼滤波的递推公式