《概率机器人》速度运动模型gmapping中代码解析

2024-08-25 06:32

本文主要是介绍《概率机器人》速度运动模型gmapping中代码解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一个刚性移动机器人的构型通常用6个变量来描述:他的三维直角坐标系,以及相对外部坐标系的三个欧拉角(RPY 横滚 ,俯仰,偏航),所以那么在平面环境中一般用三个变量既可以描述,称之为位姿。
所以一般而平面上机器人的位姿信息也就是机器人的二维平面坐标(x,y)及其方位角 θ ,用这个向量来表示:

xyθ

没有方向的位姿就叫做位置(Location).那我们知道概率运动学中的条件密度是: p(xt|ut,xt1)
我们都是知道的 xt xt1 都是机器人的位姿, ut 是运动控制,所以这个模型描述了对 xt1 执行运动控制 ut 后,机器人索取得的运动学状态的后验分布。

速度运动模型是通过两个速度:平移速度和旋转速度来控制机器人
所以控制 ut=(vtwt)
规定逆时针旋转角速度为正,向前运动线速度为正。以下直接给出
motion_model_velocity的伪代码

这里写图片描述

其中第二行最难理解,虽然我是自我理解了 但是不知道对还是不对,所以还是不写了,上伪代码中的具体含义:初始位姿 xt1=(x y θ)T 控制 ut=(v w)T 和假想的后继位姿 xt=(x y θ)T 作为输入,控制以 Δt 执行,参数 α1 α6 是机器人的运动误差参数。

对于一些参数的设置:
Motion Model Parameters (all standard deviations of a gaussian noise model) 运动模型的参数 高斯噪声模型的所有标准偏差
- “~/srr” [double] linear noise component (x and y) 线速度的噪声分量
- “~/stt” [double] angular noise component (theta) 角速度的噪声分量
- “~/srt” [double] linear -> angular noise component 线速度与角速度之间的噪声分量
- “~/str” [double] angular -> linear noise component 角速度与线速度的噪声分量

      <param name="srr" value="0.1"/><param name="srt" value="0.2"/><param name="str" value="0.1"/><param name="stt" value="0.2"/>

误差的标准方差与给定速度成正比,指定的误差参数,建立了机器人的准确性模型,一个机器人越不精确,这些参数就会越大。
所以以上是关于基于速度信息计算 p(xt|ut,xt1) 的算法。

接下来就是要从运动模型中采样,粒子滤波并不计任意 xt,utxt1 的后验。采样时,给定 ut xt1 是为了根据从运动模型 p(xt|ut,xt1) 产生一个随机的 xt ,接下来就是根据运动模型的采样算法:
这里写图片描述

此算法的输入是 xt1 ut 根据之前的分布 p(xt|ut,xt1) 产生一个随机位姿 xt ,第2-4行是有运动学模型的误差参数来产生的新的(第5-7行)样本位姿,具体的代码如下实现:

//这里有两个drawFromMotion函数可以用于函数的重载
//参数是   输出位姿  线速度  角速度   这其中是要根据《速度运动模型》写函数   具体的理论中文版《概率机器人》P90
OrientedPoint 
MotionModel::drawFromMotion (const OrientedPoint& p, double linearMove, double angularMove) const{OrientedPoint n(p);//用于存储位姿double lm=linearMove  + fabs( linearMove ) * sampleGaussian( srr ) + fabs( angularMove ) * sampleGaussian( str ); //加了噪声的线速度对应第2行double am=angularMove + fabs( linearMove ) * sampleGaussian( srt ) + fabs( angularMove ) * sampleGaussian( stt ); //加了噪声的角速度n.x+=lm*cos(n.theta+.5*am);n.y+=lm*sin(n.theta+.5*am);n.theta+=am;n.theta=atan2(sin(n.theta), cos(n.theta));return n;
}

以上是主要的根据运动模型的一个代码,很明显里面有一个函数sampleGaussian()是十分重要的。sampleGaussian( b2 )是产生一个方差为 b2 的以0为中心的分布的一个随机样本。可以通过一下的算法实现

这里写图片描述
这个算法是从均值为0 方差为 b2 的近似正态分布和三角分布中采样的算法,其中函数 rand(x,y) 是在 [b,b] 中均匀分布的一个伪随机数的产生器。
那么程序中出现 fabs( linearMove ) * sampleGaussian( srr ) 意思就是产生一个峰值为fabs( linearMove ) 方差为srr的随机样本。这也是为什么这句话中 n.x+=lm*cos(n.theta+.5*am); 为什么乘以0.5的原因。

下图给出了采样程序的结果
不同的误差参数从速度运动模型中采样的结果
对比知道第一副是具有中等误差的采样结果,第二幅图是具有较小的角度误差和较大的平移误差的采样结果,第三图是具有较大的角度误差,较小的平移误差的结果。

*这是我个人的理解,可能有一些偏差,或者错误,有错误还请指正,当然不喜勿喷

这篇关于《概率机器人》速度运动模型gmapping中代码解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1104805

相关文章

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

Java MCP 的鉴权深度解析

《JavaMCP的鉴权深度解析》文章介绍JavaMCP鉴权的实现方式,指出客户端可通过queryString、header或env传递鉴权信息,服务器端支持工具单独鉴权、过滤器集中鉴权及启动时鉴权... 目录一、MCP Client 侧(负责传递,比较简单)(1)常见的 mcpServers json 配置

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

从原理到实战解析Java Stream 的并行流性能优化

《从原理到实战解析JavaStream的并行流性能优化》本文给大家介绍JavaStream的并行流性能优化:从原理到实战的全攻略,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的... 目录一、并行流的核心原理与适用场景二、性能优化的核心策略1. 合理设置并行度:打破默认阈值2. 避免装箱

Maven中生命周期深度解析与实战指南

《Maven中生命周期深度解析与实战指南》这篇文章主要为大家详细介绍了Maven生命周期实战指南,包含核心概念、阶段详解、SpringBoot特化场景及企业级实践建议,希望对大家有一定的帮助... 目录一、Maven 生命周期哲学二、default生命周期核心阶段详解(高频使用)三、clean生命周期核心阶