Is my understanding of the Nyquist theorem correct?

  • Thread starter fog37
  • Start date
  • #1
fog37
1,569
108
TL;DR Summary
Correct understanding of Nyquist theorem
Hello,
I would really appreciate it if you could check my understanding on Nyquist theorem:

  • We start with a continuous time signal f(t) and convert it to a digital and discrete signal ##f[t]##.
  • The discrete signal ##f[t]## to be a "good" approximation of the continuous signal ##f(t)## only if we sample ##f(t)## at a sufficiently high rate. The higher the better but too many samples may also be unnecessary. Nyquist theorem tells us that if we sample ##f(t)## at a rate higher than ##2 f_{max}##, we will be able to "perfectly" reconstruct the continuous signal ##f(t)## from the samples using interpolation. Not just that: the spectrum of the digital discrete signal ##f[t]## will be a good approximation of the actual spectrum ##F(f)## of ##f(t)##. Given a sequence of ##N## time samples after sampling ##f(t)##, we can take the Fourier transform DFT of those ##N## samples to get the spectrum which also has ##N## samples.
  • Interestingly, The DFT spectrum will only have values at frequencies which are ##k \frac {f_s} {N}## Hz where k=integer, ##f_s##=sampling rate, ##N##=number of samples.
Example:
  • ##f = 5Hz##, the frequency of our continuous sine function ##f(t) = sin(2 \pi f t)##
  • Time interval ##\Delta t##=1 s
  • period ##T## of continuous sine ##f(t)## is ##\frac {1}{f}## = 1/5 = 0.2s
  • number of cycles of continuous sine f(t) during ##\Delta_t##: 1/0.2= 5
  • ##fs## = sampling frequency = 20 Hz (much higher than 5Hz)
  • ##N##=number of samples = (20/cycle)*(5 cycles)=100
  • The frequency bins in the DFT are k*fs/N: f1=20/100=0.2 , f2=40/100=0.4, f3=60/100=0.3, f4= 80/100, ...etc.
  • The discrete signal version of ##f(t)## is given by ##f[n] = sin[2 \pi 5 fs n]## where n=integer.
  • In this example, the DFT spectrum will have a single spike at ##f=5Hz##, as we desire, because 5Hz corresponds to exactly an integer multiple ##k=25##. If ##f## was not an exactly multiple of ##\frac {f_s} {N}##, we would small nonzero values also at other DFT bin frequencies. But this is NOT aliasing.
  • Aliasing occurs, for example, if ##fs=8Hz##. The DFT spectrum would be VERY different from the actual spectrum of the continuous ##f(t)## signal with large and significant nonzero values at DFT bin frequencies other than the actual frequency...Mathematically, this can seen as "replicas" of the actual spectrum overlapping with each other in the bandwidth 0-fmax distorting the spectrum: multiplication in the time domain (the sampling) is convolution in the frequency domain.
  • The time domain signal is discrete and finite with ##N## samples. Its spectrum would be continuous and infinite DTFT. However, we get the DFT which is also discrete and finite. This means that the DFT is a discrete approximation of the DTFT, correct?
In real-world applications, the input signal to a system can be continuous (ex: audio signal)...Is that signal, before it is converted to the appropriate discrete version via sampling, first low-pass filtered to set the maximum frequency ##f_{max}## in the signal itself? I think so...But isn't that risky in the sense that we may low-pass filter the continuous signal too much and get rid of important high frequency components that are important in the signal makeup?

Is my understanding correct?

Thank you
 
Engineering news on Phys.org
  • #2
Mostly correct. We might write the sampled sequence as $$f_k=f(kT_s)$$ to make the discreteness explicit, where T_s is the sampling interval. The question of reconstructing the spectrum is complicated. The DFT has pitfalls, including limited resolution (equal to the inverse of the duration of the sampled sequence), spurious “picket fence” responses, and inaccurate amplitude or power estimates due to “straddle loss.” Ad-hoc bandaids such as windows help some of these but worsen others. Prior knowledge about the system allows use of model-based spectral estimators that can do better. The topic is suitable for a grad level course.
I didn’t read your examples.
Finally, yes you low pass filter first. Most signals have a cutoff frequency above which there is no relevant information. Human ears can’t hear sounds above 20 kHz, e.g., so there’s no information lost by filtering higher frequencies away.
 
  • Like
