[algorithm] 自动驾驶 规划 非线性优化学习系列之1 :车辆横向运动动力学详细解释

news2024/9/24 5:22:16

写在前面

最近时空联合规划很火,想学习。由于在学校主打学习新能源电力电子方向,转行后也想好好零散的知识体系。计划从车辆运动动力学习,模型预测控制(经典控制目前看主打应用,不会再去深入),非线性优化开始梳理,到最后复现时空联合规划的论文。知识梳理会进行的比较快,实际复现和代码编写会慢慢来完成。

当中如果遇到和实际问题有关的细节知识,作为自己的未来解决方案储备也会强调一下。

目前计划借助的资料有(每本书阅读相关章节):
在这里插入图片描述

车辆动力学及控制第二版

在这里插入图片描述

数值优化
在这里插入图片描述
模型预测控制
在这里插入图片描述
控制之美卷2

其他资料:深蓝学院:机器人中的数值优化

本文是车辆动力学及控制第二版学习的笔记,优先学习2-6章:

主要内容是:车辆侧向简单常用模型

第二章 车辆侧向动力学

车辆侧向运动的运动学模型

在这里插入图片描述
图片来源 Vehicle Dynamics and Control 第二版

这里书上的推导思路复现如下左图
在这里插入图片描述
感觉书上求解目的性不强,这里把为求beta的过程直接利用r相等替换掉未知的r求beta
在这里插入图片描述

此外关于求yawrate的时候我感觉一个小三角形即在知道beta后不需要联立就可以没有必要如书中相加来求,可能是为了简化,可以快速估计,tan近似为线性,而lr+lf 可以直接用轴距而不需要找质心

如果后轮不能转向则有两种思考方式, 那么还是按照左边求法,直接然后忽略后轮转角即可。或者同时由于忽略了后轮转角,角boc就是纯b,同时角obc也是直角,所以通过tan(前轮转角)=ob/ab 求出ob,再用勾股求出oc即为转弯半径。 同时b也可求出了。 有了r的同时我们还有v,所以i也可求出来w了。

对于以上这个模型的假设为:
在这里插入图片描述
在这里插入图片描述

总结:
在这里插入图片描述
图片来源 Vehicle Dynamics and Control 第二版

此外我对这个模型名字有一个疑惑,如果把车视为整个刚体的话,他有三个自由度,为什么叫二自由度模型呢?网上解说是因为横向运动是由纵向和转弯导致的。但是我依然认为如果认真来说 整车为刚体且忽略z向和 pitch roll,这个刚体还剩三个自由度。

答: 我觉得这个自由度和力学里不太一样。按照力学定义必然是三个自由度。但是这里由于该模型研究对象为横向。车辆纵向速度恒定的时候,只关注车辆yawrate和横向速度两个变化量。故称为”二“自由度。

补充 忽略后轮转向和侧偏角时可以进一步简化

见下图左图
在这里插入图片描述
见我的总结

车辆侧向运动的动力学模型

对于高速的应用最好采用动力学模型,因为车轮速度方向不再好假设为车轮朝向。

这里要求一步轮胎侧偏角,其中前轮转角知道 还要多求一步theta vf
在这里插入图片描述
这里如果认为车辆没有后轮转向则有

在这里插入图片描述
图片来源 Vehicle Dynamics and Control 第二版
注意轮胎有两个
在这里插入图片描述

整体推导见我的总结

主要是利用四个方程 :两个轮胎侧向受力模型和横向受力平衡以及转矩平衡。用已知量:车身几何,魔术系数,来表达四个被选取作为车辆运动状态的状态量回头控制量间的关系。即状态转移矩阵和控制输入矩阵。见下图。

结果为
在这里插入图片描述
对于以上这个模型的假设为:车辆自身侧偏移角不大。

如果道路有侧倾

可以在横向受力里带入侧倾公式

在这里插入图片描述
在实际工程中,该角度可以从地图(如果有)或者车道线曲率和速度求得量和总线横向加速度之差获得。但是,试验过不那么准确。或者imu有这个自由度也可以测量。同时当坡度过大的时候,轮胎模型也需要改变,在书的第13章有介绍,但是不是本次学习重点,实际有需要的时候再行学习。

定义误差模型

表述车横向状态的空间状态方程服务目的改为基于横向误差得状态描述的话,需要做如下调整:

定义状态量为从车道中心线到车辆质心的距离,相对车道的车辆方向误差。

该模型要基于三个假设,车速恒定,半径恒定,半径r不是很小,让tan可以线性化。
在这里插入图片描述
在这里插入图片描述
结果为
在这里插入图片描述
结果可以整理为上图。

当所走路线为直线的时候 则认为我期待一个不存在heading的状态(忽略beta侧偏角)那么Pi des 为0.

