import numpy as np
import matplotlib.pyplot as plt 
import math  
plt.figure(figsize=(8,4))
x = np.arange(2,12.1,1)
y = -0.3*x+6.6
cos = (x**2+y**2)/162-1
theta2_rad = [math.acos(s) for s in cos]
theta2=[ x*180/3.14  for x in theta2_rad]
#print(theta2)
#求 theta2
#在接下来的的程序里,例如反三角函数 用到的theta2值是弧度制的,所以要进行转换
theta2_rad = [math.acos(s) for s in cos]
cos1 =  np.array([math.cos(s)+1 for s in theta2_rad])
sin1 =  np.array([math.sin(s) for s in theta2_rad])
cos2 =  np.array([18*(math.cos(s)+1) for s in theta2_rad])
y1   =  np.array(y)
x1   =  np.array(x)
sin  =  (y1*cos1-sin1*x1)/cos2
sin  =  list(sin)
theta1= [(math.asin(s))*180/3.14  for s in sin]
print(theta1)
#画图
t = np.arange(1,12,1)
theta1 =np.array(theta1)
theta2 =np.array(theta2)
plt.plot(t,theta1,label="$theta1$",color="red",linewidth=2)
plt.plot(t,theta2,label="$theta2$",color="blue",linewidth=2)
plt.ylim(-50,150)
plt.xlim(-1,12)
plt.xlabel("划分的段数")
plt.ylabel("角度")
plt.legend(loc="upper left")
plt.grid(True)
plt.show()

  

 

 生成的图像:

 

posted on 2018-02-28 11:41  魂淡林  阅读(121)  评论(0编辑  收藏  举报