当前位置: 首页 > news >正文

基于分布式驱动电动汽车的车辆状态估计探索

基于分布式驱动电动汽车的车辆状态估计,采用的是容积卡尔曼(ckf)观测器,可估计包括纵向速度,质心侧偏角,横摆角速度,侧倾角四个状态。 模型中第一个模块是四轮驱动电机;第二个模块是carsim输出的真实参数,包括汽车所受横向力,纵向力,驱动力矩等:第三个模块是dugoff模型计算轮胎力。 第四个模块是关于ckf的车辆状态估计,可估计包括纵向速度,横摆角速度,质心侧偏角,侧倾角四个自由度。 模型和代码完全是由自己亲手编写,可供自己参考和学习。 本模型是基于simulink与carsim联合仿真,ckf是由s function进行编写,提供相关文献和。 如果有需要在电机无传感器控制和车辆状态估计上改进卡尔曼滤波,比如平方根容积卡尔曼,高阶容积卡尔曼等

最近在研究基于分布式驱动电动汽车的车辆状态估计,过程还挺有趣的,来和大家分享分享。

这次采用的是容积卡尔曼(CKF)观测器,它能估计纵向速度、质心侧偏角、横摆角速度、侧倾角这四个关键状态。这对于了解车辆实时动态,保障行车安全和性能优化都非常重要。

模型模块剖析

  1. 四轮驱动电机模块:这是车辆动力的起始点,负责将电能转化为机械能,驱动车辆前进。它就像是车辆的“心脏”,稳定且高效的运作是车辆正常行驶的基础。虽然代码还比较基础,但却至关重要。比如下面这段简单模拟电机输出扭矩的代码(以MATLAB为例):
function torque = motorTorque(speed) % 根据电机转速计算输出扭矩 torque = 100 - 0.5 * speed; % 这里简单假设扭矩与转速呈线性关系,实际中模型会复杂得多 end

在实际应用中,需要更精确的电机模型来模拟不同工况下的输出,这就需要考虑电机的特性曲线、温度影响等等因素。

  1. Carsim输出真实参数模块:Carsim就像是一个强大的“数据宝库”,为我们提供汽车所受横向力、纵向力、驱动力矩等真实参数。这些参数是后续分析和估计的重要依据。我们可以通过接口函数来获取这些数据,例如在Simulink中,可以使用如下代码片段来连接Carsim并获取纵向力:
function longForce = getLongForceFromCarsim() % 假设这里有连接Carsim并获取数据的底层函数 longForce = callCarsimAPI('longitudinalForce'); end

这里的callCarsimAPI函数是一个自定义的与Carsim交互的函数,实际实现需要根据Carsim提供的API来编写。

  1. Dugoff模型计算轮胎力模块:轮胎力对于车辆的操控性和稳定性起着关键作用。Dugoff模型能根据车辆的各种参数准确计算轮胎力。下面是一个简化的Dugoff模型代码框架(Python实现):
def dugoffTireForce(verticalLoad, slipRatio, frictionCoefficient): # 根据Dugoff理论计算轮胎力 # 这里只是简单框架,实际公式复杂 tireForce = verticalLoad * frictionCoefficient * slipRatio return tireForce

实际的Dugoff模型包含很多复杂的公式和参数调整,以适应不同的轮胎和路面状况。

  1. CKF车辆状态估计模块:重头戏来了,这个模块利用CKF观测器估计纵向速度、横摆角速度、质心侧偏角、侧倾角四个自由度。CKF观测器在处理非线性系统状态估计方面表现出色。在Simulink中,我使用S - function来编写CKF。以下是一个简单的S - function框架(以估计纵向速度为例):
