评价此页

torch.signal.windows.hann#

torch.signal.windows.hann(M, *, sym=True, dtype=None, layout=torch.strided, device=None, requires_grad=False)[source]#

计算汉宁窗。

汉宁窗定义如下:

wn=12 [1cos(2πnM1)]=sin2(πnM1)w_n = \frac{1}{2}\ \left[1 - \cos \left( \frac{2 \pi n}{M - 1} \right)\right] = \sin^2 \left( \frac{\pi n}{M - 1} \right)

窗被归一化为1(最大值为1)。但是,如果M为偶数且symTrue,则1不会出现。

参数

M (int) – 窗的长度。换句话说,是返回的窗的点数。

关键字参数
  • symbool, optional)—— 如果为False,则返回一个适用于频谱分析的周期性窗。如果为True,则返回一个适用于滤波器设计的对称窗。默认为True

  • dtype (torch.dtype, 可选) – 返回张量的期望数据类型。默认值:如果为 None,则使用全局默认值(请参阅 torch.set_default_dtype())。

  • layout (torch.layout, 可选) – 返回张量的期望布局。默认值:torch.strided

  • device (torch.device, 可选) – 返回张量的期望设备。默认值:如果为 None,则使用默认张量类型的当前设备(请参阅 torch.set_default_device())。对于 CPU 张量类型,device 将是 CPU;对于 CUDA 张量类型,device 将是当前的 CUDA 设备。

  • requires_grad (bool, 可选) – 如果 autograd 应该记录返回张量上的操作。默认值:False

返回类型

张量

示例

>>> # Generates a symmetric Hann window.
>>> torch.signal.windows.hann(10)
tensor([0.0000, 0.1170, 0.4132, 0.7500, 0.9698, 0.9698, 0.7500, 0.4132, 0.1170, 0.0000])

>>> # Generates a periodic Hann window.
>>> torch.signal.windows.hann(10, sym=False)
tensor([0.0000, 0.0955, 0.3455, 0.6545, 0.9045, 1.0000, 0.9045, 0.6545, 0.3455, 0.0955])