Basic question about using MATLAB fft: divide fft() by number of data points?
4 views (last 30 days)
Show older comments
Hi,
I have a very basic question regarding the use of the MATLAB fft() function.
In the MATLAB documentation on fft http://www.mathworks.com/help/matlab/ref/fft.html, an example was given for calculating the spectrum of a time domain vector y, with length L. The example code is as below for reference.
****************************************
NFFT = 2^nextpow2(L); % Next power of 2 from length of y
Y = fft(y,NFFT)/L;
f = Fs/2*linspace(0,1,NFFT/2+1);
******************************************
My question is, why is the fft() result divided by L here? The actual number of data points used is NFFT, not L. Should the fft() result be divided by NFFT instead?
Thanks!
Xi
0 Comments
Accepted Answer
Star Strider
on 11 Nov 2014
The nextpow2 function zero-pads the signal so the fft calculation is more efficient. It adds no energy to the signal, so dividing by the length of the original signal is appropriate to normalise the amplitudes of the transformed components.
0 Comments
More Answers (1)
See Also
Categories
Find more on Fourier Analysis and Filtering in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!