移动机器人规划 - 基于采样的路径搜索

news2025/1/9 5:54:41

0 预备知识

基于采样的规划器:
(1)不要试图显示地构造C空间及其边界
(2)只需要简单的机器人配置是否发生碰撞
(3)利用简单的碰撞测试,充分了解空间
(4)碰撞检测是一个单独的模块-可根据应用进行定制
(5)随着碰撞检测的改进,这些算法也在改进
(6)单点查询和多点查询的请求方法不同
规划的完备性概念
(1)完备规划器:在有限的时间内正确查找一条规划的路径
(2)概率完备性:如果解存在,规划器最终会找到它,使用随机采样
(3)解决方案完备性:与上述一样,但基于确定性采样(例如,在固定网格上采样)

内容概要:

(1)PRM
(2)RRT
(3)基于优化的采样方法
(4)先进的路径规划方法
(5)实现

1 PRM

论文链接:https://ieeexplore.ieee.org/abstract/document/508439/

在这里插入图片描述
PRM:
(1)图结构
(2)分解为两个阶段:①学习 ②查询
①:在C-space上采样N个点 ;删除那些在障碍物里的点;连接到最近的点,并获得无碰撞段;删除与障碍物冲突的线段。
在这里插入图片描述

②:在路线图上搜索从起点到目标的路径(使用Dijkstra算法或A* 算法);路线图现在类似于栅格地图(或简化栅格地图)
在这里插入图片描述

(3)可以有效地检查采样配置和样本之间的连接是否存在碰撞
(4)相对少的步骤和局部路径就足以捕获自由空间的连通性

PRM的优缺点
在这里插入图片描述

优点:
简单,只需要调整参数即可实现不同场景下的路径规划,且不需要对环境中的障碍物进行精确建模,在高维空间和动态环境中的路径规划有很大优势。
缺点:
①需要处理两点边界值的问题
②在状态空间上构建图,但不特别关注生成路径(不关注启发式的添加)
③该算法存在狭窄通路问题,当规划的路径需要通过密集的障碍物或者需要经过狭窄的通道时,PRM方法的效率变的低下

为了提高效率
Lazy collision-checking
①碰撞检测过程非常耗时,特别是在复杂或高维的环境中。
②采样点并生成线段,而不考虑碰撞(Lazy)
在这里插入图片描述

③必要时进行碰撞检查:在未进行碰撞检查的情况下生成的道路图上查找路径
如果路径不是无碰撞的,则删除相应的边和节点
在这里插入图片描述
④重新启动路径查找
在这里插入图片描述

PRM算法伪代码:
在这里插入图片描述
V V V表示随机点集, E E E表示路径集
①随机采样一个无碰撞的点,将这个无碰撞的点加入 V V V中,重复 n n n
②生成概率路图

  • V V V中的每个点 q q q,根据一定的距离范围选择 k k k个邻域点
  • 对每个邻域点 q ′ q' q进行判断,如果 q q q q ′ q' q尚未形成路径,则将其连接形成路径,随后进行碰撞检测,若无碰撞,则保留该路径。
  • 按上述步骤建完图,使用图搜索算法搜索出一条最短路径。

2 RRT

①算法通常将起点作为根节点 x i n i t x_{init} xinit,加入到随机树的节点集合中
②从可行区域内随机选取一个节点 x r a n d x_{rand} xrand,并在已生成的树中利用欧氏距离判断距离 x r a n d x_{rand} xrand最近的点 x n e a r x_{near} xnear
③从 x n e a r x_{near} xnear x r a n d x_{rand} xrand的连线方向上扩展固定步长 u u u,得到新节点 x n e w x_{new} xnew(如果 x n e a r x_{near} xnear x r a n d x_{rand} xrand间的距离小于步长,则直接将 x r a n d x_{rand} xrand作为新节点 x n e w x_{new} xnew)。
④若 x n e w x_{new} xnew x n e a r x_{near} xnear之间无障碍物,将 x n e w x_{new} xnew加入到随机树的节点集合中,同时将 x n e a r x_{near} xnear作为 x n e w x_{new} xnew的父节点,将边 ( x n e a r , x n e w ) (x_{near},x_{new}) (xnear,xnew)加入到随机树的边集中
⑤若这两个节点间有障碍物,则重新选择 x n e a r x_{near} xnear并进行扩展。
循环执行以上步骤,直到随机树的叶节点包含了目标点,并从中找出一条各节点连接成的从起点至终点的无碰撞路径。
在这里插入图片描述

