我发现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;
更新:
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;
然后,当我输出M_C时,其结果是错误的。似乎C_eigenMat没有将数据复制到M_C.data。
答案 0 :(得分:5)
来自Conversion between OpenCV and Eigen的示例:
cv::Mat_<float> a = Mat_<float>::ones(2,2);
Eigen::Matrix<float,Dynamic,Dynamic> b;
cv2eigen(a,b);
已经回答on 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() );
再加上SO post
答案 1 :(得分:4)
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;
}