自动驾驶---Motion Planning之轨迹Path优化

news2024/9/27 5:45:09

1 背景

        在之前的几篇文章中,不管是通过构建SL图《自动驾驶---Motion Planning之Path Boundary》,ST图《自动驾驶---Motion Planning之Speed Boundary》,又或者是构建SLT图《自动驾驶---Motion Planning之构建SLT Driving Corridor》,最终我们都是为了得到boundary的信息。

        构造优化问题求解的前提:首先确定问题的代价函数,有初值,有边界(约束),然后进行求解。笔者会先阐述Apollo中轨迹横纵向优化的问题,接下来会在后面的博客中继续讲解STSC中的轨迹优化问题。

2 轨迹横向优化

        总体流程图以车道保持场景为例子进行说明。task的主要功能位于Process()函数中。规划模块的运动总体流程图如下:

82a3236d32ca47acafb65bb3bb7696d6.png

         首先有一点值得注意:在Apollo中,横纵向的优化求解是解耦开的,因此在横纵向分别需要求解一次,最终得到得到横纵向的轨迹信息(s,s',s'',l,l',l'')------这里的 eq?l%27 是 eq?l 关于 eq?s 的一阶导数, eq?s%27 是 eq?s 关于 eq?t 的一阶导数

        整体轨迹优化器的代码位于/apollo/modules/planning/tasks/optimizers。

d451c6f850db404eb37cd7dbb5272ee6.png

        见到下图,看过笔者之前的博客《自动驾驶---Motion Planning之参考线Path平滑》就非常熟悉了,之前在参考线平滑中详细讲解了这部分的内容。

030457801c22443f9511740e8bd483ec.png

        但是这次与参考线平滑不同的是:代价函数的定义。本篇博客主要讲解横向Path的优化过程,在下一篇为读者讲解纵向Speed的优化过程。

二次规划问题的形式:

eq?min%28%5Ccfrac%7B1%7D%7B2%7Dx%5ETHx+g%5ETx%29%20%5C%5C%20%5C%5C%20s.t.%20a_i%5ETx%20%3D%20b_i%2C%20i%5Cin%7BE%7D%20%5C%5C%20h_j%5ETx%5Cle%7Bt_j%7D%2C%20j%5Cin%7BI%7D

        其中eq?H是由二阶导构成的Hessian矩阵,eq?g%5ET是由梯度构成的Jacobi矩阵;然后包括m个等式约束集合和n个不等约束集合。

        Path优化问题的自变量为:eq?x%3D%5Bl_0%2Cl_1...l_%7Bn-1%7D%2Cl%27_0%2Cl%27_1%2Cl%27_2...l%27_%7Bn-1%7D%2Cl%27%27_0%2Cl%27%27_1...l%27%27_%7Bn-1%7D%5D

2.1.1 优化目标

        优化目标中主要考虑了:1)横向位移 ;2)横向速度;3)横向加速度;4)横向Jerk;5)障碍物的距离。

d2140fb606d643a48fbdad637bddbe08.png

 (注意:论文这里的代价函数与Apollo源码中有些差异,源码中没有考虑障碍物,而是增加了更接近参考点的代价以及终点的代价)

 %5CDelta%20s%29%5E2+w_%7Blend%7D%28l_%7Bn-1%7D-%20l_%7Bendl%7D%29%5C%5C%5C%5C+w_%7Bl%27end%7D%28l%27_%7Bn-1%7D-l%27_%7Bendl%7D%29+w_%7Bl%27%27end%7D%28l%27%27_%7Bn-1%7D-l%27%27_%7Bendl%7D%29

        这里提到了一个概念:分段加加速度。为了有效地制定优化问题并在实践中评估约束满意度,论文中根据空间参数 eq?s 将路径函数 eq?l%28s%29 离散到一定的分辨率 eq?%5CDelta%20s,并使用这些离散点来控制路径的形状,并近似地评估约束满意度。关键思想是将一维函数离散到二阶导数,并使用常数的三阶导数项来“连接”连续的离散点。位置变量的三阶

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

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

相关文章

基于springboot的4S店车辆管理系统

基于springboot的4S店车辆管理系统 的设计和实现 开发语言:Java 框架:springboot JDK版本:JDK1.8 服务器:tomcat7 数据库:mysql 5.7(一定要5.7版本) 数据库工具:Navicat11 开…

算法-最短路径

图的最短路径问题是一个经典的计算机科学和运筹学问题,旨在找到图中两个顶点之间的最短路径。这种问题在多种场景中都有应用,如网络路由、地图导航等。 解决图的最短路径问题有多种算法,其中最著名的包括: 1.迪杰斯特拉算法 (1).…

抖音小店怎么定类目?分享几个爆单几率大,适合新手的细分类目!

大家好,我是电商糖果 做电商的应该经常听过这么一句话,类目大于一切! 好的类目可以让商家减少很多竞争和难题。 糖果做电商有很多年了,我一直认为做店前期最难的定类目,中期是选品,后期是维护店铺。 如…

物联网数据报表分析

随着物联网技术的迅猛发展,越来越多的企业开始将物联网解决方案应用于各个领域,从提高生产效率到优化用户体验,物联网都发挥着至关重要的作用。然而,如何有效地分析和管理物联网产生的海量数据,成为企业面临的挑战之一…

【Java开发过程中的流程图】

流程图由一系列的图形符号和箭头组成,每个符号代表一个特定的操作或决策。下面是一些常见的流程图符号及其含义: 开始/结束符号(圆形):表示程序的开始和结束点。 过程/操作符号(矩形)&#xff…

