scipy.signal.

平方#

scipy.signal.square(t, duty=0.5)[源代码][源代码]#

返回一个周期性的方波波形。

方波的周期为 2*pi,在 0 到 2*pi*duty 之间值为 +1,在 2*pi*duty2*pi 之间值为 -1。duty 必须在区间 [0,1] 内。

请注意,这不是带限的。它会产生无限数量的谐波,这些谐波会在频谱上来回混叠。

参数:
tarray_like

输入的时间数组。

职责类似数组, 可选

占空比。默认值为0.5(50%占空比)。如果是一个数组,会导致波形随时间变化,并且必须与t的长度相同。

返回:
yndarray

输出包含方波的数组。

示例

一个以500 Hz采样频率采样1秒的5 Hz波形:

>>> import numpy as np
>>> from scipy import signal
>>> import matplotlib.pyplot as plt
>>> t = np.linspace(0, 1, 500, endpoint=False)
>>> plt.plot(t, signal.square(2 * np.pi * 5 * t))
>>> plt.ylim(-2, 2)

脉宽调制正弦波:

>>> plt.figure()
>>> sig = np.sin(2 * np.pi * t)
>>> pwm = signal.square(2 * np.pi * 30 * t, duty=(sig + 1)/2)
>>> plt.subplot(2, 1, 1)
>>> plt.plot(t, sig)
>>> plt.subplot(2, 1, 2)
>>> plt.plot(t, pwm)
>>> plt.ylim(-1.5, 1.5)
../../_images/scipy-signal-square-1_00.png
../../_images/scipy-signal-square-1_01.png