自动驾驶基础一车辆模型
- 模型概述:
- 自行车动力学模型通常用于研究自行车在骑行过程中的行为,如稳定性、操控性和速度等。
- 模型可以基于不同的简化假设和复杂度,从简单的二维模型到复杂的三维模型,甚至包括骑行者的动态。
- 力学方程:
- 基础物理学方程F=ma(力 = 质量×加速度)被应用于自行车运动。在恒定速度下,这简化为FP=FR,其中FP是推进力,FR是所有阻力的总和。
- 阻力包括重力阻力(在斜坡上骑行时)、向前运动的空气阻力、滚动阻力、车轮轴承阻力和车轮转动的空气阻力等。
- 动力学建模方法:
- 自行车动力学模型可以使用不同的数学工具和方法来建立,如牛顿-欧拉方法、拉格朗日方程等。
- 拉格朗日方程以能量和功作为力学基本量,特别适用于受约束系统的动力学问题。对于自行车一人体系统,由于刚体数目较少,经典的拉格朗日方程是一个合适的选择。
- 空气动力学应用:
- 空气动力学在自行车设计中非常重要,特别是在降低风阻和提高稳定性方面。
- 通过优化车架结构、改变车手体位和车轮形状等措施,可以减少空气阻力的影响,提高自行车的速度和效率。
- 模型参数:
- 模型参数可以包括自行车的质量、车轮半径、转动惯量、阻力系数等。
- 骑行者的体重、身高、骑行技能等也会影响模型的结果。
- 动力学模型中,有几个重要的参数需要考虑
3. 算法流程
- 质量参数:
- 自行车和骑手的总质量(m):这个参数影响重力阻力和其他阻力的计算。例如,在重力阻力的公式 Fg = mgsin(arctan(G)) 中,m 代表了自行车和骑手的总质量。
- 阻力系数:
- 空气阻力系数(Cd):在向前运动的空气阻力 FA = 0.5 * Cd * A * ρ * vA^2 中,Cd 是阻力系数,代表了自行车和骑手形状的空气动力学特性。
- 滚动阻力系数:这通常与轮胎材料和路面条件有关,影响滚动阻力 FR 的大小。
- 几何尺寸:
- 自行车和骑手的正面面积(A):用于计算空气阻力。
- 自行车长度(lf 和 lr):质心到前后轮中心的距离,这些参数在车辆动态方程中用于计算轮胎的侧向力。
- 物理常数:
- 重力加速度(g):通常取 9.81 m/s^2,用于计算重力阻力。
- 空气密度(ρ):影响空气阻力的计算,通常根据环境条件(如海拔、温度等)进行调整。
- 运动学参数:
- 期望速度(v_desired):个体自由行驶时的速度,这反映了骑行者的意图和期望。
- 反应系数:包括横向和纵向两类,描述了个体对于横向和纵向个人空间的需求程度。
- 动作持续时间和避让力强度:这些参数描述了骑行者在面对障碍物或需要改变行驶方向时的反应。
- 环境参数:
- 坡度(G):影响重力阻力的计算,陡峭的坡度会对骑行者的努力产生更大的需求。
- 路面条件:这会影响滚动阻力和轮胎的侧向力。
- 传输系统效率(η):
- 在将骑手的输入功率(P_in)转换为推进功率时,需要考虑传输系统的效率。这反映了自行车机械部件(如链条、齿轮等)的摩擦损失。
- 车辆动态参数:
- 车辆的动态方程可能会包含其他参数,如车辆的转动惯量、车轮的半径和宽度等,这些参数在更复杂的模型中可能会考虑。
- 自行车尺寸参数:
- 轴距(Wheelbase):前后轮轴之间的距离,影响车辆的稳定性和操控性。
- 车轮半径(Wheel radius):用于计算车辆的滚动速度和角速度。
- 自行车高度(Bicycle height):从地面到自行车顶部的距离,可能影响空气动力学特性。
- 自行车惯性参数:
- 自行车质量分布(Mass distribution):质心位置,影响车辆的操控稳定性和侧翻阈值。
- 转动惯量(Moments of inertia):车辆绕不同轴的转动惯量,影响车辆的旋转动态。
- 轮胎参数:
- 轮胎侧偏刚度(Cornering stiffness):描述轮胎在侧向力作用下的抵抗变形能力,影响车辆的操控性和稳定性。
- 轮胎滚动摩擦系数(Rolling friction coefficient):影响滚动阻力和车辆的滑行特性。
- 骑行者参数:
- 骑行者体重(Rider weight):影响车辆的总质量和重力阻力。
- 骑行者身高(Rider height):可能用于计算骑行者的舒适骑行姿势和空气动力学特性。
- 骑行者骑行技能(Riding skill):尽管这不是一个物理参数,但骑行者的技能水平会显著影响车辆的实际动态行为。
- 操控参数:
- 方向盘/手柄转角(Steering angle):用于控制车辆的转向。
- 踏板力/功率(Pedal force/power):用于控制车辆的速度和加速度。
- 外部干扰参数:
- 风速和风向(Wind speed and direction):影响车辆的空气动力学特性和稳定性。
- 路面不平度(Road roughness):影响车辆的振动和操控稳定性。
- 控制策略参数(如果模型包含控制策略):
- 控制增益(Control gains):用于调整控制器对车辆动态行为的影响程度。
- 控制延迟(Control delay):反映实际控制系统中的响应时间延迟。
- 车辆状态参数:
- 纵向速度(Longitudinal velocity):车辆前进的速度。
- 横向速度(Lateral velocity):车辆侧向移动的速度,通常较小但在曲线行驶时很重要。
- 偏航角(Yaw angle):车辆前进方向与绝对坐标系的夹角。
- 偏航率(Yaw rate):车辆偏航角的变化率,即车辆的转向速度。
-
1. 车辆动力学模型
车辆动力学模型是描述汽车运动规律的微分方程,它通常基于牛顿第二定律(F=ma)来推导。在这个模型中,车辆的运动受到多种力的影响,包括驱动力、制动力、阻力和转弯力等。
2. 关键参数和公式
- 质量(m):车辆的质量,影响加速度和动能的计算。
- 速度(v):车辆的速度,可以分解为纵向速度(v_x)和横向速度(v_y)。
- 加速度(a):车辆的加速度,描述了速度的变化率。
- 扭矩(T):发动机或电动机产生的扭矩,与转速(n)和马力(P)的关系为 T = P × 5252 / n。
- 马力(P):发动机或电动机的功率,与扭矩和转速的关系为 P = T × n / 5252。
- 动能(KE):KE = 0.5 × m × v^2,描述了车辆由于运动而具有的能量。
- 动量(p):p = m × v,描述了车辆的质量和速度的乘积。
- 刹车距离(d):d = (初速度 - 终速度)^2 / (2 × 刹车减速度),用于估算车辆的制动距离。
- 车辆建模:根据车辆的结构和参数,建立车辆动力学模型。
- 数据采集:通过车辆传感器和控制单元实时采集车速、油门位置、制动状态等数据。
- 目标优化:根据驾驶情况和用户需求,确定优化目标,如最小化燃油消耗、最大化加速性能或最小化排放。
- 控制策略:基于动力系统模型和优化目标,采用先进的控制策略来调整引擎功率、电机输出、换挡时机等。
- 实时优化:在车辆运行过程中,根据实时采集的数据和控制策略,不断优化车辆的动力性能。
-
RK4(Runge-Kutta 4阶方法)是一种用于解决常微分方程的数值方法,以下是对其的详细解释:
- 定义与原理:
- RK4是一种高精度的算法,用于求解微分方程的数值解。
- 它是一种迭代方法,通过逐步逼近精确解来得到数值解。
- RK4方法基于泰勒级数展开的思想,通过在差商区间内取多点斜率加权平均代替导数方法来提高精度。
- 算法步骤:
- 假设要求解初值问题:(y' = f(t, y), y(t_0) = y_0)。
- RK4的迭代公式为:
(y_{n+1} = y_n + \frac{h}{6}(k_1 + 2k_2 + 2k_3 + k_4))
其中,(h) 是仿真步长,满足 (h < \text{某个给定值}),而 (k_1, k_2, k_3, k_4) 是基于当前函数值和导数值的加权斜率。 - (k_1, k_2, k_3, k_4) 的计算方式如下:
- (k_1 = f(t_n, y_n))
- (k_2 = f(t_n + \frac{h}{2}, y_n + \frac{h}{2}k_1))
- (k_3 = f(t_n + \frac{h}{2}, y_n + \frac{h}{2}k_2))
- (k_4 = f(t_n + h, y_n + hk_3))
-
def rk4(func: Callable, state: np.ndarray, dt: float = 0.01, t: float = 0, **kwargs):"""single-step fourth-order numerical integration (RK4) methodfunc: system of first order ODEsstate: current state vector [y1, y2, y3, ...]dt: discrete time step sizet: current time**kwargs: additional parameters for ODE systemreturns: y evaluated at time k+1"""# evaluate derivative at several stages within time intervalf1 = func(t, state, **kwargs)f2 = func(t + dt / 2, state + (f1 * (dt / 2)), **kwargs)f3 = func(t + dt / 2, state + (f2 * (dt / 2)), **kwargs)f4 = func(t + dt, state + (f3 * dt), **kwargs)return state + (dt / 6) * (f1 + (2 * f2) + (2 * f3) + f4)class BicycleVehicle(Vehicle):"""A dynamical bicycle model, with tire friction and slipping.See Chapter 2 of Lateral Vehicle Dynamics. Vehicle Dynamics and Control. Rajamani, R. (2011)"""MASS: float = 1 # [kg]LENGTH_A: float = Vehicle.LENGTH / 2 # [m]LENGTH_B: float = Vehicle.LENGTH / 2 # [m]INERTIA_Z: float = (1 / 12 * MASS * (Vehicle.LENGTH**2 + Vehicle.WIDTH**2)) # [kg.m2]FRICTION_FRONT: float = 15.0 * MASS # [N]FRICTION_REAR: float = 15.0 * MASS # [N]MAX_ANGULAR_SPEED: float = 2 * np.pi # [rad/s]MAX_SPEED: float = 15 # [m/s]def __init__(self, road: Road, position: Vector, heading: float = 0, speed: float = 0) -> None:super().__init__(road, position, heading, speed)self.lateral_speed = 0self.yaw_rate = 0self.theta = Noneself.A_lat, self.B_lat = self.lateral_lpv_dynamics()
相关文章:
自动驾驶基础一车辆模型
模型概述: 自行车动力学模型通常用于研究自行车在骑行过程中的行为,如稳定性、操控性和速度等。模型可以基于不同的简化假设和复杂度,从简单的二维模型到复杂的三维模型,甚至包括骑行者的动态。力学方程: 基础物理学方…...

机器学习:数据分布的漂移问题及应对方案
首先,让我们从一位高管告诉我的一个故事开始,很多读者可能对此感同身受。 大约两年前,他的公司聘请了一家咨询公司开发一个机器学习模型,帮助他们预测下周每种食品杂货需要多少,以便他们可以相应地补货。这家咨询公司…...
公链常用的共识算法
1. 工作量证明(Proof of Work, PoW) 工作原理:要求节点(矿工)解决一个数学难题,这个过程称为挖矿。第一个解决难题的矿工将有权添加一个新的区块到区块链上,并获得一定数量的加密货币作为奖励。…...
详解 Flink Table API 和 Flink SQL 之函数
一、系统内置函数 1. 比较函数 API函数表达式示例Table API,>,<,!,>,<id1001,age>18SQL,>,<,!,>,<id‘1001’&…...

rsa加签验签C#和js以及java互通
js实现rsa加签验签 https://github.com/kjur/jsrsasign 11.1.0版本 解压选择需要的版本,这里选择all版本了 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>JS RSA加签验签</title&g…...
C语言中数组和指针的关系
在C语言中,数组和指针之间存在着密切的关系,尽管它们在概念上是不同的。以下是关于C语言中数组和指针关系的一些要点: 数组名作为指针: 在大多数情况下,数组名在表达式中会被当作指向其第一个元素的指针。例如&#x…...
idea 新建一个 JSP(JavaServer Pages)项目
环境设置: 确保你的开发环境中已经安装了 Java 开发工具包(JDK)和一个 Java Web 开发的集成开发环境(IDE),比如 Eclipse、IntelliJ IDEA 或者 NetBeans。你还需要一个 Web 服务器,比如 Apache T…...
【名词解释】Unity中的表格布局组件及其使用示例
Unity中的表格布局组件通常指的是GridLayoutGroup,这是一个在Unity的UI系统中用来布局子对象的组件。它可以帮助开发者将UI元素按照网格的形式进行排列,非常适合创建表格、网格视图等布局。 名词解释: GridLayoutGroup:Unity UI…...
判断当前设备为移动端自适应 平板和pc端为375移动端样式
在libs的setRem.js中: let html document.querySelector("html"); function setRem() {let ui_w 375;let cl_w document.documentElement.clientWidth || document.body.clientWidth;cl_w > 750 ? cl_w 375 : "";html.style.fontSize …...

Science Advances|用于胃部pH监测和早期胃漏检测的生物可吸收无线无源柔性传感器(健康监测/柔性传感/柔性电子)
2024年4月19日,美国西北大学 John A. Rogers和中国科学技术大学吕頔(Di Lu)团队,在《Science Advances》上发布了一篇题为“Bioresorbable, wireless, passive sensors for continuous pH measurements and early detection of gastric leakage”的论文。论文内容如下: 一、…...

C# 使用 webview2 嵌入网页
需求:C#客户端程序, 窗口里嵌入一个web网页,可通过URL跳转的那种。并且,需要将登录的身份验证信息(token)设置到请求头里。 核心代码如下: // 打开按钮的点击事件 private void openBtn_Click(object sen…...

公司面试题总结(五)
25.谈一谈箭头函数与普通函数的区别,箭头函数主要解决什么问题? 箭头函数与普通函数的区别: ⚫ 语法简洁性: ◼ 箭头函数使用>符号定义,省略了 function 关键字,使得语法更为紧凑。 ◼ 对于单行函…...

Flutter笔记:关于WebView插件的用法(上)
Flutter笔记 关于WebView插件的用法(上) - 文章信息 - Author: 李俊才 (jcLee95) Visit me at CSDN: https://jclee95.blog.csdn.netMy WebSite:http://thispage.tech/Email: 291148484163.com. Shenzhen ChinaAddress of this article:htt…...

计算机毕业设计Python+Django农产品推荐系统 农产品爬虫 农产品商城 农产品大数据 农产品数据分析可视化 PySpark Hadoop Hive
课题研究的意义,国内外研究现状、水平和发展趋势 研究意义21世纪是一个信息爆炸的时代,人们在日常生活中可接触到的信息量非常之巨大。推荐系统逐步发展,其中又以个性化推荐系统最为瞩目。个性化推荐系统的核心在于个性化推荐算法,…...

phpcms仿蚁乐购淘宝客网站模板
phpcms仿蚁乐购网站模板,淘宝客行业模板免费下载,该模板网站很容易吸引访客点击,提升ip流量和pv是非常有利的。本套模板采用现在非常流行的全屏自适应布局设计,且栏目列表以简洁,非常时尚大气。页面根据分辨率大小而自…...

leetcode695 岛屿的最大面积
题目 给你一个大小为 m x n 的二进制矩阵 grid 。 岛屿 是由一些相邻的 1 (代表土地) 构成的组合,这里的「相邻」要求两个 1 必须在 水平或者竖直的四个方向上 相邻。你可以假设 grid 的四个边缘都被 0(代表水)包围着。 岛屿的面积是岛上值…...

小程序无法调用服务端问题排查
1、问题描述 突然有一天线上的小程序不能登录,经查小程序无法调用。经查无法小程序页面无法调用后台服务。 2、排查过程 由于无法登录小程序发布服务器,无法测试小程序前端服务器到服务端网络,并且小程序无法看到日志。所以就得从服务端和网…...

Linux:多线程的操作
多线程操作 进程与线程线程的创建 create_pthread创建线程池给线程传入对象的指针 线程等待 pthread_join退出线程 pthread_exit线程等待参数 retval 与 线程退出参数 retval 线程中断 pthread_cancel获取线程编号 pthread_self线程分离 pthread_detach 进程与线程 进程是资源…...
kunpeng的aarch64架构cpu、openeuler系统、昇腾服务器适配文档转换功能(doc转docx、ppt转pptx)
一、安装flatpak sudo yum install flatpak flatpak remote-add --if-not-exists flathub https://flathub.org/repo/flathub.flatpakrepo二、安装libreoffice flatpak install flathub org.libreoffice.LibreOffice三、使用 对于使用 flatpak 安装的 LibreOffice,不需要手…...

unity 打包PC安装包中常见文件的功能
目录 前言 一、打包好的文件 二、常用文件 1.文件夹XXX_Data 2.文件夹MonoBleedingEdge 3.文件夹XXX_Data内部 三、文件的应用 1.如果你替换了一个图片 2.如果你新增了或减少了图片和资源 3.场景中有变动 4.resources代码加载的资源改了 5.如果你代码替换了 四、作…...

CTF show Web 红包题第六弹
提示 1.不是SQL注入 2.需要找关键源码 思路 进入页面发现是一个登录框,很难让人不联想到SQL注入,但提示都说了不是SQL注入,所以就不往这方面想了 先查看一下网页源码,发现一段JavaScript代码,有一个关键类ctfs…...

树莓派超全系列教程文档--(61)树莓派摄像头高级使用方法
树莓派摄像头高级使用方法 配置通过调谐文件来调整相机行为 使用多个摄像头安装 libcam 和 rpicam-apps依赖关系开发包 文章来源: http://raspberry.dns8844.cn/documentation 原文网址 配置 大多数用例自动工作,无需更改相机配置。但是,一…...
rknn优化教程(二)
文章目录 1. 前述2. 三方库的封装2.1 xrepo中的库2.2 xrepo之外的库2.2.1 opencv2.2.2 rknnrt2.2.3 spdlog 3. rknn_engine库 1. 前述 OK,开始写第二篇的内容了。这篇博客主要能写一下: 如何给一些三方库按照xmake方式进行封装,供调用如何按…...

【入坑系列】TiDB 强制索引在不同库下不生效问题
文章目录 背景SQL 优化情况线上SQL运行情况分析怀疑1:执行计划绑定问题?尝试:SHOW WARNINGS 查看警告探索 TiDB 的 USE_INDEX 写法Hint 不生效问题排查解决参考背景 项目中使用 TiDB 数据库,并对 SQL 进行优化了,添加了强制索引。 UAT 环境已经生效,但 PROD 环境强制索…...

循环冗余码校验CRC码 算法步骤+详细实例计算
通信过程:(白话解释) 我们将原始待发送的消息称为 M M M,依据发送接收消息双方约定的生成多项式 G ( x ) G(x) G(x)(意思就是 G ( x ) G(x) G(x) 是已知的)࿰…...

P3 QT项目----记事本(3.8)
3.8 记事本项目总结 项目源码 1.main.cpp #include "widget.h" #include <QApplication> int main(int argc, char *argv[]) {QApplication a(argc, argv);Widget w;w.show();return a.exec(); } 2.widget.cpp #include "widget.h" #include &q…...
【Go】3、Go语言进阶与依赖管理
前言 本系列文章参考自稀土掘金上的 【字节内部课】公开课,做自我学习总结整理。 Go语言并发编程 Go语言原生支持并发编程,它的核心机制是 Goroutine 协程、Channel 通道,并基于CSP(Communicating Sequential Processes࿰…...
Rust 异步编程
Rust 异步编程 引言 Rust 是一种系统编程语言,以其高性能、安全性以及零成本抽象而著称。在多核处理器成为主流的今天,异步编程成为了一种提高应用性能、优化资源利用的有效手段。本文将深入探讨 Rust 异步编程的核心概念、常用库以及最佳实践。 异步编程基础 什么是异步…...
.Net Framework 4/C# 关键字(非常用,持续更新...)
一、is 关键字 is 关键字用于检查对象是否于给定类型兼容,如果兼容将返回 true,如果不兼容则返回 false,在进行类型转换前,可以先使用 is 关键字判断对象是否与指定类型兼容,如果兼容才进行转换,这样的转换是安全的。 例如有:首先创建一个字符串对象,然后将字符串对象隐…...

OPenCV CUDA模块图像处理-----对图像执行 均值漂移滤波(Mean Shift Filtering)函数meanShiftFiltering()
操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 在 GPU 上对图像执行 均值漂移滤波(Mean Shift Filtering),用于图像分割或平滑处理。 该函数将输入图像中的…...