这个问题要求我们在python中使用从0到5的Rk4方法∫sinh()(−5)来解决这个积分。最好的方法是什么,你怎么把它变成一首颂歌呢?
def RK4(f, dx, x0, y0, imax):
output = np.empty((imax, 3))
i = 0
xi = x0
yi = y0
while(i < imax):
k1 = dx*f(xi,yi)
k2 = dx*f(xi + 0.5*dx, yi + 0.5*k1)
k3 = dx*f(xi + 0.5*dx, yi + 0.5*k2)
k4 = dx*f(xi + dx, yi + k3)
yi = yi + 1/6*(k1 + 2*k2 + 2*k3 + k4)
xi += dx
output[i, 0] = xi
output[i, 1] = yi[0]
output[i, 2] = yi[1]
i += 1
return output
RK4(0,0,5,100,10)我得到一个错误,对于k1 (“整型对象不可调用”)??我如何解决这个问题,或者问题出在我的代码中的其他地方。谢谢你的帮助。另外,这个问题明确要求我们使用辛普森规则和RK4方法来求解积分。
发布于 2020-03-31 14:05:41
您正在传递一个整数0来代替该函数。然后在k1行中,您尝试使用该整数作为函数,这会给出报告的错误,因为对0(0,5)没有合理的解释。你可以使用
RK4(lambda x,y:0,0,5,100,10)但是,如果步长为零,则不会发生积分。
https://stackoverflow.com/questions/60914465
复制相似问题