c++ - OpenCV,DFT 函数不要在带有 IMREAD_COLOR 的图像中使用

标签 c++ opencv image-processing dft

使用 IMREAD_COLOR 读取图像时,“dft”函数会引发错误:
Error
使用 IMREAD_GRAYSCALE 读取图像时,DFT 函数工作得很好。但我想用 IMREAD_COLOR 阅读图像。
主功能

const char* filename = "face.jpg";
Mat I = imread(filename, IMREAD_COLOR);
if(I.empty()) return 0;
Mat padded;

I.convertTo(padded, CV_32F);

Mat fft;
Mat planes[2];
dft(padded, fft, DFT_SCALE|DFT_COMPLEX_OUTPUT);

Mat fftBlur = fft.clone();

fftBlur *= 0.5;

split(fftBlur, planes);

Mat ph, mag;

mag.zeros(planes[0].rows, planes[0].cols, CV_32F);
ph.zeros(planes[0].rows, planes[0].cols, CV_32F);
cartToPolar(planes[0], planes[1], mag, ph);

merge(planes, 2, fftBlur);

//inverse
Mat invfft;

dft(fftBlur, invfft, DFT_INVERSE|DFT_REAL_OUTPUT);

Mat result;

invfft.convertTo(result, CV_8U);
Mat image;
cvtColor(result, image, COLOR_GRAY2RGB);

imshow("Output", result);
imshow("Image", image);


waitKey();

最佳答案

您收到的消息是一个断言,它告诉您 DFT 函数仅采用具有一个或两个 channel (CV_32FC1、CV_32FC2、标志平均 channel 末尾的字母 C)的单精度浮点图像或具有一个或两个 channel 的 double 浮点图像两个 channel (CV_64FC1、CV_64FC2)。
双 channel 情况实际上是复杂图像在 OpenCV 数据存储中的表示。
如果您愿意,可以将图像拆分为 std::vector<cv::Mat>其中每个元素确实代表一个 channel ,使用 cv::split借助 cv::merge 在每个 channel 上应用 DFT 进行所需的处理并重新创建多 channel 图像.

关于c++ - OpenCV,DFT 函数不要在带有 IMREAD_COLOR 的图像中使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52686879/

相关文章:

c++ - 枚举机器上的所有 IDispatch 实现对象

c++ - C++中的 `(... && TraitsOf())`是什么意思

python - 在 OpenCV-Python 中绘制直方图

c++ - 如何以最快的方法删除那些指定的标签组件

java - 如何在javacv或opencv开始图像处理之前提高图像质量?

C++(类和指针)

c++ - 如何获取hook winapi函数的调用后参数?

python - 从接口(interface)名称而不是摄像机编号创建 openCV VideoCapture

python - 如何在图像openCV python中找到所有颜色形状

python - 如何根据索引和值有效更新 np 数组?