【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

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

相关推荐
无限进步_3 分钟前
【C++】验证回文字符串:高效算法详解与优化
java·开发语言·c++·git·算法·github·visual studio
浅时光_c7 分钟前
12 指针
c语言·开发语言
charlie11451419110 分钟前
嵌入式现代C++工程实践——第10篇:HAL_GPIO_Init —— 把引脚配置告诉芯片的仪式
开发语言·c++·stm32·单片机·c
call me by ur name12 分钟前
ERNIE 5.0 Technical Report论文解读
android·开发语言·人工智能·机器学习·ai·kotlin
dog25012 分钟前
细看高维空间中距离度量失效
开发语言·php
码云数智-大飞14 分钟前
Rust的所有权模型如何消除内存安全问题?与C++的RAII有何异同?
开发语言
如意猴17 分钟前
【前端】002--怎样制作一个简历界面?
开发语言·前端·javascript
夜珀20 分钟前
OpenTiny NEXT 从入门到精通·第 6 篇
开发语言·前端框架
仍然.39 分钟前
多线程---CAS,JUC组件和线程安全的集合类
java·开发语言
航Hang*41 分钟前
VMware vSphere 云平台运维与管理基础——第5章:VMware vSphere 5.5 高级特性
运维·服务器·开发语言·windows·学习·虚拟化