-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathval_word2vec_wmd.py
87 lines (67 loc) · 2.53 KB
/
val_word2vec_wmd.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
from sys import argv
from gensim.models import Word2Vec
from numpy import array, float32 as REAL,dot
import numpy as np
from gensim import utils, matutils # utility fnc for pickling, common scipy operations etc
dimensions = argv[1]
epoch = argv[2]
algo = int(argv[3])
test_file = file(argv[4])
algos = {0:"CBOW",1:"SG"}
#Word2Vec_model_algo1__dimensions_256_epoch_0.word2vec
if algo == 0:
model_filename = "/lustre/amar/Word2Vec_models/Word2Vec_model_algo0__dimensions_"+str(dimensions)+"_epoch_"+str(epoch)+".word2vec"
else:
model_filename = "/lustre/amar/Word2Vec_models/Word2Vec_model_algo1__dimensions_"+str(dimensions)+"_epoch_"+str(epoch)+".word2vec"
#model_filename = "Doc2Vec.model.doc2vec"
model = Word2Vec.load(model_filename)
print "Model Loaded"
slave_vectors = []
master_vectors = []
total_vectors = []
actual_labels = []
def infer_bug_vector(words):
result = array([0.0]*int(dimensions))
count = 0
for word in words:
if word in model:
result+= model[word]
count+=1
return result/count
for line in test_file:
try:
line = line.strip().split("\t")
slave = matutils.unitvec(array(infer_bug_vector(line[1].split(" ") + line[2].split(" ")))).astype(REAL)
master = matutils.unitvec(array(infer_bug_vector(line[5].split(" ") + line[6].split(" ")))).astype(REAL)
actual_labels.append(line[3])
actual_labels.append(line[3])
slave_vectors.append(slave)
total_vectors.append(slave)
total_vectors.append(master)
except IndexError:
print line
#master_vectors.append(model.infer_vector(line[4]))
print "$$$$$$$$$$$$$$$$$$$$$$$$$"
print "Vectors Formed"
slave_vectors,total_vectors = array(slave_vectors), array(total_vectors)
dists = dot(slave_vectors,total_vectors.T)
print "distances done"
prediction_file = open("prediction_doc2vec_dimensions: " + str(dimensions) + " algo: "+ algos[algo] + " epoch: " + str(epoch)+".csv","w+")
div = [1,5,10,20,40,60,80,100]
accuracy = [0.0]*len(div)
result_file = file("Results.txt","a+")
for i in xrange(len(dists)):
dist = dists[i]
best = matutils.argsort(dist, topn=100, reverse=True)
best = best[1:]
actual_label = actual_labels[i*2]
pred_labels = map(lambda x: int(actual_labels[x]),best)
prediction_file.write(str(actual_label)+"\t"+str(pred_labels)+"\n")
#div = [20,40,60,80,100]
for i in xrange(len(div)):
if int(actual_label) in pred_labels[:div[i]+1]:
accuracy[i]+=1
result = "dimensions: " + str(dimensions) + " algo: "+ algos[algo] + " epoch: " + str(epoch)+ " " + " " + str(accuracy)+ "\n"
result_file.write(result)
result_file.close()
prediction_file.close()