RuntimeWarning:在divide中遇到无效值

Bog*_*yka 66 python matplotlib python-2.7

我必须使用Euler的方法制作一个程序,用于"春天的球"模型

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()
Run Code Online (Sandbox Code Playgroud)

我一直收到这个错误:

a=-g+km*cos(tt)*(rr-L0)*r[i,:]/rr
RuntimeWarning: invalid value encountered in divide
Run Code Online (Sandbox Code Playgroud)

我无法弄明白,代码有什么问题?

Yan*_*Zhu 117

我认为你的代码试图"除以零"或"除以NaN".如果您知道这一点并且不想让它打扰您,那么您可以尝试:

import numpy as np
np.seterr(divide='ignore', invalid='ignore')
Run Code Online (Sandbox Code Playgroud)

有关更多详情,请参阅

  • 使用`with NP.errstate(divide ='ignore',invalid ='ignore')可能很有用:``如果你想抑制代码块的警告. (55认同)
  • 为什么要忽略零或NaN除法? (5认同)
  • @xsquared当您在划分后自己正确处理了值,并且您正在将代码分发给用户(或者厌倦了看到警告).`使用np.errstate(...)`可以让你安全地执行此操作. (5认同)
  • @reve_etrange 我发现这比通常忽略除以零更容易接受。 (3认同)
  • 最好将此_before_设置为导致错误的行,然后_after_通过命令`np.seterr(divide='warn', invalid='warn')`将该行重置为`'warn'`的正常状态 (2认同)

qrt*_*tLs 14

为了防止被零除,您可以预先初始化发生 div0 错误的输出“out”,例如 np.where不切断它,因为无论条件如何,都会评估完整的行。

预初始化示例:

a = np.arange(10).reshape(2,5)
a[1,3] = 0
print(a)    #[[0 1 2 3 4], [5 6 7 0 9]]
a[0]/a[1]   # errors at 3/0
out = np.ones( (5) )  #preinit
np.divide(a[0],a[1], out=out, where=a[1]!=0) #only divide nonzeros else 1
Run Code Online (Sandbox Code Playgroud)


小智 12

Python索引从0(而不是1)开始,因此您的赋值"r [1,:] = r0"定义r的第二个(即索引1)元素,并将第一个(索引0)元素保留为一对零.你的for循环中i的第一个值是0,所以rr得到r中第一个条目的点积的平方根(它是0),并且后续行中rr的除法会抛出错误.