当前位置:   article > 正文

mpu6050姿态解算与卡尔曼滤波(2)卡尔曼滤波_mpu6050卡尔曼滤波姿态解算

mpu6050卡尔曼滤波姿态解算

卡尔曼滤波,是最优估计理论中十分重要的一个部分。
要全面地理解卡尔曼滤波,你需要一点统计学的知识,以及一点矩阵理论。通常最优估计理论的教材是从最小二乘估计讲起,接着讲到最小方差估计,极大似然估计以及维纳滤波,再到卡尔曼滤波、扩展卡尔曼、无迹卡尔曼-------这是从统计的角度来理解卡尔曼滤波。
事实上,卡尔曼滤波与《自动控制原理》中的状态观测器非常相似。状态观测器利用原系统的输入输出来估计系统状态,对原系统建模(状态方程,输出方程),把观测器的输出与原系统输出的差乘上一个增益反馈给观测器的状态,这样构成一个闭环系统使得观测器状态跟踪原系统状态。卡尔曼滤波中,同样要对系统建模得到状态方程,输出方程则取决于你的测量手段,因此改称量测方程。卡尔曼同样要预测量测值,并把预测值与真实量测值比较,乘上一个增益返回给状态。不同之处在于,状态观测器不考虑噪声,要求系统可检测,并且增益通常是时不变的,而卡尔曼滤波则详细考虑了噪声和初始估计误差,智能的计算每一步的增益,以达到对状态的最优的估计。


