【状态估计】一维粒子滤波研究(Matlab代码实现)

news2025/1/10 10:54:37

 💥💥💞💞欢迎来到本博客❤️❤️💥💥

🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。

⛳️座右铭:行百里者,半于九十。

📋📋📋本文目录如下:🎁🎁🎁

目录

💥1 概述

📚2 运行结果

🎉3 参考文献

🌈4 Matlab代码实现


💥1 概述

一维粒子滤波(1D Particle Filter)是一种基于粒子的滤波算法,用于估计一个系统中的状态变量。下面是对一维粒子滤波的概述:

1. 系统建模:首先,需要建立系统的状态空间模型。一维粒子滤波通常描述为一个动态系统,其中状态变量在时间步中随机演化。这可以通过一个状态转移函数来建模,通常假设系统的演化是非线性的。

2. 粒子表示:在一维粒子滤波中,使用一组粒子来表示对状态变量的估计。每个粒子都是一个状态假设,对系统的可能状态进行采样,可以使用随机数生成方法来生成粒子。

3. 重采样:随着时间推移和系统演化,粒子的权重会发生变化。在一维粒子滤波中,需要对粒子进行重采样,以根据它们的权重重新分配粒子的数量。重采样的目的是为了保留那些具有较高权重的粒子,去除那些权重较低的粒子。

4. 状态更新:根据测量观测值,需要对粒子进行状态更新。这是通过计算每个粒子的观测概率来实现的。观测概率度量了一个粒子与测量值之间的一致性,可以使用测量模型来计算。

5. 状态估计:根据粒子的权重,可以计算系统状态的估计值。一种常见的方法是使用粒子的加权平均值作为状态的估计,其中权重反映了粒子的可能性。

一维粒子滤波是一种基于贝叶斯滤波原理的非参数滤波方法,可以用于状态估计和跟踪问题。它适用于非线性系统和非高斯噪声的情况,并且能够处理多模态分布。然而,粒子滤波的效率和精度受到粒子数目的影响,过多的粒子会导致计算复杂度增加,而过少的粒子会引入估计误差。

以上是对一维粒子滤波的概述,涉及系统建模、粒子表示、重采样、状态更新和状态估计等关键步骤。具体的应用案例和算法细节可以根据实际问题进行调整和扩展。

📚2 运行结果

在命令框内按一个键才能逐步完成模拟。以蓝色显示移动前的粒子(带直方图)、用红线移动后的实际位置、用洋红色线显示的测量值、运动模型向前传播并根据测量值加权的粒子(以黑色显示),以红色显示重采样粒子(带直方图)

 

 

部分代码:

%%% PLOT SETTINGS %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
f1 = figure;
set(f1,'name', 'Monte Carlo Localization')
set(0,'defaultaxesfontsize',16);
set(0,'defaulttextfontsize',16);
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

SIGmeas = 1;  %standard deviation of measurement noise
SIGproc = 0.5; %standard deviation of process noise
SIGinit = 4; %standard deviation of initial position

