-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathprep_vocab.py
74 lines (65 loc) · 2.07 KB
/
prep_vocab.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
from source.datasets import Vocabulary
import argparse
import json
parser = argparse.ArgumentParser(description='Prepare vocabularies for model')
parser.add_argument(
'--defs', type=str, required=True, nargs="+",
help='location of json file with definitions.'
)
parser.add_argument(
"--lm", type=str, required=False, nargs="+",
help="location of txt file with text for LM pre-training"
)
parser.add_argument(
'--same', dest='same', action='store_true',
help="use same vocab for definitions and contexts"
)
parser.set_defaults(same=False)
parser.add_argument(
"--save", type=str, required=True,
help="where to save prepaired vocabulary (for words from definitions)"
)
parser.add_argument(
"--save_context", type=str, required=False,
help="where to save vocabulary (for words from contexts)"
)
parser.add_argument(
"--save_chars", type=str, required=True,
help="where to save char vocabulary (for chars from all words)"
)
args = parser.parse_args()
if not args.same and args.save_context is None:
parser.error("--save_context required if --same didn't used")
voc = Vocabulary()
char_voc = Vocabulary()
if not args.same:
context_voc = Vocabulary()
definitions = []
for f in args.defs:
with open(f, "r") as infile:
definitions.extend(json.load(infile))
if args.lm is not None:
lm_texts = ""
for f in args.lm:
lm_texts = lm_texts + open(f).read().lower() + " "
lm_texts = lm_texts.split()
for word in lm_texts:
voc.add_token(word)
for elem in definitions:
voc.add_token(elem[0][0])
char_voc.tok_maxlen = max(len(elem[0][0]), char_voc.tok_maxlen)
for c in elem[0][0]:
char_voc.add_token(c)
for i in range(len(elem[1])):
voc.add_token(elem[1][i])
if args.same:
for i in range(len(elem[2])):
voc.add_token(elem[2][i])
else:
context_voc.add_token(elem[0][0])
for i in range(len(elem[2])):
context_voc.add_token(elem[2][i])
voc.save(args.save)
char_voc.save(args.save_chars)
if not args.same:
context_voc.save(args.save_context)