| 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.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
|
|
|