File size: 943 Bytes
2ae68b8
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
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