web-dev-qa-db-ja.com

Eigen:Matrix3d回転をQuaternionに変換

Matrix3dローテーションをQuaternion<double>に変換しようとしていますが、今のところ奇妙なコンパイラエラーしかありません。私が使用しているコードは:

Quaternion<double> getQuaternionFromRotationMatrix(const Matrix3d& mat)
{
    AngleAxisd aa; 
    aa = mat;
    Quaternion<double> q = aa;// conversion error

    return q;
}

そしてコンパイラエラー:

path/src/Utils.cpp: In function ‘Eigen::Quaternion<double> Utils::getQuaternionFromRotationMatrix(const Matrix3d&)’:
path/src/Utils.cpp:55:26: error: conversion from ‘Eigen::AngleAxisd {aka Eigen::AngleAxis<double>}’ to non-scalar type ‘Eigen::Quaternion<double>’ requested
In file included from /usr/local/include/eigen3/Eigen/Core:283:0,
                 from /usr/local/include/eigen3/Eigen/Dense:1,
                 from path/include/Utils.h:4,
                 from path/src/Utils.cpp:1:
/usr/local/include/eigen3/Eigen/src/Core/Assign.h: In member function ‘Derived& Eigen::DenseBase<Derived>::lazyAssign(const Eigen::DenseBase<OtherDerived>&) [with OtherDerived = Eigen::Matrix<double, 3, 1>, Derived = Eigen::Block<Eigen::Matrix<double, 4, 4>, 4, -0x00000000000000001, true, true>]’:
/usr/local/include/eigen3/Eigen/src/Core/Assign.h:534:123:   instantiated from ‘static Derived& Eigen::internal::assign_selector<Derived, OtherDerived, false, false>::run(Derived&, const OtherDerived&) [with Derived = Eigen::Block<Eigen::Matrix<double, 4, 4>, 4, -0x00000000000000001, true, true>, OtherDerived = Eigen::Matrix<double, 3, 1>]’
/usr/local/include/eigen3/Eigen/src/Core/Assign.h:574:89:   instantiated from ‘Derived& Eigen::MatrixBase<Derived>::operator=(const Eigen::DenseBase<OtherDerived>&) [with OtherDerived = Eigen::Matrix<double, 3, 1>, Derived = Eigen::Block<Eigen::Matrix<double, 4, 4>, 4, -0x00000000000000001, true, true>]’
path/src/Utils.cpp:34:20:   instantiated from here
/usr/local/include/eigen3/Eigen/src/Core/Assign.h:504:3: error: static assertion failed: "YOU_MIXED_MATRICES_OF_DIFFERENT_SIZES"

誰かが両方の表現の間で変換する方法を知っていますか?

14
Esparver

AngleAxisまたはMatrixからのコンストラクターはexplicitであり、変換を次のように記述する必要があります。

Matrix3f mat;
Quaternionf q(mat);

または

Quaternionf q;
q = mat;

AngleAxisについても同様です。

25
ggael