Periodogram

In signal processing, a periodogram is an estimate of the spectral density of a signal. The term was coined by Arthur Schuster in 1898. Today, the periodogram is a component of more sophisticated methods (see spectral estimation). It is the most common tool for examining the amplitude vs frequency characteristics of FIR filters and window functions. FFT spectrum analyzers are also implemented as a time-sequence of periodograms.

Definition
There are at least two different definitions in use today. One of them involves time-averaging, and one does not. Time-averaging is also the purview of other articles (Bartlett's method and Welch's method). This article is not about time-averaging. The definition of interest here is that the power spectral density of a continuous function, $$x(t),$$ is the Fourier transform of its auto-correlation function (see Cross-correlation theorem, Spectral density, and Wiener–Khinchin theorem): $$\mathcal{F}\{x(t)\circledast x^*(-t)\} = X(f)\cdot X^*(f) = \left| X(f) \right|^2.$$

Computation


For sufficiently small values of parameter $T,$ an arbitrarily-accurate approximation for $X(f)$ can be observed in the region $$-\tfrac{1}{2T} < f < \tfrac{1}{2T}$$  of the function:

$$X_{1/T}(f)\ \triangleq \sum_{k=-\infty}^{\infty} X\left(f - k/T\right),$$

which is precisely determined by the samples $x(nT)$ that span the non-zero duration of $x(t)$ (see Discrete-time Fourier transform).

And for sufficiently large values of parameter $N$, $$X_{1/T}(f)$$ can be evaluated at an arbitrarily close frequency by a summation of the form:

$$X_{1/T}\left(\tfrac{k}{NT}\right) = \sum_{n=-\infty}^\infty \underbrace{T\cdot x(nT)}_{x[n]}\cdot e^{-i 2\pi \frac{kn}{N}},$$

where $k$ is an integer. The periodicity of $$e^{-i 2\pi \frac{kn}{N}}$$  allows this to be written very simply in terms of a Discrete Fourier transform:

$$X_{1/T}\left(\tfrac{k}{NT}\right) = \underbrace{\sum_{n} x_{_N}[n]\cdot e^{-i 2\pi \frac{kn}{N}},}_\text{DFT} \quad \scriptstyle{\text{(sum over any }n\text{-sequence of length }N)},$$

where $$x_{_N}$$ is a periodic summation: $$x_{_N}[n]\ \triangleq \sum_{m=-\infty}^{\infty} x[n - mN].$$

When evaluated for all integers, $k$, between 0 and $N$-1, the array: $$S\left(\tfrac{k}{NT}\right) = \left| \sum_{n} x_{_N}[n]\cdot e^{-i 2\pi \frac{kn}{N}} \right|^2$$ is a periodogram.

Applications


When a periodogram is used to examine the detailed characteristics of an FIR filter or window function, the parameter $N$ is chosen to be several multiples of the non-zero duration of the $x[n]$ sequence, which is called zero-padding (see ). When it is used to implement a filter bank, $N$ is several sub-multiples of the non-zero duration of the $x[n]$ sequence (see ).

One of the periodogram's deficiencies is that the variance at a given frequency does not decrease as the number of samples used in the computation increases. It does not provide the averaging needed to analyze noiselike signals or even sinusoids at low signal-to-noise ratios. Window functions and filter impulse responses are noiseless, but many other signals require more sophisticated methods of spectral estimation. Two of the alternatives use periodograms as part of the process:
 * The method of averaged periodograms, more commonly known as Welch's method,   divides a long x[n] sequence into multiple shorter, and possibly overlapping, subsequences.  It computes a windowed periodogram of each one, and computes an array average, i.e. an array where each element is an average of the corresponding elements of all the periodograms.  For stationary processes, this reduces the noise variance of each element by approximately a factor equal to the reciprocal of the number of periodograms.
 * Smoothing is an averaging technique in frequency, instead of time. The smoothed periodogram is sometimes referred to as a spectral plot.

Periodogram-based techniques introduce small biases that are unacceptable in some applications. Other techniques that do not rely on periodograms are presented in the spectral density estimation article.