1运动规划概述

2023-05-16

Motion planning

autonomous robot

在这里插入图片描述
总结一下什么是自主机器人:

首先我们需要状态估计(定位);
基于此,利用传感器融合人建立一个周围环境的三维地图;
基于状态估计和感知,运动规划模块被要求在复杂、未知的环境下能够生成安全且动力学可行的移动机器人运动轨迹;
最后交给控制器实现所生成的轨迹;
在这里插入图片描述

T(what)

basic requirements

  • safety: collision avoidance
  • smoothness: energy saving, comfort,stable
  • kinodynamic feasibility: executable , controllable
    本门课程运动规划的风格,是把整个规划问题分为前端(路径发现/路径搜索)和后端(轨迹生成/轨迹优化)。在前端,要在一个相对低维的状态空间(通常是离散的),去找一个初始的、安全的、让机器人课通行的一个初始值,解的质量可能不是很好,我们称之为Path,这个路径通常是没有时间信息的并且只局限在低维的信息。之后我们再通过后端的轨迹优化,把这样一个低维的Path转变为可执行的高维的轨迹,会用到很多优化的技巧。

w(How)

在这里插入图片描述
首先要有一个对规划的总体认知,针对不同的场景不同的需求选择合适的算法,并且常常需要设计一些自定义的策略;第二点就是要勇于去做,去调试;最后,因为规划属于一个相对顶层的位置,下面有感知定位控制机械设计等内容,所以要知道整个系统的运作才能真正的知道规划的算法是否是有效的。不需要真的去参与到那些部分的开发,但至少要熟悉,达到能够去维护的要求。

相关领域的课题组推荐

在这里插入图片描述

front-end path finding

  • search for an initial safe path
  • low dimensional
  • discrete space
    e.g search-basic ,sample-basic, kinodynmic path
    ⚫ SEARCH-BASED PATH FINDING
    ➢ Graph Search Basis
    ➢ Dijkstra and A*
    ➢ Jump Point Search
    ⚫ SAMPLING-BASED PATH FINDING
    ➢ Probabilistic Road Map
    ➢ Rapidly-exploring Random Tree (RRT)
    ➢ Optimal Sampling-based Methods
    ➢ Advanced Sampling-based Methods
    ⚫ KINODYNAMIC PATH FINDING
    ➢ Introduction
    ➢ State-state Boundary Value Optimal Control Problem
    ➢ State Lattice Search
    ➢ Kinodynamic RRT*
    ➢ Hybrid A*(在无人驾驶中应用广泛)
    在这里插入图片描述
    对于每个基于图搜索的路径规划问题,都有一个相应的状态空间图,图中节点之间的连通性用(有向或无向)边表示
    PRM
    在这里插入图片描述
    RRTvs RRT
    在这里插入图片描述
    informed RRT
    z
    在椭圆内采样,收敛时间快
  • kinematic dynamic path finding
  • state lattice search
    在这里插入图片描述

Hybrid A*
与lattice grid相似,只会在一个栅格里保留一个点
在这里插入图片描述
在这里插入图片描述
Kinodynamic RRT*
在这里插入图片描述
需要转化为两点边界值最优问题进行求解

back-end trajectory generation (后端)

  • search for an executable trajectory
  • high dimensional
  • continuous space
    e.g minimum snap trajectory generation, soft and hard constrained trajectory optimization

MDP(markov decision process-based planning)&MPC(model predictive control for robotics planning)
⚫ MINIMUM SNAP TRAJECTORY GENERATION
➢ Differential Flatness
➢ Minimum Snap Optimization
➢ Closed-form Solution to Minimum Snap
➢ Time Allocation
➢ Implementation in Practice
⚫ SOFT AND HARD CONSTRAINED TRAJECTORY OPTIMIZATION
➢ Soft Constrained Trajectory Optimization
➢ Hard Constrained Trajectory Optimization
⚫ MARKOV DECISION PROCESS-BASED PLANNING
➢ Uncertainties in Planning and MDP
➢ Minimax Cost Planning and Expected Cost Minimal Planning
➢ Value Iteration and Real-Time Dynamic Programming
⚫ MODEL PREDICTIVE CONTROL FOR ROBOTICS PLANNING
➢ Introduction
➢ Linear MPC
➢ Non-linear MPC

  • find problem
    • find actual problem
    • engineer first
  • solve
    • simple but effective solution is always preferable
    • no just simulation
      for different scenarios, suitable methods
      don’t wait ,move

Type

basic minimum-snap
在这里插入图片描述
hard constrained Minimum-snap
将安全空间表示为凸的解空间-
在这里插入图片描述
soft constrained Minimum-snap
在这里插入图片描述

Map

在这里插入图片描述
数据结构和用什么方法做数据融合

