运动学#

运动学是几何学在各种机器人机构控制中的应用。运动学方程通过提供特定的输入来控制机械装置,以实现所需的输出。

这里的许多运动学方程式取自 FIRST 机器人竞赛中的控制工程(书籍)FTC 移动机器人运动学(论文) ,其中包含相关推导。虽然这里只显示了坦克(差速驱动)和机械臂运动学方程,但这些资料还包含其他机构的推导,如转向和惰轮里程计。

正向运动学与逆向运动学#

机械装置的正向和逆向运动学可能有不同的方程组。正向运动学是根据系统的输出状态来确定系统状态的方程,而逆向运动学则是根据所需的状态来确定系统的输出。例如,在动力传动系统中,正向运动学将根据车轮的单个速度确定机器人的车身速度,而逆向运动学将根据所需的车身速度确定所需的车轮速度。

坦克底盘(差动驱动)#

坦克或差速驱动是一种传动系统,由机器人两侧独立驱动的两组车轮组成。更多详情请参见 坦克(滑移装载机)传动系统 部分。

变量#

本节使用以下变量。

  • \(v_r\) 表示右轮的线速度

  • \(v_l\) 表示左轮的线速度

  • \(v_f\) 表示机器人相对于自身的前进速度

  • \(\omega\) 表示机器人的旋转速度,单位为弧度/秒

  • \(r_b\) 表示基本轨道半径,或车轮与机器人中心之间的距离(车轮间距的一半)。

警告

除了 \(\omega\) 之外,这些变量代表的是 线性 速度,而不是 旋转 速度。以弧度/秒为单位的车轮旋转速度可以通过乘以车轮半径转换为线速度。

正的旋转速度(\(\omega\))将使机器人从上方看时顺时针旋转。

正向运动学#

坦克驱动装置的前进运动学将车轮的速度与机器人相对于自身的前进速度和旋转速度联系起来。前进速度 \(v_f\) 和旋转速度 \(v_{\theta}\) 为:

\[ \begin{align}\begin{aligned}v_f = \frac{v_r + v_l}{2}\\\omega = \frac{v_r - v_l}{2 r_b}\end{aligned}\end{align} \]

反向运动学#

坦克驱动装置的逆运动学将机器人的期望速度与车轮所需的速度联系起来。这些速度如下:

\[ \begin{align}\begin{aligned}v_r = v_f + r_d \cdot \omega\\v_l = v_f - r_d \cdot \omega\end{aligned}\end{align} \]

麦克纳姆轮底盘#

变量#

麦克纳姆底盘的运动学使用的变量与差分驱动相同,但有四个车轮速度变量和一个额外的机器人速度矢量(从左到右的速度)。

  • \(v_\mathrm{fr}\) 表示右前轮的线速度

  • \(v_\mathrm{br}\) 表示右后轮的线速度

  • \(v_\mathrm{fl}\) 表示左前轮的线速度

  • \(v_\mathrm{bl}\) 表示左后轮的线速度

  • \(v_f\) 表示机器人相对于自身的前进速度。

  • \(v_s\) 表示机器人相对于自身的横移(侧移)速度。

  • \(\omega\) 表示机器人的旋转速度,单位为弧度/秒

  • \(r_b\) 表示基本轨道半径,或车轮与机器人中心之间的距离(车轮间距离的一半)。

警告

除了 \(\omega\) 之外,这些变量代表的是 线性 速度,而不是 旋转 速度。以弧度/秒为单位的车轮旋转速度可以通过乘以车轮半径转换为线速度。

正的旋转速度(\(\omega\))将使机器人从上方看时顺时针旋转。

正向运动学#

麦克纳姆轮底盘的正向运动学将车轮的速度与机器人相对于自身的前向、侧移和旋转速度联系起来。这些是:

\[ \begin{align}\begin{aligned}v_f = \frac{v_\mathrm{fr} + v_\mathrm{fl} + v_\mathrm{br} + v_\mathrm{bl}}{4}\\v_s = \frac{v_\mathrm{bl} + v_\mathrm{fr} - v_\mathrm{fl} - v_\mathrm{br}}{4}\\\omega = \frac{v_\mathrm{br} + v_\mathrm{fr} - v_\mathrm{fl} - v_\mathrm{bl}}{4*2r_b}\end{aligned}\end{align} \]

反向运动学#

麦克纳姆轮底盘的逆运动学将机器人的期望速度与车轮所需的速度联系起来。具体如下

\[ \begin{align}\begin{aligned}v_{fl} = v_f - v_s - (2r_b \cdot \omega)\\v_{bl} = v_f + v_s - (2r_b \cdot \omega)\\v_{br} = v_f - v_s + (2r_b \cdot \omega)\\v_{fr} = v_f + v_s + (2r_b \cdot \omega)\end{aligned}\end{align} \]