graphsage-tf/eval_scripts/reddit_eval.py

106 lines
4.7 KiB
Python
Raw Permalink Normal View History

2017-05-31 01:53:15 +08:00
from __future__ import print_function
import json
import numpy as np
from networkx.readwrite import json_graph
from argparse import ArgumentParser
def run_regression(train_embeds, train_labels, test_embeds, test_labels):
np.random.seed(1)
from sklearn.linear_model import SGDClassifier
from sklearn.dummy import DummyClassifier
from sklearn.metrics import f1_score
dummy = DummyClassifier()
dummy.fit(train_embeds, train_labels)
log = SGDClassifier(loss="log", n_jobs=55)
2017-05-31 01:53:15 +08:00
log.fit(train_embeds, train_labels)
print("Test scores")
print(f1_score(test_labels, log.predict(test_embeds), average="micro"))
print("Train scores")
print(f1_score(train_labels, log.predict(train_embeds), average="micro"))
print("Random baseline")
print(f1_score(test_labels, dummy.predict(test_embeds), average="micro"))
if __name__ == '__main__':
parser = ArgumentParser("Run evaluation on Reddit data.")
parser.add_argument("dataset_dir", help="Path to directory containing the dataset.")
2017-10-13 05:15:21 +08:00
parser.add_argument("embed_dir", help="Path to directory containing the learned node embeddings. Set to 'feat' for raw features.")
parser.add_argument("setting", help="Either val or test.")
2017-05-31 01:53:15 +08:00
args = parser.parse_args()
dataset_dir = args.dataset_dir
2017-10-13 05:15:21 +08:00
data_dir = args.embed_dir
2017-05-31 01:53:15 +08:00
setting = args.setting
print("Loading data...")
G = json_graph.node_link_graph(json.load(open(dataset_dir + "/reddit-G.json")))
labels = json.load(open(dataset_dir + "/reddit-class_map.json"))
train_ids = [n for n in G.nodes() if not G.node[n]['val'] and not G.node[n]['test']]
test_ids = [n for n in G.nodes() if G.node[n][setting]]
train_labels = [labels[i] for i in train_ids]
test_labels = [labels[i] for i in test_ids]
if data_dir == "feat":
print("Using only features..")
feats = np.load(dataset_dir + "/reddit-feats.npy")
## Logistic gets thrown off by big counts, so log transform num comments and score
2017-05-31 01:53:15 +08:00
feats[:,0] = np.log(feats[:,0]+1.0)
feats[:,1] = np.log(feats[:,1]-min(np.min(feats[:,1]), -1))
feat_id_map = json.load(open(dataset_dir + "reddit-id_map.json"))
feat_id_map = {id:val for id,val in feat_id_map.iteritems()}
train_feats = feats[[feat_id_map[id] for id in train_ids]]
test_feats = feats[[feat_id_map[id] for id in test_ids]]
print("Running regression..")
from sklearn.preprocessing import StandardScaler
scaler = StandardScaler()
scaler.fit(train_feats)
train_feats = scaler.transform(train_feats)
test_feats = scaler.transform(test_feats)
run_regression(train_feats, train_labels, test_feats, test_labels)
elif "n2v" in data_dir:
print("Doing it N2V style.")
base_embeds = np.load(data_dir + "/val.npy")
base_id_map = {}
with open(data_dir + "/val.txt") as fp:
for i, line in enumerate(fp):
base_id_map[line.strip()] = i
tuned_embeds = np.load(data_dir + "/val-test.npy")
tuned_id_map = {}
with open(data_dir + "/val-test.txt") as fp:
for i, line in enumerate(fp):
tuned_id_map[line.strip()] = i
train_embeds = base_embeds[[base_id_map[id] for id in train_ids]]
test_embeds = tuned_embeds[[tuned_id_map[id] for id in test_ids]]
print("Running regression..")
run_regression(train_embeds, train_labels, test_embeds, test_labels)
# loading feats
feats = np.load(dataset_dir + "/reddit-feats.npy")
feat_id_map = json.load(open(dataset_dir + "/reddit-id_map.json"))
feat_id_map = {id:val for id,val in feat_id_map.iteritems()}
train_feats = feats[[feat_id_map[id] for id in train_ids]]
test_feats = feats[[feat_id_map[id] for id in test_ids]]
train_embeds = np.hstack([train_feats, train_embeds])
test_embeds = np.hstack([test_feats, test_embeds])
from sklearn.preprocessing import StandardScaler
scaler = StandardScaler()
scaler.fit(train_embeds)
train_embeds = scaler.transform(train_embeds)
test_embeds = scaler.transform(test_embeds)
print("Running regression with feats..")
run_regression(train_embeds, train_labels, test_embeds, test_labels)
else:
embeds = np.load(data_dir + "/val.npy")
id_map = {}
with open(data_dir + "/val.txt") as fp:
for i, line in enumerate(fp):
id_map[line.strip()] = i
train_embeds = embeds[[id_map[id] for id in train_ids]]
test_embeds = embeds[[id_map[id] for id in test_ids]]
print("Running regression..")
run_regression(train_embeds, train_labels, test_embeds, test_labels)