-
Notifications
You must be signed in to change notification settings - Fork 22
/
model_parameters.py
150 lines (128 loc) · 5.31 KB
/
model_parameters.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
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
import pickle
import model_constants as cons
class NetParams:
class Param:
def __init__(self):
self.size = 0
self.layer = 1
self.input = 0
self.margin = 0
def __init__(self):
self.note = self.Param()
self.onset = self.Param()
self.beat = self.Param()
self.measure = self.Param()
self.section = self.Param()
self.final = self.Param()
self.voice = self.Param()
self.sum = self.Param()
self.encoder = self.Param()
self.time_reg = self.Param()
self.margin = self.Param()
self.input_size = 0
self.output_size = 0
self.encoded_vector_size = 16
self.graph_iteration = 5
self.sequence_iteration = 5
self.num_edge_types = 10
self.num_attention_head = 8
self.is_graph = False
self.is_teacher_force = False
self.is_baseline = False
self.hierarchy_level = None
self.is_simplified = False
self.is_test_version = False
self.training_args = None
def save_parameters(param, save_name):
with open(save_name + ".dat", "wb") as f:
pickle.dump(param, f, protocol=2)
def load_parameters(file_name):
with open(file_name + ".dat", "rb") as f:
u = pickle._Unpickler(f)
net_params = u.load()
return net_params
def initialize_model_parameters_by_code(model_code):
net_param = NetParams()
net_param.input_size = cons.SCORE_INPUT
net_param.output_size = cons.NUM_PRIME_PARAM
if 'isgn' in model_code:
net_param.note.layer = 2
net_param.note.size = 128
net_param.measure.layer = 2
net_param.measure.size = 64
net_param.final.margin = 32
net_param.encoded_vector_size = 16
net_param.encoder.size = 128
net_param.encoder.layer = 2
net_param.time_reg.layer = 2
net_param.time_reg.size = 32
net_param.graph_iteration = 4
net_param.sequence_iteration = 3
net_param.final.input = (net_param.note.size + net_param.measure.size * 2) * 2
net_param.encoder.input = (net_param.note.size + net_param.measure.size * 2) * 2 \
+ cons.NUM_PRIME_PARAM
if 'sggnn_note' in model_code:
net_param.final.input += net_param.note.size
net_param.encoder.input += net_param.note.size
if 'baseline' in model_code:
net_param.is_baseline = True
elif 'han' in model_code:
net_param.note.layer = 2
net_param.note.size = 64
net_param.beat.layer = 2
net_param.beat.size = 64
net_param.measure.layer = 1
net_param.measure.size = 64
net_param.final.layer = 1
net_param.final.size = 64
net_param.voice.layer = 2
net_param.voice.size = 64
# net_param.num_attention_head = 1
net_param.encoded_vector_size = 16
net_param.encoder.size = 32
net_param.encoder.layer = 2
net_param.encoder.input = (net_param.note.size + net_param.beat.size +
net_param.measure.size + net_param.voice.size) * 2 \
+ cons.NUM_PRIME_PARAM
num_tempo_info = 3 # qpm primo, tempo primo
num_dynamic_info = 0
net_param.final.input = (net_param.note.size + net_param.voice.size + net_param.beat.size +
net_param.measure.size) * 2 + net_param.encoder.size + \
num_tempo_info + num_dynamic_info
if 'graph' in model_code:
net_param.is_graph = True
net_param.graph_iteration = 3
net_param.encoder.input = (net_param.note.size + net_param.beat.size +
net_param.measure.size) * 2 \
+ cons.NUM_PRIME_PARAM
net_param.final.input = (net_param.note.size + net_param.beat.size +
net_param.measure.size) * 2 + net_param.encoder.size + \
num_tempo_info + num_dynamic_info
if 'ar' in model_code:
net_param.final.input += net_param.output_size
if 'teacher' in model_code:
net_param.is_teacher_force = True
if 'baseline' in model_code:
net_param.is_baseline = True
net_param.encoder.input = net_param.note.size * 2 + cons.NUM_PRIME_PARAM
net_param.final.input = net_param.note.size * 2 + net_param.encoder.size + num_tempo_info + num_dynamic_info + net_param.output_size
elif 'trill' in model_code:
net_param.input_size = cons.SCORE_INPUT + cons.NUM_PRIME_PARAM
net_param.output_size = cons.num_trill_param
net_param.note.layer = 2
net_param.note.size = 32
else:
print('Unclassified model code')
if 'measure' in model_code:
net_param.hierarchy_level = 'measure'
net_param.output_size = 2
net_param.encoder.input += 2 - cons.NUM_PRIME_PARAM
elif 'beat' in model_code:
net_param.hierarchy_level = 'beat'
net_param.output_size = 2
net_param.encoder.input += 2 - cons.NUM_PRIME_PARAM
elif 'note' in model_code:
net_param.input_size += 2
if 'altv' in model_code:
net_param.is_test_version = True
return net_param