-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathalign_fill.pyx
82 lines (68 loc) · 3.05 KB
/
align_fill.pyx
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
import numpy as np
cimport numpy as np
def cython_fill_table(np.ndarray[np.float32_t, ndim=2] table, np.ndarray[np.float32_t, ndim=2] lpz, np.ndarray[np.int_t, ndim=2] ground_truth, np.ndarray[np.int_t, ndim=1] offsets, np.ndarray[np.int_t, ndim=1] utt_begin_indices, int blank, float argskip_prob):
cdef int c
cdef int t
cdef int offset = 0
cdef float mean_offset
cdef int offset_sum = 0
cdef int lower_offset
cdef int higher_offset
cdef float switch_prob, stay_prob, skip_prob
cdef float prob_max = -1000000000
cdef float lastMax
cdef int lastArgMax
cdef np.ndarray[np.int_t, ndim=1] cur_offset = np.zeros([ground_truth.shape[1]], np.int) - 1
cdef float max_lpz_prob
cdef float p
cdef int s
# Compute the mean offset between two window positions
mean_offset = (lpz.shape[0] - table.shape[0]) / float(table.shape[1])
print("Mean offset: " + str(mean_offset))
lower_offset = int(mean_offset)
higher_offset = lower_offset + 1
table[0, 0] = 0
for c in range(table.shape[1]):
if c > 0:
# Compute next window offset
offset = min(max(0, lastArgMax - table.shape[0] // 2), min(higher_offset, (lpz.shape[0] - table.shape[0]) - offset_sum))
# Compute relative offset to previous columns
for s in range(ground_truth.shape[1] - 1):
cur_offset[s + 1] = cur_offset[s] + offset
cur_offset[0] = offset
# Apply offset and move window one step further
offset_sum += offset
# Log offset
offsets[c] = offset_sum
lastArgMax = -1
lastMax = 0
# Go through all rows of the current column
for t in range((1 if c == 0 else 0), table.shape[0]):
# Compute max switch probability
switch_prob = prob_max
max_lpz_prob = prob_max
for s in range(ground_truth.shape[1]):
if ground_truth[c, s] != -1:
if t >= table.shape[0] - (cur_offset[s] - 1) or t - 1 + cur_offset[s] < 0 or c == 0:
p = prob_max
else:
p = table[t - 1 + cur_offset[s], c - (s + 1)] + lpz[t + offset_sum, ground_truth[c, s]]
switch_prob = max(switch_prob, p)
max_lpz_prob = max(max_lpz_prob, lpz[t + offset_sum, ground_truth[c, s]])
# Compute stay probability
if t - 1 < 0:
stay_prob = prob_max
elif c == 0:
stay_prob = 0
else:
stay_prob = table[t - 1, c] + max(lpz[t + offset_sum, blank], max_lpz_prob)
# Use max of stay and switch prob
table[t, c] = max(switch_prob, stay_prob)
# Remember the row with the max prob
if lastArgMax == -1 or lastMax < table[t, c]:
lastMax = table[t, c]
lastArgMax = t
# Return cell index with max prob in last column
c = table.shape[1] - 1
t = table[:, c].argmax()
return t, c