集合卡尔曼滤波(EnsembleKalmanFilter)的MATLAB例程(三维、二维)

在这里插入图片描述

M A T L A B MATLAB MATLAB代码实现了一个三维动态系统的集合卡尔曼滤波(Ensemble Kalman Filter, EnKF)示例。代码的主要目的是通过模拟真实状态和测量值,使用 EnKF 方法对动态系统状态进行估计。

文章目录

  • 参数设置
  • 初始化真实状态
  • 定义状态转移和测量矩阵
  • 生成真实状态和测量值
  • 初始化集合卡尔曼滤波
  • 执行集合卡尔曼滤波
  • 绘制结果
  • 误差绘图
  • 总结
  • 部分代码
  • 运行结果

参数设置

  • 状态维度 (n):设置为6,表示系统有6个状态变量(如位置和速度)。
  • 测量维度 (m):设置为3,表示系统有3个测量变量。
  • 时间步数 (N):设置为100,表示模拟会进行100个时间步。
  • 集合成员数量 (num_ensemble):设置为10,表示使用10个样本进行状态估计。
  • 过程噪声和测量噪声的协方差矩阵
    • process_noise_cov 设置为较小的值,表示过程噪声较低。
    • measurement_noise_cov 设置为1,表示测量噪声较高。

初始化真实状态

  • 创建一个 nN 列的零矩阵 true_state 来存储真实状态。
  • 设置初始真实状态为 [1; 0; 2; 1; 1; 0.1],代表系统的初始位置和速度。

定义状态转移和测量矩阵

  • 状态转移矩阵 (A):定义如何从当前状态转移到下一个状态。这里使用了时间间隔 T 来更新位置和速度。
  • 测量矩阵 (H):定义如何从状态生成测量值,使用线性组合来映射状态到测量空间。

生成真实状态和测量值

  • 在一个循环中,从第二个时间步开始:
    • 使用状态转移矩阵 A 和过程噪声生成下一个真实状态。
    • 根据真实状态和测量噪声生成测量值,存储在 measurements 矩阵中。

初始化集合卡尔曼滤波

  • 生成初始集合 ensemble,所有成员都基于初始真实状态,加上随机扰动。
  • 创建一个零矩阵 estimates 用于存储每个时间步的状态估计。

执行集合卡尔曼滤波

  • 在循环中进行预测和更新步骤:
    • 预测步骤:根据状态转移矩阵更新集合成员,加入过程噪声。
    • 计算集合的均值和协方差:用于状态更新。
    • 更新步骤
      • 计算创新(观测值与预测值的差)。
      • 计算创新协方差。
      • 计算卡尔曼增益。
      • 更新集合成员,以反映新测量信息。
    • 存储当前时间步的状态估计。

绘制结果

  • 使用三维绘图(plot3)绘制真实状态、估计状态和测量值的轨迹。
  • 创建多个子图,显示不同状态变量(如 X、Y、Z 位移)的真实状态、估计状态和测量值的变化。

误差绘图

  • 新建图形窗口,绘制估计误差和观测误差。
  • 使用 fprintf 输出 X、Y、Z 轴的误差统计信息,包括最大误差和平均绝对误差。

总结

整段代码的主要目标是通过集合卡尔曼滤波算法对一个三维动态系统进行状态估计。它通过模拟真实状态和测量值的过程,展示了如何使用 EnKF 来处理动态系统,并通过可视化结果和误差分析来评估估计的准确性。

部分代码

