我编写了以下程序,用于绘制代码后显示的形状:
length = 100
a = 50
b = 0
n = 2
alpha = np.radians(25.)
d = 18
x_nose = np.linspace(0,a,50)
r_nose = (0.5*d*(1. - ((x_nose-a)/a)**2.)**(1./n))
x_mid = np.linspace(a,(a+b),2)
r_mid = (((d/2) * np.ones(2)))
x_tail = np.linspace((a+b),length,50)
l_tail = (length - a - b)
r_tail = (0.5*d - ((3*d)/(2*l_tail**2) - np.tan(alpha)/l_tail)*(x_tail-a-b)**2 + (d/l_tail**3 - np.tan(alpha)/l_tail**2)*(x_tail-a-b)**3)
line1 = plt.plot(x_nose,r_nose,'k',x_mid,r_mid,'k',x_tail,r_tail,'k')
line2 = plt.plot(x_nose,-r_nose,'k',x_mid,-r_mid,'k',x_tail,-r_tail,'k')
plt.axis('equal')
plt.setp([line1,line2], linewidth=2)
plt.show()
但是,length = 100
定义了用于计算形状的公式。
如何缩放变量length
的整个数字?
答案 0 :(得分:1)
您可以对您正在绘制的每个向量应用缩放因子,甚至是线性变换
ax = 0.1 ; bx = -5.0 ; fx = lambda x: ax*x+bx
plt.plot(fx(x_head), r_head, fx(x_mid), r_mid, fx(x_tail), r_tail)
...
在上面的示例中,我刚刚应用了缩放,以便x轴限制为[-5,5]并且我没有更改r
上的缩放,但您可以应用相同的缩放您可以根据需要缩放或不同的r
向量。
答案 1 :(得分:0)
您可以通过以下方式使用plt.xlim
:
plt.xlim(-a*length, b*length)
其中a
和b
是您选择的一些系数(即a
= 0,b
= 1)