eigen 中四元数、欧拉角、旋转矩阵、旋转向量

一、旋转向量

1.0 初始化旋转向量:旋转角为alpha,旋转轴为(x,y,z)

Eigen::AngleAxisd rotation_vector(alpha,Vector3d(x,y,z))

1.1 旋转向量转旋转矩阵

Eigen::Matrix3d rotation_matrix;
rotation_matrix
=rotation_vector.matrix(); Eigen::Matrix3d rotation_matrix;
rotation_matrix
=rotation_vector.toRotationMatrix(); 1.2 旋转向量转欧拉角(Z-Y-X,即RPY) Eigen::Vector3d eulerAngle=rotation_vector.matrix().eulerAngles(2,1,0); 1.3 旋转向量转四元数 Eigen::Quaterniond quaternion(rotation_vector); Eigen::Quaterniond quaternion;Quaterniond quaternion; Eigen::Quaterniond quaternion;quaternion=rotation_vector; 二、旋转矩阵 2.0 初始化旋转矩阵 Eigen::Matrix3d rotation_matrix;
rotation_matrix
<<x_00,x_01,x_02,x_10,x_11,x_12,x_20,x_21,x_22; 2.1 旋转矩阵转旋转向量 Eigen::AngleAxisd rotation_vector(rotation_matrix); Eigen::AngleAxisd rotation_vector;
rotation_vector
=rotation_matrix; Eigen::AngleAxisd rotation_vector;
rotation_vector.fromRotationMatrix(rotation_matrix);
2.2 旋转矩阵转欧拉角(Z-Y-X,即RPY) Eigen::Vector3d eulerAngle=rotation_matrix.eulerAngles(2,1,0); 2.3 旋转矩阵转四元数 Eigen::Quaterniond quaternion(rotation_matrix); Eigen::Quaterniond quaternion;quaternion=rotation_matrix; 三、欧拉角 3.0 初始化欧拉角(Z-Y-X,即RPY) Eigen::Vector3d eulerAngle(yaw,pitch,roll); 3.1 欧拉角转旋转向量 Eigen::AngleAxisd rollAngle(AngleAxisd(eulerAngle(2),Vector3d::UnitX()));
Eigen::AngleAxisd pitchAngle(AngleAxisd(eulerAngle(1),Vector3d::UnitY()));
Eigen::AngleAxisd yawAngle(AngleAxisd(eulerAngle(0),Vector3d::UnitZ()));
Eigen::AngleAxisd rotation_vector;rotation_vector=yawAngle*pitchAngle*rollAngle; 3.2 欧拉角转旋转矩阵 Eigen::AngleAxisd rollAngle(AngleAxisd(eulerAngle(2),Vector3d::UnitX()));
Eigen::AngleAxisd pitchAngle(AngleAxisd(eulerAngle(1),Vector3d::UnitY()));
Eigen::AngleAxisd yawAngle(AngleAxisd(eulerAngle(0),Vector3d::UnitZ()));
Eigen::Matrix3d rotation_matrix;rotation_matrix=yawAngle*pitchAngle*rollAngle; 3.3 欧拉角转四元数 Eigen::AngleAxisd rollAngle(AngleAxisd(eulerAngle(2),Vector3d::UnitX()));
Eigen::AngleAxisd pitchAngle(AngleAxisd(eulerAngle(1),Vector3d::UnitY()));
Eigen::AngleAxisd yawAngle(AngleAxisd(eulerAngle(0),Vector3d::UnitZ()));
Eigen::Quaterniond quaternion;quaternion=yawAngle*pitchAngle*rollAngle; 四、四元数 4.0 初始化四元数 Eigen::Quaterniond quaternion(w,x,y,z); 4.1 四元数转旋转向量 Eigen::AngleAxisd rotation_vector(quaternion); Eigen::AngleAxisd rotation_vector;rotation_vector=quaternion; 4.2 四元数转旋转矩阵 Eigen::Matrix3d rotation_matrix;rotation_matrix=quaternion.matrix(); Eigen::Matrix3d rotation_matrix;rotation_matrix=quaternion.toRotationMatrix(); 4.4 四元数转欧拉角(Z-Y-X,即RPY) Eigen::Vector3d eulerAngle=quaternion.matrix().eulerAngles(2,1,0);

 代码示例:

