Kaiser window

From Wikipedia, the free encyclopedia
Jump to navigation Jump to search

Template:Short description

File:KaiserWindow.svg
The Kaiser window for several values of its parameter

The Kaiser window, also known as the Kaiser–Bessel window, was developed by James Kaiser at Bell Laboratories. It is a one-parameter family of window functions used in finite impulse response filter design and spectral analysis. The Kaiser window approximates the DPSS window which maximizes the energy concentration in the main lobe[1] but which is difficult to compute.[2]

Definition

The Kaiser window and its Fourier transform are given by:

w0(x){1LI0[πα1(2x/L)2]I0[πα],|x|L/20,|x|>L/2}sin((πLf)2(πα)2)I0(πα)(πLf)2(πα)2,   [3]Template:Efn-ua
File:Kaiser-Window-Spectra.svg
Fourier transforms of two Kaiser windows

where:

  • I0Script error: No such module "Check for unknown parameters". is the zeroth-order modified Bessel function of the first kind,
  • Template:Mvar is the window duration, and
  • αScript error: No such module "Check for unknown parameters". is a non-negative real number that determines the shape of the window. In the frequency domain, it determines the trade-off between main-lobe width and side lobe level, which is a central decision in window design.
  • Sometimes the Kaiser window is parametrized by βScript error: No such module "Check for unknown parameters"., where β = παScript error: No such module "Check for unknown parameters"..

For digital signal processing, the function can be sampled symmetrically as:

w[n]=Lw0(LN(nN/2))=I0[πα1(2nN1)2]I0[πα],0nN,

where the length of the window is N+1, and N can be even or odd. (see A list of window functions)

In the Fourier transform, the first null after the main lobe occurs at f=1+α2L, which is just 1+α2 in units of N (DFT "bins"). As α increases, the main lobe increases in width, and the side lobes decrease in amplitude.  αScript error: No such module "Check for unknown parameters". = 0 corresponds to a rectangular window. For large α,Script error: No such module "Check for unknown parameters". the shape of the Kaiser window (in both time and frequency domain) tends to a Gaussian curve.  The Kaiser window is nearly optimal in the sense of its peak's concentration around frequency 0.[4]

Kaiser–Bessel-derived (KBD) window

File:Kbd-window.svg

A related window function is the Kaiser–Bessel-derived (KBD) window, which is designed to be suitable for use with the modified discrete cosine transform (MDCT). The KBD window function is defined in terms of the Kaiser window of length N+1, by the formula:

dn={i=0nw[i]i=0Nw[i]if 0n<Ni=02N1nw[i]i=0Nw[i]if Nn2N10otherwise.

This defines a window of length 2N, where by construction dn satisfies the Princen-Bradley condition for the MDCT (using the fact that wNn = wnScript error: No such module "Check for unknown parameters".): dn2 + (dn+N)2 = 1Script error: No such module "Check for unknown parameters". (interpreting n and n + N modulo 2N). The KBD window is also symmetric in the proper manner for the MDCT: dn = d2N−1−n.

Applications

The KBD window is used in the Advanced Audio Coding digital audio format.

Notes

Template:Notelist-ua

References

  1. Script error: No such module "citation/CS1".
  2. Script error: No such module "citation/CS1".
  3. Script error: No such module "Citation/CS1".
  4. Script error: No such module "citation/CS1".

Further reading

  • Script error: No such module "Citation/CS1".
  • Script error: No such module "Citation/CS1".
  • Script error: No such module "citation/CS1".
  • Script error: No such module "citation/CS1".