最简单 occupancy grid map
2.5D地图,在空间上堆方块

  • 特点
    密集切分
    结构化
    直接索引
    在这里插入图片描述
    但实际上障碍物不需那么多,链接
    最常用的是栅格地图表示,具有以下几个特点:最稠密;结构化;直接进行坐标索引查询:复杂度为O ( 1 )

octo-map

递归8切分地图
八叉树结构:没有障碍物的用一个大的空白方块表示,有障碍物的地方递归切分,直到找到包含障碍物的小方块 ,将其存储到内存中。
特点:稀疏;结构化;非直接的坐标索引查询(树查询)。

  • 特点
    非直接查询,需要根据树结构来查询,
    结构化
    在这里插入图片描述

voxel hashing

体素哈希
离散结构,使用哈希表访问,分成两级
坐标->block->hash table ->精确查询

  • 特点
    特别稀疏(适合于视觉地图重建)
    结构化 ,非直接的坐标索引查询
    在这里插入图片描述

point cloud map

PCL 点云数据,文档非常全,这个库可以看看
不过是无序的;无法进行坐标索引查询
在这里插入图片描述

TSDF map(truncated signed distance function

按距离进行截断
截断的有符号距离函数
应用案例
在这里插入图片描述
如果不截断,则为ESDF

ESDF map

欧式带符号的距离函数。
在这里插入图片描述
应用案例
VoxBlox
FIESTA 高飞博士和同学写的
TRR’s Local Map

在这里插入图片描述
Free-space Roadmap
凸的多面体有助于路径规划

Voronoi Diagram Map

拓扑地图

在这里插入图片描述
路径搜索节省很多资源

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

1运动规划概述 的相关文章

  • matlab绘制三维图像,用ga工具箱求解有约束的优化问题(接力遗传算法)

    绘制目标函数图像 目标函数的图像绘制为 xff08 未考虑约束条件 xff09 画法1代码 有约束的三维函数图像绘制 x1 61 10 1 10 x2 61 6 1 6 x1 x2 61 meshgrid x1 x2 f 61 exp x1
  • 多元线性回归 stata

    文章目录 回归的思想 xff0c 任务 xff0c 使命 xff0c 分类线性回归一定只能用于有线性关系的变量吗数据的分类数据的标准化处理最小二乘法拟合一元线性回归方程的几个结论回归系数的解释遗漏变量会造成内生性 xff08 扰动项和变量相
  • C++编译报错:||error: ld returned 1 exit status|

    这个问题我遇到过三次了 xff0c 每次好像原因都不一样 xff0c 在网上看到很多博客都记录了这个问题 xff0c 每人原因也都不同 xff0c 所以可以有多种原因都引发这个错误 但我不懂ld returned 1 exit status
  • C++ day34 异常(三)异常规范,未捕获异常,意外异常,异常导致内存泄漏

    文章目录 异常规范 xff08 C 43 43 98添加 xff0c C 43 43 11已摒弃 xff0c 不建议使用 xff09 异常规范的作用 xff08 正是这俩作用的鸡肋和难办使它失去了粉丝 xff09 C 43 43 11支持的
  • C++ day37 标准模板库STL初识

    文章目录 简介是什么 xff1a 容器类模板 xff0c 迭代器类模板 xff0c 函数对象模板 xff0c 算法模板的集合STL不是面向对象编程 xff0c 而是泛型编程 xff01 历史 xff1a 1994年发布 模板类vector示
  • STM32烧录 Error:Flash Download Failed-“Cortex-M3“ 解决方案—ST-Link调试

    STM32烧录 Error Flash Download Failed 34 Cortex M3 34 解决方案 ST Link调试 开发环境介绍设置步骤1 于Device中选择与你的开发板相匹配的芯片 xff0c 一般主芯片上都有标注2
  • SQL (十四)插入数据(insert语句,把数据插入表中)

    文章目录 插入完整的行 xff1a values子句不安全写法安全写法 xff1a 在表名后的括号明确给出列名小结 插入行的一部分 xff1a 简单插入某些查询的结果 xff08 即检索出的数据 xff09 xff1a insert sel
  • 模2除法(CRC冗余码计算)和二进制/十进制除法

    文章目录 CRC循环冗余检验 xff1a 余数为0就没出错 xff1b 不能确定哪几个比特出错了二进制除法 xff08 和十进制除法其实一样 xff01 xff09 模2除法 xff08 不同于二进制除法 xff01 本质就是异或而已 xf
  • latex超链接Argument of \Hy@setref@link has an extra }.错误解决

    用了 usepackage url 来在文章中写了超链接 xff0c 如 url https www baidu com 但是直接编译后没有颜色 xff0c 就是黑色的 xff0c 参考文献也是黑色的 加入下面两句代码可以让超链接显示出颜色
  • 希捷移动硬盘更换文件系统(exfat vs NTFS)

    毕业资料多 xff0c 专门买了个移动硬盘 xff0c 希捷的 2T 第一次买移动硬盘 xff0c 以为和常规U盘一样 xff0c 买来没仔细看说明书就直接用上了 xff0c 但是使用过程中老出问题 xff0c 比如从featurize平台
  • LPWAN——Sigfox实战经验介绍

    0 序 最近半年的时间一直在从事这方面的开发工作 xff0c 到目前为止对于Sigfox有一定想法和经验 xff0c 同时目前国内对于该技术的使用和应用还处在刚刚起步的阶段 xff0c 很多博客对Sigfox的讲解是一个浅尝辄止的介绍 xf
  • 拉格朗日乘子法详解(Lagrange multiplier)

    最近在视频的变换编码里推导最优变换 xff08 KL变换 xff09 时需要用拉格朗日乘子法 xff0c 之前在机器学习的各种优化问题里也要用到这个方法 xff0c 特此仔细钻研一番 xff0c 总结如下 xff1a 注 xff1a 这篇博
  • MATLAB求解规划问题(线性规划, 整数规划, 非线性规划)

    文章目录 基础知识规划问题的数学模型的三个要素解 线性规划Linear Programing理论示例 整数规划理论示例 非线性规划理论示例 生产实践中 xff0c 经常会遇到很多资源分配的问题 xff0c 如何分配各种资源以获得最大经济效益
  • matlab画三维图像(plot3,mesh,surf)

    二维函数的图像必须用三维坐标系画 xff0c 很多函数的图像长得很好看 xff0c 很有意思 会可视化也会有利于我们理解更深刻 xff08 1 xff09 plot3 三维曲线图 在网上看到这图觉得挺好看 xff1a t 61 0 pi 3
  • 智能小车学习笔记

    教程 视频教程 xff1b 资源网站 xff1b 可以获取模块的基础资料 xff1b 有刷电机有损耗 电机选型考虑 xff1a 转速和额定电压 xff1b 电机的力矩 xff0c 减速电机减速箱的作用 xff1a 减速 增大力矩 xff08
  • C++ 容器详解

    顺序容器vectorlistdequestackqueuepriority queue 关联容器mapmultimapsetmultiset 无序容器容器的互相比较迭代器 顺序容器 顺序容器类型特点vector可变大小数组支持快速随机访问
  • Cmake入门&运行保存C/C++文件

    Cmake入门 amp 运行保存C C 43 43 文件 在ubuntu创建 保存 运行c 43 43 文件CMake入门创建文件编译 参考 最近在学习Intel realsense T265双目视觉 xff0c 其中一步需要创建源文件ma
  • NVIDIA Jetson TX2 上手指南

    文章目录 一个性能强大的边缘设备我和 NVIDIA Jetson TX2 的初体验Fresh Your TX2为什么在第一步取消Host Machine可能遇到的问题 用上最好的性能 xff0c 小风扇跳舞吧 xff5e xff5e 运行一
  • extern "C"的作用以及为什么要使用extern "C"

    实现c 43 43 代码能够调用其他c语言代码 xff0c 加上extern 34 C 34 后 xff0c 这部分代码编译器以c语言的方式进行编译和链接 xff0c 而不是按c 43 43 方式原因 xff1a c和c 43 43 对同一

