Problem with ifftn and ifftshift??

5 visualizaciones (últimos 30 días)
Bran
Bran el 26 de Jun. de 2013
Comentada: Walter Roberson el 14 de Oct. de 2023
Hi there I was wondering if someone could help me. I am using the fftn fftshift functions as part of my alogrithm;
tmp = fftn(MAT); Adash = fftshift(tmp);
Adashup=ifftshift(Adash);
Adashup2new = ifftn(Adashup);
However, When I took everything else out and left these in as a tester I noticed that instead of the above taking me back to the original MAT, it alters the numbers quite a lot. What am I doing wrong?? Example original file MAT has a min of 0 and a max of 1.0856, however the file Adashup2new has a min of -6.792 and a max of 1.0856
  2 comentarios
Mehri Mehrnia
Mehri Mehrnia el 14 de Oct. de 2023
why we should use fftshit?when I dont use fftshit, scale is good and untouched
Walter Roberson
Walter Roberson el 14 de Oct. de 2023
fft() returns back the 2-sided fft. By convention, the order of frequency bins returns back from fft() of real input signals is like
0, 1, 2, 3, 4, ... n-1, n, conj(-n), conj(-(n-1)), ... conj(-(4)), conj(-(3)), conj(-(2)), conj(-1)
but people often prefer to visualize it in the order
conj(-(n-1)), ... conj(-(4)), conj(-(3)), conj(-(2)), conj(-1), 0, 1, 2, 3, 4, ... n-1, n
The change is not mathematically significant: it is just easier for people to look at the plots.

Iniciar sesión para comentar.

Respuesta aceptada

Nitin
Nitin el 26 de Jun. de 2013
Sounds like Imaginary components are there due to round off errors, try extracting the real part
f = real(ifft2(F));

Más respuestas (1)

Bran
Bran el 27 de Jun. de 2013
Thanks so much for the help! I will try your suggestion! :D

Categorías

Más información sobre Fourier Analysis and Filtering en Help Center y File Exchange.

Community Treasure Hunt

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

Start Hunting!

Translated by