实际工程常常面临这样的情况:变量 X X X无法直接测量,能测量的是一些与 X X X相关的量 Z Z Z,通常可以得到确定的函数关系: Z = H ( X ) Z=H(X) Z=H(X),例如要用mpu6050测量转动欧拉角 ( ψ , θ , γ ) T (\psi, \theta,\gamma)^T (ψ,θ,γ)T,无法直接测量,但是加速度计的测量值与欧拉角有关系:
[ a x a y a z ] = [ − g sin ⁡ γ cos ⁡ θ g sin ⁡ θ g cos ⁡ γ cos ⁡ θ ] [axayaz]=[gsinγcosθgsinθgcosγcosθ] axayaz = gsinγcosθgsinθgcosγcosθ
由测量值Z估计状态X,典型的方法–最小二乘估计,即对X的估计— X ^ \hat X X^应当使得 E { ( Z − H ( X ^ ) ) ( Z − H ( X ^ ) ) T } E\{(Z-H(\hat X))(Z-H(\hat X))^T\} E{(ZH(X^))(ZH(X^))T}最小。典型例子如用直尺测量一支笔的长度,多次测量取平均值就是一个最简单的最小二乘估计。
实际工程中,对状态 X X X可以通过建模,给出 X X X的动力学过程: X ˙ = f ( X , t ) \dot X=f(X,t) X˙=f(X,t),若能确定初始时刻的状态 X 0 X_0 X0,那么显然初始时刻以后的状态都可以确定,对状态 X X X的确定就是一个微分方程求解的问题。然而实际系统 f ( X ) f(X) f(X)多具有复杂的形式,给出 X X X的解析解是一件困难甚至不可能的事。好在我们并不要求 X X X绝对精确的值,只需要满足精度需求的值,那么我们可以依靠数值积分方法给出状态 X X X的解,只要步长 Δ t \Delta t Δt取得足够小,龙格库塔法正是其中的一种典型方法。
X X X的动力学过程与对 Z Z Z的测量都包含有关于 X X X的信息,卡尔曼滤波正是综合运用了这两种信息来给出状态x的最优估计。
卡尔曼滤波包含两个基本方程–状态方程和量测方程,这也是卡尔曼滤波最根本的地方,但凡要实现一个卡尔曼滤波器,只要写出状态方程和量测方程,剩下的就只是代公式了,如果连状态方程和测量方程都写不出来搞不清楚,那也别谈什么实现卡尔曼滤波器。
状态方程: X k = Φ k / k − 1 X k − 1 + Γ k − 1 W k − 1 X_{k}=\Phi_{k/k-1}X_{k-1}+\Gamma_{k-1}W_{k-1} Xk=Φk/k1Xk1+Γk1Wk1
状态方程描述了状态 X X X的动力学过程, Φ k / k − 1 \Phi_{k/k-1} Φk/k1是从k-1时刻到k时刻的状态转移矩阵, Γ k − 1 \Gamma_{k-1} Γk1是k-1时刻的噪声输入矩阵, W k − 1 W_{k-1} Wk1是k-1时刻的系统噪声。
量测方程: Z k = H k X k + V k Z_{k}=H_kX_k+V_k Zk=HkXk+Vk
量测方程描述了状态与量测量的关系, V k V_k Vk是k时刻的测量噪声。
上述两个方程是标准线性卡尔曼的基本方程,它要求两个方程是线性的,还要求系统噪声 W W W和测量噪声 V V V都是白噪声。
卡尔曼的推导过程需要较强的数学基础,这里不讨论,只说明卡尔曼的具体做法和物理意义。
卡尔曼要解决的问题:若在k-1时刻估计状态为 X ^ k − 1 \hat X_{k-1} X^k1,在k时刻有一个测量 Z k Z_k Zk,那么k时刻对状态的预测 X ^ k \hat X_k X^k应该是多少呢?
回答这个问题,需要考察状态方程:
X k = Φ k / k − 1 X k − 1 + Γ k − 1 W k − 1 X_{k}=\Phi_{k/k-1}X_{k-1}+\Gamma_{k-1}W_{k-1} Xk=Φk/k1Xk1+Γk1Wk1
和量测方程:
Z k = H k X k + V k Z_{k}=H_kX_k+V_k Zk=HkXk+Vk
以及必要的假设:系统噪声 W W W和测量噪声 V V V都是白噪声,即 E ( W k ) = 0 E(W_{k})=0 E(Wk)=0 E ( W k W j T ) = Q k δ k j E(W_kW_j^T)=Q_k \delta_{kj} E(WkWjT)=Qkδkj E ( V k ) = 0 E(V_{k})=0 E(Vk)=0 E ( V k V j T ) = R k δ k j E(V_kV_j^T)=R_k \delta_{kj} E(VkVjT)=Rkδkj,并且假设k-1时刻状态估计为 X ^ k − 1 \hat X_{k-1} X^k1,误差协方差为 P k − 1 = E ( X k − 1 − X ^ k − 1 ) ( X k − 1 − X ^ k − 1 ) T P_{k-1}=E(X_{k-1}-\hat X_{k-1})(X_{k-1}-\hat X_{k-1})^T Pk1=E(Xk1X^k1)(Xk1X^k1)T
首先,既然在k-1时刻已经估计出状态为 X ^ k − 1 \hat X_{k-1} X^k1,那么k时刻的状态按照状态方程就应当预测为: X ^ k / k − 1 = Φ k / k − 1 X ^ k − 1 \hat X_{k/k-1}=\Phi_{k/k-1} \hat X_{k-1} X^k/k1=Φk/k1X^k1 X ^ k / k − 1 \hat X_{k/k-1} X^k/k1被称为状态一步预测值。
既然对k时刻状态做出预测,那么显然可以根据量测方程再对k时刻的测量值做出预测: Z ^ k = H k X ^ k / k − 1 \hat Z_k=H_k\hat X_{k/k-1} Z^k=HkX^k/k1
既然对测量做出了预测,又获得了一个真正的测量值 Z k Z_k Zk,那么显然它们的差 Z k − Z ^ k Z_k-\hat Z_k ZkZ^k反映了预测状态与真实状态的差。所以毫无疑问,需要利用这个差对状态做出修正: X ^ k = X ^ k / k − 1 + K k ( Z k − H k X ^ k / k − 1 ) \hat X_k=\hat X_{k/k-1}+K_k(Z_k-H_k\hat X_{k/k-1}) X^k=X^k/k1+Kk(ZkHkX^k/k1)
K k K_k Kk是增益阵,那么剩下的问题就是如何选取 K k K_k Kk。选取 K k K_k Kk的原则是使得误差协方差阵 E ( X k − X ^ k ) ( X k − X ^ k ) T E(X_k-\hat X_k)(X_k-\hat X_k)^T E(XkX^k)(XkX^k)T最小,按照上式,对 K k K_k Kk的选取既要考虑 X ^ k / k − 1 \hat X_{k/k-1} X^k/k1的误差协方差,也要考虑测量的噪声阵 R k R_k Rk,记 P k / k − 1 P_{k/k-1} Pk/k1 X ^ k / k − 1 \hat X_{k/k-1} X^k/k1的误差协方差阵,则 K k K_k Kk为: K k = P k / k − 1 H k T ( H k P k / k − 1 H k T + R k ) − 1 K_k=P_{k/k-1}H_k^T(H_kP_{k/k-1}H_k^T+R_k)^{-1} Kk=Pk/k1HkT(HkPk/k1HkT+Rk)1
P k / k − 1 P_{k/k-1} Pk/k1与上一步的误差协方差 P k − 1 P_{k-1} Pk1 和系统噪声 Q k − 1 Q_{k-1} Qk1有关:
P k / k − 1 = Φ k / k − 1 P k − 1 Φ k / k − 1 T + Γ k − 1 Q k − 1 Γ k − 1 T P_{k/k-1}=\Phi _{k/k-1}P_{k-1}\Phi _{k/k-1}^T+\Gamma _{k-1}Q_{k-1}\Gamma _{k-1}^T Pk/k1=Φk/k1Pk1Φk/k1T+Γk1Qk1Γk1T
到这里就确定了增益K,给出了估计 X ^ k \hat X_k X^k,最后一步是计算 X ^ k \hat X_k X^k 的误差协方差 P k P_k Pk
P k = [ I − K k H k ] T P k / k − 1 [ I − K k H k ] T + K k R k K k T P_k=[I-K_kH_k]^TP_{k/k-1}[I-K_kH_k]^T+K_kR_kK_k^T Pk=[IKkHk]TPk/k1[IKkHk]T+KkRkKkT
P k P_k Pk还有两种形式:
P k = [ I − K k H k ] P k / k − 1 P_k=[I-K_kH_k]P_{k/k-1} Pk=[IKkHk]Pk/k1 P k − 1 = P k / k − 1 − 1 + H k T R k − 1 H k P_k^{-1}=P_{k/k-1}^{-1}+H_k^TR_k^{-1}H_k Pk1=Pk/k11+HkTRk1Hk
以及 K k K_k Kk也还有一种简单形式: K k = P k H k T R k − 1 K_k=P_kH_k^TR_k^{-1} Kk=PkHkTRk1

