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