import numba | |
def maximum_path_jit(paths, values, t_ys, t_xs): | |
b = paths.shape[0] | |
max_neg_val = -1e9 | |
for i in range(int(b)): | |
path = paths[i] | |
value = values[i] | |
t_y = t_ys[i] | |
t_x = t_xs[i] | |
v_prev = v_cur = 0.0 | |
index = t_x - 1 | |
for y in range(t_y): | |
for x in range(max(0, t_x + y - t_y), min(t_x, y + 1)): | |
if x == y: | |
v_cur = max_neg_val | |
else: | |
v_cur = value[y - 1, x] | |
if x == 0: | |
if y == 0: | |
v_prev = 0.0 | |
else: | |
v_prev = max_neg_val | |
else: | |
v_prev = value[y - 1, x - 1] | |
value[y, x] += max(v_prev, v_cur) | |
for y in range(t_y - 1, -1, -1): | |
path[y, index] = 1 | |
if index != 0 and ( | |
index == y or value[y - 1, index] < value[y - 1, index - 1] | |
): | |
index = index - 1 | |