TypeError: у объекта 'float' нет атрибута '__getitem__' Python NBody Simulation
Я хочу сделать N-Body
моделирование с использованием Hermite Algorithm
, но когда я пишу этот код, я получаю сообщение об ошибке:
TypeError: 'float' object has no attribute '__getitem__'
и я понятия не имею, почему это происходит, потому что мой объект в списке не является плавающим.
dt = input('dt = ')
t_end = input('t_end = ')
n = input('n= ')
t = input('t= ')
m = np.zeros(n)
r = np.zeros((n, 3))
rji = np.zeros((3))
vji = np.zeros((3))
v = np.zeros((n, 3))
a = np.zeros((n, 3))
jk = np.zeros((n, 3))
for i in range (0,n,1):
m[i] = 2
for k in range (0,3,1):
r[i,k] = 2+i
for k in range (0,3,1):
v[i,k] = 1+i
print ('m'),m,r,v
for i in range (0,n,1):
for k in range (0,3,1):
a[i,k] = jk[i,k] = 0.0
for i in range (0,n,1):
for j in range (i+1,n,1):
for k in range (0,3,1):
rji[k] = r[j,k] - r[i,k]
vji[k] = v[j,k] - v[i,k]
r2 = 0.
for k in range (0,3,1):
r2 += rji[k] * rji[k]
r3 = r2 * math.sqrt(r2)
rv = 0.
for k in range (0,3,1):
rv += rji[k] * vji[k]
rv /= r2
for k in range (0,3,1):
a[i,k] += m[j] * rji[k] / r3;
a[j,k] -= m[i] * rji[k] / r3;
jk[i,k] += m[j] * (vji[k] - 3 * rv * rji[k]) / r3;
jk[j,k] -= m[i] * (vji[k] - 3 * rv * rji[k]) / r3;
ekin = 0.
epot = 0.
for i in range (0,n,1):
for j in range (i+1,n,1):
for k in range (0,3,1):
rji[k] = r[j,k] - r[i,k] #the error coming from this line
r2=0.
for k in range (0,3,1):
r2 += rji[k] * rji[k]
print rji
r = math.sqrt(r2)
epot -= m[i] * m[j] / r
for k in range (0,3,1):
ekin += 0.5 * m[i] * v[i,k] *v[i,k]
e_in = ekin + epot
print('Initial total energy E_in = '), e_in
1 ответ
Я не уверен, является ли это источником ошибки, которую вы видите, но вам не хватает имени переменной в этой строке (последняя строка всех циклов):
ekin += 0.5 * m[i] * v[i][k] *[i][k]
Которые должны быть
ekin += 0.5 * m[i] * v[i][k] * v[i][k]
Комментарий к вашему коду: вы используете двумерные массивы, так что вы можете индексировать их, например, как v[i,k]
вместо v[i][k]
, Эта запись намного эффективнее, и ее легче читать.