Kalman Filter的推导与应用(二)

来源:互联网 发布:手机防盗报警软件 编辑:程序博客网 时间:2024/06/04 20:01

(二)Kalman Filter公式推导

考虑一个用状态空间模型描述的动态系统

X(t+1)=ΦX(t)+ΓW(t)
Y(t)=HX(t)+V(t)
其中,t 为时间,系统在时刻 t 的状态为 X(t)Rn ;Y(t)为观测信号; W(t)Rr 为输入的噪声, V(t)Rm 为观测噪声。由于不同问题的状态空间描述是不一样的,因此只有在确定状态空间后才可以得到递推公式(这是我自己的看法,不知道对不对,可能递推公式还是一样,不过根据问题来推一遍公式总不会有错的,只是麻烦点)。

【假设1】

  • W(t)V(t) 是均值为零,方差各为 QR 的不相关白噪声

【假设2】

  • 初始状态 X(0)W(t)V(t) 不相关,而且
    E[X(0)]=μ0,E[(X(0)μ0)(X(0)μ0)T]=P0

推导

  • 问题重述

卡尔曼滤波是一个基于观测信号 {Y(1),Y(2),...,Y(t)} ,求状态 X(k) 的线性最小方差估计值的问题 X^(k|t) ,而且这个问题的目标函数是

J=E[(X(k)X^(k|t))T(X(k)X^(k|t))]
那么由之前的定义1.1可以得到,卡尔曼滤波问题可以归为求射影
X^(k|t)=proj(X(k)|Y(1),Y(2),...,Y(t))
由定义1.5可以得到递推公式为
X^(t+1|t+1)=X^(t+1|t)+K(t+1)ϵ(t+1)
K(t+1)=E[X(t+1)ϵT(t+1)]{E[ϵ(t+1)ϵT(t+1)]}1
其中K(t+1) 为卡尔曼滤波器增益。

  • 对状态方程求射影

w 表示观测信号,对状态方程 X(t+1)=ΦX(t)+ΓW(t) 两边取射影有(射影运算具有分配律,跟向量点乘一样)

proj(X(t+1)|w)=Φproj(X(t)|w)+Γproj(W(t)|w)
X^(t+1|t)=ΦX^(t|t)+Γproj(W(t)|w)
迭代求解状态方程后获得原状态方程的另一种表示
X(t+1)=Φt+1X(0)+Γ[Φ0W(t)+Φ1W(t1)+...+ΦtW(0)]
对于没有控制量的状态方程,由于假设1的白噪声的性质和假设2,我们可以知道 X(0),W(0),...,W(t) 互不相关,即正交,因此可以把它们看作基,而 X(t+1) 是可以由它们表示,所以有
X(t+1)L(W(t),...,W(0),X(0))
当然,如果状态方程里面有控制量U(t)的加入,即
X(t+1)=ΦX(t)+ΨU(t)+ΓW(t)
相应递推公式为
X(t+1)=Φt+1X(0)+[Φ0ΨU(t)+Φ1ΨU(t1)+...+ΦtΨU(0)]+[Φ0ΓW(t)+Φ1ΓW(t1)+...+ΦtΓW(0)]
而有控制量的状态方程,我们认为每个时刻的控制量都是与公式中其它变量不相关,所以同理有
X(t+1)L(U(t),...,U(0),W(t),...,W(0),X(0))

  • 对观测方程求射影

考虑上文中不带控制量的状态方程的推导,同理,对观测方程做同样的运算有

Y(t+1)L(V(t+1),W(t)...,W(0),X(0))
所以有
L(Y(1),Y(2),...,Y(t))L(V(t),...,V(1),W(t1),...,W(0),X(0))

  • 状态方程和观测方程的递推式

由于假设,可以知道 W(t){V(t),...,V(1),W(t1),...,W(0),X(0)}不相关(正交),所以有

W(t)L(Y(1),Y(2),...,Y(t))
因为正交,所以投影后的状态方程尾项为零,即
X^(t+1|t)=ΦX^(t|t)
对观测方程做同样的推导可以同理得到
V(t+1)L(Y(1),Y(2),...,Y(t))
Y^(t+1|t)=HX^(t+1|t)

  • 协方差更新公式推导

