forked from Mehran-k/SimplE
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtrainer_tester.py
executable file
·69 lines (56 loc) · 2.57 KB
/
trainer_tester.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
#Copyright (C) 2018 Seyed Mehran Kazemi, Licensed under the GPL V3; see: <https://www.gnu.org/licenses/gpl-3.0.en.html>
from TransE import *
from simplE_ignr import *
from complEx import *
from reader import *
from tensor_factorizer import *
from simplE_avg import *
from params import *
class TrainerTester:
def __init__(self, model_name, params, dataset):
instance_gen = globals()[model_name]
self.model = instance_gen(params=params, dataset=dataset)
self.model.setup_reader()
def train(self):
self.model.setup_weights()
self.model.setup_saver()
self.model.create_train_placeholders()
self.model.gather_train_embeddings()
self.model.create_train_model()
self.model.define_regularization()
self.model.create_optimizer()
self.model.create_session()
self.model.optimize()
self.model.close_session()
def test_model_on(self, itr, valid_or_test="test"):
tf.reset_default_graph()
self.model.setup_weights()
self.model.setup_loader()
self.model.create_test_placeholders()
self.model.gather_test_embeddings()
self.model.create_test_model()
self.model.create_session()
self.model.load_session(itr)
raw_mrr, raw_hit1, raw_hit3, raw_hit10, fil_mrr, fil_hit1, fil_hit3, fil_hit10 = self.model.test(self.model.reader.triples[valid_or_test])
print(raw_mrr, raw_hit1, raw_hit3, raw_hit10, fil_mrr, fil_hit1, fil_hit3, fil_hit10)
return fil_mrr
def early_stop(self):
best_mrr, best_itr = -1, "-1"
for itr in self.model.params.get_early_stopping_itrs():
print("Early Stop Iteration", itr)
fil_mrr = self.test_model_on(itr=itr, valid_or_test="valid")
if fil_mrr > best_mrr:
best_mrr, best_itr = fil_mrr, itr
self.model.close_session()
print("Best Iteration:", best_itr)
return best_itr, best_mrr
def test(self, itr):
self.test_model_on(itr=itr, valid_or_test="test")
self.model.close_session()
def train_earlystop_test(self):
print("Training " + self.model.model_name + " on " + self.model.dataset + " with emb_size = " + str(self.model.params.emb_size) + ", learning rate = " + str(self.model.params.learning_rate) + " neg_ratio = " + str(self.model.params.neg_ratio) + " alpha = " + str(self.model.params.alpha))
self.train()
print("Early stoppin for " + self.model.model_name + " on " + self.model.dataset + " with emb_size = " + str(self.model.params.emb_size) + ", itrs = ", self.model.params.get_early_stopping_itrs())
best_itr, _ = self.early_stop()
print("Testing " + self.model.model_name + " on " + self.model.dataset + " with emb_size = " + str(self.model.params.emb_size) + ", best itr = " + best_itr)
self.test(itr=best_itr)