-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathPart4.py
133 lines (107 loc) · 4.47 KB
/
Part4.py
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
import pprint, pickle, components
from components import *
pp = pprint.PrettyPrinter(indent=5)
transition_dict = {}
emission_dict = {}
observed_sequences_dict = {}
viterbi_dict = {}
top=5
####load parameters
for language in components.files:
emission = pickle.load(open("params/emission/" + language + ".txt", "rb"))
emission_dict[language] = emission
transition = pickle.load(open("params/transition/" + language + ".txt", "rb"))
transition_dict[language] = transition
def top_k_viterbi(k, observed_sequence, states, a_dict, b_dict):
pure_state = states[1:len(states) - 1]
n = len(observed_sequence)
###initializing path_dict
buffer = Buffer(k)
buffer.push(1.0, "NA", -1)
path_dict = {0: {"start": buffer}}
for i in range(n):
path_dict[i + 1] = {}
for layer in path_dict:
if layer == 0: continue
for state in pure_state:
path_dict[layer][state] = Buffer(k)
path_dict[n + 1] = {"stop": Buffer(k)}
for layer in path_dict:
if layer == 0: continue
if layer == n + 1:
for previous_state in path_dict[layer - 1]:
for k_th in range(k):
p = path_dict[layer - 1][previous_state].getP(k_th) * \
a_dict[previous_state]["stop"]
path_dict[layer]["stop"].push(p, previous_state, k_th)
continue
for current_state in path_dict[layer]:
for previous_state in path_dict[layer - 1]:
for k_th in range(k):
if current_state in b_dict[observed_sequence[layer - 1]]:
p = path_dict[layer - 1][previous_state].getP(k_th) * \
a_dict[previous_state][current_state] * \
b_dict[observed_sequence[layer - 1]][current_state]
else:
p = path_dict[layer - 1][previous_state].getP(k_th) * \
a_dict[previous_state][current_state] * \
0.0000001
path_dict[layer][current_state].push(p, previous_state, k_th)
# # path_dict printing
# for layer in path_dict:
# print("Layer: " + str(layer))
# for state in path_dict[layer]:
# print(" state: " + state)
# for k_th in range(k):
# print(" k_th: " + str(k_th), path_dict[layer][state].getBuffer()[k_th])
# backtracking
current_layer = n
from_k_th = top-1
path_reverse = ["stop"]
while current_layer >= 0:
while path_dict[current_layer + 1][path_reverse[len(path_reverse) - 1]].getBuffer()[from_k_th]['previous_state']== "NA":
from_k_th-=1
path_reverse.append(path_dict[current_layer + 1]
[path_reverse[len(path_reverse) - 1]].getBuffer()
[from_k_th]
['previous_state'])
from_k_th=path_dict[current_layer + 1][path_reverse[len(path_reverse) - 2]].getBuffer()[from_k_th]['from_k_th']
current_layer -= 1
return path_reverse[::-1][1:len(path_reverse) - 1]
for language in components.files:
file = open("raw/" + language + "/dev.in", encoding='utf8')
rawinput = file.readlines()
observed_sequences = [[]]
index = 0
for input in rawinput:
if input == "\n":
observed_sequences.append([])
index += 1
else:
observed_sequences[index].append(input.strip('\n'))
observed_sequences.pop()
states_viterbi = [[]]
index = 0
for observed_sequence in observed_sequences:
for state in top_k_viterbi(top,observed_sequence, components.states, transition_dict[language], emission_dict[language]):
states_viterbi[index].append(state)
states_viterbi.append([])
index += 1
states_viterbi.pop()
viterbi_dict[language] = states_viterbi
observed_sequences_dict[language] = observed_sequences
###write to file
for language in components.files:
msg = ""
for i in range(len(viterbi_dict[language])):
for j in range(len(viterbi_dict[language][i])):
msg += observed_sequences_dict[language][i][j]
msg += ' '
msg += viterbi_dict[language][i][j]
msg += '\n'
msg += '\n'
# print(msg)
result = open("result/" + language + "/dev.p4.out", "wb")
result.write(msg.encode("utf-8"))
result.close()
print("result/" + language + "/dev.p4.out saved!")