本次课程主要研究李群和李代数(Lie Group, Lie Algebra),主要的目的是为了能够相机得旋转和平移进行微调。因为相机的运动估计可能不准确,而无法对旋转矩阵加上微小量之后依然是旋转矩阵(旋转矩阵无法定义加法,如果用四元数,必须是单位四元数,那么也无法定义加法)。李群李代数与后面的优化,流形都会有很大的联系。
在视觉SLAM中,相机的位姿是未知的,而我们需要解决什么样的相机位姿最符合当前观测数据这样的问题。一种典型的方式是把其构建成一个优化问题,求解最优的 R R R 和 t t t ,使得误差最小化。
由于旋转矩阵自身带有约束,即必须正交且行列式为1,因此作为优化变量会引入额外的约束,使得优化变得困难。而通过李群李代数的转换关系,可以顺利求导,把位姿估计变成无约束的优化问题。
群 群(Group)是一种集合加上一种运算的代数结构,满足封闭性,结合律,幺元 ,逆。其中幺元可以认为是单位元,就是与其他元素作用不改变这个元素,逆是元素和和它的逆进行运算后得到了幺元。
三维旋转矩阵构成了三维正交群(special orthogonal group)
S O ( 3 ) = { R ∈ R 3 × 3 ∣ R R T = I , det ( R ) = 1 } SO(3) = \left \{ R \in {\mathbb R}^{3 \times 3} | RR^{T} =I, \det (R)=1 \right \} S O ( 3 ) = { R ∈ R 3 × 3 ∣ R R T = I , det ( R ) = 1 }
三维变换矩阵构成了特殊欧式群(special euclidean group)
S E ( 3 ) = { T = [ R t O T 1 ] ∈ R 4 × 4 ∣ R ∈ S O ( 3 ) , t ∈ R 3 } SE(3) = \left \{ T= \begin{bmatrix} R & t\\ O^{T} & 1 \end{bmatrix} \in {\mathbb R}^{4 \times 4} | R \in SO(3), t \in {\mathbb R}^{3} \right \} S E ( 3 ) = { T = [ R O T t 1 ] ∈ R 4 × 4 ∣ R ∈ S O ( 3 ) , t ∈ R 3 }
旋转矩阵集合与矩阵乘法构成群,变换矩阵集合与矩阵乘法也构成了群,因此称它们为旋转矩阵群和变换矩阵群。
群结构保证了在群上的运算具有良好的性质。
李群与李代数 李群 具有连续(光滑)性质的群;
既是群也是流形;
直观上看,一个刚体能够连续地在空间中运动,因此S O ( 3 ) SO(3) S O ( 3 ) 和S E ( 3 ) SE(3) S E ( 3 ) 都是李群,然而,它们都没有定义加法,所以很难进行取极限和求导等操作;
李代数 与李代数对应的一种结构,位于向量空间(李群单位元处的正切空间)s o ( 3 ) \mathfrak so(3) s o ( 3 ) ,s e ( 3 ) \mathfrak se(3) s e ( 3 )
从旋转矩阵引出旋转正交群的李代数:
对于相机的连续运动,旋转矩阵也随时间变化,则有:
R ( t ) R ( t ) T = I R ˙ ( t ) R ( t ) T + R ( t ) R ˙ ( t ) T = 0 对时间求导 R ˙ ( t ) R ( t ) T = − ( R ˙ ( t ) R ( t ) T ) T 反对称矩阵 记 R ˙ ( t ) R ( t ) T = ϕ ( t ) ∧ ⟹ R ˙ ( t ) = ϕ ( t ) ∧ R ( t ) \begin{aligned} & R(t)R(t)^{T} = I \\ & \dot{R}(t)R(t)^{T}+R(t)\dot{R}(t)^{T} = 0 \quad \quad 对时间求导\\ & \dot{R}(t)R(t)^{T} = - (\dot{R}(t)R(t)^{T})^{T} \quad \quad 反对称矩阵\\ & 记\dot{R}(t)R(t)^{T} = \phi (t)^{\wedge} \implies \dot{R}(t) = \phi (t)^{\wedge} R(t) \end{aligned} R ( t ) R ( t ) T = I R ˙ ( t ) R ( t ) T + R ( t ) R ˙ ( t ) T = 0 对 时 间 求 导 R ˙ ( t ) R ( t ) T = − ( R ˙ ( t ) R ( t ) T ) T 反 对 称 矩 阵 记 R ˙ ( t ) R ( t ) T = ϕ ( t ) ∧ ⟹ R ˙ ( t ) = ϕ ( t ) ∧ R ( t )
符号∧ \wedge ∧ 看作是反对称矩阵的符号,在这里是指将向量ϕ \phi ϕ 变成了反对称矩阵,这是由叉乘引申而来,在第二讲有提过。反过来符号∨ \vee ∨ 代表反对称矩阵到向量的变换。
上面的式子表示,对旋转矩阵求导,就是在其左侧乘以一个ϕ ( t ) \phi (t) ϕ ( t ) ,类似于指数函数的求导。
下面进行进一步地近似,假设在单位元附近,t 0 = 0 , R ( 0 ) = I t_{0}=0, R(0)=I t 0 = 0 , R ( 0 ) = I ,则:
R ( t ) ≈ R ( t 0 ) + R ˙ ( t 0 ) ( t − t 0 ) = I + ϕ ( t 0 ) ∧ ( t ) 将 R 在 t 0 进行泰勒展开,并忽略二次及以上高阶项 R(t) \approx R(t_{0}) + \dot {R}(t_{0})(t-t_{0}) = I + \phi (t_{0})^{\wedge} (t) \quad \quad 将R在t_{0}进行泰勒展开,并忽略二次及以上高阶项 R ( t ) ≈ R ( t 0 ) + R ˙ ( t 0 ) ( t − t 0 ) = I + ϕ ( t 0 ) ∧ ( t ) 将 R 在 t 0 进 行 泰 勒 展 开 , 并 忽 略 二 次 及 以 上 高 阶 项
进一步假设,在t 0 t_{0} t 0 附近,ϕ \phi ϕ 不变,则R ˙ ( t ) = ϕ ( t 0 ) ∧ R ( t ) = ϕ 0 ∧ R ( t ) \dot{R}(t)=\phi(t_{0})^{\wedge}R(t)=\phi_{0}^{\wedge} R(t) R ˙ ( t ) = ϕ ( t 0 ) ∧ R ( t ) = ϕ 0 ∧ R ( t ) ,再根据初值条件,得出:
R ( t ) = exp ( ϕ 0 ∧ t ) R(t) = \exp( \phi _{0} ^{\wedge} t) R ( t ) = exp ( ϕ 0 ∧ t )
在泰勒展开那一步可以看出,ϕ \phi ϕ 反映的是一阶导数的性质,位于旋转正交群的正切空间上(tangent space,切平面上)。
上述证明提供了一种思路,可能不太严谨。实际上可以证明最后得出的式子在任意时间都适用,且该关系称为指数映射(exponential map),ϕ \phi ϕ 称为S O ( 3 ) SO(3) S O ( 3 ) 对应的李代数s o ( 3 ) \mathfrak so(3) s o ( 3 ) 。
李群是高维空间的低维曲面,或者说低维流形,在流形原点附近的切空间上的任意一个点,是李代数,可以通过指数映射映回李群上。李代数描述了李群单位元附近的正切空间的性质。
李代数由一个集合 V ,一个数域 F ,和一个二元运算 [ , ] (李括号,直观上说表示了两个元素的差异)组成。如果满足下面的四条性质,称 ( V , F , [ , ] ) 为一个李代数,记作 g 。 1. 封闭性 ∀ X , Y ∈ V , [ X , Y ] ∈ V 2. 双线性 ∀ X , Y ∈ V , a , b ∈ F , 有: [ a X + b Y , Z ] = a [ X , Z ] + b [ Y , Z ] , [ Z , a X + b Y ] = a [ Z , X ] + b [ Z , Y ] 3. 自反性 ∀ X ∈ V , [ X , X ] = 0 4. 雅可比等价 ∀ X , Y , Z ∈ V , [ X , [ Y , Z ] ] + [ Z , [ Y , X ] ] + [ Y , [ Z , X ] ] = 0 \begin{aligned} & 李代数由一个集合\mathbb V,一个数域\mathbb F,和一个二元运算[,](李括号,直观上说表示了两个元素的差异)组成。如果满足下面的四条性质,称\\ & (\mathbb V, \mathbb F, [,])为一个李代数,记作 \mathfrak g。\\ &1. 封闭性 \quad \quad \forall {\bf X, Y}\in \mathbb V, [{\bf X,Y}] \in \mathbb V\\ &2. 双线性 \quad \quad \forall {\bf X, Y}\in \mathbb V, a,b \in \mathbb F,有: [a {\bf X} + b {\bf Y}, {\bf Z}] =a[{\bf X,Z}]+b[{\bf Y, Z}],[{\bf Z},a{\bf X}+b{\bf Y}] =a[{\bf Z,X}]+b[{\bf Z,Y}] \\ &3. 自反性 \quad \quad \forall {\bf X} \in \mathbb V, [{\bf X,X}]={\bf 0}\\ &4. 雅可比等价 \quad \quad \forall {\bf X,Y,Z} \in \mathbb V,[{\bf X},[{\bf Y,Z}]]+[{\bf Z},[{\bf Y,X}]]+[{\bf Y},[{\bf Z,X}]]= {\bf 0} \end{aligned} 李 代 数 由 一 个 集 合 V , 一 个 数 域 F , 和 一 个 二 元 运 算 [ , ] ( 李 括 号 , 直 观 上 说 表 示 了 两 个 元 素 的 差 异 ) 组 成 。 如 果 满 足 下 面 的 四 条 性 质 , 称 ( V , F , [ , ] ) 为 一 个 李 代 数 , 记 作 g 。 1 . 封 闭 性 ∀ X , Y ∈ V , [ X , Y ] ∈ V 2 . 双 线 性 ∀ X , Y ∈ V , a , b ∈ F , 有 : [ a X + b Y , Z ] = a [ X , Z ] + b [ Y , Z ] , [ Z , a X + b Y ] = a [ Z , X ] + b [ Z , Y ] 3 . 自 反 性 ∀ X ∈ V , [ X , X ] = 0 4 . 雅 可 比 等 价 ∀ X , Y , Z ∈ V , [ X , [ Y , Z ] ] + [ Z , [ Y , X ] ] + [ Y , [ Z , X ] ] = 0
李代数s o ( 3 ) \mathfrak so(3) s o ( 3 ) 可以看成是三维空间向量和叉积运算构成的,s o ( 3 ) = { ϕ ∈ R 3 , Φ = ϕ ∧ ∈ R 3 × 3 } so(3)=\left \{ \phi \in \mathbb R^{3}, \Phi = \phi ^{\wedge} \in \mathbb R^{3 \times 3} \right \} s o ( 3 ) = { ϕ ∈ R 3 , Φ = ϕ ∧ ∈ R 3 × 3 } ,其中:
Φ = ϕ ∧ = [ 0 − ϕ 3 ϕ 2 ϕ 3 0 − ϕ 1 − ϕ 2 ϕ 1 0 ] ∈ R 3 × 3 \Phi = \phi ^{\wedge} = \begin{bmatrix} 0 & - \phi_{3} & \phi _{2}\\ \phi _{3} & 0 & -\phi _{1}\\ -\phi _{2} & \phi _{1} & 0 \end{bmatrix} \in \mathbb R^{3 \times 3} Φ = ϕ ∧ = ⎣ ⎢ ⎡ 0 ϕ 3 − ϕ 2 − ϕ 3 0 ϕ 1 ϕ 2 − ϕ 1 0 ⎦ ⎥ ⎤ ∈ R 3 × 3
李括号[ ϕ 1 , ϕ 2 ] = ( Φ 1 Φ 2 − Φ 2 Φ 1 ) ∨ [\phi_{1},\phi_{2}] = (\Phi_{1} \Phi_{2} - \Phi_{2} \Phi_{1})^{\vee} [ ϕ 1 , ϕ 2 ] = ( Φ 1 Φ 2 − Φ 2 Φ 1 ) ∨ ,容易验证此李括号满足上述四条性质。
对于变换矩阵的特殊欧式群S E ( 3 ) SE(3) S E ( 3 ) ,也有对应的李代数s e ( 3 ) \mathfrak se(3) s e ( 3 ) (6维的向量)
s e ( 3 ) = { ξ = [ ρ ϕ ] ∈ R 6 , ρ ∈ R 3 , ϕ ∈ s e ( 3 ) , ξ ∧ = [ ϕ ∧ ρ 0 T 0 ] ∈ R 4 × 4 } \mathfrak se(3) = \left \{ \xi = \begin{bmatrix} \rho \\ \phi \end{bmatrix} \in \mathbb R^{6}, \rho \in \mathbb R^{3}, \phi \in \mathfrak se(3), \xi ^{\wedge} = \begin{bmatrix} \phi ^{\wedge} & \rho \\ {\bf 0}^{T} & 0 \end{bmatrix} \in \mathbb R^{4 \times 4} \right \} s e ( 3 ) = { ξ = [ ρ ϕ ] ∈ R 6 , ρ ∈ R 3 , ϕ ∈ s e ( 3 ) , ξ ∧ = [ ϕ ∧ 0 T ρ 0 ] ∈ R 4 × 4 }
此时还是以用符号∧ \wedge ∧ 来表示向量到矩阵的变换,只不过不再是限制于反对称矩阵。
设变换矩阵 g ( t ) = [ R α 0 T 1 ] ,则 g ( t ) − 1 = [ R T − R T α 0 T 1 ] 有 g ˙ ( t ) g ( t ) − 1 = [ R ˙ R T α − R ˙ R T α 0 T 0 ] = [ ω ∧ v 0 T 0 ] ,其中, ω ∧ ∈ R 3 × 3 , v ∈ R 3 , 记 ξ ∧ = g ˙ ( t ) g ( t ) − 1 ( ξ ∧ ) ∨ = [ v ω ] ∈ R 6 g ˙ ( t ) = ( g ˙ ( t ) g ( t ) − 1 ) g ( t ) = ξ ∧ g ( t ) , 则 g ( t ) = exp ( ξ ∧ ) , 假设 g ( 0 ) = I \begin{aligned} & 设变换矩阵g(t)= \begin{bmatrix} R & \alpha \\ {\bf 0}^{T} & 1 \end{bmatrix} ,则g(t)^{-1} = \begin{bmatrix} R^{T} & -R^{T}\alpha \\ {\bf 0}^{T} & 1 \end{bmatrix}\\ &有\dot{g}(t)g(t)^{-1}= \begin{bmatrix} \dot{R}R^{T} & \alpha- \dot{R}R^{T}\alpha \\ {\bf 0}^{T} & 0 \end{bmatrix} = \begin{bmatrix} \omega^{\wedge} & v\\ {\bf 0}^{T} &0 \end{bmatrix} ,其中,\omega^{\wedge} \in \mathbb R^{3 \times 3},v \in \mathbb R^{3},记 \xi^{\wedge}=\dot{g}(t)g(t)^{-1}\\ & (\xi^{\wedge})^{\vee}= \begin{bmatrix} v \\ \omega \end{bmatrix} \in \mathbb R^{6} \\ &\dot{g}(t)=(\dot{g}(t)g(t)^{-1})g(t)=\xi^{\wedge}g(t),则g(t)=\exp(\xi^{\wedge}),假设g(0)=I \end{aligned} 设 变 换 矩 阵 g ( t ) = [ R 0 T α 1 ] , 则 g ( t ) − 1 = [ R T 0 T − R T α 1 ] 有 g ˙ ( t ) g ( t ) − 1 = [ R ˙ R T 0 T α − R ˙ R T α 0 ] = [ ω ∧ 0 T v 0 ] , 其 中 , ω ∧ ∈ R 3 × 3 , v ∈ R 3 , 记 ξ ∧ = g ˙ ( t ) g ( t ) − 1 ( ξ ∧ ) ∨ = [ v ω ] ∈ R 6 g ˙ ( t ) = ( g ˙ ( t ) g ( t ) − 1 ) g ( t ) = ξ ∧ g ( t ) , 则 g ( t ) = exp ( ξ ∧ ) , 假 设 g ( 0 ) = I
李括号[ ξ 1 , ξ 2 ] = ( ξ 1 ∧ ξ 2 ∧ − ξ 2 ∧ ξ 1 ∧ ) ∨ [\xi _{1}, \xi _{2}] = (\xi _{1} ^{\wedge} \xi_{2} ^{\wedge} - \xi _{2} ^{\wedge} \xi_{1} ^{\wedge}) ^{\vee} [ ξ 1 , ξ 2 ] = ( ξ 1 ∧ ξ 2 ∧ − ξ 2 ∧ ξ 1 ∧ ) ∨
指数映射和对数映射 指数映射反映了李代数到李群的关系,对于旋转矩阵R R R ,有R = exp ( ϕ ∧ ) = ∑ n = 0 ∞ 1 n ! ( ϕ ∧ ) n R=\exp (\phi ^{\wedge})=\sum_{n=0}^{\infty} \frac{1}{n!}(\phi ^{\wedge})^{n} R = exp ( ϕ ∧ ) = ∑ n = 0 ∞ n ! 1 ( ϕ ∧ ) n
为了研究的方便,先将ϕ \phi ϕ 写成旋转向量的形式,即设ϕ = θ a ⃗ \phi = \theta \vec{a} ϕ = θ a ,其中a ⃗ \vec{a} a 是单位向量,而且具有以下性质
1. a ⃗ ∧ a ⃗ ∧ = a ⃗ a ⃗ T − I 2. a ⃗ ∧ a ⃗ ∧ a ⃗ ∧ = − a ⃗ ∧ \begin{aligned} &1.\vec{a}^{\wedge} \vec{a}^{\wedge} = \vec {a} \vec{a}^{T} - I \\ &2.\vec {a}^{\wedge} \vec {a}^{\wedge} \vec {a}^{\wedge} = -\vec {a}^{\wedge} \end{aligned} 1 . a ∧ a ∧ = a a T − I 2 . a ∧ a ∧ a ∧ = − a ∧
下面利用上述性质对exp ( ϕ ) ∧ \exp (\phi)^{\wedge} exp ( ϕ ) ∧ 进行Taylor展开
exp ( ϕ ) ∧ = exp ( θ a ⃗ ) = ∑ n = 0 ∞ 1 n ! ( θ a ⃗ ∧ ) n = I + θ a ⃗ ∧ + 1 2 ! θ 2 a ⃗ ∧ a ⃗ ∧ + 1 3 ! θ 3 a ⃗ ∧ a ⃗ ∧ a ⃗ ∧ + 1 4 ! θ 4 a ⃗ ∧ a ⃗ ∧ a ⃗ ∧ a ⃗ ∧ + ⋯ = a ⃗ a ⃗ T − a ⃗ ∧ a ⃗ ∧ + θ a ⃗ ∧ + 1 2 ! θ 2 a ⃗ ∧ a ⃗ ∧ − 1 3 ! θ 3 a ⃗ ∧ − 1 4 ! θ 4 a ⃗ ∧ a ⃗ ∧ + ⋯ = a ⃗ a ⃗ T + ( θ − 1 3 ! θ 3 + 1 5 ! θ 5 − ⋯ ) a ⃗ ∧ − ( 1 − 1 2 ! θ 2 + 1 4 ! θ 4 − ⋯ ) a ⃗ ∧ a ⃗ ∧ = a ⃗ ∧ a ⃗ ∧ + I + sin θ a ⃗ ∧ − cos θ a ⃗ ∧ a ⃗ ∧ = ( 1 − cos θ ) a ⃗ ∧ a ⃗ ∧ + I + sin θ a ⃗ ∧ = cos θ I + ( 1 − cos θ ) a ⃗ a ⃗ T + sin θ a ⃗ ∧ \begin{aligned} \exp (\phi)^{\wedge} & =\exp (\theta \vec{a}) = \sum _{n=0}^{\infty}\frac{1}{n!}(\theta \vec{a}^{\wedge})^{n}\\\\ & = I+\theta \vec{a}^{\wedge}+\frac{1}{2!}\theta ^{2} \vec{a}^{\wedge}\vec{a}^{\wedge}+\frac{1}{3!} \theta ^{3} \vec{a}^{\wedge}\vec{a}^{\wedge}\vec{a}^{\wedge}+\frac{1}{4!} \theta ^{4} \vec{a}^{\wedge}\vec{a}^{\wedge}\vec{a}^{\wedge}\vec{a}^{\wedge}+ \cdots\\\\ & = \vec{a}\vec{a}^{T}-\vec{a}^{\wedge}\vec{a}^{\wedge}+\theta \vec{a}^{\wedge}+\frac{1}{2!}\theta ^{2}\vec{a}^{\wedge}\vec{a}^{\wedge}-\frac{1}{3!} \theta^{3}\vec{a}^{\wedge}-\frac{1}{4!}\theta ^{4}\vec{a}^{\wedge}\vec{a}^{\wedge}+\cdots \\\\ & = \vec{a}\vec{a}^{T}+(\theta -\frac{1}{3!}\theta^{3}+\frac{1}{5!}\theta^{5}-\cdots)\vec{a}^{\wedge}-(1-\frac{1}{2!}\theta^{2}+\frac{1}{4!}\theta^{4}-\cdots)\vec{a}^{\wedge}\vec{a}^{\wedge}\\\\ & = \vec{a}^{\wedge}\vec{a}^{\wedge}+I+\sin \theta \vec{a}^{\wedge}-\cos \theta \vec{a}^{\wedge}\vec{a}^{\wedge}\\\\ & = (1-\cos \theta)\vec{a}^{\wedge}\vec{a}^{\wedge}+I+\sin \theta \vec{a}^{\wedge}\\\\ & = \cos \theta I+(1-\cos \theta)\vec{a}\vec{a}^{T}+\sin \theta \vec{a}^{\wedge} \end{aligned} exp ( ϕ ) ∧ = exp ( θ a ) = n = 0 ∑ ∞ n ! 1 ( θ a ∧ ) n = I + θ a ∧ + 2 ! 1 θ 2 a ∧ a ∧ + 3 ! 1 θ 3 a ∧ a ∧ a ∧ + 4 ! 1 θ 4 a ∧ a ∧ a ∧ a ∧ + ⋯ = a a T − a ∧ a ∧ + θ a ∧ + 2 ! 1 θ 2 a ∧ a ∧ − 3 ! 1 θ 3 a ∧ − 4 ! 1 θ 4 a ∧ a ∧ + ⋯ = a a T + ( θ − 3 ! 1 θ 3 + 5 ! 1 θ 5 − ⋯ ) a ∧ − ( 1 − 2 ! 1 θ 2 + 4 ! 1 θ 4 − ⋯ ) a ∧ a ∧ = a ∧ a ∧ + I + sin θ a ∧ − cos θ a ∧ a ∧ = ( 1 − cos θ ) a ∧ a ∧ + I + sin θ a ∧ = cos θ I + ( 1 − cos θ ) a a T + sin θ a ∧
这进一步说明了李代数s o ( 3 ) \mathfrak so(3) s o ( 3 ) 的物理意义确实就是旋转向量。
反之,给定旋转矩阵亦可以求出对应的李代数,即对数映射ϕ = ln ( R ) ∨ \phi = \ln(R)^{\vee} ϕ = ln ( R ) ∨ 。不过实际情况下可以通过旋转矩阵到向量的公式来得出李代数。
同理,可以得到s e ( 3 ) \mathfrak se(3) s e ( 3 ) 到S E ( 3 ) SE(3) S E ( 3 ) 的指数映射(具体推导过程会在作业中展示)
exp ( ξ ∧ ) = [ ∑ n = 0 ∞ 1 n ! ( ϕ ∧ ) n ∑ n = 0 ∞ 1 ( n + 1 ) ! ( ϕ ∧ ) n ρ 0 T 1 ] ≜ [ R J ρ 0 T 1 ] = T \begin{aligned} \exp(\xi^{\wedge}) & = \begin{bmatrix} \sum _{n=0}^{\infty}\frac{1}{n!}(\phi^{\wedge})^{n} & \sum _{n=0}^{\infty} \frac{1}{(n+1)!}(\phi ^{\wedge})^{n} \rho \\ {\bf 0}^{T} & 1 \end{bmatrix} \\ & \triangleq \begin{bmatrix} R & J\rho \\ {\bf 0}^{T} & 1 \end{bmatrix} \\ & = T \end{aligned} exp ( ξ ∧ ) = [ ∑ n = 0 ∞ n ! 1 ( ϕ ∧ ) n 0 T ∑ n = 0 ∞ ( n + 1 ) ! 1 ( ϕ ∧ ) n ρ 1 ] ≜ [ R 0 T J ρ 1 ] = T
其中J J J 为S E ( 3 ) SE(3) S E ( 3 ) 的雅可比矩阵,J = sin θ θ I + ( 1 − sin θ θ ) a ⃗ a ⃗ T + 1 − cos θ θ a ⃗ ∧ J=\frac{\sin \theta}{\theta} I + (1-\frac{\sin \theta} {\theta}) \vec{a} \vec{a}^{T} + \frac{1-\cos \theta} {\theta} \vec{a}^{\wedge} J = θ s i n θ I + ( 1 − θ s i n θ ) a a T + θ 1 − c o s θ a ∧
注意,这里的平移部分与变换矩阵的平移部分不完全相同,可以看出,指数映射会对李代数中的平移部分进行线性变换后才得到了真正的平移部分。
李代数求导与扰动模型 前面说过,视觉SLAM应用李群李代数的最初目的就是为了对相机的位姿进行优化。因为相机在观测世界的时候,会不可避免地引入噪声,而我们优化的目的就是会取N个观测,然后对其进行误差最小化,得到一个在这么多N个观测的过程中最优的变换关系。因此,针对优化(一般是最小化问题)问题,我们常用的手段就是求导,此时李代数的功能就体现出来了,因为李代数具有良好的加法运算,可以进行无约束优化问题分析。
不过问题是,李代数上的加法并不会对应李群上的乘法,即exp ( ϕ 1 ∧ ) exp ( ϕ 2 ∧ ) ≠ exp ( ( ϕ 1 + ϕ 2 ) ∧ ) \exp(\phi_{1}^{\wedge}) \exp(\phi_{2}^{\wedge}) \neq \exp ((\phi_{1}+\phi_{2})^{\wedge}) exp ( ϕ 1 ∧ ) exp ( ϕ 2 ∧ ) = exp ( ( ϕ 1 + ϕ 2 ) ∧ )
该关系由BCH公式(Baker-Campbell-Hausdorff)给出:
ln ( exp ( A ) exp ( B ) ) = A + B + 1 2 [ A , B ] + 1 12 [ A , [ A , B ] ] − 1 12 [ B . [ A , B ] ] + ⋯ \ln (\exp (A) \exp(B)) = A +B + \frac{1}{2} [A,B] + \frac{1}{12}[A,[A,B]] - \frac{1}{12}[B.[A,B]]+\cdots ln ( exp ( A ) exp ( B ) ) = A + B + 2 1 [ A , B ] + 1 2 1 [ A , [ A , B ] ] − 1 2 1 [ B . [ A , B ] ] + ⋯
如果其中一个量为小量,则有下列的近似表达关系:
ln ( exp ( ϕ 1 ∧ ) exp ( ϕ 2 ∧ ) ) ∨ ≈ { J l ( ϕ 2 ) − 1 ϕ 1 + ϕ 2 if ϕ 1 is small J r ( ϕ 1 ) − 1 ϕ 2 + ϕ 1 if ϕ 2 is small \ln (\exp (\phi_{1}^{\wedge}) \exp (\phi_{2}^{\wedge}))^{\vee} \approx \begin{cases} J_{l} (\phi _{2})^{-1} \phi_{1}+\phi_{2} \quad \quad \text{if $\phi_{1}$is small}\\ J_{r}(\phi_{1})^{-1} \phi_{2} + \phi_{1} \quad \quad \text{if $\phi_{2}$is small} \end{cases} ln ( exp ( ϕ 1 ∧ ) exp ( ϕ 2 ∧ ) ) ∨ ≈ { J l ( ϕ 2 ) − 1 ϕ 1 + ϕ 2 if ϕ 1 is small J r ( ϕ 1 ) − 1 ϕ 2 + ϕ 1 if ϕ 2 is small
其中:
J l = J = sin θ θ I + ( 1 − sin θ θ ) a ⃗ a ⃗ T + 1 − cos θ θ a ⃗ ∧ 左雅可比 J l − 1 = θ 2 cot θ 2 I + ( 1 − θ 2 cot θ 2 ) a ⃗ a ⃗ T − θ 2 a ⃗ ∧ J r ( ϕ ) = J l ( − ϕ ) 右雅可比 \begin{aligned} & J_{l}=J=\frac{\sin \theta}{\theta} I + (1-\frac{\sin \theta} {\theta}) \vec{a} \vec{a}^{T} + \frac{1-\cos \theta} {\theta} \vec{a}^{\wedge} \quad左雅可比\\ & J_{l}^{-1} = \frac{\theta}{2}\cot \frac{\theta}{2}I+(1-\frac{\theta}{2}\cot \frac{\theta}{2})\vec{a}\vec{a}^{T}-\frac{\theta}{2}\vec{a}^{\wedge}\\ & J_{r}(\phi) = J_{l}(-\phi) \quad 右雅可比 \end{aligned} J l = J = θ sin θ I + ( 1 − θ sin θ ) a a T + θ 1 − cos θ a ∧ 左 雅 可 比 J l − 1 = 2 θ cot 2 θ I + ( 1 − 2 θ cot 2 θ ) a a T − 2 θ a ∧ J r ( ϕ ) = J l ( − ϕ ) 右 雅 可 比
一般来说,利用T c w T_{cw} T c w 时会进行左乘,利用T w c T_{wc} T w c 时会进行右乘,以左乘为例,直观的写法是
exp ( Δ ϕ ∧ ) exp ( ϕ ∧ ) = exp ( ( J l ( ϕ ) − 1 Δ ϕ + ϕ ) ∧ ) 李群上的微小量乘法,李代数上的加法相差雅可比矩阵的逆 exp ( ( ϕ + Δ ϕ ) ∧ ) = exp ( ( J l Δ ϕ ) ∧ ) exp ( ϕ ∧ ) = exp ( ϕ ∧ ) exp ( ( J r Δ ϕ ) ∧ ) 李代数上的微小量加法,李群上要乘上雅可比矩阵 \begin{aligned} & \exp (\Delta \phi ^{\wedge}) \exp(\phi ^{\wedge}) = \exp ((J_{l}(\phi)^{-1}\Delta \phi +\phi)^{\wedge}) \quad \quad 李群上的微小量乘法,李代数上的加法相差雅可比矩阵的逆\\ & \exp((\phi + \Delta \phi)^{\wedge})=\exp ((J_{l}\Delta \phi)^{\wedge})\exp(\phi^{\wedge})=\exp(\phi^{\wedge}) \exp((J_{r}\Delta \phi)^{\wedge}) \quad \quad 李代数上的微小量加法,李群上要乘上雅可比矩阵 \end{aligned} exp ( Δ ϕ ∧ ) exp ( ϕ ∧ ) = exp ( ( J l ( ϕ ) − 1 Δ ϕ + ϕ ) ∧ ) 李 群 上 的 微 小 量 乘 法 , 李 代 数 上 的 加 法 相 差 雅 可 比 矩 阵 的 逆 exp ( ( ϕ + Δ ϕ ) ∧ ) = exp ( ( J l Δ ϕ ) ∧ ) exp ( ϕ ∧ ) = exp ( ϕ ∧ ) exp ( ( J r Δ ϕ ) ∧ ) 李 代 数 上 的 微 小 量 加 法 , 李 群 上 要 乘 上 雅 可 比 矩 阵
对于S E ( 3 ) SE(3) S E ( 3 ) 和s e ( 3 ) \mathfrak se(3) s e ( 3 ) ,关系要复杂一些(雅可比矩阵较为复杂,是个6 × 6 6 \times 6 6 × 6 矩阵,但在实际计算中不用到该雅可比):
exp ( Δ ξ ∧ ) exp ( ξ ∧ ) ≈ exp ( ( J l − 1 Δ ξ + ξ ) ∧ ) exp ( ξ ∧ ) exp ( Δ ξ ∧ ) ≈ exp ( ( J r − 1 Δ ξ + ξ ) ∧ ) \begin{aligned} & \exp(\Delta \xi ^{\wedge}) \exp(\xi ^{\wedge}) \approx \exp ((\mathcal J_{l}^{-1}\Delta \xi +\xi)^{\wedge})\\ & \exp(\xi ^{\wedge}) \exp (\Delta \xi^{\wedge}) \approx \exp ((\mathcal J_{r}^{-1} \Delta \xi+\xi)^{\wedge}) \end{aligned} exp ( Δ ξ ∧ ) exp ( ξ ∧ ) ≈ exp ( ( J l − 1 Δ ξ + ξ ) ∧ ) exp ( ξ ∧ ) exp ( Δ ξ ∧ ) ≈ exp ( ( J r − 1 Δ ξ + ξ ) ∧ )
有了上述公示后,开始对旋转矩阵进行求导,这里有两种方法,一种是导数定义求导,一种是通过扰动模型进行求导,实际中,扰动模型因为形式更加简单,因此采用的更多,先不严谨地记旋转后的点关于旋转矩阵的导数的求导式为 ∂ ( R p ) ∂ R \frac{\partial (Rp)}{\partial R} ∂ R ∂ ( R p )
导数模型:
∂ ( exp ( ϕ ∧ ) p ) ∂ ϕ = lim δ ϕ → 0 exp ( ( ϕ + δ ϕ ) ∧ ) p − exp ( ϕ ∧ ) p δ ϕ = lim δ ϕ → 0 exp ( ( J l δ ϕ ) ∧ ) exp ( ϕ ∧ ) p − exp ( ϕ ∧ ) p δ ϕ ≈ lim δ ϕ → 0 ( I + ( J l δ ϕ ) ∧ ) exp ( ϕ ∧ ) p − exp ( ϕ ∧ ) p δ ϕ = lim δ ϕ → 0 ( J l δ ϕ ) ∧ exp ( ϕ ∧ ) p δ ϕ = lim δ ϕ → 0 − ( exp ( ϕ ∧ ) p ) ∧ J l δ ϕ δ ϕ = − ( R p ) ∧ J l \begin{aligned} \frac{\partial(\exp (\phi^{\wedge})p)}{\partial \phi} & = \lim_{\delta \phi \to 0} \frac{\exp((\phi+\delta \phi)^{\wedge})p-\exp(\phi^{\wedge})p}{\delta \phi} \\ & = \lim_{\delta \phi \to 0} \frac{\exp ((J_{l}\delta \phi)^{\wedge})\exp(\phi^{\wedge})p-\exp (\phi^{\wedge})p}{\delta \phi}\\ & \approx \lim_{\delta \phi \to 0} \frac{(I+(J_{l}\delta \phi)^{\wedge})\exp(\phi^{\wedge})p-\exp(\phi^{\wedge})p}{\delta \phi} \\ & = \lim_{\delta \phi \to 0} \frac{(J_{l}\delta \phi)^{\wedge}\exp(\phi^{\wedge})p}{\delta \phi}\\ & = \lim_{\delta \phi \to 0} \frac{-(\exp(\phi^{\wedge})p)^{\wedge} J_{l}\delta \phi}{\delta \phi} \\ & = -(Rp)^{\wedge}J_{l} \end{aligned} ∂ ϕ ∂ ( exp ( ϕ ∧ ) p ) = δ ϕ → 0 lim δ ϕ exp ( ( ϕ + δ ϕ ) ∧ ) p − exp ( ϕ ∧ ) p = δ ϕ → 0 lim δ ϕ exp ( ( J l δ ϕ ) ∧ ) exp ( ϕ ∧ ) p − exp ( ϕ ∧ ) p ≈ δ ϕ → 0 lim δ ϕ ( I + ( J l δ ϕ ) ∧ ) exp ( ϕ ∧ ) p − exp ( ϕ ∧ ) p = δ ϕ → 0 lim δ ϕ ( J l δ ϕ ) ∧ exp ( ϕ ∧ ) p = δ ϕ → 0 lim δ ϕ − ( exp ( ϕ ∧ ) p ) ∧ J l δ ϕ = − ( R p ) ∧ J l
扰动模型(左乘微小量):
∂ ( R p ) ∂ R = lim δ ϕ → 0 exp ( ( δ ϕ ) ∧ ) exp ( ϕ ∧ ) p − exp ( ϕ ∧ ) p δ ϕ ≈ lim δ ϕ → 0 ( I + ( δ ϕ ) ∧ ) exp ( ϕ ∧ ) p − exp ( ϕ ∧ ) p δ ϕ = lim δ ϕ → 0 ( δ ϕ ) ∧ R p δ ϕ = − ( R p ) ∧ \begin{aligned} \frac{\partial(Rp)}{\partial R} & = \lim_{\delta \phi \to 0} \frac{\exp((\delta \phi)^{\wedge})\exp(\phi^{\wedge})p-\exp(\phi^{\wedge})p}{\delta \phi}\\ & \approx \lim_{\delta \phi \to 0} \frac{(I+(\delta \phi)^{\wedge})\exp(\phi^{\wedge})p-\exp(\phi^{\wedge})p}{\delta \phi}\\ & = \lim_{\delta \phi \to 0} \frac{(\delta \phi)^{\wedge}Rp}{\delta \phi} = -(Rp)^{\wedge} \end{aligned} ∂ R ∂ ( R p ) = δ ϕ → 0 lim δ ϕ exp ( ( δ ϕ ) ∧ ) exp ( ϕ ∧ ) p − exp ( ϕ ∧ ) p ≈ δ ϕ → 0 lim δ ϕ ( I + ( δ ϕ ) ∧ ) exp ( ϕ ∧ ) p − exp ( ϕ ∧ ) p = δ ϕ → 0 lim δ ϕ ( δ ϕ ) ∧ R p = − ( R p ) ∧
同理可得,S E ( 3 ) SE(3) S E ( 3 ) 上的扰动模型(左乘微小量)为:
∂ ( T p ) ∂ δ ξ = [ I − ( R p + t ) ∧ 0 T 0 T ] ≜ ( T p ) ⊙ \frac{\partial (Tp)}{\partial \delta \xi}= \begin{bmatrix} I & -(Rp+t)^{\wedge}\\ {\bf 0}^{T} & {\bf 0}^{T} \end{bmatrix} \triangleq (Tp)^{\odot} ∂ δ ξ ∂ ( T p ) = [ I 0 T − ( R p + t ) ∧ 0 T ] ≜ ( T p ) ⊙
相似变换 对于单目视觉,由于存在尺度不确定性,因此不能使用S E ( 3 ) SE(3) S E ( 3 ) 来表达位姿变化,而是利用相似变换群S i m ( 3 ) Sim(3) S i m ( 3 ) ,也就是说要加一个尺度因子s s s ,这个尺度因子会同时作用在变换的点p p p 上,对其进行缩放,也就是在相机坐标系下进行了一次相似变换,而不是欧式变换,即:p ′ = s R p + t p^{'} = sRp+t p ′ = s R p + t
S i m ( 3 ) = { [ S = s R t 0 T 1 ] ∈ R 4 × 4 } Sim(3)=\left\{\left[ \begin{array}{lll}{\boldsymbol{S}=} & {\boldsymbol{s} \boldsymbol{R}} & {\boldsymbol{t}} \\ {\boldsymbol{0}^{T}} & {1}\end{array}\right] \in \mathbb{R}^{4 \times 4}\right\} S i m ( 3 ) = { [ S = 0 T s R 1 t ] ∈ R 4 × 4 }
s i m ( 3 ) = { ζ ∣ ζ = [ ρ ϕ σ ] ∈ R 7 , ζ ∧ = [ σ I + ϕ ∧ ρ 0 T 0 ] ∈ R 4 × 4 } \mathfrak sim(3)=\left\{\zeta | \zeta=\left[ \begin{array}{l}{\rho} \\ {\phi} \\ {\sigma}\end{array}\right] \in \mathbb{R}^{7}, \zeta^{\wedge}=\left[ \begin{array}{cc}{\sigma I+\phi^{\wedge}} & {\rho} \\ {0^{T}} & {0}\end{array}\right] \in \mathbb{R}^{4 \times 4}\right\} s i m ( 3 ) = ⎩ ⎪ ⎨ ⎪ ⎧ ζ ∣ ζ = ⎣ ⎢ ⎡ ρ ϕ σ ⎦ ⎥ ⎤ ∈ R 7 , ζ ∧ = [ σ I + ϕ ∧ 0 T ρ 0 ] ∈ R 4 × 4 ⎭ ⎪ ⎬ ⎪ ⎫
exp ( ζ ∧ ) = [ e σ exp ( ϕ ∧ ) J s ρ 0 T 1 ] \exp \left(\zeta^{\wedge}\right)=\left[ \begin{array}{cc}{e^{\sigma} \exp \left(\phi^{\wedge}\right)} & {J_{s} \rho} \\ {0^{T}} & {1}\end{array}\right] exp ( ζ ∧ ) = [ e σ exp ( ϕ ∧ ) 0 T J s ρ 1 ]
J s = e σ − 1 σ I + σ e σ sin θ + ( 1 − e σ cos θ ) θ σ 2 + θ 2 a ∧ + ( e σ − 1 σ − ( e σ cos θ − 1 ) σ + ( e σ sin θ ) θ σ 2 + θ 2 ) a ∧ a ∧ \begin{aligned} J_{s}=& \frac{e^{\sigma}-1}{\sigma} I+\frac{\sigma e^{\sigma} \sin \theta+\left(1-e^{\sigma} \cos \theta\right) \theta}{\sigma^{2}+\theta^{2}} a^{\wedge} \\ &+\left(\frac{e^{\sigma}-1}{\sigma}-\frac{\left(e^{\sigma} \cos \theta-1\right) \sigma+\left(e^{\sigma} \sin \theta\right) \theta}{\sigma^{2}+\theta^{2}}\right) a^{\wedge} a^{\wedge} \end{aligned} J s = σ e σ − 1 I + σ 2 + θ 2 σ e σ sin θ + ( 1 − e σ cos θ ) θ a ∧ + ( σ e σ − 1 − σ 2 + θ 2 ( e σ cos θ − 1 ) σ + ( e σ sin θ ) θ ) a ∧ a ∧
s = e σ , R = exp ( ϕ ∧ ) , t = J s ρ s=e^{\sigma}, \boldsymbol{R}=\exp \left(\boldsymbol{\phi}^{\wedge}\right), \boldsymbol{t}=\boldsymbol{J}_{s} \boldsymbol{\rho} s = e σ , R = exp ( ϕ ∧ ) , t = J s ρ
对于S i m ( 3 ) Sim(3) S i m ( 3 ) 的求导,利用左扰动模型和BCH近似(这里的BCH近似与S E ( 3 ) SE(3) S E ( 3 ) 公式不同)。假设点p p p 经过相似变换S p Sp S p 后,相对于S S S 的导数为:
∂ S p ∂ ζ = [ I − q ∧ q 0 T 0 T 0 ] \frac{\partial S p}{\partial \zeta}=\left[ \begin{array}{ccc}{\boldsymbol{I}} & {-\boldsymbol{q}^{\wedge}} & {\boldsymbol{q}} \\ {\mathbf{0}^{T}} & {\mathbf{0}^{T}} & {0}\end{array}\right] ∂ ζ ∂ S p = [ I 0 T − q ∧ 0 T q 0 ]
其中q q q 是S p Sp S p 的前三维向量,最后的形式应该是4 × 7 4 \times 7 4 × 7 的雅可比矩阵。
有关相似变换群的更为详细的理解和运用,等后面进行实际应用时再说,毕竟库已经提供好了,而且推导过程也与S E ( 3 ) SE(3) S E ( 3 ) 类似。
作业与实践 群的性质 群要满足封闭性,结合律,幺元和逆这四个性质。其中,满足前两个性质的叫半群,满足前三个性质的叫有单位元的半群,若满足了上述四个性质,还具有交换律的叫做阿贝尔群。
对于{ Z , + } \left \{ \mathbb Z, + \right \} { Z , + } 封闭性和结合律显然满足,幺元是0,逆为自身的相反数,因此是群,而且是阿贝尔群。
对于{ N , + } \left \{ \mathbb N, +\right \} { N , + } ,前三个性质都满足,幺元是0,但是除了0之外,其他的元素不存在逆,因此不是群,是有单位元的半群。
验证向量叉乘的李代数性质 设X = a 1 i ⃗ + b 1 j ⃗ + c 1 k ⃗ , Y = a 2 i ⃗ + b 2 j ⃗ + c 2 k ⃗ , Z = a 3 i ⃗ + b 3 j ⃗ + z 3 k ⃗ {\bf X}=a_{1}\vec{i}+b_{1}\vec{j}+c_{1}\vec{k}, {\bf Y}=a_{2}\vec{i}+b_{2}\vec{j}+c_{2}\vec{k}, {\bf Z}=a_{3}\vec{i}+b_{3}\vec{j}+z_{3}\vec{k} X = a 1 i + b 1 j + c 1 k , Y = a 2 i + b 2 j + c 2 k , Z = a 3 i + b 3 j + z 3 k
封闭性:
[ X , Y ] = X × Y ∈ R 3 [{\bf X},{\bf Y}] = {\bf X} \times {\bf Y} \in \mathbb R^{3} [ X , Y ] = X × Y ∈ R 3
双线性:
[ a X + b Y , Z ] = ( a X + b Y ) × Z = a X × Z + b Y × Z = a [ X , Z ] + b [ Y , Z ] [ Z , a X + b Y ] = Z × ( a X + b Y ) = Z × a X + Z × b Y = a [ Z , X ] + b [ Z , Y ] \begin{aligned} & [a{\bf X}+b{\bf Y},{\bf Z}]=(a{\bf X}+b{\bf Y}) \times {\bf Z}=a{\bf X}\times {\bf Z}+b{\bf Y} \times {\bf Z} = a[{\bf X,Z}]+b[{\bf Y,Z}]\\ & [{\bf Z},a{\bf X}+b{\bf Y}]={\bf Z} \times (a{\bf X}+b{\bf Y})={\bf Z}\times a {\bf X}+{\bf Z} \times b{\bf Y}=a[{\bf Z,X}]+b[{\bf Z,Y}] \end{aligned} [ a X + b Y , Z ] = ( a X + b Y ) × Z = a X × Z + b Y × Z = a [ X , Z ] + b [ Y , Z ] [ Z , a X + b Y ] = Z × ( a X + b Y ) = Z × a X + Z × b Y = a [ Z , X ] + b [ Z , Y ]
自反性:
[ X , X ] = X × X = 0 [{\bf X,X}]={\bf X} \times {\bf X}={\bf 0} [ X , X ] = X × X = 0
雅可比等价:
[ X , [ Y , Z ] ] + [ Y , [ Z , X ] ] + [ Z , [ X , Y ] ] = X × Y × Z + Y × Z × X + Z × X × Y = X ∧ Z ∧ Y + Y ∧ X ∧ Z + Z ∧ Y ∧ X = [ 0 − c 1 b 1 c 1 0 − a 1 − b 1 a 1 0 ] [ 0 − c 3 b 3 c 3 0 − a 3 − b 3 a 3 0 ] [ a 2 b 2 c 2 ] + [ 0 − c 2 b 2 c 2 0 − a 2 − b 2 a 2 0 ] [ 0 − c 1 b 1 c 1 0 − a 1 − b 1 a 1 0 ] [ a 3 b 3 c 3 ] + [ 0 − c 3 b 3 c 3 0 − a 3 − b 3 a 3 0 ] [ 0 − c 2 b 2 c 2 0 − a 2 − b 2 a 2 0 ] [ a 1 b 1 c 1 ] = [ a 3 ( b 1 b 2 + c 1 c 2 ) − a 2 ( b 1 b 3 + c 1 c 3 ) b 3 ( a 1 a 2 + c 1 c 2 ) − b 2 ( a 1 a 3 + c 1 c 3 ) c 3 ( a 1 a 2 + b 1 b 2 ) − c 2 ( b 1 b 3 + a 1 a 3 ) ] + [ a 1 ( b 2 b 3 + c 2 c 3 ) − a 3 ( b 1 b 2 + c 1 c 2 ) b 1 ( a 2 a 3 + c 2 c 3 ) − b 3 ( a 1 a 2 + c 1 c 2 ) c 1 ( a 2 a 3 + b 2 b 3 ) − c 3 ( b 1 b 2 + a 1 a 2 ) ] + [ a 2 ( b 1 b 3 + c 1 c 3 ) − a 1 ( b 2 b 3 + c 1 c 3 ) b 2 ( a 1 a 3 + c 1 c 3 ) − b 1 ( a 2 a 3 + c 1 c 3 ) c 2 ( a 1 a 3 + b 1 b 3 ) − c 1 ( b 2 b 3 + a 1 a 3 ) ] = [ 0 0 0 ] = 0 \begin{aligned} &[{\bf X},[{\bf Y,Z}]]+[{\bf Y},[{\bf Z,X}]]+[{\bf Z},[{\bf X,Y}]]\\ & ={\bf X} \times {\bf Y} \times {\bf Z}+{\bf Y} \times {\bf Z} \times {\bf X}+{\bf Z} \times {\bf X} \times {\bf Y}\\ & = {\bf X}^{\wedge} {\bf Z}^{\wedge} {\bf Y}+{\bf Y}^{\wedge} {\bf X}^{\wedge} {\bf Z}+{\bf Z}^{\wedge} {\bf Y}^{\wedge} {\bf X}\\ & = \begin{bmatrix} 0 & -c_{1} & b_{1}\\ c_{1} & 0 & -a_{1}\\ -b_{1} & a_{1} &0 \end{bmatrix} \begin{bmatrix} 0 & -c_{3} & b_{3}\\ c_{3} & 0 & -a_{3}\\ -b_{3} & a_{3} & 0 \end{bmatrix} \begin{bmatrix} a_{2}\\ b_{2}\\ c_{2} \end{bmatrix} + \begin{bmatrix} 0 & -c_{2} & b_{2}\\ c_{2} & 0 & -a_{2}\\ -b_{2} & a_{2} &0 \end{bmatrix} \begin{bmatrix} 0 & -c_{1} & b_{1}\\ c_{1} & 0 & -a_{1}\\ -b_{1} & a_{1} & 0 \end{bmatrix} \begin{bmatrix} a_{3}\\ b_{3}\\ c_{3} \end{bmatrix} + \begin{bmatrix} 0 & -c_{3} & b_{3}\\ c_{3} & 0 & -a_{3}\\ -b_{3} & a_{3} &0 \end{bmatrix} \begin{bmatrix} 0 & -c_{2} & b_{2}\\ c_{2} & 0 & -a_{2}\\ -b_{2} & a_{2} & 0 \end{bmatrix} \begin{bmatrix} a_{1}\\ b_{1}\\ c_{1} \end{bmatrix} \\ & = \begin{bmatrix} a_{3}(b_{1}b_{2}+c_{1}c_{2})-a_{2}(b_{1}b_{3}+c_{1}c_{3})\\ b_{3}(a_{1}a_{2}+c_{1}c_{2})-b_{2}(a_{1}a_{3}+c_{1}c_{3})\\ c_{3}(a_{1}a_{2}+b_{1}b_{2})-c_{2}(b_{1}b_{3}+a_{1}a_{3}) \end{bmatrix} + \begin{bmatrix} a_{1}(b_{2}b_{3}+c_{2}c_{3})-a_{3}(b_{1}b_{2}+c_{1}c_{2})\\ b_{1}(a_{2}a_{3}+c_{2}c_{3})-b_{3}(a_{1}a_{2}+c_{1}c_{2})\\ c_{1}(a_{2}a_{3}+b_{2}b_{3})-c_{3}(b_{1}b_{2}+a_{1}a_{2}) \end{bmatrix} + \begin{bmatrix} a_{2}(b_{1}b_{3}+c_{1}c_{3})-a_{1}(b_{2}b_{3}+c_{1}c_{3})\\ b_{2}(a_{1}a_{3}+c_{1}c_{3})-b_{1}(a_{2}a_{3}+c_{1}c_{3})\\ c_{2}(a_{1}a_{3}+b_{1}b_{3})-c_{1}(b_{2}b_{3}+a_{1}a_{3}) \end{bmatrix} \\ & = \begin{bmatrix} 0\\ 0\\ 0 \end{bmatrix} ={\bf 0} \end{aligned} [ X , [ Y , Z ] ] + [ Y , [ Z , X ] ] + [ Z , [ X , Y ] ] = X × Y × Z + Y × Z × X + Z × X × Y = X ∧ Z ∧ Y + Y ∧ X ∧ Z + Z ∧ Y ∧ X = ⎣ ⎢ ⎡ 0 c 1 − b 1 − c 1 0 a 1 b 1 − a 1 0 ⎦ ⎥ ⎤ ⎣ ⎢ ⎡ 0 c 3 − b 3 − c 3 0 a 3 b 3 − a 3 0 ⎦ ⎥ ⎤ ⎣ ⎢ ⎡ a 2 b 2 c 2 ⎦ ⎥ ⎤ + ⎣ ⎢ ⎡ 0 c 2 − b 2 − c 2 0 a 2 b 2 − a 2 0 ⎦ ⎥ ⎤ ⎣ ⎢ ⎡ 0 c 1 − b 1 − c 1 0 a 1 b 1 − a 1 0 ⎦ ⎥ ⎤ ⎣ ⎢ ⎡ a 3 b 3 c 3 ⎦ ⎥ ⎤ + ⎣ ⎢ ⎡ 0 c 3 − b 3 − c 3 0 a 3 b 3 − a 3 0 ⎦ ⎥ ⎤ ⎣ ⎢ ⎡ 0 c 2 − b 2 − c 2 0 a 2 b 2 − a 2 0 ⎦ ⎥ ⎤ ⎣ ⎢ ⎡ a 1 b 1 c 1 ⎦ ⎥ ⎤ = ⎣ ⎢ ⎡ a 3 ( b 1 b 2 + c 1 c 2 ) − a 2 ( b 1 b 3 + c 1 c 3 ) b 3 ( a 1 a 2 + c 1 c 2 ) − b 2 ( a 1 a 3 + c 1 c 3 ) c 3 ( a 1 a 2 + b 1 b 2 ) − c 2 ( b 1 b 3 + a 1 a 3 ) ⎦ ⎥ ⎤ + ⎣ ⎢ ⎡ a 1 ( b 2 b 3 + c 2 c 3 ) − a 3 ( b 1 b 2 + c 1 c 2 ) b 1 ( a 2 a 3 + c 2 c 3 ) − b 3 ( a 1 a 2 + c 1 c 2 ) c 1 ( a 2 a 3 + b 2 b 3 ) − c 3 ( b 1 b 2 + a 1 a 2 ) ⎦ ⎥ ⎤ + ⎣ ⎢ ⎡ a 2 ( b 1 b 3 + c 1 c 3 ) − a 1 ( b 2 b 3 + c 1 c 3 ) b 2 ( a 1 a 3 + c 1 c 3 ) − b 1 ( a 2 a 3 + c 1 c 3 ) c 2 ( a 1 a 3 + b 1 b 3 ) − c 1 ( b 2 b 3 + a 1 a 3 ) ⎦ ⎥ ⎤ = ⎣ ⎢ ⎡ 0 0 0 ⎦ ⎥ ⎤ = 0
则g = ( R 3 , R , × ) \mathfrak g =(\mathbb R^{3}, \mathbb R, \times) g = ( R 3 , R , × ) 构成李代数。
推导S E ( 3 ) SE(3) S E ( 3 ) 的指数映射 推导S E ( 3 ) SE(3) S E ( 3 ) 指数映射部分左雅可比的形式:
J ≜ ∑ n = 0 ∞ 1 ( n + 1 ) ! ( ϕ ∧ ) n = ∑ n = 0 ∞ 1 ( n + 1 ) ! ( θ a ∧ ) n = I + 1 2 ! θ a ∧ + 1 3 ! θ 2 a ∧ a ∧ − 1 4 ! θ 3 a ∧ a ∧ a ∧ + 1 5 ! θ 4 a ∧ a ∧ a ∧ a ∧ + ⋯ = a a T − a ∧ a ∧ + 1 2 ! θ a ∧ + 1 3 ! θ 2 a ∧ a ∧ − 1 4 ! θ 3 a ∧ − 1 5 ! θ 4 a ∧ a ∧ + ⋯ = 1 θ { a a T θ − a ∧ a ∧ θ + a ∧ − a ∧ + 1 2 ! θ 2 a ∧ + 1 3 ! θ 3 a ∧ a ∧ − 1 4 ! θ 4 a ∧ − 1 5 ! θ 5 a ∧ a ∧ + ⋯ } = 1 θ { a a T θ − a ∧ a ∧ ( θ − 1 3 ! θ 3 + 1 5 ! θ 5 + ⋯ ) − a ∧ ( 1 − 1 2 ! θ 2 + 1 4 ! θ 4 + ⋯ ) + a ∧ } = 1 θ { a a T θ − a ∧ a ∧ sin θ − a ∧ cos θ + a ∧ } = 1 θ { a a T θ − sin θ ( a a T − I ) + a ∧ ( 1 − cos θ ) } = 1 θ { sin θ I + ( θ − sin θ ) a a T + ( 1 − cos θ ) a ∧ } = sin θ θ I + ( 1 − sin θ θ ) a a T + 1 − cos θ θ a ∧ \begin{aligned} J & \triangleq \sum_{n=0}^{\infty} \frac{1}{(n+1)!}(\phi ^{\wedge})^{n}=\sum_{n=0}^{\infty} \frac{1}{(n+1)!}(\theta a^{\wedge})^{n}\\ & =I+\frac{1}{2!}\theta a^{\wedge}+\frac{1}{3!} \theta^{2}a^{\wedge}a^{\wedge}-\frac{1}{4!}\theta^{3}a^{\wedge}a^{\wedge}a^{\wedge}+\frac{1}{5!}\theta^{4}a^{\wedge}a^{\wedge}a^{\wedge}a^{\wedge}+\cdots\\ & =aa^{T}-a^{\wedge}a^{\wedge}+\frac{1}{2!}\theta a^{\wedge}+\frac{1}{3!}\theta^{2}a^{\wedge}a^{\wedge}-\frac{1}{4!}\theta^{3}a^{\wedge}-\frac{1}{5!}\theta^{4}a^{\wedge}a^{\wedge}+\cdots \\ & = \frac{1}{\theta}\left \{ aa^{T}\theta-a^{\wedge}a^{\wedge}\theta+a^{\wedge}-a^{\wedge}+\frac{1}{2!}\theta^{2}a^{\wedge}+\frac{1}{3!}\theta^{3}a^{\wedge}a^{\wedge}-\frac{1}{4!}\theta^{4}a^{\wedge}-\frac{1}{5!}\theta^{5}a^{\wedge}a^{\wedge}+\cdots \right \} \\ & = \frac{1}{\theta} \left \{ aa^{T}\theta - a^{\wedge}a^{\wedge}(\theta-\frac{1}{3!}\theta^{3}+\frac{1}{5!}\theta^{5}+\cdots)-a^{\wedge}(1-\frac{1}{2!}\theta^{2}+\frac{1}{4!}\theta^{4}+\cdots)+a^{\wedge} \right\}\\ & = \frac{1}{\theta} \left \{ aa^{T}\theta - a^{\wedge}a^{\wedge}\sin \theta -a^{\wedge}\cos \theta +a^{\wedge} \right \}\\ & = \frac{1}{\theta} \left \{ aa^{T}\theta-\sin \theta (aa^{T}-I)+a^{\wedge}(1-\cos \theta) \right \} \\ & = \frac{1}{\theta} \left \{ \sin \theta I +(\theta-\sin \theta)aa^{T}+(1-\cos \theta)a^{\wedge} \right \} \\ & = \frac{\sin \theta}{\theta}I + (1-\frac{\sin \theta}{\theta})aa^{T}+\frac{1-\cos \theta}{\theta}a^{\wedge} \end{aligned} J ≜ n = 0 ∑ ∞ ( n + 1 ) ! 1 ( ϕ ∧ ) n = n = 0 ∑ ∞ ( n + 1 ) ! 1 ( θ a ∧ ) n = I + 2 ! 1 θ a ∧ + 3 ! 1 θ 2 a ∧ a ∧ − 4 ! 1 θ 3 a ∧ a ∧ a ∧ + 5 ! 1 θ 4 a ∧ a ∧ a ∧ a ∧ + ⋯ = a a T − a ∧ a ∧ + 2 ! 1 θ a ∧ + 3 ! 1 θ 2 a ∧ a ∧ − 4 ! 1 θ 3 a ∧ − 5 ! 1 θ 4 a ∧ a ∧ + ⋯ = θ 1 { a a T θ − a ∧ a ∧ θ + a ∧ − a ∧ + 2 ! 1 θ 2 a ∧ + 3 ! 1 θ 3 a ∧ a ∧ − 4 ! 1 θ 4 a ∧ − 5 ! 1 θ 5 a ∧ a ∧ + ⋯ } = θ 1 { a a T θ − a ∧ a ∧ ( θ − 3 ! 1 θ 3 + 5 ! 1 θ 5 + ⋯ ) − a ∧ ( 1 − 2 ! 1 θ 2 + 4 ! 1 θ 4 + ⋯ ) + a ∧ } = θ 1 { a a T θ − a ∧ a ∧ sin θ − a ∧ cos θ + a ∧ } = θ 1 { a a T θ − sin θ ( a a T − I ) + a ∧ ( 1 − cos θ ) } = θ 1 { sin θ I + ( θ − sin θ ) a a T + ( 1 − cos θ ) a ∧ } = θ sin θ I + ( 1 − θ sin θ ) a a T + θ 1 − cos θ a ∧
至于为什么雅可比矩阵是这种形式,即J = ∑ n = 0 ∞ 1 ( n + 1 ) ! ( ϕ ∧ ) n J=\sum_{n=0}^{\infty} \frac{1}{(n+1)!}(\phi ^{\wedge})^{n} J = ∑ n = 0 ∞ ( n + 1 ) ! 1 ( ϕ ∧ ) n 是从何而来的,这个在state estimation for robotics
一书的223-226有讲到,但是写的很抽象,下面给出证明:
ξ ∧ = [ ϕ ∧ ρ 0 T 0 ] ξ ∧ ξ ∧ = [ ϕ ∧ ρ 0 T 0 ] [ ϕ ∧ ρ 0 T 0 ] = ϕ ∧ ξ ∧ ξ ∧ ξ ∧ ξ ∧ = ( ϕ ∧ ) 2 ξ ∧ \begin{aligned} & \xi ^{\wedge} = \begin{bmatrix} \phi ^{\wedge} & \rho \\ {\bf 0}^{T} & 0 \end{bmatrix} \\ & \xi ^{\wedge} \xi^{\wedge}= \begin{bmatrix} \phi ^{\wedge} & \rho \\ {\bf 0}^{T} & 0 \end{bmatrix} \begin{bmatrix} \phi ^{\wedge} & \rho \\ {\bf 0}^{T} & 0 \end{bmatrix} =\phi ^{\wedge} \xi^{\wedge} \\ & \xi^{\wedge}\xi^{\wedge}\xi^{\wedge}=(\phi ^{\wedge})^{2}\xi^{\wedge} \end{aligned} ξ ∧ = [ ϕ ∧ 0 T ρ 0 ] ξ ∧ ξ ∧ = [ ϕ ∧ 0 T ρ 0 ] [ ϕ ∧ 0 T ρ 0 ] = ϕ ∧ ξ ∧ ξ ∧ ξ ∧ ξ ∧ = ( ϕ ∧ ) 2 ξ ∧
exp ( ξ ∧ ) = ∑ n = 0 ∞ 1 n ! ( ξ ∧ ) n = I + ξ ∧ + 1 2 ! ξ ∧ ξ ∧ + 1 3 ! ξ ∧ ξ ∧ ξ ∧ + ⋯ = I + ξ ∧ + 1 2 ! ϕ ∧ ξ ∧ + 1 3 ! ( ϕ ∧ ) 2 ξ ∧ + ⋯ = I + ∑ n = 0 ∞ 1 ( n + 1 ) ! ( ϕ ∧ ) n ξ ∧ = [ I + ∑ n = 0 ∞ 1 ( n + 1 ) ! ( ϕ ∧ ) n + 1 ∑ n = 0 ∞ 1 ( n + 1 ) ! ( ϕ ∧ ) n ρ 0 T 1 ] = [ ∑ n = 0 ∞ 1 n ! ( ϕ ∧ ) n ∑ n = 0 ∞ 1 ( n + 1 ) ! ( ϕ ∧ ) n ρ 0 T 1 ] \begin{aligned} \exp(\xi ^{\wedge}) & = \sum_{n=0}^{\infty}\frac{1}{n!}(\xi ^{\wedge})^{n}\\ & = I+\xi^{\wedge}+\frac{1}{2!}\xi^{\wedge}\xi^{\wedge}+\frac{1}{3!}\xi^{\wedge}\xi^{\wedge}\xi^{\wedge}+\cdots \\ & =I+\xi^{\wedge}+\frac{1}{2!}\phi^{\wedge}\xi^{\wedge}+\frac{1}{3!}(\phi^{\wedge})^{2}\xi^{\wedge}+\cdots \\ & = I+\sum_{n=0}^{\infty}\frac{1}{(n+1)!}(\phi^{\wedge})^{n}\xi^{\wedge}\\ & = \begin{bmatrix} I+\sum_{n=0}^{\infty}\frac{1}{(n+1)!}(\phi^{\wedge})^{n+1} & \sum_{n=0}^{\infty}\frac{1}{(n+1)!}(\phi^{\wedge})^{n}\rho \\ {\bf 0}^{T} & 1 \end{bmatrix} \\ & = \begin{bmatrix} \sum_{n=0}^{\infty}\frac{1}{n!}(\phi^{\wedge})^{n} & \sum_{n=0}^{\infty}\frac{1}{(n+1)!}(\phi^{\wedge})^{n}\rho \\ {\bf 0}^{T} & 1 \end{bmatrix} \end{aligned} exp ( ξ ∧ ) = n = 0 ∑ ∞ n ! 1 ( ξ ∧ ) n = I + ξ ∧ + 2 ! 1 ξ ∧ ξ ∧ + 3 ! 1 ξ ∧ ξ ∧ ξ ∧ + ⋯ = I + ξ ∧ + 2 ! 1 ϕ ∧ ξ ∧ + 3 ! 1 ( ϕ ∧ ) 2 ξ ∧ + ⋯ = I + n = 0 ∑ ∞ ( n + 1 ) ! 1 ( ϕ ∧ ) n ξ ∧ = [ I + ∑ n = 0 ∞ ( n + 1 ) ! 1 ( ϕ ∧ ) n + 1 0 T ∑ n = 0 ∞ ( n + 1 ) ! 1 ( ϕ ∧ ) n ρ 1 ] = [ ∑ n = 0 ∞ n ! 1 ( ϕ ∧ ) n 0 T ∑ n = 0 ∞ ( n + 1 ) ! 1 ( ϕ ∧ ) n ρ 1 ]
伴随 先证明∀ a ∈ R 3 , R a ∧ R T = ( R a ) ∧ \forall a \in \mathbb R^{3}, Ra^{\wedge}R^{T}=(Ra)^{\wedge} ∀ a ∈ R 3 , R a ∧ R T = ( R a ) ∧ ,高翔提供的网址的证明不严谨,即
( R a ) ∧ v = ( R a ) × v = ( R a ) × ( R R − 1 v ) = R ( a × R − 1 v ) = R a ∧ R − 1 v (Ra)^{\wedge}v=(Ra)\times v =(Ra) \times (RR^{-1}v)=R(a \times R^{-1}v)=Ra^{\wedge}R^{-1}v ( R a ) ∧ v = ( R a ) × v = ( R a ) × ( R R − 1 v ) = R ( a × R − 1 v ) = R a ∧ R − 1 v
A B = B C , 不能推导出 A ≠ B A,B,C是矩阵 AB=BC,不能推导出A \neq B \quad\text{A,B,C是矩阵} A B = B C , 不 能 推 导 出 A = B A,B,C 是矩阵
下面通过旋转矩阵正交的性质来证明该式成立。
设旋转矩阵 R = [ r 1 r 2 r 3 ] 这里的 r 1 , r 2 , r 3 既可以看作是 1 × 3 的单位向量,也可以看作是矩阵,因此下面不再进行区分 对于 R p ∧ R T = ( R p ) ∧ ⟺ p ∧ = R T ( R p ) ∧ R ,因此转为证明后式 \begin{aligned} & 设旋转矩阵R= \begin{bmatrix} {\bf r}_{1} & {\bf r}_{2} & {\bf r}_{3} \end{bmatrix} \quad \text{这里的${\bf r}_{1},{\bf r}_{2},{\bf r}_{3}$既可以看作是$1 \times 3$的单位向量,也可以看作是矩阵,因此下面不再进行区分}\\ & 对于Rp^{\wedge}R^{T} = (Rp)^{\wedge} \iff p^{\wedge}=R^{T}(Rp)^{\wedge}R,因此转为证明后式\\ \end{aligned} 设 旋 转 矩 阵 R = [ r 1 r 2 r 3 ] 这里的 r 1 , r 2 , r 3 既可以看作是 1 × 3 的单位向量,也可以看作是矩阵,因此下面不再进行区分 对 于 R p ∧ R T = ( R p ) ∧ ⟺ p ∧ = R T ( R p ) ∧ R , 因 此 转 为 证 明 后 式
在证明之前,有两个事项需要注意:
1.r i T r j = r i ⋅ r j {\bf r}_{i}^{T} {\bf r}_{j}={\bf r}_{i} \cdot {\bf r}_{j} r i T r j = r i ⋅ r j 前面可以看作矩阵,后面看作向量点乘,r {\bf r} r 是列向量
2.因为R R R 是旋转矩阵,因此行向量和列向量都是单位向量且两两正交。为了后面叉乘运算的一致性,需要将r 1 , r 2 , r 3 {\bf r}_{1},{\bf r}_{2},{\bf r}_{3} r 1 , r 2 , r 3 分别看成三维正交坐标系的x , y , z x,y,z x , y , z 轴,即:
{ r 1 × r 2 = r 1 ∧ r 2 = r 3 r 2 × r 3 = r 2 ∧ r 3 = r 1 r 3 × r 1 = r 3 ∧ r 1 = r 2 \begin{cases} {\bf r}_{1} \times {\bf r}_{2} = {\bf r}_{1}^{\wedge}{\bf r}_{2}={\bf r}_{3}\\ {\bf r}_{2} \times {\bf r}_{3} = {\bf r}_{2}^{\wedge}{\bf r}_{3}={\bf r}_{1}\\ {\bf r}_{3} \times {\bf r}_{1} = {\bf r}_{3}^{\wedge}{\bf r}_{1}={\bf r}_{2} \end{cases} ⎩ ⎪ ⎪ ⎨ ⎪ ⎪ ⎧ r 1 × r 2 = r 1 ∧ r 2 = r 3 r 2 × r 3 = r 2 ∧ r 3 = r 1 r 3 × r 1 = r 3 ∧ r 1 = r 2
p ∧ = R T ( R p ) ∧ R = [ r 1 T r 2 T r 3 T ] ( [ r 1 r 2 r 3 ] [ p 1 p 2 p 3 ] ) ∧ [ r 1 r 2 r 3 ] = [ r 1 T r 2 T r 3 T ] ( r 1 p 1 + r 2 p 2 + r 3 p 3 ) ∧ [ r 1 r 2 r 3 ] = [ r 1 T r 2 T r 3 T ] ( r 1 ∧ p 1 + r 2 ∧ p 2 + r 3 ∧ p 3 ) [ r 1 r 2 r 3 ] = p 1 [ r 1 T r 2 T r 3 T ] r 1 ∧ [ r 1 r 2 r 3 ] + p 2 [ r 1 T r 2 T r 3 T ] r 2 ∧ [ r 1 r 2 r 3 ] + p 3 [ r 1 T r 2 T r 3 T ] r 3 ∧ [ r 1 r 2 r 3 ] = p 1 [ r 1 T r 1 ∧ r 1 r 1 T r 1 ∧ r 2 r 1 T r 1 ∧ r 3 r 2 T r 1 ∧ r 1 r 2 T r 1 ∧ r 2 r 2 T r 1 ∧ r 3 r 3 T r 1 ∧ r 1 r 3 T r 1 ∧ r 2 r 3 T r 1 ∧ r 3 ] + p 2 [ r 1 T r 2 ∧ r 1 r 1 T r 2 ∧ r 2 r 1 T r 2 ∧ r 3 r 2 T r 2 ∧ r 1 r 2 T r 2 ∧ r 2 r 2 T r 2 ∧ r 3 r 3 T r 2 ∧ r 1 r 3 T r 2 ∧ r 2 r 3 T r 2 ∧ r 3 ] + p 3 [ r 1 T r 3 ∧ r 1 r 1 T r 3 ∧ r 2 r 1 T r 3 ∧ r 3 r 2 T r 3 ∧ r 1 r 2 T r 3 ∧ r 2 r 2 T r 3 ∧ r 3 r 3 T r 3 ∧ r 1 r 3 T r 3 ∧ r 2 r 3 T r 3 ∧ r 3 ] = p 1 [ 0 0 0 0 0 − 1 0 1 0 ] + p 2 [ 0 0 1 0 0 0 − 1 0 0 ] + p 3 [ 0 − 1 0 1 0 0 0 0 0 ] = [ 0 − p 3 p 2 p 3 0 − p 1 − p 2 p 1 0 ] \begin{aligned} p^{\wedge} & = R^{T}(Rp)^{\wedge}R \\ & = \begin{bmatrix} {\bf r}_{1}^{T}\\ {\bf r}_{2}^{T}\\ {\bf r}_{3}^{T} \end{bmatrix} (\begin{bmatrix} {\bf r}_{1} & {\bf r}_{2} & {\bf r}_{3} \end{bmatrix} \begin{bmatrix} p_{1}\\ p_{2}\\ p_{3} \end{bmatrix})^{\wedge} \begin{bmatrix} {\bf r}_{1} & {\bf r}_{2} & {\bf r}_{3} \end{bmatrix} \\ & = \begin{bmatrix} {\bf r}_{1}^{T}\\ {\bf r}_{2}^{T}\\ {\bf r}_{3}^{T} \end{bmatrix} ({\bf r}_{1}p_{1}+{\bf r}_{2}p_{2}+{\bf r}_{3}p_{3})^{\wedge} \begin{bmatrix} {\bf r}_{1} & {\bf r}_{2} & {\bf r}_{3} \end{bmatrix} \\ & = \begin{bmatrix} {\bf r}_{1}^{T}\\ {\bf r}_{2}^{T}\\ {\bf r}_{3}^{T} \end{bmatrix} ({\bf r}_{1}^{\wedge}p_{1}+{\bf r}_{2}^{\wedge}p_{2}+{\bf r}_{3}^{\wedge}p_{3}) \begin{bmatrix} {\bf r}_{1} & {\bf r}_{2} & {\bf r}_{3} \end{bmatrix} \\ & = p_{1} \begin{bmatrix} {\bf r}_{1}^{T}\\ {\bf r}_{2}^{T}\\ {\bf r}_{3}^{T} \end{bmatrix} {\bf r}_{1}^{\wedge} \begin{bmatrix} {\bf r}_{1} & {\bf r}_{2} & {\bf r}_{3} \end{bmatrix} + p_{2} \begin{bmatrix} {\bf r}_{1}^{T}\\ {\bf r}_{2}^{T}\\ {\bf r}_{3}^{T} \end{bmatrix} {\bf r}_{2}^{\wedge} \begin{bmatrix} {\bf r}_{1} & {\bf r}_{2} & {\bf r}_{3} \end{bmatrix} + p_{3} \begin{bmatrix} {\bf r}_{1}^{T}\\ {\bf r}_{2}^{T}\\ {\bf r}_{3}^{T} \end{bmatrix} {\bf r}_{3}^{\wedge} \begin{bmatrix} {\bf r}_{1} & {\bf r}_{2} & {\bf r}_{3} \end{bmatrix} \\ & = p_{1} \begin{bmatrix} {\bf r}_{1}^{T} {\bf r}_{1}^{\wedge} {\bf r}_{1} & {\bf r}_{1}^{T} {\bf r}_{1}^{\wedge} {\bf r}_{2} & {\bf r}_{1}^{T} {\bf r}_{1}^{\wedge} {\bf r}_{3}\\ {\bf r}_{2}^{T} {\bf r}_{1}^{\wedge} {\bf r}_{1} & {\bf r}_{2}^{T} {\bf r}_{1}^{\wedge} {\bf r}_{2} & {\bf r}_{2}^{T} {\bf r}_{1}^{\wedge} {\bf r}_{3}\\ {\bf r}_{3}^{T} {\bf r}_{1}^{\wedge} {\bf r}_{1} & {\bf r}_{3}^{T} {\bf r}_{1}^{\wedge} {\bf r}_{2} & {\bf r}_{3}^{T} {\bf r}_{1}^{\wedge} {\bf r}_{3}\\ \end{bmatrix} + p_{2} \begin{bmatrix} {\bf r}_{1}^{T} {\bf r}_{2}^{\wedge} {\bf r}_{1} & {\bf r}_{1}^{T} {\bf r}_{2}^{\wedge} {\bf r}_{2} & {\bf r}_{1}^{T} {\bf r}_{2}^{\wedge} {\bf r}_{3}\\ {\bf r}_{2}^{T} {\bf r}_{2}^{\wedge} {\bf r}_{1} & {\bf r}_{2}^{T} {\bf r}_{2}^{\wedge} {\bf r}_{2} & {\bf r}_{2}^{T} {\bf r}_{2}^{\wedge} {\bf r}_{3}\\ {\bf r}_{3}^{T} {\bf r}_{2}^{\wedge} {\bf r}_{1} & {\bf r}_{3}^{T} {\bf r}_{2}^{\wedge} {\bf r}_{2} & {\bf r}_{3}^{T} {\bf r}_{2}^{\wedge} {\bf r}_{3}\\ \end{bmatrix} + p_{3} \begin{bmatrix} {\bf r}_{1}^{T} {\bf r}_{3}^{\wedge} {\bf r}_{1} & {\bf r}_{1}^{T} {\bf r}_{3}^{\wedge} {\bf r}_{2} & {\bf r}_{1}^{T} {\bf r}_{3}^{\wedge} {\bf r}_{3}\\ {\bf r}_{2}^{T} {\bf r}_{3}^{\wedge} {\bf r}_{1} & {\bf r}_{2}^{T} {\bf r}_{3}^{\wedge} {\bf r}_{2} & {\bf r}_{2}^{T} {\bf r}_{3}^{\wedge} {\bf r}_{3}\\ {\bf r}_{3}^{T} {\bf r}_{3}^{\wedge} {\bf r}_{1} & {\bf r}_{3}^{T} {\bf r}_{3}^{\wedge} {\bf r}_{2} & {\bf r}_{3}^{T} {\bf r}_{3}^{\wedge} {\bf r}_{3}\\ \end{bmatrix} \\ & = p_{1} \begin{bmatrix} 0 & 0 & 0\\ 0 & 0 & -1\\ 0 & 1 & 0 \end{bmatrix} + p_{2} \begin{bmatrix} 0 & 0 & 1\\ 0 & 0 & 0\\ -1 & 0 & 0 \end{bmatrix} + p_{3} \begin{bmatrix} 0 & -1 & 0\\ 1 & 0 & 0\\ 0 & 0 & 0 \end{bmatrix} \\ & = \begin{bmatrix} 0 & -p_{3} & p_{2}\\ p_{3} & 0 & -p_{1}\\ -p_{2} & p_{1} & 0 \end{bmatrix} \end{aligned} p ∧ = R T ( R p ) ∧ R = ⎣ ⎢ ⎡ r 1 T r 2 T r 3 T ⎦ ⎥ ⎤ ( [ r 1 r 2 r 3 ] ⎣ ⎢ ⎡ p 1 p 2 p 3 ⎦ ⎥ ⎤ ) ∧ [ r 1 r 2 r 3 ] = ⎣ ⎢ ⎡ r 1 T r 2 T r 3 T ⎦ ⎥ ⎤ ( r 1 p 1 + r 2 p 2 + r 3 p 3 ) ∧ [ r 1 r 2 r 3 ] = ⎣ ⎢ ⎡ r 1 T r 2 T r 3 T ⎦ ⎥ ⎤ ( r 1 ∧ p 1 + r 2 ∧ p 2 + r 3 ∧ p 3 ) [ r 1 r 2 r 3 ] = p 1 ⎣ ⎢ ⎡ r 1 T r 2 T r 3 T ⎦ ⎥ ⎤ r 1 ∧ [ r 1 r 2 r 3 ] + p 2 ⎣ ⎢ ⎡ r 1 T r 2 T r 3 T ⎦ ⎥ ⎤ r 2 ∧ [ r 1 r 2 r 3 ] + p 3 ⎣ ⎢ ⎡ r 1 T r 2 T r 3 T ⎦ ⎥ ⎤ r 3 ∧ [ r 1 r 2 r 3 ] = p 1 ⎣ ⎢ ⎡ r 1 T r 1 ∧ r 1 r 2 T r 1 ∧ r 1 r 3 T r 1 ∧ r 1 r 1 T r 1 ∧ r 2 r 2 T r 1 ∧ r 2 r 3 T r 1 ∧ r 2 r 1 T r 1 ∧ r 3 r 2 T r 1 ∧ r 3 r 3 T r 1 ∧ r 3 ⎦ ⎥ ⎤ + p 2 ⎣ ⎢ ⎡ r 1 T r 2 ∧ r 1 r 2 T r 2 ∧ r 1 r 3 T r 2 ∧ r 1 r 1 T r 2 ∧ r 2 r 2 T r 2 ∧ r 2 r 3 T r 2 ∧ r 2 r 1 T r 2 ∧ r 3 r 2 T r 2 ∧ r 3 r 3 T r 2 ∧ r 3 ⎦ ⎥ ⎤ + p 3 ⎣ ⎢ ⎡ r 1 T r 3 ∧ r 1 r 2 T r 3 ∧ r 1 r 3 T r 3 ∧ r 1 r 1 T r 3 ∧ r 2 r 2 T r 3 ∧ r 2 r 3 T r 3 ∧ r 2 r 1 T r 3 ∧ r 3 r 2 T r 3 ∧ r 3 r 3 T r 3 ∧ r 3 ⎦ ⎥ ⎤ = p 1 ⎣ ⎢ ⎡ 0 0 0 0 0 1 0 − 1 0 ⎦ ⎥ ⎤ + p 2 ⎣ ⎢ ⎡ 0 0 − 1 0 0 0 1 0 0 ⎦ ⎥ ⎤ + p 3 ⎣ ⎢ ⎡ 0 1 0 − 1 0 0 0 0 0 ⎦ ⎥ ⎤ = ⎣ ⎢ ⎡ 0 p 3 − p 2 − p 3 0 p 1 p 2 − p 1 0 ⎦ ⎥ ⎤
对于S O ( 3 ) SO(3) S O ( 3 ) 上的伴随的证明只需进行泰勒展开即可,与上面的证明相同。
exp ( ( A d ( R ) P ) ∧ ) = exp ( ( R p ) ∧ ) = exp ( R p ∧ R T ) = exp ( R θ a ∧ R T ) = ∑ n = 0 ∞ 1 n ! ( R θ a ∧ R T ) n 令 p = θ a , a 是单位向量, θ 为模长 R a ∧ R T R a ∧ R T = R a ∧ a ∧ R T = R ( a a T − I ) R T = R a a T R T − I R a ∧ R T R a ∧ R T R a ∧ R T = R a ∧ a ∧ a ∧ R T = − R a ∧ R T \begin{aligned} & \exp ((Ad(R)P)^{\wedge}) = \exp ((Rp)^{\wedge})=\exp (Rp^{\wedge}R^{T})=\exp (R\theta a^{\wedge}R^{T})=\sum _{n=0}^{\infty}\frac{1}{n!}(R\theta a^{\wedge}R^{T})^{n} \\ & 令p=\theta a,a是单位向量,\theta为模长\\ & Ra^{\wedge}R^{T} Ra^{\wedge}R^{T} =Ra^{\wedge}a^{\wedge}R^{T}=R(aa^{T}-I)R^{T}=Raa^{T}R^{T}-I\\ & Ra^{\wedge}R^{T} Ra^{\wedge}R^{T} Ra^{\wedge}R^{T} =Ra^{\wedge}a^{\wedge}a^{\wedge}R^{T}=-Ra^{\wedge}R^{T} \end{aligned} exp ( ( A d ( R ) P ) ∧ ) = exp ( ( R p ) ∧ ) = exp ( R p ∧ R T ) = exp ( R θ a ∧ R T ) = n = 0 ∑ ∞ n ! 1 ( R θ a ∧ R T ) n 令 p = θ a , a 是 单 位 向 量 , θ 为 模 长 R a ∧ R T R a ∧ R T = R a ∧ a ∧ R T = R ( a a T − I ) R T = R a a T R T − I R a ∧ R T R a ∧ R T R a ∧ R T = R a ∧ a ∧ a ∧ R T = − R a ∧ R T
泰勒展开后的式子利用正余弦函数表示,结果为:
exp ( R p ∧ R T ) = ∑ n = 0 ∞ 1 n ! ( θ R a ∧ R T ) n = ( 1 − cos θ ) R a a T R T + cos θ I + sin θ R a ∧ R T = R ( ( 1 − cos θ ) a a T + cos θ I + sin θ a ∧ ) R T = R exp ( p ∧ ) R T \begin{aligned} \exp(Rp^{\wedge}R^{T}) & = \sum _{n=0}^{\infty}\frac{1}{n!}(\theta R a^{\wedge}R^{T})^{n}\\ & = (1-\cos \theta)Raa^{T}R^{T}+\cos \theta I+\sin \theta Ra^{\wedge}R^{T}\\ & =R((1-\cos \theta)aa^{T}+\cos \theta I+\sin \theta a^{\wedge})R^{T}\\ & =R \exp(p^{\wedge})R^{T} \end{aligned} exp ( R p ∧ R T ) = n = 0 ∑ ∞ n ! 1 ( θ R a ∧ R T ) n = ( 1 − cos θ ) R a a T R T + cos θ I + sin θ R a ∧ R T = R ( ( 1 − cos θ ) a a T + cos θ I + sin θ a ∧ ) R T = R exp ( p ∧ ) R T
对于S E ( 3 ) SE(3) S E ( 3 ) 的伴随A d ( T ) Ad(T) A d ( T ) 有:
T exp ( ξ ∧ ) T − 1 = exp ( ( A d ( T ) ξ ) ∧ ) A d ( T ) = [ R t ∧ R 0 R ] \begin{aligned} & T\exp (\xi ^{\wedge})T^{-1} = \exp((Ad(T)\xi )^{\wedge})\\ & Ad(T)= \begin{bmatrix} R & t^{\wedge}R\\ {\bf 0} & R \end{bmatrix} \end{aligned} T exp ( ξ ∧ ) T − 1 = exp ( ( A d ( T ) ξ ) ∧ ) A d ( T ) = [ R 0 t ∧ R R ]
S O ( 3 ) SO(3) S O ( 3 ) 和S E ( 3 ) SE(3) S E ( 3 ) 的伴随将在后面的位姿图优化中用到。
轨迹的描绘 1.T W C T_{WC} T W C 是相机坐标系到世界坐标系的变换矩阵,其平移部分就是相机的移动距离,我们在解算位姿的时候是计算两帧之间的位姿,因此平移部分连起来就是相机的轨迹,即机器人的轨迹。
实际上,T W C T_{WC} T W C 和T C W T_{CW} T C W 之间只差了一个逆而已,都可以用来表示相机的位姿,但是实践当中使用T C W T_{CW} T C W 更为常见,不过T W C T_{WC} T W C 更为直观,因为p W = T W C p C = R p C + t W C p_{W} =T_{WC}p_{C}=Rp_{C}+t_{WC} p W = T W C p C = R p C + t W C 对于相机原点来说,p W p_{W} p W 就是在其对应于世界坐标系的点,而且正是T W C T_{WC} T W C 的平移部分,那么连起来就可以看到相机的平移轨迹。
2.仿照ORB-SLAM2里的CMakeLists.txt
写的CMakeLists.txt
cmake_minimum_required(VERSION 2.8) project(trajectorydrawing) set(CMAKE_BUILD_TYPE "Release") # check C++11 or C++0x support include(CheckCCompilerFlag) include(CheckCXXCompilerFlag) CHECK_CXX_COMPILER_FLAG("-std=c++11" COMPILER_SUPPORTS_CXX11) CHECK_CXX_COMPILER_FLAG("-std=c++0x" COMPILER_SUPPORTS_CXX0X) if(COMPILER_SUPPORTS_CXX11) set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11") add_definitions(-DCOMPILEDWITHC11) message(STATUS "Using flag -std=c++11.") elseif(COMPILER_SUPPORTS_CXX0X) set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++0x") add_definitions(-DCOMPILEDWITHC0X) message(STATUS "Using flag -std=c++0x.") else() message(FATAL_ERROR "The compiler ${CMAKE_CXX_COMPILER} has no C++11 support. Please use a different C++ compiler.") endif() find_package(Eigen3 REQUIRED) find_package(Pangolin REQUIRED) find_package(Sophus REQUIRED) include_directories( ${EIGEN3_SOURCE_DIR} ${Pangolin_INCLUDE_DIR} ${Sophus_INCLUDE_DIR} ) add_executable(trajectorydrawing draw_trajectory.cpp) target_link_libraries(trajectorydrawing ${EIGEN3_LIBRARIES} ${Pangolin_LIBRARIES} ${Sophus_LIBRARIES})
读取数据的代码如下:
// 第一种方法,用fstream的getline分行读取 ifstream fin(trajectory_file); //从文件中读取数据 if(!fin.is_open()){ cout<<"No "<<trajectory_file<<endl; return 0; } double t,tx,ty,tz,qx,qy,qz,qw; string line; while(getline(fin,line)) { istringstream record(line); //从string读取数据 record>>t>>tx>>ty>>tz>>qx>>qy>>qz>>qw; Eigen::Vector3d p(tx,ty,tz); Eigen::Quaterniond q = Eigen::Quaterniond(qw,qx,qy,qz).normalized(); Sophus::SE3 SE3_qp(q,p); poses.push_back(SE3_qp); } //第二种方法 // ifstream in(trajectory_file);//创建输入流 // if(!in){ // cout<<"open posefile failture!!!"<<endl; // return 0; // } // for(int i=0; i<620; i++){ // double data[8]={0}; // for(auto& d:data) in>>d;//按行依次去除数组中的值 // Eigen::Quaterniond q(data[7], data[8], data[5], data[6]); // Eigen::Vector3d t(data[1], data[2], data[3]); // Sophus::SE3 SE3(q,t); // poses.push_back(SE3); // } // end your code here
生成的轨迹图如下:
轨迹的误差 CMakeLists.txt文件内容如下:
cmake_minimum_required(VERSION 2.8) project(trajectory_error) set(CMAKE_BUILD_TYPE "Release") # check C++11 or C++0x support include(CheckCCompilerFlag) include(CheckCXXCompilerFlag) CHECK_CXX_COMPILER_FLAG("-std=c++11" COMPILER_SUPPORTS_CXX11) CHECK_CXX_COMPILER_FLAG("-std=c++0x" COMPILER_SUPPORTS_CXX0X) if(COMPILER_SUPPORTS_CXX11) set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11") add_definitions(-DCOMPILEDWITHC11) message(STATUS "Using flag -std=c++11.") elseif(COMPILER_SUPPORTS_CXX0X) set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++0x") add_definitions(-DCOMPILEDWITHC0X) message(STATUS "Using flag -std=c++0x.") else() message(FATAL_ERROR "The compiler ${CMAKE_CXX_COMPILER} has no C++11 support. Please use a different C++ compiler.") endif() find_package(Eigen3 REQUIRED) find_package(Pangolin REQUIRED) find_package(Sophus REQUIRED) include_directories( ${EIGEN3_SOURCE_DIR} ${Pangolin_INCLUDE_DIR} ${Sophus_INCLUDE_DIR} ) add_executable(trajectory_error trajectory_error.cpp) target_link_libraries(trajectory_error ${EIGEN3_LIBRARIES} ${Pangolin_LIBRARIES} ${Sophus_LIBRARIES})
trajectory_error.cpp文件内容如下:
#include <sophus/se3.h> #include <string> #include <iostream> #include <fstream> #include <cmath> #include <pangolin/pangolin.h> #include <Eigen/Core> #include <Eigen/Geometry> using namespace std; using namespace Eigen; void ReadData(string FileName ,vector<Sophus::SE3, Eigen::aligned_allocator<Sophus::SE3>> &poses); double ErrorTrajectory(vector<Sophus::SE3, Eigen::aligned_allocator<Sophus::SE3>> poses_g, vector<Sophus::SE3, Eigen::aligned_allocator<Sophus::SE3>> poses_e); void DrawTrajectory(vector<Sophus::SE3, Eigen::aligned_allocator<Sophus::SE3>> poses_g, vector<Sophus::SE3, Eigen::aligned_allocator<Sophus::SE3>> poses_e); int main(int argc, char **argv) { string GroundFile = "./groundtruth.txt"; string ErrorFile = "./estimated.txt"; double trajectory_error_RMSE = 0; vector<Sophus::SE3, Eigen::aligned_allocator<Sophus::SE3>> poses_g; vector<Sophus::SE3, Eigen::aligned_allocator<Sophus::SE3>> poses_e; ReadData(GroundFile,poses_g); ReadData(ErrorFile,poses_e); trajectory_error_RMSE = ErrorTrajectory(poses_g, poses_e); cout<<"trajectory_error_RMSE = "<< trajectory_error_RMSE<<endl; DrawTrajectory(poses_g,poses_e); } /***************************读取文件的数据,并存储到vector类型的pose中**************************************/ void ReadData(string FileName ,vector<Sophus::SE3, Eigen::aligned_allocator<Sophus::SE3>> &poses) { ifstream fin(FileName); //从文件中读取数据 //这句话一定要加上,保证能够正确读取文件。如果没有正确读取,结果显示-nan if(!fin.is_open()){ cout<<"No "<<FileName<<endl; return; } double t,tx,ty,tz,qx,qy,qz,qw; string line; while(getline(fin,line)) { istringstream record(line); //从string读取数据 record >> t >> tx >> ty >> tz >> qx >> qy >> qz >> qw; Eigen::Vector3d p(tx, ty, tz); Eigen::Quaterniond q = Eigen::Quaterniond(qw, qx, qy, qz).normalized(); //四元数的顺序要注意 Sophus::SE3 SE3_qp(q, p); poses.push_back(SE3_qp); } } /*******************************计算轨迹误差*********************************************/ double ErrorTrajectory(vector<Sophus::SE3, Eigen::aligned_allocator<Sophus::SE3>> poses_g, vector<Sophus::SE3, Eigen::aligned_allocator<Sophus::SE3>> poses_e ) { double RMSE = 0; Matrix<double ,6,1> se3; vector<double> error; for(int i=0;i<poses_g.size();i++){ se3=(poses_g[i].inverse()*poses_e[i]).log(); //这里的se3为向量形式,求log之后是向量形式 //cout<<se3.transpose()<<endl; error.push_back( se3.squaredNorm() ); //二范数 // cout<<error[i]<<endl; } for(int i=0; i<poses_g.size();i++){ RMSE += error[i]; } RMSE /= double(error.size()); RMSE = sqrt(RMSE); return RMSE; } /*****************************绘制轨迹*******************************************/ void DrawTrajectory(vector<Sophus::SE3, Eigen::aligned_allocator<Sophus::SE3>> poses_g, vector<Sophus::SE3, Eigen::aligned_allocator<Sophus::SE3>> poses_e) { if (poses_g.empty() || poses_e.empty()) { cerr << "Trajectory is empty!" << endl; return; } // create pangolin window and plot the trajectory pangolin::CreateWindowAndBind("Trajectory Viewer", 1024, 768); //创建一个窗口 glEnable(GL_DEPTH_TEST); //启动深度测试 glEnable(GL_BLEND); //启动混合 glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);//混合函数glBlendFunc( GLenum sfactor , GLenum dfactor );sfactor 源混合因子dfactor 目标混合因子 pangolin::OpenGlRenderState s_cam( pangolin::ProjectionMatrix(1024, 768, 500, 500, 512, 389, 0.1, 1000), pangolin::ModelViewLookAt(0, -0.1, -1.8, 0, 0, 0, 0.0, -1.0, 0.0) //对应的是gluLookAt,摄像机位置,参考点位置,up vector(上向量) ); pangolin::View &d_cam = pangolin::CreateDisplay() .SetBounds(0.0, 1.0, pangolin::Attach::Pix(175), 1.0, -1024.0f / 768.0f) .SetHandler(new pangolin::Handler3D(s_cam)); while (pangolin::ShouldQuit() == false) { glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); d_cam.Activate(s_cam); glClearColor(1.0f, 1.0f, 1.0f, 1.0f); glLineWidth(2); for (size_t i = 0; i < poses_g.size() - 1; i++) { glColor3f(1 - (float) i / poses_g.size(), 0.0f, (float) i / poses_g.size()); glBegin(GL_LINES); auto p1 = poses_g[i], p2 = poses_g[i + 1]; glVertex3d(p1.translation()[0], p1.translation()[1], p1.translation()[2]); glVertex3d(p2.translation()[0], p2.translation()[1], p2.translation()[2]); glEnd(); } for (size_t j = 0; j < poses_e.size() - 1; j++) { //glColor3f(1 - (float) j / poses_e.size(), 0.0f, (float) j / poses_e.size()); glColor3f(1.0f, 1.0f, 0.f);//为了区分第二条轨迹,用不同的颜色代替,黄色 glBegin(GL_LINES); auto p1 = poses_e[j], p2 = poses_e[j + 1]; glVertex3d(p1.translation()[0], p1.translation()[1], p1.translation()[2]); glVertex3d(p2.translation()[0], p2.translation()[1], p2.translation()[2]); glEnd(); } pangolin::FinishFrame(); usleep(5000); // sleep 5 ms } }