采样过程是完全随机的,但是我们可以在采样时以一定的概率直接采样终点作为 x r a n d x_{rand} xrand ,加快搜索速度。

RRT概述:
单查询算法,目标是尽可能快的找到一条从起点到终点的可行路径;模拟树木生长时树根不断向四周扩散的过程
在这里插入图片描述

RRT的优缺点:
优点:
(1)旨在找到从开始到目标的路径,若能够获得全局环境并进行建模,可进行全局路径规划。若无法获得全局环境,如自动驾驶汽车路径规划问题,能够在动态规划中对局部地图进行规划以生成局部路径
(2)比PRM更有针对性
缺点:
(1)非最优解决方案;当路径中包含障碍物之间形成的狭窄通道时,使用RRT算法规划路径有一定几率无法规划出最优路径
(2)效率不高,留有改进空间
(3)在整个空间采样

为了提高效率:
(1)引入Kd-tree

参考博客:https://blog.csdn.net/junshen1314/article/details/51121582

在这里插入图片描述
在这里插入图片描述
(2)双向RRT / RRT连接
①RRT-Connect算法在RRT的基础上引入了双树扩展环节,分别以起点和目标点为根节点同时扩展随机树从而②实现对状态空间的快速搜索。
当两棵树建立连接时可认为路径规划成功。
③通过一次采样得到一个采样点 q r a n d q_{rand} qrand,然后两棵搜索树同时向采样点​方向进行扩展,加快两棵树建立连接的速度。相较于单树扩展的RRT算法,RRT-Connect加入了启发式步骤,加快了搜索速度,对于狭窄通道也具有较好的效果。
在这里插入图片描述

特点:
(1)Connect算法较之前的算法在扩展的步长上更长,使得树的生长更快
(2)两棵树不断朝向对方交替扩展,而不是采用随机扩展的方式,特别当起始位姿和目标位姿处于约束区域时,两棵树可以通过朝向对方快速扩展而逃离各自的约束区域
(3)带有启发性的扩展使得树的扩展更加贪婪和明确,使得双树RRT算法较之单树RRT算法更加有效

缺点:都是单查询算法,最终路径并不是最优的

总结RRT:
(1)逐步构建
(2)快速搜索
(3)关键功能:Sampling, Nearest, Collision-checking

3 基于优化的采样方法

RRT*是渐进最优算法
在这里插入图片描述

  • S a m p l e F r e e SampleFree SampleFree:在可行的区域内随机采样
  • N e a r e s t ( G , x r a n d ) Nearest(G,x_{rand}) Nearest(G,xrand):在已生成的树中利用欧氏距离判断距离 x r a n d x_{rand} xrand最近的点 x n e a r e s t x_{nearest} xnearest
  • S t e e r ( x n e a r e s t , x r a n d ) Steer(x_{nearest},x_{rand}) Steer(xnearest,xrand): 从 x n e a r e s t x_{nearest} xnearest x r a n d x_{rand} xrand的连线方向上扩展固定步长得到新节点 x n e w x_{new} xnew
  • L i n e ( x n e a r e s t , x n e w ) Line(x_nearest, x_new) Line(xnearest,xnew):两个点之间的直线距离(欧氏距离)
  • CollisionFree和ObstacleFree:都是判断两个节点之间是否有障碍物
    在这里插入图片描述
    在这里插入图片描述

Kinodynamic-RRT*
在这里插入图片描述
更改Steer()函数以适应机器人导航中的运动或其他约束

Anytime-RRT*
当机器人执行当前轨迹时,继续优化RRT树,讲究一个实时!!
在这里插入图片描述