function [sys,x0,str,ts] = longitudinalVelocityCKF(t,x,u,flag) switch flag, case 0, [sys,x0,str,ts]=mdlInitializeSizes; case 1, sys=mdlDerivatives(t,x,u); case 2, sys=mdlUpdate(t,x,u); case 3, sys=mdlOutputs(t,x,u); case 4, sys=mdlGetTimeOfNextVarHit(t,x,u); case 9, sys=mdlTerminate(t,x,u); otherwise DAStudio.error('Simulink:blocks:unhandledFlag', num2str(flag)); end function [sys,x0,str,ts]=mdlInitializeSizes() sizes = simsizes; sizes.NumContStates = 1; sizes.NumDiscStates = 0; sizes.NumOutputs = 1; sizes.NumInputs = 1; sizes.DirFeedthrough = 1; sizes.NumSampleTimes = 1; sys = simsizes(sizes); x0 = [0]; str = []; ts = [0.01 0]; function sys=mdlDerivatives(t,x,u) % 这里编写状态转移方程的导数,简单假设 sys(1) = u(1); function sys=mdlUpdate(t,x,u) sys = x; function sys=mdlOutputs(t,x,u) sys(1) = x(1); % 输出估计的纵向速度 function sys=mdlGetTimeOfNextVarHit(t,x,u) sampleTime = 0.01; sys = t + sampleTime; function sys=mdlTerminate(t,x,u) sys = [];

这个S - function框架实现了一个基本的CKF估计纵向速度的过程,实际应用中需要根据具体的系统模型和噪声特性来完善状态转移方程、观测方程以及噪声协方差等参数。

联合仿真与拓展

整个模型是基于Simulink与Carsim联合仿真的,这样能充分利用两者的优势。Simulink便于搭建控制系统模型,而Carsim提供高精度的车辆动力学模型。

如果有需要在电机无传感器控制和车辆状态估计上改进卡尔曼滤波,平方根容积卡尔曼(SRCKF)和高阶容积卡尔曼(HKF)是不错的选择。SRCKF能提高数值稳定性,在处理一些对精度和稳定性要求极高的场景时很有用。而HKF则可以通过增加容积点的数量来提高估计精度,适用于系统模型较为复杂,需要更精确估计的情况。感兴趣的朋友可以参考相关文献进一步研究,我这里也整理了一些有用的文献资料,后续可以分享给大家一起探讨。

这次的模型和代码都是自己亲手编写的,在这个过程中收获了很多,也希望能给同样在这个领域探索的朋友们一些启发。后续还会继续优化和完善这个模型,期待能有更多新发现!

http://www.jsqmd.com/news/139850/

相关文章:

  • SVN忽略已经上传的node_modules
  • c语言之utf8转unicdoe
  • 20251222 - 强连通分量 总结
  • 【前端】svelte支持scss,包管理器是webpack
  • COMSOL手性GST相变文章复现
  • 绩效考核需要考核什么内容?
  • 写小说类型
  • 《告别无效等待:大规模第三方库项目的快速增量构建指南》
  • 抽象圣诞树
  • MAUI库推荐三:Syncfusion.Maui.Toolkit
  • 提高信噪比的操作
  • 全球化部署 多活多区域写入 → 汇总中心同步方案
  • 电动汽车时空双层调度 研究了发电机、电动汽车和风力发电的协同优化调度问题。 针对风电存在时电动...
  • Lupa库功能及使用场景介绍
  • 相机坐标系转车辆坐标系以及相反, RT矩阵,旋转变换P_cam = rot_car2cam * P_car + trans_car2cam; P_cam = rot * (P_car - trans)
  • Note -「Intro. to Computer Systems」「CS:APP」Review!
  • 安徽省宣城市国控集团党委书记、董事长钱邦青一行到访国联股份卫多多
  • 从化文旅宣传策划公司推荐:效率提升80%方案引追捧 - 品牌测评家
  • 跑分第一的Gpt Image 1.5真的干过了Nano banana Pro?深度测评+便宜稳定0.02/张APi接入教程
  • MiniMax - yi
  • 机器学习时间特征处理:循环编码(Cyclical Encoding)与其在预测模型中的应用
  • 百炼成钢:小金鱼的软件工程课程总结
  • 基于SpringBoot泰山登山陪爬平台的设计与实现(毕设源码+文档)
  • 计算机基础小题
  • 4 倍扩容 + 700 + 流程图极速展示!ProDB×TDengine 赋能泰州石化
  • 基于SpringBoot特色农产品销售系统(毕设源码+文档)
  • 游戏手柄电池选购指南:聚电新能源成靠谱之选 - 工业品网
  • 手把手教你用MCGS撸一个立体车库控制系统
  • 《从视觉到听觉:游戏状态信息的屏幕阅读器适配底层逻辑》
  • 自动驾驶控制-纯跟踪算法路径跟踪仿真 matlab和carsim联合仿真搭建的无人驾驶纯跟踪控...