IndexError:索引3超出轴1的大小为3的范围

时间:2016-07-12 09:14:12

标签: python numpy

我想解决错误:

  

IndexError:索引3超出了轴1的大小为3的范围

from numpy import *
from pylab import *

def SIR2(I0, beta, gama, w, sigma, p, dt, tmax):
    N = int(tmax / dt) + 1  # nombre de pas de temps
    T = zeros([N + 1, 3])
    T[0, 0] = 1000000 - I0
    T[0, 1] = I0

    for i in range(N + 1):
        T[i + 1, 0] = T[i, 0] - dt * (beta * T[i, 0] * T[i, 1] + p * T[i, 0] - w * T[i, 2])
        T[i + 1, 1] = T[i, 1] + dt * T[i, 1] * (beta * T[i, 0] - gama - sigma)
        T[i + 1, 2] = T[i, 2] + dt * (gama * T[i, 1] + p * T[i, 0] + w * T[i, 2])
        T[i + 1, 3] = sigma * T[i, 1] * dt + T[i, 3]

    return T

beta = 1 / 3000000
gama = 1 / 20

I0 = 10
p = 0
sigma = 5 / 1000
w = 0
dt = 0.05
tmax = 150
T = SIR2(I0, beta, gama, w, sigma, p, dt, tmax)

N = int(tmax / dt) + 1
X = zeros(N + 1)

for i in range(N + 1):
    X[i] = i * dt

plot(X, T[:, 0])
plot(X, T[:, 1])
plot(X, T[:, 2])
plot(X, T[:, 3])

show()

1 个答案:

答案 0 :(得分:1)

numpy中的数组索引从0开始。因此,第二个轴为3的数组将可订阅,最大索引为2.

因此以下内容不适用于T[:,3]

T=zeros([N+1,3])

如果您打算在0,1,2和3上进行索引,那么您应该考虑增加数组的大小,例如:

T=zeros([N+1,4])
#            ^ subscriptable up to 3