lp2bp_zpk#
- scipy.signal.lp2bp_zpk(z, p, k, wo=1.0, bw=1.0)[source]#
- Transform a lowpass filter prototype to a bandpass filter. - Return an analog band-pass filter with center frequency wo and bandwidth bw from an analog low-pass filter prototype with unity cutoff frequency, using zeros, poles, and gain (‘zpk’) representation. - Parameters:
- zarray_like
- Zeros of the analog filter transfer function. 
- parray_like
- Poles of the analog filter transfer function. 
- kfloat
- System gain of the analog filter transfer function. 
- wofloat
- Desired passband center, as angular frequency (e.g., rad/s). Defaults to no change. 
- bwfloat
- Desired passband width, as angular frequency (e.g., rad/s). Defaults to 1. 
 
- Returns:
- zndarray
- Zeros of the transformed band-pass filter transfer function. 
- pndarray
- Poles of the transformed band-pass filter transfer function. 
- kfloat
- System gain of the transformed band-pass filter. 
 
 - Notes - This is derived from the s-plane substitution \[s \rightarrow \frac{s^2 + {\omega_0}^2}{s \cdot \mathrm{BW}}\]- This is the “wideband” transformation, producing a passband with geometric (log frequency) symmetry about wo. - Added in version 1.1.0. - Examples - Use the ‘zpk’ (Zero-Pole-Gain) representation of a lowpass filter to transform it to a bandpass filter with a center frequency wo and bandwidth 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)