forked from wangzhegeek/EGES
-
Notifications
You must be signed in to change notification settings - Fork 2
/
utils.py
105 lines (87 loc) · 3.24 KB
/
utils.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
import numpy as np
import matplotlib.pyplot as plt
from sklearn.manifold import TSNE
def plot_embeddings(embebed_mat, side_info_mat):
model = TSNE(n_components=2)
node_pos = model.fit_transform(embebed_mat)
brand_color_idx, shop_color_idx, cate_color_idx = {}, {}, {}
for i in range(len(node_pos)):
brand_color_idx.setdefault(side_info_mat[i, 1], [])
brand_color_idx[side_info_mat[i, 1]].append(i)
shop_color_idx.setdefault(side_info_mat[i, 2], [])
shop_color_idx[side_info_mat[i, 2]].append(i)
cate_color_idx.setdefault(side_info_mat[i, 3], [])
cate_color_idx[side_info_mat[i, 3]].append(i)
plt.figure()
for c, idx in brand_color_idx.items():
plt.scatter(node_pos[idx, 0], node_pos[idx, 1], label=c) # c=node_colors)
plt.title('brand distribution')
plt.savefig('./data_cache/brand_dist.png')
plt.figure()
for c, idx in shop_color_idx.items():
plt.scatter(node_pos[idx, 0], node_pos[idx, 1], label=c) # c=node_colors)
plt.title('shop distribution')
plt.savefig('./data_cache/shop_dist.png')
plt.figure()
for c, idx in cate_color_idx.items():
plt.scatter(node_pos[idx, 0], node_pos[idx, 1], label=c) # c=node_colors)
plt.title('cate distribution')
plt.savefig('./data_cache/cate_dist.png')
def write_embedding(embedding_result, outputFileName):
f = open(outputFileName, 'w')
for i in range(len(embedding_result)):
s = " ".join(str(f) for f in embedding_result[i].tolist())
f.write(s + "\n")
f.close()
def graph_context_batch_iter(all_pairs, batch_size, side_info, num_features):
while True:
start_idx = np.random.randint(0, len(all_pairs) - batch_size)
batch_idx = np.array(range(start_idx, start_idx + batch_size))
batch_idx = np.random.permutation(batch_idx)
batch = np.zeros((batch_size, num_features), dtype=np.int32)
labels = np.zeros((batch_size, 1), dtype=np.int32)
batch[:] = side_info[all_pairs[batch_idx, 0]]
labels[:, 0] = all_pairs[batch_idx, 1]
yield batch, labels
def preprocess_nxgraph(graph):
node2idx = {}
idx2node = []
node_size = 0
for node in graph.nodes():
node2idx[node] = node_size
idx2node.append(node)
node_size += 1
return idx2node, node2idx
def partition_dict(vertices, workers):
batch_size = (len(vertices) - 1) // workers + 1
part_list = []
part = []
count = 0
for v1, nbs in vertices.items():
part.append((v1, nbs))
count += 1
if count % batch_size == 0:
part_list.append(part)
part = []
if len(part) > 0:
part_list.append(part)
return part_list
def partition_list(vertices, workers):
batch_size = (len(vertices) - 1) // workers + 1
part_list = []
part = []
count = 0
for v1, nbs in enumerate(vertices):
part.append((v1, nbs))
count += 1
if count % batch_size == 0:
part_list.append(part)
part = []
if len(part) > 0:
part_list.append(part)
return part_list
def partition_num(num, workers):
if num % workers == 0:
return [num//workers]*workers
else:
return [num//workers]*workers + [num % workers]