【自动驾驶】控制算法(二)三大坐标系与车辆运动学模型

写在前面:
🌟 欢迎光临 清流君 的博客小天地,这里是我分享技术与心得的温馨角落。📝
个人主页:清流君_CSDN博客,期待与您一同探索 移动机器人 领域的无限可能。

🔍 本文系 清流君 原创之作,荣幸在CSDN首发🐒
若您觉得内容有价值,还请评论告知一声,以便更多人受益。
转载请注明出处,尊重原创,从我做起。

👍 点赞、评论、收藏,三连走一波,让我们一起养成好习惯😜
在这里,您将收获的不只是技术干货,还有思维的火花

📚 系列专栏:【运动控制】系列,带您深入浅出,领略控制之美。🖊
愿我的分享能为您带来启迪,如有不足,敬请指正,让我们共同学习,交流进步!

🎭 人生如戏,我们并非能选择舞台和剧本,但我们可以选择如何演绎 🌟
感谢您的支持与关注,让我们一起在知识的海洋中砥砺前行~~~

文章目录

  • 引言
  • 一、控制算法基础
    • 1、控制算法分类
    • 2、控制算法优劣分析
  • 二、车辆控制基本原理
    • 1、纵向控制原理
    • 2、横向控制原理
  • 三 、坐标系的引入
    • 1、横向控制中的耦合现象
    • 2、关键坐标系的定义与作用
  • 四、自行车模型
    • 1、自行车模型的基本假设
    • 2、自行车模型的构建
  • 五、车辆运动学建模
    • 1、车辆运动学模型的分类
    • 2、车辆运动学模型的建立与推导
  • 六、总结
  • 参考资料


引言

  本篇博客开始正式讲解自动驾驶控制算法。内容整理自 B站知名up主 忠厚老实的老王 的视频,作为博主的学习笔记,分享给大家共同学习。

一、控制算法基础

1、控制算法分类

控制算法相对比较成熟,一般就三个算法:

  • PID 算法
  • LQR 算法
  • MPC 算法

  其中百度 Apollo 用的是 PID 和 LQR 算法,学术界用 MPC 算法。

2、控制算法优劣分析

  从控制效果来看, MPC控制效果一般要优于 PID、LQR。但是 MPC 有个缺点是计算量太大。

  目前量产的实车上面应用算法一般是 PID + LQR

控制算法的前提:路径规划

  在本系列博客中,默认已经做好了路径规划,有一条参考路径:
在这里插入图片描述

二、车辆控制基本原理

1、纵向控制原理

  控制原理其实很简单,就是通过油门和刹车来控制力,通过力来控制加速度,通过加速度控制速度,然后再控制位置,一般叫纵向控制,原理如下:

油门/刹车
加速度
速度
位置

2、横向控制原理

  通过方向盘控制前轮转角,然后通过前轮转角来影响横向位移,这就是横向控制的原理。当然方向盘也可以控制车辆的航向角,横向控制原理如下:

方向盘
前轮转角
横向位移
航向角

三 、坐标系的引入

1、横向控制中的耦合现象

  在上面的控制基本原理中,可能会产生两个疑问:

  • 航向角是什么?
    没有学过车辆的知识,可能不知道航向角是什么。

  • 仅凭方向盘能做横向控制吗?
    也就是打方向盘,就能让车能横向运动吗?感觉横向控制应该是和纵向控制耦合在一起的,因为必须要有一定的速度,再打方向盘才能,车才能横向移动。

  在前面横向控制原理的讨论中,仅关注方向盘与纵向控制车速之间的耦合现象,而未深入探讨这一耦合的本质所在。为了清晰地阐明这一问题,需要必要引入三个关键坐标系,这三个坐标系构成了理解横向控制复杂性的基础。

