IMU卡尔曼滤波方法详细介绍

一、IMU 卡尔曼滤波简介

IMU 通常包含:

  • 三轴加速度计(测量比力 f
  • 三轴陀螺仪(测量角速度 ω

由于传感器存在噪声和漂移,需用 卡尔曼滤波(Kalman Filter, KF) 或其扩展形式(如 EKF)对姿态、速度、位置进行融合估计。

二、状态向量定义

我们估计以下 9 维状态向量:

x = [ p ᵀ, v ᵀ, a_b ᵀ ]ᵀ

其中:

  • p ∈ ℝ³:位置(Position)
  • v ∈ ℝ³:速度(Velocity)
  • a_b ∈ ℝ³:加速度计零偏(Bias of accelerometer)

三、系统动态模型(状态方程)

假设采样周期为 Δt,系统动态由牛顿运动学描述:

状态转移方程:

xₖ = F · xₖ₋₁ + B · uₖ + wₖ

其中:

  • uₖ = fₖ 是加速度计测量值(比力,单位:m/s²)
  • wₖ ~ N(0, Q) 是过程噪声
  • F 是状态转移矩阵(9×9)
  • B 是控制输入矩阵(9×3)

具体矩阵形式:

F =

⎡ I₃ Δt·I₃ 0₃ ⎤

⎢ 0₃ I₃ -Δt·I₃ ⎥

⎣ 0₃ 0₃ I₃ ⎦

B =

⎡ 0.5·Δt²·I₃ ⎤

⎢ Δt·I₃ ⎥

⎣ 0₃ ⎦

其中 I₃ 是 3×3 单位阵,0₃ 是 3×3 零矩阵。

物理含义:

  • 位置更新:pₖ = pₖ₋₁ + Δt·vₖ₋₁ + 0.5·Δt²·(fₖa_b,ₖ₋₁)
  • 速度更新:vₖ = vₖ₋₁ + Δt·(fₖa_b,ₖ₋₁)
  • 偏置假设缓慢变化:a_b,ₖa_b,ₖ₋₁

四、观测模型(量测方程)

假设我们有外部位置观测(如 GPS、视觉定位),提供位置测量:

zₖ = H · xₖ + vₖ

其中:

  • zₖ ∈ ℝ³:位置观测值(如 GPS 输出)
  • vₖ ~ N(0, R):观测噪声
  • H = [ I₃, 0₃, 0₃ ](3×9 矩阵,只观测位置)

若无外部观测,则无法校正加速度计偏置,需引入其他约束(如静止检测、零速修正等)。

五、卡尔曼滤波算法步骤

初始化:x̂₀ , P₀

For each time step k:

  1. 预测(Predict)
    x̂ₖ⁻ = F · x̂ₖ₋₁ + B · uₖ
    Pₖ⁻ = F · Pₖ₋₁ · F ᵀ + Q
  2. 更新(Update)
    Kₖ = Pₖ⁻ · H ᵀ · ( H · Pₖ⁻ · H ᵀ + R )⁻¹
    x̂ₖ = x̂ₖ⁻ + Kₖ · ( zₖH · x̂ₖ⁻ )
    Pₖ = ( I − Kₖ · H ) · Pₖ⁻

六、噪声协方差矩阵设定

  • Q (过程噪声协方差):反映模型不确定性
    通常设为块对角:
    Q = diag( q_p·I₃, q_v·I₃, q_b·I₃ )
    其中 q_p、q_v、q_b 为标量噪声强度。
  • R (观测噪声协方差):由传感器精度决定
    R = r_gps·I₃(例如 r_gps = 1.0 表示 GPS 1σ 误差为 1 米)
相关推荐
斐夷所非4 天前
卡尔曼滤波 | EKF、UKF 原理与实例
卡尔曼滤波
斐夷所非4 天前
卡尔曼滤波 | UKF 原理、仿真与实现
卡尔曼滤波
黑符石6 天前
【论文研读】Madgwick 姿态滤波算法报告总结
人工智能·算法·机器学习·imu·惯性动捕·madgwick·姿态滤波
点云SLAM20 天前
SLAM文献之-Embedding Manifold Structures into Kalman Filters(2)
机器人·slam·位姿估计·导航·imu·卡尔曼滤波算法·流行空间操作
点云SLAM1 个月前
四元数 (Quaternion)动力学左乘/右乘约定下之误差态 EKF 的连续线性化与离散化传播示例(11)
机器人·slam·位姿估计·imu·四元数·误差状态ekf
点云SLAM1 个月前
四元数 (Quaternion)微分-单位四元数 q(t) 的导数详细推导(10)
算法·计算机视觉·机器人·slam·imu·四元数·单位四元数求导
Evand J2 个月前
【matlabfilter例程】二维平面的雷达测角+测距目标跟踪,单个雷达,KF融合雷达和IMU数据。轨迹绘图、误差绘图输出。附代码下载链接
matlab·雷达·卡尔曼滤波·kf·跟踪·kalman·二维
Evand J2 个月前
【MATLAB例程】2雷达二维目标跟踪滤波系统-UKF(无迹卡尔曼滤波)实现,目标匀速运动模型(带扰动)。附代码下载链接
开发语言·matlab·目标跟踪·滤波·卡尔曼滤波
Evand J2 个月前
【MATLAB例程】二维平面上,三个雷达对一个目标跟踪,输出观测平均与UKF滤波两种算法的结果对比,附下载链接
matlab·平面·目标跟踪·滤波·卡尔曼滤波