自动驾驶(七十六)---------Apollo MPC之代码解析

2023-11-07 23:30

本文主要是介绍自动驾驶(七十六)---------Apollo MPC之代码解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

      最近一直在调LQR上车的效果,初见成效,所以也很好奇Apollo的MPC控制算法,没有项目驱动,只能靠自己的驱动力了,这里结合代码分析理论,详细梳理一遍apollo的MPC算法。

      首先MPC的代码在apollo文件地址为:

1. 初始化

  1. 加载MPC的参数和配置:,主要包含vehicle_param、速度和转角限制等。
  2. 车辆运动学模型及其离散化:;包括矩阵A,矩阵B,矩阵C,矩阵K,矩阵R,矩阵Q,加载MPC增益调度序列,初始化滤波器。

          其中调度增益gain scheduling是一种利用一系列线性控制器,来控制非线性系统的方法,类似于汽车标定中的map图。

2. 计算控制

      计算控制的入口函数是:

      这是MPC的核心函数,输入:当前车辆状态,目标轨迹;输出:方向盘转向角度,油门,制动。下面详细看一下这个函数:

  • 计算纵向偏差,实现如下所示:       

             (1). 首先找到离轨迹最近的点: 

             (2). 计算到最近点的误差:,包含 横向偏差,横向车速,纵向偏差,纵向车速。

             (3). 计算轨迹上的预瞄点:  这里主要是用到预瞄点的曲率做为前馈。

  • 更新车辆状态: 根据车速、车身角度计算车辆新的位置信息。重新计算横向偏差、横向偏差变化率、航向角偏差、航向角偏差变化率、位置偏差、速度偏差。
  • 更新系数矩阵:  更新矩阵A,并采用双线性变换离散法进行离散化处理;更新矩阵C,并将其离散化处理;
  • 计算前馈控制量: 通过预瞄点的曲率,结合轴距和速度公式,计算预瞄点对应的方向盘转角。
  • 如果需要增加对于高速转向的增益序列,则需要将Q,R矩阵的相应参数乘以车速。并更新Q,R矩阵。设置预测时序矩阵和参考时序矩阵。
  • 初始化OSQP Solver:
  • 求解优化函数: ,这里需要稍加展开:

             Apollo MPC使用如下优化目标函数:,而OSQP优化问题的标准形式是:

            在Apollo中系统的状态方程:,而OSQP中是:需要对MPC优化问题进行重新构造,从而适配接口。

  • MPC算法求得两个最优值:车轮转角,加速度。之后将车轮转角转换成方向盘转角:,同时求出当前控制量的约束值:
  • 如果允许对MPC控制进行前馈补偿,则不受约束的控制量差值=正常控制量-约束控制量,如果该差值小于差值限制值,则计算方向盘转角补偿量。否则补偿量等于0。
  • 方向盘转角=MPC计算的方向盘转角+当前车速下的方向盘转角增加量+方向盘转角补偿量:
  • 允许设置方向盘转角限制值,则限制值为最大纵向加速度*轴距/速度平方转换成方向盘转角:
  • 输出角度滤波:
  • 加速命令=MPC求出的加速反馈+reference_point点的加速度:
  • 如果满足停车条件,则加速度为最大停车减速度:
  • 根据加速度命令,查找标定表得到标定值:

       至此,整个mpc的计算过程就结束了,本文并不是从MPC的算法角度出发,单纯从apollo代码的实现角度理解MPC,想要升入理解MPC的算法可以参见我之前的文章。

    apollo开源,大大简化了传统车企的自动驾驶开发时间,但并未想百度设想的能统一自动驾驶平台,说到底百度只有软件算法的解决方案,车企找几个刚毕业的大学生也能移植改进,只有软硬结合的一整套解决方案才能真正统一自动驾驶平台。

这篇关于自动驾驶(七十六)---------Apollo MPC之代码解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/366757

相关文章

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

代码随想录冲冲冲 Day39 动态规划Part7

198. 打家劫舍 dp数组的意义是在第i位的时候偷的最大钱数是多少 如果nums的size为0 总价值当然就是0 如果nums的size为1 总价值是nums[0] 遍历顺序就是从小到大遍历 之后是递推公式 对于dp[i]的最大价值来说有两种可能 1.偷第i个 那么最大价值就是dp[i-2]+nums[i] 2.不偷第i个 那么价值就是dp[i-1] 之后取这两个的最大值就是d

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

基于51单片机的自动转向修复系统的设计与实现

文章目录 前言资料获取设计介绍功能介绍设计清单具体实现截图参考文献设计获取 前言 💗博主介绍:✌全网粉丝10W+,CSDN特邀作者、博客专家、CSDN新星计划导师,一名热衷于单片机技术探索与分享的博主、专注于 精通51/STM32/MSP430/AVR等单片机设计 主要对象是咱们电子相关专业的大学生,希望您们都共创辉煌!✌💗 👇🏻 精彩专栏 推荐订阅👇🏻 单片机

OWASP十大安全漏洞解析

OWASP(开放式Web应用程序安全项目)发布的“十大安全漏洞”列表是Web应用程序安全领域的权威指南,它总结了Web应用程序中最常见、最危险的安全隐患。以下是对OWASP十大安全漏洞的详细解析: 1. 注入漏洞(Injection) 描述:攻击者通过在应用程序的输入数据中插入恶意代码,从而控制应用程序的行为。常见的注入类型包括SQL注入、OS命令注入、LDAP注入等。 影响:可能导致数据泄

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动