Problem with ifftn and ifftshift??

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

0 votos

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

0 votos

Thanks so much for the help! I will try your suggestion! :D

Categorías

Más información sobre Fourier Analysis and Filtering en Centro de ayuda y File Exchange.

Preguntada:

el 26 de Jun. de 2013

Comentada:

el 14 de Oct. de 2023

Community Treasure Hunt

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

Start Hunting!

Translated by