旋轉變換的指數形式
用單位向量$\hat{\omega}$代表旋轉軸,以及$\theta$代表繞該軸的旋轉角度。則可以用三維向量$\hat{\omega}\theta\in\mathbb{R}^3$以指數形式來描述旋轉。如果將$\hat{\omega}$和$\theta$分開描述,即為Axis-Angle形式。用$\hat{\omega}\theta$來描述旋轉矩陣R可以有下面幾種理解方法:
- 某坐標系初始與參考坐標系{s}重合,繞軸$\hat{\omega}$旋轉$\theta$角度后當到達當前姿態,其相對於{s}的旋轉矩陣為R。這種描述方法為 Axis–angle representation
- 角速度矢量$\hat{\omega}\theta$ 在參考坐標系{s}中描述,某坐標系初始與參考坐標系{s}重合,以角速度$\hat{\omega}\theta$轉動,經過單位時間到達當前姿態(可由矩陣R表示)。
- 角速度矢量$\hat{\omega}$在參考坐標系{s}中描述,某坐標系初始與參考坐標系{s}重合,以角速度$\hat{\omega}$轉動,經過$\theta$時間到達當前姿態(可由矩陣R表示)。
- Essential Results from Linear Differential Equations Theory
考慮下面的一階線性微分方程:$$\dot{x}(t)=Ax(t)$$
其中,$x(t)\in\mathbb{R}^n$,$A\in\mathbb{R}^{n\times n}$是一個常量矩陣。若給出初始條件$x(0)=x_0$,則可得到微分方程的解為:$$x(t)=x_0e^{At}$$
矩陣指數$e^{At}$可以根據泰勒展開式來計算:$$e^{At}=I+At+\frac{(At)^2}{2!}+\frac{(At)^3}{3!}+...$$
如果矩陣$A$可以表達成$A=PDP^{-1}$,$P$為可逆矩陣,則有:
$$\begin{align*} e^{At}&=I+At+\frac{(At)^2}{2!}+\frac{(At)^3}{3!}+...\\
&=I+(PDP^{-1})t+(PDP^{-1})(PDP^{-1})\frac{t^2}{2!}+...\\
&=P(I+Dt+\frac{(Dt)^2}{2!}+...)P^{-1}\\
&=Pe^{Dt}P^{-1}
\end{align*}$$
更進一步,如果$A$可以對角化,即$D$是對角矩陣:$D=diag\{d_1,d_2,...,d_n\}$,則$e^{Dt}$可以很方便的計算:
$$e^{Dt}=\begin{bmatrix}
e^{d_1t} & 0 & \cdots & 0 \\
0 & e^{d_2t} & \cdots & 0 \\
\vdots & \vdots & \ddots &\vdots \\
0 & 0 & \cdots & e^{d_nt}
\end{bmatrix}$$
- Exponential Coordinates of Rotations
參考下圖中的描述,假設三維向量$p(0)$繞着轉軸$\hat{\omega}$旋轉$\theta$度后到達$p(\theta)$。用$p(t)$代表$t$時刻向量$p$的位置,則該過程也可以描述為:$p(0)$以角速度$\hat{\omega}$旋轉($\hat{\omega}$為單位角速度),從$t=0$運動到$t=\theta$。
旋轉時的速度可用$\dot{p}$來描述,且有:$$\dot{p}=\hat{\omega}\times p$$
用斜對稱矩陣$[\hat{\omega}]$可以將向量叉乘變為矩陣與向量乘法,因此上面的微分方程可寫為:$$\dot{p}=[\hat{\omega}]p$$
若$\hat{\omega}=[\omega_x,\omega_y,\omega_z]^T$,定義斜對稱矩陣$[\hat{\omega}]$:
$$[\hat{\omega}]=\begin{bmatrix}
0 & -\omega_z & \omega_y \\
\omega_z & 0 & -\omega_x\\
-\omega_y & \omega_x & 0
\end{bmatrix}$$
已知初始條件$p(0)$,該方程形式如前面研究過的$\dot{x}=Ax$,因此其解為:$p(t)=e^{[\hat{\omega}]t}p(0)$
由於變量$t$和$\theta$可互換,則上面方程可寫為:$$p(\theta)=e^{[\hat{\omega}]\theta}p(0)$$
下面將$e^{[\hat{\omega}]t}$進行泰勒展開,計算斜對稱矩陣$[\hat{\omega}]$的冪可得關系式:$[\hat{\omega}]^3=-[\hat{\omega}]$,利用這一關系我們可以將$[\hat{\omega}]^3$替換為$-[\hat{\omega}]$,$[\hat{\omega}]^4$替換為$-[\hat{\omega}]^2$,$[\hat{\omega}]^5$替換為$-[\hat{\omega}]^3$...於是可以得到:
$$\begin{align*} e^{[\hat{\omega}]\theta}&=I+[\hat{\omega}]\theta+[\hat{\omega}]^2\frac{\theta^2}{2!}+[\hat{\omega}]^3\frac{\theta^3}{3!}+...\\ &=I+(\theta-\frac{\theta^3}{3!}+\frac{\theta^5}{5!}-...)[\hat{\omega}]+(\frac{\theta^2}{2!}-\frac{\theta^4}{4!}-\frac{\theta^6}{6!}-...)[\hat{\omega}]^2\end{align*}$$
根據正弦和余弦函數的泰勒展開式:
$$\begin{align*} \sin\theta&= \theta-\frac{\theta^3}{3!}+\frac{\theta^5}{5!}-...\\
\cos\theta&=1-\frac{\theta^2}{2!}+\frac{\theta^4}{4!}-...\end{align*}$$
可以將上面公式進行簡化。給定$\hat{\omega}\theta\in\mathbb{R}^3$,其中$\theta$為任意標量,$\hat{\omega}\in\mathbb{R}^3$且為單位向量。則根據$[\hat{\omega}]$、$\theta$進行旋轉的旋轉矩陣為:$$\boxed{Rot(\hat{\omega},\theta)=e^{[\hat{\omega}]\theta}=I+\sin\theta[\hat{\omega}]+(1-\cos\theta)[\hat{\omega}]^2}$$
該公式也稱為Rodrigues’ formula(羅德里格斯公式) 。
舉個例子,下圖中坐標系{b}相對於固定參考坐標系{s}的姿態可以描述為:初始時刻兩坐標系一致,{b}繞單位向量$\hat{\omega_1}=(0,0.866,0.5)$旋轉$\theta_1=30^°=0.524rad$后到達當前姿態。
則{b}相對於{s}的旋轉矩陣可以計算為:
$$\begin{align*}
R&=e^{[\hat{\omega_1}]\theta_1}=I+\sin\theta_1[\hat{\omega_1}]+(1-\cos\theta_1)[\hat{\omega_1}]^2 \\
&=I+0.5\begin{bmatrix}0&-0.5&0.866\\0.5&0&0\\-0.866&0&0\end{bmatrix}+0.134\begin{bmatrix}0&-0.5&0.866\\0.5&0&0\\-0.866&0&0\end{bmatrix}^2\\
&=\begin{bmatrix}0.866&-0.250&0.433\\0.250&0.967&0.058\\-0.433&0.058&0.899\end{bmatrix}
\end{align*}$$
坐標系{b}的姿態可由矩陣$R$描述,或者由單位向量$\hat{\omega_1}=(0,0.866,0.5)$以及轉角$\theta_1=0.524rad$來描述,即旋轉矩陣R的指數坐標為$\hat{\omega_1}\theta_1=(0,0.453,0.262)$
在Mathematica中RotationMatrix函數可以根據轉軸和轉角計算旋轉矩陣:
- Matrix Logarithm of Rotations
如果向量$\hat{\omega}\theta\in\mathbb{R}^3$表達了旋轉矩陣R的指數坐標,則斜對稱矩陣$[\hat{\omega}\theta]=[\hat{\omega}]\theta$是旋轉矩陣R的對數。矩陣的對數是矩陣指數的逆:
當轉角$\theta$不為$\pi$的整數倍時,可以根據旋轉矩陣R計算出轉軸:$$\begin{align*} \hat{\omega_x}=\frac{1}{2\sin\theta}(r_{32}-r_{23})\\\hat{\omega_y}=\frac{1}{2\sin\theta}(r_{13}-r_{31})\\\hat{\omega_z}=\frac{1}{2\sin\theta}(r_{21}-r_{12})\end{align*}$$
或表述為斜對稱矩陣形式:$$[\hat{\omega}]=\begin{bmatrix}0&-\hat{\omega_z}&\hat{\omega_y}\\ \hat{\omega_z}&0&-\hat{\omega_x}\\-\hat{\omega_y}&\hat{\omega_x}&0 \end{bmatrix}=\frac{1}{2\sin\theta}(R-R^T)$$
具體推導和細節可參考:Modern Robotics: Mechanics, Planning, and Control 3.2.3.3 Matrix Logarithm of Rotations
參考:
李群與李代數 - part 2 指數與對數映射、李代數求導與擾動模型
Lie Groups for 2D and 3D Transformations
Modern Robotics: Mechanics, Planning, and Control 3.2.3 Exponential Coordinate Representation of Rotation