### What is the relation between FFT length and frequency resolution?

If I have sampled a signal using proper sampling methods (Nyquist, filtering, etc) how do I relate the length of my FFT to the resulting frequency resolution I can obtain?

Like if I have a 2,000 Hz and 1,999 Hz sine wave, how would I determine the length of FFT needed to accurately tell the difference between those two waves?

Mark Correct answer

9 years agoThe frequency resolution is dependent on the relationship between the FFT length and the sampling rate of the input signal.

If we collect 8192 samples for the FFT then we will have:

$$\frac{8192\ \text{samples}}{2} = 4096\ \,\text{FFT bins}$$

If our sampling rate is 10 kHz, then the Nyquist-Shannon sampling theorem says that our signal can contain frequency content up to 5 kHz. Then, our frequency bin resolution is:

$$\frac{5\ \text{kHz}}{4096\ \,\text{FFT bins}} \simeq \frac{1.22\ \text{Hz}}{\text{bin}}$$

This is may be the easier way to explain it conceptually but simplified: your bin resolution is just \$\frac{f_{samp}}{N}\$, where \$f_{samp}\$ is the input signal's sampling rate and N is the number of FFT points used (sample length).

We can see from the above that to get smaller FFT bins we can either run a longer FFT (that is, take more samples

*at the same rate*before running the FFT) or decrease our sampling rate.**The Catch:**There is always a trade-off between temporal resolution and frequency resolution.

In the example above, we need to collect 8192 samples before we can run the FFT, which when sampling at 10 kHz takes 0.82 seconds.

If we tried to get smaller FFT bins by running a longer FFT it would take even longer to collect the needed samples.

That may be OK, it may not be. The important point is that at a fixed sampling rate, increasing frequency resolution decreases temporal resolution. That is the more accurate your measurement in the frequency domain, the less accurate you can be in the time domain. You effectively lose all time information inside the FFT length.

In this example, if a 1999 Hz tone starts and stops in the first half of the 8192 sample FFT and a 2002 Hz tone plays in the second half of the window, we would see both, but they would appear to have occurred at the same time.

You also have to consider processing time. A 8192 point FFT takes some decent processing power. A way to reduce this need is to reduce the sampling rate, which is the second way to increase frequency resolution.

In your example, if you drop your sampling rate to something like 4096 Hz, then you only need a 4096 point FFT to achieve 1 Hz bins *4096 Hz, then you only need a 4096 point FFT to achieve 1hz bins and can still resolve a 2khz signal. This reduces the FFT bin size, but also reduces the bandwidth of the signal.

Ultimately with an FFT there will always be a trade off between frequency resolution and time resolution. You have to perform a bit of a balancing act to reach all goals.

with header tags and some formatting this post could go from good to great. You touched on everything I wanted to note, and very well, but the way the post is formatted fewer people will read it as its length is prohibitive, if you give headers with each section of what you are discussing people will jump to the juicy bit that suites them and your number of +1s will increase a lot. Not from me of course, as you already earned it.

@kurtuk I spit this one out in a rush, I'll clean up the formatting when i have some spare time (or feel free to edit it if you wish).

@kortuk, name starts with an 'o'. I assumed you had, I was just sharing my view, both for you if you did not already know, but more for the community on the whole.

Note that you don't have to calculate the FFT. If you only want to know a few bins, it's cheaper to calculate the DFT of just those bins, than to run an optimized FFT which calculates all the bins at once by sharing many of the operations.

It is also worth noting that a similar frequency/time domain trade-off applies to analog and IIR filters.

Basic FFT resolution is \$f_s \over N\$, where \$f_s\$ is the sampling frequency.

The ability to differentiate two very closely spaced signals depends strongly on relative amplitudes and the windowing function used.

You may find that playing with the Baudline signal analyzer is a good way to develop some intuition on this matter - and no, running some FFTs and plotting one spectrum at a time in Matlab or Python/Numpy is really not the same.

EDIT: There is also a trick to pad the input with zeros and taking a bigger FFT. It will not improve your differentiation ability but may make the spectrum more readable. It is basically a trick similar to antialiasing in vector graphics.

Am I the only one who doesn't see the Latex code displayed properly formatted?

@stevenvh Not work for me too.

Works for me. The latex is only 2 places.

Fixed (already for some time). Firefox's NoScript add-on blocked mathjax.org.

It's worth noting that an FFT is an alternative to computing a number of separate pairs of sums (k=0..sample_length-1) of Sample[k]*SineRefWave[j][k] and Sample[j]*CosRefWave[j][k], for all j up to half the sample length. If one needs amplitude readouts at all those frequencies, an FFT will compute them all in O(NlgN) time, whereas computing them individually would take O(N^2) time. On the other hand, if one only needs amplitude readouts at a few frequencies, one will often be better off simply computing them individually, especially if one is using a processor or DSP which can efficiently compute that style of sum.

It's also worth noting that while an FFT with e.g. a 20ms sampling window won't be able to distinguish between a single 1975Hz tone, or a combination of frequencies (1975-N)Hz and (1975+N)Hz for N<25, it can be used to measure isolated frequencies with accuracy finer than the sampling window if there is no other spectral content nearby. A lone 1975Hz frequency will pick up equally in the 1950Hz and 2000Hz bins, as would a combination of 1974Hz and 1976Hz tones. An isolated 1974Hz tone, however, would pick up more strongly in the 1950Hz bin than in the 2000Hz bin, and a 1976Hz tone would pick up more strongly in the 2000Hz bin.

The frequency resolution does not depend on the length of FFT, but the length of the total sampling time T, i.e. it's 1/T, which is also the lowest frequency component you obtained.

Note, zero padding does not increase the frequency resoltuion; DFT of the zero padding signal is merely a better approximation of the DTFT of the orginal signal.

to sum up, does that mean the lowest frequency is just given by \$ 1/T \$ and the maximum frequency is sampling frequency/2 ?

If you know the range of possible input frequencies, and the range is narrow, you may apply undersampling to reduce the number of samples and the time to compute the FFT. With 256 samples and a sample frequency of 256 Hz, you get the wanted 1-Hz resolution and an alias-free bandwidth of 128 Hz.

It's not totally clear from this picture what's going on. (It doesn't help that the picture isn't in English.) What does this add that the other answers haven't mentioned?

License under CC-BY-SA with attribution

Content dated before 6/26/2020 9:53 AM

Kortuk 9 years ago

with header tags and some formatting this post could go from good to great. You touched on everything I wanted to note, and very well, but the way the post is formatted fewer people will read it as its length is prohibitive, if you give headers with each section of what you are discussing people will jump to the juicy bit that suites them and your number of +1s will increase a lot. Not from me of course, as you already earned it.