随机推荐

  • 什么是链表?(图解)

    一 xff1a 链表是什么 1 链表是物理存储单元上非连续的 非顺序的存储结构 xff0c 数据元素的逻辑顺序是通过链表的指针地址实现 xff0c 有一系列结点 xff08 地址 xff09 组成 xff0c 结点可动态的生成 2 结点包括
  • C++ STL各个容器的区别

    1 STL容器分类 xff1a STL的容器可以分为以下几个大类 一 顺序 xff08 序列 xff09 容器 xff0c 有vector list deque string stack 适配器类 queue 适配器类 priority q
  • Bat脚本-编译及烧录keil-MDK工程

    目录 概述背景需求需求分析需求实现实现功能使用示例1 修改脚本中的编译软件路径2 将脚本的文件路径加入系统的环境变量3 通过Vscode 进行调用 可进一步优化的方向总结 概述 本文主要讲述的是一个关于调用keil MDK的软件编译对应单片
  • ubuntu部署http服务器

    一 安装apache2 sudo apt install y apache2 二 配置环境 默认是80端口 xff0c 防止冲突自定义端口 xff1a 8001 1 修改 etc apache2 ports conf文件j监听端口 List
  • c/c++math.h标准库

    math h数学函数 这个库中所有可用的函数取double参数并返回double的结果 abs 绝对值 acos 反余弦 acosh 反双曲余弦 asin 反正弦 asinh 反双曲正弦 atan2 两个参数的反正切 atan 反正切 at
  • Linux Simulink打不开——unable to run the MATLABWindow application on Linux

    Linux Simulink打不开 unable to run the MATLABWindow application on Linux 解决办法 xff1a 解决办法 xff1a 参考网页 xff1a https www mathwor
  • RTX移植STM32F103,超详细~

    目录 RTX移植前言移植1 创建工程2 配置工程3 添加LED文件4 编写测试代码5 编译烧录 RTX移植 往期回顾 为什么需要RTOS 前言 keil RTX是一款应用广泛的嵌入式RTOS xff0c 具体可见官网 为什么需要RTOS x
  • 基于28035的ePWM触发ADC采样设计

    目录 前言实验目的实验要求硬件电路实验步骤代码解释实验结果总结体会 前言 玖道最近在做一个开关电源项目 xff0c 需要用到TI 的TMS320F28035 芯片 xff0c 实现控制电路的设计 简单来说就是利用28035采集信号量 xff
  • 浅析DSP28035的看门狗模块

    目录 背景工作原理结构与寄存器代码实验结果总结 背景 嵌入式系统通常会使用DSP来实现控制功能 xff0c 比如开关电源的数字控制 试想如果DSP中程序出现Bug 崩溃 跑飞了怎么办 xff1f 如果不及时处理 xff0c 这对整个嵌入式系
  • 浅析TMS320F28035的GPIO模块

    目录 GPIO简介硬件电路软件代码总结 通用输入输出端口 General Purpose Input Output GPIO 几乎是学习包括DSP xff0c 单片机在内的微处理器的第一步 GPIO的功能包括基本的输入 xff0c 输出 x
  • Ubuntu 20.04下配置 HAL 汇编开发环境教程

    目录 安装解压配置环境变量测试 案例 安装 环境 xff1a Ubuntu 20 04 安装包 xff1a linux64 hla tar gz 这里安装的是64位的 xff0c 具体与linux hla tar gz有什么不同 xff0c
  • 为什么单片机需要时钟系统,时钟信号在单片机中扮演怎样的角色?

    现在想想 xff0c 我自学单片机都快一年了 我自学过8051 msp430和STM32 xff0c 做一些基本的小项目 xff0c 参加过2018年江苏省电子设计大赛 xff0c 还获得了一等奖 我懂 xff0c 也不懂单片机 不懂就要去
  • Spring Security OAuth2.0认证授权学习与使用~(更新中)

    Spring Security OAuth2 0认证授权学习与使用 1 1 什么是认证1 1 1 系统为什么要认证 xff1f 1 1 2 认证 1 2 什么是会话 xff1f 1 2 1 会话1 2 2 基于Session的认证方式如下图
  • Altium中PCB上走线镀锡的方法

    Altium中PCB上走线镀锡的方法 PCB设计时 有时候需要在不增加PCB走线宽度的情况下提高该走线通过大电流的能力 载流能力 通常的方法是给该导线镀锡 或者上锡 下面以在PCB顶层走线镀锡为例 使用AD09软件 简单介绍如何走线上锡处理
  • Arduino成长日记2 - Arduino编程基础

    上一篇讲述了什么是Arduino以及各类Arduino开发板的参数 xff0c 本篇开始介绍开发环境搭建以及一些编程基础 Arduino开发环境 开发环境即Arduino项目的编程环境 Arduino IDE xff0c Arduino集成
  • 通过QGC应用TFmini Plus

    TFmini QGC中所需设置参数 xff1a EKF2 RNG AID enable EKF2 RNG MODE Range sensor SENS TFMINI CFG TELEM SERIAL 4 最后一个参数如何确定是哪一通道 xf
  • C语言格式化字符串漏洞实验

    格式化字符串漏洞实验 在线实验环境 xff1a 格式化字符串漏洞实验 文章转载自 xff1a https github com shiyanlou seedlab blob master formatstring md 一 实验描述 格式化
  • C语言Socket编程(TCP与UDP)

    C语言Socket编程 xff08 TCP与UDP xff09 UDP xff1a span class token comment udp server c span span class token macro property spa
  • ubuntu 换源深层次解析

    换源也是一个容易出错的问题 xff0c 本文以树莓派为例展开 xff0c x86也是一样的操作 那么假设成立的话 xff0c 就要记住我们是在树莓派 xff08 arm xff09 上安装的ubuntu xff0c 不是X86 xff0c
  • 1运动规划概述

    Motion planning autonomous robot 总结一下什么是自主机器人 xff1a 首先我们需要状态估计 xff08 定位 xff09 xff1b 基于此 xff0c 利用传感器融合人建立一个周围环境的三维地图 xff1