why fft of an even and real signal in time domain gives imaginary part?

48 views (last 30 days)
This is the question:
a. Create a real and even-symmetric signal for use as a test signal. Since this is easiest to do when the length is odd, take N to be odd (e.g., N = 21). Verify that the DFT of this signal is purely real, and that it is also even-symmetric.
This is my attempt:
I have a coine function which is real and even and I expecy its fourier transform to be real and conjugate symmetry. I applied f1=fftshift(abs(fft(x1))); for taking the fft and the imaginary part is zero. But for part b it asks:
b. Now take the FFT of the same signal, but with the length three times the original (i.e., N = 63). Verify that the transform is no longer purely real (unless, of course, your test signal were the impulse).
still with the same procedure the imaginary part is zero. Where did I make a mistake?
This is my code for a:
N = 21;
tmin=-1;
tmax=1;
t = linspace(tmin,tmax,N+1);
t(end) = [] ;
fs=1/abs(t(1)-t(2));
a = 2;
x1 = cos(a*pi*t);
figure,plot(t,x1);xlabel 'x axis', ylabel 'y axis', title 'cos(2*pi*t)'
k = ( (-(N-1)/2) : ((N-1)/2) )/N*fs;
f1=fftshift(abs(fft(x1)));
figure,plot(k,f1);xlabel 'x axis', ylabel 'y axis',
title 'fourier transform of cos(2*pi*t)'
figure,plot(k,imag(f1)),
title 'imaginary part of the fourier transform of cos(2*pi*t)'
xlabel 'x axis', ylabel 'y axis'
code for part b:
%% the same signal with three times more points
N2 = 63;
tmin=-1;
tmax=1;
t2 = linspace(tmin,tmax,N2+1);
t2(end) = [] ;
fs2=1/abs(t2(1)-t2(2));
a = 2;
x2 = cos(a*pi*t2);
figure,plot(t2,x2);xlabel 'x axis', ylabel 'y axis', title 'cos(2*pi*t)'
k2 = ( (-(N2-1)/2) : ((N2-1)/2) )/N2*fs2;
f2=fftshift(abs(fft(x2)));
figure,plot(k2,f2);xlabel 'x axis', ylabel 'y axis',
title 'fourier transform of cos(2*pi*t)'
figure,plot(k2,imag(f2)),
title 'imaginary part of the fourier transform of cos(2*pi*t)'
xlabel 'x axis', ylabel 'y axis';

Accepted Answer

Walter Roberson
Walter Roberson on 2 Dec 2022
t = linspace(tmin,tmax,N+1);
t(end) = [] ;
Your signal must not return to origin in the final sample. You need a signal such that repmat of the signal would be multiple periods. For example if the signal was triangle 0 1 then if you input 0 1 0 then fft treats it as if it were an indefinite chain of 0 1 0 0 1 0 0 1 0 rather than as 0 1 0 1 0 1...
Also if you are going to use that k then you need to fftshift to plot properly. The negative frequencies are after the positive.
  9 Comments
Walter Roberson
Walter Roberson on 3 Dec 2022
fft of "the same signal" "with length 63" is probably fft(x1, 63) rather than creating a new signal of length 63
2NOR_Kh
2NOR_Kh on 3 Dec 2022
Thanks for your attention. I fixed it and these are the results:
%%part a:
N = 21;
tmin=-1;
tmax=1;
t = linspace(tmin,tmax,N+1);
t(end) = [] ;
fs=1/abs(t(1)-t(2));
a = 2;
x1 = cos(a*pi*t);
figure,plot(t,x1);xlabel 'x axis', ylabel 'y axis', title 'cos(2*pi*t)'
k = ( (-(N-1)/2) : ((N-1)/2) )/N*fs;
f1=fftshift((fft(x1)));
figure,plot(k,f1);xlabel 'x axis', ylabel 'y axis',
Warning: Imaginary parts of complex X and/or Y arguments ignored.
title 'fourier transform of cos(2*pi*t)'
figure,plot(k,imag(f1)),
title 'imaginary part of the fourier transform of cos(2*pi*t)'
xlabel 'x axis', ylabel 'y axis';
%% partb:the same signal wit
h three times more points
N2=63;
k2 = ( (-(N2-1)/2) : ((N2-1)/2) )/N2*fs;
f2=fftshift((fft(x1,63)));
figure,plot(k2,f2);xlabel 'x axis', ylabel 'y axis',
Warning: Imaginary parts of complex X and/or Y arguments ignored.
title 'fourier transform of cos(2*pi*t)'
figure,plot(k2,imag(f2)),
title 'imaginary part of the fourier transform of cos(2*pi*t)'
xlabel 'x axis', ylabel 'y axis';
So, based on what we discuused so far, I've got to this conclusion that for N=21 the imaginary part is negligible since it in the range of power of -16. Ans as you said this id due to the round-off error.
I learned alot from you in this post and I appreciate it so much.

Sign in to comment.

More Answers (1)

Image Analyst
Image Analyst on 2 Dec 2022
You might like to look at Steve's blog on the topic.
  1 Comment
2NOR_Kh
2NOR_Kh on 2 Dec 2022
It was a great link, I appreciate your help.
However, I couldnt find the answer for my question. In theory we expect the fourier transform of a real and even function to be real and conjugate symmetric but I cant see that in MATLAB. I chose cosine function from -1 to 1. So, the imaginary part of its fourier transform must be zero but it is not. Why?

Sign in to comment.

Products


Release

R2021a

Community Treasure Hunt

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

Start Hunting!