《概率机器人》速度运动模型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

相关文章

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

Python如何去除图片干扰代码示例

《Python如何去除图片干扰代码示例》图片降噪是一个广泛应用于图像处理的技术,可以提高图像质量和相关应用的效果,:本文主要介绍Python如何去除图片干扰的相关资料,文中通过代码介绍的非常详细,... 目录一、噪声去除1. 高斯噪声(像素值正态分布扰动)2. 椒盐噪声(随机黑白像素点)3. 复杂噪声(如伪

Java Spring ApplicationEvent 代码示例解析

《JavaSpringApplicationEvent代码示例解析》本文解析了Spring事件机制,涵盖核心概念(发布-订阅/观察者模式)、代码实现(事件定义、发布、监听)及高级应用(异步处理、... 目录一、Spring 事件机制核心概念1. 事件驱动架构模型2. 核心组件二、代码示例解析1. 事件定义

CSS place-items: center解析与用法详解

《CSSplace-items:center解析与用法详解》place-items:center;是一个强大的CSS简写属性,用于同时控制网格(Grid)和弹性盒(Flexbox)... place-items: center; 是一个强大的 css 简写属性,用于同时控制 网格(Grid) 和 弹性盒(F

python常见环境管理工具超全解析

《python常见环境管理工具超全解析》在Python开发中,管理多个项目及其依赖项通常是一个挑战,下面:本文主要介绍python常见环境管理工具的相关资料,文中通过代码介绍的非常详细,需要的朋友... 目录1. conda2. pip3. uvuv 工具自动创建和管理环境的特点4. setup.py5.

全面解析HTML5中Checkbox标签

《全面解析HTML5中Checkbox标签》Checkbox是HTML5中非常重要的表单元素之一,通过合理使用其属性和样式自定义方法,可以为用户提供丰富多样的交互体验,这篇文章给大家介绍HTML5中C... 在html5中,Checkbox(复选框)是一种常用的表单元素,允许用户在一组选项中选择多个项目。本

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

Python包管理工具核心指令uvx举例详细解析

《Python包管理工具核心指令uvx举例详细解析》:本文主要介绍Python包管理工具核心指令uvx的相关资料,uvx是uv工具链中用于临时运行Python命令行工具的高效执行器,依托Rust实... 目录一、uvx 的定位与核心功能二、uvx 的典型应用场景三、uvx 与传统工具对比四、uvx 的技术实

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma