对线性代数库Eigen3中eulerAngles函数的理解

编写程序时有时会遇到在四元数、旋转矩阵、欧拉角之间进行转换的操作,使用eulerAngles函数从旋转矩阵中获得欧拉角,了解其使用方法才能保证转换时不出错。

头文件<Eigen/Geometry>

使用这个函数只需#include<Eigen/Geometry>即可,源代码位置为/usr/include/eigen3/Eigen/src/Geometry/EulerAngles.h,源代码已上传,地址为https://download.csdn.net/download/qingtian11112/12292259,方便查看。

CMakeLists.txt
find_package(Eigen3 REQUIRED)
include_directories(${EIGEN3_INCLUDE_DIRS})
函数原型
template<typename Derived>
inline Matrix<typename MatrixBase<Derived>::Scalar,3,1>
MatrixBase<Derived>::eulerAngles(Index a0, Index a1, Index a2) const
使用方法

从函数原型上,可以看出其有三个参数,a0、a1、a2的取值为{0,1,2},分别表示X轴,Y轴和Z轴。
例如

Vector3f ea = mat.eulerAngles(2, 0, 2);

等价于

mat == AngleAxisf(ea[0], Vector3f::UnitZ())
     * AngleAxisf(ea[1], Vector3f::UnitX())
     * AngleAxisf(ea[2], Vector3f::UnitZ());

mat为按照参数中相应的顺序右乘得到。
如果已知
A = R x [ ϕ ] R y [ θ ] R z [ ψ ] A=R_x[\phi]R_y[\theta]R_z[\psi] A=Rx[ϕ]Ry[θ]Rz[ψ]
可以使用

Vector3f ea = R.eulerAngles(0, 1, 2);


{ e a [ 0 ] = ϕ e a [ 1 ] = θ e a [ 2 ] = ψ \begin{cases} ea[0]=\phi \\ ea[1]=\theta \\ ea[2]=\psi \end{cases} ea[0]=ϕea[1]=θea[2]=ψ

存在的问题

这个函数转换出来的欧拉角可能不稳定,如下图所示:
欧拉角数值不稳定
形成这个现象的原因在四元数和欧拉角互相转换这篇知乎回答中有解释,其中也给出了解决办法,但要注意这个解法是针对左手旋转的,要使用的话需要根据情况进行修改。也可参考这篇英文维基Conversion between quaternions and Euler angles

  • 8
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值