import numba @numba.jit(numba.void(numba.int32[:, :, ::1], numba.float32[:, :, ::1], numba.int32[::1], numba.int32[::1]), nopython=True, nogil=True) 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. 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