卡尔曼滤波的推导过程详解

在学习卡尔曼滤波的时候看了很多博客讲这方面的知识,感觉都讲得表面的东西,无法了解它五个公式真正代表的过程,这篇博客我想以我的理解讲讲卡尔曼滤波。

首先我先写出卡尔曼滤波的具体过程,首先针对如下状态空间模型(因为卡尔曼滤波都是针对状态空间模型进行滤波的):                                               

                                        x\left ( k+1 \right )=\phi *x\left ( k \right )+\Gamma *w\left ( k \right )

                                         y\left ( k \right )=H*x\left ( k \right )+v\left ( k \right )

其中w\left ( k \right ),v\left ( k \right )分别为系统噪声和测量噪声,对于不了解这个模型怎么回事的建议去补补现代控制理论的知识,这里就不加解释这个模型是什么。

针对上述模型存在如下卡尔曼滤波迭代公式:

卡尔曼滤波的推导过程详解_第1张图片

这里我想解释一下这五个公式中变量代表的含义:

1.x_{k/k-1}代表状态一步预测值,简单理解就是我们在已知模型的基础上(这时候不知道下一拍的测量值)预测下一拍系统的状态值得到的结果。举个例子,假如一个恒温系统中,此时估计的温度为38度,在不知道下一时刻温度计测量值的基础上估计系统下一时刻的预测值为38度。

2.P_{k/k-1}代表状态预测的误差,由公式1可以知道状态预测值x_{k/k-1},但是这个值肯定和我们下一拍实际的状态值有所偏差,P_{k/k-1}就是体现这个偏差大小的一个指标,统计学上将误差均方差。

3.K_{k}表示滤波增益,怎么理解这个增益??我们由系统方程可以得到下一拍状态预测值,由传感器可以得到状态的测量值,当前这两个数据对于状态的真实值来说都是存在误差的,怎么将误差达到更小呢??将两种数据融合在一起可以达到误差更小,融合的方式就是这和滤波增益K_{k},你可以看成两种数据之间的一个权重。

4.x_{k}代表状态估计,就是将上面将的两种数据融合之后的值。

5.P_{k/k}表示状态估计均方差,我们融合后的数据肯定相对于真实值之间还存在一定的误差,P_{k/k}表示就是这个误差的大小,也是均方差。

通过上述的解释后,我将卡尔曼滤波推导过程写下来,推导的方式我现在看到的有两种:一种是严恭敏老师在捷联惯导算法与组合导航算法中的推导;一种是邓自立老师在信息融合滤波理论及其应用中的推导。严老师的推导过程便于理解,但是推导过程不是特别严谨,邓老师的推导过程严谨,但是过程很难理解,但是理解之后对于后续的学习很有好处,不然你连新息是啥都不知道。

  • 严老师推导过程

由状态方程可知,一步预测状态表达式如下:

                                                                   (1)

 

这里是因为系统方差W为零均值的误差,所以有:

                                                                                  E\left ( w \right )=0                                          (2)

则状态一步预测误差如下:

                                                                                                                  (3)

将状态方程和一步预测表达式带入上式可知:

                 (4)

由此可得一步预测均方差误差阵:

卡尔曼滤波的推导过程详解_第2张图片                            (5)

我们定义一个名词:新息,新息表达式如下:

                                             \epsilon \left ( t \right )=y\left ( t \right )-H*x\left ( k/k-1\right )                                                       (6)

这里可以通过新息来对状态估计值来进行修正,即得到如下式子:

                                                 x\left ( k \right )=x\left ( k/k-1 \right )+K*\epsilon \left ( t \right )                                                     (7)

由此我们可以得到k时刻的状态估计误差如下:

                                                                           (8)

状态估计误差均方差阵如下:

卡尔曼滤波的推导过程详解_第3张图片                                      (9)

下面就是怎么来求滤波增益K的问题??我们估计状态的目的肯定是为了使得估计值与真实值之间误差最小,这里的误差最小指的各个状态的均方误差之和最小,即:

                                                                   (10) 

卡尔曼滤波的推导过程详解_第4张图片                                                        (11)

等价于:

                                                                                                            (12)

由此可得:

        (13)

最小可以对上式进行求导获得:

下面给出矩阵求导的两个式子如下:

                                                                                           (14)

利用矩阵求导式子对关于K_{k}求偏导可得:

                                         (15)

根据函数极值原理,令其右端等于零可得:

                                                                                     (16)

                                                                                        (17)

将式16带入式9,即可得到:

                                                                                                                (18)

由此卡尔曼滤波的五个迭代式子就都导出了,感觉这样推导比较好理解一点,因为严老师在讲义上讲这部分很细,所以以上部分好多都是照搬的,自己理解的部分很少,有不懂的可以多看看严老师讲义。

  • 邓老师书上推导

邓老师推导过程就相对而言更加严谨一点,需要的数学知识也多一点,以下全都是我个人对书上知识的理解。

