scipy.signal.

lp2bp_zpk#

scipy.signal.lp2bp_zpk(z, p, k, wo=1.0, bw=1.0)[源代码][源代码]#

将低通滤波器原型转换为带通滤波器。

返回一个中心频率为 wo 且带宽为 bw 的模拟带通滤波器,该滤波器基于具有单位截止频率的模拟低通滤波器原型,使用零点、极点和增益(’zpk’)表示。

参数:
zarray_like

模拟滤波器传递函数的零点。

parray_like

模拟滤波器传递函数的极点。

k浮动

模拟滤波器传递函数的系统增益。

浮动

期望的通带中心,以角频率表示(例如,弧度/秒)。默认为不改变。

bw浮动

期望的通带宽度,以角频率表示(例如,弧度/秒)。默认为1。

返回:
zndarray

变换后的带通滤波器传递函数的零点。

pndarray

变换后的带通滤波器传递函数的极点。

k浮动

变换后的带通滤波器的系统增益。

注释

这是从 s-平面替换派生出来的

\[s \rightarrow \frac{s^2 + {\omega_0}^2}{s \cdot \mathrm{BW}}\]

这是“宽带”变换,产生一个关于 wo 的几何(对数频率)对称通带。

Added in version 1.1.0.

示例

使用低通滤波器的 ‘zpk’(零极点增益)表示法将其转换为具有中心频率 wo 和带宽 bw 的带通滤波器。

>>> from scipy.signal import lp2bp_zpk
>>> z   = [ 5 + 2j ,  5 - 2j ]
>>> p   = [ 7      ,  -16    ]
>>> k   = 0.8
>>> wo  = 0.62
>>> bw  = 15
>>> lp2bp_zpk(z, p, k, wo, bw)
(   array([7.49955815e+01+3.00017676e+01j, 7.49955815e+01-3.00017676e+01j,
           4.41850748e-03-1.76761126e-03j, 4.41850748e-03+1.76761126e-03j]),
    array([1.04996339e+02+0.j, -1.60167736e-03+0.j,  3.66108003e-03+0.j,
           -2.39998398e+02+0.j]), 0.8)