路径规划——曲线拟合详解(一):多项式轨迹与QP优化(minimum-snap算法核心部分)

news2025/1/16 7:49:44

前言

历经一个多星期时间,我们在路径规划——搜索算法部分讲解了7种常见的路径搜索算法,每一种算法的链接放在下面了,有需要的朋友点击跳转即可:

路径规划——搜索算法详解(一):Dijkstra算法详解与代码_dijkstrac代码实现-CSDN博客

路径规划——搜索算法详解(二):Floyd算法详解与MATLAB代码-CSDN博客

路径规划——搜索算法详解(三):RRT算法详解与MATLAB代码-CSDN博客

路径规划——搜索算法详解(四):A*算法详解与C++代码-CSDN博客

路径规划——搜索算法详解(五):Dynamic A Star(D*)算法详解与Matlab代码-CSDN博客

路径规划——搜索算法详解(六):LPA*算法详解与Matlab代码-CSDN博客

路径规划——搜索算法详解(七):D*lite算法详解与Matlab代码-CSDN博客

以上所有算法的仿真都在笔者github上了:GitHub - Adamaser/Path-Planning

路径规划问题可以粗糙地划分为两个步骤:路径搜索与轨迹优化, 路径搜索生成可行的折线路径,但是不符合无人机、无人车的动力学,不能够直接输出给无人机、无人车直接执行。所以此时就需要进行轨迹优化,结合机器人的运动学模型,采用合适的曲线进行轨迹优化,生成光滑可行且符合机器人运动学的路径,由于笔者是做无人机方向的,所以在曲线拟合这一章中将以生成符合无人机运动学的轨迹为例讲解轨迹优化的知识。

曲线拟合部分将介绍两种无人机中常用的曲线,即多项式拟合与B样条拟合,由于其极具工程意义,所以曲线篇将会提供C++代码并且在ROS环境下进行仿真,大家可以看作是minimum-snap算法的复现,希望对大家有所帮助!

一、多项式轨迹介绍:

1.无人机的微分平坦特性

无人机12个状态量,分别为x、y、z三个维度上的位置、速度、角度、角速度,其符号表示如下:

微分平坦特性指的是可以通过对输入的高阶导数进行显示表示,以简化轨迹设计与跟踪控制的表达,可以通过选择合理的控制量对系统的控制空间进行有效降维。

简言说之,就是原有的状态空间有12个量,他们并不是相互之间互不关联的,我们从里面得到几个状态量,通过这些状态量及其高阶导数可以直接求出其他状态量,经过证明,无人机具有微分平坦特性,其状态量可以简化为以下四个量表示:

具体的证明过程大家直接搜索就可以看到很多帖子,这里就不多介绍了,所以我们可以直接通过控制x、y、z、yaw角就可以控制无人机的姿态。

2.多项式轨迹表示与约束构建:

多项式轨迹是一种常见的曲线,根据多项式的最高次数可以分为一次、二次、...、N次多项式,我们需要怎么选择次数呢,我们以五次多项式为例:

如上所示,五次多项式一共拥有p0-p5六个求解的自由度,我们可以添加6个约束条件以求得p0-p5,如下所示,我们可以先通过路径搜索算法得到如下的折线(黑色)轨迹:

我们对每段轨迹进行多项式的拟合,然后连接每一段轨迹的头与尾就可以得到一条连续的多项式轨迹,对于每一条折线轨迹,假设曲线表示为x(t),可以根据需要对起点位置x(0)、终点位置x(T)、起点速度x‘(0)、终点速度x’(T)、起点加速度x‘’(0)、终点加速度x‘’(T)进行约束:

假设此时的约束条件如下:

我们将起点t=0、终点t=T带入以下多项式中:

此外x(t)求导一次后再将起点t=0、终点t=T带入可以得到该时刻的速度、再次求导带入可以得到起点t=0、终点t=T处的加速度,此时我们将其写成矩阵形式可以得到以下的矩阵方程:

求解后我们便可得到满足上述约束条件所对应的p0-p5,此时便可以准确地表达出t=0到t=T时刻的多项式曲线,该曲线满足起点与终点的位置、速度、加速度条件。

以上求解x维度上的多项式曲线,同理我们可以求出y、z维度上的曲线,它们轨迹在各个坐标轴上是独立的,因此我们可以对其分别进行轨迹拟合。也就是说我们可以分别对它们在x , y , z进行路径生成,然后直接将三个轴合成就可以得到一个完整的空间轨迹。