% 集合卡尔曼滤波示例 三维
% 2024-11-12/Ver1
clear; clc; close all; % 清除工作空间,清空命令窗口,关闭所有图形窗口
rng(0); % 设置随机数生成器的种子,以确保结果可重复% 参数设置
n = 6; % 状态维度(4个状态变量)
m = 3; % 测量维度(2个测量变量)
N = 100; % 时间步数(总共进行100个时间步的模拟)
num_ensemble = 10; % 集合成员数量(使用10个样本进行估计)
process_noise_cov = 1e-5 * eye(n); % 过程噪声协方差矩阵(小值,表示低噪声)
measurement_noise_cov = 1 * eye(m); % 测量噪声协方差矩阵(较大值,表示较高噪声)% 初始化真实状态
true_state = zeros(n, N); % 创建一个n行N列的零矩阵,用于存储真实状态
true_state(:, 1) = [1; 0; 2; 1; 1 ; 0.1]; % 设置初始真实状态(X位移、X速度、Y位移、Y速度)T = 1; %时间间隔
% 状态转移矩阵
A = [1 T 0 0 0 0;  % 状态转移矩阵,定义如何从一个状态转移到下一个状态0 1 0 0 0 0 ; 0 0 1 T 0 0; 0 0 0 1 0 0;0 0 0 0 1 T;0 0 0 0 0 1];% 测量矩阵
H = [1 0 0 0 0 0; % 测量矩阵,定义如何从状态生成测量值0 0 1 0 0 0;0 0 0 0 1 0];

下载链接:https://gf.bilibili.com/item/detail/1106653012

运行结果

三维轨迹图:
在这里插入图片描述

  • 各轴状态量
    在这里插入图片描述

  • 误差曲线

在这里插入图片描述

  • 误差统计特性输出

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/14761.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

OpenGL ES 共享上下文实现多线程渲染

OpenGL ES 共享上下文时,可以共享哪些资源? 共享上下文实现多线程渲染 EGL 概念回顾 EGL 是 OpenGL ES 和本地窗口系统(Native Window System)之间的通信接口,它的主要作用: 与设备的原生窗口系统通信; 查询绘图表面的可用类型和配置; 创建绘图表面; 在OpenGL ES 和…

如何安装和使用SSH远程连接工具MobaXterm

文章目录 一、下载二、安装三、使用四、配置1、配置默认编辑器2、配置右键粘贴3、SSH配置4、关闭X-Server服务 一、下载 1、进入官网:https://mobaxterm.mobatek.net/download-home-edition.html 2、Download——>Home Edition。 3、下载绿色安装版本。 二、安…

Java项目实战II基于微信小程序的原创音乐小程序(开发文档+数据库+源码)

目录 一、前言 二、技术介绍 三、系统实现 四、文档参考 五、核心代码 六、源码获取 全栈码农以及毕业设计实战开发,CSDN平台Java领域新星创作者,专注于大学生项目实战开发、讲解和毕业答疑辅导。获取源码联系方式请查看文末 一、前言 随着移动互…

linux-文件的读写

操作系统一切皆文件,访问文件实际上就是访问硬件,因为文件都保存在硬件上,或者文件就是硬件,而要访问硬件,就需要操作系统提供的系统调用,所以c/c函数中关于访问硬件设备,基本上是由系统调用封装…

「实战应用」如何可视化 DHTMLX Scheduler 中的资源工作量?

DHTMLX Scheduler是一个全面的 UI 组件,用于处理面向业务的 Web 应用程序中复杂的调度和任务管理需求。但是,某些场景可能需要自定义解决方案。例如,如果项目的资源(即劳动力)有限,则需要确保以更高的精度分…

RNA-seq 差异分析的点点滴滴(2)

引言 本系列[1]将开展全新的转录组分析专栏,主要针对使用DESeq2时可能出现的问题和方法进行展开。 Tximeta:自动导入并附加元数据 Bioconductor 家族中的 tximeta 包,在 tximport 的基础上进行了扩展,不仅保留了原有功能&#xff…

Pycharm PyQt5 环境搭建创建第一个Hello程序

第一步: 创建Pycharm项目,下载包: pip install PyQt5 -i https://pypi.tuna.tsinghua.edu.cn/simple/pip install PyQt5-tools -i https://pypi.tuna.tsinghua.edu.cn/simple/下载好了之后,可以看到相应包: PyQt5:PyQt5是一套Python绑定Digia QT5应用的框架。Qt库是最…

安装luasocket模块时提示“sudo: luarocks:找不到命令“问题,该如何解决?

大家好,我是袁庭新。分享一个我在使用luarocks来安装luarocks模块报错的解决方法。 在Unix系统中安装LuaRocks。本文我以CentOS 7.x系统为例,来讲解如何安装LuaRocks。 $ cd /opt $ wget https://luarocks.org/releases/luarocks-3.11.1.tar.gz $ tar …

Axure安装步骤及免费替代方案