若考虑坡度则要再横向受力维度加上 sin bank
在这里插入图片描述
书中随后还有提供侧偏角的动力学推导方式,本人实际尚未使用,但原理和之前一样,带入受力和转矩平衡中,以及加入轮胎受力分析,这里要考虑车的速度方向与轴向不一致带来的不同,截图如下(同时还有侧倾角度)在大速度和大弯道下未来可以尝试一下。在MPC建模的时候考虑。
在这里插入图片描述
书中2.7的坐标转化本人理解所讲述意思,但是实际中坐标车辆坐标系和全局坐标系转换另有方法,待未来遇到这种做法再行研究,因为这里的e1 e2 不是一个直观的量,需要量测手段来求
而2.8 我接触的常见道路模型有散点,有三次多项式,有向量。暂时没有接触,且与我复现论文的最终目标关系不大,此两章节省略。

第三章 自动车道保持系统的转向控制

该章节本意在分析使用pid的稳定性和可控性。实际中车辆难以被优化为一个线性时不变系统,同时也不写传递函数,pid一版是在估算前馈后直接调参,虽然有很多工程细节,但是再次收敛于我的目的,不过多研究学习。同时控制我们在使用MPC时候,发现稳定性会比pid好很多。

动力学方程的稳态误差

对于在这里插入图片描述
控制输入为前轮转角 delta,其中把delta是写成状态加控制律的形式,则有
在这里插入图片描述
PI des之前提到是道路弯道有关,如果是直线则不用考虑。
书中研究使用前馈是否可确保弯道行驶的零稳态误差。文中做了拉普拉斯变换以及matlab求解,这里不深入,结果是可以确保稳态横向误差为0但是heading稳态不能保证。
在这里插入图片描述
红框下 我的理解是,稳态过弯道的时候,可以通过前馈来让横向误差为0,但是方向误差会存在。

用几何法来找到稳态转向角的方法见下图
在这里插入图片描述

基于假设半径很大,但是可以有轮胎侧偏角(带入横向动力学),且车辆处于稳态
在这里插入图片描述
则有
在这里插入图片描述
之后较为细节的讨论不做深入。只用PD不开积分足以解决大部分问题。侧倾和死区可以略微开I但是I要比较小做好饱和处理和过点清零工程我见过的简单应用基本到此为止,未来有机会再深入。
一个闭环的pid带前馈的示意图(实际我们用mpc了)
在这里插入图片描述

关于横向的控制总结到此,未来有机会深入学习,也希望大家指正批评!关于离散化空间状态方程可以用欧拉法和龙格库卡等近似,可以见老王或其他笔记,同不过深入,还可见之前总结https://blog.csdn.net/weixin_46479223/article/details/135293785

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

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

相关文章

下载音频(MP3)解决跨域,不跳转界面,直接下载

需求 项目需求,将通话记录下载下来,要求不跳转界面直接下载。 效果 代码 // 下载录音downloadRecording(data) {const url data.urlconst fileName 录音.mp3this.getOSSBlobResource(url).then(res > {this.saveFile(res, fileName)})},getOSSBlo…

车载显示,“激斗”与“换代”

编者按:车载显示,正在进入新一轮变革周期。 车载显示作为汽车智能化的重要交互终端,在过去几年,持续受益车企的大屏化、多屏化配置趋势,部分头部厂商赚得盆满钵满。 比如,作为京东方旗下唯一的车载显示模组…

apipost和curl收不到服务器响应的HTTP/1.1 404 Not Found

windows的apipost发送请求后,服务器响应了HTTP/1.1 404 Not Found,但是apipost一直显示发送中。 linux上的curl也一样。 使用wireshark抓包发现收到了响应,但是wireshark识别不了(图中是回应404后关闭了连接)&#xff…

描绘未知:数据缺乏场景的缺陷检测方案

了解更多方案内容,欢迎您访问官网:neuro-T | 友思特 机器视觉 光电检测;或联系销售经理:18124130753 导读: 深度学习模型帮助工业生产实现更加精确的缺陷检测,但其准确性可能受制于数据样本的数量。友思特…

from sklearn.preprocessing import LabelEncoder的详细用法

sklearn.preprocessing 0. 基本解释1. 用法说明2. python例子说明 0. 基本解释 LabelEncoder 是 sklearn.preprocessing 模块中的一个工具,用于将分类特征的标签转换为整数。这在许多机器学习算法中是必要的,因为它们通常不能处理类别数据。 1. 用法说…

校园跑腿小程序源码系统+代取快递+食堂超市代买+跑腿 带完整的安装代码包以及搭建教程

随着移动互联网的普及,人们越来越依赖于手机应用来解决日常生活中的各种问题。特别是在校园内,由于快递点距离宿舍较远、食堂排队人数过多等情况,学生对于便捷、高效的服务需求愈发强烈。在此背景下,校园跑腿小程序源码系统应运而…

