Итак, я пытаюсь создать 3D-массив с некоторыми стандартными значениями, определенными мной (на самом деле другими людьми, но это не имеет значения)
Это мой код:
Tt = 120 # Total duration (sec)
delta = 0.001 # Time bin (sec)
T = Tt/delta # number of time bins
Ncells = 8;
Cmap = np.zeros([Ncells,Ncells,int(T)])
ExcInhID = np.expand_dims([1, -1, 1, -1, 1, -1, 1], axis =1)
a = list(range(0,int(T)))
for t in a:
Cmap[:,:,t] = (-1)*np.identity(Ncells)
Cmap[1:,0,t] = list(ExcInhID*np.ones([Ncells-1,1])*(1 - min(max(t-T/3,0)*(1/(T/3)),0)))
CC5 = list(np.arange(0,Ncells)) ; del CC5[4];
Cmap[CC5,4,t] = list(ExcInhID*np.ones([Ncells-1,1])*(min(max(t-T/3,0)*(1/(T/3)),0)))
Cmap[6,2,t] = 1; Cmap[5,7,t] = -1; Cmap[1,5,t] = 1;
Это работает до
Cmap[CC5,4,t] = list(ExcInhID*np.ones([Ncells-1,1])*(min(max(t-T/3,0)*(1/(T/3)),0))) Cmap[CC5,4,t] = list(ExcInhID*np.ones([Ncells-1,1])*(min(max(t-T/3,0)*(1/(T/3)),0)))
Где я получаю ошибку:
ValueError: несоответствие формы: массив значений формы (7,1) не может быть
трансляция для индексации результата формы (7,)
Что странно, поскольку он работал с другой строкой здесь:
Cmap[1:,0,t] = list(ExcInhID*np.ones([Ncells-1,1])*(1 - min(max(t-T/3,0)*(1/(T/3)),0)))
Я перепробовал все и больше не знаю, что делать ..
У кого-нибудь из вас есть предложения?