2、关键坐标系的定义与作用

  在自动驾驶技术的相关文献中,尽管存在一些对原理的阐述,但并非所有作者都对其中的三个坐标系进行了详尽的解释。部分文章由于对这三个坐标系的定义和取法存在差异,导致了内容上的矛盾和混淆。这种不一致性成了理解上的混乱之源。因此,为了准确无误地解释横向控制原理,我们必须对这三个坐标系进行深入而清晰的阐述。

  比如,用长方形代表车辆,那么三个坐标系可以表示如下:
在这里插入图片描述

  • 绝对坐标系 ( X , Y ) (X,Y) (X,Y)
    也称为大地坐标系。它是相对于地球表面的固定坐标系。在这个坐标系中,车辆的位置是相对于地球表面上的一个固定点来测量的。绝对坐标系通常用于车辆导航系统,它能够提供车辆相对于全球定位系统(GPS)或其他地面参考点的精确位置。

  • 车身坐标系 ( x , y ) (x,y) (x,y)
    是车辆内部的一个相对坐标系,以车辆中心轴线为参考。在这个坐标系中,车辆的位置是相对于车辆本身的中心点来测量的。车身坐标系常用于车辆的内部控制系统中,如自动驾驶系统,它能够提供车辆相对于自身中心轴线的运动状态。

  • 自然坐标系 ( τ , n ) (\tau,n) (τ,n)
    无人驾驶领域特有的坐标系,也被称为 Frenet 坐标系。是一种在道路曲线上定义的坐标系,用于描述车辆在弯曲道路上的位置和方向,能够清晰地表达车辆相对于道路曲线的姿态和运动。

  之所以采用自然坐标系,是因为它可以简化控制算法的复杂性,并且与轨迹规划所采用的坐标系相匹配。此外,自然坐标系的一个重要优势在于它可以 实现纵向控制与横向控制的解耦,从而解释了为什么在传统的控制原理中,横向控制只需通过方向盘即可实现

  当坐标系选择为大地坐标系或车身坐标系时,纵向控制和横向控制是无法解耦的,必须混合进行。当采用自然坐标系后,这两个控制可以分开进行,从而降低了计算量。因此,Frenet 坐标系在自动驾驶技术中具有重要的地位。这三个坐标系之间的坐标变换也是一个难点。

  大地坐标系和车身坐标系之间的坐标变换相对简单,而车身坐标系和自然坐标系之间的变换则较为复杂。市面上的一些关于坐标变换的博客内容可能不够清晰,因此,在实际应用中,理解坐标系及其变换至关重要。

这三个坐标系的混淆主要有三个原因:

  • 首先,Frenet 坐标系和车身坐标系之间的坐标变换相对较为复杂。
  • 其次,无人驾驶领域早期由不同学科背景的人员参与,有的学科使用右手系,有的使用左手系,这可能导致坐标方向上的差异,并在某些文章中表现为一个负号。
  • 此外,Frenet 坐标系之间的变换也较为复杂,

  这些因素共同导致了坐标系选择上的混乱。因此,在阅读相关文献时,必须首先了解作者所采用的坐标系,因为不同的坐标系会导致同一变量在不同坐标系中的符号发生变化。

  本系列博客一律采用右手系的坐标系。什么是右手系呢?下面画一下右手的三个手指:
在这里插入图片描述

用这三个手指摆一个标架,让三个手指之间互相垂直,拇指向上,食指向左,中指指向自己。

  • 右手系
    当右手拇指指向 x 轴,右手食指指向 y 轴时,若 z 轴和中指方向一致,则为右手系。

  • 左手系
    当左手的拇指是 x 轴,左手食指指向 y 轴时,若 z 轴和左手中指向一致 ,则为左手系。

举几个例子:

  在数学和物理领域,专业人员通常采用右手坐标系来描述和分析物理现象。例如,在描述力、速度和加速度等物理量时,右手坐标系提供了一种直观且一致的框架。
  而在计算机科学领域,特别是在计算机图形学和计算机视觉领域,左手坐标系更为常见,因为这些技术在屏幕上渲染图像时更方便使用。

  自动驾驶技术作为一个涉及多个学科的领域,这种跨学科特性使得在解决相关问题时,不同背景的专业人员可能会使用他们各自的术语和知识。如果某个问题需要不同领域的专业知识来解决,那么使用不同的坐标系可能会导致理论上的矛盾和错误。

  因此,为了准确地传达理论,需要清楚地说明所使用的坐标系,以及物理量在特定坐标系中的正负号。

