Eigen::Vector3d ea0(Eular[1] * M_PI / 180.0, Eular[0] * M_PI / 180.0, Eular[2] * M_PI / 180.0); Eigen::Matrix3d R; R = Eigen::AngleAxisd(ea0[0], ::Eigen::Vector3d::UnitX()) * Eigen::AngleAxisd(ea0[1], ::Eigen::Vector3d::UnitY()) * Eigen::AngleAxisd(ea0[2], ::Eigen::Vector3d::UnitZ()); Eigen::Quaterniond q; q = R;
时间: 2024-02-29 10:57:04 浏览: 272
eigen-eigen-07105f7124f9.rar_eigen 库_eigen库
这段代码是通过欧拉角计算得到旋转矩阵,然后将旋转矩阵转换为四元数。首先,通过Eular数组表示欧拉角,将角度值转换成弧度值并用Eigen::Vector3d类型的变量ea0存储。接着,通过Eigen::AngleAxisd()函数将欧拉角转换成旋转矩阵R。最后,通过Eigen::Quaterniond()函数将旋转矩阵R转换成四元数q。
阅读全文