将滤波器的预报估计值误差和协方差记为

X˜(t|t)=X(t)X^(t|t)
X˜(t+1|t)=X(t+1)X^(t+1|t)
P(t|t)=E[X˜(t|t)X˜T(t|t)]
P(t+1|t)=E[X˜(t+1|t)]X˜T(t+1|t)]
由之前的定义1.3,引入新息(不需要管这个名词怎么来的)的表达式
ϵ(t+1)=Y(t+1)proj(Y(t+1)|Y(1),Y(2),...,Y(t))=Y(t+1)Y^(t+1|t)=[HX(t+1)+V(t+1)][HX^(t+1|t)]=HX˜(t+1|t)+V(t+1)
下面进行估计值的误差和协方差的推导
X˜(t+1|t)=X(t+1)X^(t+1|t)
=[ΦX(t)+ΓW(t)][ΦX^(t|t)]
=ΦX˜(t|t)+ΓW(t)
另外一个公式
X˜(t+1|t+1)=X(t+1)X^(t+1|t+1)
=X(t+1)[X^(t+1|t)+K(t+1)ϵ(t+1)]
=X˜(t+1|t)K(t+1)ϵ(t+1)
=X˜(t+1|t)K(t+1)[HX˜(t+1|t)+V(t+1)]
=[IK(t+1)H]X˜(t+1|t)K(t+1)V(t+1)
在计算协方差更新公式时就要利用之前进行射影运算后得到的正交关系。由于X(t)L(W(t1),...,W(0),X(0)),而且 X^(t|t)X(t) 在流型上的投影(简单把流型理解成空间即可),因此由 X^(t|t)X(t) 运算得到的 X˜(t|t) 也属于这个流型,而 W(t) 与这个流型正交,所以有 W(t)X˜(t|t) ,那么在计算协方差更新公式时有

P(t+1|t)=E[X˜(t+1|t)]X˜T(t+1|t)]
=E{[ΦX˜(t|t)+ΓW(t)][ΦX˜(t|t)+ΓW(t)]T}
=E[ΦX˜(t|t)X˜T(t|t)Φ]+E[ΦX˜(t|t)WT(t)ΓT]+E[ΓW(t)X˜T(t|t)Φ]+E[ΓW(t)WT(t)ΓT]
=ΦE[X˜(t|t)X˜T(t|t)]ΦT+0+0+ΓE[W(t)WT(t)]ΓT
=ΦP(t|t)ΦT+ΓQΓT
(真长(-。-;))同理对另一个协方差更新公式进行计算会得到
P(t+1|t+1)=[IK(t+1)H]P(t+1|t)[IK(t+1)H]T+K(t+1)RKT(t+1)
当然这个公式还不是最简的形式,还可以进一步化简,之前文中已经提到了K(t+1)的表达式,则
K(t+1)=E[X(t+1)ϵT(t+1)]{E[ϵ(t+1)ϵT(t+1)]}1
=E{[X^(t+1|t)+X˜(t+1|t)][HX˜(t+1|t)+V(t+1)]T}{E[ϵ(t+1)ϵT(t+1)]}1
={E[X^(t+1|t)X˜T(t+1|t)HT]+E[X˜(t+1|t)X˜T(t+1|t)HT]+E[X^(t+1|t)VT(t+1)]+E[X˜(t+1|t)VT(t+1)]}{E[ϵ(t+1)ϵT(t+1)]}1
=(0+P(t+1|t)HT+0+0){E[ϵ(t+1)ϵT(t+1)]}1
=P(t+1|t)HTE{[HX˜(t+1|t)+V(t+1)][HX˜(t+1|t)+V(t+1)]T}1
=P(t+1|t)HT{HP(t+1|t)HT+R}1
将这个表达式代入上面的协方差更新公式 (基于简化公式的考虑,下面的推导省略时标)
P(t+1|t+1)=[IKH]P[IKH]T+KRKT
=[IKH]PPHTKT+K(HPHT+R)KT
=[IKH]PPHTKT+PHTKT
=[IKH]P

P(t+1|t+1)=[IK(t+1)H]P(t+1|t)
至此所有推导已经完成了

0 0