Basic question about using MATLAB fft: divide fft() by number of data points?

4 views (last 30 days)
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

Accepted Answer

Star Strider
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.

More Answers (1)

XC
XC on 11 Nov 2014
Thanks Star Strider, that was a very clear answer! Thank you.

Categories

Find more on Fourier Analysis and Filtering in Help Center and File Exchange

Tags

Community Treasure Hunt

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

Start Hunting!