Likes scottdave and fog37
  • #3
marcusl said:
Mostly correct. We might write the sampled sequence as $$f_k=f(kT_s)$$ to make the discreteness explicit, where T_s is the sampling interval. The question of reconstructing the spectrum is complicated. The DFT has pitfalls, including limited resolution (equal to the inverse of the duration of the sampled sequence), spurious “picket fence” responses, and inaccurate amplitude or power estimates due to “straddle loss.” Ad-hoc bandaids such as windows help some of these but worsen others. Prior knowledge about the system allows use of model-based spectral estimators that can do better. The topic is suitable for a grad level course.
I didn’t read your examples.
Finally, yes you low pass filter first. Most signals have a cutoff frequency above which there is no relevant information. Human ears can’t hear sounds above 20 kHz, e.g., so there’s no information lost by filtering higher frequencies away.
Thank you.

If the DFT is not that great, I guess other transforms, like the wavelet transform, may be better. For example, the wavelet transform is better at time-frequency localization, I believe...

For sound, as you mention, the 20kHz is the limit but for other signals (ex: seismic waves, etc.) we don't know what the largest frequency may be so the cut-off may be application dependent...
 
  • #4
The DFT is the most general, easiest to compute and universally used spectral estimator, so you should use it also. Just be aware of its idiosyncrasies and limitations.
 
  • #5
fog37 said:
If the DFT is not that great, I guess other transforms, like the wavelet transform, may be better. For example, the wavelet transform is better at time-frequency localization, I believe...
It's a while since I was learning about A to D conversion but I learned that two more factors can be relevant if we want to discuss the relative merits of methods for analysing the performance of the system. Firstly, the practical details of just how tight we want to push the Nyquist limit and secondly the time profile of the samples. If you really want a 'near perfect' reconstructed signal at the other end then there must be a combination of filtering before the ADC and after the DAC. Then depending on the nature of the input analogue signal to noise ratio it may be better to use a shorter sampling times to reduce the sinc distortion that simple box-car samples will introduce.
Where are we, in this thread, in terms of knowledge of the finer levels of digital signalling? There are any number of texts that could flesh out my above concerns. I don't have convenient access to the most suitable texts any more but it may be worth while going back to basics here if the OP wants the best advice.
 

FAQ: Is my understanding of the Nyquist theorem correct?

What is the Nyquist theorem?

The Nyquist theorem, also known as the Nyquist-Shannon sampling theorem, states that in order to accurately reconstruct a continuous signal from its samples, the sampling rate must be at least twice the highest frequency present in the signal. This minimum rate is called the Nyquist rate.

Why is the Nyquist rate important?

The Nyquist rate is crucial because sampling below this rate leads to aliasing, where different signals become indistinguishable from each other after sampling. This results in a loss of information and distortion in the reconstructed signal. Sampling at or above the Nyquist rate ensures that the original signal can be accurately reconstructed.

How do I determine the highest frequency in a signal?

The highest frequency in a signal is called the Nyquist frequency. To determine it, you need to analyze the signal's frequency spectrum, which can be done using tools like the Fourier transform. The Nyquist frequency is half of the sampling rate, so if you know your sampling rate, you can determine the maximum frequency you can accurately capture by dividing the sampling rate by two.

What happens if I sample below the Nyquist rate?

If you sample below the Nyquist rate, aliasing occurs. Aliasing is a phenomenon where higher frequency components of the signal are misrepresented as lower frequency components, leading to distortion and an inaccurate representation of the original signal. This makes it impossible to accurately reconstruct the original signal from its samples.

Can I sample above the Nyquist rate, and what are the benefits?

Yes, you can sample above the Nyquist rate, which is known as oversampling. Oversampling can provide several benefits, including improved signal-to-noise ratio (SNR), easier filtering requirements, and reduced aliasing artifacts. However, it also increases the amount of data that needs to be processed and stored, which may require more computational resources.

Back
Top