我正在测试Eigen< - > OpenCV使用opencv2/core/eigen.hpp
。文档似乎缺乏。
我可以将cv :: Mat转换为Matrix。
Matrix<float,Dynamic, Dynamic> im;
cv::cv2eigen(cv::imread("lena.jpg", cv::IMREAD_GRAYSCALE), im );
完成此步骤后,我会在浮点数中进行一些处理。当我将im
转换回cv::Mat
并显示图片时,我会看到一张白色图片。
cv::Mat dst;
cv::eigen2cv(im,dst);
cv::imshow( "win", dst );
cv::waitKey(0);
我认为问题在于dst仍然是CV_32F
Mat。我怎样才能解决这个问题。
答案 0 :(得分:2)
如果图片类型为CV_32F
并且您只看到白色图片,则表明图片的值不在[0, 1]
范围内。
#include <opencv2/opencv.hpp>
#include <opencv2/highgui.hpp>
#include <Eigen/Core>
#include <opencv2/core/eigen.hpp>
#include <algorithm>
#include <iostream>
// ...
Eigen::Matrix<float, Eigen::Dynamic, Eigen::Dynamic> im;
#if 0
// Wrong value range; you'll see only a white image.
cv::cv2eigen( cv::imread( "lena.jpg", cv::IMREAD_GRAYSCALE ), im );
#else
// This should work ok.
cv::Mat image;
cv::Mat1b image1b = cv::imread( "lena.jpg", cv::IMREAD_GRAYSCALE );
image1b.convertTo( image, CV_32F, 1./255. );
cv::cv2eigen( image, im );
#endif
// Your processing
// ...
cv::Mat1f dst;
cv::eigen2cv( im, dst );
// Check the value range.
float maxV = *( std::max_element( dst.begin(), dst.end() ) );
float minV = *( std::min_element( dst.begin(), dst.end() ) );
std::cout << "value range = [" << minV << ", " << maxV << "]" << std::endl;
cv::imshow( "dst", dst );
cv::waitKey( 0 );
这是第一个变体(#if 1
)的输出:
$ ./a.out
value range = [24, 247]
这是第二个变体(#if 0
)的输出:
$ ./a.out
value range = [0.0941177, 0.968628]
答案 1 :(得分:0)
尝试了一下之后,意识到如果我需要的只是四舍五入,我可以使用convertTo()
cv::Mat dst,dst2;
cv::eigen2cv(im_inv,dst2);
dst2.convertTo(dst, CV_8UC1 );
cv::imshow( "win", dst );