当我认为我已定义它时,我的变量即将出现

时间:2016-04-24 19:47:55

标签: python

这是我的代码

#project starts here
import numpy as np
import scipy.integrate
import matplotlib.pyplot as plt
from numpy import pi
from scipy.integrate import odeint

def deriv(cond,t):
    for q in range (0,N):
        i=6*q
        dydt[i]=cond[i+3]
        dydt[i+1]=cond[i+4]
        dydt[i+2]=cond[i+5]
        r=sqrt((cond[i])**2 +(cond[i+1])**2 +(cond[i+2])**2)
        dydt[i+3]=-G*M*cond[i]/(r**3)
        dydt[i+4]=-G*M*cond[i+1]/(r**3)
        dydt[i+5]=-G*M*cond[i+2]/(r**3)
    return dydt

G=1
M=1
N=12
vmag=((G*M)/(2))**(0.5)
theta = np.linspace(0,2*pi,N)
x=2*np.cos(theta)
y=2*np.sin(theta)
vx=-vmag*np.sin(theta)
vy=vmag*np.cos(theta)
z=np.zeros(N)
vz=np.zeros(N)
t=np.linspace(0,30,100)

cond=list(item for group in zip(x,y,z,vx,vy,vz) for item in group)
sln=odeint(deriv, cond, t, args=(G,M))

我收到有关未定义dydt的错误消息。我以为我已经在我的衍生函数中定义了它。我的目的是使它成为一个带有适当导数的向量(因此使用i)cond数组。为什么我的定义错了?

1 个答案:

答案 0 :(得分:0)

“dydt”未定义,您应该先定义它,然后才能使用索引。

关于您的代码,您可以执行以下操作:

i = 6*q
dydt = list(range(i))