Axure作为一款强大的原型设计工具,因其丰富的功能而受到设计师的青睐。它包括动态面板、复杂表格编辑、协同设计和高保真原型设计等,这些功能可以简化复杂的设计流程,提高团队效率。本文将介绍Axure的安装方法,并探索一款新兴的Ax…

分布式数据库:架构、优势与实践应用

📝个人主页🌹:一ge科研小菜鸡-CSDN博客 🌹🌹期待您的关注 🌹🌹 分布式数据库在现代信息技术中扮演着至关重要的角色,尤其在需要处理大规模数据和实现高可用性、可扩展性的应用中更是…

小试银河麒麟系统OCR软件

0 前言 今天在国产电脑上办公,需要从一些PDF文件中复制文字内容,但是这些PDF文件是图片转换生成的,不支持文字选择和复制,除了手工输入,我们还可以使用OCR。 1 什么是OCR OCR (Optical Character Recogni…

np.zeros_like奇怪的bug

import numpy as np aa np.array([[1,2,3],[2,3,3]]) cc np.random.randn(2,3) print(aa) print(cc)bb np.zeros_like(aa) print(bb)for i in range(bb.shape[0]):for j in range(bb.shape[1]):bb[i,j] cc[i,j]print(bb)结果如下 这里发现这个bb的结果是没有赋值的 正确做…

C++(Qt)软件调试---内存泄漏分析工具MTuner (25)

C(Qt)软件调试—内存泄漏分析工具MTuner (25) 文章目录 C(Qt)软件调试---内存泄漏分析工具MTuner (25)[toc]1、概述🐜2、下载MTuner🪲3、使用MTuner分析qt程序内存泄漏🦧4、相关地址&#x1f41…

apk反编译修改教程系列-----apk应用反编译中AndroidManifest.xml详细代码释义解析 包含各种权限 代码含义

在反编译apk应用中。需要增加或者减少有些apk功能或者权限类的修改。其中大多都在于 AndroidManifest.xml文件中。了解AndroidManifest.xml其中每串代码代表的含义对修改apk有着至关重要的作用。 通过博文了解💝💝💝💝 1💝💝💝💝----AndroidManifest.xml中代…

项目功能--运营数据统计

一、需求分析 通过运营数据统计可以展示出体检机构的运营情况,包括会员数据、预约到诊数据、热门套餐等信息。我们要通过一个表格的形式来展示这些运营数据。如下图: 二、代码实现 实现步骤: 步骤一:定义数据模型,通过…

电子制造行业Top5贴片机品牌

在电子制造业的快速发展中,SMT(Surface Mount Technology)表面贴装技术扮演着至关重要的角色。贴片机作为SMT生产线的核心设备,其性能直接关系到整个生产线的效率和产品质量。 SPEA作为全球领先的自动化测试设备服务商&#xff0…

【maven踩坑】一个坑 junit报错 但真正导致这个的不是junit的原因

目录 事件起因环境和工具操作过程解决办法结束语 事件起因 报错一: Internal Error occurred. org.junit.platform.commons.JUnitException: TestEngine with ID junit-vintage failed to discover tests报错二: Internal Error occurred. org.junit.pl…

拷贝和浅拷贝的区别,以及对于循环引用如何处理深拷贝

深拷贝和浅拷贝的区别,以及对于循环引用如何处理深拷贝 浅拷贝仅拷贝对象的第一层属性值,对于基本数据类型,会复制其值;对于引用数据类型,仅复制引用地址而不复制实际的对象内容。浅拷贝后的新对象与原对象中的引用类…

gitlab与jenkins

一 gitlab代码仓库 1.1 gitlab简介 GitLab 是一个用于仓库管理系统的开源项目,使用 Git 作为代码管理工具,并在此基础上搭建起来的 web 服务。GitLab 具有很多功能,比如代码托管、持续集成和持续部署(CI/CD)、问题跟踪…

LeetCode 86.分隔链表

题目: 给你一个链表的头节点 head 和一个特定值 x ,请你对链表进行分隔,使得所有 小于 x 的节点都出现在 大于或等于 x 的节点之前。 你应当 保留 两个分区中每个节点的初始相对位置。 思路: 代码: /*** Definiti…