我正在尝试使用python的scipy.signal.remez函数设计等高通滤波器。但是,由此产生的传递函数对我来说很奇怪,通带中有〜15 db的峰值,而阻带衰减仅为6 dB。相应的低通设计看起来还不错(〜0.1 dB通带纹波和40 dB阻带衰减):
#!/usr/bin/env python
# -*- coding: iso-8859-15 -*-
# Minimum working example for remez (equiripple) filter designs:
from __future__ import division, print_function
import numpy as np
import scipy.signal as sig
import matplotlib.pyplot as plt
F_PB = 0.1 # corner frequency of pass band
F_SB = 0.15 # corner frequency of stop band
W_PB = 1 # weight factor for pass band
W_SB = 1 # weight factor for stop band
L = 40 # filter order
#b = sig.remez(L, [0, F_PB, F_SB, 0.5], [1, 0], [W_PB, W_SB], Hz = 1) # low pass
b = sig.remez(L, [0, F_PB, F_SB, 0.5], [0, 1], [W_PB, W_SB], Hz = 1) # high pass
# Calculate H(w), w = 0 ... pi, 1024 Pts.
[w, H] = sig.freqz(b, worN = 1024)
# Translate w to normalized frequencies F = 0 ... 0.5:
F = w / (2 * np.pi)
plt.figure(1)
plt.plot(F, 20 * np.log10(abs(H)))
plt.title(r'Magnitude transfer function in dB')
plt.show()
有人可以向我解释发生了什么吗?
基督徒,干杯
对于具有默认remez
参数的高通滤波器type='bandpass'
,请使用奇数个抽头。用偶数的抽头remez
创建II型滤波器,该滤波器的奈奎斯特频率为零。该算法很难创建具有这种约束的高通滤波器。
这是以下情况下的增益图L = 41
:
或使用偶数的水龙头,然后按type='hilbert'
。下面显示了L=40
和获得的结果type='hilbert'
:
但是请注意,这种情况下FIR滤波器为IV型-滤波器系数具有奇对称性。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句