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

Inverse Discrete Fourier transform output image

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

这是我写的代码。

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));


    }

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

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

奇怪的镜像混合

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

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 与此无关。