遇到我使用欧拉方法为“在春天的球”,以使程序模型RuntimeWarning:无效的价值鸿沟
from pylab import*
from math import*
m=0.1
Lo=1
tt=30
k=200
t=20
g=9.81
dt=0.01
n=int((ceil(t/dt)))
km=k/m
r0=[-5,5*sqrt(3)]
v0=[-5,5*sqrt(3)]
a=zeros((n,2))
r=zeros((n,2))
v=zeros((n,2))
t=zeros((n,2))
r[1,:]=r0
v[1,:]=v0
for i in range(n-1):
rr=dot(r[i,:],r[i,:])**0.5
a=-g+km*cos(tt)*(rr-L0)*r[i,:]/rr
v[i+1,:]=v[i,:]+a*dt
r[i+1,:]=r[i,:]+v[i+1,:]*dt
t[i+1]=t[i]+dt
#print norm(r[i,:])
plot(r[:,0],r[:,1])
xlim(-100,100)
ylim(-100,100)
xlabel('x [m]')
ylabel('y [m]')
show()
我不断收到此错误:
a=-g+km*cos(tt)*(rr-L0)*r[i,:]/rr
RuntimeWarning: invalid value encountered in divide
我可以不知道,代码有什么问题?
打印该行代码中每个较小项目中正在发生的事情。这是调试它的唯一方法。 – CppLearner 2013-02-13 20:11:55
你有'nan's'rr',它抛出了那个错误。 'rr'的问题来源于'r [i,:]',在某些情况下,它等于'array([nan,nan])'。正如@CppLearner提到的那样,调试(或编写)代码的最好方法是在实现之前测试每个较小的部分。 – cosmosis 2013-02-13 20:20:25