3.minimum-snap算法(PPT来自深蓝学院课程笔记):

基于此思想,我们分段表示每一段折线轨迹:

 采用分段的方式表示其轨迹:

f(t)为位置、f'(t)为速度、f''(t)加速度、f'''(t)为加加速度jerk、f''''(t)为加加加速度snap,jerk可以影响无人机在该维度上的角速度,而jerk可以影响该维度上的角加速度,如下图所示:

以minimum-snap为例,由于我们要对其求4次导数,需要保证jerk是连续的(所以我们要对轨每一段轨迹的起点与终点的位置、速度、加速度、加加速度jerk进行约束,后面会说约束要怎么加),对于每一段轨迹累加其snap的最小值:

如上所示,累加每段轨迹的snap可以化为一个二次优化问题QP,通过求解该优化问题得到每一段轨迹的系数矩阵P,但是在求解之间我们需要将每一段轨迹的起点与终点的位置、速度、加速度约束加入到该优化问题中,可以通过以下方式构建约束:

通过上述方式,我们将起点与终点的导数约束统一为AP=D这一约束条件,所以我们需要求解的优化问题如下所示:

通过调用OOQP、Mosek等QP问题求解器即可得到每一段轨迹的多项式系数,即得到了该维度上的光滑曲线。

具体的大家参考该论文:

Mellinger D, Kumar V. Minimum snap trajectory generation and control for quadrotors[C]//Robotics and Automation (ICRA), 2011 IEEE International Conference on. IEEE, 2011: 2520-2525.

二、多项式轨迹仿真:

demo大家可以参考下笔者的Github吧(笔者版本为ubuntu18.04),手搓的,代码注释很详细,包括QP矩阵构建与求解都有:

Path-Planning/Astar_/src at main · Adamaser/Path-Planning (github.com)

将src放到工作空间中,直接catkin build编译,编译后运行:

roslaunch grid_path_searcher my_demo.launch 

就可以直接看到效果(绿色折线为A*搜索结果)

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

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

相关文章

redis之穿透、击穿、雪崩

目录 缓存雪崩 问题描述 缓存雪崩 问题描述 key 对应的数据存在,但在 redis 中过期,此时若有大量并发请求过来,这些请求发现缓存过期一般都会从后端数据库加载数据并回设到缓存,这个时候大并发的请求可能会瞬间把后端数据库压垮。…

GPTfinger赋能指纹识别技术,德施曼赢下这一局

生成式AI这场战局里,德施曼跑赢同行,成为行业里第一个引入GPT技术的智能锁厂商。 4月2日,德施曼智能锁在北京举办了新品发布会之前的“创新技术预沟通会”,向到场媒体揭晓了最新技术突破之一——GPTfinger。 「智哪儿」认为&…

关闭PyCharm中因双击Shift而跳出的搜索框

有时候老是多次按到shift而跳出一个搜索框,本来在编写代码,怎么突然就开始搜索了,非常的烦人。 其实这个搜索框叫做“随处搜索”。 关闭步骤 1、打开PyCharm的设置。 2、在设置-高级设置中勾选-禁用双击修改键快捷键即可。

4.3学习总结

[HNCTF 2022 WEEK2]Canyource(无参数) 通过这题又接触了一种无参数RCE的方法,前面学习的getallheaders只有在apache环境下才能使用,具有一定的局限性 这里是利用php函数来构造读取flag的方法 localeconv() – 函数返回一个包含本…

Ribbon有哪些负载均衡策略

负载均衡类都实现了IRule接口。 RandomRule:随机的选用一个实例 RoundRobinRule:轮询的使用实例 RetryRule:在轮询的基础上加了一个错误重试机制,在deadline时间内会不断的重试 WeightResponeTimeRule:根据权重去做…

Golang 开发实战day07 - Functions

Golang 教程07 - Functions 1. Functions 1.1 什么是函数? 在 Golang 中,函数就像是代码的超级组合体,可以将一段代码封装成一个独立的单元,以便重复使用。 1.2 函数声明 func funcName(parameter1 type1, parameter2 type2)…

必看!香港Web3活动周跑会指南

星移斗转,又是一年嘉年华。 去年4月,在《虚拟资产发展政策宣言》的影响下,四散的华人Web3生态再度汇集,由万向区块链实验室、HashKey Group、W3ME联合举办的Hong Kong Web3 Festival 2023率先奏响了以香港为鼓点的加密奏曲&#x…

Celery的任务流

Celery的任务流 在之前调用任务的时候只是使用delay()和apply_async()方法。但是有时我们并不想简单的执行单个异步任务,比如说需要将某个异步任务的结果作为另一个异步任务的参数或者需要将多个异步任务并行执行,返回一组返回值,为了实现此…

个人医疗开支预测项目

注意:本文引用自专业人工智能社区Venus AI 更多AI知识请参考原站 ([www.aideeplearning.cn]) 项目背景 随着医疗成本的持续上涨,个人医疗开支成为一个重要议题。理解影响医疗费用的多种因素对于医疗保险公司、政府机构以及个人…

计算机组成结构1

概念 计算机组成: 运算器、控制器、存储器、输出设备、输入设备 CPU:运算器控制器 运算器:算数逻辑单元ALU、累加寄存器AC、数据缓冲寄存器DR、状态条件寄存器PSW 控制器:指令寄存器IR、程序计数器PC、地址寄存器AR、指令译码器I…

制作ubuntu镜像及烧录

最近更换了nuc主机作为机器人的控制主机,为了避免之前在操作系统过程中把系统搞崩了的惨状决定养成定期备份系统的好习惯,这就需要掌握制作系统镜像及烧录的能力。 1、安装systemback软件 ubuntu中可以使用systemback工具进行系统的备份,这…

人工智能、深度伪造和数字身份:企业网络安全的新前沿

深度伪造(Deepfakes)的出现打响了网络安全军备竞赛的发令枪。对其影响的偏执已经波及到一系列领域,包括政治错误信息、假新闻和社交媒体操纵。 深度伪造将加剧公共领域对信任和沟通的本已严峻的压力。这将理所当然地引起监管机构和政策制定者…

鸿蒙南向开发实战:【智能窗帘】

样例简介 智能窗帘设备不仅接收数字管家应用下发的指令来控制窗帘开启的时间,而且还可以加入到数字管家的日程管理中。通过日程可以设定窗帘开关的时间段,使其在特定的时间段内,窗帘自动打开或者关闭;通过日程管家还可以实现窗帘…

Intel TBB安装​​​​

下载 windows 版本,如: oneapi-tbb-2021.11.0-win.zip Releases oneapi-src/oneTBB (github.com)https://github.com/oneapi-src/oneTBB/releases 下载后解压,执行 env 文件夹下的 vars.bat 即可 Intel TBB,全称Intel Threading Building…

idea建多级目录出现问题,报错找不到xml文件,如何解决?

🏆本文收录于「Bug调优」专栏,主要记录项目实战过程中的Bug之前因后果及提供真实有效的解决方案,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&…

Python3.10 - 列表的常用方法

01 列表的切片 lst [a, b, 1, 2, [c1, 1]]# 01 列表的切片 lst1 lst[0:2] # 从0开始切到1(顾头不顾尾), 切得长度超过1时, 切出来为list类型 print(lst1, type(lst1))lst2 lst[0] # 从中切某个元素时, 切出来的类型即元素本身, 以下同理 print(lst2, type(lst2))lst3 ls…

会声会影可以制作卡拉OK字幕吗 会声会影制作卡拉OK字幕教程 会声会影视频制作教程 会声会影模板免费下载 会声会影2023永久激活版

会声会影是一款功能强大、操作简便的视频剪辑软件,适合不同级别的用户使用,无论是初学者还是专业人员,都能够轻松地实现自己的创意和想法。这篇文章就一起来学习一下会声会影可以制作卡拉OK字幕吗,会声会影制作卡拉OK字幕教程。 …

stm32之基本定时器的使用

在上文我们使用到了HAL库的自带的延时函数,HAL_Delay();我们来看一下函数的原型 __weak void HAL_Delay(uint32_t Delay) {uint32_t tickstart HAL_GetTick();uint32_t wait Delay;/* Add a freq to guarantee minimum wait */…

数据结构算法题(力扣)——链表

以下题目建议大家先自己动手练习,再看题解代码。这里只提供一种做法,可能不是最优解。 1. 移除链表元素(OJ链接) 题目描述:给一个链表的头节点 head 和一个整数 val ,删除链表中所有满足值等于 val 的节点…

关于ansible的模块 ③

转载说明:如果您喜欢这篇文章并打算转载它,请私信作者取得授权。感谢您喜爱本文,请文明转载,谢谢。 接《关于Ansible的模块①》和《关于Ansible的模块②》,继续学习ansible的user模块。 user模块可以增、删、改linux远…