{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "eb81e1aa-1d17-4313-a2bc-fd553805810d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "========== Dataset: Cora ==========\n",
      "\n",
      "=== Processing Mask File: Cora_30_70_masked_indices_seed123.npy (30_70, GCN) ===\n",
      "Train nodes: 813 | Test nodes: 1895\n",
      "Epoch 001 | Train Loss: 5.0445 | Val Loss: 5.0237\n",
      "Epoch 020 | Train Loss: 0.5364 | Val Loss: 1.2896\n",
      "Epoch 040 | Train Loss: 0.1225 | Val Loss: 1.5384\n",
      "Epoch 060 | Train Loss: 0.0514 | Val Loss: 1.6711\n",
      "Epoch 080 | Train Loss: 0.0428 | Val Loss: 1.6668\n",
      "Epoch 100 | Train Loss: 0.0424 | Val Loss: 1.6359\n",
      "Epoch 120 | Train Loss: 0.0399 | Val Loss: 1.6345\n",
      "Epoch 140 | Train Loss: 0.0358 | Val Loss: 1.6570\n",
      "Epoch 160 | Train Loss: 0.0326 | Val Loss: 1.6791\n",
      "Epoch 180 | Train Loss: 0.0304 | Val Loss: 1.6968\n",
      "Epoch 200 | Train Loss: 0.0286 | Val Loss: 1.7126\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/30_70/Cora_GCN_30_70_seed123.pt\n",
      "\n",
      "=== Processing Mask File: Cora_30_70_masked_indices_seed2025.npy (30_70, GCN) ===\n",
      "Train nodes: 813 | Test nodes: 1895\n",
      "Epoch 001 | Train Loss: 5.0173 | Val Loss: 5.0129\n",
      "Epoch 020 | Train Loss: 0.5261 | Val Loss: 1.2792\n",
      "Epoch 040 | Train Loss: 0.1194 | Val Loss: 1.5516\n",
      "Epoch 060 | Train Loss: 0.0509 | Val Loss: 1.7068\n",
      "Epoch 080 | Train Loss: 0.0419 | Val Loss: 1.6983\n",
      "Epoch 100 | Train Loss: 0.0414 | Val Loss: 1.6692\n",
      "Epoch 120 | Train Loss: 0.0386 | Val Loss: 1.6718\n",
      "Epoch 140 | Train Loss: 0.0344 | Val Loss: 1.6940\n",
      "Epoch 160 | Train Loss: 0.0313 | Val Loss: 1.7151\n",
      "Epoch 180 | Train Loss: 0.0291 | Val Loss: 1.7292\n",
      "Epoch 200 | Train Loss: 0.0273 | Val Loss: 1.7421\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/30_70/Cora_GCN_30_70_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: Cora_30_70_masked_indices_seed42.npy (30_70, GCN) ===\n",
      "Train nodes: 813 | Test nodes: 1895\n",
      "Epoch 001 | Train Loss: 4.9730 | Val Loss: 4.9726\n",
      "Epoch 020 | Train Loss: 0.5524 | Val Loss: 1.2757\n",
      "Epoch 040 | Train Loss: 0.1226 | Val Loss: 1.4609\n",
      "Epoch 060 | Train Loss: 0.0487 | Val Loss: 1.6111\n",
      "Epoch 080 | Train Loss: 0.0401 | Val Loss: 1.6053\n",
      "Epoch 100 | Train Loss: 0.0401 | Val Loss: 1.5745\n",
      "Epoch 120 | Train Loss: 0.0375 | Val Loss: 1.5822\n",
      "Epoch 140 | Train Loss: 0.0333 | Val Loss: 1.6121\n",
      "Epoch 160 | Train Loss: 0.0302 | Val Loss: 1.6389\n",
      "Epoch 180 | Train Loss: 0.0282 | Val Loss: 1.6569\n",
      "Epoch 200 | Train Loss: 0.0265 | Val Loss: 1.6714\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/30_70/Cora_GCN_30_70_seed42.pt\n",
      "\n",
      "=== Processing Mask File: Cora_30_70_masked_indices_seed46.npy (30_70, GCN) ===\n",
      "Train nodes: 813 | Test nodes: 1895\n",
      "Epoch 001 | Train Loss: 5.0868 | Val Loss: 5.0791\n",
      "Epoch 020 | Train Loss: 0.5684 | Val Loss: 1.2682\n",
      "Epoch 040 | Train Loss: 0.1184 | Val Loss: 1.4246\n",
      "Epoch 060 | Train Loss: 0.0442 | Val Loss: 1.5367\n",
      "Epoch 080 | Train Loss: 0.0375 | Val Loss: 1.5315\n",
      "Epoch 100 | Train Loss: 0.0384 | Val Loss: 1.5090\n",
      "Epoch 120 | Train Loss: 0.0364 | Val Loss: 1.5174\n",
      "Epoch 140 | Train Loss: 0.0325 | Val Loss: 1.5457\n",
      "Epoch 160 | Train Loss: 0.0296 | Val Loss: 1.5732\n",
      "Epoch 180 | Train Loss: 0.0276 | Val Loss: 1.5929\n",
      "Epoch 200 | Train Loss: 0.0260 | Val Loss: 1.6107\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/30_70/Cora_GCN_30_70_seed46.pt\n",
      "\n",
      "=== Processing Mask File: Cora_30_70_masked_indices_seed999.npy (30_70, GCN) ===\n",
      "Train nodes: 813 | Test nodes: 1895\n",
      "Epoch 001 | Train Loss: 5.0739 | Val Loss: 5.0804\n",
      "Epoch 020 | Train Loss: 0.5339 | Val Loss: 1.3141\n",
      "Epoch 040 | Train Loss: 0.1176 | Val Loss: 1.5339\n",
      "Epoch 060 | Train Loss: 0.0473 | Val Loss: 1.6856\n",
      "Epoch 080 | Train Loss: 0.0394 | Val Loss: 1.6780\n",
      "Epoch 100 | Train Loss: 0.0396 | Val Loss: 1.6442\n",
      "Epoch 120 | Train Loss: 0.0374 | Val Loss: 1.6463\n",
      "Epoch 140 | Train Loss: 0.0335 | Val Loss: 1.6679\n",
      "Epoch 160 | Train Loss: 0.0304 | Val Loss: 1.6902\n",
      "Epoch 180 | Train Loss: 0.0283 | Val Loss: 1.7071\n",
      "Epoch 200 | Train Loss: 0.0266 | Val Loss: 1.7190\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/30_70/Cora_GCN_30_70_seed999.pt\n",
      "\n",
      "=== Processing Mask File: Cora_30_70_masked_indices_seed123.npy (30_70, GAT) ===\n",
      "Train nodes: 813 | Test nodes: 1895\n",
      "Epoch 001 | Train Loss: 5.0101 | Val Loss: 5.0083\n",
      "Epoch 020 | Train Loss: 0.1886 | Val Loss: 1.9413\n",
      "Epoch 040 | Train Loss: 0.2956 | Val Loss: 2.3229\n",
      "Epoch 060 | Train Loss: 0.1789 | Val Loss: 2.2234\n",
      "Epoch 080 | Train Loss: 0.3298 | Val Loss: 2.5222\n",
      "Epoch 100 | Train Loss: 0.3542 | Val Loss: 2.6205\n",
      "Epoch 120 | Train Loss: 0.1761 | Val Loss: 2.4779\n",
      "Epoch 140 | Train Loss: 0.1744 | Val Loss: 2.4875\n",
      "Epoch 160 | Train Loss: 0.1338 | Val Loss: 2.3973\n",
      "Epoch 180 | Train Loss: 0.1344 | Val Loss: 2.1977\n",
      "Epoch 200 | Train Loss: 0.1748 | Val Loss: 2.2768\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/30_70/Cora_GAT_30_70_seed123.pt\n",
      "\n",
      "=== Processing Mask File: Cora_30_70_masked_indices_seed2025.npy (30_70, GAT) ===\n",
      "Train nodes: 813 | Test nodes: 1895\n",
      "Epoch 001 | Train Loss: 5.0245 | Val Loss: 5.0376\n",
      "Epoch 020 | Train Loss: 0.1829 | Val Loss: 1.8911\n",
      "Epoch 040 | Train Loss: 0.2061 | Val Loss: 1.7804\n",
      "Epoch 060 | Train Loss: 0.2446 | Val Loss: 1.8055\n",
      "Epoch 080 | Train Loss: 0.2579 | Val Loss: 1.8848\n",
      "Epoch 100 | Train Loss: 0.1986 | Val Loss: 1.8767\n",
      "Epoch 120 | Train Loss: 0.1496 | Val Loss: 1.7893\n",
      "Epoch 140 | Train Loss: 0.1392 | Val Loss: 1.7771\n",
      "Epoch 160 | Train Loss: 0.1234 | Val Loss: 1.6770\n",
      "Epoch 180 | Train Loss: 0.1214 | Val Loss: 1.5907\n",
      "Epoch 200 | Train Loss: 0.1167 | Val Loss: 1.5283\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/30_70/Cora_GAT_30_70_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: Cora_30_70_masked_indices_seed42.npy (30_70, GAT) ===\n",
      "Train nodes: 813 | Test nodes: 1895\n",
      "Epoch 001 | Train Loss: 5.0314 | Val Loss: 5.0427\n",
      "Epoch 020 | Train Loss: 0.1924 | Val Loss: 2.0213\n",
      "Epoch 040 | Train Loss: 0.1582 | Val Loss: 2.0395\n",
      "Epoch 060 | Train Loss: 0.0996 | Val Loss: 2.1209\n",
      "Epoch 080 | Train Loss: 0.0715 | Val Loss: 2.2570\n",
      "Epoch 100 | Train Loss: 0.0592 | Val Loss: 2.2726\n",
      "Epoch 120 | Train Loss: 0.0572 | Val Loss: 2.1616\n",
      "Epoch 140 | Train Loss: 0.0585 | Val Loss: 2.0122\n",
      "Epoch 160 | Train Loss: 0.0572 | Val Loss: 1.8860\n",
      "Epoch 180 | Train Loss: 0.0764 | Val Loss: 1.7935\n",
      "Epoch 200 | Train Loss: 0.0558 | Val Loss: 1.7586\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/30_70/Cora_GAT_30_70_seed42.pt\n",
      "\n",
      "=== Processing Mask File: Cora_30_70_masked_indices_seed46.npy (30_70, GAT) ===\n",
      "Train nodes: 813 | Test nodes: 1895\n",
      "Epoch 001 | Train Loss: 5.0568 | Val Loss: 5.0603\n",
      "Epoch 020 | Train Loss: 0.0181 | Val Loss: 2.5008\n",
      "Epoch 040 | Train Loss: 0.0045 | Val Loss: 2.6172\n",
      "Epoch 060 | Train Loss: 0.0047 | Val Loss: 1.9805\n",
      "Epoch 080 | Train Loss: 0.0046 | Val Loss: 1.6273\n",
      "Epoch 100 | Train Loss: 0.0303 | Val Loss: 1.7433\n",
      "Epoch 120 | Train Loss: 0.0011 | Val Loss: 2.0415\n",
      "Epoch 140 | Train Loss: 0.0023 | Val Loss: 1.6381\n",
      "Epoch 160 | Train Loss: 0.0062 | Val Loss: 1.4936\n",
      "Epoch 180 | Train Loss: 0.0044 | Val Loss: 1.5760\n",
      "Epoch 200 | Train Loss: 0.0045 | Val Loss: 1.4680\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/30_70/Cora_GAT_30_70_seed46.pt\n",
      "\n",
      "=== Processing Mask File: Cora_30_70_masked_indices_seed999.npy (30_70, GAT) ===\n",
      "Train nodes: 813 | Test nodes: 1895\n",
      "Epoch 001 | Train Loss: 5.0176 | Val Loss: 5.0113\n",
      "Epoch 020 | Train Loss: 0.2339 | Val Loss: 1.9347\n",
      "Epoch 040 | Train Loss: 0.1901 | Val Loss: 2.1916\n",
      "Epoch 060 | Train Loss: 0.2555 | Val Loss: 2.1797\n",
      "Epoch 080 | Train Loss: 0.1700 | Val Loss: 2.2391\n",
      "Epoch 100 | Train Loss: 0.2011 | Val Loss: 1.9761\n",
      "Epoch 120 | Train Loss: 0.1293 | Val Loss: 2.2163\n",
      "Epoch 140 | Train Loss: 0.1952 | Val Loss: 2.1538\n",
      "Epoch 160 | Train Loss: 0.1783 | Val Loss: 2.2430\n",
      "Epoch 180 | Train Loss: 0.2102 | Val Loss: 2.3264\n",
      "Epoch 200 | Train Loss: 0.1869 | Val Loss: 2.2990\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/30_70/Cora_GAT_30_70_seed999.pt\n",
      "\n",
      "=== Processing Mask File: Cora_30_70_masked_indices_seed123.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 813 | Test nodes: 1895\n",
      "Epoch 001 | Train Loss: 5.0286 | Val Loss: 5.0089\n",
      "Epoch 020 | Train Loss: 0.0132 | Val Loss: 2.0651\n",
      "Epoch 040 | Train Loss: 0.0017 | Val Loss: 2.5026\n",
      "Epoch 060 | Train Loss: 0.0034 | Val Loss: 2.3146\n",
      "Epoch 080 | Train Loss: 0.0073 | Val Loss: 2.0624\n",
      "Epoch 100 | Train Loss: 0.0082 | Val Loss: 1.9118\n",
      "Epoch 120 | Train Loss: 0.0075 | Val Loss: 1.8477\n",
      "Epoch 140 | Train Loss: 0.0071 | Val Loss: 1.8150\n",
      "Epoch 160 | Train Loss: 0.0066 | Val Loss: 1.8021\n",
      "Epoch 180 | Train Loss: 0.0062 | Val Loss: 1.7992\n",
      "Epoch 200 | Train Loss: 0.0059 | Val Loss: 1.8017\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/30_70/Cora_GraphSAGE_30_70_seed123.pt\n",
      "\n",
      "=== Processing Mask File: Cora_30_70_masked_indices_seed2025.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 813 | Test nodes: 1895\n",
      "Epoch 001 | Train Loss: 5.1134 | Val Loss: 5.1133\n",
      "Epoch 020 | Train Loss: 0.0165 | Val Loss: 2.0987\n",
      "Epoch 040 | Train Loss: 0.0018 | Val Loss: 2.5079\n",
      "Epoch 060 | Train Loss: 0.0035 | Val Loss: 2.3149\n",
      "Epoch 080 | Train Loss: 0.0075 | Val Loss: 2.0589\n",
      "Epoch 100 | Train Loss: 0.0085 | Val Loss: 1.9223\n",
      "Epoch 120 | Train Loss: 0.0078 | Val Loss: 1.8667\n",
      "Epoch 140 | Train Loss: 0.0073 | Val Loss: 1.8394\n",
      "Epoch 160 | Train Loss: 0.0068 | Val Loss: 1.8285\n",
      "Epoch 180 | Train Loss: 0.0064 | Val Loss: 1.8271\n",
      "Epoch 200 | Train Loss: 0.0060 | Val Loss: 1.8319\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/30_70/Cora_GraphSAGE_30_70_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: Cora_30_70_masked_indices_seed42.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 813 | Test nodes: 1895\n",
      "Epoch 001 | Train Loss: 5.1814 | Val Loss: 5.1766\n",
      "Epoch 020 | Train Loss: 0.0163 | Val Loss: 2.0895\n",
      "Epoch 040 | Train Loss: 0.0018 | Val Loss: 2.4959\n",
      "Epoch 060 | Train Loss: 0.0033 | Val Loss: 2.2968\n",
      "Epoch 080 | Train Loss: 0.0072 | Val Loss: 2.0503\n",
      "Epoch 100 | Train Loss: 0.0083 | Val Loss: 1.9097\n",
      "Epoch 120 | Train Loss: 0.0076 | Val Loss: 1.8504\n",
      "Epoch 140 | Train Loss: 0.0072 | Val Loss: 1.8245\n",
      "Epoch 160 | Train Loss: 0.0068 | Val Loss: 1.8160\n",
      "Epoch 180 | Train Loss: 0.0063 | Val Loss: 1.8193\n",
      "Epoch 200 | Train Loss: 0.0059 | Val Loss: 1.8292\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/30_70/Cora_GraphSAGE_30_70_seed42.pt\n",
      "\n",
      "=== Processing Mask File: Cora_30_70_masked_indices_seed46.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 813 | Test nodes: 1895\n",
      "Epoch 001 | Train Loss: 4.9751 | Val Loss: 4.9702\n",
      "Epoch 020 | Train Loss: 0.0135 | Val Loss: 1.9920\n",
      "Epoch 040 | Train Loss: 0.0017 | Val Loss: 2.3789\n",
      "Epoch 060 | Train Loss: 0.0034 | Val Loss: 2.1900\n",
      "Epoch 080 | Train Loss: 0.0074 | Val Loss: 1.9497\n",
      "Epoch 100 | Train Loss: 0.0083 | Val Loss: 1.8105\n",
      "Epoch 120 | Train Loss: 0.0076 | Val Loss: 1.7463\n",
      "Epoch 140 | Train Loss: 0.0071 | Val Loss: 1.7175\n",
      "Epoch 160 | Train Loss: 0.0067 | Val Loss: 1.7065\n",
      "Epoch 180 | Train Loss: 0.0063 | Val Loss: 1.7046\n",
      "Epoch 200 | Train Loss: 0.0059 | Val Loss: 1.7092\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/30_70/Cora_GraphSAGE_30_70_seed46.pt\n",
      "\n",
      "=== Processing Mask File: Cora_30_70_masked_indices_seed999.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 813 | Test nodes: 1895\n",
      "Epoch 001 | Train Loss: 5.1711 | Val Loss: 5.1677\n",
      "Epoch 020 | Train Loss: 0.0187 | Val Loss: 2.0999\n",
      "Epoch 040 | Train Loss: 0.0020 | Val Loss: 2.4396\n",
      "Epoch 060 | Train Loss: 0.0036 | Val Loss: 2.2849\n",
      "Epoch 080 | Train Loss: 0.0076 | Val Loss: 2.0546\n",
      "Epoch 100 | Train Loss: 0.0088 | Val Loss: 1.9338\n",
      "Epoch 120 | Train Loss: 0.0080 | Val Loss: 1.8834\n",
      "Epoch 140 | Train Loss: 0.0075 | Val Loss: 1.8625\n",
      "Epoch 160 | Train Loss: 0.0071 | Val Loss: 1.8543\n",
      "Epoch 180 | Train Loss: 0.0066 | Val Loss: 1.8567\n",
      "Epoch 200 | Train Loss: 0.0061 | Val Loss: 1.8631\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/30_70/Cora_GraphSAGE_30_70_seed999.pt\n",
      "Saved averaged results and execution times for Cora split 30_70\n",
      "\n",
      "=== Processing Mask File: Cora_70_30_masked_indices_seed123.npy (70_30, GCN) ===\n",
      "Train nodes: 1896 | Test nodes: 812\n",
      "Epoch 001 | Train Loss: 5.1383 | Val Loss: 5.1390\n",
      "Epoch 020 | Train Loss: 0.7525 | Val Loss: 1.0497\n",
      "Epoch 040 | Train Loss: 0.3087 | Val Loss: 0.8175\n",
      "Epoch 060 | Train Loss: 0.1583 | Val Loss: 0.7722\n",
      "Epoch 080 | Train Loss: 0.1090 | Val Loss: 0.7783\n",
      "Epoch 100 | Train Loss: 0.0909 | Val Loss: 0.7794\n",
      "Epoch 120 | Train Loss: 0.0806 | Val Loss: 0.7841\n",
      "Epoch 140 | Train Loss: 0.0715 | Val Loss: 0.7907\n",
      "Epoch 160 | Train Loss: 0.0643 | Val Loss: 0.7972\n",
      "Epoch 180 | Train Loss: 0.0591 | Val Loss: 0.7996\n",
      "Epoch 200 | Train Loss: 0.0553 | Val Loss: 0.7982\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/70_30/Cora_GCN_70_30_seed123.pt\n",
      "\n",
      "=== Processing Mask File: Cora_70_30_masked_indices_seed2025.npy (70_30, GCN) ===\n",
      "Train nodes: 1896 | Test nodes: 812\n",
      "Epoch 001 | Train Loss: 4.9772 | Val Loss: 4.9817\n",
      "Epoch 020 | Train Loss: 0.7178 | Val Loss: 1.1017\n",
      "Epoch 040 | Train Loss: 0.2761 | Val Loss: 0.9253\n",
      "Epoch 060 | Train Loss: 0.1371 | Val Loss: 0.8594\n",
      "Epoch 080 | Train Loss: 0.0955 | Val Loss: 0.8461\n",
      "Epoch 100 | Train Loss: 0.0815 | Val Loss: 0.8502\n",
      "Epoch 120 | Train Loss: 0.0728 | Val Loss: 0.8570\n",
      "Epoch 140 | Train Loss: 0.0645 | Val Loss: 0.8667\n",
      "Epoch 160 | Train Loss: 0.0581 | Val Loss: 0.8734\n",
      "Epoch 180 | Train Loss: 0.0534 | Val Loss: 0.8811\n",
      "Epoch 200 | Train Loss: 0.0499 | Val Loss: 0.8882\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/70_30/Cora_GCN_70_30_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: Cora_70_30_masked_indices_seed42.npy (70_30, GCN) ===\n",
      "Train nodes: 1896 | Test nodes: 812\n",
      "Epoch 001 | Train Loss: 5.2017 | Val Loss: 5.2213\n",
      "Epoch 020 | Train Loss: 0.7673 | Val Loss: 1.0558\n",
      "Epoch 040 | Train Loss: 0.3243 | Val Loss: 0.8164\n",
      "Epoch 060 | Train Loss: 0.1650 | Val Loss: 0.7525\n",
      "Epoch 080 | Train Loss: 0.1119 | Val Loss: 0.7551\n",
      "Epoch 100 | Train Loss: 0.0930 | Val Loss: 0.7612\n",
      "Epoch 120 | Train Loss: 0.0821 | Val Loss: 0.7675\n",
      "Epoch 140 | Train Loss: 0.0726 | Val Loss: 0.7743\n",
      "Epoch 160 | Train Loss: 0.0654 | Val Loss: 0.7814\n",
      "Epoch 180 | Train Loss: 0.0602 | Val Loss: 0.7875\n",
      "Epoch 200 | Train Loss: 0.0563 | Val Loss: 0.7922\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/70_30/Cora_GCN_70_30_seed42.pt\n",
      "\n",
      "=== Processing Mask File: Cora_70_30_masked_indices_seed46.npy (70_30, GCN) ===\n",
      "Train nodes: 1896 | Test nodes: 812\n",
      "Epoch 001 | Train Loss: 5.0156 | Val Loss: 5.0091\n",
      "Epoch 020 | Train Loss: 0.7315 | Val Loss: 1.0786\n",
      "Epoch 040 | Train Loss: 0.2843 | Val Loss: 0.8780\n",
      "Epoch 060 | Train Loss: 0.1418 | Val Loss: 0.8524\n",
      "Epoch 080 | Train Loss: 0.1005 | Val Loss: 0.8512\n",
      "Epoch 100 | Train Loss: 0.0867 | Val Loss: 0.8545\n",
      "Epoch 120 | Train Loss: 0.0779 | Val Loss: 0.8586\n",
      "Epoch 140 | Train Loss: 0.0696 | Val Loss: 0.8699\n",
      "Epoch 160 | Train Loss: 0.0632 | Val Loss: 0.8789\n",
      "Epoch 180 | Train Loss: 0.0584 | Val Loss: 0.8854\n",
      "Epoch 200 | Train Loss: 0.0547 | Val Loss: 0.8922\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/70_30/Cora_GCN_70_30_seed46.pt\n",
      "\n",
      "=== Processing Mask File: Cora_70_30_masked_indices_seed999.npy (70_30, GCN) ===\n",
      "Train nodes: 1896 | Test nodes: 812\n",
      "Epoch 001 | Train Loss: 4.9360 | Val Loss: 4.9168\n",
      "Epoch 020 | Train Loss: 0.7060 | Val Loss: 1.0842\n",
      "Epoch 040 | Train Loss: 0.2741 | Val Loss: 0.8919\n",
      "Epoch 060 | Train Loss: 0.1374 | Val Loss: 0.8815\n",
      "Epoch 080 | Train Loss: 0.0966 | Val Loss: 0.8776\n",
      "Epoch 100 | Train Loss: 0.0826 | Val Loss: 0.8791\n",
      "Epoch 120 | Train Loss: 0.0742 | Val Loss: 0.8816\n",
      "Epoch 140 | Train Loss: 0.0662 | Val Loss: 0.8934\n",
      "Epoch 160 | Train Loss: 0.0598 | Val Loss: 0.9067\n",
      "Epoch 180 | Train Loss: 0.0554 | Val Loss: 0.9143\n",
      "Epoch 200 | Train Loss: 0.0520 | Val Loss: 0.9222\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/70_30/Cora_GCN_70_30_seed999.pt\n",
      "\n",
      "=== Processing Mask File: Cora_70_30_masked_indices_seed123.npy (70_30, GAT) ===\n",
      "Train nodes: 1896 | Test nodes: 812\n",
      "Epoch 001 | Train Loss: 5.0232 | Val Loss: 5.0362\n",
      "Epoch 020 | Train Loss: 0.1848 | Val Loss: 0.8531\n",
      "Epoch 040 | Train Loss: 0.0963 | Val Loss: 1.0496\n",
      "Epoch 060 | Train Loss: 0.0611 | Val Loss: 1.0724\n",
      "Epoch 080 | Train Loss: 0.0633 | Val Loss: 0.9774\n",
      "Epoch 100 | Train Loss: 0.0357 | Val Loss: 1.0941\n",
      "Epoch 120 | Train Loss: 0.0327 | Val Loss: 1.0404\n",
      "Epoch 140 | Train Loss: 0.0991 | Val Loss: 1.1142\n",
      "Epoch 160 | Train Loss: 0.0235 | Val Loss: 1.1490\n",
      "Epoch 180 | Train Loss: 0.0069 | Val Loss: 1.1488\n",
      "Epoch 200 | Train Loss: 0.0070 | Val Loss: 1.1248\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/70_30/Cora_GAT_70_30_seed123.pt\n",
      "\n",
      "=== Processing Mask File: Cora_70_30_masked_indices_seed2025.npy (70_30, GAT) ===\n",
      "Train nodes: 1896 | Test nodes: 812\n",
      "Epoch 001 | Train Loss: 5.0470 | Val Loss: 5.0583\n",
      "Epoch 020 | Train Loss: 0.2213 | Val Loss: 1.3502\n",
      "Epoch 040 | Train Loss: 0.3116 | Val Loss: 1.5432\n",
      "Epoch 060 | Train Loss: 0.2993 | Val Loss: 1.4615\n",
      "Epoch 080 | Train Loss: 0.1922 | Val Loss: 1.4909\n",
      "Epoch 100 | Train Loss: 0.0947 | Val Loss: 1.5725\n",
      "Epoch 120 | Train Loss: 0.0778 | Val Loss: 1.6446\n",
      "Epoch 140 | Train Loss: 0.0672 | Val Loss: 1.5902\n",
      "Epoch 160 | Train Loss: 0.0608 | Val Loss: 1.4903\n",
      "Epoch 180 | Train Loss: 0.0551 | Val Loss: 1.3969\n",
      "Epoch 200 | Train Loss: 0.0519 | Val Loss: 1.3465\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/70_30/Cora_GAT_70_30_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: Cora_70_30_masked_indices_seed42.npy (70_30, GAT) ===\n",
      "Train nodes: 1896 | Test nodes: 812\n",
      "Epoch 001 | Train Loss: 5.0684 | Val Loss: 5.0745\n",
      "Epoch 020 | Train Loss: 0.3194 | Val Loss: 1.1537\n",
      "Epoch 040 | Train Loss: 0.2447 | Val Loss: 1.1840\n",
      "Epoch 060 | Train Loss: 0.2186 | Val Loss: 1.2599\n",
      "Epoch 080 | Train Loss: 0.1836 | Val Loss: 1.2875\n",
      "Epoch 100 | Train Loss: 0.1933 | Val Loss: 1.3278\n",
      "Epoch 120 | Train Loss: 0.1425 | Val Loss: 1.3116\n",
      "Epoch 140 | Train Loss: 0.1269 | Val Loss: 1.2666\n",
      "Epoch 160 | Train Loss: 0.1017 | Val Loss: 1.1872\n",
      "Epoch 180 | Train Loss: 0.0700 | Val Loss: 1.2341\n",
      "Epoch 200 | Train Loss: 0.0468 | Val Loss: 1.2819\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/70_30/Cora_GAT_70_30_seed42.pt\n",
      "\n",
      "=== Processing Mask File: Cora_70_30_masked_indices_seed46.npy (70_30, GAT) ===\n",
      "Train nodes: 1896 | Test nodes: 812\n",
      "Epoch 001 | Train Loss: 5.0508 | Val Loss: 5.0671\n",
      "Epoch 020 | Train Loss: 0.3154 | Val Loss: 1.1509\n",
      "Epoch 040 | Train Loss: 0.2164 | Val Loss: 1.1933\n",
      "Epoch 060 | Train Loss: 0.2126 | Val Loss: 1.1856\n",
      "Epoch 080 | Train Loss: 0.1882 | Val Loss: 1.2074\n",
      "Epoch 100 | Train Loss: 0.1793 | Val Loss: 1.2365\n",
      "Epoch 120 | Train Loss: 0.1568 | Val Loss: 1.1700\n",
      "Epoch 140 | Train Loss: 0.1506 | Val Loss: 1.2048\n",
      "Epoch 160 | Train Loss: 0.1447 | Val Loss: 1.1499\n",
      "Epoch 180 | Train Loss: 0.1199 | Val Loss: 1.1099\n",
      "Epoch 200 | Train Loss: 0.1036 | Val Loss: 1.2128\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/70_30/Cora_GAT_70_30_seed46.pt\n",
      "\n",
      "=== Processing Mask File: Cora_70_30_masked_indices_seed999.npy (70_30, GAT) ===\n",
      "Train nodes: 1896 | Test nodes: 812\n",
      "Epoch 001 | Train Loss: 5.0365 | Val Loss: 5.0184\n",
      "Epoch 020 | Train Loss: 0.2683 | Val Loss: 1.1213\n",
      "Epoch 040 | Train Loss: 0.2173 | Val Loss: 1.2971\n",
      "Epoch 060 | Train Loss: 0.1826 | Val Loss: 1.3977\n",
      "Epoch 080 | Train Loss: 0.1758 | Val Loss: 1.3519\n",
      "Epoch 100 | Train Loss: 0.1392 | Val Loss: 1.3336\n",
      "Epoch 120 | Train Loss: 0.1022 | Val Loss: 1.3725\n",
      "Epoch 140 | Train Loss: 0.0875 | Val Loss: 1.3215\n",
      "Epoch 160 | Train Loss: 0.0790 | Val Loss: 1.2816\n",
      "Epoch 180 | Train Loss: 0.0674 | Val Loss: 1.2341\n",
      "Epoch 200 | Train Loss: 0.0578 | Val Loss: 1.2714\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/70_30/Cora_GAT_70_30_seed999.pt\n",
      "\n",
      "=== Processing Mask File: Cora_70_30_masked_indices_seed123.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 1896 | Test nodes: 812\n",
      "Epoch 001 | Train Loss: 5.0166 | Val Loss: 5.0117\n",
      "Epoch 020 | Train Loss: 0.1147 | Val Loss: 1.3130\n",
      "Epoch 040 | Train Loss: 0.0084 | Val Loss: 1.4339\n",
      "Epoch 060 | Train Loss: 0.0087 | Val Loss: 1.3572\n",
      "Epoch 080 | Train Loss: 0.0141 | Val Loss: 1.2339\n",
      "Epoch 100 | Train Loss: 0.0144 | Val Loss: 1.1399\n",
      "Epoch 120 | Train Loss: 0.0127 | Val Loss: 1.0890\n",
      "Epoch 140 | Train Loss: 0.0117 | Val Loss: 1.0537\n",
      "Epoch 160 | Train Loss: 0.0108 | Val Loss: 1.0311\n",
      "Epoch 180 | Train Loss: 0.0101 | Val Loss: 1.0167\n",
      "Epoch 200 | Train Loss: 0.0095 | Val Loss: 1.0087\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/70_30/Cora_GraphSAGE_70_30_seed123.pt\n",
      "\n",
      "=== Processing Mask File: Cora_70_30_masked_indices_seed2025.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 1896 | Test nodes: 812\n",
      "Epoch 001 | Train Loss: 5.0734 | Val Loss: 5.0973\n",
      "Epoch 020 | Train Loss: 0.1083 | Val Loss: 1.5005\n",
      "Epoch 040 | Train Loss: 0.0081 | Val Loss: 1.6501\n",
      "Epoch 060 | Train Loss: 0.0088 | Val Loss: 1.5298\n",
      "Epoch 080 | Train Loss: 0.0144 | Val Loss: 1.3643\n",
      "Epoch 100 | Train Loss: 0.0146 | Val Loss: 1.2537\n",
      "Epoch 120 | Train Loss: 0.0128 | Val Loss: 1.2019\n",
      "Epoch 140 | Train Loss: 0.0118 | Val Loss: 1.1730\n",
      "Epoch 160 | Train Loss: 0.0110 | Val Loss: 1.1569\n",
      "Epoch 180 | Train Loss: 0.0102 | Val Loss: 1.1500\n",
      "Epoch 200 | Train Loss: 0.0095 | Val Loss: 1.1493\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/70_30/Cora_GraphSAGE_70_30_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: Cora_70_30_masked_indices_seed42.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 1896 | Test nodes: 812\n",
      "Epoch 001 | Train Loss: 5.1817 | Val Loss: 5.1654\n",
      "Epoch 020 | Train Loss: 0.1222 | Val Loss: 1.3246\n",
      "Epoch 040 | Train Loss: 0.0084 | Val Loss: 1.4333\n",
      "Epoch 060 | Train Loss: 0.0085 | Val Loss: 1.3564\n",
      "Epoch 080 | Train Loss: 0.0140 | Val Loss: 1.2252\n",
      "Epoch 100 | Train Loss: 0.0145 | Val Loss: 1.1324\n",
      "Epoch 120 | Train Loss: 0.0127 | Val Loss: 1.0866\n",
      "Epoch 140 | Train Loss: 0.0117 | Val Loss: 1.0562\n",
      "Epoch 160 | Train Loss: 0.0109 | Val Loss: 1.0342\n",
      "Epoch 180 | Train Loss: 0.0101 | Val Loss: 1.0230\n",
      "Epoch 200 | Train Loss: 0.0095 | Val Loss: 1.0173\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/70_30/Cora_GraphSAGE_70_30_seed42.pt\n",
      "\n",
      "=== Processing Mask File: Cora_70_30_masked_indices_seed46.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 1896 | Test nodes: 812\n",
      "Epoch 001 | Train Loss: 5.0547 | Val Loss: 5.0448\n",
      "Epoch 020 | Train Loss: 0.1069 | Val Loss: 1.4337\n",
      "Epoch 040 | Train Loss: 0.0077 | Val Loss: 1.5945\n",
      "Epoch 060 | Train Loss: 0.0082 | Val Loss: 1.4740\n",
      "Epoch 080 | Train Loss: 0.0138 | Val Loss: 1.3291\n",
      "Epoch 100 | Train Loss: 0.0142 | Val Loss: 1.2233\n",
      "Epoch 120 | Train Loss: 0.0125 | Val Loss: 1.1665\n",
      "Epoch 140 | Train Loss: 0.0116 | Val Loss: 1.1303\n",
      "Epoch 160 | Train Loss: 0.0107 | Val Loss: 1.1054\n",
      "Epoch 180 | Train Loss: 0.0100 | Val Loss: 1.0889\n",
      "Epoch 200 | Train Loss: 0.0093 | Val Loss: 1.0806\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/70_30/Cora_GraphSAGE_70_30_seed46.pt\n",
      "\n",
      "=== Processing Mask File: Cora_70_30_masked_indices_seed999.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 1896 | Test nodes: 812\n",
      "Epoch 001 | Train Loss: 5.2517 | Val Loss: 5.2386\n",
      "Epoch 020 | Train Loss: 0.1142 | Val Loss: 1.3653\n",
      "Epoch 040 | Train Loss: 0.0084 | Val Loss: 1.4955\n",
      "Epoch 060 | Train Loss: 0.0085 | Val Loss: 1.3987\n",
      "Epoch 080 | Train Loss: 0.0141 | Val Loss: 1.2583\n",
      "Epoch 100 | Train Loss: 0.0145 | Val Loss: 1.1545\n",
      "Epoch 120 | Train Loss: 0.0127 | Val Loss: 1.0965\n",
      "Epoch 140 | Train Loss: 0.0118 | Val Loss: 1.0628\n",
      "Epoch 160 | Train Loss: 0.0109 | Val Loss: 1.0435\n",
      "Epoch 180 | Train Loss: 0.0101 | Val Loss: 1.0332\n",
      "Epoch 200 | Train Loss: 0.0095 | Val Loss: 1.0257\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/Cora/70_30/Cora_GraphSAGE_70_30_seed999.pt\n",
      "Saved averaged results and execution times for Cora split 70_30\n",
      "\n",
      "========== Dataset: CiteSeer ==========\n",
      "\n",
      "=== Processing Mask File: CiteSeer_30_70_masked_indices_seed123.npy (30_70, GCN) ===\n",
      "Train nodes: 999 | Test nodes: 2328\n",
      "Epoch 001 | Train Loss: 5.0515 | Val Loss: 5.0444\n",
      "Epoch 020 | Train Loss: 0.6597 | Val Loss: 1.7343\n",
      "Epoch 040 | Train Loss: 0.1835 | Val Loss: 2.0850\n",
      "Epoch 060 | Train Loss: 0.0798 | Val Loss: 2.3384\n",
      "Epoch 080 | Train Loss: 0.0626 | Val Loss: 2.3678\n",
      "Epoch 100 | Train Loss: 0.0596 | Val Loss: 2.3167\n",
      "Epoch 120 | Train Loss: 0.0565 | Val Loss: 2.2967\n",
      "Epoch 140 | Train Loss: 0.0520 | Val Loss: 2.3162\n",
      "Epoch 160 | Train Loss: 0.0481 | Val Loss: 2.3475\n",
      "Epoch 180 | Train Loss: 0.0452 | Val Loss: 2.3722\n",
      "Epoch 200 | Train Loss: 0.0430 | Val Loss: 2.3950\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/30_70/CiteSeer_GCN_30_70_seed123.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_30_70_masked_indices_seed2025.npy (30_70, GCN) ===\n",
      "Train nodes: 999 | Test nodes: 2328\n",
      "Epoch 001 | Train Loss: 5.0509 | Val Loss: 5.0569\n",
      "Epoch 020 | Train Loss: 0.7121 | Val Loss: 1.7669\n",
      "Epoch 040 | Train Loss: 0.2005 | Val Loss: 2.1165\n",
      "Epoch 060 | Train Loss: 0.0834 | Val Loss: 2.3976\n",
      "Epoch 080 | Train Loss: 0.0645 | Val Loss: 2.4538\n",
      "Epoch 100 | Train Loss: 0.0617 | Val Loss: 2.4028\n",
      "Epoch 120 | Train Loss: 0.0584 | Val Loss: 2.3862\n",
      "Epoch 140 | Train Loss: 0.0537 | Val Loss: 2.4151\n",
      "Epoch 160 | Train Loss: 0.0497 | Val Loss: 2.4483\n",
      "Epoch 180 | Train Loss: 0.0467 | Val Loss: 2.4769\n",
      "Epoch 200 | Train Loss: 0.0443 | Val Loss: 2.4980\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/30_70/CiteSeer_GCN_30_70_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_30_70_masked_indices_seed42.npy (30_70, GCN) ===\n",
      "Train nodes: 999 | Test nodes: 2328\n",
      "Epoch 001 | Train Loss: 4.9043 | Val Loss: 4.8928\n",
      "Epoch 020 | Train Loss: 0.6167 | Val Loss: 1.8041\n",
      "Epoch 040 | Train Loss: 0.1658 | Val Loss: 2.2427\n",
      "Epoch 060 | Train Loss: 0.0728 | Val Loss: 2.5275\n",
      "Epoch 080 | Train Loss: 0.0584 | Val Loss: 2.5498\n",
      "Epoch 100 | Train Loss: 0.0563 | Val Loss: 2.5009\n",
      "Epoch 120 | Train Loss: 0.0535 | Val Loss: 2.4906\n",
      "Epoch 140 | Train Loss: 0.0494 | Val Loss: 2.5230\n",
      "Epoch 160 | Train Loss: 0.0457 | Val Loss: 2.5651\n",
      "Epoch 180 | Train Loss: 0.0430 | Val Loss: 2.5986\n",
      "Epoch 200 | Train Loss: 0.0413 | Val Loss: 2.6273\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/30_70/CiteSeer_GCN_30_70_seed42.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_30_70_masked_indices_seed46.npy (30_70, GCN) ===\n",
      "Train nodes: 999 | Test nodes: 2328\n",
      "Epoch 001 | Train Loss: 5.2097 | Val Loss: 5.2113\n",
      "Epoch 020 | Train Loss: 0.6835 | Val Loss: 1.7861\n",
      "Epoch 040 | Train Loss: 0.1732 | Val Loss: 2.2448\n",
      "Epoch 060 | Train Loss: 0.0674 | Val Loss: 2.5746\n",
      "Epoch 080 | Train Loss: 0.0533 | Val Loss: 2.6198\n",
      "Epoch 100 | Train Loss: 0.0523 | Val Loss: 2.5611\n",
      "Epoch 120 | Train Loss: 0.0500 | Val Loss: 2.5402\n",
      "Epoch 140 | Train Loss: 0.0458 | Val Loss: 2.5654\n",
      "Epoch 160 | Train Loss: 0.0421 | Val Loss: 2.6011\n",
      "Epoch 180 | Train Loss: 0.0394 | Val Loss: 2.6293\n",
      "Epoch 200 | Train Loss: 0.0373 | Val Loss: 2.6527\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/30_70/CiteSeer_GCN_30_70_seed46.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_30_70_masked_indices_seed999.npy (30_70, GCN) ===\n",
      "Train nodes: 999 | Test nodes: 2328\n",
      "Epoch 001 | Train Loss: 5.0166 | Val Loss: 5.0295\n",
      "Epoch 020 | Train Loss: 0.6709 | Val Loss: 1.7842\n",
      "Epoch 040 | Train Loss: 0.1793 | Val Loss: 2.2640\n",
      "Epoch 060 | Train Loss: 0.0775 | Val Loss: 2.6000\n",
      "Epoch 080 | Train Loss: 0.0615 | Val Loss: 2.6388\n",
      "Epoch 100 | Train Loss: 0.0591 | Val Loss: 2.5889\n",
      "Epoch 120 | Train Loss: 0.0560 | Val Loss: 2.5767\n",
      "Epoch 140 | Train Loss: 0.0515 | Val Loss: 2.6058\n",
      "Epoch 160 | Train Loss: 0.0475 | Val Loss: 2.6429\n",
      "Epoch 180 | Train Loss: 0.0447 | Val Loss: 2.6675\n",
      "Epoch 200 | Train Loss: 0.0425 | Val Loss: 2.6869\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/30_70/CiteSeer_GCN_30_70_seed999.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_30_70_masked_indices_seed123.npy (30_70, GAT) ===\n",
      "Train nodes: 999 | Test nodes: 2328\n",
      "Epoch 001 | Train Loss: 5.0512 | Val Loss: 5.0599\n",
      "Epoch 020 | Train Loss: 0.1440 | Val Loss: 3.5024\n",
      "Epoch 040 | Train Loss: 0.1609 | Val Loss: 3.5571\n",
      "Epoch 060 | Train Loss: 0.1823 | Val Loss: 3.5130\n",
      "Epoch 080 | Train Loss: 0.1538 | Val Loss: 3.6404\n",
      "Epoch 100 | Train Loss: 0.1240 | Val Loss: 3.5512\n",
      "Epoch 120 | Train Loss: 0.1084 | Val Loss: 3.4402\n",
      "Epoch 140 | Train Loss: 0.0980 | Val Loss: 3.3782\n",
      "Epoch 160 | Train Loss: 0.0927 | Val Loss: 3.2265\n",
      "Epoch 180 | Train Loss: 0.0915 | Val Loss: 3.0480\n",
      "Epoch 200 | Train Loss: 0.0909 | Val Loss: 2.8864\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/30_70/CiteSeer_GAT_30_70_seed123.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_30_70_masked_indices_seed2025.npy (30_70, GAT) ===\n",
      "Train nodes: 999 | Test nodes: 2328\n",
      "Epoch 001 | Train Loss: 5.0564 | Val Loss: 5.0640\n",
      "Epoch 020 | Train Loss: 0.1657 | Val Loss: 3.5601\n",
      "Epoch 040 | Train Loss: 0.1244 | Val Loss: 3.7156\n",
      "Epoch 060 | Train Loss: 0.1589 | Val Loss: 3.7838\n",
      "Epoch 080 | Train Loss: 0.2174 | Val Loss: 3.9970\n",
      "Epoch 100 | Train Loss: 0.1939 | Val Loss: 3.9511\n",
      "Epoch 120 | Train Loss: 0.1511 | Val Loss: 3.8919\n",
      "Epoch 140 | Train Loss: 0.0970 | Val Loss: 3.8413\n",
      "Epoch 160 | Train Loss: 0.1093 | Val Loss: 3.8043\n",
      "Epoch 180 | Train Loss: 0.1202 | Val Loss: 3.8195\n",
      "Epoch 200 | Train Loss: 0.0907 | Val Loss: 3.7268\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/30_70/CiteSeer_GAT_30_70_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_30_70_masked_indices_seed42.npy (30_70, GAT) ===\n",
      "Train nodes: 999 | Test nodes: 2328\n",
      "Epoch 001 | Train Loss: 5.0413 | Val Loss: 5.0616\n",
      "Epoch 020 | Train Loss: 0.1595 | Val Loss: 3.6160\n",
      "Epoch 040 | Train Loss: 0.2155 | Val Loss: 3.7617\n",
      "Epoch 060 | Train Loss: 0.1436 | Val Loss: 3.8317\n",
      "Epoch 080 | Train Loss: 0.1302 | Val Loss: 4.0080\n",
      "Epoch 100 | Train Loss: 0.1667 | Val Loss: 4.0542\n",
      "Epoch 120 | Train Loss: 0.1146 | Val Loss: 4.1748\n",
      "Epoch 140 | Train Loss: 0.1281 | Val Loss: 4.1169\n",
      "Epoch 160 | Train Loss: 0.1106 | Val Loss: 4.0856\n",
      "Epoch 180 | Train Loss: 0.0770 | Val Loss: 3.9384\n",
      "Epoch 200 | Train Loss: 0.0672 | Val Loss: 3.8145\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/30_70/CiteSeer_GAT_30_70_seed42.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_30_70_masked_indices_seed46.npy (30_70, GAT) ===\n",
      "Train nodes: 999 | Test nodes: 2328\n",
      "Epoch 001 | Train Loss: 5.0643 | Val Loss: 5.0494\n",
      "Epoch 020 | Train Loss: 0.1334 | Val Loss: 3.5976\n",
      "Epoch 040 | Train Loss: 0.1559 | Val Loss: 3.8785\n",
      "Epoch 060 | Train Loss: 0.1677 | Val Loss: 3.7882\n",
      "Epoch 080 | Train Loss: 0.1797 | Val Loss: 3.8936\n",
      "Epoch 100 | Train Loss: 0.1237 | Val Loss: 3.9250\n",
      "Epoch 120 | Train Loss: 0.1165 | Val Loss: 3.8088\n",
      "Epoch 140 | Train Loss: 0.0923 | Val Loss: 3.6331\n",
      "Epoch 160 | Train Loss: 0.0913 | Val Loss: 3.4851\n",
      "Epoch 180 | Train Loss: 0.0823 | Val Loss: 3.4146\n",
      "Epoch 200 | Train Loss: 0.0800 | Val Loss: 3.2590\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/30_70/CiteSeer_GAT_30_70_seed46.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_30_70_masked_indices_seed999.npy (30_70, GAT) ===\n",
      "Train nodes: 999 | Test nodes: 2328\n",
      "Epoch 001 | Train Loss: 5.0311 | Val Loss: 5.0409\n",
      "Epoch 020 | Train Loss: 0.2193 | Val Loss: 3.0812\n",
      "Epoch 040 | Train Loss: 0.1941 | Val Loss: 3.4111\n",
      "Epoch 060 | Train Loss: 0.1744 | Val Loss: 3.3773\n",
      "Epoch 080 | Train Loss: 0.2873 | Val Loss: 3.4020\n",
      "Epoch 100 | Train Loss: 0.1645 | Val Loss: 3.3427\n",
      "Epoch 120 | Train Loss: 0.1371 | Val Loss: 3.1820\n",
      "Epoch 140 | Train Loss: 0.1118 | Val Loss: 3.1280\n",
      "Epoch 160 | Train Loss: 0.1077 | Val Loss: 3.0165\n",
      "Epoch 180 | Train Loss: 0.1040 | Val Loss: 2.8907\n",
      "Epoch 200 | Train Loss: 0.1002 | Val Loss: 2.7592\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/30_70/CiteSeer_GAT_30_70_seed999.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_30_70_masked_indices_seed123.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 999 | Test nodes: 2328\n",
      "Epoch 001 | Train Loss: 5.1096 | Val Loss: 5.0989\n",
      "Epoch 020 | Train Loss: 0.0349 | Val Loss: 2.7415\n",
      "Epoch 040 | Train Loss: 0.0033 | Val Loss: 3.4535\n",
      "Epoch 060 | Train Loss: 0.0054 | Val Loss: 3.1728\n",
      "Epoch 080 | Train Loss: 0.0103 | Val Loss: 2.8257\n",
      "Epoch 100 | Train Loss: 0.0108 | Val Loss: 2.6482\n",
      "Epoch 120 | Train Loss: 0.0096 | Val Loss: 2.5817\n",
      "Epoch 140 | Train Loss: 0.0089 | Val Loss: 2.5465\n",
      "Epoch 160 | Train Loss: 0.0083 | Val Loss: 2.5341\n",
      "Epoch 180 | Train Loss: 0.0077 | Val Loss: 2.5341\n",
      "Epoch 200 | Train Loss: 0.0072 | Val Loss: 2.5408\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/30_70/CiteSeer_GraphSAGE_30_70_seed123.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_30_70_masked_indices_seed2025.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 999 | Test nodes: 2328\n",
      "Epoch 001 | Train Loss: 4.9719 | Val Loss: 4.9834\n",
      "Epoch 020 | Train Loss: 0.0295 | Val Loss: 2.8073\n",
      "Epoch 040 | Train Loss: 0.0030 | Val Loss: 3.5459\n",
      "Epoch 060 | Train Loss: 0.0053 | Val Loss: 3.2422\n",
      "Epoch 080 | Train Loss: 0.0102 | Val Loss: 2.8706\n",
      "Epoch 100 | Train Loss: 0.0104 | Val Loss: 2.6822\n",
      "Epoch 120 | Train Loss: 0.0093 | Val Loss: 2.6103\n",
      "Epoch 140 | Train Loss: 0.0087 | Val Loss: 2.5734\n",
      "Epoch 160 | Train Loss: 0.0081 | Val Loss: 2.5586\n",
      "Epoch 180 | Train Loss: 0.0075 | Val Loss: 2.5589\n",
      "Epoch 200 | Train Loss: 0.0070 | Val Loss: 2.5678\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/30_70/CiteSeer_GraphSAGE_30_70_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_30_70_masked_indices_seed42.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 999 | Test nodes: 2328\n",
      "Epoch 001 | Train Loss: 5.0623 | Val Loss: 5.0492\n",
      "Epoch 020 | Train Loss: 0.0335 | Val Loss: 2.7984\n",
      "Epoch 040 | Train Loss: 0.0032 | Val Loss: 3.4703\n",
      "Epoch 060 | Train Loss: 0.0052 | Val Loss: 3.1953\n",
      "Epoch 080 | Train Loss: 0.0100 | Val Loss: 2.8384\n",
      "Epoch 100 | Train Loss: 0.0106 | Val Loss: 2.6548\n",
      "Epoch 120 | Train Loss: 0.0096 | Val Loss: 2.5885\n",
      "Epoch 140 | Train Loss: 0.0089 | Val Loss: 2.5593\n",
      "Epoch 160 | Train Loss: 0.0083 | Val Loss: 2.5501\n",
      "Epoch 180 | Train Loss: 0.0077 | Val Loss: 2.5536\n",
      "Epoch 200 | Train Loss: 0.0072 | Val Loss: 2.5612\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/30_70/CiteSeer_GraphSAGE_30_70_seed42.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_30_70_masked_indices_seed46.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 999 | Test nodes: 2328\n",
      "Epoch 001 | Train Loss: 5.1578 | Val Loss: 5.1648\n",
      "Epoch 020 | Train Loss: 0.0324 | Val Loss: 2.7455\n",
      "Epoch 040 | Train Loss: 0.0031 | Val Loss: 3.4670\n",
      "Epoch 060 | Train Loss: 0.0051 | Val Loss: 3.1723\n",
      "Epoch 080 | Train Loss: 0.0099 | Val Loss: 2.8165\n",
      "Epoch 100 | Train Loss: 0.0104 | Val Loss: 2.6337\n",
      "Epoch 120 | Train Loss: 0.0094 | Val Loss: 2.5665\n",
      "Epoch 140 | Train Loss: 0.0087 | Val Loss: 2.5385\n",
      "Epoch 160 | Train Loss: 0.0081 | Val Loss: 2.5295\n",
      "Epoch 180 | Train Loss: 0.0075 | Val Loss: 2.5329\n",
      "Epoch 200 | Train Loss: 0.0070 | Val Loss: 2.5415\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/30_70/CiteSeer_GraphSAGE_30_70_seed46.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_30_70_masked_indices_seed999.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 999 | Test nodes: 2328\n",
      "Epoch 001 | Train Loss: 5.0695 | Val Loss: 5.0729\n",
      "Epoch 020 | Train Loss: 0.0365 | Val Loss: 2.7317\n",
      "Epoch 040 | Train Loss: 0.0035 | Val Loss: 3.4785\n",
      "Epoch 060 | Train Loss: 0.0055 | Val Loss: 3.1909\n",
      "Epoch 080 | Train Loss: 0.0104 | Val Loss: 2.8356\n",
      "Epoch 100 | Train Loss: 0.0109 | Val Loss: 2.6668\n",
      "Epoch 120 | Train Loss: 0.0097 | Val Loss: 2.6104\n",
      "Epoch 140 | Train Loss: 0.0090 | Val Loss: 2.5810\n",
      "Epoch 160 | Train Loss: 0.0084 | Val Loss: 2.5717\n",
      "Epoch 180 | Train Loss: 0.0078 | Val Loss: 2.5742\n",
      "Epoch 200 | Train Loss: 0.0073 | Val Loss: 2.5818\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/30_70/CiteSeer_GraphSAGE_30_70_seed999.pt\n",
      "Saved averaged results and execution times for CiteSeer split 30_70\n",
      "\n",
      "=== Processing Mask File: CiteSeer_70_30_masked_indices_seed123.npy (70_30, GCN) ===\n",
      "Train nodes: 2329 | Test nodes: 998\n",
      "Epoch 001 | Train Loss: 5.1319 | Val Loss: 5.1186\n",
      "Epoch 020 | Train Loss: 0.9669 | Val Loss: 1.5056\n",
      "Epoch 040 | Train Loss: 0.4603 | Val Loss: 1.2917\n",
      "Epoch 060 | Train Loss: 0.2437 | Val Loss: 1.3137\n",
      "Epoch 080 | Train Loss: 0.1737 | Val Loss: 1.3820\n",
      "Epoch 100 | Train Loss: 0.1493 | Val Loss: 1.4145\n",
      "Epoch 120 | Train Loss: 0.1361 | Val Loss: 1.4373\n",
      "Epoch 140 | Train Loss: 0.1249 | Val Loss: 1.4693\n",
      "Epoch 160 | Train Loss: 0.1155 | Val Loss: 1.5030\n",
      "Epoch 180 | Train Loss: 0.1085 | Val Loss: 1.5359\n",
      "Epoch 200 | Train Loss: 0.1031 | Val Loss: 1.5602\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/70_30/CiteSeer_GCN_70_30_seed123.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_70_30_masked_indices_seed2025.npy (70_30, GCN) ===\n",
      "Train nodes: 2329 | Test nodes: 998\n",
      "Epoch 001 | Train Loss: 5.1632 | Val Loss: 5.1645\n",
      "Epoch 020 | Train Loss: 0.9674 | Val Loss: 1.5220\n",
      "Epoch 040 | Train Loss: 0.4578 | Val Loss: 1.4016\n",
      "Epoch 060 | Train Loss: 0.2355 | Val Loss: 1.4478\n",
      "Epoch 080 | Train Loss: 0.1646 | Val Loss: 1.5434\n",
      "Epoch 100 | Train Loss: 0.1411 | Val Loss: 1.5873\n",
      "Epoch 120 | Train Loss: 0.1289 | Val Loss: 1.6022\n",
      "Epoch 140 | Train Loss: 0.1185 | Val Loss: 1.6269\n",
      "Epoch 160 | Train Loss: 0.1095 | Val Loss: 1.6577\n",
      "Epoch 180 | Train Loss: 0.1028 | Val Loss: 1.6871\n",
      "Epoch 200 | Train Loss: 0.0977 | Val Loss: 1.7077\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/70_30/CiteSeer_GCN_70_30_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_70_30_masked_indices_seed42.npy (70_30, GCN) ===\n",
      "Train nodes: 2329 | Test nodes: 998\n",
      "Epoch 001 | Train Loss: 5.0543 | Val Loss: 5.0651\n",
      "Epoch 020 | Train Loss: 0.9053 | Val Loss: 1.5361\n",
      "Epoch 040 | Train Loss: 0.3985 | Val Loss: 1.4121\n",
      "Epoch 060 | Train Loss: 0.2094 | Val Loss: 1.5201\n",
      "Epoch 080 | Train Loss: 0.1538 | Val Loss: 1.6205\n",
      "Epoch 100 | Train Loss: 0.1342 | Val Loss: 1.6566\n",
      "Epoch 120 | Train Loss: 0.1227 | Val Loss: 1.6846\n",
      "Epoch 140 | Train Loss: 0.1125 | Val Loss: 1.7159\n",
      "Epoch 160 | Train Loss: 0.1040 | Val Loss: 1.7526\n",
      "Epoch 180 | Train Loss: 0.0978 | Val Loss: 1.7823\n",
      "Epoch 200 | Train Loss: 0.0928 | Val Loss: 1.8047\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/70_30/CiteSeer_GCN_70_30_seed42.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_70_30_masked_indices_seed46.npy (70_30, GCN) ===\n",
      "Train nodes: 2329 | Test nodes: 998\n",
      "Epoch 001 | Train Loss: 5.2760 | Val Loss: 5.2827\n",
      "Epoch 020 | Train Loss: 0.9478 | Val Loss: 1.5676\n",
      "Epoch 040 | Train Loss: 0.4451 | Val Loss: 1.3969\n",
      "Epoch 060 | Train Loss: 0.2323 | Val Loss: 1.4630\n",
      "Epoch 080 | Train Loss: 0.1672 | Val Loss: 1.5369\n",
      "Epoch 100 | Train Loss: 0.1450 | Val Loss: 1.5676\n",
      "Epoch 120 | Train Loss: 0.1325 | Val Loss: 1.5863\n",
      "Epoch 140 | Train Loss: 0.1219 | Val Loss: 1.6118\n",
      "Epoch 160 | Train Loss: 0.1129 | Val Loss: 1.6379\n",
      "Epoch 180 | Train Loss: 0.1059 | Val Loss: 1.6642\n",
      "Epoch 200 | Train Loss: 0.1006 | Val Loss: 1.6861\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/70_30/CiteSeer_GCN_70_30_seed46.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_70_30_masked_indices_seed999.npy (70_30, GCN) ===\n",
      "Train nodes: 2329 | Test nodes: 998\n",
      "Epoch 001 | Train Loss: 5.1094 | Val Loss: 5.1239\n",
      "Epoch 020 | Train Loss: 0.9473 | Val Loss: 1.5036\n",
      "Epoch 040 | Train Loss: 0.4265 | Val Loss: 1.3504\n",
      "Epoch 060 | Train Loss: 0.2159 | Val Loss: 1.4148\n",
      "Epoch 080 | Train Loss: 0.1560 | Val Loss: 1.5126\n",
      "Epoch 100 | Train Loss: 0.1363 | Val Loss: 1.5585\n",
      "Epoch 120 | Train Loss: 0.1251 | Val Loss: 1.5936\n",
      "Epoch 140 | Train Loss: 0.1149 | Val Loss: 1.6273\n",
      "Epoch 160 | Train Loss: 0.1062 | Val Loss: 1.6618\n",
      "Epoch 180 | Train Loss: 0.0996 | Val Loss: 1.6850\n",
      "Epoch 200 | Train Loss: 0.0945 | Val Loss: 1.7064\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/70_30/CiteSeer_GCN_70_30_seed999.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_70_30_masked_indices_seed123.npy (70_30, GAT) ===\n",
      "Train nodes: 2329 | Test nodes: 998\n",
      "Epoch 001 | Train Loss: 5.0364 | Val Loss: 5.0500\n",
      "Epoch 020 | Train Loss: 0.2470 | Val Loss: 1.8547\n",
      "Epoch 040 | Train Loss: 0.2550 | Val Loss: 2.2692\n",
      "Epoch 060 | Train Loss: 0.2240 | Val Loss: 2.2473\n",
      "Epoch 080 | Train Loss: 0.1776 | Val Loss: 2.3778\n",
      "Epoch 100 | Train Loss: 0.1695 | Val Loss: 2.2244\n",
      "Epoch 120 | Train Loss: 0.1607 | Val Loss: 2.1240\n",
      "Epoch 140 | Train Loss: 0.1525 | Val Loss: 2.0443\n",
      "Epoch 160 | Train Loss: 0.1384 | Val Loss: 2.0438\n",
      "Epoch 180 | Train Loss: 0.1298 | Val Loss: 2.0922\n",
      "Epoch 200 | Train Loss: 0.1211 | Val Loss: 2.1945\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/70_30/CiteSeer_GAT_70_30_seed123.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_70_30_masked_indices_seed2025.npy (70_30, GAT) ===\n",
      "Train nodes: 2329 | Test nodes: 998\n",
      "Epoch 001 | Train Loss: 5.0831 | Val Loss: 5.0941\n",
      "Epoch 020 | Train Loss: 0.2726 | Val Loss: 1.8487\n",
      "Epoch 040 | Train Loss: 0.2621 | Val Loss: 2.1946\n",
      "Epoch 060 | Train Loss: 0.2395 | Val Loss: 2.2306\n",
      "Epoch 080 | Train Loss: 0.2258 | Val Loss: 2.2531\n",
      "Epoch 100 | Train Loss: 0.1857 | Val Loss: 2.2328\n",
      "Epoch 120 | Train Loss: 0.1735 | Val Loss: 2.1185\n",
      "Epoch 140 | Train Loss: 0.1626 | Val Loss: 2.0694\n",
      "Epoch 160 | Train Loss: 0.1494 | Val Loss: 2.0985\n",
      "Epoch 180 | Train Loss: 0.1288 | Val Loss: 2.0748\n",
      "Epoch 200 | Train Loss: 0.1151 | Val Loss: 2.1309\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/70_30/CiteSeer_GAT_70_30_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_70_30_masked_indices_seed42.npy (70_30, GAT) ===\n",
      "Train nodes: 2329 | Test nodes: 998\n",
      "Epoch 001 | Train Loss: 5.0498 | Val Loss: 5.0548\n",
      "Epoch 020 | Train Loss: 0.2030 | Val Loss: 2.0731\n",
      "Epoch 040 | Train Loss: 0.2055 | Val Loss: 2.4594\n",
      "Epoch 060 | Train Loss: 0.1798 | Val Loss: 2.3820\n",
      "Epoch 080 | Train Loss: 0.1968 | Val Loss: 2.3767\n",
      "Epoch 100 | Train Loss: 0.2110 | Val Loss: 2.4989\n",
      "Epoch 120 | Train Loss: 0.1620 | Val Loss: 2.2996\n",
      "Epoch 140 | Train Loss: 0.1340 | Val Loss: 2.3321\n",
      "Epoch 160 | Train Loss: 0.1270 | Val Loss: 2.2212\n",
      "Epoch 180 | Train Loss: 0.1213 | Val Loss: 2.1358\n",
      "Epoch 200 | Train Loss: 0.1146 | Val Loss: 2.1554\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/70_30/CiteSeer_GAT_70_30_seed42.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_70_30_masked_indices_seed46.npy (70_30, GAT) ===\n",
      "Train nodes: 2329 | Test nodes: 998\n",
      "Epoch 001 | Train Loss: 5.0759 | Val Loss: 5.0923\n",
      "Epoch 020 | Train Loss: 0.2683 | Val Loss: 2.0766\n",
      "Epoch 040 | Train Loss: 0.2573 | Val Loss: 2.5375\n",
      "Epoch 060 | Train Loss: 0.2569 | Val Loss: 2.4388\n",
      "Epoch 080 | Train Loss: 0.2034 | Val Loss: 2.3548\n",
      "Epoch 100 | Train Loss: 0.1766 | Val Loss: 2.3751\n",
      "Epoch 120 | Train Loss: 0.1638 | Val Loss: 2.3168\n",
      "Epoch 140 | Train Loss: 0.1540 | Val Loss: 2.1912\n",
      "Epoch 160 | Train Loss: 0.1396 | Val Loss: 2.2122\n",
      "Epoch 180 | Train Loss: 0.1371 | Val Loss: 2.2487\n",
      "Epoch 200 | Train Loss: 0.1381 | Val Loss: 2.2341\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/70_30/CiteSeer_GAT_70_30_seed46.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_70_30_masked_indices_seed999.npy (70_30, GAT) ===\n",
      "Train nodes: 2329 | Test nodes: 998\n",
      "Epoch 001 | Train Loss: 5.0552 | Val Loss: 5.0600\n",
      "Epoch 020 | Train Loss: 0.2481 | Val Loss: 1.9942\n",
      "Epoch 040 | Train Loss: 0.2218 | Val Loss: 2.3141\n",
      "Epoch 060 | Train Loss: 0.2518 | Val Loss: 2.3888\n",
      "Epoch 080 | Train Loss: 0.2334 | Val Loss: 2.2463\n",
      "Epoch 100 | Train Loss: 0.1801 | Val Loss: 2.1602\n",
      "Epoch 120 | Train Loss: 0.1564 | Val Loss: 2.1947\n",
      "Epoch 140 | Train Loss: 0.1489 | Val Loss: 2.1321\n",
      "Epoch 160 | Train Loss: 0.1421 | Val Loss: 2.0215\n",
      "Epoch 180 | Train Loss: 0.1386 | Val Loss: 2.0080\n",
      "Epoch 200 | Train Loss: 0.1376 | Val Loss: 2.0655\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/70_30/CiteSeer_GAT_70_30_seed999.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_70_30_masked_indices_seed123.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 2329 | Test nodes: 998\n",
      "Epoch 001 | Train Loss: 5.0176 | Val Loss: 5.0409\n",
      "Epoch 020 | Train Loss: 0.2050 | Val Loss: 2.0586\n",
      "Epoch 040 | Train Loss: 0.0140 | Val Loss: 2.4475\n",
      "Epoch 060 | Train Loss: 0.0124 | Val Loss: 2.3203\n",
      "Epoch 080 | Train Loss: 0.0192 | Val Loss: 2.0932\n",
      "Epoch 100 | Train Loss: 0.0189 | Val Loss: 1.9701\n",
      "Epoch 120 | Train Loss: 0.0164 | Val Loss: 1.9141\n",
      "Epoch 140 | Train Loss: 0.0149 | Val Loss: 1.8767\n",
      "Epoch 160 | Train Loss: 0.0138 | Val Loss: 1.8533\n",
      "Epoch 180 | Train Loss: 0.0127 | Val Loss: 1.8418\n",
      "Epoch 200 | Train Loss: 0.0118 | Val Loss: 1.8328\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/70_30/CiteSeer_GraphSAGE_70_30_seed123.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_70_30_masked_indices_seed2025.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 2329 | Test nodes: 998\n",
      "Epoch 001 | Train Loss: 5.1289 | Val Loss: 5.1433\n",
      "Epoch 020 | Train Loss: 0.1988 | Val Loss: 1.8917\n",
      "Epoch 040 | Train Loss: 0.0130 | Val Loss: 2.2146\n",
      "Epoch 060 | Train Loss: 0.0118 | Val Loss: 2.1032\n",
      "Epoch 080 | Train Loss: 0.0184 | Val Loss: 1.9023\n",
      "Epoch 100 | Train Loss: 0.0183 | Val Loss: 1.7879\n",
      "Epoch 120 | Train Loss: 0.0159 | Val Loss: 1.7431\n",
      "Epoch 140 | Train Loss: 0.0146 | Val Loss: 1.7128\n",
      "Epoch 160 | Train Loss: 0.0134 | Val Loss: 1.6971\n",
      "Epoch 180 | Train Loss: 0.0124 | Val Loss: 1.6807\n",
      "Epoch 200 | Train Loss: 0.0116 | Val Loss: 1.6780\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/70_30/CiteSeer_GraphSAGE_70_30_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_70_30_masked_indices_seed42.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 2329 | Test nodes: 998\n",
      "Epoch 001 | Train Loss: 5.0513 | Val Loss: 5.0642\n",
      "Epoch 020 | Train Loss: 0.2111 | Val Loss: 2.0171\n",
      "Epoch 040 | Train Loss: 0.0151 | Val Loss: 2.3444\n",
      "Epoch 060 | Train Loss: 0.0125 | Val Loss: 2.2212\n",
      "Epoch 080 | Train Loss: 0.0191 | Val Loss: 2.0073\n",
      "Epoch 100 | Train Loss: 0.0190 | Val Loss: 1.8754\n",
      "Epoch 120 | Train Loss: 0.0165 | Val Loss: 1.8241\n",
      "Epoch 140 | Train Loss: 0.0151 | Val Loss: 1.7977\n",
      "Epoch 160 | Train Loss: 0.0139 | Val Loss: 1.7800\n",
      "Epoch 180 | Train Loss: 0.0128 | Val Loss: 1.7737\n",
      "Epoch 200 | Train Loss: 0.0119 | Val Loss: 1.7748\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/70_30/CiteSeer_GraphSAGE_70_30_seed42.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_70_30_masked_indices_seed46.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 2329 | Test nodes: 998\n",
      "Epoch 001 | Train Loss: 5.2293 | Val Loss: 5.2531\n",
      "Epoch 020 | Train Loss: 0.2234 | Val Loss: 2.0771\n",
      "Epoch 040 | Train Loss: 0.0153 | Val Loss: 2.4287\n",
      "Epoch 060 | Train Loss: 0.0125 | Val Loss: 2.3361\n",
      "Epoch 080 | Train Loss: 0.0190 | Val Loss: 2.1244\n",
      "Epoch 100 | Train Loss: 0.0191 | Val Loss: 1.9939\n",
      "Epoch 120 | Train Loss: 0.0166 | Val Loss: 1.9412\n",
      "Epoch 140 | Train Loss: 0.0151 | Val Loss: 1.9018\n",
      "Epoch 160 | Train Loss: 0.0139 | Val Loss: 1.8802\n",
      "Epoch 180 | Train Loss: 0.0128 | Val Loss: 1.8669\n",
      "Epoch 200 | Train Loss: 0.0119 | Val Loss: 1.8606\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/70_30/CiteSeer_GraphSAGE_70_30_seed46.pt\n",
      "\n",
      "=== Processing Mask File: CiteSeer_70_30_masked_indices_seed999.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 2329 | Test nodes: 998\n",
      "Epoch 001 | Train Loss: 5.0692 | Val Loss: 5.0587\n",
      "Epoch 020 | Train Loss: 0.2124 | Val Loss: 1.9614\n",
      "Epoch 040 | Train Loss: 0.0142 | Val Loss: 2.3162\n",
      "Epoch 060 | Train Loss: 0.0125 | Val Loss: 2.2063\n",
      "Epoch 080 | Train Loss: 0.0193 | Val Loss: 1.9858\n",
      "Epoch 100 | Train Loss: 0.0190 | Val Loss: 1.8726\n",
      "Epoch 120 | Train Loss: 0.0165 | Val Loss: 1.8274\n",
      "Epoch 140 | Train Loss: 0.0150 | Val Loss: 1.8025\n",
      "Epoch 160 | Train Loss: 0.0138 | Val Loss: 1.7920\n",
      "Epoch 180 | Train Loss: 0.0128 | Val Loss: 1.7875\n",
      "Epoch 200 | Train Loss: 0.0119 | Val Loss: 1.7831\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/CiteSeer/70_30/CiteSeer_GraphSAGE_70_30_seed999.pt\n",
      "Saved averaged results and execution times for CiteSeer split 70_30\n",
      "\n",
      "========== Dataset: PubMed ==========\n",
      "\n",
      "=== Processing Mask File: PubMed_30_70_masked_indices_seed123.npy (30_70, GCN) ===\n",
      "Train nodes: 5916 | Test nodes: 13801\n",
      "Epoch 001 | Train Loss: 5.0171 | Val Loss: 5.0162\n",
      "Epoch 020 | Train Loss: 0.9356 | Val Loss: 1.0588\n",
      "Epoch 040 | Train Loss: 0.7969 | Val Loss: 0.9867\n",
      "Epoch 060 | Train Loss: 0.6015 | Val Loss: 0.9266\n",
      "Epoch 080 | Train Loss: 0.4045 | Val Loss: 0.8957\n",
      "Epoch 100 | Train Loss: 0.2785 | Val Loss: 0.9045\n",
      "Epoch 120 | Train Loss: 0.2133 | Val Loss: 0.9242\n",
      "Epoch 140 | Train Loss: 0.1776 | Val Loss: 0.9360\n",
      "Epoch 160 | Train Loss: 0.1542 | Val Loss: 0.9479\n",
      "Epoch 180 | Train Loss: 0.1376 | Val Loss: 0.9594\n",
      "Epoch 200 | Train Loss: 0.1250 | Val Loss: 0.9689\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/30_70/PubMed_GCN_30_70_seed123.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_30_70_masked_indices_seed2025.npy (30_70, GCN) ===\n",
      "Train nodes: 5916 | Test nodes: 13801\n",
      "Epoch 001 | Train Loss: 5.0147 | Val Loss: 5.0198\n",
      "Epoch 020 | Train Loss: 0.9281 | Val Loss: 1.0609\n",
      "Epoch 040 | Train Loss: 0.7889 | Val Loss: 0.9843\n",
      "Epoch 060 | Train Loss: 0.6047 | Val Loss: 0.9268\n",
      "Epoch 080 | Train Loss: 0.4168 | Val Loss: 0.8912\n",
      "Epoch 100 | Train Loss: 0.2913 | Val Loss: 0.8971\n",
      "Epoch 120 | Train Loss: 0.2236 | Val Loss: 0.9111\n",
      "Epoch 140 | Train Loss: 0.1859 | Val Loss: 0.9243\n",
      "Epoch 160 | Train Loss: 0.1612 | Val Loss: 0.9330\n",
      "Epoch 180 | Train Loss: 0.1434 | Val Loss: 0.9432\n",
      "Epoch 200 | Train Loss: 0.1302 | Val Loss: 0.9526\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/30_70/PubMed_GCN_30_70_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_30_70_masked_indices_seed42.npy (30_70, GCN) ===\n",
      "Train nodes: 5916 | Test nodes: 13801\n",
      "Epoch 001 | Train Loss: 5.0342 | Val Loss: 5.0371\n",
      "Epoch 020 | Train Loss: 0.9363 | Val Loss: 1.0598\n",
      "Epoch 040 | Train Loss: 0.7910 | Val Loss: 0.9802\n",
      "Epoch 060 | Train Loss: 0.6003 | Val Loss: 0.9209\n",
      "Epoch 080 | Train Loss: 0.4099 | Val Loss: 0.8848\n",
      "Epoch 100 | Train Loss: 0.2846 | Val Loss: 0.8900\n",
      "Epoch 120 | Train Loss: 0.2185 | Val Loss: 0.9047\n",
      "Epoch 140 | Train Loss: 0.1818 | Val Loss: 0.9167\n",
      "Epoch 160 | Train Loss: 0.1578 | Val Loss: 0.9270\n",
      "Epoch 180 | Train Loss: 0.1403 | Val Loss: 0.9364\n",
      "Epoch 200 | Train Loss: 0.1270 | Val Loss: 0.9444\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/30_70/PubMed_GCN_30_70_seed42.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_30_70_masked_indices_seed46.npy (30_70, GCN) ===\n",
      "Train nodes: 5916 | Test nodes: 13801\n",
      "Epoch 001 | Train Loss: 5.0735 | Val Loss: 5.0721\n",
      "Epoch 020 | Train Loss: 0.9393 | Val Loss: 1.0572\n",
      "Epoch 040 | Train Loss: 0.8013 | Val Loss: 0.9883\n",
      "Epoch 060 | Train Loss: 0.6082 | Val Loss: 0.9288\n",
      "Epoch 080 | Train Loss: 0.4066 | Val Loss: 0.8960\n",
      "Epoch 100 | Train Loss: 0.2774 | Val Loss: 0.9050\n",
      "Epoch 120 | Train Loss: 0.2124 | Val Loss: 0.9239\n",
      "Epoch 140 | Train Loss: 0.1768 | Val Loss: 0.9359\n",
      "Epoch 160 | Train Loss: 0.1536 | Val Loss: 0.9457\n",
      "Epoch 180 | Train Loss: 0.1369 | Val Loss: 0.9543\n",
      "Epoch 200 | Train Loss: 0.1244 | Val Loss: 0.9626\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/30_70/PubMed_GCN_30_70_seed46.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_30_70_masked_indices_seed999.npy (30_70, GCN) ===\n",
      "Train nodes: 5916 | Test nodes: 13801\n",
      "Epoch 001 | Train Loss: 5.0854 | Val Loss: 5.0784\n",
      "Epoch 020 | Train Loss: 0.9330 | Val Loss: 1.0563\n",
      "Epoch 040 | Train Loss: 0.7888 | Val Loss: 0.9861\n",
      "Epoch 060 | Train Loss: 0.5951 | Val Loss: 0.9297\n",
      "Epoch 080 | Train Loss: 0.4005 | Val Loss: 0.9026\n",
      "Epoch 100 | Train Loss: 0.2761 | Val Loss: 0.9144\n",
      "Epoch 120 | Train Loss: 0.2132 | Val Loss: 0.9354\n",
      "Epoch 140 | Train Loss: 0.1784 | Val Loss: 0.9494\n",
      "Epoch 160 | Train Loss: 0.1548 | Val Loss: 0.9609\n",
      "Epoch 180 | Train Loss: 0.1381 | Val Loss: 0.9716\n",
      "Epoch 200 | Train Loss: 0.1255 | Val Loss: 0.9821\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/30_70/PubMed_GCN_30_70_seed999.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_30_70_masked_indices_seed123.npy (30_70, GAT) ===\n",
      "Train nodes: 5916 | Test nodes: 13801\n",
      "Epoch 001 | Train Loss: 5.0374 | Val Loss: 5.0373\n",
      "Epoch 020 | Train Loss: 0.7188 | Val Loss: 0.9971\n",
      "Epoch 040 | Train Loss: 0.3551 | Val Loss: 0.7298\n",
      "Epoch 060 | Train Loss: 0.2541 | Val Loss: 0.7948\n",
      "Epoch 080 | Train Loss: 0.2005 | Val Loss: 0.9211\n",
      "Epoch 100 | Train Loss: 0.1679 | Val Loss: 1.0400\n",
      "Epoch 120 | Train Loss: 0.1571 | Val Loss: 1.1178\n",
      "Epoch 140 | Train Loss: 0.1498 | Val Loss: 1.1514\n",
      "Epoch 160 | Train Loss: 0.2205 | Val Loss: 1.0282\n",
      "Epoch 180 | Train Loss: 0.1612 | Val Loss: 1.1434\n",
      "Epoch 200 | Train Loss: 0.1453 | Val Loss: 1.2027\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/30_70/PubMed_GAT_30_70_seed123.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_30_70_masked_indices_seed2025.npy (30_70, GAT) ===\n",
      "Train nodes: 5916 | Test nodes: 13801\n",
      "Epoch 001 | Train Loss: 5.0320 | Val Loss: 5.0303\n",
      "Epoch 020 | Train Loss: 0.6434 | Val Loss: 0.9354\n",
      "Epoch 040 | Train Loss: 0.3519 | Val Loss: 0.7361\n",
      "Epoch 060 | Train Loss: 0.2575 | Val Loss: 0.8194\n",
      "Epoch 080 | Train Loss: 0.2063 | Val Loss: 0.9390\n",
      "Epoch 100 | Train Loss: 0.1796 | Val Loss: 1.0574\n",
      "Epoch 120 | Train Loss: 0.1643 | Val Loss: 1.1361\n",
      "Epoch 140 | Train Loss: 0.2414 | Val Loss: 1.0531\n",
      "Epoch 160 | Train Loss: 0.1775 | Val Loss: 1.0809\n",
      "Epoch 180 | Train Loss: 0.1598 | Val Loss: 1.1576\n",
      "Epoch 200 | Train Loss: 0.1512 | Val Loss: 1.1821\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/30_70/PubMed_GAT_30_70_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_30_70_masked_indices_seed42.npy (30_70, GAT) ===\n",
      "Train nodes: 5916 | Test nodes: 13801\n",
      "Epoch 001 | Train Loss: 5.0584 | Val Loss: 5.0601\n",
      "Epoch 020 | Train Loss: 0.7762 | Val Loss: 0.9941\n",
      "Epoch 040 | Train Loss: 0.3784 | Val Loss: 0.7638\n",
      "Epoch 060 | Train Loss: 0.2496 | Val Loss: 0.8257\n",
      "Epoch 080 | Train Loss: 0.1978 | Val Loss: 0.9585\n",
      "Epoch 100 | Train Loss: 0.1848 | Val Loss: 1.0868\n",
      "Epoch 120 | Train Loss: 0.1631 | Val Loss: 1.1456\n",
      "Epoch 140 | Train Loss: 0.1520 | Val Loss: 1.1775\n",
      "Epoch 160 | Train Loss: 0.1429 | Val Loss: 1.2165\n",
      "Epoch 180 | Train Loss: 0.2569 | Val Loss: 1.0053\n",
      "Epoch 200 | Train Loss: 0.1723 | Val Loss: 1.1074\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/30_70/PubMed_GAT_30_70_seed42.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_30_70_masked_indices_seed46.npy (30_70, GAT) ===\n",
      "Train nodes: 5916 | Test nodes: 13801\n",
      "Epoch 001 | Train Loss: 5.0385 | Val Loss: 5.0389\n",
      "Epoch 020 | Train Loss: 0.4971 | Val Loss: 0.8985\n",
      "Epoch 040 | Train Loss: 0.2574 | Val Loss: 0.8710\n",
      "Epoch 060 | Train Loss: 0.2112 | Val Loss: 1.0366\n",
      "Epoch 080 | Train Loss: 0.1925 | Val Loss: 1.1188\n",
      "Epoch 100 | Train Loss: 0.1829 | Val Loss: 1.1548\n",
      "Epoch 120 | Train Loss: 0.1732 | Val Loss: 1.1692\n",
      "Epoch 140 | Train Loss: 0.1531 | Val Loss: 1.1806\n",
      "Epoch 160 | Train Loss: 0.1427 | Val Loss: 1.2515\n",
      "Epoch 180 | Train Loss: 0.1391 | Val Loss: 1.2380\n",
      "Epoch 200 | Train Loss: 0.1619 | Val Loss: 1.2559\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/30_70/PubMed_GAT_30_70_seed46.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_30_70_masked_indices_seed999.npy (30_70, GAT) ===\n",
      "Train nodes: 5916 | Test nodes: 13801\n",
      "Epoch 001 | Train Loss: 5.0421 | Val Loss: 5.0346\n",
      "Epoch 020 | Train Loss: 0.6535 | Val Loss: 0.8857\n",
      "Epoch 040 | Train Loss: 0.3682 | Val Loss: 0.7140\n",
      "Epoch 060 | Train Loss: 0.2642 | Val Loss: 0.7778\n",
      "Epoch 080 | Train Loss: 0.2013 | Val Loss: 0.8809\n",
      "Epoch 100 | Train Loss: 0.1719 | Val Loss: 0.9951\n",
      "Epoch 120 | Train Loss: 0.2227 | Val Loss: 0.9710\n",
      "Epoch 140 | Train Loss: 0.1704 | Val Loss: 1.0364\n",
      "Epoch 160 | Train Loss: 0.1549 | Val Loss: 1.1053\n",
      "Epoch 180 | Train Loss: 0.1435 | Val Loss: 1.1373\n",
      "Epoch 200 | Train Loss: 0.1358 | Val Loss: 1.1794\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/30_70/PubMed_GAT_30_70_seed999.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_30_70_masked_indices_seed123.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 5916 | Test nodes: 13801\n",
      "Epoch 001 | Train Loss: 4.9238 | Val Loss: 4.9303\n",
      "Epoch 020 | Train Loss: 0.4597 | Val Loss: 0.9225\n",
      "Epoch 040 | Train Loss: 0.1041 | Val Loss: 0.9725\n",
      "Epoch 060 | Train Loss: 0.0363 | Val Loss: 1.0696\n",
      "Epoch 080 | Train Loss: 0.0326 | Val Loss: 1.0597\n",
      "Epoch 100 | Train Loss: 0.0311 | Val Loss: 1.0472\n",
      "Epoch 120 | Train Loss: 0.0271 | Val Loss: 1.0512\n",
      "Epoch 140 | Train Loss: 0.0241 | Val Loss: 1.0563\n",
      "Epoch 160 | Train Loss: 0.0218 | Val Loss: 1.0628\n",
      "Epoch 180 | Train Loss: 0.0198 | Val Loss: 1.0713\n",
      "Epoch 200 | Train Loss: 0.0182 | Val Loss: 1.0799\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/30_70/PubMed_GraphSAGE_30_70_seed123.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_30_70_masked_indices_seed2025.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 5916 | Test nodes: 13801\n",
      "Epoch 001 | Train Loss: 5.1174 | Val Loss: 5.1142\n",
      "Epoch 020 | Train Loss: 0.4451 | Val Loss: 0.8978\n",
      "Epoch 040 | Train Loss: 0.0957 | Val Loss: 0.9559\n",
      "Epoch 060 | Train Loss: 0.0339 | Val Loss: 1.0478\n",
      "Epoch 080 | Train Loss: 0.0313 | Val Loss: 1.0366\n",
      "Epoch 100 | Train Loss: 0.0298 | Val Loss: 1.0216\n",
      "Epoch 120 | Train Loss: 0.0260 | Val Loss: 1.0224\n",
      "Epoch 140 | Train Loss: 0.0231 | Val Loss: 1.0286\n",
      "Epoch 160 | Train Loss: 0.0209 | Val Loss: 1.0346\n",
      "Epoch 180 | Train Loss: 0.0191 | Val Loss: 1.0410\n",
      "Epoch 200 | Train Loss: 0.0176 | Val Loss: 1.0466\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/30_70/PubMed_GraphSAGE_30_70_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_30_70_masked_indices_seed42.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 5916 | Test nodes: 13801\n",
      "Epoch 001 | Train Loss: 5.1209 | Val Loss: 5.1313\n",
      "Epoch 020 | Train Loss: 0.4656 | Val Loss: 0.9152\n",
      "Epoch 040 | Train Loss: 0.1026 | Val Loss: 0.9700\n",
      "Epoch 060 | Train Loss: 0.0350 | Val Loss: 1.0558\n",
      "Epoch 080 | Train Loss: 0.0318 | Val Loss: 1.0388\n",
      "Epoch 100 | Train Loss: 0.0302 | Val Loss: 1.0213\n",
      "Epoch 120 | Train Loss: 0.0263 | Val Loss: 1.0211\n",
      "Epoch 140 | Train Loss: 0.0234 | Val Loss: 1.0246\n",
      "Epoch 160 | Train Loss: 0.0212 | Val Loss: 1.0277\n",
      "Epoch 180 | Train Loss: 0.0194 | Val Loss: 1.0341\n",
      "Epoch 200 | Train Loss: 0.0178 | Val Loss: 1.0399\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/30_70/PubMed_GraphSAGE_30_70_seed42.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_30_70_masked_indices_seed46.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 5916 | Test nodes: 13801\n",
      "Epoch 001 | Train Loss: 5.1246 | Val Loss: 5.1250\n",
      "Epoch 020 | Train Loss: 0.4654 | Val Loss: 0.9172\n",
      "Epoch 040 | Train Loss: 0.1094 | Val Loss: 0.9487\n",
      "Epoch 060 | Train Loss: 0.0376 | Val Loss: 1.0435\n",
      "Epoch 080 | Train Loss: 0.0329 | Val Loss: 1.0345\n",
      "Epoch 100 | Train Loss: 0.0314 | Val Loss: 1.0221\n",
      "Epoch 120 | Train Loss: 0.0274 | Val Loss: 1.0218\n",
      "Epoch 140 | Train Loss: 0.0242 | Val Loss: 1.0258\n",
      "Epoch 160 | Train Loss: 0.0220 | Val Loss: 1.0309\n",
      "Epoch 180 | Train Loss: 0.0200 | Val Loss: 1.0380\n",
      "Epoch 200 | Train Loss: 0.0184 | Val Loss: 1.0455\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/30_70/PubMed_GraphSAGE_30_70_seed46.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_30_70_masked_indices_seed999.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 5916 | Test nodes: 13801\n",
      "Epoch 001 | Train Loss: 5.3460 | Val Loss: 5.3475\n",
      "Epoch 020 | Train Loss: 0.4685 | Val Loss: 0.9228\n",
      "Epoch 040 | Train Loss: 0.1111 | Val Loss: 0.9454\n",
      "Epoch 060 | Train Loss: 0.0374 | Val Loss: 1.0375\n",
      "Epoch 080 | Train Loss: 0.0320 | Val Loss: 1.0344\n",
      "Epoch 100 | Train Loss: 0.0307 | Val Loss: 1.0209\n",
      "Epoch 120 | Train Loss: 0.0271 | Val Loss: 1.0211\n",
      "Epoch 140 | Train Loss: 0.0241 | Val Loss: 1.0257\n",
      "Epoch 160 | Train Loss: 0.0218 | Val Loss: 1.0310\n",
      "Epoch 180 | Train Loss: 0.0199 | Val Loss: 1.0378\n",
      "Epoch 200 | Train Loss: 0.0183 | Val Loss: 1.0459\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/30_70/PubMed_GraphSAGE_30_70_seed999.pt\n",
      "Saved averaged results and execution times for PubMed split 30_70\n",
      "\n",
      "=== Processing Mask File: PubMed_70_30_masked_indices_seed123.npy (70_30, GCN) ===\n",
      "Train nodes: 13802 | Test nodes: 5915\n",
      "Epoch 001 | Train Loss: 5.0924 | Val Loss: 5.0887\n",
      "Epoch 020 | Train Loss: 0.9754 | Val Loss: 1.0229\n",
      "Epoch 040 | Train Loss: 0.8752 | Val Loss: 0.9542\n",
      "Epoch 060 | Train Loss: 0.7499 | Val Loss: 0.8858\n",
      "Epoch 080 | Train Loss: 0.6008 | Val Loss: 0.8157\n",
      "Epoch 100 | Train Loss: 0.4758 | Val Loss: 0.7817\n",
      "Epoch 120 | Train Loss: 0.3905 | Val Loss: 0.7715\n",
      "Epoch 140 | Train Loss: 0.3349 | Val Loss: 0.7727\n",
      "Epoch 160 | Train Loss: 0.2960 | Val Loss: 0.7768\n",
      "Epoch 180 | Train Loss: 0.2666 | Val Loss: 0.7846\n",
      "Epoch 200 | Train Loss: 0.2436 | Val Loss: 0.7906\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/70_30/PubMed_GCN_70_30_seed123.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_70_30_masked_indices_seed2025.npy (70_30, GCN) ===\n",
      "Train nodes: 13802 | Test nodes: 5915\n",
      "Epoch 001 | Train Loss: 4.9275 | Val Loss: 4.9267\n",
      "Epoch 020 | Train Loss: 0.9708 | Val Loss: 1.0363\n",
      "Epoch 040 | Train Loss: 0.8775 | Val Loss: 0.9657\n",
      "Epoch 060 | Train Loss: 0.7566 | Val Loss: 0.8995\n",
      "Epoch 080 | Train Loss: 0.6075 | Val Loss: 0.8285\n",
      "Epoch 100 | Train Loss: 0.4774 | Val Loss: 0.7874\n",
      "Epoch 120 | Train Loss: 0.3898 | Val Loss: 0.7735\n",
      "Epoch 140 | Train Loss: 0.3326 | Val Loss: 0.7735\n",
      "Epoch 160 | Train Loss: 0.2921 | Val Loss: 0.7757\n",
      "Epoch 180 | Train Loss: 0.2619 | Val Loss: 0.7828\n",
      "Epoch 200 | Train Loss: 0.2392 | Val Loss: 0.7894\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/70_30/PubMed_GCN_70_30_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_70_30_masked_indices_seed42.npy (70_30, GCN) ===\n",
      "Train nodes: 13802 | Test nodes: 5915\n",
      "Epoch 001 | Train Loss: 5.1647 | Val Loss: 5.1647\n",
      "Epoch 020 | Train Loss: 0.9836 | Val Loss: 1.0180\n",
      "Epoch 040 | Train Loss: 0.8852 | Val Loss: 0.9529\n",
      "Epoch 060 | Train Loss: 0.7598 | Val Loss: 0.8839\n",
      "Epoch 080 | Train Loss: 0.6083 | Val Loss: 0.8103\n",
      "Epoch 100 | Train Loss: 0.4804 | Val Loss: 0.7703\n",
      "Epoch 120 | Train Loss: 0.3962 | Val Loss: 0.7570\n",
      "Epoch 140 | Train Loss: 0.3401 | Val Loss: 0.7533\n",
      "Epoch 160 | Train Loss: 0.2999 | Val Loss: 0.7571\n",
      "Epoch 180 | Train Loss: 0.2696 | Val Loss: 0.7608\n",
      "Epoch 200 | Train Loss: 0.2463 | Val Loss: 0.7676\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/70_30/PubMed_GCN_70_30_seed42.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_70_30_masked_indices_seed46.npy (70_30, GCN) ===\n",
      "Train nodes: 13802 | Test nodes: 5915\n",
      "Epoch 001 | Train Loss: 5.0374 | Val Loss: 5.0340\n",
      "Epoch 020 | Train Loss: 0.9813 | Val Loss: 1.0290\n",
      "Epoch 040 | Train Loss: 0.8897 | Val Loss: 0.9592\n",
      "Epoch 060 | Train Loss: 0.7730 | Val Loss: 0.8921\n",
      "Epoch 080 | Train Loss: 0.6237 | Val Loss: 0.8186\n",
      "Epoch 100 | Train Loss: 0.4914 | Val Loss: 0.7761\n",
      "Epoch 120 | Train Loss: 0.4027 | Val Loss: 0.7617\n",
      "Epoch 140 | Train Loss: 0.3445 | Val Loss: 0.7587\n",
      "Epoch 160 | Train Loss: 0.3029 | Val Loss: 0.7634\n",
      "Epoch 180 | Train Loss: 0.2717 | Val Loss: 0.7716\n",
      "Epoch 200 | Train Loss: 0.2479 | Val Loss: 0.7774\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/70_30/PubMed_GCN_70_30_seed46.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_70_30_masked_indices_seed999.npy (70_30, GCN) ===\n",
      "Train nodes: 13802 | Test nodes: 5915\n",
      "Epoch 001 | Train Loss: 5.1765 | Val Loss: 5.1786\n",
      "Epoch 020 | Train Loss: 0.9815 | Val Loss: 1.0312\n",
      "Epoch 040 | Train Loss: 0.8867 | Val Loss: 0.9618\n",
      "Epoch 060 | Train Loss: 0.7673 | Val Loss: 0.8956\n",
      "Epoch 080 | Train Loss: 0.6174 | Val Loss: 0.8228\n",
      "Epoch 100 | Train Loss: 0.4875 | Val Loss: 0.7802\n",
      "Epoch 120 | Train Loss: 0.3992 | Val Loss: 0.7650\n",
      "Epoch 140 | Train Loss: 0.3412 | Val Loss: 0.7609\n",
      "Epoch 160 | Train Loss: 0.3001 | Val Loss: 0.7658\n",
      "Epoch 180 | Train Loss: 0.2692 | Val Loss: 0.7705\n",
      "Epoch 200 | Train Loss: 0.2453 | Val Loss: 0.7760\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/70_30/PubMed_GCN_70_30_seed999.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_70_30_masked_indices_seed123.npy (70_30, GAT) ===\n",
      "Train nodes: 13802 | Test nodes: 5915\n",
      "Epoch 001 | Train Loss: 5.0666 | Val Loss: 5.0699\n",
      "Epoch 020 | Train Loss: 0.5141 | Val Loss: 0.6495\n",
      "Epoch 040 | Train Loss: 0.3975 | Val Loss: 0.6222\n",
      "Epoch 060 | Train Loss: 0.3341 | Val Loss: 0.6436\n",
      "Epoch 080 | Train Loss: 0.2894 | Val Loss: 0.6868\n",
      "Epoch 100 | Train Loss: 0.2624 | Val Loss: 0.7538\n",
      "Epoch 120 | Train Loss: 0.2590 | Val Loss: 0.7781\n",
      "Epoch 140 | Train Loss: 0.2351 | Val Loss: 0.8036\n",
      "Epoch 160 | Train Loss: 0.2858 | Val Loss: 0.7969\n",
      "Epoch 180 | Train Loss: 0.2279 | Val Loss: 0.7939\n",
      "Epoch 200 | Train Loss: 0.2419 | Val Loss: 0.8940\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/70_30/PubMed_GAT_70_30_seed123.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_70_30_masked_indices_seed2025.npy (70_30, GAT) ===\n",
      "Train nodes: 13802 | Test nodes: 5915\n",
      "Epoch 001 | Train Loss: 5.0224 | Val Loss: 5.0194\n",
      "Epoch 020 | Train Loss: 0.6280 | Val Loss: 0.7932\n",
      "Epoch 040 | Train Loss: 0.4095 | Val Loss: 0.6174\n",
      "Epoch 060 | Train Loss: 0.3366 | Val Loss: 0.6184\n",
      "Epoch 080 | Train Loss: 0.2904 | Val Loss: 0.6436\n",
      "Epoch 100 | Train Loss: 0.2616 | Val Loss: 0.7004\n",
      "Epoch 120 | Train Loss: 0.2626 | Val Loss: 0.7751\n",
      "Epoch 140 | Train Loss: 0.2364 | Val Loss: 0.7755\n",
      "Epoch 160 | Train Loss: 0.3321 | Val Loss: 0.8817\n",
      "Epoch 180 | Train Loss: 0.2315 | Val Loss: 0.7735\n",
      "Epoch 200 | Train Loss: 0.2110 | Val Loss: 0.8253\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/70_30/PubMed_GAT_70_30_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_70_30_masked_indices_seed42.npy (70_30, GAT) ===\n",
      "Train nodes: 13802 | Test nodes: 5915\n",
      "Epoch 001 | Train Loss: 5.0491 | Val Loss: 5.0452\n",
      "Epoch 020 | Train Loss: 0.5279 | Val Loss: 0.6742\n",
      "Epoch 040 | Train Loss: 0.4169 | Val Loss: 0.6190\n",
      "Epoch 060 | Train Loss: 0.3415 | Val Loss: 0.6104\n",
      "Epoch 080 | Train Loss: 0.2928 | Val Loss: 0.6463\n",
      "Epoch 100 | Train Loss: 0.2684 | Val Loss: 0.7108\n",
      "Epoch 120 | Train Loss: 0.2620 | Val Loss: 0.7088\n",
      "Epoch 140 | Train Loss: 0.2388 | Val Loss: 0.7273\n",
      "Epoch 160 | Train Loss: 0.2324 | Val Loss: 0.7893\n",
      "Epoch 180 | Train Loss: 0.3686 | Val Loss: 0.8674\n",
      "Epoch 200 | Train Loss: 0.2359 | Val Loss: 0.7227\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/70_30/PubMed_GAT_70_30_seed42.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_70_30_masked_indices_seed46.npy (70_30, GAT) ===\n",
      "Train nodes: 13802 | Test nodes: 5915\n",
      "Epoch 001 | Train Loss: 5.0363 | Val Loss: 5.0342\n",
      "Epoch 020 | Train Loss: 0.5465 | Val Loss: 0.7185\n",
      "Epoch 040 | Train Loss: 0.3897 | Val Loss: 0.6280\n",
      "Epoch 060 | Train Loss: 0.3330 | Val Loss: 0.6468\n",
      "Epoch 080 | Train Loss: 0.2971 | Val Loss: 0.6785\n",
      "Epoch 100 | Train Loss: 0.3884 | Val Loss: 0.8045\n",
      "Epoch 120 | Train Loss: 0.2656 | Val Loss: 0.7040\n",
      "Epoch 140 | Train Loss: 0.2427 | Val Loss: 0.7625\n",
      "Epoch 160 | Train Loss: 0.2879 | Val Loss: 0.8845\n",
      "Epoch 180 | Train Loss: 0.2639 | Val Loss: 0.7476\n",
      "Epoch 200 | Train Loss: 0.2309 | Val Loss: 0.8029\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/70_30/PubMed_GAT_70_30_seed46.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_70_30_masked_indices_seed999.npy (70_30, GAT) ===\n",
      "Train nodes: 13802 | Test nodes: 5915\n",
      "Epoch 001 | Train Loss: 5.0305 | Val Loss: 5.0324\n",
      "Epoch 020 | Train Loss: 0.5355 | Val Loss: 0.7101\n",
      "Epoch 040 | Train Loss: 0.4101 | Val Loss: 0.6333\n",
      "Epoch 060 | Train Loss: 0.3453 | Val Loss: 0.6308\n",
      "Epoch 080 | Train Loss: 0.3017 | Val Loss: 0.6494\n",
      "Epoch 100 | Train Loss: 0.2638 | Val Loss: 0.7049\n",
      "Epoch 120 | Train Loss: 0.2645 | Val Loss: 0.7889\n",
      "Epoch 140 | Train Loss: 0.2346 | Val Loss: 0.7839\n",
      "Epoch 160 | Train Loss: 0.2616 | Val Loss: 0.8545\n",
      "Epoch 180 | Train Loss: 0.2311 | Val Loss: 0.8069\n",
      "Epoch 200 | Train Loss: 0.2685 | Val Loss: 0.9020\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/70_30/PubMed_GAT_70_30_seed999.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_70_30_masked_indices_seed123.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 13802 | Test nodes: 5915\n",
      "Epoch 001 | Train Loss: 4.9652 | Val Loss: 4.9626\n",
      "Epoch 020 | Train Loss: 0.6092 | Val Loss: 0.8244\n",
      "Epoch 040 | Train Loss: 0.2816 | Val Loss: 0.7159\n",
      "Epoch 060 | Train Loss: 0.1176 | Val Loss: 0.7423\n",
      "Epoch 080 | Train Loss: 0.0690 | Val Loss: 0.7785\n",
      "Epoch 100 | Train Loss: 0.0562 | Val Loss: 0.7814\n",
      "Epoch 120 | Train Loss: 0.0492 | Val Loss: 0.7792\n",
      "Epoch 140 | Train Loss: 0.0430 | Val Loss: 0.7881\n",
      "Epoch 160 | Train Loss: 0.0383 | Val Loss: 0.7974\n",
      "Epoch 180 | Train Loss: 0.0346 | Val Loss: 0.8036\n",
      "Epoch 200 | Train Loss: 0.0317 | Val Loss: 0.8100\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/70_30/PubMed_GraphSAGE_70_30_seed123.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_70_30_masked_indices_seed2025.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 13802 | Test nodes: 5915\n",
      "Epoch 001 | Train Loss: 5.0560 | Val Loss: 5.0555\n",
      "Epoch 020 | Train Loss: 0.5976 | Val Loss: 0.8070\n",
      "Epoch 040 | Train Loss: 0.2576 | Val Loss: 0.7024\n",
      "Epoch 060 | Train Loss: 0.1046 | Val Loss: 0.7385\n",
      "Epoch 080 | Train Loss: 0.0630 | Val Loss: 0.7685\n",
      "Epoch 100 | Train Loss: 0.0524 | Val Loss: 0.7722\n",
      "Epoch 120 | Train Loss: 0.0455 | Val Loss: 0.7775\n",
      "Epoch 140 | Train Loss: 0.0397 | Val Loss: 0.7862\n",
      "Epoch 160 | Train Loss: 0.0355 | Val Loss: 0.7975\n",
      "Epoch 180 | Train Loss: 0.0321 | Val Loss: 0.8071\n",
      "Epoch 200 | Train Loss: 0.0295 | Val Loss: 0.8158\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/70_30/PubMed_GraphSAGE_70_30_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_70_30_masked_indices_seed42.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 13802 | Test nodes: 5915\n",
      "Epoch 001 | Train Loss: 5.3209 | Val Loss: 5.3152\n",
      "Epoch 020 | Train Loss: 0.6129 | Val Loss: 0.8103\n",
      "Epoch 040 | Train Loss: 0.2796 | Val Loss: 0.6966\n",
      "Epoch 060 | Train Loss: 0.1177 | Val Loss: 0.7254\n",
      "Epoch 080 | Train Loss: 0.0684 | Val Loss: 0.7610\n",
      "Epoch 100 | Train Loss: 0.0554 | Val Loss: 0.7693\n",
      "Epoch 120 | Train Loss: 0.0483 | Val Loss: 0.7731\n",
      "Epoch 140 | Train Loss: 0.0422 | Val Loss: 0.7784\n",
      "Epoch 160 | Train Loss: 0.0375 | Val Loss: 0.7841\n",
      "Epoch 180 | Train Loss: 0.0339 | Val Loss: 0.7884\n",
      "Epoch 200 | Train Loss: 0.0311 | Val Loss: 0.7952\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/70_30/PubMed_GraphSAGE_70_30_seed42.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_70_30_masked_indices_seed46.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 13802 | Test nodes: 5915\n",
      "Epoch 001 | Train Loss: 5.0551 | Val Loss: 5.0443\n",
      "Epoch 020 | Train Loss: 0.6079 | Val Loss: 0.8158\n",
      "Epoch 040 | Train Loss: 0.2669 | Val Loss: 0.7055\n",
      "Epoch 060 | Train Loss: 0.1081 | Val Loss: 0.7404\n",
      "Epoch 080 | Train Loss: 0.0650 | Val Loss: 0.7791\n",
      "Epoch 100 | Train Loss: 0.0539 | Val Loss: 0.7838\n",
      "Epoch 120 | Train Loss: 0.0470 | Val Loss: 0.7864\n",
      "Epoch 140 | Train Loss: 0.0410 | Val Loss: 0.7939\n",
      "Epoch 160 | Train Loss: 0.0366 | Val Loss: 0.8021\n",
      "Epoch 180 | Train Loss: 0.0332 | Val Loss: 0.8098\n",
      "Epoch 200 | Train Loss: 0.0304 | Val Loss: 0.8169\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/70_30/PubMed_GraphSAGE_70_30_seed46.pt\n",
      "\n",
      "=== Processing Mask File: PubMed_70_30_masked_indices_seed999.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 13802 | Test nodes: 5915\n",
      "Epoch 001 | Train Loss: 5.1455 | Val Loss: 5.1600\n",
      "Epoch 020 | Train Loss: 0.6123 | Val Loss: 0.8147\n",
      "Epoch 040 | Train Loss: 0.2835 | Val Loss: 0.7048\n",
      "Epoch 060 | Train Loss: 0.1188 | Val Loss: 0.7338\n",
      "Epoch 080 | Train Loss: 0.0686 | Val Loss: 0.7745\n",
      "Epoch 100 | Train Loss: 0.0552 | Val Loss: 0.7846\n",
      "Epoch 120 | Train Loss: 0.0480 | Val Loss: 0.7851\n",
      "Epoch 140 | Train Loss: 0.0418 | Val Loss: 0.7917\n",
      "Epoch 160 | Train Loss: 0.0371 | Val Loss: 0.7970\n",
      "Epoch 180 | Train Loss: 0.0335 | Val Loss: 0.8019\n",
      "Epoch 200 | Train Loss: 0.0307 | Val Loss: 0.8078\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/PubMed/70_30/PubMed_GraphSAGE_70_30_seed999.pt\n",
      "Saved averaged results and execution times for PubMed split 70_30\n",
      "\n",
      "========== Dataset: WikiCS ==========\n",
      "\n",
      "=== Processing Mask File: WikiCS_30_70_masked_indices_seed123.npy (30_70, GCN) ===\n",
      "Train nodes: 3511 | Test nodes: 8190\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/Downloads/GraFN/grafn-env/lib/python3.12/site-packages/torch_geometric/datasets/wikics.py:45: UserWarning: The WikiCS dataset now returns an undirected graph by default. Please explicitly specify 'is_undirected=False' to restore the old behavior.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 001 | Train Loss: 4.9903 | Val Loss: 4.9906\n",
      "Epoch 020 | Train Loss: 1.5915 | Val Loss: 1.8498\n",
      "Epoch 040 | Train Loss: 1.0328 | Val Loss: 1.7229\n",
      "Epoch 060 | Train Loss: 0.8017 | Val Loss: 1.7964\n",
      "Epoch 080 | Train Loss: 0.6784 | Val Loss: 1.8451\n",
      "Epoch 100 | Train Loss: 0.5904 | Val Loss: 1.8812\n",
      "Epoch 120 | Train Loss: 0.5307 | Val Loss: 1.9048\n",
      "Epoch 140 | Train Loss: 0.4886 | Val Loss: 1.9314\n",
      "Epoch 160 | Train Loss: 0.4563 | Val Loss: 1.9512\n",
      "Epoch 180 | Train Loss: 0.4307 | Val Loss: 1.9637\n",
      "Epoch 200 | Train Loss: 0.4101 | Val Loss: 1.9746\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/30_70/WikiCS_GCN_30_70_seed123.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_30_70_masked_indices_seed2025.npy (30_70, GCN) ===\n",
      "Train nodes: 3511 | Test nodes: 8190\n",
      "Epoch 001 | Train Loss: 5.0716 | Val Loss: 5.0648\n",
      "Epoch 020 | Train Loss: 1.5968 | Val Loss: 1.8923\n",
      "Epoch 040 | Train Loss: 1.0404 | Val Loss: 1.7678\n",
      "Epoch 060 | Train Loss: 0.8286 | Val Loss: 1.8199\n",
      "Epoch 080 | Train Loss: 0.7043 | Val Loss: 1.8535\n",
      "Epoch 100 | Train Loss: 0.6093 | Val Loss: 1.8741\n",
      "Epoch 120 | Train Loss: 0.5452 | Val Loss: 1.8966\n",
      "Epoch 140 | Train Loss: 0.5004 | Val Loss: 1.9162\n",
      "Epoch 160 | Train Loss: 0.4655 | Val Loss: 1.9356\n",
      "Epoch 180 | Train Loss: 0.4381 | Val Loss: 1.9509\n",
      "Epoch 200 | Train Loss: 0.4163 | Val Loss: 1.9622\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/30_70/WikiCS_GCN_30_70_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_30_70_masked_indices_seed42.npy (30_70, GCN) ===\n",
      "Train nodes: 3511 | Test nodes: 8190\n",
      "Epoch 001 | Train Loss: 5.0329 | Val Loss: 5.0369\n",
      "Epoch 020 | Train Loss: 1.5865 | Val Loss: 1.8828\n",
      "Epoch 040 | Train Loss: 1.0285 | Val Loss: 1.7907\n",
      "Epoch 060 | Train Loss: 0.8058 | Val Loss: 1.8655\n",
      "Epoch 080 | Train Loss: 0.6852 | Val Loss: 1.8954\n",
      "Epoch 100 | Train Loss: 0.5979 | Val Loss: 1.9223\n",
      "Epoch 120 | Train Loss: 0.5382 | Val Loss: 1.9495\n",
      "Epoch 140 | Train Loss: 0.4951 | Val Loss: 1.9750\n",
      "Epoch 160 | Train Loss: 0.4626 | Val Loss: 1.9963\n",
      "Epoch 180 | Train Loss: 0.4375 | Val Loss: 2.0136\n",
      "Epoch 200 | Train Loss: 0.4169 | Val Loss: 2.0284\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/30_70/WikiCS_GCN_30_70_seed42.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_30_70_masked_indices_seed46.npy (30_70, GCN) ===\n",
      "Train nodes: 3511 | Test nodes: 8190\n",
      "Epoch 001 | Train Loss: 5.0128 | Val Loss: 5.0143\n",
      "Epoch 020 | Train Loss: 1.6048 | Val Loss: 1.8578\n",
      "Epoch 040 | Train Loss: 1.0677 | Val Loss: 1.7747\n",
      "Epoch 060 | Train Loss: 0.8512 | Val Loss: 1.8194\n",
      "Epoch 080 | Train Loss: 0.7192 | Val Loss: 1.8387\n",
      "Epoch 100 | Train Loss: 0.6194 | Val Loss: 1.8600\n",
      "Epoch 120 | Train Loss: 0.5517 | Val Loss: 1.8770\n",
      "Epoch 140 | Train Loss: 0.5042 | Val Loss: 1.8980\n",
      "Epoch 160 | Train Loss: 0.4687 | Val Loss: 1.9188\n",
      "Epoch 180 | Train Loss: 0.4414 | Val Loss: 1.9425\n",
      "Epoch 200 | Train Loss: 0.4195 | Val Loss: 1.9639\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/30_70/WikiCS_GCN_30_70_seed46.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_30_70_masked_indices_seed999.npy (30_70, GCN) ===\n",
      "Train nodes: 3511 | Test nodes: 8190\n",
      "Epoch 001 | Train Loss: 4.9984 | Val Loss: 5.0007\n",
      "Epoch 020 | Train Loss: 1.5775 | Val Loss: 1.8798\n",
      "Epoch 040 | Train Loss: 1.0237 | Val Loss: 1.8095\n",
      "Epoch 060 | Train Loss: 0.8082 | Val Loss: 1.8743\n",
      "Epoch 080 | Train Loss: 0.6886 | Val Loss: 1.9152\n",
      "Epoch 100 | Train Loss: 0.5999 | Val Loss: 1.9533\n",
      "Epoch 120 | Train Loss: 0.5382 | Val Loss: 1.9793\n",
      "Epoch 140 | Train Loss: 0.4945 | Val Loss: 2.0018\n",
      "Epoch 160 | Train Loss: 0.4609 | Val Loss: 2.0193\n",
      "Epoch 180 | Train Loss: 0.4338 | Val Loss: 2.0373\n",
      "Epoch 200 | Train Loss: 0.4122 | Val Loss: 2.0534\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/30_70/WikiCS_GCN_30_70_seed999.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_30_70_masked_indices_seed123.npy (30_70, GAT) ===\n",
      "Train nodes: 3511 | Test nodes: 8190\n",
      "Epoch 001 | Train Loss: 4.9963 | Val Loss: 4.9938\n",
      "Epoch 020 | Train Loss: 1.4915 | Val Loss: 2.0269\n",
      "Epoch 040 | Train Loss: 0.4712 | Val Loss: 1.6010\n",
      "Epoch 060 | Train Loss: 0.1795 | Val Loss: 1.7230\n",
      "Epoch 080 | Train Loss: 0.0936 | Val Loss: 1.8923\n",
      "Epoch 100 | Train Loss: 0.0655 | Val Loss: 1.9621\n",
      "Epoch 120 | Train Loss: 0.0534 | Val Loss: 2.0030\n",
      "Epoch 140 | Train Loss: 0.0467 | Val Loss: 2.0053\n",
      "Epoch 160 | Train Loss: 0.0414 | Val Loss: 1.9888\n",
      "Epoch 180 | Train Loss: 0.0372 | Val Loss: 1.9738\n",
      "Epoch 200 | Train Loss: 0.0337 | Val Loss: 1.9686\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/30_70/WikiCS_GAT_30_70_seed123.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_30_70_masked_indices_seed2025.npy (30_70, GAT) ===\n",
      "Train nodes: 3511 | Test nodes: 8190\n",
      "Epoch 001 | Train Loss: 5.0146 | Val Loss: 5.0107\n",
      "Epoch 020 | Train Loss: 1.1043 | Val Loss: 1.7405\n",
      "Epoch 040 | Train Loss: 0.2999 | Val Loss: 1.6407\n",
      "Epoch 060 | Train Loss: 0.1044 | Val Loss: 1.9718\n",
      "Epoch 080 | Train Loss: 0.0702 | Val Loss: 2.1481\n",
      "Epoch 100 | Train Loss: 0.0617 | Val Loss: 2.1549\n",
      "Epoch 120 | Train Loss: 0.0567 | Val Loss: 2.1227\n",
      "Epoch 140 | Train Loss: 0.0522 | Val Loss: 2.0804\n",
      "Epoch 160 | Train Loss: 0.0459 | Val Loss: 2.0669\n",
      "Epoch 180 | Train Loss: 0.0422 | Val Loss: 2.0513\n",
      "Epoch 200 | Train Loss: 0.0375 | Val Loss: 2.0319\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/30_70/WikiCS_GAT_30_70_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_30_70_masked_indices_seed42.npy (30_70, GAT) ===\n",
      "Train nodes: 3511 | Test nodes: 8190\n",
      "Epoch 001 | Train Loss: 5.0404 | Val Loss: 5.0381\n",
      "Epoch 020 | Train Loss: 1.4970 | Val Loss: 1.9898\n",
      "Epoch 040 | Train Loss: 0.5130 | Val Loss: 1.5615\n",
      "Epoch 060 | Train Loss: 0.1988 | Val Loss: 1.6457\n",
      "Epoch 080 | Train Loss: 0.0998 | Val Loss: 1.8091\n",
      "Epoch 100 | Train Loss: 0.0682 | Val Loss: 1.9054\n",
      "Epoch 120 | Train Loss: 0.0536 | Val Loss: 1.9408\n",
      "Epoch 140 | Train Loss: 0.0449 | Val Loss: 1.9628\n",
      "Epoch 160 | Train Loss: 0.0403 | Val Loss: 1.9688\n",
      "Epoch 180 | Train Loss: 0.0367 | Val Loss: 1.9584\n",
      "Epoch 200 | Train Loss: 0.0340 | Val Loss: 1.9520\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/30_70/WikiCS_GAT_30_70_seed42.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_30_70_masked_indices_seed46.npy (30_70, GAT) ===\n",
      "Train nodes: 3511 | Test nodes: 8190\n",
      "Epoch 001 | Train Loss: 5.0216 | Val Loss: 5.0233\n",
      "Epoch 020 | Train Loss: 1.4872 | Val Loss: 1.9340\n",
      "Epoch 040 | Train Loss: 0.4463 | Val Loss: 1.4794\n",
      "Epoch 060 | Train Loss: 0.1667 | Val Loss: 1.6319\n",
      "Epoch 080 | Train Loss: 0.0916 | Val Loss: 1.8090\n",
      "Epoch 100 | Train Loss: 0.0692 | Val Loss: 1.8550\n",
      "Epoch 120 | Train Loss: 0.0575 | Val Loss: 1.8637\n",
      "Epoch 140 | Train Loss: 0.0503 | Val Loss: 1.8508\n",
      "Epoch 160 | Train Loss: 0.0453 | Val Loss: 1.8396\n",
      "Epoch 180 | Train Loss: 0.0402 | Val Loss: 1.8345\n",
      "Epoch 200 | Train Loss: 0.0351 | Val Loss: 1.8409\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/30_70/WikiCS_GAT_30_70_seed46.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_30_70_masked_indices_seed999.npy (30_70, GAT) ===\n",
      "Train nodes: 3511 | Test nodes: 8190\n",
      "Epoch 001 | Train Loss: 5.0124 | Val Loss: 5.0142\n",
      "Epoch 020 | Train Loss: 1.0538 | Val Loss: 1.7840\n",
      "Epoch 040 | Train Loss: 0.2832 | Val Loss: 1.6726\n",
      "Epoch 060 | Train Loss: 0.1077 | Val Loss: 1.9366\n",
      "Epoch 080 | Train Loss: 0.0753 | Val Loss: 2.0654\n",
      "Epoch 100 | Train Loss: 0.0607 | Val Loss: 2.0472\n",
      "Epoch 120 | Train Loss: 0.0529 | Val Loss: 1.9700\n",
      "Epoch 140 | Train Loss: 0.0479 | Val Loss: 1.9283\n",
      "Epoch 160 | Train Loss: 0.0427 | Val Loss: 1.8921\n",
      "Epoch 180 | Train Loss: 0.0378 | Val Loss: 1.8643\n",
      "Epoch 200 | Train Loss: 0.0325 | Val Loss: 1.8585\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/30_70/WikiCS_GAT_30_70_seed999.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_30_70_masked_indices_seed123.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 3511 | Test nodes: 8190\n",
      "Epoch 001 | Train Loss: 4.9392 | Val Loss: 4.9422\n",
      "Epoch 020 | Train Loss: 0.6097 | Val Loss: 1.5944\n",
      "Epoch 040 | Train Loss: 0.0751 | Val Loss: 1.7540\n",
      "Epoch 060 | Train Loss: 0.0304 | Val Loss: 1.8449\n",
      "Epoch 080 | Train Loss: 0.0352 | Val Loss: 1.7824\n",
      "Epoch 100 | Train Loss: 0.0341 | Val Loss: 1.7475\n",
      "Epoch 120 | Train Loss: 0.0296 | Val Loss: 1.7477\n",
      "Epoch 140 | Train Loss: 0.0270 | Val Loss: 1.7500\n",
      "Epoch 160 | Train Loss: 0.0248 | Val Loss: 1.7550\n",
      "Epoch 180 | Train Loss: 0.0231 | Val Loss: 1.7629\n",
      "Epoch 200 | Train Loss: 0.0216 | Val Loss: 1.7698\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/30_70/WikiCS_GraphSAGE_30_70_seed123.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_30_70_masked_indices_seed2025.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 3511 | Test nodes: 8190\n",
      "Epoch 001 | Train Loss: 5.0729 | Val Loss: 5.0742\n",
      "Epoch 020 | Train Loss: 0.6461 | Val Loss: 1.6338\n",
      "Epoch 040 | Train Loss: 0.0870 | Val Loss: 1.7822\n",
      "Epoch 060 | Train Loss: 0.0324 | Val Loss: 1.8885\n",
      "Epoch 080 | Train Loss: 0.0356 | Val Loss: 1.8248\n",
      "Epoch 100 | Train Loss: 0.0354 | Val Loss: 1.7897\n",
      "Epoch 120 | Train Loss: 0.0308 | Val Loss: 1.7889\n",
      "Epoch 140 | Train Loss: 0.0279 | Val Loss: 1.7946\n",
      "Epoch 160 | Train Loss: 0.0258 | Val Loss: 1.8005\n",
      "Epoch 180 | Train Loss: 0.0239 | Val Loss: 1.8109\n",
      "Epoch 200 | Train Loss: 0.0224 | Val Loss: 1.8214\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/30_70/WikiCS_GraphSAGE_30_70_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_30_70_masked_indices_seed42.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 3511 | Test nodes: 8190\n",
      "Epoch 001 | Train Loss: 5.0086 | Val Loss: 5.0183\n",
      "Epoch 020 | Train Loss: 0.5994 | Val Loss: 1.6009\n",
      "Epoch 040 | Train Loss: 0.0747 | Val Loss: 1.8055\n",
      "Epoch 060 | Train Loss: 0.0299 | Val Loss: 1.9030\n",
      "Epoch 080 | Train Loss: 0.0343 | Val Loss: 1.8368\n",
      "Epoch 100 | Train Loss: 0.0337 | Val Loss: 1.8025\n",
      "Epoch 120 | Train Loss: 0.0293 | Val Loss: 1.8041\n",
      "Epoch 140 | Train Loss: 0.0266 | Val Loss: 1.8066\n",
      "Epoch 160 | Train Loss: 0.0246 | Val Loss: 1.8128\n",
      "Epoch 180 | Train Loss: 0.0228 | Val Loss: 1.8194\n",
      "Epoch 200 | Train Loss: 0.0214 | Val Loss: 1.8291\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/30_70/WikiCS_GraphSAGE_30_70_seed42.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_30_70_masked_indices_seed46.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 3511 | Test nodes: 8190\n",
      "Epoch 001 | Train Loss: 4.9406 | Val Loss: 4.9349\n",
      "Epoch 020 | Train Loss: 0.6413 | Val Loss: 1.5980\n",
      "Epoch 040 | Train Loss: 0.0866 | Val Loss: 1.7298\n",
      "Epoch 060 | Train Loss: 0.0317 | Val Loss: 1.8386\n",
      "Epoch 080 | Train Loss: 0.0350 | Val Loss: 1.7862\n",
      "Epoch 100 | Train Loss: 0.0348 | Val Loss: 1.7497\n",
      "Epoch 120 | Train Loss: 0.0303 | Val Loss: 1.7501\n",
      "Epoch 140 | Train Loss: 0.0275 | Val Loss: 1.7507\n",
      "Epoch 160 | Train Loss: 0.0254 | Val Loss: 1.7551\n",
      "Epoch 180 | Train Loss: 0.0236 | Val Loss: 1.7634\n",
      "Epoch 200 | Train Loss: 0.0221 | Val Loss: 1.7725\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/30_70/WikiCS_GraphSAGE_30_70_seed46.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_30_70_masked_indices_seed999.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 3511 | Test nodes: 8190\n",
      "Epoch 001 | Train Loss: 5.0095 | Val Loss: 5.0046\n",
      "Epoch 020 | Train Loss: 0.6525 | Val Loss: 1.5692\n",
      "Epoch 040 | Train Loss: 0.0936 | Val Loss: 1.6644\n",
      "Epoch 060 | Train Loss: 0.0336 | Val Loss: 1.7840\n",
      "Epoch 080 | Train Loss: 0.0362 | Val Loss: 1.7423\n",
      "Epoch 100 | Train Loss: 0.0358 | Val Loss: 1.7134\n",
      "Epoch 120 | Train Loss: 0.0311 | Val Loss: 1.7176\n",
      "Epoch 140 | Train Loss: 0.0282 | Val Loss: 1.7249\n",
      "Epoch 160 | Train Loss: 0.0260 | Val Loss: 1.7331\n",
      "Epoch 180 | Train Loss: 0.0241 | Val Loss: 1.7445\n",
      "Epoch 200 | Train Loss: 0.0226 | Val Loss: 1.7536\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/30_70/WikiCS_GraphSAGE_30_70_seed999.pt\n",
      "Saved averaged results and execution times for WikiCS split 30_70\n",
      "\n",
      "=== Processing Mask File: WikiCS_70_30_masked_indices_seed123.npy (70_30, GCN) ===\n",
      "Train nodes: 8191 | Test nodes: 3510\n",
      "Epoch 001 | Train Loss: 4.9766 | Val Loss: 4.9730\n",
      "Epoch 020 | Train Loss: 1.6790 | Val Loss: 1.8179\n",
      "Epoch 040 | Train Loss: 1.2023 | Val Loss: 1.6487\n",
      "Epoch 060 | Train Loss: 1.0084 | Val Loss: 1.5846\n",
      "Epoch 080 | Train Loss: 0.8862 | Val Loss: 1.5349\n",
      "Epoch 100 | Train Loss: 0.7856 | Val Loss: 1.4972\n",
      "Epoch 120 | Train Loss: 0.7131 | Val Loss: 1.4826\n",
      "Epoch 140 | Train Loss: 0.6610 | Val Loss: 1.4799\n",
      "Epoch 160 | Train Loss: 0.6206 | Val Loss: 1.4828\n",
      "Epoch 180 | Train Loss: 0.5901 | Val Loss: 1.4850\n",
      "Epoch 200 | Train Loss: 0.5652 | Val Loss: 1.4896\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/70_30/WikiCS_GCN_70_30_seed123.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_70_30_masked_indices_seed2025.npy (70_30, GCN) ===\n",
      "Train nodes: 8191 | Test nodes: 3510\n",
      "Epoch 001 | Train Loss: 5.0039 | Val Loss: 5.0009\n",
      "Epoch 020 | Train Loss: 1.6782 | Val Loss: 1.8405\n",
      "Epoch 040 | Train Loss: 1.2013 | Val Loss: 1.6735\n",
      "Epoch 060 | Train Loss: 1.0060 | Val Loss: 1.6317\n",
      "Epoch 080 | Train Loss: 0.8800 | Val Loss: 1.5938\n",
      "Epoch 100 | Train Loss: 0.7801 | Val Loss: 1.5695\n",
      "Epoch 120 | Train Loss: 0.7112 | Val Loss: 1.5503\n",
      "Epoch 140 | Train Loss: 0.6609 | Val Loss: 1.5450\n",
      "Epoch 160 | Train Loss: 0.6217 | Val Loss: 1.5430\n",
      "Epoch 180 | Train Loss: 0.5910 | Val Loss: 1.5513\n",
      "Epoch 200 | Train Loss: 0.5666 | Val Loss: 1.5573\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/70_30/WikiCS_GCN_70_30_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_70_30_masked_indices_seed42.npy (70_30, GCN) ===\n",
      "Train nodes: 8191 | Test nodes: 3510\n",
      "Epoch 001 | Train Loss: 5.0272 | Val Loss: 5.0261\n",
      "Epoch 020 | Train Loss: 1.6892 | Val Loss: 1.8341\n",
      "Epoch 040 | Train Loss: 1.2010 | Val Loss: 1.6551\n",
      "Epoch 060 | Train Loss: 1.0024 | Val Loss: 1.6309\n",
      "Epoch 080 | Train Loss: 0.8778 | Val Loss: 1.6056\n",
      "Epoch 100 | Train Loss: 0.7792 | Val Loss: 1.5818\n",
      "Epoch 120 | Train Loss: 0.7106 | Val Loss: 1.5714\n",
      "Epoch 140 | Train Loss: 0.6616 | Val Loss: 1.5718\n",
      "Epoch 160 | Train Loss: 0.6236 | Val Loss: 1.5712\n",
      "Epoch 180 | Train Loss: 0.5940 | Val Loss: 1.5678\n",
      "Epoch 200 | Train Loss: 0.5702 | Val Loss: 1.5705\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/70_30/WikiCS_GCN_70_30_seed42.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_70_30_masked_indices_seed46.npy (70_30, GCN) ===\n",
      "Train nodes: 8191 | Test nodes: 3510\n",
      "Epoch 001 | Train Loss: 5.0224 | Val Loss: 5.0260\n",
      "Epoch 020 | Train Loss: 1.6960 | Val Loss: 1.8290\n",
      "Epoch 040 | Train Loss: 1.2100 | Val Loss: 1.6386\n",
      "Epoch 060 | Train Loss: 1.0098 | Val Loss: 1.6110\n",
      "Epoch 080 | Train Loss: 0.8832 | Val Loss: 1.5902\n",
      "Epoch 100 | Train Loss: 0.7821 | Val Loss: 1.5701\n",
      "Epoch 120 | Train Loss: 0.7125 | Val Loss: 1.5586\n",
      "Epoch 140 | Train Loss: 0.6628 | Val Loss: 1.5542\n",
      "Epoch 160 | Train Loss: 0.6242 | Val Loss: 1.5594\n",
      "Epoch 180 | Train Loss: 0.5935 | Val Loss: 1.5626\n",
      "Epoch 200 | Train Loss: 0.5689 | Val Loss: 1.5636\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/70_30/WikiCS_GCN_70_30_seed46.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_70_30_masked_indices_seed999.npy (70_30, GCN) ===\n",
      "Train nodes: 8191 | Test nodes: 3510\n",
      "Epoch 001 | Train Loss: 5.0295 | Val Loss: 5.0244\n",
      "Epoch 020 | Train Loss: 1.6810 | Val Loss: 1.8123\n",
      "Epoch 040 | Train Loss: 1.1847 | Val Loss: 1.6323\n",
      "Epoch 060 | Train Loss: 0.9827 | Val Loss: 1.5753\n",
      "Epoch 080 | Train Loss: 0.8600 | Val Loss: 1.5538\n",
      "Epoch 100 | Train Loss: 0.7632 | Val Loss: 1.5286\n",
      "Epoch 120 | Train Loss: 0.6951 | Val Loss: 1.5100\n",
      "Epoch 140 | Train Loss: 0.6471 | Val Loss: 1.5040\n",
      "Epoch 160 | Train Loss: 0.6109 | Val Loss: 1.5042\n",
      "Epoch 180 | Train Loss: 0.5818 | Val Loss: 1.5007\n",
      "Epoch 200 | Train Loss: 0.5584 | Val Loss: 1.4985\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/70_30/WikiCS_GCN_70_30_seed999.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_70_30_masked_indices_seed123.npy (70_30, GAT) ===\n",
      "Train nodes: 8191 | Test nodes: 3510\n",
      "Epoch 001 | Train Loss: 5.0294 | Val Loss: 5.0250\n",
      "Epoch 020 | Train Loss: 1.1908 | Val Loss: 1.5181\n",
      "Epoch 040 | Train Loss: 0.5314 | Val Loss: 1.2209\n",
      "Epoch 060 | Train Loss: 0.2754 | Val Loss: 1.2451\n",
      "Epoch 080 | Train Loss: 0.1599 | Val Loss: 1.3516\n",
      "Epoch 100 | Train Loss: 0.1116 | Val Loss: 1.4553\n",
      "Epoch 120 | Train Loss: 0.0892 | Val Loss: 1.5021\n",
      "Epoch 140 | Train Loss: 0.0767 | Val Loss: 1.5399\n",
      "Epoch 160 | Train Loss: 0.0685 | Val Loss: 1.5575\n",
      "Epoch 180 | Train Loss: 0.0618 | Val Loss: 1.5722\n",
      "Epoch 200 | Train Loss: 0.0710 | Val Loss: 1.5407\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/70_30/WikiCS_GAT_70_30_seed123.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_70_30_masked_indices_seed2025.npy (70_30, GAT) ===\n",
      "Train nodes: 8191 | Test nodes: 3510\n",
      "Epoch 001 | Train Loss: 5.0004 | Val Loss: 5.0000\n",
      "Epoch 020 | Train Loss: 1.4807 | Val Loss: 1.7448\n",
      "Epoch 040 | Train Loss: 0.7278 | Val Loss: 1.2610\n",
      "Epoch 060 | Train Loss: 0.4313 | Val Loss: 1.1720\n",
      "Epoch 080 | Train Loss: 0.2755 | Val Loss: 1.1917\n",
      "Epoch 100 | Train Loss: 0.1874 | Val Loss: 1.2740\n",
      "Epoch 120 | Train Loss: 0.1373 | Val Loss: 1.3668\n",
      "Epoch 140 | Train Loss: 0.1099 | Val Loss: 1.4353\n",
      "Epoch 160 | Train Loss: 0.0925 | Val Loss: 1.4803\n",
      "Epoch 180 | Train Loss: 0.0828 | Val Loss: 1.5231\n",
      "Epoch 200 | Train Loss: 0.0769 | Val Loss: 1.5673\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/70_30/WikiCS_GAT_70_30_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_70_30_masked_indices_seed42.npy (70_30, GAT) ===\n",
      "Train nodes: 8191 | Test nodes: 3510\n",
      "Epoch 001 | Train Loss: 4.9977 | Val Loss: 4.9973\n",
      "Epoch 020 | Train Loss: 1.4352 | Val Loss: 1.6565\n",
      "Epoch 040 | Train Loss: 0.6762 | Val Loss: 1.2251\n",
      "Epoch 060 | Train Loss: 0.3913 | Val Loss: 1.1355\n",
      "Epoch 080 | Train Loss: 0.2455 | Val Loss: 1.1439\n",
      "Epoch 100 | Train Loss: 0.1650 | Val Loss: 1.2568\n",
      "Epoch 120 | Train Loss: 0.1223 | Val Loss: 1.3611\n",
      "Epoch 140 | Train Loss: 0.0985 | Val Loss: 1.4440\n",
      "Epoch 160 | Train Loss: 0.0874 | Val Loss: 1.4965\n",
      "Epoch 180 | Train Loss: 0.0788 | Val Loss: 1.5316\n",
      "Epoch 200 | Train Loss: 0.0698 | Val Loss: 1.5793\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/70_30/WikiCS_GAT_70_30_seed42.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_70_30_masked_indices_seed46.npy (70_30, GAT) ===\n",
      "Train nodes: 8191 | Test nodes: 3510\n",
      "Epoch 001 | Train Loss: 5.0515 | Val Loss: 5.0503\n",
      "Epoch 020 | Train Loss: 1.3772 | Val Loss: 1.6405\n",
      "Epoch 040 | Train Loss: 0.6232 | Val Loss: 1.1960\n",
      "Epoch 060 | Train Loss: 0.3472 | Val Loss: 1.1462\n",
      "Epoch 080 | Train Loss: 0.2083 | Val Loss: 1.2279\n",
      "Epoch 100 | Train Loss: 0.1381 | Val Loss: 1.3357\n",
      "Epoch 120 | Train Loss: 0.1041 | Val Loss: 1.4320\n",
      "Epoch 140 | Train Loss: 0.0864 | Val Loss: 1.4900\n",
      "Epoch 160 | Train Loss: 0.0761 | Val Loss: 1.5325\n",
      "Epoch 180 | Train Loss: 0.2724 | Val Loss: 1.7037\n",
      "Epoch 200 | Train Loss: 0.1189 | Val Loss: 1.3229\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/70_30/WikiCS_GAT_70_30_seed46.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_70_30_masked_indices_seed999.npy (70_30, GAT) ===\n",
      "Train nodes: 8191 | Test nodes: 3510\n",
      "Epoch 001 | Train Loss: 5.0241 | Val Loss: 5.0193\n",
      "Epoch 020 | Train Loss: 1.4219 | Val Loss: 1.6469\n",
      "Epoch 040 | Train Loss: 0.6617 | Val Loss: 1.1741\n",
      "Epoch 060 | Train Loss: 0.3868 | Val Loss: 1.1279\n",
      "Epoch 080 | Train Loss: 0.2385 | Val Loss: 1.1514\n",
      "Epoch 100 | Train Loss: 0.1608 | Val Loss: 1.2332\n",
      "Epoch 120 | Train Loss: 0.1214 | Val Loss: 1.3055\n",
      "Epoch 140 | Train Loss: 0.0997 | Val Loss: 1.3568\n",
      "Epoch 160 | Train Loss: 0.0866 | Val Loss: 1.4086\n",
      "Epoch 180 | Train Loss: 0.0875 | Val Loss: 1.4420\n",
      "Epoch 200 | Train Loss: 0.0740 | Val Loss: 1.4494\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/70_30/WikiCS_GAT_70_30_seed999.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_70_30_masked_indices_seed123.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 8191 | Test nodes: 3510\n",
      "Epoch 001 | Train Loss: 4.9837 | Val Loss: 4.9770\n",
      "Epoch 020 | Train Loss: 0.9008 | Val Loss: 1.3498\n",
      "Epoch 040 | Train Loss: 0.3279 | Val Loss: 1.1807\n",
      "Epoch 060 | Train Loss: 0.1220 | Val Loss: 1.2610\n",
      "Epoch 080 | Train Loss: 0.0737 | Val Loss: 1.3186\n",
      "Epoch 100 | Train Loss: 0.0632 | Val Loss: 1.3292\n",
      "Epoch 120 | Train Loss: 0.0560 | Val Loss: 1.3340\n",
      "Epoch 140 | Train Loss: 0.0497 | Val Loss: 1.3439\n",
      "Epoch 160 | Train Loss: 0.0450 | Val Loss: 1.3529\n",
      "Epoch 180 | Train Loss: 0.0414 | Val Loss: 1.3606\n",
      "Epoch 200 | Train Loss: 0.0386 | Val Loss: 1.3741\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/70_30/WikiCS_GraphSAGE_70_30_seed123.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_70_30_masked_indices_seed2025.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 8191 | Test nodes: 3510\n",
      "Epoch 001 | Train Loss: 5.0191 | Val Loss: 5.0176\n",
      "Epoch 020 | Train Loss: 0.9084 | Val Loss: 1.3579\n",
      "Epoch 040 | Train Loss: 0.3236 | Val Loss: 1.1455\n",
      "Epoch 060 | Train Loss: 0.1163 | Val Loss: 1.2073\n",
      "Epoch 080 | Train Loss: 0.0699 | Val Loss: 1.2761\n",
      "Epoch 100 | Train Loss: 0.0610 | Val Loss: 1.2866\n",
      "Epoch 120 | Train Loss: 0.0542 | Val Loss: 1.2947\n",
      "Epoch 140 | Train Loss: 0.0482 | Val Loss: 1.3065\n",
      "Epoch 160 | Train Loss: 0.0438 | Val Loss: 1.3218\n",
      "Epoch 180 | Train Loss: 0.0403 | Val Loss: 1.3323\n",
      "Epoch 200 | Train Loss: 0.0376 | Val Loss: 1.3429\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/70_30/WikiCS_GraphSAGE_70_30_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_70_30_masked_indices_seed42.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 8191 | Test nodes: 3510\n",
      "Epoch 001 | Train Loss: 5.0173 | Val Loss: 5.0212\n",
      "Epoch 020 | Train Loss: 0.9307 | Val Loss: 1.3473\n",
      "Epoch 040 | Train Loss: 0.3547 | Val Loss: 1.1455\n",
      "Epoch 060 | Train Loss: 0.1355 | Val Loss: 1.1851\n",
      "Epoch 080 | Train Loss: 0.0785 | Val Loss: 1.2486\n",
      "Epoch 100 | Train Loss: 0.0659 | Val Loss: 1.2613\n",
      "Epoch 120 | Train Loss: 0.0583 | Val Loss: 1.2655\n",
      "Epoch 140 | Train Loss: 0.0517 | Val Loss: 1.2743\n",
      "Epoch 160 | Train Loss: 0.0466 | Val Loss: 1.2861\n",
      "Epoch 180 | Train Loss: 0.0429 | Val Loss: 1.2987\n",
      "Epoch 200 | Train Loss: 0.0399 | Val Loss: 1.3107\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/70_30/WikiCS_GraphSAGE_70_30_seed42.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_70_30_masked_indices_seed46.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 8191 | Test nodes: 3510\n",
      "Epoch 001 | Train Loss: 5.1526 | Val Loss: 5.1565\n",
      "Epoch 020 | Train Loss: 0.9361 | Val Loss: 1.3448\n",
      "Epoch 040 | Train Loss: 0.3718 | Val Loss: 1.1415\n",
      "Epoch 060 | Train Loss: 0.1445 | Val Loss: 1.1895\n",
      "Epoch 080 | Train Loss: 0.0820 | Val Loss: 1.2560\n",
      "Epoch 100 | Train Loss: 0.0676 | Val Loss: 1.2798\n",
      "Epoch 120 | Train Loss: 0.0595 | Val Loss: 1.2973\n",
      "Epoch 140 | Train Loss: 0.0527 | Val Loss: 1.3155\n",
      "Epoch 160 | Train Loss: 0.0476 | Val Loss: 1.3298\n",
      "Epoch 180 | Train Loss: 0.0438 | Val Loss: 1.3431\n",
      "Epoch 200 | Train Loss: 0.0407 | Val Loss: 1.3565\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/70_30/WikiCS_GraphSAGE_70_30_seed46.pt\n",
      "\n",
      "=== Processing Mask File: WikiCS_70_30_masked_indices_seed999.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 8191 | Test nodes: 3510\n",
      "Epoch 001 | Train Loss: 5.1078 | Val Loss: 5.1130\n",
      "Epoch 020 | Train Loss: 0.9385 | Val Loss: 1.3258\n",
      "Epoch 040 | Train Loss: 0.3555 | Val Loss: 1.0932\n",
      "Epoch 060 | Train Loss: 0.1357 | Val Loss: 1.1498\n",
      "Epoch 080 | Train Loss: 0.0784 | Val Loss: 1.2138\n",
      "Epoch 100 | Train Loss: 0.0659 | Val Loss: 1.2289\n",
      "Epoch 120 | Train Loss: 0.0582 | Val Loss: 1.2430\n",
      "Epoch 140 | Train Loss: 0.0516 | Val Loss: 1.2580\n",
      "Epoch 160 | Train Loss: 0.0466 | Val Loss: 1.2699\n",
      "Epoch 180 | Train Loss: 0.0429 | Val Loss: 1.2835\n",
      "Epoch 200 | Train Loss: 0.0398 | Val Loss: 1.3006\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/WikiCS/70_30/WikiCS_GraphSAGE_70_30_seed999.pt\n",
      "Saved averaged results and execution times for WikiCS split 70_30\n",
      "\n",
      "========== Dataset: AmazonPhoto ==========\n",
      "No mask files found for AmazonPhoto split 30_70. Skipping.\n",
      "No mask files found for AmazonPhoto split 70_30. Skipping.\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import glob\n",
    "import torch\n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "import time\n",
    "import pandas as pd\n",
    "from sklearn.metrics import accuracy_score, f1_score\n",
    "from torch_geometric.datasets import Planetoid, WikiCS, Amazon\n",
    "from torch_geometric.transforms import NormalizeFeatures\n",
    "from layers import Classifier\n",
    "from models.GraFN import GraFN\n",
    "from torch_geometric.nn import GCNConv, GATConv, SAGEConv\n",
    "import torch.nn as nn\n",
    "\n",
    "# -------------------------------\n",
    "# Encoder definitions\n",
    "# -------------------------------\n",
    "class GCNEncoder(nn.Module):\n",
    "    def __init__(self, in_dim, hidden_dim, out_dim):\n",
    "        super().__init__()\n",
    "        self.conv1 = GCNConv(in_dim, hidden_dim)\n",
    "        self.conv2 = GCNConv(hidden_dim, out_dim)\n",
    "    def forward(self, data):\n",
    "        x, edge_index = data.x, data.edge_index\n",
    "        x = F.relu(self.conv1(x, edge_index))\n",
    "        x = self.conv2(x, edge_index)\n",
    "        return x\n",
    "\n",
    "class GATEncoder(nn.Module):\n",
    "    def __init__(self, in_dim, hidden_dim, out_dim, heads=8):\n",
    "        super().__init__()\n",
    "        self.conv1 = GATConv(in_dim, hidden_dim, heads=heads, concat=True)\n",
    "        self.conv2 = GATConv(hidden_dim * heads, out_dim, heads=1, concat=False)\n",
    "    def forward(self, data):\n",
    "        x, edge_index = data.x, data.edge_index\n",
    "        x = F.elu(self.conv1(x, edge_index))\n",
    "        x = self.conv2(x, edge_index)\n",
    "        return x\n",
    "\n",
    "class GraphSAGEEncoder(nn.Module):\n",
    "    def __init__(self, in_dim, hidden_dim, out_dim):\n",
    "        super().__init__()\n",
    "        self.conv1 = SAGEConv(in_dim, hidden_dim)\n",
    "        self.conv2 = SAGEConv(hidden_dim, out_dim)\n",
    "    def forward(self, data):\n",
    "        x, edge_index = data.x, data.edge_index\n",
    "        x = F.relu(self.conv1(x, edge_index))\n",
    "        x = self.conv2(x, edge_index)\n",
    "        return x\n",
    "\n",
    "# -------------------------------\n",
    "# Datasets\n",
    "# -------------------------------\n",
    "datasets_info = {\n",
    "    \"Cora\": lambda: Planetoid(root='data/Planetoid', name='Cora', transform=NormalizeFeatures()),\n",
    "    \"CiteSeer\": lambda: Planetoid(root='data/Planetoid', name='CiteSeer', transform=NormalizeFeatures()),\n",
    "    \"PubMed\": lambda: Planetoid(root='data/Planetoid', name='PubMed', transform=NormalizeFeatures()),\n",
    "    \"WikiCS\": lambda: WikiCS(root='data/WikiCS', transform=NormalizeFeatures()),\n",
    "    \"AmazonPhoto\": lambda: Amazon(root='data/Amazon', name='Photo', transform=NormalizeFeatures())\n",
    "}\n",
    "\n",
    "mask_dirs_template = \"/Users/sujan/Modularity based semi supervised learning/masks/{dataset}/{split}\"\n",
    "splits = [\"30_70\", \"70_30\"]\n",
    "\n",
    "base_results_dir = \"/Users/sujan/Downloads/GraFN/results\"\n",
    "base_embeddings_dir = \"/Users/sujan/Downloads/GraFN/embeddings\"\n",
    "\n",
    "# -------------------------------\n",
    "# Pipeline per mask and encoder\n",
    "# -------------------------------\n",
    "def run_pipeline(data, mask_file, dataset_name, split_type, encoder_class, encoder_name, embedding_dim=150, epochs=200):\n",
    "    num_nodes = data.num_nodes\n",
    "    test_indices = np.load(mask_file)\n",
    "    test_mask = torch.zeros(num_nodes, dtype=torch.bool)\n",
    "    test_mask[test_indices] = True\n",
    "    train_mask = ~test_mask\n",
    "    data.train_mask = train_mask\n",
    "    data.test_mask = test_mask\n",
    "\n",
    "    print(f\"\\n=== Processing Mask File: {os.path.basename(mask_file)} ({split_type}, {encoder_name}) ===\")\n",
    "    print(f\"Train nodes: {train_mask.sum().item()} | Test nodes: {test_mask.sum().item()}\")\n",
    "\n",
    "    # Model\n",
    "    in_features = embedding_dim\n",
    "    hidden_dim = 128\n",
    "    out_dim = embedding_dim\n",
    "    encoder = encoder_class(in_features, hidden_dim, out_dim)\n",
    "    classifier = Classifier(out_dim, data.y.max().item() + 1)\n",
    "    model = GraFN(encoder, classifier, unique_labels=list(range(data.y.max().item() + 1)))\n",
    "    optimizer = torch.optim.Adam(model.parameters(), lr=0.01, weight_decay=5e-4)\n",
    "\n",
    "    # Training\n",
    "    model.train()\n",
    "    start_time = time.time()\n",
    "    for epoch in range(epochs):\n",
    "        optimizer.zero_grad()\n",
    "        out = model(data)\n",
    "        loss = F.cross_entropy(out[data.train_mask], data.y[data.train_mask])\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "        if (epoch+1) % 20 == 0 or epoch == 0:\n",
    "            val_loss = F.cross_entropy(out[data.test_mask], data.y[data.test_mask])\n",
    "            print(f\"Epoch {epoch+1:03d} | Train Loss: {loss.item():.4f} | Val Loss: {val_loss.item():.4f}\")\n",
    "    elapsed_time = time.time() - start_time\n",
    "\n",
    "    # Save embeddings\n",
    "    model.eval()\n",
    "    with torch.no_grad():\n",
    "        embeddings = model(data)\n",
    "    mask_basename = os.path.basename(mask_file)\n",
    "    seed_str = \"seed42\"\n",
    "    if \"seed\" in mask_basename:\n",
    "        parts = mask_basename.split(\"seed\")\n",
    "        if len(parts) > 1:\n",
    "            seed_str = \"seed\" + parts[1].replace(\".npy\", \"\")\n",
    "    embeddings_subdir = os.path.join(base_embeddings_dir, dataset_name, split_type)\n",
    "    os.makedirs(embeddings_subdir, exist_ok=True)\n",
    "    embedding_filename = f\"{dataset_name}_{encoder_name}_{split_type}_{seed_str}.pt\"\n",
    "    torch.save(embeddings, os.path.join(embeddings_subdir, embedding_filename))\n",
    "    print(f\"Saved embeddings to {os.path.join(embeddings_subdir, embedding_filename)}\")\n",
    "\n",
    "    # Evaluation\n",
    "    with torch.no_grad():\n",
    "        out = model(data)\n",
    "        preds = out.argmax(dim=1).cpu().numpy()\n",
    "        true_labels = data.y.cpu().numpy()\n",
    "        test_mask_np = data.test_mask.cpu().numpy()\n",
    "        test_preds = preds[test_mask_np]\n",
    "        test_labels = true_labels[test_mask_np]\n",
    "\n",
    "        acc = accuracy_score(test_labels, test_preds)\n",
    "        f1_macro = f1_score(test_labels, test_preds, average=\"macro\")\n",
    "        f1_micro = f1_score(test_labels, test_preds, average=\"micro\")\n",
    "\n",
    "    return {\n",
    "        \"encoder\": encoder_name,\n",
    "        \"accuracy\": acc,\n",
    "        \"f1_macro\": f1_macro,\n",
    "        \"f1_micro\": f1_micro,\n",
    "        \"time\": elapsed_time\n",
    "    }\n",
    "\n",
    "# -------------------------------\n",
    "# Run experiments\n",
    "# -------------------------------\n",
    "encoder_classes = {\n",
    "    \"GCN\": GCNEncoder,\n",
    "    \"GAT\": GATEncoder,\n",
    "    \"GraphSAGE\": GraphSAGEEncoder\n",
    "}\n",
    "\n",
    "embedding_dim = 150\n",
    "epochs = 200\n",
    "\n",
    "for dataset_name, loader in datasets_info.items():\n",
    "    print(f\"\\n========== Dataset: {dataset_name} ==========\")\n",
    "    dataset = loader()\n",
    "    data = dataset[0]\n",
    "    data.x = torch.randn(data.num_nodes, embedding_dim)\n",
    "\n",
    "    for split_type in splits:\n",
    "        mask_dir = mask_dirs_template.format(dataset=dataset_name, split=split_type)\n",
    "        results_subdir = os.path.join(base_results_dir, dataset_name, split_type)\n",
    "        os.makedirs(results_subdir, exist_ok=True)\n",
    "\n",
    "        mask_files = sorted(glob.glob(os.path.join(mask_dir, \"*.npy\")))\n",
    "        if len(mask_files) == 0:\n",
    "            print(f\"No mask files found for {dataset_name} split {split_type}. Skipping.\")\n",
    "            continue\n",
    "\n",
    "        all_encoder_results = []\n",
    "\n",
    "        for encoder_name, encoder_class in encoder_classes.items():\n",
    "            encoder_results = []\n",
    "            for mask_file in mask_files:\n",
    "                result = run_pipeline(data, mask_file, dataset_name, split_type, encoder_class, encoder_name, embedding_dim, epochs)\n",
    "                encoder_results.append(result)\n",
    "\n",
    "            # Compute mean ± std\n",
    "            acc_vals = [r[\"accuracy\"] for r in encoder_results]\n",
    "            f1_macro_vals = [r[\"f1_macro\"] for r in encoder_results]\n",
    "            f1_micro_vals = [r[\"f1_micro\"] for r in encoder_results]\n",
    "            time_vals = [r[\"time\"] for r in encoder_results]\n",
    "\n",
    "            avg_metrics = {\n",
    "                \"encoder\": encoder_name,\n",
    "                \"accuracy\": f\"{np.mean(acc_vals):.4f} ± {np.std(acc_vals):.4f}\",\n",
    "                \"f1_macro\": f\"{np.mean(f1_macro_vals):.4f} ± {np.std(f1_macro_vals):.4f}\",\n",
    "                \"f1_micro\": f\"{np.mean(f1_micro_vals):.4f} ± {np.std(f1_micro_vals):.4f}\",\n",
    "                \"time\": f\"{np.mean(time_vals):.2f} ± {np.std(time_vals):.2f}\"\n",
    "            }\n",
    "            all_encoder_results.append(avg_metrics)\n",
    "\n",
    "        # Save averaged results\n",
    "        results_df = pd.DataFrame(all_encoder_results)\n",
    "        metrics_df = results_df[['encoder', 'accuracy', 'f1_macro', 'f1_micro']]\n",
    "        times_df = results_df[['encoder', 'time']]\n",
    "        metrics_df.to_csv(os.path.join(results_subdir, f\"{dataset_name}_results.csv\"), index=False)\n",
    "        times_df.to_csv(os.path.join(results_subdir, f\"{dataset_name}_execution_times.csv\"), index=False)\n",
    "\n",
    "        print(f\"Saved averaged results and execution times for {dataset_name} split {split_type}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "d3978365-4e85-4695-9854-5d7da7dddc29",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "========== Dataset: AmazonPhotos ==========\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_30_70_masked_indices_seed123.npy (30_70, GCN) ===\n",
      "Train nodes: 2295 | Test nodes: 5355\n",
      "Epoch 001 | Train Loss: 4.9809 | Val Loss: 4.9800\n",
      "Epoch 020 | Train Loss: 0.9502 | Val Loss: 1.1252\n",
      "Epoch 040 | Train Loss: 0.4202 | Val Loss: 0.8891\n",
      "Epoch 060 | Train Loss: 0.2843 | Val Loss: 0.8885\n",
      "Epoch 080 | Train Loss: 0.2391 | Val Loss: 0.9117\n",
      "Epoch 100 | Train Loss: 0.2066 | Val Loss: 0.9340\n",
      "Epoch 120 | Train Loss: 0.1816 | Val Loss: 0.9513\n",
      "Epoch 140 | Train Loss: 0.1651 | Val Loss: 0.9681\n",
      "Epoch 160 | Train Loss: 0.1527 | Val Loss: 0.9813\n",
      "Epoch 180 | Train Loss: 0.1428 | Val Loss: 0.9921\n",
      "Epoch 200 | Train Loss: 0.1351 | Val Loss: 1.0017\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/30_70/AmazonPhotos_GCN_30_70_seed123.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_30_70_masked_indices_seed2025.npy (30_70, GCN) ===\n",
      "Train nodes: 2295 | Test nodes: 5355\n",
      "Epoch 001 | Train Loss: 4.9794 | Val Loss: 4.9753\n",
      "Epoch 020 | Train Loss: 0.9350 | Val Loss: 1.1250\n",
      "Epoch 040 | Train Loss: 0.3857 | Val Loss: 0.9228\n",
      "Epoch 060 | Train Loss: 0.2595 | Val Loss: 0.9352\n",
      "Epoch 080 | Train Loss: 0.2221 | Val Loss: 0.9554\n",
      "Epoch 100 | Train Loss: 0.1952 | Val Loss: 0.9787\n",
      "Epoch 120 | Train Loss: 0.1736 | Val Loss: 0.9991\n",
      "Epoch 140 | Train Loss: 0.1592 | Val Loss: 1.0154\n",
      "Epoch 160 | Train Loss: 0.1483 | Val Loss: 1.0295\n",
      "Epoch 180 | Train Loss: 0.1396 | Val Loss: 1.0398\n",
      "Epoch 200 | Train Loss: 0.1327 | Val Loss: 1.0500\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/30_70/AmazonPhotos_GCN_30_70_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_30_70_masked_indices_seed42.npy (30_70, GCN) ===\n",
      "Train nodes: 2295 | Test nodes: 5355\n",
      "Epoch 001 | Train Loss: 5.0279 | Val Loss: 5.0234\n",
      "Epoch 020 | Train Loss: 0.9753 | Val Loss: 1.1423\n",
      "Epoch 040 | Train Loss: 0.3940 | Val Loss: 0.8666\n",
      "Epoch 060 | Train Loss: 0.2618 | Val Loss: 0.8711\n",
      "Epoch 080 | Train Loss: 0.2238 | Val Loss: 0.8852\n",
      "Epoch 100 | Train Loss: 0.1969 | Val Loss: 0.9041\n",
      "Epoch 120 | Train Loss: 0.1749 | Val Loss: 0.9184\n",
      "Epoch 140 | Train Loss: 0.1604 | Val Loss: 0.9335\n",
      "Epoch 160 | Train Loss: 0.1495 | Val Loss: 0.9441\n",
      "Epoch 180 | Train Loss: 0.1408 | Val Loss: 0.9529\n",
      "Epoch 200 | Train Loss: 0.1336 | Val Loss: 0.9616\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/30_70/AmazonPhotos_GCN_30_70_seed42.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_30_70_masked_indices_seed46.npy (30_70, GCN) ===\n",
      "Train nodes: 2295 | Test nodes: 5355\n",
      "Epoch 001 | Train Loss: 5.0654 | Val Loss: 5.0648\n",
      "Epoch 020 | Train Loss: 0.9488 | Val Loss: 1.1261\n",
      "Epoch 040 | Train Loss: 0.3956 | Val Loss: 0.8948\n",
      "Epoch 060 | Train Loss: 0.2656 | Val Loss: 0.9202\n",
      "Epoch 080 | Train Loss: 0.2250 | Val Loss: 0.9364\n",
      "Epoch 100 | Train Loss: 0.1951 | Val Loss: 0.9563\n",
      "Epoch 120 | Train Loss: 0.1719 | Val Loss: 0.9776\n",
      "Epoch 140 | Train Loss: 0.1565 | Val Loss: 0.9956\n",
      "Epoch 160 | Train Loss: 0.1453 | Val Loss: 1.0133\n",
      "Epoch 180 | Train Loss: 0.1365 | Val Loss: 1.0279\n",
      "Epoch 200 | Train Loss: 0.1297 | Val Loss: 1.0400\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/30_70/AmazonPhotos_GCN_30_70_seed46.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_30_70_masked_indices_seed999.npy (30_70, GCN) ===\n",
      "Train nodes: 2295 | Test nodes: 5355\n",
      "Epoch 001 | Train Loss: 5.0095 | Val Loss: 5.0081\n",
      "Epoch 020 | Train Loss: 0.9622 | Val Loss: 1.1183\n",
      "Epoch 040 | Train Loss: 0.3918 | Val Loss: 0.8763\n",
      "Epoch 060 | Train Loss: 0.2614 | Val Loss: 0.8902\n",
      "Epoch 080 | Train Loss: 0.2223 | Val Loss: 0.9080\n",
      "Epoch 100 | Train Loss: 0.1934 | Val Loss: 0.9332\n",
      "Epoch 120 | Train Loss: 0.1705 | Val Loss: 0.9552\n",
      "Epoch 140 | Train Loss: 0.1551 | Val Loss: 0.9745\n",
      "Epoch 160 | Train Loss: 0.1437 | Val Loss: 0.9904\n",
      "Epoch 180 | Train Loss: 0.1347 | Val Loss: 1.0045\n",
      "Epoch 200 | Train Loss: 0.1275 | Val Loss: 1.0189\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/30_70/AmazonPhotos_GCN_30_70_seed999.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_30_70_masked_indices_seed123.npy (30_70, GAT) ===\n",
      "Train nodes: 2295 | Test nodes: 5355\n",
      "Epoch 001 | Train Loss: 5.0189 | Val Loss: 5.0281\n",
      "Epoch 020 | Train Loss: 0.7271 | Val Loss: 0.9603\n",
      "Epoch 040 | Train Loss: 0.2607 | Val Loss: 0.7919\n",
      "Epoch 060 | Train Loss: 0.1392 | Val Loss: 0.8038\n",
      "Epoch 080 | Train Loss: 0.1030 | Val Loss: 0.8299\n",
      "Epoch 100 | Train Loss: 0.0648 | Val Loss: 0.8582\n",
      "Epoch 120 | Train Loss: 0.0742 | Val Loss: 0.8570\n",
      "Epoch 140 | Train Loss: 0.0474 | Val Loss: 0.8628\n",
      "Epoch 160 | Train Loss: 0.0343 | Val Loss: 0.8392\n",
      "Epoch 180 | Train Loss: 0.0280 | Val Loss: 0.8089\n",
      "Epoch 200 | Train Loss: 0.0254 | Val Loss: 0.7631\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/30_70/AmazonPhotos_GAT_30_70_seed123.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_30_70_masked_indices_seed2025.npy (30_70, GAT) ===\n",
      "Train nodes: 2295 | Test nodes: 5355\n",
      "Epoch 001 | Train Loss: 5.0252 | Val Loss: 5.0246\n",
      "Epoch 020 | Train Loss: 0.2726 | Val Loss: 0.8645\n",
      "Epoch 040 | Train Loss: 0.0349 | Val Loss: 0.8971\n",
      "Epoch 060 | Train Loss: 0.0176 | Val Loss: 0.8949\n",
      "Epoch 080 | Train Loss: 0.0136 | Val Loss: 0.8042\n",
      "Epoch 100 | Train Loss: 0.0121 | Val Loss: 0.7232\n",
      "Epoch 120 | Train Loss: 0.0105 | Val Loss: 0.7090\n",
      "Epoch 140 | Train Loss: 0.0088 | Val Loss: 0.7078\n",
      "Epoch 160 | Train Loss: 0.0091 | Val Loss: 0.7212\n",
      "Epoch 180 | Train Loss: 0.0186 | Val Loss: 0.6329\n",
      "Epoch 200 | Train Loss: 0.0055 | Val Loss: 0.6701\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/30_70/AmazonPhotos_GAT_30_70_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_30_70_masked_indices_seed42.npy (30_70, GAT) ===\n",
      "Train nodes: 2295 | Test nodes: 5355\n",
      "Epoch 001 | Train Loss: 5.0303 | Val Loss: 5.0249\n",
      "Epoch 020 | Train Loss: 0.4672 | Val Loss: 0.7775\n",
      "Epoch 040 | Train Loss: 0.1818 | Val Loss: 0.7080\n",
      "Epoch 060 | Train Loss: 0.1262 | Val Loss: 0.7443\n",
      "Epoch 080 | Train Loss: 0.0533 | Val Loss: 0.7008\n",
      "Epoch 100 | Train Loss: 0.0283 | Val Loss: 0.7349\n",
      "Epoch 120 | Train Loss: 0.0205 | Val Loss: 0.7176\n",
      "Epoch 140 | Train Loss: 0.0179 | Val Loss: 0.6853\n",
      "Epoch 160 | Train Loss: 0.0159 | Val Loss: 0.6617\n",
      "Epoch 180 | Train Loss: 0.0150 | Val Loss: 0.6503\n",
      "Epoch 200 | Train Loss: 0.0135 | Val Loss: 0.6425\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/30_70/AmazonPhotos_GAT_30_70_seed42.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_30_70_masked_indices_seed46.npy (30_70, GAT) ===\n",
      "Train nodes: 2295 | Test nodes: 5355\n",
      "Epoch 001 | Train Loss: 5.0155 | Val Loss: 5.0118\n",
      "Epoch 020 | Train Loss: 0.4441 | Val Loss: 0.8373\n",
      "Epoch 040 | Train Loss: 0.1677 | Val Loss: 0.7239\n",
      "Epoch 060 | Train Loss: 0.0707 | Val Loss: 0.6554\n",
      "Epoch 080 | Train Loss: 0.0346 | Val Loss: 0.6577\n",
      "Epoch 100 | Train Loss: 0.0202 | Val Loss: 0.6702\n",
      "Epoch 120 | Train Loss: 0.0143 | Val Loss: 0.6557\n",
      "Epoch 140 | Train Loss: 0.0116 | Val Loss: 0.7085\n",
      "Epoch 160 | Train Loss: 0.0115 | Val Loss: 0.6188\n",
      "Epoch 180 | Train Loss: 0.0069 | Val Loss: 0.6343\n",
      "Epoch 200 | Train Loss: 0.0062 | Val Loss: 0.6281\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/30_70/AmazonPhotos_GAT_30_70_seed46.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_30_70_masked_indices_seed999.npy (30_70, GAT) ===\n",
      "Train nodes: 2295 | Test nodes: 5355\n",
      "Epoch 001 | Train Loss: 5.0500 | Val Loss: 5.0480\n",
      "Epoch 020 | Train Loss: 0.2727 | Val Loss: 0.7877\n",
      "Epoch 040 | Train Loss: 0.0341 | Val Loss: 0.8049\n",
      "Epoch 060 | Train Loss: 0.0186 | Val Loss: 0.7983\n",
      "Epoch 080 | Train Loss: 0.0148 | Val Loss: 0.7457\n",
      "Epoch 100 | Train Loss: 0.0132 | Val Loss: 0.6854\n",
      "Epoch 120 | Train Loss: 0.0129 | Val Loss: 0.6398\n",
      "Epoch 140 | Train Loss: 0.0094 | Val Loss: 0.6449\n",
      "Epoch 160 | Train Loss: 0.0086 | Val Loss: 0.7386\n",
      "Epoch 180 | Train Loss: 0.0058 | Val Loss: 0.7417\n",
      "Epoch 200 | Train Loss: 0.0054 | Val Loss: 0.7285\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/30_70/AmazonPhotos_GAT_30_70_seed999.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_30_70_masked_indices_seed123.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 2295 | Test nodes: 5355\n",
      "Epoch 001 | Train Loss: 5.1452 | Val Loss: 5.1475\n",
      "Epoch 020 | Train Loss: 0.2318 | Val Loss: 1.1028\n",
      "Epoch 040 | Train Loss: 0.0179 | Val Loss: 1.1049\n",
      "Epoch 060 | Train Loss: 0.0170 | Val Loss: 1.0916\n",
      "Epoch 080 | Train Loss: 0.0241 | Val Loss: 1.0407\n",
      "Epoch 100 | Train Loss: 0.0215 | Val Loss: 1.0086\n",
      "Epoch 120 | Train Loss: 0.0188 | Val Loss: 0.9987\n",
      "Epoch 140 | Train Loss: 0.0174 | Val Loss: 0.9936\n",
      "Epoch 160 | Train Loss: 0.0160 | Val Loss: 0.9921\n",
      "Epoch 180 | Train Loss: 0.0149 | Val Loss: 0.9936\n",
      "Epoch 200 | Train Loss: 0.0140 | Val Loss: 0.9958\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/30_70/AmazonPhotos_GraphSAGE_30_70_seed123.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_30_70_masked_indices_seed2025.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 2295 | Test nodes: 5355\n",
      "Epoch 001 | Train Loss: 5.0575 | Val Loss: 5.0500\n",
      "Epoch 020 | Train Loss: 0.2145 | Val Loss: 1.1306\n",
      "Epoch 040 | Train Loss: 0.0162 | Val Loss: 1.1770\n",
      "Epoch 060 | Train Loss: 0.0164 | Val Loss: 1.1366\n",
      "Epoch 080 | Train Loss: 0.0238 | Val Loss: 1.0782\n",
      "Epoch 100 | Train Loss: 0.0212 | Val Loss: 1.0473\n",
      "Epoch 120 | Train Loss: 0.0185 | Val Loss: 1.0381\n",
      "Epoch 140 | Train Loss: 0.0172 | Val Loss: 1.0315\n",
      "Epoch 160 | Train Loss: 0.0158 | Val Loss: 1.0300\n",
      "Epoch 180 | Train Loss: 0.0147 | Val Loss: 1.0318\n",
      "Epoch 200 | Train Loss: 0.0138 | Val Loss: 1.0338\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/30_70/AmazonPhotos_GraphSAGE_30_70_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_30_70_masked_indices_seed42.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 2295 | Test nodes: 5355\n",
      "Epoch 001 | Train Loss: 5.0924 | Val Loss: 5.0966\n",
      "Epoch 020 | Train Loss: 0.2138 | Val Loss: 1.1091\n",
      "Epoch 040 | Train Loss: 0.0172 | Val Loss: 1.1101\n",
      "Epoch 060 | Train Loss: 0.0167 | Val Loss: 1.0994\n",
      "Epoch 080 | Train Loss: 0.0241 | Val Loss: 1.0540\n",
      "Epoch 100 | Train Loss: 0.0215 | Val Loss: 1.0292\n",
      "Epoch 120 | Train Loss: 0.0188 | Val Loss: 1.0215\n",
      "Epoch 140 | Train Loss: 0.0174 | Val Loss: 1.0196\n",
      "Epoch 160 | Train Loss: 0.0160 | Val Loss: 1.0210\n",
      "Epoch 180 | Train Loss: 0.0149 | Val Loss: 1.0225\n",
      "Epoch 200 | Train Loss: 0.0140 | Val Loss: 1.0250\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/30_70/AmazonPhotos_GraphSAGE_30_70_seed42.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_30_70_masked_indices_seed46.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 2295 | Test nodes: 5355\n",
      "Epoch 001 | Train Loss: 5.1066 | Val Loss: 5.1035\n",
      "Epoch 020 | Train Loss: 0.2351 | Val Loss: 1.1220\n",
      "Epoch 040 | Train Loss: 0.0180 | Val Loss: 1.1287\n",
      "Epoch 060 | Train Loss: 0.0172 | Val Loss: 1.1116\n",
      "Epoch 080 | Train Loss: 0.0247 | Val Loss: 1.0695\n",
      "Epoch 100 | Train Loss: 0.0219 | Val Loss: 1.0467\n",
      "Epoch 120 | Train Loss: 0.0191 | Val Loss: 1.0408\n",
      "Epoch 140 | Train Loss: 0.0178 | Val Loss: 1.0373\n",
      "Epoch 160 | Train Loss: 0.0163 | Val Loss: 1.0374\n",
      "Epoch 180 | Train Loss: 0.0152 | Val Loss: 1.0403\n",
      "Epoch 200 | Train Loss: 0.0143 | Val Loss: 1.0439\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/30_70/AmazonPhotos_GraphSAGE_30_70_seed46.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_30_70_masked_indices_seed999.npy (30_70, GraphSAGE) ===\n",
      "Train nodes: 2295 | Test nodes: 5355\n",
      "Epoch 001 | Train Loss: 5.0954 | Val Loss: 5.0911\n",
      "Epoch 020 | Train Loss: 0.2134 | Val Loss: 1.1285\n",
      "Epoch 040 | Train Loss: 0.0168 | Val Loss: 1.1523\n",
      "Epoch 060 | Train Loss: 0.0166 | Val Loss: 1.1302\n",
      "Epoch 080 | Train Loss: 0.0238 | Val Loss: 1.0759\n",
      "Epoch 100 | Train Loss: 0.0212 | Val Loss: 1.0461\n",
      "Epoch 120 | Train Loss: 0.0186 | Val Loss: 1.0335\n",
      "Epoch 140 | Train Loss: 0.0172 | Val Loss: 1.0262\n",
      "Epoch 160 | Train Loss: 0.0158 | Val Loss: 1.0239\n",
      "Epoch 180 | Train Loss: 0.0147 | Val Loss: 1.0245\n",
      "Epoch 200 | Train Loss: 0.0139 | Val Loss: 1.0252\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/30_70/AmazonPhotos_GraphSAGE_30_70_seed999.pt\n",
      "Saved averaged results and execution times for AmazonPhotos split 30_70\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_70_30_masked_indices_seed123.npy (70_30, GCN) ===\n",
      "Train nodes: 5355 | Test nodes: 2295\n",
      "Epoch 001 | Train Loss: 5.0115 | Val Loss: 5.0093\n",
      "Epoch 020 | Train Loss: 1.0157 | Val Loss: 1.1249\n",
      "Epoch 040 | Train Loss: 0.4899 | Val Loss: 0.8242\n",
      "Epoch 060 | Train Loss: 0.3562 | Val Loss: 0.7731\n",
      "Epoch 080 | Train Loss: 0.3094 | Val Loss: 0.7815\n",
      "Epoch 100 | Train Loss: 0.2742 | Val Loss: 0.7843\n",
      "Epoch 120 | Train Loss: 0.2473 | Val Loss: 0.7848\n",
      "Epoch 140 | Train Loss: 0.2287 | Val Loss: 0.7857\n",
      "Epoch 160 | Train Loss: 0.2148 | Val Loss: 0.7872\n",
      "Epoch 180 | Train Loss: 0.2037 | Val Loss: 0.7900\n",
      "Epoch 200 | Train Loss: 0.1948 | Val Loss: 0.7913\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/70_30/AmazonPhotos_GCN_70_30_seed123.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_70_30_masked_indices_seed2025.npy (70_30, GCN) ===\n",
      "Train nodes: 5355 | Test nodes: 2295\n",
      "Epoch 001 | Train Loss: 5.0781 | Val Loss: 5.0824\n",
      "Epoch 020 | Train Loss: 1.0194 | Val Loss: 1.1219\n",
      "Epoch 040 | Train Loss: 0.4983 | Val Loss: 0.7938\n",
      "Epoch 060 | Train Loss: 0.3649 | Val Loss: 0.7251\n",
      "Epoch 080 | Train Loss: 0.3185 | Val Loss: 0.6945\n",
      "Epoch 100 | Train Loss: 0.2831 | Val Loss: 0.6723\n",
      "Epoch 120 | Train Loss: 0.2553 | Val Loss: 0.6578\n",
      "Epoch 140 | Train Loss: 0.2363 | Val Loss: 0.6514\n",
      "Epoch 160 | Train Loss: 0.2219 | Val Loss: 0.6477\n",
      "Epoch 180 | Train Loss: 0.2104 | Val Loss: 0.6448\n",
      "Epoch 200 | Train Loss: 0.2010 | Val Loss: 0.6429\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/70_30/AmazonPhotos_GCN_70_30_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_70_30_masked_indices_seed42.npy (70_30, GCN) ===\n",
      "Train nodes: 5355 | Test nodes: 2295\n",
      "Epoch 001 | Train Loss: 5.0592 | Val Loss: 5.0609\n",
      "Epoch 020 | Train Loss: 1.0138 | Val Loss: 1.1230\n",
      "Epoch 040 | Train Loss: 0.4937 | Val Loss: 0.7945\n",
      "Epoch 060 | Train Loss: 0.3568 | Val Loss: 0.7458\n",
      "Epoch 080 | Train Loss: 0.3103 | Val Loss: 0.7292\n",
      "Epoch 100 | Train Loss: 0.2766 | Val Loss: 0.7220\n",
      "Epoch 120 | Train Loss: 0.2502 | Val Loss: 0.7171\n",
      "Epoch 140 | Train Loss: 0.2315 | Val Loss: 0.7123\n",
      "Epoch 160 | Train Loss: 0.2172 | Val Loss: 0.7080\n",
      "Epoch 180 | Train Loss: 0.2061 | Val Loss: 0.7030\n",
      "Epoch 200 | Train Loss: 0.1972 | Val Loss: 0.7005\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/70_30/AmazonPhotos_GCN_70_30_seed42.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_70_30_masked_indices_seed46.npy (70_30, GCN) ===\n",
      "Train nodes: 5355 | Test nodes: 2295\n",
      "Epoch 001 | Train Loss: 5.0220 | Val Loss: 5.0209\n",
      "Epoch 020 | Train Loss: 1.0246 | Val Loss: 1.1339\n",
      "Epoch 040 | Train Loss: 0.4929 | Val Loss: 0.8439\n",
      "Epoch 060 | Train Loss: 0.3583 | Val Loss: 0.7859\n",
      "Epoch 080 | Train Loss: 0.3119 | Val Loss: 0.7704\n",
      "Epoch 100 | Train Loss: 0.2758 | Val Loss: 0.7667\n",
      "Epoch 120 | Train Loss: 0.2479 | Val Loss: 0.7639\n",
      "Epoch 140 | Train Loss: 0.2291 | Val Loss: 0.7611\n",
      "Epoch 160 | Train Loss: 0.2148 | Val Loss: 0.7593\n",
      "Epoch 180 | Train Loss: 0.2034 | Val Loss: 0.7577\n",
      "Epoch 200 | Train Loss: 0.1943 | Val Loss: 0.7543\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/70_30/AmazonPhotos_GCN_70_30_seed46.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_70_30_masked_indices_seed999.npy (70_30, GCN) ===\n",
      "Train nodes: 5355 | Test nodes: 2295\n",
      "Epoch 001 | Train Loss: 5.0012 | Val Loss: 5.0062\n",
      "Epoch 020 | Train Loss: 1.0157 | Val Loss: 1.1084\n",
      "Epoch 040 | Train Loss: 0.4969 | Val Loss: 0.7913\n",
      "Epoch 060 | Train Loss: 0.3616 | Val Loss: 0.7393\n",
      "Epoch 080 | Train Loss: 0.3139 | Val Loss: 0.7262\n",
      "Epoch 100 | Train Loss: 0.2789 | Val Loss: 0.7208\n",
      "Epoch 120 | Train Loss: 0.2515 | Val Loss: 0.7203\n",
      "Epoch 140 | Train Loss: 0.2330 | Val Loss: 0.7187\n",
      "Epoch 160 | Train Loss: 0.2190 | Val Loss: 0.7163\n",
      "Epoch 180 | Train Loss: 0.2077 | Val Loss: 0.7170\n",
      "Epoch 200 | Train Loss: 0.1987 | Val Loss: 0.7174\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/70_30/AmazonPhotos_GCN_70_30_seed999.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_70_30_masked_indices_seed123.npy (70_30, GAT) ===\n",
      "Train nodes: 5355 | Test nodes: 2295\n",
      "Epoch 001 | Train Loss: 5.0323 | Val Loss: 5.0320\n",
      "Epoch 020 | Train Loss: 0.1760 | Val Loss: 0.5591\n",
      "Epoch 040 | Train Loss: 0.0389 | Val Loss: 0.4890\n",
      "Epoch 060 | Train Loss: 0.0184 | Val Loss: 0.5211\n",
      "Epoch 080 | Train Loss: 0.0140 | Val Loss: 0.5253\n",
      "Epoch 100 | Train Loss: 0.0119 | Val Loss: 0.5187\n",
      "Epoch 120 | Train Loss: 0.0124 | Val Loss: 0.5136\n",
      "Epoch 140 | Train Loss: 0.0087 | Val Loss: 0.5402\n",
      "Epoch 160 | Train Loss: 0.0116 | Val Loss: 0.5032\n",
      "Epoch 180 | Train Loss: 0.0078 | Val Loss: 0.5211\n",
      "Epoch 200 | Train Loss: 0.0112 | Val Loss: 0.5238\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/70_30/AmazonPhotos_GAT_70_30_seed123.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_70_30_masked_indices_seed2025.npy (70_30, GAT) ===\n",
      "Train nodes: 5355 | Test nodes: 2295\n",
      "Epoch 001 | Train Loss: 5.0204 | Val Loss: 5.0185\n",
      "Epoch 020 | Train Loss: 0.5490 | Val Loss: 0.7976\n",
      "Epoch 040 | Train Loss: 0.2135 | Val Loss: 0.5698\n",
      "Epoch 060 | Train Loss: 0.1075 | Val Loss: 0.5801\n",
      "Epoch 080 | Train Loss: 0.0720 | Val Loss: 0.5978\n",
      "Epoch 100 | Train Loss: 0.0576 | Val Loss: 0.6137\n",
      "Epoch 120 | Train Loss: 0.0489 | Val Loss: 0.6097\n",
      "Epoch 140 | Train Loss: 0.0410 | Val Loss: 0.5981\n",
      "Epoch 160 | Train Loss: 0.0333 | Val Loss: 0.5905\n",
      "Epoch 180 | Train Loss: 0.0309 | Val Loss: 0.5885\n",
      "Epoch 200 | Train Loss: 0.0219 | Val Loss: 0.6245\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/70_30/AmazonPhotos_GAT_70_30_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_70_30_masked_indices_seed42.npy (70_30, GAT) ===\n",
      "Train nodes: 5355 | Test nodes: 2295\n",
      "Epoch 001 | Train Loss: 5.0056 | Val Loss: 5.0056\n",
      "Epoch 020 | Train Loss: 0.3936 | Val Loss: 0.6223\n",
      "Epoch 040 | Train Loss: 0.1025 | Val Loss: 0.4311\n",
      "Epoch 060 | Train Loss: 0.0438 | Val Loss: 0.4293\n",
      "Epoch 080 | Train Loss: 0.0253 | Val Loss: 0.4749\n",
      "Epoch 100 | Train Loss: 0.0189 | Val Loss: 0.4969\n",
      "Epoch 120 | Train Loss: 0.0162 | Val Loss: 0.5033\n",
      "Epoch 140 | Train Loss: 0.0144 | Val Loss: 0.5076\n",
      "Epoch 160 | Train Loss: 0.0162 | Val Loss: 0.5163\n",
      "Epoch 180 | Train Loss: 0.0132 | Val Loss: 0.5273\n",
      "Epoch 200 | Train Loss: 0.0114 | Val Loss: 0.5354\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/70_30/AmazonPhotos_GAT_70_30_seed42.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_70_30_masked_indices_seed46.npy (70_30, GAT) ===\n",
      "Train nodes: 5355 | Test nodes: 2295\n",
      "Epoch 001 | Train Loss: 5.0039 | Val Loss: 5.0054\n",
      "Epoch 020 | Train Loss: 0.2518 | Val Loss: 0.7397\n",
      "Epoch 040 | Train Loss: 0.0491 | Val Loss: 0.6886\n",
      "Epoch 060 | Train Loss: 0.0249 | Val Loss: 0.6713\n",
      "Epoch 080 | Train Loss: 0.0195 | Val Loss: 0.6078\n",
      "Epoch 100 | Train Loss: 0.0162 | Val Loss: 0.5438\n",
      "Epoch 120 | Train Loss: 0.0133 | Val Loss: 0.5191\n",
      "Epoch 140 | Train Loss: 0.0118 | Val Loss: 0.5079\n",
      "Epoch 160 | Train Loss: 0.0121 | Val Loss: 0.5047\n",
      "Epoch 180 | Train Loss: 0.0099 | Val Loss: 0.5034\n",
      "Epoch 200 | Train Loss: 0.0090 | Val Loss: 0.5062\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/70_30/AmazonPhotos_GAT_70_30_seed46.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_70_30_masked_indices_seed999.npy (70_30, GAT) ===\n",
      "Train nodes: 5355 | Test nodes: 2295\n",
      "Epoch 001 | Train Loss: 5.0310 | Val Loss: 5.0294\n",
      "Epoch 020 | Train Loss: 0.3900 | Val Loss: 0.6560\n",
      "Epoch 040 | Train Loss: 0.1871 | Val Loss: 0.6150\n",
      "Epoch 060 | Train Loss: 0.1148 | Val Loss: 0.6175\n",
      "Epoch 080 | Train Loss: 0.0734 | Val Loss: 0.6396\n",
      "Epoch 100 | Train Loss: 0.0513 | Val Loss: 0.6664\n",
      "Epoch 120 | Train Loss: 0.0390 | Val Loss: 0.6899\n",
      "Epoch 140 | Train Loss: 0.0345 | Val Loss: 0.6638\n",
      "Epoch 160 | Train Loss: 0.0297 | Val Loss: 0.6457\n",
      "Epoch 180 | Train Loss: 0.0265 | Val Loss: 0.6513\n",
      "Epoch 200 | Train Loss: 0.0290 | Val Loss: 0.6629\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/70_30/AmazonPhotos_GAT_70_30_seed999.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_70_30_masked_indices_seed123.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 5355 | Test nodes: 2295\n",
      "Epoch 001 | Train Loss: 5.0691 | Val Loss: 5.0634\n",
      "Epoch 020 | Train Loss: 0.3920 | Val Loss: 0.8955\n",
      "Epoch 040 | Train Loss: 0.0687 | Val Loss: 0.7397\n",
      "Epoch 060 | Train Loss: 0.0362 | Val Loss: 0.7205\n",
      "Epoch 080 | Train Loss: 0.0370 | Val Loss: 0.7007\n",
      "Epoch 100 | Train Loss: 0.0331 | Val Loss: 0.6953\n",
      "Epoch 120 | Train Loss: 0.0288 | Val Loss: 0.6965\n",
      "Epoch 140 | Train Loss: 0.0261 | Val Loss: 0.6974\n",
      "Epoch 160 | Train Loss: 0.0239 | Val Loss: 0.7016\n",
      "Epoch 180 | Train Loss: 0.0221 | Val Loss: 0.7032\n",
      "Epoch 200 | Train Loss: 0.0206 | Val Loss: 0.7056\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/70_30/AmazonPhotos_GraphSAGE_70_30_seed123.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_70_30_masked_indices_seed2025.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 5355 | Test nodes: 2295\n",
      "Epoch 001 | Train Loss: 5.1829 | Val Loss: 5.1874\n",
      "Epoch 020 | Train Loss: 0.4422 | Val Loss: 0.8949\n",
      "Epoch 040 | Train Loss: 0.0878 | Val Loss: 0.6753\n",
      "Epoch 060 | Train Loss: 0.0423 | Val Loss: 0.6477\n",
      "Epoch 080 | Train Loss: 0.0406 | Val Loss: 0.6341\n",
      "Epoch 100 | Train Loss: 0.0367 | Val Loss: 0.6237\n",
      "Epoch 120 | Train Loss: 0.0318 | Val Loss: 0.6217\n",
      "Epoch 140 | Train Loss: 0.0286 | Val Loss: 0.6225\n",
      "Epoch 160 | Train Loss: 0.0261 | Val Loss: 0.6237\n",
      "Epoch 180 | Train Loss: 0.0240 | Val Loss: 0.6263\n",
      "Epoch 200 | Train Loss: 0.0223 | Val Loss: 0.6281\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/70_30/AmazonPhotos_GraphSAGE_70_30_seed2025.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_70_30_masked_indices_seed42.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 5355 | Test nodes: 2295\n",
      "Epoch 001 | Train Loss: 5.0092 | Val Loss: 5.0157\n",
      "Epoch 020 | Train Loss: 0.3969 | Val Loss: 0.8067\n",
      "Epoch 040 | Train Loss: 0.0667 | Val Loss: 0.6630\n",
      "Epoch 060 | Train Loss: 0.0349 | Val Loss: 0.6543\n",
      "Epoch 080 | Train Loss: 0.0365 | Val Loss: 0.6348\n",
      "Epoch 100 | Train Loss: 0.0327 | Val Loss: 0.6219\n",
      "Epoch 120 | Train Loss: 0.0285 | Val Loss: 0.6203\n",
      "Epoch 140 | Train Loss: 0.0259 | Val Loss: 0.6210\n",
      "Epoch 160 | Train Loss: 0.0237 | Val Loss: 0.6195\n",
      "Epoch 180 | Train Loss: 0.0219 | Val Loss: 0.6192\n",
      "Epoch 200 | Train Loss: 0.0205 | Val Loss: 0.6198\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/70_30/AmazonPhotos_GraphSAGE_70_30_seed42.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_70_30_masked_indices_seed46.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 5355 | Test nodes: 2295\n",
      "Epoch 001 | Train Loss: 5.1184 | Val Loss: 5.1303\n",
      "Epoch 020 | Train Loss: 0.4233 | Val Loss: 0.8581\n",
      "Epoch 040 | Train Loss: 0.0751 | Val Loss: 0.6597\n",
      "Epoch 060 | Train Loss: 0.0373 | Val Loss: 0.6494\n",
      "Epoch 080 | Train Loss: 0.0380 | Val Loss: 0.6372\n",
      "Epoch 100 | Train Loss: 0.0340 | Val Loss: 0.6256\n",
      "Epoch 120 | Train Loss: 0.0295 | Val Loss: 0.6223\n",
      "Epoch 140 | Train Loss: 0.0267 | Val Loss: 0.6215\n",
      "Epoch 160 | Train Loss: 0.0244 | Val Loss: 0.6217\n",
      "Epoch 180 | Train Loss: 0.0226 | Val Loss: 0.6223\n",
      "Epoch 200 | Train Loss: 0.0211 | Val Loss: 0.6246\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/70_30/AmazonPhotos_GraphSAGE_70_30_seed46.pt\n",
      "\n",
      "=== Processing Mask File: AmazonPhotos_70_30_masked_indices_seed999.npy (70_30, GraphSAGE) ===\n",
      "Train nodes: 5355 | Test nodes: 2295\n",
      "Epoch 001 | Train Loss: 5.1364 | Val Loss: 5.1347\n",
      "Epoch 020 | Train Loss: 0.4066 | Val Loss: 0.8203\n",
      "Epoch 040 | Train Loss: 0.0701 | Val Loss: 0.6566\n",
      "Epoch 060 | Train Loss: 0.0360 | Val Loss: 0.6469\n",
      "Epoch 080 | Train Loss: 0.0368 | Val Loss: 0.6297\n",
      "Epoch 100 | Train Loss: 0.0331 | Val Loss: 0.6179\n",
      "Epoch 120 | Train Loss: 0.0287 | Val Loss: 0.6138\n",
      "Epoch 140 | Train Loss: 0.0260 | Val Loss: 0.6137\n",
      "Epoch 160 | Train Loss: 0.0239 | Val Loss: 0.6158\n",
      "Epoch 180 | Train Loss: 0.0220 | Val Loss: 0.6173\n",
      "Epoch 200 | Train Loss: 0.0206 | Val Loss: 0.6193\n",
      "Saved embeddings to /Users/sujan/Downloads/GraFN/embeddings/AmazonPhotos/70_30/AmazonPhotos_GraphSAGE_70_30_seed999.pt\n",
      "Saved averaged results and execution times for AmazonPhotos split 70_30\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import glob\n",
    "import torch\n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "import time\n",
    "import pandas as pd\n",
    "from sklearn.metrics import accuracy_score, f1_score\n",
    "from torch_geometric.datasets import Planetoid, WikiCS, Amazon\n",
    "from torch_geometric.transforms import NormalizeFeatures\n",
    "from layers import Classifier\n",
    "from models.GraFN import GraFN\n",
    "from torch_geometric.nn import GCNConv, GATConv, SAGEConv\n",
    "import torch.nn as nn\n",
    "\n",
    "# -------------------------------\n",
    "# Encoder definitions\n",
    "# -------------------------------\n",
    "class GCNEncoder(nn.Module):\n",
    "    def __init__(self, in_dim, hidden_dim, out_dim):\n",
    "        super().__init__()\n",
    "        self.conv1 = GCNConv(in_dim, hidden_dim)\n",
    "        self.conv2 = GCNConv(hidden_dim, out_dim)\n",
    "    def forward(self, data):\n",
    "        x, edge_index = data.x, data.edge_index\n",
    "        x = F.relu(self.conv1(x, edge_index))\n",
    "        x = self.conv2(x, edge_index)\n",
    "        return x\n",
    "\n",
    "class GATEncoder(nn.Module):\n",
    "    def __init__(self, in_dim, hidden_dim, out_dim, heads=8):\n",
    "        super().__init__()\n",
    "        self.conv1 = GATConv(in_dim, hidden_dim, heads=heads, concat=True)\n",
    "        self.conv2 = GATConv(hidden_dim * heads, out_dim, heads=1, concat=False)\n",
    "    def forward(self, data):\n",
    "        x, edge_index = data.x, data.edge_index\n",
    "        x = F.elu(self.conv1(x, edge_index))\n",
    "        x = self.conv2(x, edge_index)\n",
    "        return x\n",
    "\n",
    "class GraphSAGEEncoder(nn.Module):\n",
    "    def __init__(self, in_dim, hidden_dim, out_dim):\n",
    "        super().__init__()\n",
    "        self.conv1 = SAGEConv(in_dim, hidden_dim)\n",
    "        self.conv2 = SAGEConv(hidden_dim, out_dim)\n",
    "    def forward(self, data):\n",
    "        x, edge_index = data.x, data.edge_index\n",
    "        x = F.relu(self.conv1(x, edge_index))\n",
    "        x = self.conv2(x, edge_index)\n",
    "        return x\n",
    "\n",
    "# -------------------------------\n",
    "# Datasets\n",
    "# -------------------------------\n",
    "datasets_info = {\n",
    "    \"AmazonPhotos\": lambda: Amazon(root='data/Amazon', name='Photo', transform=NormalizeFeatures())\n",
    "}\n",
    "\n",
    "mask_dirs_template = \"/Users/sujan/Modularity based semi supervised learning/masks/{dataset}/{split}\"\n",
    "splits = [\"30_70\", \"70_30\"]\n",
    "\n",
    "base_results_dir = \"/Users/sujan/Downloads/GraFN/results\"\n",
    "base_embeddings_dir = \"/Users/sujan/Downloads/GraFN/embeddings\"\n",
    "\n",
    "# -------------------------------\n",
    "# Pipeline per mask and encoder\n",
    "# -------------------------------\n",
    "def run_pipeline(data, mask_file, dataset_name, split_type, encoder_class, encoder_name, embedding_dim=150, epochs=200):\n",
    "    num_nodes = data.num_nodes\n",
    "    test_indices = np.load(mask_file)\n",
    "    test_mask = torch.zeros(num_nodes, dtype=torch.bool)\n",
    "    test_mask[test_indices] = True\n",
    "    train_mask = ~test_mask\n",
    "    data.train_mask = train_mask\n",
    "    data.test_mask = test_mask\n",
    "\n",
    "    print(f\"\\n=== Processing Mask File: {os.path.basename(mask_file)} ({split_type}, {encoder_name}) ===\")\n",
    "    print(f\"Train nodes: {train_mask.sum().item()} | Test nodes: {test_mask.sum().item()}\")\n",
    "\n",
    "    # Model\n",
    "    in_features = embedding_dim\n",
    "    hidden_dim = 128\n",
    "    out_dim = embedding_dim\n",
    "    encoder = encoder_class(in_features, hidden_dim, out_dim)\n",
    "    classifier = Classifier(out_dim, data.y.max().item() + 1)\n",
    "    model = GraFN(encoder, classifier, unique_labels=list(range(data.y.max().item() + 1)))\n",
    "    optimizer = torch.optim.Adam(model.parameters(), lr=0.01, weight_decay=5e-4)\n",
    "\n",
    "    # Training\n",
    "    model.train()\n",
    "    start_time = time.time()\n",
    "    for epoch in range(epochs):\n",
    "        optimizer.zero_grad()\n",
    "        out = model(data)\n",
    "        loss = F.cross_entropy(out[data.train_mask], data.y[data.train_mask])\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "        if (epoch+1) % 20 == 0 or epoch == 0:\n",
    "            val_loss = F.cross_entropy(out[data.test_mask], data.y[data.test_mask])\n",
    "            print(f\"Epoch {epoch+1:03d} | Train Loss: {loss.item():.4f} | Val Loss: {val_loss.item():.4f}\")\n",
    "    elapsed_time = time.time() - start_time\n",
    "\n",
    "    # Save embeddings\n",
    "    model.eval()\n",
    "    with torch.no_grad():\n",
    "        embeddings = model(data)\n",
    "    mask_basename = os.path.basename(mask_file)\n",
    "    seed_str = \"seed42\"\n",
    "    if \"seed\" in mask_basename:\n",
    "        parts = mask_basename.split(\"seed\")\n",
    "        if len(parts) > 1:\n",
    "            seed_str = \"seed\" + parts[1].replace(\".npy\", \"\")\n",
    "    embeddings_subdir = os.path.join(base_embeddings_dir, dataset_name, split_type)\n",
    "    os.makedirs(embeddings_subdir, exist_ok=True)\n",
    "    embedding_filename = f\"{dataset_name}_{encoder_name}_{split_type}_{seed_str}.pt\"\n",
    "    torch.save(embeddings, os.path.join(embeddings_subdir, embedding_filename))\n",
    "    print(f\"Saved embeddings to {os.path.join(embeddings_subdir, embedding_filename)}\")\n",
    "\n",
    "    # Evaluation\n",
    "    with torch.no_grad():\n",
    "        out = model(data)\n",
    "        preds = out.argmax(dim=1).cpu().numpy()\n",
    "        true_labels = data.y.cpu().numpy()\n",
    "        test_mask_np = data.test_mask.cpu().numpy()\n",
    "        test_preds = preds[test_mask_np]\n",
    "        test_labels = true_labels[test_mask_np]\n",
    "\n",
    "        acc = accuracy_score(test_labels, test_preds)\n",
    "        f1_macro = f1_score(test_labels, test_preds, average=\"macro\")\n",
    "        f1_micro = f1_score(test_labels, test_preds, average=\"micro\")\n",
    "\n",
    "    return {\n",
    "        \"encoder\": encoder_name,\n",
    "        \"accuracy\": acc,\n",
    "        \"f1_macro\": f1_macro,\n",
    "        \"f1_micro\": f1_micro,\n",
    "        \"time\": elapsed_time\n",
    "    }\n",
    "\n",
    "# -------------------------------\n",
    "# Run experiments\n",
    "# -------------------------------\n",
    "encoder_classes = {\n",
    "    \"GCN\": GCNEncoder,\n",
    "    \"GAT\": GATEncoder,\n",
    "    \"GraphSAGE\": GraphSAGEEncoder\n",
    "}\n",
    "\n",
    "embedding_dim = 150\n",
    "epochs = 200\n",
    "\n",
    "for dataset_name, loader in datasets_info.items():\n",
    "    print(f\"\\n========== Dataset: {dataset_name} ==========\")\n",
    "    dataset = loader()\n",
    "    data = dataset[0]\n",
    "    data.x = torch.randn(data.num_nodes, embedding_dim)\n",
    "\n",
    "    for split_type in splits:\n",
    "        mask_dir = mask_dirs_template.format(dataset=dataset_name, split=split_type)\n",
    "        results_subdir = os.path.join(base_results_dir, dataset_name, split_type)\n",
    "        os.makedirs(results_subdir, exist_ok=True)\n",
    "\n",
    "        mask_files = sorted(glob.glob(os.path.join(mask_dir, \"*.npy\")))\n",
    "        if len(mask_files) == 0:\n",
    "            print(f\"No mask files found for {dataset_name} split {split_type}. Skipping.\")\n",
    "            continue\n",
    "\n",
    "        all_encoder_results = []\n",
    "\n",
    "        for encoder_name, encoder_class in encoder_classes.items():\n",
    "            encoder_results = []\n",
    "            for mask_file in mask_files:\n",
    "                result = run_pipeline(data, mask_file, dataset_name, split_type, encoder_class, encoder_name, embedding_dim, epochs)\n",
    "                encoder_results.append(result)\n",
    "\n",
    "            # Compute mean ± std\n",
    "            acc_vals = [r[\"accuracy\"] for r in encoder_results]\n",
    "            f1_macro_vals = [r[\"f1_macro\"] for r in encoder_results]\n",
    "            f1_micro_vals = [r[\"f1_micro\"] for r in encoder_results]\n",
    "            time_vals = [r[\"time\"] for r in encoder_results]\n",
    "\n",
    "            avg_metrics = {\n",
    "                \"encoder\": encoder_name,\n",
    "                \"accuracy\": f\"{np.mean(acc_vals):.4f} ± {np.std(acc_vals):.4f}\",\n",
    "                \"f1_macro\": f\"{np.mean(f1_macro_vals):.4f} ± {np.std(f1_macro_vals):.4f}\",\n",
    "                \"f1_micro\": f\"{np.mean(f1_micro_vals):.4f} ± {np.std(f1_micro_vals):.4f}\",\n",
    "                \"time\": f\"{np.mean(time_vals):.2f} ± {np.std(time_vals):.2f}\"\n",
    "            }\n",
    "            all_encoder_results.append(avg_metrics)\n",
    "\n",
    "        # Save averaged results\n",
    "        results_df = pd.DataFrame(all_encoder_results)\n",
    "        metrics_df = results_df[['encoder', 'accuracy', 'f1_macro', 'f1_micro']]\n",
    "        times_df = results_df[['encoder', 'time']]\n",
    "        metrics_df.to_csv(os.path.join(results_subdir, f\"{dataset_name}_results.csv\"), index=False)\n",
    "        times_df.to_csv(os.path.join(results_subdir, f\"{dataset_name}_execution_times.csv\"), index=False)\n",
    "\n",
    "        print(f\"Saved averaged results and execution times for {dataset_name} split {split_type}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4ca8c319-2391-4217-9764-d9cf89850706",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python (grafn-env)",
   "language": "python",
   "name": "grafn-env"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
