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 37 if x_i < a: 38 return (b * P2) * (-x_i**3 + a * (a + 2 * b) * x_i) / (6 * E2 * I2 * L) 39 else: 40 return (a * P2) / (6 * E2 * I2 * L) * (-(L - x_i)**3 + b * (2 * a + b) * (L - x_i)) 41 42x = list(range(L)) 43y=list(map(f,x)) 44y2=list(map(f,x)) 45 46plt.grid(which="major", color="gray", linestyle="-") 47plt.xlim(0, L) 48plt.ylim(min(y) - 1, max(y) + 1) 49 50 51 52plt.plot(x, y, label = "label-A") 53plt.plot(x,y2, label = "label-B") 54plt.legend(loc = 'lower right') 55plt.show() 56```### 前提・実現したいこと 57 58for文をmap文にして繰り返しをおこないたい 59 60 61### 該当のソースコード 62 63```Python 64import matplotlib.pyplot as plt 65 66a = 1200 67b = 1800 68L = 3000 69 70print("E") 71E = input() 72E = int(E) 73 74print("I") 75I = input() 76I = int(I) 77 78print("P") 79P = input() 80P = int(P) 81 82print("E2") 83E2 = input() 84E2 = int(E2) 85 86print("I2") 87I2 = input() 88I2 = int(I2) 89 90print("P2") 91P2=input() 92P2=int(P2) 93 94 95x = list(range(L)) 96y = [(b * P) * (-x_i**3 + a * (a + 2 * b) * x_i) / (6 * E * I * L) 97 if x_i < a else (a * P) / (6 * E * I * L) * (-(L - x_i)**3 + b * (2 * a + b) * (L - x_i)) for x_i in x] 98 99y2 = [(b * P2) * (-x_i**3 + a * (a + 2 * b) * x_i) / (6 * E2 * I2 * L) 100 if x_i < a else (a * P2) / (6 * E2 * I2 * L) * (-(L - x_i)**3 + b * (2 * a + b) * (L - x_i)) for x_i in x] 101 102plt.grid(which="major", color="gray", linestyle="-") 103plt.xlim(0, L) 104plt.ylim(min(y) - 1, max(y) + 1) 105 106 107 108plt.plot(x, y, label = "label-A") 109plt.plot(x,y2, label = "label-B") 110plt.legend(loc = 'lower right') 111plt.show()
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/12/09 09:16
2020/12/09 09:18
2020/12/09 09:22
2020/12/09 09:25
2020/12/09 09:28