Problem with ifftn and ifftshift??

6 Ansichten (letzte 30 Tage)
Bran
Bran am 26 Jun. 2013
Kommentiert: Walter Roberson am 14 Okt. 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 Kommentare
Mehri Mehrnia
Mehri Mehrnia am 14 Okt. 2023
why we should use fftshit?when I dont use fftshit, scale is good and untouched
Walter Roberson
Walter Roberson am 14 Okt. 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.

Melden Sie sich an, um zu kommentieren.

Akzeptierte Antwort

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

Weitere Antworten (1)

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

Kategorien

Mehr zu Fourier Analysis and Filtering finden Sie in Help Center und File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by