李群是什么?
李群就是一个矩阵的集合,为何有了矩阵还要弄个矩阵集合呢?因为矩阵它只是一个数,而像实际应用中我可能需要一系列数去描述某个事件的变化。而李群就是用来描述旋转平移上的变化,物体的旋转平移是连续的所以李群它也是随时间变化连续的。某个时刻下李群它是一个矩阵,但是一段时间内它是无数个矩阵的集合。
旋转矩阵和齐次变换矩阵都是李群。旋转矩阵一般叫做特殊正交群简写为SO(3)
,Special orthogonal Group,齐次变换矩阵一般叫做特殊欧几里得群SE(3)
,Special euclidean Group。之所以字前面加个特殊是因为他们的行列式等于1,正交群是指他们是正交矩阵,欧几里得是指的是欧几里得变换这种变换是刚体变换(不会改变物体、向量的大小)。
李代数又是什么?
由于李群它是矩阵,而矩阵的元素是关于角度和时间的函数。某个时刻角度增加了一点点,并不能通过矩阵直接加减某个增量。这使得求导有困难。然后科学家就想到一个办法,那就是我对它自变量直接进行加减某个小的增量不就可以实现导数了么?李群就像一个函数,而李代数就是这个函数的自变量。只不过李群这个函数比较特殊,它是一个矩阵。李代数这个自变量也很特殊它是一个向量。
李群与李代数之间的关系?
我们在前面提到了旋转矩阵SO(3)和齐次变换矩阵SE(3)都是李群。那么他们对应的李代数是什么呢?
答:旋转矩阵SO(3)对应的李代数是旋转向量(如果不懂旋转向量和旋转矩阵可以看这篇文章),齐次变换矩阵的李代数是一个六维的向量组成这个向量的内容是平移量和旋转角度量。前面我们提到了李群就相当于一个函数,李代数就是相当于李群的自变量。那么这个自变量与函数之间的变换关系是什么呢?答:他们是指数变换关系。
数学家是怎么发现李群与李代数他们是指数关系?
我们知道旋转矩阵是李群,旋转矩阵是正交矩阵。正交矩阵意味着RRT=IRR^T=IRRT=I,由于李群是随时间变化的矩阵,所以我们把那个矩阵加个时间自变量,于是前面那个式子就变成了R(t)R(t)T=IR(t)R(t)^T=IR(t)R(t)T=I。然后我们对这个式子进行求导,自变量是t。然后上面那个式子变成了R˙(t)R(t)T+R(t)R˙(t)T=0\dot R(t)R(t)^T + R(t)\dot R(t)^T=0R˙(t)R(t)T+R(t)R˙(t)T=0。然后有R˙(t)R(t)T=−R(t)R˙(t)T=−[R˙(t)R(t)T]T\dot R(t)R(t)^T = -R(t)\dot R(t)^T = -[\dot R(t)R(t)^T]^TR˙(t)R(t)T=−R(t)R˙(t)T=−[R˙(t)R(t)T]T,把R˙(t)R(t)T\dot R(t)R(t)^TR˙(t)R(t)T看做一个整体记作H=−R˙(t)R(t)TH=-\dot R(t)R(t)^TH=−R˙(t)R(t)T。那么式子可以写作H=−HTH=-H ^ TH=−HT可以看到其实H他是反对称矩阵。我们知道反对称变换是可以产生反对称矩阵的我假设某个向量ϕ\phiϕ经过反对称变换后是HHH。用公式表示就是ϕ∧=H\phi ^\wedge = Hϕ∧=H,其中ϕ∧\phi ^ \wedgeϕ∧表示反对称变换,它可以把一个向量变成一个反对称矩阵。
回到R˙(t)R(t)T=−R(t)R˙(t)T=−[R˙(t)R(t)T]T\dot R(t)R(t)^T = -R(t)\dot R(t)^T = -[\dot R(t)R(t)^T]^TR˙(t)R(t)T=−R(t)R˙(t)T=−[R˙(t)R(t)T]T这个公式,如果我们把ϕ∧=−R˙(t)R(t)T\phi ^ \wedge=-\dot R(t)R(t)^Tϕ∧=−R˙(t)R(t)T代入进去会发现R˙(t)=ϕ∧R(t)\dot R(t) = \phi ^ \wedge R(t)R˙(t)=ϕ∧R(t)。这个李群R(t)R(t)R(t)导数很有意思,李群它的导数等于它自身然后乘上某个数,这个不就和eate^{at}eat很像吗?所以得到李群和李代数之间的变换关系为:R(t)=eϕ∧tR(t)=e^{ \phi ^ \wedge t}R(t)=eϕ∧t。
但是有个问题,R(t)=eϕ∧tR(t)=e^{ \phi ^ \wedge t}R(t)=eϕ∧t这个式子是进行矩阵的指数运算,矩阵的指数运算并不是直接把各个元素直接进行指数运算就行。一般是先把指数运算用泰勒展开,然后再进行计算。为什么用泰勒展开就好算了呢?答:如果我们假设ϕ=θa\phi=\theta aϕ=θa其中θ\thetaθ是ϕ\phiϕ的模,aaa是单位向量那么有。有a∧a∧=aaT−Ia^\wedge a^\wedge=aa^T-Ia∧a∧=aaT−I,a∧a∧a∧=−a∧a^\wedge a^\wedge a^\wedge=-a^\wedgea∧a∧a∧=−a∧。所以ϕ∧\phi^\wedgeϕ∧它的幂运算很方便。
R(t)=eϕ∧tR(t)=e^{ \phi ^ \wedge t}R(t)=eϕ∧t的泰勒展开为:
然后得到结果(其实这个结果就是罗德里格斯公式,ϕ=θa\phi=\theta aϕ=θa就是旋转向量):
然后对上面这个公式求迹运算(对角线元素之和)可以找到根据旋转矩阵反推李代数(旋转向量)的方法。
旋转矩阵的李代数ϕ\phiϕ为:
齐次变换矩阵的李代数为ξ=[ρ,ϕ]\xi=[\rho,\phi]ξ=[ρ,ϕ],这个ϕ\phiϕ就是上面那个旋转矩阵的李代数ϕ\phiϕ:
其中J是雅克比矩阵
总结
参考文献:
[1] https://www.bilibili.com/video/av38496245/?p=2