从上述过程可以看出,卡尔曼滤波遵循“预测-修正”的思想,通过对比测量真实值与测量预测值来修正状态估计。确定增益阵K是卡尔曼滤波的核心也是精髓所在,对增益阵的计算充分考虑了初始估计误差,系统噪声,测量噪声,给出了误差最小意义下的状态最优估计。


再说一下扩展卡尔曼(EKF)。
线性卡尔曼要求状态方程和量测方程都是线性方程,在实际问题中面临最多的却是非线性系统的问题。
对于非线性的状态方程和量测方程:
X k = f ( X k − 1 , k − 1 ) + Γ k − 1 W k − 1 X_k=f(X_{k-1},k-1)+\Gamma_{k-1}W_{k-1} Xk=f(Xk1,k1)+Γk1Wk1
Z k = h ( X k , k ) + V k Z_k=h(X_k,k)+V_k Zk=h(Xk,k)+Vk
上述的基于线性方程的做法已经不再适用了。为了能对非线性系统应用卡尔曼滤波,利用泰勒展开对原非线性系统在 X k − 1 = X ^ k − 1 X_{k-1}=\hat X_{k-1} Xk1=X^k1 处做一阶线性化:
X k = f ( X ^ k − 1 , k − 1 ) + J f ( k − 1 ) ( X k − 1 − X ^ k − 1 ) + Γ k − 1 W k − 1 X_k=f(\hat X_{k-1},k-1)+J_f(k-1)(X_{k-1}-\hat X_{k-1})+\Gamma_{k-1}W_{k-1} Xk=f(X^k1,k1)+Jf(k1)(Xk1X^k1)+Γk1Wk1
Z k = h ( X k − 1 , k − 1 ) + J h ( k ) ( X k − X ^ k − 1 ) + V k Z_k=h(X_{k-1},{k-1})+J_h(k)(X_{k}-\hat X_{k-1})+V_k Zk=h(Xk1,k1)+Jh(k)(XkX^k1)+Vk
这样就能应用线性方程中的做法进行滤波,这就是扩展卡尔曼滤波。
EKF在 X k = X ^ k X_k=\hat X_k Xk=X^k处用一个线性化的方程对原非线性方程做近似,这个做法在系统非线性不强的时候能够给出比较好的估计,但是在非线性较强的时候,EKF很难获得较高的滤波精度。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/木道寻08/article/detail/888157
推荐阅读
相关标签
  

闽ICP备14008679号