前提・実現したいこと
if文を使った関数を1つにし、変数を処理し、グラフを2つ表示したいです。
結果としては添付の画像の様にしたいです。
該当のソースコード
Python
1import matplotlib.pyplot as plt 2 3a = 1200 4b = 1800 5L = 3000 6 7print("E") 8E = input() 9E = int(E) 10 11print("I") 12I = input() 13I = int(I) 14 15print("P") 16P = input() 17P = int(P) 18 19print("E2") 20E2 = input() 21E2 = int(E2) 22 23print("I2") 24I2 = input() 25I2 = int(I2) 26 27print("P2") 28P2=input() 29P2=int(P2) 30 31def f(x_i) : 32 if x_i < a: 33 return (b * P) * (-x_i**3 + a * (a + 2 * b) * x_i) / (6 * E * I * L) 34 else: 35 return (a * P) / (6 * E * I * L) * (-(L - x_i)**3 + b * (2 * a + b) * (L - x_i)) 36 37def k(x_i) : 38 if x_i < a: 39 return (b * P2) * (-x_i**3 + a * (a + 2 * b) * x_i) / (6 * E2 * I2 * L) 40 else: 41 return (a * P2) / (6 * E2 * I2 * L) * (-(L - x_i)**3 + b * (2 * a + b) * (L - x_i)) 42 43x = list(range(L)) 44y=list(map(f,x)) 45y2=list(map(k,x)) 46 47plt.grid(which="major", color="gray", linestyle="-") 48plt.xlim(0, L) 49plt.ylim(min(y), max(y) + 0.5) 50 51 52 53plt.plot(x, y, label = "label-A") 54plt.plot(x,y2, label = "label-B") 55plt.xlabel("x[mm]") 56plt.ylabel("y[mm]") 57plt.legend(loc = 'lower right') 58plt.show()
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/12/10 04:31
2020/12/10 05:16 編集
2020/12/10 08:10
2020/12/10 09:21
2020/12/10 09:38
2020/12/10 10:19
2020/12/10 10:27 編集
2020/12/10 10:32
2020/12/10 10:54 編集
2020/12/10 11:03 編集