四、自行车模型

  在对车建模做力学分析时,一般把四个轮子变成两个轮子,简化为自行车模型:
在这里插入图片描述

1、自行车模型的基本假设

  假设车辆是完全左右对称的,并且认为轮距(即左轮与右轮之间的距离)相对于车辆的运动轨迹可以忽略不计。这种假设将车辆简化为一条线,从而简化问题。

  这种简化的假设也回答了为什么在横向控制中只需要考虑方向盘转扭的问题。在自然坐标系中,纵向控制和横向控制可以实现解耦,使得方向盘转扭成为唯一需要考虑的横向控制输入。关于如何具体实现解耦控制,将在后续的内容中详细讲解,目前只需记住这个概念即可。

2、自行车模型的构建

  构建自行车模型如下图所示:
在这里插入图片描述
  在绝对坐标系下,后轮速度为 v v v,前轮速度为 v ′ v' v。假设红点处为质心,质心速度可以用理论力学的速度瞬心法来求。过质心这一点,做瞬心与质心连线的垂线方向就是质心速度的方向。

  从图中可以看到,质心的速度方向和车的轴线方向一般不重合,而车的轴线方向和 X X X 方向一般也不重合。定义两个角度,第一个角度是横摆角 φ \varphi φ,第二个角度是质心侧偏角 β \beta β φ \varphi φ β \beta β 定义为航向角。

  • 横摆角 是指车的轴线方向和绝对坐标系 X X X 方向的夹角。(绝对坐标系下)
  • 质心侧偏角 是指质心速度 v v v 与车身坐标系 x x x 方向的夹角。(车身坐标系下)
  • 航向角 是指质心速度与 X X X 方向的夹角。(绝对坐标系下)
  • 前轮转角 δ f \delta_f δf后轮转角 δ r \delta_r δr(车身坐标系下)

自行车模型有三个假设:

  • 车辆左右对称
  • 车辆轮距忽略不计,把它压扁成一根线
  • 车辆轮轮胎为刚性轮胎,不存在变形

  在实际情况下,车辆并不完全符合简化模型中的假设。车辆轮胎的材料是橡胶,虽然相对普通材料较硬,但与钢铁相比仍然是一种相对柔软的材料。因此,当轮胎受到力的作用时,会发生变形,这种变形是不能被忽略的。

  由于轮胎的这种变形特性,自行车模型的前轮转角与实际车辆的前轮转角并不完全相同。由于前轮转角与方向盘转角之间存在一一对应的关系,例如,如果传动比是
10,那么当方向盘转角为 30 度时,理论上前轮转角应为 3 度。但是由于轮胎的变形,实际的前轮转角可能并非完全按照这一比例变化。

  因此,在考虑车辆的实际操作时,需要考虑轮胎变形对前轮转角的影响,这可能会导致方向盘转角与前轮转角之间的实际比例与理论比例存在差异。

【侧偏】因为轮胎有变形而导致前轮转角和方向盘转角不能一一对应的现象。

  后面会讲到侧偏,现在大家只要心里有个印象就行了,就是实际上前端转角和方向盘转角不是一一对应的。但是在这里先忽略这件事情,认为他们是一一对应的。就是如果传动比里是 10 的话,方向盘转角是 30 度,那么前段转角就是 3 度。

自行车模型有两种:

  • 一种是不考虑轮胎变形,就认为轮子是一个钢铁的轮子
  • 一种是考虑轮胎变形,需要注意轮胎侧偏的特性

  在当前的讨论中,我们不考虑轮胎变形的情况。在低速条件下,轮胎受到的阻力较小,因此其变形也相对较小。在这种情况下,轮胎可以近似地被视为刚性轮子。因此,不考虑轮胎变形的自行车模型在某些情况下仍然是有用的。

  用 v v v 代表直行车速,对 v v v 沿着车身坐标系正交分解:
