gpt4 book ai didi

matlab - 在 OpenCV 中显示傅里叶变换

转载 作者:太空宇宙 更新时间:2023-11-03 22:35:43 25 4
gpt4 key购买 nike

我刚刚开始学习使用 OpenCV,但在使用 DFT 时遇到了问题。我已经完成了一个使用 MatLab 的信号处理类(class),所以我正在尝试完成我们在该类(class)中所做的一些练习。我正在尝试获取并显示图像的 FT,因此我可以屏蔽一些频率。我希望能够看到英国《金融时报》,所以我知道要制作多大的面具,但当我尝试时,我得到了这样的图像:
alt text
而不是喜欢其中之一
alt text http://www.ceremade.dauphine.fr/~peyre/numerical-tour/tours/graphics_synthesis_fourier/index_03.png
我在某处忘记了一步吗?我正在加载图像,将其类型转换为 CV_32FC1,获取它的矩阵,获取 DFT,然后将生成的矩阵转回图像。如果有帮助,我会发布我正在使用的代码吗?
或者,如果有人链接到显示 FT 的示例?我只能找到将它用于卷积的那些。

编辑:我得到图像的相位了吗?

最佳答案

我在尝试使用 OpenCV 可视化图像上 2D DFT 的大小时遇到​​了类似的麻烦。我终于推出了一个可行的实现方案。我不认为它是很好的代码,它只在 256 x 256 8 位(灰度)单 channel 图像上进行了测试--lenna.png(可能需要调整以适当填充其他图像尺寸)。输入图像和重建图像之间的均方误差为零,因此它可以正常工作。需要 OpenCV v2.1。

文件:mstrInclude.h

    #ifndef _MASTER_INCLUDE_
#define _MASTER_INCLUDE_

// Standard
#include <stdio.h>
#include <string>
#include <sstream>
#include <iostream>
#include <cmath>
using namespace std;

// OpenCV2.1
#include "cv.h"
#include "highgui.h"
using namespace cv;

#define LOAD_IMAGE "lenna.png"

#endif // _MASTER_INCLUDE_

文件:main.cpp

    #include "mstrInclude.h"
void translateImg(Mat& imgIn, Mat& imgOut)
{
int i, j;

for (i = 0; i < imgIn.rows; i++)
for (j = 0; j < imgIn.cols; j++)
imgOut.at<double>(i,j) = imgIn.at<double>(i,j) * pow(-1.0, i+j);
}
void scaleImg(Mat& imgIn, Mat& imgOut, float scaleFactor)
{
int i, j;

for (i = 0; i < imgIn.rows; i++)
for (j = 0; j < imgIn.cols; j++)
imgOut.at<double>(i,j) = (double)scaleFactor * log(1.0 + imgIn.at<double>(i,j));
}

void consoleOut(cv::Mat outMat, int rows = 5, int cols = 5)
{
rows = ((rows == -1 || rows >= outMat.rows) ? outMat.rows : rows);
cols = ((cols == -1 || cols >= outMat.cols) ? outMat.cols : cols);

for(int i = 0; i < rows; i++)
{
for(int j = 0; j < cols; j++)
{
cout << outMat.at<double>(i, j);
cout << " ";
}
cout << endl;
}
}

double calcMSE(Mat& imgOrig, Mat& imgReconst)
{
int valOrig = 0, valReconst = 0;
double MSE = 0.0;

for(int i = 0; i < imgOrig.rows; i++)
{
for (int j = 0; j < imgOrig.cols; j++)
{
valOrig = imgOrig.at<unsigned char>(i, j);
valReconst = imgReconst.at<unsigned char>(i, j);

MSE += pow( (double)(valOrig - valReconst), 2.0 );
}
}
return (MSE / (imgOrig.rows * imgOrig.cols));
}

string convertInt(int number) // converts integer to string
{
stringstream ss;
ss << number;
return ss.str();
}

int main(unsigned int argc, char* const argv[])
{
int dftH, dftW;
cv::Mat imgIn;

imgIn = cv::imread(LOAD_IMAGE, 0); //grayscale
cv::imshow("Original Image", imgIn);
waitKey();

dftH = cv::getOptimalDFTSize(imgIn.rows);
dftW = cv::getOptimalDFTSize(imgIn.cols);

Mat imgMod;
Mat imgPrecFFT(dftH, dftW, CV_64FC1, Scalar::all(0));
imgIn.convertTo(imgMod, CV_64FC1);
imgPrecFFT = imgMod(cv::Range::all(), cv::Range::all()).clone();

// translate image
std::vector<Mat> imgsTrans;
imgsTrans.push_back(Mat_<double>(imgIn.size(), CV_64FC1));
imgsTrans.push_back(Mat_<double>(imgIn.size(), CV_64FC1));
imgsTrans[1].setTo(Scalar::all(0), Mat());
translateImg(imgPrecFFT, imgsTrans[0]);

Mat imgPrecTransFFT(imgIn.size(), CV_64FC2, Scalar::all(0));
cv::merge(imgsTrans, imgPrecTransFFT);

// dft
cv::Mat imgFFT;
dft(imgPrecTransFFT, imgFFT, DFT_COMPLEX_OUTPUT);
cv::Mat imgDispFFT;

// calculate magnitude
Mat imgMagnitude(imgIn.size(), CV_64FC1);
std::vector<Mat> chans;
cv::split(imgFFT, chans);
cv::magnitude(chans[0], chans[1], imgMagnitude);

// scale magnitude image
Mat imgMagnitudeScaled(imgIn.size(), CV_64FC1);
scaleImg(imgMagnitude, imgMagnitudeScaled, 10.0);

// display magnitude image
cv::Mat imgDisp;
cv::convertScaleAbs(imgMagnitudeScaled, imgDisp);
imshow("Magnitude Output", imgDisp);
waitKey();

// inverse dft
cv::split(imgFFT, chans);
chans[1].zeros(imgIn.size(), CV_64FC1);
cv::merge(chans, imgFFT);
cv::Mat invFFT;
cv::idft(imgFFT, invFFT, DFT_REAL_OUTPUT + DFT_SCALE);

// translate image back to original location
cv::split(invFFT, imgsTrans);
Mat imgAfterTrans(imgIn.size(), CV_64FC1);
translateImg(imgsTrans[0], imgAfterTrans);
imgAfterTrans.convertTo(imgDisp, CV_8UC1);

imshow("After Inverse Output", imgDisp);
waitKey();

// calculate and output mean-squared error between input/output images
double MSE = calcMSE(imgIn, imgDisp);
cout<<endl<<"MSE: "<<MSE<<endl;
waitKey();

return 0;
}

关于matlab - 在 OpenCV 中显示傅里叶变换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2979928/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com