import torch
import numpy as np

L = np.array([[1e10,1,2,2.3,10],[1e10,1e10,2,2.3,2],[1e10,1e10,1e10,2.3,1],[1e10,1e10,1e10,1e10,6],[1e10,1e10,1e10,1e10,1e10]])
print(L)
# L(s,t): s -> t 
#L = L.T
T = L.shape[0]-1
#D = torch.ones(size=(T+1,T+1))*torch.tensor(-1)
D = np.full([T+1,T+1], -1)
C = np.full([T+1,T+1], 1e10)
C[0,0] = 0
C[0,1:] = 1e10
for k in range(1,T+1):
    for t in range(1,T+1):
        C[k,t] = np.min(C[k-1,:]+L[:,t])
        D[k,t] = np.argmin(C[k-1,:]+L[:,t])
    #bpds = C[k-1,None]+L[:,:]
    #C[k] = np.min(bpds,axis=-1)
    #D[k] = np.argmin(bpds,axis=-1)
print(C)
print(D)
#C = torch.ones(size=(T+1,T+1))*torch.tensor(-1)
#print(torch.tensor(C))