在这里插入图片描述

  • 沿着 x x x 轴方向定义为纵向车速 v x v_x vx,纵向加速度 a x a_x ax
  • 垂直于车的轴线,定义为侧向速度 v y v_y vy,侧向加速度 a y a_y ay

  物理量定义好后,就可以建立微分方程了。微分方程用来描述前端转角 δ f \delta_f δf 是如何影响侧向位移与航向角的,微分方程是控制的理论基础。

五、车辆运动学建模

1、车辆运动学模型的分类

车辆模型有两种:

  • 根据几何关系建立运动学模型
  • 根据牛顿力学建立动力学模型

  这两个模型的区别在于运动型模型认为轮胎是刚性轮胎,不会变形;而牛顿力学会充分考虑轮胎变形

  所以一般动力学模型要比运动学模型更加精确,但动力学模型考虑轮胎变形就很复杂,因为轮胎它是橡胶和空气混在一起的,这样的东西很难去精确地去描述轮胎的变形到底是怎样的,所以动力学模型的参数很难给做到非常准确,但是运动性模型就没有这样的缺点,它就是纯粹的几何关系,不考虑轮胎变形。

  因此,运动型模型相对较为简单,其代价在于 不考虑轮胎的变形。这种简化的模型适用于轮胎变形较小的特定情况,例如在低速行驶大转弯半径频繁规划轨迹的情况下。然而,对于一些更激烈的驾驶情况,运动型模型可能不再适用,因为在这种情况下,轮胎的变形可能变得显著,从而导致较大的误差。

2、车辆运动学模型的建立与推导

  首先构建自行车模型,建立坐标系:
在这里插入图片描述

  可以得到如下方程:
X ˙ = v cos ⁡ ( β + φ ) Y ˙ = v sin ⁡ ( β + φ ) φ ˙ = v R \begin{aligned}&\dot{X}=v\cos(\beta+\varphi)\\&\dot{Y}=v\sin(\beta+\varphi)\\&\dot{\varphi}=\frac{v}{R}\end{aligned} X˙=vcos(β+φ)Y˙=vsin(β+φ)φ˙=Rv  第三个式子是理论力学的知识,刚体的角速度等于它的线速度除以线速度到速度瞬心的距离

  上述微分方程只体现质心速度 v v v x 、 y 、 φ x、y、\varphi xyφ 的影响,没体现前轮转角 δ f \delta_f δf,所以还需要更进一步的推导。

  设质心到前轮的距离为 a a a,质心到后轮的距离为 b b b

  把一个大三角形分为两个小三角形,使用正弦定理:
