我遇到了我的代碼問題,這是Runge Kutta算法的數值求解諧振子的問題。不幸的是,我收到一個錯誤,說我不能通過類型爲float的非整型來乘序列。考慮到這些代碼幾乎完全來自教育文本,我看不出錯誤在哪裏。有人可以幫我嗎?感謝您友好的鄰居蜘蛛俠。爲什麼我收到我乘以非整型'float'的錯誤?
import numpy as np
import matplotlib.pyplot as plt
#Variable Definitions
N = 500
x0 = 1.0
v0 = 0.0
dur = 10.0
dt = dur/float(N-1)
#creating the array
y = np.zeros([N,2])
y[0,0] = x0
y[0,1] = v0
#runge kutta algorithm
def rk4(y, time, dt, deriv)
k1 = dt * deriv(y,time)
k2 = dt * deriv(y + 0.5*k1,time + 0.5*dt)
k3 = dt * deriv(y + 0.5*k2, time + 0.5*dt)
k4 = dt * deriv(y + k3, time + dt)
y_next = y + (k1 + 2*(k2+k3)+k4)/6
return y_next
#Harmonic oscillator
def Harmonic(x,time):
y0 = x[1]
y1 = (-1)*x[0]
return ([y0,y1])
#forming data points
for i in range(N-1):
y[i+1] = rk4(y[i],0, dt, Harmonic)
time = np.linspace(0, dur, N)
#plotting
plt.plot(time,y[:,1])
plt.show()
該錯誤是33行
類型錯誤:無法按類型「浮動」的非INT繁衍序列
哪條線沒有說發生在你的錯誤? – Loocid
'諧波'返回列表。當你將這些列表中的一個乘以浮點數時,你期望發生什麼? – user2357112
在問題中發佈你的實際異常(帶回溯),不要模糊地描述它。 – abarnert