How to extract phase and amplitude information from FFT?
18 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
I am doing signal processing of radar data. I applied butturworth bandpass filter and applied fft to the radar data.I want to know how to extract the phase and amplitude information of radar data so i can add it to my ideal radar simualation and make it non ideal :D . Thanks
load('fb2040'); % loading the data
x = fb2040(3,:);
y_filt = filter(b,a,x); % filtering the received signal
nfft = length(y_filt);
res = fft(y_filt,nfft)/ nfft; % normalizing the fft
f = fs/2*linspace(0,1,nfft/2+1); % choosing correct frequency axes
res = res(1:nfft/2+1);
figure, plot(f,abs(res));
xlabel('Frequency in MHz');ylabel('Amplitude');
return
0 commentaires
Réponse acceptée
Adam
le 26 Juin 2015
If you want the phase and amplitude for different frequencies then these are just:
angle( res );
real( res );
or
abs( res );
if you want the magnitude rather than amplitude.
2 commentaires
Peter Mbamaluikem
le 13 Juil 2017
Hi, Adam what if there are several frequencies and one is to extract the magnitude of one say 60Hz. what will the code be?
Adam
le 14 Juil 2017
'res' in the above code is a vector of results corresponding to the frequencies in 'f' in the original code in the question so just find the 'f' that is closest to 60Hz and take the magnitude of that value rather than the whole vector.
Plus de réponses (0)
Voir également
Catégories
En savoir plus sur Spectral Measurements dans Help Center et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!