一款相对比较强大的国产ARM单片机HC32F4A0

已经用了3年的HC32F4A0,已经对它比较熟悉了,与STM32相比它的外设使用这些的确是挺大大,不像GD32一类的单片机很多都能兼容STM32。用久了之后就更喜欢用HC32F4A0,功能强大,外设使用灵活,用点向FPGA靠拢的感觉…

模型选择实战

我们现在可以通过多项式拟合来探索这些概念。 import math import numpy as np import torch from torch import nn from d2l import torch as d2l生成数据集 给定x,我们将使用以下三阶多项式来生成训练和测试数据的标签: max_degree 20 # 多项式的最…

第四十周:文献阅读+GAN

目录 摘要 Abstract 文献阅读:结合小波变换和主成分分析的长短期记忆神经网络深度学习在城市日需水量预测中的应用 现有问题 创新点 方法论 PCA(主要成分分析法) DWT(离散小波变换) DWT-PCA-LSTM模型 研究实…

Tomcat Notes: Web Security, HTTPS In Tomcat

This is a personal study notes of Apache Tomcat. Below are main reference material. - YouTube Apache Tomcat Full Tutorial,owed by Alpha Brains Courses. https://www.youtube.com/watch?vrElJIPRw5iM&t801s 1、Overview2、Two Levels Of Web Securi…

运用ETLCloud快速实现数据清洗、转换

一、数据清洗和转换的重要性及传统方式的痛点 1.数据清洗的重要性 数据清洗、转换作为数据ETL流程中的转换步骤,是指在数据收集、处理、存储和使用的整个过程中,对数据进行检查、处理和修复的过程,是数据分析中必不可少的环节,对…

Maps基础知识

什么是Maps? 在JavaScript中,Map是一种用于存储键值对的数据结构。它类似于对象,但有一些区别。 Map对象允许任何类型的值作为键(包括对象、函数和基本数据类型),而对象只能使用字符串或符号作为键。这使得…

一次性密码 One Time Password,简称OTP

一次性密码(One Time Password,简称OTP),又称“一次性口令”,是指只能使用一次的密码。一次性密码是根据专门算法、每隔60秒生成一个不可预测的随机数字组合,iKEY一次性密码已在金融、电信、网游等领域被广…

three.js中Meshline库的使用

three.js中Meshline的使用 库的地址为什么要使用MeshLine,three.js内置的线不好用吗?MeshLine入门MeshLine的深入思考样条曲线一个问题 库的地址 https://github.com/spite/THREE.MeshLine?tabreadme-ov-file 为什么要使用MeshLine,three.js内置的线不好用吗? 确实不好用,…

一个监控小技巧,巧妙破解超低温冰箱难题!

在当今科技飞速发展的时代,超低温冰箱监控系统以其在各行各业中关键的温度控制和环境监测功能而备受关注。 超低温环境对于存储生物样本、药品和其他温度敏感物品至关重要,而监控系统则提供了实时、精准的环境数据,确保这些物品的质量和安全性…

(2)Elastix图像配准:参数文件(配准精度的关键)

文章目录 前言一、Elastix简介二、参数文件(类型)三、参数文件(定义):由多个组件组成,每个组件包含多个参数。3.1、组件的相关参数3.2、图解组件3.2.1、图解 - 金字塔(pyramid)3.2.2…

Mediasoup Demo-v3笔记(二)——server.js和room.js分析

server.js 主要运行逻辑 async function run() {// Open the interactive server.await interactiveServer();// Open the interactive client.if (process.env.INTERACTIVE true || process.env.INTERACTIVE 1)await interactiveClient();// Run a mediasoup Worker.await…

基于node.js和Vue3的医院挂号就诊住院信息管理系统

摘要: 随着信息技术的快速发展,医院挂号就诊住院信息管理系统的构建变得尤为重要。该系统旨在提供一个高效、便捷的医疗服务平台,以改善患者就医体验和提高医院工作效率。本系统基于Node.js后端技术和Vue3前端框架进行开发,利用其…

spring中循环依赖问题、Servlet 的过滤器与 Spring 拦截器区别

spring中的循环依赖问题 当A类中关联B,B类中关联A class A {B b; } class B {A a; } 正常java代码中new A时,b为null;new B时,a为null; 但是在spring中,由于对象是由spring容器管理的,当创建…

Netty Reactor 模式解析

目录 Reactor 模式 具体流程 配置 初始化 NioEventLoop ServerBootstrapAcceptor 分发 Reactor 模式 在刚学 Netty 的时候,我们肯定都很熟悉下面这张图,它就是单Reactor多线程模型。 在写Netty 服务端代码的时候,下面…