【EKF定位滤波例程】三维空间(XYZ)速度与位置观测与滤波(使用扩展卡尔曼滤波EKF),状态量和观测量都是非线性的。附MATLAB例程下载链接

EKF 三维空间中,多维度的 强非线性 强非线性 强非线性滤波示例(位置 + 速度六维状态)
原创程序,非AI生成,保证运行成功,截图为实际运行结果

文章目录

程序概述

系统同时受到过程噪声影响,并可获得带噪声的三维位置与速度观测。为了在强非线性动力学下保持状态估计的稳定与精度,引入扩展卡尔曼滤波(EKF)对系统进行实时状态估计。

速度分量使用非线性的形式,构造强非线性,使得系统对状态变化更加敏感,适合验证 EKF 在复杂动力学下的表现。

示例程序提供:

  • 三维真实轨迹、未滤波轨迹、EKF 估计轨迹对比图
  • 六个维度的位置与速度时间对比图
  • 未滤波 vs EKF 的误差曲线
  • 各维度绝对误差的 CDF 曲线
  • 详细的误差统计输出(最大误差、均值、标准差)

运行结果

状态曲线(包括位置和速度):

对应的误差曲线:

部分代码:

程序结构:

MATLAB源代码

部分代码如下:

matlab 复制代码
% EKF三维滤波(观测为三维速度和位置),强非线性状态方程,MATLAB例程
% 6维状态: [x, y, z, vx, vy, vz]'
% 作者:matlabfilter
% 2025-12-8/Ver1

clear; clc; close all;% 清除变量、命令行和图形窗口
rng(0); % 设置随机数种子

%% 模型初始化
t = 1:1:100; %设置时间序列
dt = 1; % 时间步长

% 状态向量: [x, y, z, vx, vy, vz]' (位置x, y, z, 速度vx, vy, vz)
Q = 0.01 * diag([0.5, 0.5, 0.5, 0.1, 0.1, 0.1]); % 过程噪声协方差矩阵 (6x6)
w = sqrt(Q) * randn(size(Q, 1), length(t)); % 过程噪声
R = 1 * diag([1, 1, 1, 0.5, 0.5, 0.5]); % 观测噪声协方差矩阵 (6x6) - 观测位置和速度
v = sqrt(R) * randn(size(R, 1), length(t)); % 观测噪声
P0 = 1 * eye(6); % 初始状态协方差矩阵 (6x6)

X = zeros(6, length(t)); % 真实状态 [x, y, z, vx, vy, vz]
X(:, 1) = [0; 0; 0; 0; 0; 0]; % 初始状态
X_ekf = zeros(6, length(t)); % 扩展卡尔曼滤波估计的状态
Z = zeros(6, length(t)); % 观测值 [x_obs, y_obs, z_obs, vx_obs, vy_obs, vz_obs]
Z(:, 1) = [X(1, 1)^2 / 20; X(2, 1); X(3, 1); X(4, 1); X(5, 1); X(6, 1)] + v(:, 1); % 设置观测量初值

%% 运动模型建立
X_ = zeros(6, length(t)); %给带误差的(未滤波的)状态量建立空间
X_(:, 1) = X(:, 1); %给带误差的状态量赋初值

for i1 = 2:length(t)
    % 真实状态更新
    % 位置更新: x = x + vx*dt, y = y + vy*dt, z = z + vz*dt
    % 速度更新: vx, vy, vz根据非线性动力学更新

完整代码下载链接:
https://download.csdn.net/download/callmeup/92445103

或:
如需帮助,或有导航、定位滤波相关的代码定制需求,请联系作者⬇️

相关推荐
AM越.5 小时前
Java设计模式超详解--观察者设计模式
java·开发语言·设计模式
云上漫步者5 小时前
深度实战:Rust交叉编译适配OpenHarmony PC——sys_locale完整适配案例
开发语言·后端·rust
guygg885 小时前
基于MATLAB的精密星历内插实现方案
开发语言·matlab
专注VB编程开发20年5 小时前
c#语法和java相差多少
java·开发语言·microsoft·c#
cici158745 小时前
MATLAB中实现图像超分辨率
开发语言·matlab
kaikaile19955 小时前
基于 MATLAB 实现 近红外光谱(NIRS)血液定量分析
开发语言·matlab
爱装代码的小瓶子5 小时前
【c++进阶】在c++11之前的编译器的努力
开发语言·c++·vscode·visualstudio·编辑器·vim
蜗牛love天空5 小时前
智能指针的值传递和引用传递
开发语言·c++
☆cwlulu5 小时前
C语言关键字详解
开发语言