【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

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

相关推荐
m0_706653235 分钟前
分布式系统安全通信
开发语言·c++·算法
寻寻觅觅☆37 分钟前
东华OJ-基础题-104-A == B ?(C++)
开发语言·c++
lightqjx1 小时前
【C++】unordered系列的封装
开发语言·c++·stl·unordered系列
zh_xuan1 小时前
kotlin lazy委托异常时执行流程
开发语言·kotlin
阿猿收手吧!1 小时前
【C++】string_view:高效字符串处理指南
开发语言·c++
玄同7652 小时前
我的 Trae Skill 实践|使用 UV 工具一键搭建 Python 项目开发环境
开发语言·人工智能·python·langchain·uv·trae·vibe coding
Yorlen_Zhang2 小时前
Python Tkinter Text 控件完全指南:从基础编辑器到富文本应用
开发语言·python·c#
lxl13072 小时前
C++算法(1)双指针
开发语言·c++
不绝1912 小时前
C#进阶:预处理指令/反射,Gettype,Typeof/关键类
开发语言·c#
无小道2 小时前
Qt-qrc机制简单介绍
开发语言·qt