-
Notifications
You must be signed in to change notification settings - Fork 33
/
Copy pathsimplE_ignr.py
executable file
·38 lines (30 loc) · 2.57 KB
/
simplE_ignr.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
#Copyright (C) 2018 Seyed Mehran Kazemi, Licensed under the GPL V3; see: <https://www.gnu.org/licenses/gpl-3.0.en.html>
from tensor_factorizer import *
from reader import *
class SimplE_ignr(TensorFactorizer):
def __init__(self, params, dataset="wn18"):
TensorFactorizer.__init__(self, model_name="SimplE_ignr", loss_function="likelihood", params=params, dataset=dataset)
def setup_weights(self):
sqrt_size = 6.0 / math.sqrt(self.params.emb_size)
self.rel_emb = tf.get_variable(name="rel_emb", initializer=tf.random_uniform(shape=[self.num_rel, self.params.emb_size], minval=-sqrt_size, maxval=sqrt_size, dtype=tf.float64))
self.rel_inv_emb = tf.get_variable(name="rel_inv_emb", initializer=tf.random_uniform(shape=[self.num_rel, self.params.emb_size], minval=-sqrt_size, maxval=sqrt_size, dtype=tf.float64))
self.ent_head_emb = tf.get_variable(name="ent_head_emb", initializer=tf.random_uniform(shape=[self.num_ent, self.params.emb_size], minval=-sqrt_size, maxval=sqrt_size, dtype=tf.float64))
self.ent_tail_emb = tf.get_variable(name="ent_tail_emb", initializer=tf.random_uniform(shape=[self.num_ent, self.params.emb_size], minval=-sqrt_size, maxval=sqrt_size, dtype=tf.float64))
self.var_list = [self.rel_emb, self.rel_inv_emb, self.ent_head_emb, self.ent_tail_emb]
def define_regularization(self):
self.regularizer = 2.0 * (tf.nn.l2_loss(self.ent_head_emb) + tf.nn.l2_loss(self.ent_tail_emb) + tf.nn.l2_loss(self.rel_emb) + tf.nn.l2_loss(self.rel_inv_emb)) / self.num_batch
def gather_train_embeddings(self):
self.h_emb = tf.concat( [tf.gather(self.ent_head_emb, self.head), tf.gather(self.ent_head_emb, self.tail)], 0 )
self.t_emb = tf.concat( [tf.gather(self.ent_tail_emb, self.tail), tf.gather(self.ent_tail_emb, self.head)], 0 )
self.r_emb = tf.concat( [tf.gather(self.rel_emb, self.rel), tf.gather(self.rel_inv_emb, self.rel)], 0 )
def gather_test_embeddings(self):
self.h_emb = tf.gather(self.ent_head_emb, self.head)
self.t_emb = tf.gather(self.ent_tail_emb, self.tail)
self.r_emb = tf.gather(self.rel_emb, self.rel)
def create_train_model(self):
self.init_scores = tf.reduce_sum(tf.multiply(tf.multiply(self.h_emb, self.r_emb), self.t_emb), 1)
self.scores = tf.clip_by_value(self.init_scores, -20, 20) #Without clipping, we run into NaN problems.
self.labels = tf.tile(self.y, [2])
def create_test_model(self):
self.init_scores = tf.reduce_sum(tf.multiply(tf.multiply(self.h_emb, self.r_emb), self.t_emb), 1)
self.dissims = -tf.clip_by_value(self.init_scores, -20, 20) #Without clipping, we run into NaN problems.