Я хотел бы выполнить операцию свертки синусового сигнала и прямоугольного импульса в scipy. Я свернул синусоидальный сигнал с косинусным сигналом и изобразил это на графике, но я хотел бы знать, как создать массив с прямоугольным импульсом, что-то похожее на это выражение Matlab
y = rectpulse(x,nsamp)
так что я могу свернуть их. Я использую это, чтобы создать свой сигнал синуса и косинуса
x=r_[0:50] (my array)
y01=sin(2*pi*x/49)
y02=cos(2*pi*x/49)
Поэтому я попытался создать nu.zeros (50) и вручную изменить нули с позиции 15-25 с 0,0. до 0,9, так что это выглядит как прямоугольник, но свертка на массиве синуса, и этот массив «прямоугольник» странный. Предполагается, что он равен нулю, когда нет пересечения, но я получаю сигнал синуса взамен, вот код:
from scipy import *
from pylab import *
x = r_[0:50]
y1 = sin(2*pi*x/49)
#y2 = cos(2*pi*x/49)
y2 = np.zeros(50)
for i in range(15,25):
y2[i] = 0.9
#print len(y1),len(y2)
y3 = convolve(y2,y1,mode="same")
subplot(2,2,1)
plot(x,y1)
hold(True)
plot(x,y2)
hold(True)
subplot(2,2,2)
print len(x),len(y3)
plot(x,y3)
hold(True)
show()
Заранее извиняюсь, мне кажется, это самое простое, но я не смог найти ссылку на то, как создать прямоугольный импульс.