首先我们要估计一个系统的状态值,我们能够获得的是系统输出的测量值y(t),即我们要做的就是怎么利用y(t)来估计状态x(t),我们采用的是线性最小估计,即:

                                                                      \hat{x}=A*y+b                                                    (2.1)

其中A,b都为矩阵,我们需要做的就是怎么获得参数A和b。

首先我们得到期望方差均方差表达式如下:

                                                       J=E\left [ \left ( x-A*y-b\right )^{T}\left ( x-A*y-b \right ) \right ]                      (2.2)

选择A和b极小化J,则有\frac{\partial J}{\partial b}=0,则有:

                                                                    \frac{\partial J}{\partial x}=-2E\left ( x-b-A*y \right )=0                           (2.3)

则有:

                                                                       b=E(x)-A*E(y)                                            (2.4)

将式2.4带入式2.2,则有:

这里不妨令:

卡尔曼滤波的推导过程详解_第5张图片                                                    (2.5)

则有:

卡尔曼滤波的推导过程详解_第6张图片       (2.6)

\frac{\partial J}{\partial A}=0,则有:

                                                                                           (2.7)

因为:

                                                                                                                                  (2.8)

则有:

                                                                                                                              (2.9)

由此可得线性最小估计下,状态估计值表达式如下:

                                                                                           (2.10)

射影定理:

我一直想着怎么将这段知识能把射影定理给绕过去,因为射影定理理解起来比较难,但是没办法,还是绕不过去,还是需要了解一些定义。

推论1:(正交性)

                                                                                                                   (2.11)

证明:

卡尔曼滤波的推导过程详解_第7张图片                                                  (2.12)

上述式子成立是因为:

卡尔曼滤波的推导过程详解_第8张图片         (2.13)

由此证明上述推论。

定义:我们称x-\hat{x}与y不相关为x-\hat{x}与y正交,记\left ( x-\hat{x} \right ) \perp y,称为\hat{x}为x在y上的投影,记为\hat{x}=proj\left ( x|y \right )。示意图如下:

卡尔曼滤波的推导过程详解_第9张图片

推论2:设x为零均值随机变量,y(1),y(2),.....y(k)为零均值互不相关的随机变量,则有:

                                                        (2.14)

这个式子应该比较好理解,我就不证明了,你可以看成向量x投影到由y(1),y(2),.....y(k)为基组合构成的向量上投影等于向量x分别投影到y(1),y(2),.....y(k)基向量上分量的组合。

由此我们可以通过x投影到由y(1),y(2),.....y(k)构成的平面上的分量,即我们的估计值,计算过程如下:

卡尔曼滤波的推导过程详解_第10张图片                         (2.15)

从2.15可知,由于\tilde{y}两两之间并不是正交的,所以在求2.15的表达式就会出现问题,即使求出来也会比较复杂,所以我们希望能找到一组另外的基向量,两两正交,且与y(k)具有相同的统计信息,这里的新息概念就出来了。

定义:设y(1),y(2),......y(k)为存在二阶矩的随机序列,其新息序列定义为:

                                                  \epsilon\left ( k \right )=y(k)-proj\left ( y(k))|y(1),......y(k-1))) \right )                     (2.16)

定理3:信息序列\epsilon\left ( k \right )是零均值白噪声。该定理可以看出\epsilon\left ( k \right )\epsilon\left ( j \right )两两正交。

综上可得递推射影定理:

证明过程如下:

卡尔曼滤波的推导过程详解_第11张图片

有了递推射影公式现在来推导卡尔曼滤波的五个公式。

  • 表达式1

现在针对状态方程在y(1).............y(k-1)构成的平面空间进行投影,可得;

                                           (2.17)

通过对最上面的状态空间模型不断迭代可知,y(t)的值只与w(1).......w(t-1),v(t),x(0)有关,表达式如下:

卡尔曼滤波的推导过程详解_第12张图片                                 (2.18)

由此:

                                                            (2.19)

其中L代表线性空间,可得:

               (2.20)

由于系统噪声w(t)为零均值白噪声,且与测量v(t)互不相关,则有:

                                                                                                 (2.21)

由此可得:

                                                                                                          (2.22)

  • 表达式2

       (2.23)

因为:

                           (2.24)

所以有:

                                          (2.25)

所以简化式2.23可得:

                                                                                   (2.26)

  • 表达式3

由射影递推公式可得:

                                                          (2.17)

其中:

                                      (2.18)

卡尔曼滤波的推导过程详解_第13张图片                                   (2.19)

这里是因为有:

垂直于x(t)的投影

 

卡尔曼滤波的推导过程详解_第14张图片(2.20)

这里是因为:

将式2.20和式2.19带入式2.18可得

                                                                   (2.21)

  • 表达式4

其中有:

                                                                                  (2.22)

带入上式有:

                                                                          (2.23)

  • 表达式5

由此可得卡尔曼滤波所有表达式的推导,希望对你们理解卡尔曼滤波过程有帮助。

 

 

 

你可能感兴趣的:(卡尔曼滤波的推导过程详解)