[英]How to plot a deadband for a simple sine wave using python
我正在使用下面的代碼來繪制正弦波的死區,以便死區出現在 x 軸上為 y=0。 輸出通過上限[y-0.5]和下限的值最小化。這里需要顯示死區。任何人都可以幫我解決這個問題。
import matplotlib.pyplot as plt
import numpy as np
UpperLimit = 0.5;
LowerLimit = -0.5;
x=np.linspace(-20,20,100);
y=np.sin(x);
if y < 0:
y=np.sin(x)-LowerLimit
if y > 0:
y=np.sin(x)-UpperLimit
else:
y=0
plt.plot(x,y)
plt.grid()
plt.show()
我想你應該使用矢量化值,所以試試這個
import matplotlib.pyplot as plt
import numpy as np
LL = -0.5
UL = 0.5
x=np.linspace(-20,20,100)
y=np.sin(x)
# plot original sine
plt.plot(x,y)
# zero output value for the dead zone
y[(y>=LL) & (y<=UL)] = 0
y[y>UL] -= UL
y[y<LL] -= LL
# plot "simulinked" ....
plt.plot(x,y)
plt.grid()
plt.show()
您需要遍歷y
值數組並修改每個值,而不是讓if
語句作用於您的數組。 此外,使用y > 0
或y < 0
的if
語句將無法實現您正在尋找的死區結果。 相反,您應該使用y > UpperLimit
或y < LowerLimit
這應該有效:
import matplotlib.pyplot as plt
import numpy as np
UpperLimit = 0.5;
LowerLimit = -0.5;
x=np.linspace(-20,20,100);
y=np.sin(x);
for y_point in np.nditer(y, op_flags=['readwrite']):
if y_point > UpperLimit:
y_point[...] -= UpperLimit
elif y_point < LowerLimit:
y_point[...] -= LowerLimit
else:
y_point[...] = 0
plt.plot(x,y)
plt.grid()
plt.show()
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.