Contents
clear all, close all t = 0:1/1024:1; t = t(1:1024); f = 0:1023;
The first example is a signal that contains three harmonics.
Write the code that does the discrete Fourier transform.
Compare your frequency-domain results with the ones generated from MATLAB function fft.
f1 = 10; f2 = 80; f3 = 150; x1 = rand(1)*exp(sqrt(-1)*2*pi*f1*t) + rand(1)*exp(sqrt(-1)*2*pi*f2*t) + rand(1)*exp(sqrt(-1)*2*pi*f3*t); y1 = fft(x1); figure(1) subplot(2,1,1) plot(t,real(x1)) ylabel('Real') subplot(2,1,2) plot(t,imag(x1)) ylabel('Imag') xlabel('Time (sec)') figure(2) subplot(2,1,1) plot(f,real(y1)) ylabel('Real') subplot(2,1,2) plot(f,imag(y1)) ylabel('Imag') xlabel('Frequency (Hz)') figure(3) subplot(2,1,1) plot(f,abs(y1)) ylabel('Radius') subplot(2,1,2) plot(f,angle(y1)) ylabel('Angle') xlabel('Frequency (Hz)')
data:image/s3,"s3://crabby-images/fa024/fa02446e3bf37045fbb9c0a664fcf4b9abdf9df3" alt=""
data:image/s3,"s3://crabby-images/589f8/589f8a0e69607f80aee2c39cdf6899d06935f96e" alt=""
data:image/s3,"s3://crabby-images/fd31b/fd31b02d0a00cc15fa2012ea6e90272a9016e118" alt=""
The second example is a rectangular (box) function. Therefore, its Fourier transform is a sinc function.
Write the code that does the discrete Fourier transform.
Compare your frequency-domain results with the ones generated from MATLAB function fft.
x2 = [ones(64,1); zeros(960,1)]; y2 = fft(x2); figure(4) subplot(2,1,1) plot(t,real(x2)) ylabel('Real') subplot(2,1,2) plot(t,imag(x2)) ylabel('Imag') xlabel('Time (sec)') figure(5) subplot(2,1,1) plot(f,real(y2)) ylabel('Real') subplot(2,1,2) plot(f,imag(y2)) ylabel('Imag') xlabel('Frequency (Hz)') figure(6) subplot(2,1,1) plot(f,abs(y2)) ylabel('Radius') subplot(2,1,2) plot(f,angle(y2)) ylabel('Angle') xlabel('Frequency (Hz)') f2 = f - 512; figure(7) subplot(2,1,1) plot(f2,real(fftshift(y2))) ylabel('Real') subplot(2,1,2) plot(f2,imag(fftshift(y2))) ylabel('Imag') xlabel('Frequency (Hz)') figure(8) subplot(2,1,1) plot(f2,abs(fftshift(y2))) ylabel('Radius') subplot(2,1,2) plot(f2,angle(fftshift(y2))) ylabel('Angle') xlabel('Frequency (Hz)')
data:image/s3,"s3://crabby-images/7da5d/7da5db9aaebc7660c30eb9b4890cffe033572797" alt=""
data:image/s3,"s3://crabby-images/929b3/929b3bc529b005b359e57486107462d5c2e0d93a" alt=""
data:image/s3,"s3://crabby-images/f0294/f0294c4c892373d84be9df975b86a68903c7904e" alt=""
data:image/s3,"s3://crabby-images/b299d/b299d2b8c77d462431702ba4c6e1a3c79cd81414" alt=""
data:image/s3,"s3://crabby-images/27525/2752580ff79afb0d5f6a476a026d535711469ad2" alt=""