scipy.signal.

firwin2#

scipy.signal.firwin2(numtaps, freq, gain, *, nfreqs=None, window='hamming', antisymmetric=False, fs=None)[源代码]#

使用窗口方法的 FIR 滤波器设计。

从给定的频率 freq 和对应的增益 gain,此函数构造一个具有线性相位且(近似)具有给定频率响应的 FIR 滤波器。

参数:
numtapsint

FIR 滤波器中的抽头数。numtaps 必须小于 nfreqs

freqarray_like,1-D

频率采样点。通常为 0.0 到 1.0,其中 1.0 为奈奎斯特频率。奈奎斯特频率是 fs 的一半。freq 中的值必须是非递减的。一个值可以重复一次以实现不连续性。freq 中的第一个值必须为 0,最后一个值必须为 fs/2。值 0 和 fs/2 不能重复。

gainarray_like

频率采样点处的滤波器增益。根据滤波器类型,对增益值应用某些约束,详情请参见“说明”。

nfreqsint,可选

用于构造滤波器的插值网格的大小。为了获得最有效的行为,这应该是一个 2 的幂加 1(例如,129、257 等)。默认值是大于或等于 numtaps 的最小 2 的幂加 1。nfreqs 必须大于 numtaps

window字符串或(字符串,浮点数)或浮点数,或 None,可选

要使用的窗口函数。默认为“hamming”。有关可能值的完整列表,请参见 scipy.signal.get_window。如果为 None,则不应用窗口函数。

antisymmetricbool,可选

结果脉冲响应是否为对称/反对称。有关更多详细信息,请参见“说明”。

fsfloat,可选

信号的采样频率。cutoff 中的每个频率都必须在 0 和 fs/2 之间。默认值为 2。

返回:
tapsndarray

FIR 滤波器的滤波器系数,作为长度为 numtaps 的 1-D 数组。

说明

从给定的频率和增益集,在频域中构造所需的响应。将逆 FFT 应用于所需的响应以创建相关的卷积核,并返回此内核的第一个 numtaps 系数,并按 window 缩放。

FIR 滤波器将具有线性相位。滤波器的类型由 'numtaps' 的值和 antisymmetric 标志确定。有四种可能的组合

  • 奇数 numtapsantisymmetric 为 False,生成 I 型滤波器

  • 偶数 numtapsantisymmetric 为 False,生成 II 型滤波器

  • 奇数 numtapsantisymmetric 为 True,生成 III 型滤波器

  • 偶数 numtapsantisymmetric 为 True,生成 IV 型滤波器

除 I 型滤波器外的所有滤波器的幅度响应都受以下约束

  • II 型 - 在奈奎斯特频率处为零

  • III 型 - 在零频率和奈奎斯特频率处为零

  • IV 型 - 在零频率处为零

在 0.9.0 版本中添加。

参考文献

[1]

Oppenheim, A. V. and Schafer, R. W., “Discrete-Time Signal Processing”, Prentice-Hall, Englewood Cliffs, New Jersey (1989). (例如,参见第 7.4 节。)

[2]

Smith, Steven W., “The Scientist and Engineer’s Guide to Digital Signal Processing”, Ch. 17. http://www.dspguide.com/ch17/1.htm

示例

一个低通 FIR 滤波器,其在 [0.0, 0.5] 上的响应为 1,并且在 [0.5, 1.0] 上从 1 线性减小到 0

>>> from scipy import signal
>>> taps = signal.firwin2(150, [0.0, 0.5, 1.0], [1.0, 1.0, 0.0])
>>> print(taps[72:78])
[-0.02286961 -0.06362756  0.57310236  0.57310236 -0.06362756 -0.02286961]