#include<iostream>
#include<Eigen/Eigen>
 
using namespace std;
 
#define pi 3.14159265359
 
int main()
{
    cout << "##-------------------搞清旋转关系-------------------##" << endl;
    Eigen::Vector3d v1(1, 1, 0);//列向量(1系下)
    Eigen::AngleAxisd angle_axis1(pi / 4, Eigen::Vector3d(0, 0, 1));//1系绕z轴逆时针旋转45得到2系
    Eigen::Vector3d rotated_v1 = angle_axis1.matrix().inverse()*v1;
    cout << "绕z轴逆时针旋转45°(R12):" << endl << angle_axis1.matrix() << endl;
    cout << "(1, 1, 0)旋转后:" << endl << rotated_v1.transpose() << endl;
    cout << "------------------------------------------------------" << endl;
 
    Eigen::Vector3d v2;
    v2 << 0, 1, 1;
    Eigen::AngleAxisd angle_axis2(pi / 4, Eigen::Vector3d(1, 0, 0));//1系绕x轴逆时针旋转45得到2系
    Eigen::Vector3d rotated_v2 = angle_axis2.matrix().inverse()*v2;
    cout << "绕x轴逆时针旋转45°(R12):" << endl << angle_axis2.matrix() << endl;
    cout << "(0, 1, 1)旋转后:" << endl << rotated_v2.transpose() << endl;
    cout << "------------------------------------------------------" << endl;
 
    Eigen::Vector3d v3(0, 0, 0);
    v3.x() = 1;
    v3[2] = 1;
    Eigen::AngleAxisd angle_axis3(pi / 4, Eigen::Vector3d(0, 1, 0));//1系绕y轴逆时针旋转45得到2系
    Eigen::Vector3d rotated_v3 = angle_axis3.matrix().inverse()*v3;
    cout << "绕y轴逆时针旋转45°(R12):" << endl << angle_axis3.matrix() << endl;//注意和绕x轴z轴不一样
    cout << "(1, 0, 1)旋转后:" << endl << rotated_v3.transpose() << endl;
    
    cout << "##-------------------常用数学运算-------------------##" << endl;
    Eigen::Vector3d v4(1, 1, 0);
    cout << "(1, 1, 0)模长:" << v4.norm() << endl;
    cout << "(1, 1, 0)单位向量:" << v4.normalized().transpose() << endl;
 
    Eigen::Vector3d v5(1, 0, 0),v6(0, 1, 0);
    cout << "(1, 0, 0)点乘(0, 1, 0):" << v5.dot(v6) << endl;
    cout << "(1, 0, 0)叉乘(0, 1, 0):" << v5.cross(v6).transpose() << endl;
    
    cout << "##----------------------使用块----------------------##" << endl;
    Eigen::Matrix<double, 4, 4> T12;
    T12.Identity();//设为单位阵
 
    Eigen::AngleAxisd angle_axis(pi / 4, Eigen::Vector3d(0, 0, 1));
    Eigen::Matrix3d R12(angle_axis);//用角轴初始化旋转矩阵
 
    Eigen::Vector3d t12;
    t12.setOnes();//各分量设为1
    //t.setZero();//各分量设为0
 
    T12.block<3, 3>(0, 0) = R12;
    T12.block<3, 1>(0, 3) = t12;
    cout << "旋转R12:" << endl << T12.topLeftCorner(3, 3) << endl;
    cout << "平移t12:" << T12.topRightCorner(3, 1).transpose() << endl;//2系原点在1系下的坐标 
    
    cout << "##---------------欧式变换矩阵(Isometry)-------------##" << endl;
    Eigen::Isometry3d T = Eigen::Isometry3d::Identity();//虽然称为3d,实质上是4x4的矩阵(旋转R+平移t)
    T.linear() = Eigen::Matrix3d::Identity();//旋转部分赋值
    //T.linear() << 1, 0, 0, 0, 1, 0, 0, 0, 1;//cv::Mat赋值
    //T.rotate(Eigen::Matrix3d::Identity());
    //T.rotate(angle_axis);
    T.translation() = Eigen::Vector3d(1, 1, 1);//平移部分赋值
    //Eigen::Isometry3d T(quaterniond);
    //T(0,3) = 1; T(1,3) = 1; T(2,3) = 1;
    cout << "R_12: " << endl << T.linear().matrix() << endl;//输出旋转部分
    cout << "t_12:" << T.translation().transpose() << endl;//输出平移部分
    cout << "T_12: " << endl << T.matrix() << endl;//输出4x4变换矩阵
    cout << "T_12*(1, 2, 3): " << endl << (T*Eigen::Vector3d(1, 2, 3)).transpose() << endl;//相当于R21*v+t21,隐含齐次坐标(1,2,3,1)
 
    //Eigen::Quaterniond q = T.rotation();
    //Eigen::Quaterniond q(T.linear());
    //cout << "q: " << q.w() << " " << q.x() << " " << q.y() << " " << q.z() << endl;
 
    cout << "##旋转向量(轴角)、旋转矩阵、欧拉角、四元素相互转换##" << endl;
    //旋转向量(轴角)
    Eigen::AngleAxisd rotation_vector(pi / 4, Eigen::Vector3d(0, 1, 0));//绕y轴逆时针旋转45度(转yaw)
    cout << "axi: " << rotation_vector.axis().transpose() << " angle: " << rotation_vector.angle() * 180 / pi << endl;
 
    //旋转向量->旋转矩阵
    Eigen::Matrix3d rotation_matrix3d = rotation_vector.matrix();
    //Eigen::Matrix3d rotation_matrix3d = rotation_vector.toRotationMatrix();
    cout << "rotation_matrix:" << endl << rotation_matrix3d << endl;
 
    //旋转矩阵->欧拉角
    Eigen::Vector3d euler_angles = rotation_matrix3d.eulerAngles(0,1,2);//(0,1,2)表示分别绕XYZ轴顺序,即pitch yaw roll顺序,逆时针为正
    cout << "pitch yaw roll = " << euler_angles.transpose() * 180 / pi << endl;
 
    //旋转向量->四元素
    Eigen::Quaterniond q = Eigen::Quaterniond(rotation_vector);//或用旋转矩阵
    cout << "q: " << q.w() << " " << q.x() << " " << q.y() << " " << q.z() << endl;
 
    //旋转矩阵->旋转向量
    Eigen::AngleAxisd rotation_vector2;
    rotation_vector2.fromRotationMatrix(rotation_matrix3d);
    cout << "axi: " << rotation_vector.axis().transpose() << " angle: " << rotation_vector.angle() * 180 / pi << endl;
 
    //四元素->旋转矩阵
    Eigen::Quaterniond q2 = Eigen::Quaterniond(1, 0, 0, 0);//(w,x,y,z)
    cout << "q2:" << endl << q2.toRotationMatrix() << endl;
    
    cout << "##------------------解线性方程------------------##" << endl;
    //AX = 0
    //(AX)`(AX)
    //X`(A`A)X
    Eigen::SelfAdjointEigenSolver<Eigen::Matrix4d> self_adjoint_solver;
    self_adjoint_solver.compute(ATA);
    cout << "eigenvalues:\n" << self_adjoint_solver.eigenvalues();
    cout << "eigenvectors:\n" << self_adjoint_solver.eigenvectors();
    Eigen::Vector4d wxyz = self_adjoint_solver.eigenvectors().col(0);
 
    Eigen::EigenSolver<Eigen::Matrix4d> general_solver;
    general_solver.compute(ATA);
    cout << "eigenvalues:\n" << general_solver.eigenvalues();
    cout << "eigenvectors:\n" << general_solver.eigenvectors();
    //wxyz = general_solver.eigenvectors().col(0);
 
    //AX=B
    Eigen::Vector3d t = A.bdcSvd(Eigen::ComputeThinU | Eigen::ComputeThinV).solve(B);
 
    getchar();
    return 0;
}

 

参考:

四元数与欧拉角(RPY角)的相互转换 - XXX已失联 - 博客园 (cnblogs.com)

Quaternions - Visualisation

posted @ 2019-07-19 18:14  玥茹苟  阅读(26801)  评论(0编辑  收藏  举报