python - 运行时警告 : invalid value encountered in divide

标签 python python-2.7 matplotlib

我必须为“ Spring 中的球”模型使用欧拉方法编写程序

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

想不通,代码有什么问题?

最佳答案

我认为您的代码试图“除以零”或“除以 NaN”。如果您意识到这一点并且不想打扰您,那么您可以尝试:

import numpy as np
np.seterr(divide='ignore', invalid='ignore')

更多详情见:

关于python - 运行时警告 : invalid value encountered in divide,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14861891/

相关文章:

python - scipy 中的 Sobel 过滤器实现

python - 形容词 - 最高级和比较级

matplotlib - Seaborn 散点图矩阵 - 使用自定义样式添加额外的点

python - 如何将绘图添加到子图 matplotlib

python - 如何使用 matplotlib.animation 在 python 中对数据图进行动画处理

python - Pymongo 聚合管道

python - Tkinter : Getting screen text unit width.(不是像素)

python - 将 HISTFILE 设置为命名管道

python - python 中的映射函数在解包值时抛出错误

python - 无法安装触发网络自动化工具