如何从opencv cv :: Mat或行主要数组初始化一个特征矩阵?

min*_*ing 6 c++ eigen

我发现Eigen的Matrix是默认的列主要,就像MATLAB,但是如何从cv :: Mat初始化Eigen :: MatrixXd?以下代码是我的测试.但是没有一个能够成功编译.请问有人给我一些建议吗?或其他一些链接?谢谢.

    cv::Mat A_M=cv::Mat(rows, cols, CV_64FC1);
    double *A=(double *)A_M.data();
    typedef Map<MatrixXd> MapMat;
    MapMat A_eigen(A,m,n);

    Eigen::Matrix<double,Eigen::Dynamic,Eigen::Dynamic,Eigen::RowMajor> A_eigen;
    Eigen::Map<Matrix<double,Eigen::Dynamic,Eigen::Dynamic,Eigen::RowMajor> >(A,m,n) = A_eigen;
Run Code Online (Sandbox Code Playgroud)

更新:

    double *A=(double *)A_M.data();//m*n
    double *B=(double *)B_M.data();//n*p
    double *C=(double *)C_M.data();//m*p
    //regular Eigen Matrix
    Eigen::MatrixXd A_eigenMat;
    Eigen::MatrixXd B_eigenMat;
    Eigen::MatrixXd C_eigenMat;
    Eigen::Map<Eigen::Matrix<double, Eigen::Dynamic, Eigen::Dynamic, Eigen::RowMajor> > A_mappedMat (A, m, n);
    Eigen::Map<Eigen::Matrix<double, Eigen::Dynamic, Eigen::Dynamic, Eigen::RowMajor> > B_mappedMat (B, n, p);
    Eigen::Map<Eigen::Matrix<double, Eigen::Dynamic, Eigen::Dynamic, Eigen::RowMajor> > C_mappedMat (C, m, p);
    // Eigen handles the conversion from row major to column major
    A_eigenMat = A_mappedMat;
    B_eigenMat = B_mappedMat;
    C_eigenMat = C_mappedMat;

    // multiplication
    C_eigenMat=A_eigenMat*B_eigenMat;
Run Code Online (Sandbox Code Playgroud)

然后,当我输出M_C时,其结果是错误的.似乎C_eigenMat没有将数据复制到M_C.data中.

Mik*_*Del 5

来自OpenCV和Eigen之间转换的样本:

cv::Mat_<float> a = Mat_<float>::ones(2,2);
Eigen::Matrix<float,Dynamic,Dynamic> b;
cv2eigen(a,b);
Run Code Online (Sandbox Code Playgroud)

它已在SO上回答:

//allocate memory for a 4x4 float matrix
cv::Mat cvT(4,4,CV_32FC1); 

//directly use the buffer allocated by OpenCV
Eigen::Map<Matrix4f> eigenT( cvT.data() ); 
Run Code Online (Sandbox Code Playgroud)

还有一篇SO帖子


use*_*906 5

MikroDel的答案使用了OpenCV的功能,但是cv2eigen包含了数据的副本,如果您只想映射数据指针,那并不是最佳选择。使用Eigen::Map<>通常是更好的选择。我修改了您的代码,此示例有效:

int main(int argc, char *argv[]) {
  int rows = 4, cols = 3;
  cv::Mat A_M=cv::Mat::eye(rows, cols, CV_64FC1);
  A_M.at<double>(0,2) = 10;
  double *A=(double *)A_M.data;
  //regular Eigen Matrix
  Eigen::MatrixXd eigenMat;

  Eigen::Map<Eigen::Matrix<double,Eigen::Dynamic,Eigen::Dynamic,Eigen::RowMajor> > mappedMat (A,rows, cols);
  // Eigen handles the conversion from row major to column major
  eigenMat = mappedMat;   

  std::cout << A_M << std::endl;
  std::cout << eigenMat << std::endl;
  return 0;
}
Run Code Online (Sandbox Code Playgroud)