Windowing Functions¶
This section describes the various windowing functions in the math
module.
These windowing functions are useful for spectral approximation as they
are compact in both the time and frequency domains.
See hamming(), Hamming window for more details.
Interfaces¶
hamming()
, Hamming window¶
The function hamming
computes the \(n^{th}\) of \(N\) indices of
the Hamming window:
data:image/s3,"s3://crabby-images/bfbf4/bfbf4b091c9f3cb37c06489ecb273dd90bcdfa90" alt="../_images/windowing-0.png"
Figure 19 Hamming window response¶
hann()
, Hann window¶
The function hann
computes the \(n^{th}\) of \(N\) indices of
the Hann window:
data:image/s3,"s3://crabby-images/80b6a/80b6a147f5bd4cf4c96c343dc6f8789db2a18072" alt="../_images/windowing-1.png"
Figure 20 Hann window response¶
blackmanharris()
, Blackman-harris window¶
The function blackmanharris
computes the \(n^{th}\) of \(N\)
indices of the Blackman-harris window:
where \(a_0 = 0.35875\), \(a_1 = -0.48829\), \(a_2 = 0.14128\), and \(a_3 = -0.01168\).
data:image/s3,"s3://crabby-images/bc658/bc658acee55a655f7d0838d4da2fe13207cf0d8c" alt="../_images/windowing-2.png"
Figure 21 Blackman-harris window response¶
blackmanharris7()
, 7th-order Blackman-harris Window¶
The function blackmanharris7
computes the \(n^{th}\) of \(N\)
indices of the 7:math:^{th}-order Blackman-harris window:
where \(a_0 = 0.27105\), \(a_1 = 0.43329\), \(a_2 = 0.21812\), \(a_3 = 0.06592\), \(a_4 = 0.01081\), \(a_5 = 0.00077\), and \(a_6 = 0.00001\).
Notice that the side-lobes have been suppressed below 100 dB at the expense of a wider main lobe.
data:image/s3,"s3://crabby-images/d93c6/d93c63c52f9538279e0effdd14a11c7aa295cffd" alt="../_images/windowing-3.png"
Figure 22 Blackman-harris (7) window response¶
flattop()
, Flat-top Window¶
The function flattop
computes the \(n^{th}\) of \(N\)
indices of the Flat-top window:
Notice that the response looks similar to a low-pass non-recursive [filter design][/doc/firdes/], allows the window to have negative values, and has a peak much greater than one.
data:image/s3,"s3://crabby-images/aed04/aed041e88781f789e1292111d0bd36fba0fb9e13" alt="../_images/windowing-4.png"
Figure 23 Flat top window response¶
triangular()
, Triangular window¶
The function triangular
computes the \(n^{th}\) of \(N\)
indices of the triangular window:
data:image/s3,"s3://crabby-images/cb0e1/cb0e1b9392fbd9ac663cd553f46d9d63474c9a41" alt="../_images/windowing-5.png"
Figure 24 Triangular window response¶
kaiser()
, Kaiser-Bessel window¶
The function kaiser
computes the \(n^{th}\) of \(N\)
indices of the Kaiser-\(\beta\) window with a shape parameter \(\beta\):
where \(I_\nu(z)\) is the modified Bessel function of the first kind of order \(\nu\), and \(\beta\) is a parameter controlling the width of the window and its stop-band attenuation. In liquid, \(I_0(z)\) is computed using liquid_besseli0f() (see [section-math-transcendentals]). A fractional sample offset \(\Delta t\) can be introduced by substituting \(\frac{n}{N/2}\) with \(\frac{n+\Delta t}{N/2}\) in [eqn-math-window-kaiser].
data:image/s3,"s3://crabby-images/ae28f/ae28f42ec3389e184ea3a6f746802709eeb640e1" alt="../_images/windowing-6.png"
Figure 25 Kaiser window response, \(\beta = 10\)¶
liquid_kbd_window()
, Kaiser-Bessel derived window¶
The function liquid_kbd_window
computes the \(n\)-point Kaiser-Bessel derived window with a shape
parameter \(\beta\) storing the result in the \(n\)-point array w.
The length of the window must be even.
data:image/s3,"s3://crabby-images/35926/35926140530e114971ca5e5c1a507f379c9906cf" alt="../_images/windowing-7.png"
Figure 26 Kaiser-Besssel derived window response, \(beta = 10\)¶
liquid_rcostaper_windowf()
, Raised-Cosine Tapering Window¶
The function liquid_rcostaper_windowf
computes the \(n^{th}\) of \(N\)
indices of the raised-cosine tapering window with t samples on the front
and tail used for tapering.
data:image/s3,"s3://crabby-images/29c0d/29c0dfc98cd1ec60bf214e59e775f6ed8532a913" alt="../_images/windowing-8.png"
Figure 27 Raised-Cosine taper window response¶