c++ - 逆离散傅里叶变换输出图像

标签 c++ image opencv image-processing dft

我正在尝试对我预先应用离散傅立叶变换的图像实现逆离散傅立叶变换。输出是两张图片。一个图像在正确的位置,另一个是相反的位置。你能帮我解决这个问题吗?

这是我写的代码。

double inverseFourierReal = 0.0;
    double inverseFourierImg = 0.0;
    double degreeValue,cosValue,sinValue;
   // double inverse = inverseFourier;
    for(int rowm = 0; rowm < rows; rowm++ )
    for(int coln = 0; coln < cols; coln++ ) {


        inverseFourierImg = 0.0;
        inverseFourierReal = 0.0;
        for(int rowk = 0; rowk < rows; rowk++ ) {
           for(int coll = 0; coll < cols; coll++ ) {



           degreeValue  = 2. * PI * (float(rowk*rowm)/rows + float(coll*coln)/cols);
           cosValue  = cos(degreeValue);
           sinValue  = sin(degreeValue);

           inverseFourierReal += cosValue * fourierImageReal[rowk][coll] - sinValue * fourierImageImg[rowk][coll];
           //inverseFourierImg += (cosValue * fourierImageImg[rowk][coll] + sinValue * fourierImageReal[rowk][coll]);
           //cout<<inverseFourierReal;

            }

       }

        invr_FourierReal.at<double>(rowm,coln) = abs((inverseFourierReal) / (sqrt(rows*cols)));
       // invr_FourierReal.at<double>(rowm,coln) = double(inverseFourierReal) / (sqrt(rows*cols));
        //invr_FourierImg.at<double>(int(rowm),int(coln)) = double(inverseFourierImg) / (sqrt(rows*cols));


    }

你可以在这里看到输出图像:

img

编辑: 我已经更改了代码,您可以看到新的输出。它是颠倒的。 imgg 我使用 Lena 图像作为输入
P.S 抱歉我的英语不好。

最佳答案

奇怪的镜像混合

什么是fourierFilterImg?你在做某种卷积而不是 IDFT 吗?也希望invr_FourierRealfourierImageReal不是同一个内存地方。我敢打赌,这只是一个复制/粘贴错字,所以我会更改这一行:

inverseFourierReal += (cosValue * fourierImageReal[rowk][coll] - sinValue * fourierFilterImg[rowk][coll]);

收件人:

inverseFourierReal += cosValue * fourierImageReal[rowk][coll] - sinValue * fourierImageImg[rowk][coll];

另外,我希望您的输入图像正确地 DFT 转换并处于复杂域中。

[Edit1] X,Y 的反转

对于 DFTIDFT 某处,row,col 方向的计数可能不同。图像通常有向下的 Y 轴和向右的 X 轴。如果它只是颠倒了,那么就把错误的倒过来。

如果问题出在 IDFT 中,则只需更改:

invr_FourierReal.at<double>(rowm,coln)

到:

invr_FourierReal.at<double>(rows-rowm-1,cols-coln-1)

但我敢打赌,它只是在加载或渲染期间被反转,而 DFT/IDFT 与此无关。

关于c++ - 逆离散傅里叶变换输出图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40964823/

相关文章:

C++11 thread::id 表示无线程的特殊值

c++ - 我是否应该让一个成员函数成为虚拟的只是为了让一个类可测试?

python - 检测嘈杂的背景/物体 - OpenCV

c++ - 将浮点 vector 转换为 16 位 int 而不饱和

c++ - 修改 C++ unordered_map 中复杂类型的值

image - 如何打印处理中的图像

c# - Windows 窗体中图像资源的本地化

reactjs - NextJs 13 中的图像组件如何工作?

linux - 在 ubuntu 14.04 上安装 opencv 时出错

python - 在图像opencv python中找到单词中每个字符的中心坐标