I wanted to calculate a 2D FFT on a 3D array and then get the 2D IFFT back. I wanted to use the gpuArray to accelerate the implementation, and I am not sure why I am getting the wrong answer when I have the 3D array on the gpu. For example:
A = fft2(gpuArray(rand(10,10,5)));
A1 = ifft2(A);
A2 = ifft(ifft(A,[],2),[],1);
all(A1==A2,'all')
gpuArray logical
0
A1 = ifft2(gather(A));
A2 = ifft(ifft(gather(A),[],2),[],1);
all(A1==A2,'all')
logical
1
The reason that I used ifft(ifft(A,[],2),[],1) is that I am going to extend the code for a 4D array, and I could not use FFTn to perform a 3D FFT on the first three dimensions! But, when I wanted to get a 3D FFT and then a 3D IFFT using 1d FFT/IFFT, I noticed different GPU and CPU results. Would you please explain what I am doing wrong here?

 採用された回答

Matt J
Matt J 2021 年 3 月 30 日
編集済み: Matt J 2021 年 3 月 30 日

0 投票

Your criterion for agreement is too strong:
A = fft2(gpuArray(rand(10,10,5)));
A1 = ifft2(A);
A2 = ifft(ifft(A,[],2),[],1);
>> max(abs(A1-A2),[],'all')
ans =
3.3529e-16

6 件のコメント

Mojtaba Zarei
Mojtaba Zarei 2021 年 3 月 30 日
I see! BTW, would you please guide me if you know any other way which might be faster than ifft(ifft(A,[],2),[],1) to perform fft/ifft on the first n dimension of an n+1 dimension array?
Matt J
Matt J 2021 年 3 月 30 日
No, I think that is the fastest.
Walter Roberson
Walter Roberson 2021 年 3 月 30 日
there is ifft2() but it ends up doing multiple ifft. I seem to recall some transposes, so hypothetically it could be faster to transpose/permute to be ifft along the first dimension each time, might allow more efficient vectorization potentially.
Mojtaba Zarei
Mojtaba Zarei 2021 年 3 月 30 日
Yes, for 2d, I used ifft2, but it seems a series of ifft/fft is the most efficient way for a bigger dimension.
Matt J
Matt J 2021 年 3 月 30 日
編集済み: Matt J 2021 年 3 月 30 日
Also, if your input has conjugate symmetry, it will be beneficial to use ifft(Y,[],dim,'symmetric') .
Mojtaba Zarei
Mojtaba Zarei 2021 年 3 月 30 日
Yes, but it is not! Thank you for your help!

サインインしてコメントする。

その他の回答 (0 件)

製品

リリース

R2021a

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by