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

news2025/1/11 2:20:18

写在前面:
🌟 欢迎光临 清流君 的博客小天地,这里是我分享技术与心得的温馨角落。📝
个人主页:清流君_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.coloradmin.cn/o/2051600.html

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

相关文章

Dubbo服务自动Web化之路

本文字数:6047字 预计阅读时间:40分钟 01 故障出现 事情起源于一次故障,2023年12月14日14点26分,大量Dubbo服务报出异常,无法链接zookeeper集群: Session 0x0 for server dubboZk.xxx.com/10.x.x.x:2181, C…

【高校科研前沿】南方科技大学冯炼教授等人在遥感顶刊RSE发文:全球人类改造的基塘系统制图

1.文章简介 论文名称:Global mapping of human-transformed dike-pond systems(全球人类改造的基塘系统制图) 第一作者及单位:Yang Xu(南方科技大学环境学院) 第一通讯作者及单位:冯炼&#x…

机器学习:线性回归算法(一元和多元回归代码)

1、线性回归 1、数据准备: 描述如何获取和准备数据。 2、图像预处理: 包括图像读取。 3、将数据划分为训练集和测试集。 4、计算数据的相关系数矩阵。 5、模型训练: 详细说明如何使用线性回归算法训练模型&…

京东2025届秋招 算法开发工程师 第2批笔试

目录 1. 第一题2. 第二题3. 第三题 ⏰ 时间:2024/08/17 🔄 输入输出:ACM格式 ⏳ 时长:2h 本试卷还有选择题部分,但这部分比较简单就不再展示。 1. 第一题 村子里有一些桩子,从左到右高度依次为 1 , 1 2…

达梦数据库的系统视图v$reserved_words

达梦数据库的系统视图v$reserved_words 达梦数据库(DM Database)提供了一系列系统视图以帮助管理员和开发人员了解数据库的状态和配置。V$RESERVED_WORDS 是其中一个系统视图,它显示了数据库系统中已保留的关键字。这些关键字在SQL语句中具有…

SpringBoot自动配置--原理探究

什么是自动配置? SpringBoot自动配置是指在SpringBoot应用启动时,可以把一些配置类自动注入到Spring的IOC容器中,项目运行时可以直接使用这些配置类的属性。简单来说就是用注解来对一些常规的配置做默认配置,简化xml配置内容&…

【三维目标检测】H3DNet(三)

【版权声明】本文为博主原创文章,未经博主允许严禁转载,我们会定期进行侵权检索。 参考书籍:《人工智能点云处理及深度学习算法》 H3DNet数据和源码配置调试过程以及主干网络介绍请参考上一篇博文:【三维目标检测】H3DNet&am…

[Java]面向对象-内部类

类的五大成员:属性、方法、构造方法、代码块、内部类 内部类 在一个类里边再定义一个类。可以在外部其他类中创建内部类对象并调用它的方法 public class Outer {//外部类public class inner{//内部类} } 内部类使用时机: 内部类表示的事物是外部类…

打造高可用集群的基石:深度解析Keepalived实践与优化

高可用集群 集群类型 集群类型主要分为负载均衡集群(LB)、高可用集群(HA)和高性能计算集群(HPC)三大类。每种集群类型都有其特定的应用场景和优势。 1. 负载均衡集群(LB) 负载均衡集…

drawio的问题

drawio的问题 先给出drawio的链接https://app.diagrams.net/ 我在用overleaf写论文的过程中,发现了一个问题,就是使用drawio画好图之后,只能保存以下几个选项: 但是不管是什么类型,在overleaf上面图片都不显示。如果…

SpringBoot如何做自动配置

目录 一、什么是springboot的自动配置? 二、Enable注解 三、springboot自动配置流程 ComponentScan SpringBootConfiguration EnableAutoConfiguration注解 condition的几个注解: 四、自定义启动类 需求: 参考: 实现步…

使用JQUERY请求数据出现500报错

我在写项目的时候遇到了一个问题,就是在存商品id的时候我将它使用了JSON.stringify的格式转换了!!!于是便爆出了500这个错误!!! 我将JSON.stringify的格式去除之后,它就正常显示了&a…

【数学建模】趣味数模问题——四人追逐问题

问题描述: 如图所示,在正方形ABCD的四个顶点各有一个人。在初始时刻 t0 时,四人同时出发,以匀速 v 沿顺时针方向朝下一个人移动。如果他们始终对准下一个人为目标行进,最终结果会如何?需要作出各自的运动轨…

路径规划 | 灰狼算法+B样条曲线优化无人机三维路径规划(Matlab)

目录 效果一览基本介绍程序设计参考文献 效果一览 基本介绍 灰狼算法B样条曲线优化无人机三维路径规划(Matlab) 群智能路径规划算法。三维灰狼算法(GWO)加B样条曲线优化的matlab代码。无人机(UAV)路径规划…

QT:安装软件

QT 介绍 QT是一个跨平台的C应用程序开发框架,具有广泛的应用领域和强大的功能。 定义:QT是一个跨平台的C图形用户界面应用程序框架,为开发者提供了建立艺术级图形界面所需的所有功能。 特点:QT具有短平快的优秀特质,即…

csrf漏洞(二)

本文仅作为学习参考使用,本文作者对任何使用本文进行渗透攻击破坏不负任何责任。 前言: 本文依靠phpstudy以及dvwa靶场进行操作,具体搭建流程参考:xss漏洞(二,xss靶场搭建以及简单利用) 前篇…

Godot关于3d射线投射的一些问题

首先你得把刚体模式激活如图否则将是空对象 为了区分其他坐标颜色园哥把射线设置成紫色以示区别 另外运行模式中貌似射线不可见只在调试模式中可见。最后查看调试器 成功碰撞一个名为主角的物体,也许都命中了但是方法只返回第一个命中的物体,吐槽一下&a…

场外个股期权如何发出行权指令?

场外期权行权指令也就是平仓指令的意思,一般场外个股期权交易有三种方式开仓和行权平仓指令,分别是市价,限价和半小时询价,跟普通股票的买卖和交易方式类似,唯一区别是手动发出场外个股期权的行权指令,下文…

Linux系统中的高级系统资源管理技术:systemd资源控制

在当今信息技术的快速发展中,服务器的性能管理和资源分配变得尤为重要。Linux操作系统以其灵活性和可定制性在服务器领域广受欢迎。而在Linux系统中,systemd资源控制作为一项重要的高级系统资源管理技术,为管理员提供了精细化控制和调整系统服…

STM32标准库学习笔记-2.GPIO

参考教程:【STM32入门教程-2023版 细致讲解 中文字幕】 标准库开发新建工程准备工作: 建立工程文件夹,Keil中新建工程,选择型号STM32F103C8T6工程文件夹里建立Start、Library、User等文件夹,复制固件库里面的文件到工…