3

我正在尝试学习 OpenCV,我想应用这个简单的公式: 在此处输入图像描述

这是一个逐像素操作,将像素从r转换为s

这是我的代码:

int main(int /*argc*/, char** /*argv*/) {

    Mat _img = imread("lena.jpg"); 
    cvtColor(_img, img, CV_32F);

    cout << "original image size: " << img.rows << " " << img.cols << endl;
    cout << "original type: " << img.type() << endl;
    cout << "original depth: " << img.depth() << endl;

    Mat _src = img.clone();
    _src += 1;
    log(_src, logContrast);
    logContrast *= log_c;

    /// ...

我得到这个错误:

OpenCV Error: Assertion failed (depth == CV_32F || depth == CV_64F) in log, file /home/user/Documents/Code/OpenCV-2.3.1/modules/core/src/mathfuncs.cpp, line 1772
terminate called after throwing an instance of 'cv::Exception'
  what():  /home/alberto/Documents/Code/OpenCV-2.3.1/modules/core/src/mathfuncs.cpp:1772: error: (-215) depth == CV_32F || depth == CV_64F in function log

我尝试使用灰色和彩色图像,并使用cvtColor,CV_8UCV_32F, C1C3但我总是将 0 作为深度..

我在 OpenCV 手册和OpenCV-2.3.1/modules/core/include/opencv2/core/types_c.h上花费了数小时,但是……我找不到解决方案。我想我对如何转换Mat对象的深度有些困惑。

4

2 回答 2

6

您确定将图像转换为 float32吗?

请检查下面的代码,我刚刚写的。不知道输出是否正确,但它没有抛出任何错误。

#include "opencv2/highgui/highgui.hpp"
#include "opencv2/imgproc/imgproc.hpp"
#include <iostream>
using namespace std;

int main ()
{
    cv::Mat binary = cv::imread("kick.jpg",0);

    cv::Mat fg;
    binary.convertTo(fg,CV_32F);
    fg = fg + 1;
    cv::log(fg,fg);
    cv::convertScaleAbs(fg,fg);
    cv::normalize(fg,fg,0,255,cv::NORM_MINMAX);
    cv::imshow("a",fg);
cv::waitKey(0);
}

下面是我得到的输出:

在此处输入图像描述

于 2012-07-16T15:43:58.633 回答
0

交换以下行以获得更好的结果:

    cv::normalize(fg,fg,0,255,cv::NORM_MINMAX);
    cv::convertScaleAbs(fg,fg);
于 2014-01-10T14:55:57.823 回答