a sin ⁡ ( δ f − β ) = R sin ⁡ ( π 2 − δ f ) \frac{a}{\sin(\delta_f-\beta)}=\frac{R}{\sin(\frac{\pi}{2}-\delta_f)} sin(δfβ)a=sin(2πδf)R b sin ⁡ ( δ r + β ) = R sin ⁡ ( π 2 − δ r ) \frac{b}{\sin(\delta_r+\beta)}=\frac{R}{\sin(\frac{\pi}{2}-\delta_r)} sin(δr+β)b=sin(2πδr)R  对这两个式子化简:
a R = sin ⁡ ( δ f − β ) sin ⁡ ( π 2 − δ f ) = sin ⁡ δ f cos ⁡ β − sin ⁡ β cos ⁡ δ f cos ⁡ δ f = tan ⁡ δ f cos ⁡ β − sin ⁡ β \frac{a}{R}=\frac{\sin(\delta_f-\beta)}{\sin(\frac{\pi}{2}-\delta_f)}=\frac{\sin\delta_f\cos \beta-\sin \beta\cos\delta_f}{\cos\delta_f}=\tan\delta_f\cos \beta-\sin\beta Ra=sin(2πδf)sin(δfβ)=cosδfsinδfcosβsinβcosδf=tanδfcosβsinβ b R = sin ⁡ ( δ r + β ) sin ⁡ ( π 2 − δ r ) = sin ⁡ δ r cos ⁡ β + sin ⁡ β cos ⁡ δ r cos ⁡ δ r = tan ⁡ δ r cos ⁡ β + sin ⁡ β \frac{b}{R}=\frac{\sin(\delta_{r}+\beta)}{\sin(\frac{\pi}{2}-\delta_{r})}=\frac{\sin\delta_{r}\cos\beta+\sin\beta\cos\delta_{r}}{\cos\delta_{r}}=\tan\delta_{r}\cos\beta+\sin\beta Rb=sin(2πδr)sin(δr+β)=cosδrsinδrcosβ+sinβcosδr=tanδrcosβ+sinβ   由此得到 R R R δ f \delta_f δf δ r \delta_r δr 之间的关系,但是这样还不够,因为质心会变,比如多坐几个人,多装几件行李后,质心的位置就会变, a a a b b b 的数值也会相应变化。

  所以要用不因质心改变而变化的车辆轴距 L L L 来表示 R R R δ f \delta_f δf δ r \delta_r δr 之间的关系: a + b R = ( tan ⁡ δ f + tan ⁡ δ r ) \frac{a+b}{R}=(\tan\delta_f+\tan\delta r) Ra+b=(tanδf+tanδr) 1 R = tan ⁡ δ f + tan ⁡ δ r L \frac1R=\frac{\tan\delta f+\tan\delta r}L R1=Ltanδf+tanδr其中,车辆轴距 L = a + b L=a+b L=a+b.

  得到运动学微分方程:
X ˙ = v cos ⁡ ( φ + β ) Y ˙ = v sin ⁡ ( φ + β ) φ ˙ = v R = v ( tan ⁡ δ f + tan ⁡ δ r ) L \begin{aligned}&\dot{X}=v\cos(\varphi+\beta)\\&\dot{Y}=v\sin(\varphi+\beta)\\&\dot{\varphi}=\frac{v}{R}=\frac{v(\tan\delta_{f}+\tan\delta_{r})}{L}\end{aligned} X˙=vcos(φ+β)Y˙=vsin(φ+β)φ˙=Rv=Lv(tanδf+tanδr)  运动学方程的前提是低速条件,在低速条件下认为车不会发生侧向滑动,即车不会漂移,所以 v y ≈ 0 v_y \approx 0 vy0

  根据定义,质心侧偏角 β \beta β
