File size: 819 Bytes
a3682cf | 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 | 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 |