<Linux> 生产者消费者模型

目录 前言: 一、什么是生产者消费者模型 (一)概念 (二)生产者消费者之间的关系 (三)生产者消费者模型特点 (四)生产者消费者模型的优点 二、基于阻塞队列实现生产…

《定时执行专家》:Nircmd 的超级搭档,解锁自动化新境界

目录 Nircmd 简介 《定时执行专家》与 Nircmd 的结合 示例: 自动清理电脑垃圾: 定时发送邮件: 定时关闭电脑: 《定时执行专家》的优势: 总结: 以下是一些其他使用示例: 立即下载《定时执行专家》: Nircmd 官方网站: 更…

代码随想录阅读笔记-栈与队列【用队列实现栈】

题目 使用队列实现栈的下列操作: push(x) -- 元素 x 入栈pop() -- 移除栈顶元素top() -- 获取栈顶元素empty() -- 返回栈是否为空 注意: 你只能使用队列的基本操作-- 也就是 push to back, peek/pop from front, size, 和 is empty 这些操作是合法的。你所使用的语言…

普发Pfeiffer镀膜机Classic580-500SP Spider600 全套资料包含操作使用说明

普发Pfeiffer镀膜机Classic580-500SP Spider600 全套资料包含操作使用说明

LeetCode---126双周赛

题目列表 3079. 求出加密整数的和 3080. 执行操作标记数组中的元素 3081. 替换字符串中的问号使分数最小 3082. 求出所有子序列的能量和 一、求出加密整数的和 按照题目要求,直接模拟即可,代码如下 class Solution { public:int sumOfEncryptedInt…

瑞芯微RK3576|触觉智能:开启科技新篇章

更多产品详情可关注深圳触觉智能官网! “瑞芯微,创新不止步!”——全新芯片RK3576即将震撼登场。指引科技风潮,创造未来无限可能!这款芯片在瑞芯微不断创新和突破的道路上,不仅是对过往成就的完美延续&…

ROS2从入门到精通0-3:VSCode 搭建 ROS2 工程环境

目录 0 专栏介绍1 Ubuntu下安装VSCode1.1 基本安装1.2 将VSCode添加到侧边栏 2 VSCode集成相关插件3 VSCode运行ROS2环境步骤3.1 安装编译依赖项3.2 创建工作空间和源码空间3.3 启动VSCode与配置 4 测试工程环境4.1 C版本4.2 Python版本 0 专栏介绍 本专栏旨在通过对ROS2的系统…

【机器学习入门 】逻辑斯蒂回归和分类

系列文章目录 第1章 专家系统 第2章 决策树 第3章 神经元和感知机 识别手写数字——感知机 第4章 线性回归 文章目录 系列文章目录前言一、分类问题的数学形式二、最大似然估计三、交叉熵损失函数四、多类别分类多类别逻辑斯蒂回归归一化指数函数交叉熵误差和均方误差的比较 五…

详解JavaScript中this指向

this 原理 this 是一个指针型变量,它指向当前函数的运行环境。 1.内存的数据结构 var obj { foo: 5 };2.函数 var obj { foo: function () {} };引擎会将函数单独保存在内存中,然后再将函数的地址赋值给foo属性的value属性。 由于函数是一个单独的…

目标检测——PP-YOLO算法解读

PP-YOLO系列,均是基于百度自研PaddlePaddle深度学习框架发布的算法,2020年基于YOLOv3改进发布PP-YOLO,2021年发布PP-YOLOv2和移动端检测算法PP-PicoDet,2022年发布PP-YOLOE和PP-YOLOE-R。由于均是一个系列,所以放一起解…

聚酰亚胺PI材料难于粘接,用什么胶水粘接?那么让我们先一步步的从认识它开始(七): 聚酰亚胺PI薄膜的厚度

聚酰亚胺PI薄膜的厚度 聚酰亚胺(PI)薄膜的厚度可以根据具体的应用需求而有所不同,通常可以在几个微米(μm)到几十微米之间。下面是一些常见的聚酰亚胺PI薄膜的厚度范围及其应用: 1.超薄膜: 聚酰…

记录‘No module named ‘notebook.notebookapp‘’导致jupyter打不开的解决方法

最初是因为无法重命名文件的问题&#xff0c;更新了notebook&#xff0c;但是更新之后打不开了 在终端输入 jupyter notebook 报错 File "/Users/maclin/Library/Python/3.8/bin/jupyter-notebook", line 5, in <module> from notebook.notebookapp import ma…

#Linux(SSH软件安装及简单使用)

&#xff08;一&#xff09;发行版&#xff1a;Ubuntu16.04.7 &#xff08;二&#xff09;记录&#xff1a; &#xff08;1&#xff09;终端键入&#xff08;root权限&#xff09;安装 apt-get install openssh-server 安装时遇到报错 E: Could not get lock /var/lib/dpkg/…

网络编程套接字——实现简单的TCP网络程序

目录 1、TCP socket API详解 socket()&#xff1a; bind()&#xff1a; listen(): accept(): connect(): 2、简易的TCP网络程序 TcpServer.hpp TcpClient.cc Main.cc Log.hpp ThreadPool.hpp Task.hpp Init.hpp Daemon.hpp dict.txt Makefile 1、TCP socket A…

基于springboot+vue+Mysql的“智慧食堂”设计与实现

开发语言&#xff1a;Java框架&#xff1a;springbootJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包&#xff1a;…