β = arctan ⁡ v y v x = 0 \beta=\arctan\frac{v_{y}}{v_{x}}=0 β=arctanvxvy=0  一般车都是前轮转向,后轮驱动,所以在低速产条件下,近似认为 δ r ≈ 0 \delta_r \approx 0 δr0

  最终运动学方程如下: { x ˙ = v cos ⁡ φ y ˙ = v sin ⁡ φ ψ ˙ = v tan ⁡ δ f L \begin{cases}\dot{x}=v\cos\varphi\\\dot{y}=v\sin\varphi\\\dot{\psi}=\frac{v\tan\delta_f}{L}\end{cases} x˙=vcosφy˙=vsinφψ˙=Lvtanδf  因为 β ≈ 0 \beta \approx0 β0,所以 航向角 ≈ \approx 横摆角 φ \varphi φ ,质心速度 v = v x v=v_x v=vx

  由此建立起了车辆运动学模型,通过 v v v δ f \delta_f δf 控制 车辆位姿 ( X , Y , φ ) (X,Y,\varphi) (X,Y,φ)

六、总结

  本篇博客讲解了车辆控制中的三大坐标系,定义了一些物理量,并且求出了低速条件下的车辆运动学模型。对于高速情况下的动力学模型,将在后续的博客中介绍,欢迎关注!

参考资料

  【基础】自动驾驶控制算法第二讲 三个坐标系与运动学方程


后记:

🌟 感谢您耐心阅读这篇关于 自动驾驶三大坐标系与车辆运动学模型 的技术博客。 📚

🎯 如果您觉得这篇博客对您有所帮助,请不要吝啬您的点赞和评论 📢

🌟您的支持是我继续创作的动力。同时,别忘了收藏本篇博客,以便日后随时查阅。🚀

🚗 让我们一起期待更多的技术分享,共同探索移动机器人的无限可能!💡

🎭感谢您的支持与关注,让我们一起在知识的海洋中砥砺前行 🚀

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

第37讲:Cephfs文件系统的正确使用姿势

文章目录 1.Cephfs文件系统简介2.Cephfs文件系统细节介绍2.1.Cephfs文件系统多客户端隔离挂载2.2.Ceph集群中多个Cephfs如何单独使用 3.挂载多个Cephfs文件系统4.Cephfs文件系统多客户端隔离挂载实战4.1.创建一个Cephfs文件系统4.2.将Cephfs文件系统挂载到本地路径4.3.在Cephfs…

java:IDEA修改java版本的几个不同的地方

文章目录 项目JDK设置(Project SDK)项目模块级JDK设置(Module SDK)IDE级别的JDK设置Maven配置文件编译器(Java Compiler)构建工具配置文件(如build.gradle或pom.xml).idea/misc.xml文…

Chrome快捷键提高效率

浏览效率提高快捷建 快速切换标签页 Ctrl 数字(1或者2),标签页数字从左到右为顺序,1开始。快速切换标签页。 Ctrl1 到 Ctrl8 切换到标签栏中指定位置编号所对应的标签页 Ctrl9切换到最后一个标签页 CtrlTab 或 CtrlPgDown 切…

EasyCVR视频汇聚平台构建远程安防监控:5大亮点解析,助力安防无死角

随着科技的飞速发展,远程安防监控系统已经成为现代社会中不可或缺的一部分,无论是在小区、公共场所还是工业领域,安防监控都发挥着至关重要的作用。而EasyCVR作为一款功能强大的视频监控综合管理平台,其在构建远程安防监控系统方面…

英伟达开源 Nemotron-4-4B:小型模型,大能量

前沿科技速递🚀 在人工智能领域,语言模型已经成为推动自然语言处理(NLP)进步的关键力量。然而,随着模型规模的不断扩大,训练和部署这些大型语言模型(LLM)的资源成本也在急剧增加。为…

WUP-MY-LABEL-PRINTER 旻佑热敏打印机标签打印uniapp插件使用说明

插件地址:WUP-MY-LABEL-PRINTER 旻佑热敏打印机标签打印安卓库 简介 本插件主要用于旻佑热敏打印机打印标签,不支持票据打印。适用于旻佑的各型支持标签打印的热敏打印机。本插件开发时使用的打印机型号为MY-805嵌入式面板打印机,其他型号请…

uni-app--》打造个性化壁纸预览应用平台(二)

🏙️作者简介:大家好,我是亦世凡华、渴望知识储备自己的一名前端工程师 🌄个人主页:亦世凡华、 🌆系列专栏:uni-app 🌇座右铭:人生亦可燃烧,亦可腐败&#xf…

深度学习的量化和剪枝

一:背景 如果要将深度学习的AI模型部署到受限设备(FPGA)上,往往需要更小的存储需求和最低的计算复杂度。当然,还得保持一定的性能(下降在能够接受的范围)。受限设备资源的环境,一般是…

数据结构与算法--插入排序与选择排序

文章目录 回顾提要排序基本概念排序的分类排序算法的稳定性排序算法的性能指标内排序 排序方法直接插入排序直接插入排序的要点直接插入排序的实现直接插入排序性能分析直接插入排序的适用情景 简单选择排序简单选择排序的要点简单选择排序的执行过程简单选择排序的实现简单选择…

分布式锁:Mysql实现,Redis实现,Zookeeper实现

目录 前置知识 Mysql实现分布式锁 1.get_lock函数 Java代码实现: 2.for update尾缀 Java代码实现: 3.自己定义锁表 Java代码实现: 4.时间戳列实现乐观锁 Java代码实现: Redis实现分布式锁 Zookeeper实现分布式锁&#…

完整搭建windows下mysql8.0源码编译调试环境!

背景: 前段时间一直在看mysql相关的博客,所以对源码起了浓厚的兴趣,所以尝试通过vmware和vscode在windosw环境中搭建一套编译调试的环境~ 看了一下网上的搭建教程基本杂乱无章,想要从零跟着搭建出一个完善的调试环境也不是易事&…

Leetcode3232. 判断是否可以赢得数字游戏

Every day a Leetcode 题目来源:3232. 判断是否可以赢得数字游戏 解法1:3232. 判断是否可以赢得数字游戏 用一个 sum1 统计个位数的和,sum2 统计十位数的和。 只要 sum1 和 sum2 不相等,Alice 拿大的就能赢得这场游戏。 代码…

Maven的依赖范围

依赖的jar包,默认情况下,可以在任何地方使用,可以通过scope来设置作用范围 作用范围: 主程序范围有效(main文件夹范围内)测试程序范围有效(test文件夹范围内)是否参与打包运行&…

一次日志记录中使用fastjson涉及到ByteBuffer的教训

背景 目前本人在公司负责的模块中,有一个模块是负责数据同步的,主要是将我们数据产线使用的 AWS Dynamodb 同步的我们的测试QA 的环境的 MongoDB 的库中,去年开始也提供了使用 EMR 批量同步的功能,但是有时候业务也需要少量的数据…

【OpenCV_python】凸包检测 轮廓特征 直方图均衡化 模板匹配 霍夫变换

凸包特征检测 凸包就是图像的最小外接多边形,通过图像的轮廓点,找到距离最远的两个点的直线,根据直线找到距离最远的下一个点,直到所有的点被包围在多边形内 读取图像二值化找图像的轮廓获取凸包点的坐标绘制凸包点 convexHull 获…

程序员如何写PLC程序

PLC是可编程逻辑控制器的简称,常用的编程语言是IEC61131-3(梯形图、结构化文本、指令表、功能块、顺序功能图)和西门子的SCL。程序员常用的编程语言是JS、Java、Python、C/C、Go等。PLC广泛采用编程工具有codesys、博图等。程序员常用的编程工…

敏捷架构在数字时代的应用:从理论到实践的全面指南

在数字化转型和技术变革的浪潮中,企业面临着不断提升敏捷性和应对复杂环境的挑战。敏捷架构在数字时代的应用不仅从理论层面阐述了敏捷架构的基本原理,还为企业提供了详细的实践指南,帮助企业从理论走向实际操作。本文将从理论与实践的双重视…

STM32——CAN通讯基础知识

CAN 协议简介 CAN 是控制器局域网络 (Controller Area Network) 的简称,它是由研发和生产汽车电子产品著称的德国 BOSCH 公司开发的,并最终成为国际标准(ISO11519以及ISO11898),是国际上应用最广泛的现场总线之一。差异点如下: 高速CAN可以达…

YOLOv8_det/seg/pose/obb推理流程

本章将介绍目标检测、实例分割、关键点检测和旋转目标检测的推理原理,基于onnx模型推理,那么首先就需要了解onnx模型的输入和输出,对输入的图片需要进行预处理的操作,对输出的结果需要进行后处理的操作,这部分内容在我的另一个专栏《YOLOv8深度剖析》中也有介绍,如果对YO…

《机器学习》一元、多元线性回归的实现 No.4

一、一元线性回归实现 先直接看完整代码: import pandas as pd import matplotlib.pyplot as plt from sklearn.linear_model import LinearRegressiondate pd.read_csv(data.csv) #导入数据plt.scatter(date[广告投入],date[销售额]) # 用散点图展示数据 plt.sh…