4 基于采样的先进方法

informed RRT*(启发式)
在这里插入图片描述
在这里插入图片描述
Cross-entropy motion planning
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

5 实现

OMPL
Moveit with ROS
Tutorials
在这里插入图片描述
在这里插入图片描述


加油😀

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

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

相关文章

UKP3d的管道编辑

山西这家用户在使用UKP3d时,提出以下问题: 1、stp导入的模型怎么测量距离;另外需要把某一个点移动至原点坐标,这个怎么操作呢? 回复:dist(主要是捕捉点,推荐使用(开启精…

Cortex-M3/M4内核NVIC及HAL库函数详解(4):使用HAL库配置外部中断

0 工具准备 Keil uVision5 Cortex M3权威指南(中文) Cortex M3与M4权威指南 stm32f407的HAL库工程 STM32F4xx中文参考手册 1 使用HAL库配置外部中断 前面我们已经熟悉了有关内核部分的寄存器配置,接下来我们结合stm32f407的GPIO外设&#xf…

深耕文档型数据库12载,SequoiaDB再开源

1月15日,巨杉数据库举行SequoiaDB新特性及开源项目发布活动。本次活动回顾了巨杉数据库深耕JSON文档型数据库12年的发展历程与技术演进,全面解读了SequoiaDB包括在高可用、安全、实时、易用性四个方向的技术特性,宣布了2024年面向技术社区的开…

toolz,一个无敌的 Python 库!

更多Python学习内容:ipengtao.com 大家好,今天为大家分享一个无敌的 Python 库 - toolz。 Github地址:https://github.com/pytoolz/toolz Python是一种多用途的编程语言,具备广泛的库和框架,以支持各种编程范式&#x…

SSD硬盘数据恢复工具哪个强?分享五款好用的SSD硬盘数据恢复软件

固态硬盘 (SSD) 是数据存储领域真正的奇迹。SSD 没有机械部件,具有类似激光的读写速度,在笔记本电脑、游戏机和超级计算机中非常受欢迎。 然而,数据删除问题仍然很突出。如果您不小心删除了 SSD 中的关键数据怎么办? 5 款最佳 SS…

Python 类变量和实例变量详解

更多资料获取 📚 个人网站:ipengtao.com 在Python中,变量分为类变量和实例变量两种类型,它们有着不同的作用范围和生命周期。理解这两种变量类型的区别对于面向对象编程非常重要。本文将详细介绍Python中的类变量和实例变量&…

SATA驱动中FIS命令处理(详细)流程附代码和协议解析

目录 一、简介二、命令处理详细流程2.1 总体过程总结2.2 内存布局2.2.1 具体内存分配规则2.2.2 具体命令填充2.2.3 命令触发流程2.2.4 其他注意事项 三、其他相关链接1、SATA模块之HBA卡开发总结(一)2、SATA信息传输FIS结构总结3、PCIe物理层总结-PCIE专…

Vue2移动端项目使用$router.go(-1)不生效问题记录

目录 1、this.$router.go(-1) 改成 this.$router.back() 2、存储 from.path,使用 this.$router.push 3、hash模式中使用h5新增的onhashchange事件做hack处理 4、this.$router.go(-1) 之前添加一个 replace 方法 问题背景 : 在 Vue2 的一个移动端开发…

快速入门:使用 Gemini Embeddings 和 Elasticsearch 进行向量搜索

Gemini 是 Google DeepMind 开发的多模态大语言模型家族,作为 LaMDA 和 PaLM 2 的后继者。由 Gemini Ultra、Gemini Pro 和 Gemini Nano 组成,于 2023 年 12 月 6 日发布,定位为 OpenAI 的竞争者 GPT-4。 本教程演示如何使用 Gemini API 创建…

万界星空科技免费MES/开源MES/功能齐全,支持低代码大屏

目前国内智能制造如火如荼,工厂信息化、数字化是大趋势。如果找到一个工厂,搞定一个老板,搞软件的朋友就能吃几年。 开源软件不失为一条路子,大量的服务商选择开源MES做出了低成本的项目,收入也还可以。 今天介绍Git…

Linux 驱动开发基础知识——认识LED驱动程序 (二)

个人名片: 🦁作者简介:一名喜欢分享和记录学习的在校大学生 🐯个人主页:妄北y 🐧个人QQ:2061314755 🐻个人邮箱:2061314755qq.com 🦉个人WeChat:V…

文件处理的重定义,dup2函数

目录 1.了解dup2函数的参数意义 2.举例子了解dup2函数 3.在模拟shell中加入> , >> , < 的指令 4.stdout和stderr的区别 1.了解dup2函数的参数意义 C中系统调用接口中的open-CSDN博客 可以在我上面的博客中了解到&#xff0c;文件其实是被进程以数组的形式存储…

空间解析几何在激光雷达的定位和测距中的应用

空间解析几何是一种数学工具&#xff0c;用于描述和分析空间中的几何关系。空间解析几何在激光雷达的定位和测距中起着重要的作用&#xff0c;在激光雷达的定位和测距中&#xff0c;空间解析几何可以帮助我们理解和计算激光雷达与目标物体之间的几何关系&#xff0c;通过描述和…

k8s的包管理工具helm

Helm是什么? 之前的这篇文章介绍了一开始接触k8s的时候接触到的几个命令工具 kubectl&kubelet&rancher&helm&kubeadm这几个命令行工具是什么关系&#xff1f;-CSDN博客 Helm 是一个用于管理和部署 Kubernetes 应用程序的包管理工具。它允许用户定义、安装和…

protobuf-Java使用.md

protobuf 环境配置 1、安装编译器 下载地址 直接解压缩。 2、配置环境变量 环境变量Path 中增加安装目录的路径 3、检查是否配置成功 protoc Usage: protoc [OPTION] PROTO_FILES Parse PROTO_FILES and generate output based on the options given:-IPATH, --proto_pa…

关于程序员的未来的这件事情,我是这么看的!

关于程序员的未来在哪里&#xff1f;很多想做程序员以及已经入坑的程序员都想知道&#xff0c;我作为一名工龄超过12年的资深大龄程序员&#xff0c;我其实也想知道&#xff0c;我也没办法确定程序员的未来在哪里。 或者我也不知道&#xff0c;为什么互联网当初招聘那么多的程…

10 Hadoop的安全模式及权限介绍

1、HDFS工作流程 启动NameNode&#xff0c;NameNode加载fsimage到内存&#xff0c;对内存数据执行edits log日志中的事务操作。文件系统元数据内存镜像加载完毕&#xff0c;进行fsimage和edits log日志的合并&#xff0c;并创建新的fsimage文件和一个空的edits log日志文件。N…

跟着cherno手搓游戏引擎【8】按键和鼠标的KeyCode

自定义KeyCode 先把glfw3.h里的KeyCode的定义抄到咱这里来。 在YOTO下创建KeyCode.h: #pragma once#ifdef YT_PLATFORM_WINDOWS///从glfw3中拿的 #define YT_KEY_SPACE 32 #define YT_KEY_APOSTROPHE 39 /* */ #define YT_KEY_COMMA 44…

node.js项目express的初始化

目录 1.初始化项目2.配置跨域3.开始编写API3.1准备3.2路由处理函数router_make下的user.js3.3路由模块router下的user.js3.4入口文件app.js里面去新增这段代码3.5启动项目进行测试 &#x1f44d; 点赞&#xff0c;你的认可是我创作的动力&#xff01; ⭐️ 收藏&#xff0c;你…

如何在浏览器上设置 VPN 网络虚拟专用网络

如何在DT浏览器上设置 VPN 网络 虚拟专用网络&#xff08;VPN&#xff09;是一种用公用网络架设专用网络的技术。如何在DT浏览器上设置 VPN 呢&#xff0c;先下载DT浏览器&#xff0c;建议在官方网站下载最新版&#xff0c;安装&#xff0c;在DT浏览器首页点更多&#xff0c;网…