M = 100;  %number of particles (the more, the better the particle
%Probability Mass Function (PMF) matches the true Probability Distribution
% Function (PDF).

CHI = [SIGinit*randn(M,1), ones(M,1)/M];  %array of particles and associated weights
xACTt = SIGinit*randn(1); %true position of the robot (unknown to particles)
ut = 5; %control input (constant motion in x-direction)
max_moves = 10;
for mv = 1:max_moves
    % move ACTUAL robot
    xACTt = sample_motion_model(ut, xACTt, SIGproc);
    %take measurement

🎉3 参考文献

部分理论来源于网络,如有侵权请联系删除。

1. 杨琛, 孟翔宇, 李绪连. (2017). 一维离散曲线上的粒子滤波算法. 计算机科学, 44(11), 261-263.

2. 吉宇峰, 赵孜辰, 李燕. (2016). 一维非线性系统的粒子滤波算法研究. 计算机科学与探索, 10(7), 767-775.

3. 孙增茹, 吴琳, 张良康. (2015). 基于一维粒子滤波算法的离散状态系统状态估计. 控制工程, 22(5), 826-829.

4. 赵凯, 张余波, 郑劲松等. (2016). 基于动力系统的一维离散状态粒子滤波算法研究. 电子与信息学报, 38(9), 2359-2366.

🌈4 Matlab代码实现

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

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

相关文章

虚函数表的地址

结论 1. c多态的实现是靠虚函数表来实现的,有虚函数的类有虚函数表,没虚函数的类就没有虚函数表 2. 虚函数表是类的所有对象共用,切记是共同所有,不是一个对象所有 3. 每个虚函数成员占据虚函数表的一行,是个指针&a…

机械设计制造及其自动化专业向PLC方向发展的可行性

是的,机械设计制造及其自动化专业往PLC(可编程逻辑控制器)方向发展是可行的。PLC是一种用于控制和自动化各种机械设备和工业过程的计算机控制系统。它被广泛应用于工业自动化领域,包括制造业、能源行业、交通运输等。 我这里刚好…

001- database - 数据库

1、新的数据库进入默认有四个数据库,一般不要轻易删除; -- 创建数据库 CREATE DATABASE 数据库名 -- 查询所有数据库 SHOW DATABASES -- 使用数据库 -- USE 数据库名 -- 查询当前使用的数据库 SELECT DATABASE() -- 删除数据库 DROP DATABASE 数据库名

Rdkit|分子3D构象生成与优化

github; 地址 文章目录 Rdkit|分子3D构象生成与优化构象生成算法概述基于距离(distance-based)代码示例 距离几何算法生成3D结构距离几何ETKDG生成3D构象距离几何ETKDG生成多构象将Conformer类转为Mol类手动对齐 距离几何ETKDGMMFF生成3D构象距离几何ETK…

Sevlet规范:HttpServlet类 和 HttpServletRequest接口 源码解析

1. HTTP协议解读 什么是协议? 协议实际上是某些人,或者某些组织提前制定好的一套规范,大家都按照这个规范来,这样可以做到沟通无障碍。 协议就是一套规范,就是一套标准。由其他人或其他组织来负责制定的。 我说的话你…

PyCharm 自动添加作者信息、创建时间等信息

PyCharm 自动添加作者信息、创建时间等信息‘ 第一步 找到settings 第二步,找到下图所示位置输入下面代码,作者改成你自己的缩写,你也可以添加其他的 Project :${PROJECT_NAME} File :${NAME}.py IDE &…

【iOS】编译与链接

前言 计算机语言分为机器语言、汇编语言和高级语言。 可以将高级语言分为两种:编译语言和解释型语言(直译式语言)。 解释型语言(逐步进行解释执行) 解释语言编写的程序在每次运行时都需要通过解释器对程序进行动态…

【Leetcode】142.环形链表II

题意: 给定一个链表,返回链表开始入环的第一个节点。 如果链表无环,则返回 null。 为了表示给定链表中的环,使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。 如果 pos 是 -1,则…

多媒体开发之cgo

go语言作为近十年来优秀的现代开发语言的代表,由于继承了c语言的简洁和很多现代语言的表达方式,在广泛的应用场景中得到众多爱好者的喜爱,如何将go和c、c进行联合开发,拓展整个开发生态,不用重复造轮子,掌握…

k8s 持久化存储

我们继续来查看 k8s 的卷,上一次我们分享了将磁盘挂载到容器中,empyDir 和 gitRepo 都是会随着 pod 的启动而创建,随着 pod 的删除而销毁 那么我们或许会有这样的需求,期望在 pod 上面读取节点的文件或者使用节点的文件系统来访问…

Win10 配置ADB安装2023.7.12版本

目录 1. ADB工具介绍2. ADB安装流程 参考 Win10 配置安装ADB教程总结20200514, fastboot刷机 1. ADB工具介绍 ADB ( Android Debug Bridge),即Android 调试桥。是 Google 为开发人员提供的一种命令行工具,用于与安卓设备进行通信&#xff0…

开源网安加入东莞市大数据协会,共建安全可靠软件产业生态

​近日,开源网安成为东莞市大数据协会会员单位,与协会共同构建安全可靠软件产业生态,在科技创新、共建安全生态等方面发力,推动软件产业引领经济高质量发展,推动大湾区企业加快数字化建设进程。 东莞市大数据协会致力于…

Oracle使用PL/SQL导出表,结果显示insert语句

导出表到sql文件中有两种方法,下面我们列举两种方法的操作 1、选择工具->导出->选中要导出的表->点击sql插入->自定义导出路径以及文件,点击导出即可。当然也可以在where子句中增加条件,以便筛选导出 2、首选查询表数据&#xff…

阿里云无影云电脑使用方法_3分钟上手教程

阿里云无影云电脑即无影云电脑,云电脑如何使用?云电脑购买后没有用户名和密码,先创建用户设置密码,才可以登录连接到云电脑。云桌面想要访问公网还需要开通互联网访问功能。阿里云百科来详细说下阿里云无影云电脑从购买、创建用户…

Low-Light Image Enhancement via Stage-Transformer-Guided Network 论文阅读笔记

这是TCSVT 2023年的一篇暗图增强的论文 文章的核心思想是,暗图有多种降质因素,单一stage的model难以实现多降质因素的去除,因此需要一个multi-stage的model,文章中设置了4个stage。同时提出了用预设query向量来代表不同的降质因素…

Kubernetes 组件介绍

Kubernetes 组件 部署完 Kubernetes,便拥有了一个完整的集群 一组工作机器,称为节点, 会运行容器化应用程序。每个集群至少有一个工作节点 工作节点会托管 Pod ,而 Pod 就是作为应用负载的组件。 控制平面管理集群中的工作节点…

【JAVA8】Stream\Comparator

Stream Reduction, 给N个数值,求出其总和/最大值/最小值/均值这一类的操作,称为Reduction Option Optional类是一个可以为null的容器对象。如果值存在则isPresent()方法会返回true,调用get()方法会返回该对象。 Optional 类的引入很好的解…

<网络>UPD协议详解

UDP协议详解 网络传输的实质UDP协议端格式UDP的特点面向数据报UDP的缓冲区UDP使用注意事项基于UDP的应用层协议 网络传输的实质 在网络中,我们通过调用系统函数send/recv/write/read使用套接字来进行主机之间的网络通信,那么是不是我们在调用这几个函数…

vue3使用provideinject实现祖孙组件通讯

vue3使用provide&inject实现祖孙组件通讯 之前在使用vue2时,写过一篇博客记录父子组件的数据通讯 简单来说,父传子通过自定义属性,子传父通过自定义事件,兄弟间通过事件总线。也有更直观的vuex实现任意组件之间的数据通讯&a…

掘金量化—Python SDK文档—2.策略程序架构

目录 Python SDK文档 2.策略程序架构 2.1掘金策略程序初始化 2.2行情事件处理函数 2.3交易事件处理函数 2.4其他事件处理函数 2.5策略入口 Python SDK文档 2.策略程序架构 2.1掘金策略程序初始化 通过init 函数初始化策略,策略启动即会自动执行。在 init 函数中可以&#x…