temporal-twins-code / src /gnn /evaluate.py
temporal-twins-anon's picture
Add anonymous Temporal Twins code release
a3682cf verified
raw
history blame contribute delete
819 Bytes
import torch
from sklearn.metrics import roc_auc_score, average_precision_score
def evaluate_gnn(model, graph_data):
device = torch.device("cpu")
edge_index = torch.tensor(graph_data["edge_index"], dtype=torch.long).to(device)
edge_attr = torch.tensor(graph_data["edge_attr"], dtype=torch.float32).to(device)
x = torch.tensor(graph_data["x"], dtype=torch.float32).to(device)
y = torch.tensor(graph_data["y"], dtype=torch.float32).to(device)
src = edge_index[0]
dst = edge_index[1]
model.eval()
with torch.no_grad():
logits = model(x, edge_index, edge_attr, src, dst) # ✅ FIXED
probs = torch.sigmoid(logits).cpu().numpy()
y_true = y.cpu().numpy()
roc = roc_auc_score(y_true, probs)
pr = average_precision_score(y_true, probs)
return roc, pr