評價此頁

torch.signal.windows.kaiser#

torch.signal.windows.kaiser(M, *, beta=12.0, sym=True, dtype=None, layout=torch.strided, device=None, requires_grad=False)[原始碼]#

計算 Kaiser 視窗。

Kaiser 視窗定義如下:

wn=I0(β1(nN/2N/2)2)/I0(β)w_n = I_0 \left( \beta \sqrt{1 - \left( {\frac{n - N/2}{N/2}} \right) ^2 } \right) / I_0( \beta )

其中 I_0 是第一類零階修正貝塞爾函式(參見 torch.special.i0()),且 N = M - 1 if sym else M

該視窗被歸一化為 1(最大值為 1)。但如果 M 為偶數且 symTrue,則 1 不會出現。

引數

M (int) – 視窗的長度。換句話說,返回視窗的點數。

關鍵字引數
  • beta (float, optional) – 視窗的形狀引數。必須是非負的。預設值:12.0

  • sym (bool, optional) – 如果為 False,則返回適用於頻譜分析的週期視窗。如果為 True,則返回適用於濾波器設計的對稱視窗。預設值:True

  • dtype (torch.dtype, optional) – 返回張量的期望資料型別。預設值:如果 None,則使用全域性預設值(參見 torch.set_default_dtype())。

  • layout (torch.layout, 可選) – 返回張量的所需佈局。預設:torch.strided

  • device (torch.device, optional) – 返回張量的期望裝置。預設值:如果為 None,則使用預設張量型別的當前裝置(請參閱 torch.set_default_device())。對於 CPU 張量型別,device 將是 CPU,對於 CUDA 張量型別,將是當前 CUDA 裝置。

  • requires_grad (bool, optional) – 如果 autograd 應記錄在返回的張量上的操作。預設值:False

返回型別

張量

示例

>>> # Generates a symmetric gaussian window with a standard deviation of 1.0.
>>> torch.signal.windows.kaiser(5)
tensor([4.0065e-05, 2.1875e-03, 4.3937e-02, 3.2465e-01, 8.8250e-01, 8.8250e-01, 3.2465e-01, 4.3937e-02, 2.1875e-03, 4.0065e-05])
>>> # Generates a periodic gaussian window and standard deviation equal to 0.9.
>>> torch.signal.windows.kaiser(5, sym=False,std=0.9)
tensor([1.9858e-07, 5.1365e-05, 3.8659e-03, 8.4658e-02, 5.3941e-01, 1.0000e+00, 5.3941e-01, 8.4658e-02, 3.8659e-03, 5.1365e-05])