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

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

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)

Categories

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

Tags

Asked:

XC
on 11 Nov 2014

Commented:

on 11 Nov 2014

Community Treasure Hunt

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

Start Hunting!