{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7772b3ce-b6a4-498b-902f-33a76f11c5d4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded AMAZON-PHOTOS\n",
      "Data(x=[7650, 150], edge_index=[2, 238162], y=[7650])\n",
      "Number of nodes: 7650, Number of features: 150, Number of classes: 8\n",
      "------------------------------------------------------------\n",
      "Loaded WIKICS\n",
      "Data(x=[11701, 150], edge_index=[2, 431726], y=[11701], train_mask=[11701, 20], val_mask=[11701, 20], test_mask=[11701], stopping_mask=[11701, 20])\n",
      "Number of nodes: 11701, Number of features: 150, Number of classes: 10\n",
      "------------------------------------------------------------\n",
      "Loaded PUBMED\n",
      "Data(x=[19717, 150], edge_index=[2, 88648], y=[19717], train_mask=[19717], val_mask=[19717], test_mask=[19717])\n",
      "Number of nodes: 19717, Number of features: 150, Number of classes: 3\n",
      "------------------------------------------------------------\n",
      "Loaded CITESEER\n",
      "Data(x=[3327, 150], edge_index=[2, 9104], y=[3327], train_mask=[3327], val_mask=[3327], test_mask=[3327])\n",
      "Number of nodes: 3327, Number of features: 150, Number of classes: 6\n",
      "------------------------------------------------------------\n",
      "Loaded CORA\n",
      "Data(x=[2708, 150], edge_index=[2, 10556], y=[2708], train_mask=[2708], val_mask=[2708], test_mask=[2708])\n",
      "Number of nodes: 2708, Number of features: 150, Number of classes: 7\n",
      "------------------------------------------------------------\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n",
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/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"
     ]
    }
   ],
   "source": [
    "%run load_datasets_revar.ipynb"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "9aecca90-60a7-4cc7-aae8-ef272ed8acb3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded CORA\n",
      "Data(x=[2708, 150], edge_index=[2, 10556], y=[2708], train_mask=[2708], val_mask=[2708], test_mask=[2708])\n",
      "Number of nodes: 2708, Number of features: 150, Number of classes: 7\n",
      "\n",
      ">>> Processing file: Cora_70_30_masked_indices_seed123.npy with encoder: GCN\n",
      "Train size: 1896 | Test size: 812\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9342\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9582\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9734\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9843\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9917\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9956\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9974\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9984\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9989\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9992\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.8100 | Acc: 0.3140 | F1: 0.1043\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7817 | Acc: 0.3153 | F1: 0.0889\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7672 | Acc: 0.3177 | F1: 0.0969\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.7565 | Acc: 0.3153 | F1: 0.1152\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.7471 | Acc: 0.3202 | F1: 0.1257\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.7383 | Acc: 0.3227 | F1: 0.1321\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.7301 | Acc: 0.3264 | F1: 0.1398\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.7223 | Acc: 0.3337 | F1: 0.1498\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.7150 | Acc: 0.3337 | F1: 0.1533\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.7080 | Acc: 0.3399 | F1: 0.1609\n",
      "\n",
      ">>> Processing file: Cora_70_30_masked_indices_seed123.npy with encoder: GAT\n",
      "Train size: 1896 | Test size: 812\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9701\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9897\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9959\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9979\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9988\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9990\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9983\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9993\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7011 | Acc: 0.3534 | F1: 0.2223\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6557 | Acc: 0.3818 | F1: 0.2666\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.6271 | Acc: 0.3867 | F1: 0.2776\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6035 | Acc: 0.3904 | F1: 0.2952\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.5825 | Acc: 0.3892 | F1: 0.2994\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.5633 | Acc: 0.4002 | F1: 0.3137\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.5458 | Acc: 0.4089 | F1: 0.3288\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.5296 | Acc: 0.4113 | F1: 0.3346\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.5147 | Acc: 0.4187 | F1: 0.3418\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.5008 | Acc: 0.4187 | F1: 0.3409\n",
      "\n",
      ">>> Processing file: Cora_70_30_masked_indices_seed123.npy with encoder: SAGE\n",
      "Train size: 1896 | Test size: 812\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9953\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9990\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9996\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9997\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -0.9999\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7954 | Acc: 0.3079 | F1: 0.1003\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7484 | Acc: 0.2869 | F1: 0.1064\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7189 | Acc: 0.2635 | F1: 0.1063\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6972 | Acc: 0.2586 | F1: 0.1152\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6801 | Acc: 0.2562 | F1: 0.1214\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6662 | Acc: 0.2463 | F1: 0.1179\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6546 | Acc: 0.2365 | F1: 0.1123\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6448 | Acc: 0.2278 | F1: 0.1102\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6364 | Acc: 0.2303 | F1: 0.1179\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6291 | Acc: 0.2266 | F1: 0.1177\n",
      "\n",
      ">>> Processing file: Cora_70_30_masked_indices_seed2025.npy with encoder: GCN\n",
      "Train size: 1896 | Test size: 812\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9396\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9621\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9763\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9861\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9924\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9959\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9976\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9985\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9990\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9993\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7896 | Acc: 0.2845 | F1: 0.0917\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7655 | Acc: 0.2734 | F1: 0.0752\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7531 | Acc: 0.2783 | F1: 0.0840\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.7425 | Acc: 0.2796 | F1: 0.0880\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.7328 | Acc: 0.2783 | F1: 0.0877\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.7240 | Acc: 0.2783 | F1: 0.0936\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.7158 | Acc: 0.2759 | F1: 0.0965\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.7082 | Acc: 0.2771 | F1: 0.0985\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.7011 | Acc: 0.2808 | F1: 0.1043\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6944 | Acc: 0.2857 | F1: 0.1124\n",
      "\n",
      ">>> Processing file: Cora_70_30_masked_indices_seed2025.npy with encoder: GAT\n",
      "Train size: 1896 | Test size: 812\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9729\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9902\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9958\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9979\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9987\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9991\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.6665 | Acc: 0.3534 | F1: 0.2247\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6121 | Acc: 0.3732 | F1: 0.2609\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.5841 | Acc: 0.3842 | F1: 0.2715\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.5610 | Acc: 0.4027 | F1: 0.2936\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.5405 | Acc: 0.4138 | F1: 0.3137\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.5216 | Acc: 0.4187 | F1: 0.3179\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.5043 | Acc: 0.4273 | F1: 0.3266\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.4883 | Acc: 0.4372 | F1: 0.3479\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.4734 | Acc: 0.4384 | F1: 0.3550\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.4596 | Acc: 0.4433 | F1: 0.3660\n",
      "\n",
      ">>> Processing file: Cora_70_30_masked_indices_seed2025.npy with encoder: SAGE\n",
      "Train size: 1896 | Test size: 812\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9955\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9991\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9996\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -0.9999\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7595 | Acc: 0.2623 | F1: 0.0873\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7126 | Acc: 0.2537 | F1: 0.1079\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.6833 | Acc: 0.2500 | F1: 0.1132\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6619 | Acc: 0.2451 | F1: 0.1202\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6450 | Acc: 0.2414 | F1: 0.1144\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6313 | Acc: 0.2328 | F1: 0.1121\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6201 | Acc: 0.2192 | F1: 0.1080\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6107 | Acc: 0.2180 | F1: 0.1131\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6029 | Acc: 0.2217 | F1: 0.1195\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.5963 | Acc: 0.2217 | F1: 0.1247\n",
      "\n",
      ">>> Processing file: Cora_70_30_masked_indices_seed42.npy with encoder: GCN\n",
      "Train size: 1896 | Test size: 812\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9403\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9629\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9769\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9866\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9929\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9962\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9978\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9986\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9990\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9993\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7757 | Acc: 0.3067 | F1: 0.1249\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7448 | Acc: 0.3165 | F1: 0.1280\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7308 | Acc: 0.3165 | F1: 0.1341\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.7195 | Acc: 0.3177 | F1: 0.1401\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.7094 | Acc: 0.3103 | F1: 0.1416\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.7001 | Acc: 0.3054 | F1: 0.1423\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6914 | Acc: 0.3128 | F1: 0.1493\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6834 | Acc: 0.3153 | F1: 0.1571\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6758 | Acc: 0.3153 | F1: 0.1585\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6686 | Acc: 0.3140 | F1: 0.1595\n",
      "\n",
      ">>> Processing file: Cora_70_30_masked_indices_seed42.npy with encoder: GAT\n",
      "Train size: 1896 | Test size: 812\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9739\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9906\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9960\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9980\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9988\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9992\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.6765 | Acc: 0.3953 | F1: 0.2794\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6123 | Acc: 0.4384 | F1: 0.3448\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.5740 | Acc: 0.4520 | F1: 0.3627\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.5444 | Acc: 0.4594 | F1: 0.3734\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.5191 | Acc: 0.4754 | F1: 0.3880\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.4964 | Acc: 0.4803 | F1: 0.3922\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.4756 | Acc: 0.4803 | F1: 0.3942\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.4562 | Acc: 0.4901 | F1: 0.4094\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.4381 | Acc: 0.5000 | F1: 0.4194\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.4210 | Acc: 0.5012 | F1: 0.4222\n",
      "\n",
      ">>> Processing file: Cora_70_30_masked_indices_seed42.npy with encoder: SAGE\n",
      "Train size: 1896 | Test size: 812\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9961\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9992\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9996\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -0.9999\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7774 | Acc: 0.2796 | F1: 0.1110\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7273 | Acc: 0.2586 | F1: 0.1090\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.6968 | Acc: 0.2500 | F1: 0.1193\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6752 | Acc: 0.2475 | F1: 0.1180\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6588 | Acc: 0.2438 | F1: 0.1237\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6458 | Acc: 0.2451 | F1: 0.1280\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6352 | Acc: 0.2500 | F1: 0.1380\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6265 | Acc: 0.2488 | F1: 0.1425\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6193 | Acc: 0.2451 | F1: 0.1449\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6132 | Acc: 0.2426 | F1: 0.1450\n",
      "\n",
      ">>> Processing file: Cora_70_30_masked_indices_seed46.npy with encoder: GCN\n",
      "Train size: 1896 | Test size: 812\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9406\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9622\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9758\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9855\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9922\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9958\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9975\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9984\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9989\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9992\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7660 | Acc: 0.3005 | F1: 0.0824\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7396 | Acc: 0.2980 | F1: 0.0902\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7222 | Acc: 0.2980 | F1: 0.1176\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.7085 | Acc: 0.2906 | F1: 0.1182\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6964 | Acc: 0.2968 | F1: 0.1269\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6853 | Acc: 0.3017 | F1: 0.1369\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6751 | Acc: 0.3079 | F1: 0.1502\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6656 | Acc: 0.3128 | F1: 0.1544\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6567 | Acc: 0.3165 | F1: 0.1624\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6484 | Acc: 0.3202 | F1: 0.1716\n",
      "\n",
      ">>> Processing file: Cora_70_30_masked_indices_seed46.npy with encoder: GAT\n",
      "Train size: 1896 | Test size: 812\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9720\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9901\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9958\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9979\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9987\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9992\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9965\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.6754 | Acc: 0.3251 | F1: 0.1661\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6236 | Acc: 0.3559 | F1: 0.2258\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.5840 | Acc: 0.3448 | F1: 0.2231\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.5540 | Acc: 0.3584 | F1: 0.2422\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.5295 | Acc: 0.3793 | F1: 0.2707\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.5085 | Acc: 0.3855 | F1: 0.2863\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.4897 | Acc: 0.3929 | F1: 0.2972\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.4726 | Acc: 0.4002 | F1: 0.3115\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.4567 | Acc: 0.4039 | F1: 0.3173\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.4420 | Acc: 0.4064 | F1: 0.3227\n",
      "\n",
      ">>> Processing file: Cora_70_30_masked_indices_seed46.npy with encoder: SAGE\n",
      "Train size: 1896 | Test size: 812\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9959\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9991\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9996\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -0.9999\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7736 | Acc: 0.2931 | F1: 0.1019\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7296 | Acc: 0.2906 | F1: 0.1284\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7025 | Acc: 0.2709 | F1: 0.1223\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6834 | Acc: 0.2599 | F1: 0.1240\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6690 | Acc: 0.2562 | F1: 0.1294\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6576 | Acc: 0.2438 | F1: 0.1285\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6484 | Acc: 0.2426 | F1: 0.1327\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6408 | Acc: 0.2414 | F1: 0.1329\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6344 | Acc: 0.2291 | F1: 0.1304\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6292 | Acc: 0.2278 | F1: 0.1330\n",
      "\n",
      ">>> Processing file: Cora_70_30_masked_indices_seed999.npy with encoder: GCN\n",
      "Train size: 1896 | Test size: 812\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9370\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9599\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9754\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9865\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9932\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9964\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9979\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9987\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9991\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9994\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7835 | Acc: 0.3017 | F1: 0.0663\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7582 | Acc: 0.3054 | F1: 0.0756\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7413 | Acc: 0.3054 | F1: 0.1002\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.7282 | Acc: 0.3091 | F1: 0.1219\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.7170 | Acc: 0.3153 | F1: 0.1461\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.7071 | Acc: 0.3177 | F1: 0.1622\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6981 | Acc: 0.3214 | F1: 0.1731\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6899 | Acc: 0.3251 | F1: 0.1841\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6822 | Acc: 0.3276 | F1: 0.1870\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6751 | Acc: 0.3325 | F1: 0.1985\n",
      "\n",
      ">>> Processing file: Cora_70_30_masked_indices_seed999.npy with encoder: GAT\n",
      "Train size: 1896 | Test size: 812\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9729\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9904\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9960\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9980\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9988\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9992\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.6314 | Acc: 0.3904 | F1: 0.2752\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.5718 | Acc: 0.4175 | F1: 0.3162\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.5398 | Acc: 0.4397 | F1: 0.3487\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.5158 | Acc: 0.4458 | F1: 0.3627\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.4957 | Acc: 0.4495 | F1: 0.3713\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.4781 | Acc: 0.4557 | F1: 0.3794\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.4622 | Acc: 0.4581 | F1: 0.3865\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.4477 | Acc: 0.4631 | F1: 0.3965\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.4343 | Acc: 0.4667 | F1: 0.4027\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.4218 | Acc: 0.4655 | F1: 0.4029\n",
      "\n",
      ">>> Processing file: Cora_70_30_masked_indices_seed999.npy with encoder: SAGE\n",
      "Train size: 1896 | Test size: 812\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9955\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9990\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9996\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -0.9999\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7889 | Acc: 0.2833 | F1: 0.1222\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7407 | Acc: 0.2869 | F1: 0.0989\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7105 | Acc: 0.2808 | F1: 0.1068\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6883 | Acc: 0.2796 | F1: 0.1150\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6702 | Acc: 0.2796 | F1: 0.1220\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6549 | Acc: 0.2734 | F1: 0.1276\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6420 | Acc: 0.2759 | F1: 0.1352\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6309 | Acc: 0.2722 | F1: 0.1370\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6214 | Acc: 0.2783 | F1: 0.1455\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6131 | Acc: 0.2722 | F1: 0.1444\n",
      "\n",
      "===== Cora (70_30) Summary =====\n",
      "GAT -> Acc: 44.7044 ± 3.7898, BAcc: 36.6573 ± 4.2379, F1: 37.0954 ± 4.1545\n",
      "GCN -> Acc: 31.8473 ± 2.0929, BAcc: 18.9875 ± 1.9608, F1: 16.0577 ± 3.1168\n",
      "SAGE -> Acc: 23.8177 ± 2.0545, BAcc: 14.6600 ± 1.3141, F1: 13.2960 ± 1.2018\n",
      "\n",
      ">>> Processing file: Cora_30_70_masked_indices_seed123.npy with encoder: GCN\n",
      "Train size: 813 | Test size: 1895\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9412\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9642\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9784\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9884\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9942\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9969\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9982\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9988\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9992\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9994\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7735 | Acc: 0.3251 | F1: 0.1561\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7389 | Acc: 0.3277 | F1: 0.1580\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7138 | Acc: 0.3388 | F1: 0.1834\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6930 | Acc: 0.3451 | F1: 0.2079\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6747 | Acc: 0.3478 | F1: 0.2199\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6582 | Acc: 0.3541 | F1: 0.2326\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6431 | Acc: 0.3583 | F1: 0.2409\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6290 | Acc: 0.3620 | F1: 0.2514\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6157 | Acc: 0.3668 | F1: 0.2591\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6032 | Acc: 0.3689 | F1: 0.2631\n",
      "\n",
      ">>> Processing file: Cora_30_70_masked_indices_seed123.npy with encoder: GAT\n",
      "Train size: 813 | Test size: 1895\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9721\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9902\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9959\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9979\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9987\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9991\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.6230 | Acc: 0.3435 | F1: 0.2844\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.5552 | Acc: 0.3784 | F1: 0.3184\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.5113 | Acc: 0.3989 | F1: 0.3467\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.4760 | Acc: 0.4106 | F1: 0.3609\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.4457 | Acc: 0.4195 | F1: 0.3718\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.4188 | Acc: 0.4201 | F1: 0.3759\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.3944 | Acc: 0.4216 | F1: 0.3788\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.3722 | Acc: 0.4253 | F1: 0.3837\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.3516 | Acc: 0.4216 | F1: 0.3821\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.3324 | Acc: 0.4301 | F1: 0.3934\n",
      "\n",
      ">>> Processing file: Cora_30_70_masked_indices_seed123.npy with encoder: SAGE\n",
      "Train size: 813 | Test size: 1895\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9958\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9991\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9996\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -0.9999\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7253 | Acc: 0.2612 | F1: 0.1206\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6390 | Acc: 0.2628 | F1: 0.1340\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.5784 | Acc: 0.2443 | F1: 0.1330\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.5309 | Acc: 0.2380 | F1: 0.1398\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.4920 | Acc: 0.2296 | F1: 0.1407\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.4593 | Acc: 0.2222 | F1: 0.1433\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.4314 | Acc: 0.2169 | F1: 0.1475\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.4073 | Acc: 0.2153 | F1: 0.1502\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.3864 | Acc: 0.2111 | F1: 0.1471\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.3680 | Acc: 0.2116 | F1: 0.1495\n",
      "\n",
      ">>> Processing file: Cora_30_70_masked_indices_seed2025.npy with encoder: GCN\n",
      "Train size: 813 | Test size: 1895\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9371\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9594\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9739\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9845\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9916\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9956\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9975\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9984\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9989\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9992\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7885 | Acc: 0.3077 | F1: 0.1047\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7678 | Acc: 0.3061 | F1: 0.1122\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7521 | Acc: 0.3055 | F1: 0.1213\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.7390 | Acc: 0.3055 | F1: 0.1260\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.7264 | Acc: 0.3108 | F1: 0.1376\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.7141 | Acc: 0.3150 | F1: 0.1469\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.7022 | Acc: 0.3203 | F1: 0.1589\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6906 | Acc: 0.3245 | F1: 0.1657\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6794 | Acc: 0.3235 | F1: 0.1695\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6686 | Acc: 0.3224 | F1: 0.1720\n",
      "\n",
      ">>> Processing file: Cora_30_70_masked_indices_seed2025.npy with encoder: GAT\n",
      "Train size: 813 | Test size: 1895\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9729\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9907\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9961\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9980\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9988\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9992\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9996\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.6695 | Acc: 0.3451 | F1: 0.2037\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6234 | Acc: 0.3620 | F1: 0.2535\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.5888 | Acc: 0.3704 | F1: 0.2771\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.5606 | Acc: 0.3763 | F1: 0.2845\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.5355 | Acc: 0.3894 | F1: 0.2964\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.5124 | Acc: 0.3953 | F1: 0.3099\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.4908 | Acc: 0.3958 | F1: 0.3135\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.4703 | Acc: 0.3968 | F1: 0.3184\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.4508 | Acc: 0.4016 | F1: 0.3276\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.4322 | Acc: 0.4026 | F1: 0.3312\n",
      "\n",
      ">>> Processing file: Cora_30_70_masked_indices_seed2025.npy with encoder: SAGE\n",
      "Train size: 813 | Test size: 1895\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9960\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9991\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9996\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -0.9999\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7093 | Acc: 0.2591 | F1: 0.1217\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6259 | Acc: 0.2454 | F1: 0.1247\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.5701 | Acc: 0.2311 | F1: 0.1219\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.5267 | Acc: 0.2164 | F1: 0.1211\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.4909 | Acc: 0.2127 | F1: 0.1265\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.4604 | Acc: 0.2106 | F1: 0.1292\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.4341 | Acc: 0.2069 | F1: 0.1289\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.4110 | Acc: 0.2042 | F1: 0.1304\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.3906 | Acc: 0.2026 | F1: 0.1319\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.3724 | Acc: 0.1984 | F1: 0.1328\n",
      "\n",
      ">>> Processing file: Cora_30_70_masked_indices_seed42.npy with encoder: GCN\n",
      "Train size: 813 | Test size: 1895\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9325\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9560\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9710\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9816\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9891\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9938\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9965\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9979\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9987\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9992\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7737 | Acc: 0.2945 | F1: 0.0684\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7522 | Acc: 0.2892 | F1: 0.0896\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7394 | Acc: 0.2876 | F1: 0.0887\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.7293 | Acc: 0.2908 | F1: 0.1002\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.7199 | Acc: 0.2923 | F1: 0.1048\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.7112 | Acc: 0.2897 | F1: 0.1063\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.7030 | Acc: 0.2923 | F1: 0.1102\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6954 | Acc: 0.2945 | F1: 0.1134\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6883 | Acc: 0.2945 | F1: 0.1149\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6816 | Acc: 0.2945 | F1: 0.1196\n",
      "\n",
      ">>> Processing file: Cora_30_70_masked_indices_seed42.npy with encoder: GAT\n",
      "Train size: 813 | Test size: 1895\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9710\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9909\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9965\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9983\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9972\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9989\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9997\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9998\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7074 | Acc: 0.3145 | F1: 0.1493\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6651 | Acc: 0.3235 | F1: 0.2063\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.6348 | Acc: 0.3367 | F1: 0.2290\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6088 | Acc: 0.3499 | F1: 0.2406\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.5856 | Acc: 0.3588 | F1: 0.2560\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.5646 | Acc: 0.3604 | F1: 0.2618\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.5453 | Acc: 0.3646 | F1: 0.2679\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.5274 | Acc: 0.3652 | F1: 0.2696\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.5107 | Acc: 0.3662 | F1: 0.2740\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.4950 | Acc: 0.3689 | F1: 0.2797\n",
      "\n",
      ">>> Processing file: Cora_30_70_masked_indices_seed42.npy with encoder: SAGE\n",
      "Train size: 813 | Test size: 1895\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9965\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9992\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9997\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.6833 | Acc: 0.2697 | F1: 0.1100\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.5879 | Acc: 0.2507 | F1: 0.1346\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.5242 | Acc: 0.2396 | F1: 0.1357\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.4765 | Acc: 0.2338 | F1: 0.1469\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.4382 | Acc: 0.2317 | F1: 0.1510\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.4064 | Acc: 0.2306 | F1: 0.1546\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.3794 | Acc: 0.2237 | F1: 0.1492\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.3561 | Acc: 0.2169 | F1: 0.1453\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.3359 | Acc: 0.2142 | F1: 0.1447\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.3181 | Acc: 0.2111 | F1: 0.1450\n",
      "\n",
      ">>> Processing file: Cora_30_70_masked_indices_seed46.npy with encoder: GCN\n",
      "Train size: 813 | Test size: 1895\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9352\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9586\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9738\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9849\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9923\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9960\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9976\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9985\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9989\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9992\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.8101 | Acc: 0.3103 | F1: 0.0699\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7868 | Acc: 0.3077 | F1: 0.0811\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7688 | Acc: 0.3077 | F1: 0.0893\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.7528 | Acc: 0.3077 | F1: 0.1044\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.7382 | Acc: 0.3119 | F1: 0.1210\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.7248 | Acc: 0.3182 | F1: 0.1356\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.7123 | Acc: 0.3203 | F1: 0.1452\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.7006 | Acc: 0.3224 | F1: 0.1593\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6896 | Acc: 0.3224 | F1: 0.1662\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6792 | Acc: 0.3214 | F1: 0.1722\n",
      "\n",
      ">>> Processing file: Cora_30_70_masked_indices_seed46.npy with encoder: GAT\n",
      "Train size: 813 | Test size: 1895\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9695\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9892\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9957\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9979\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9987\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9992\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7140 | Acc: 0.3604 | F1: 0.1927\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6595 | Acc: 0.3646 | F1: 0.1936\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.6199 | Acc: 0.3763 | F1: 0.2185\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.5882 | Acc: 0.3805 | F1: 0.2347\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.5612 | Acc: 0.3868 | F1: 0.2503\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.5374 | Acc: 0.3889 | F1: 0.2583\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.5160 | Acc: 0.3974 | F1: 0.2740\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.4966 | Acc: 0.3995 | F1: 0.2826\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.4787 | Acc: 0.4042 | F1: 0.2928\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.4621 | Acc: 0.4074 | F1: 0.2996\n",
      "\n",
      ">>> Processing file: Cora_30_70_masked_indices_seed46.npy with encoder: SAGE\n",
      "Train size: 813 | Test size: 1895\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9955\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9990\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9996\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -0.9999\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7069 | Acc: 0.2580 | F1: 0.1363\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6156 | Acc: 0.2380 | F1: 0.1424\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.5544 | Acc: 0.2206 | F1: 0.1323\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.5073 | Acc: 0.2237 | F1: 0.1436\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.4690 | Acc: 0.2121 | F1: 0.1411\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.4367 | Acc: 0.2084 | F1: 0.1439\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.4091 | Acc: 0.2053 | F1: 0.1448\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.3851 | Acc: 0.2069 | F1: 0.1490\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.3639 | Acc: 0.2111 | F1: 0.1544\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.3451 | Acc: 0.2079 | F1: 0.1530\n",
      "\n",
      ">>> Processing file: Cora_30_70_masked_indices_seed999.npy with encoder: GCN\n",
      "Train size: 813 | Test size: 1895\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9364\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9588\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9729\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9830\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9904\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9949\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9972\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9983\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9989\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9992\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7719 | Acc: 0.3040 | F1: 0.0911\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7381 | Acc: 0.3145 | F1: 0.1123\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7169 | Acc: 0.3187 | F1: 0.1344\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.7002 | Acc: 0.3256 | F1: 0.1513\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6861 | Acc: 0.3261 | F1: 0.1612\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6737 | Acc: 0.3261 | F1: 0.1657\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6625 | Acc: 0.3256 | F1: 0.1749\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6523 | Acc: 0.3272 | F1: 0.1786\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6428 | Acc: 0.3303 | F1: 0.1857\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6339 | Acc: 0.3303 | F1: 0.1895\n",
      "\n",
      ">>> Processing file: Cora_30_70_masked_indices_seed999.npy with encoder: GAT\n",
      "Train size: 813 | Test size: 1895\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9701\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9881\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9946\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9972\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9983\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9989\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9992\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9996\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.5170 | Acc: 0.4042 | F1: 0.3512\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.4423 | Acc: 0.4306 | F1: 0.3911\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.3938 | Acc: 0.4332 | F1: 0.3960\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.3542 | Acc: 0.4322 | F1: 0.3960\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.3198 | Acc: 0.4338 | F1: 0.4020\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.2893 | Acc: 0.4401 | F1: 0.4126\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.2618 | Acc: 0.4454 | F1: 0.4208\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.2369 | Acc: 0.4512 | F1: 0.4272\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.2140 | Acc: 0.4522 | F1: 0.4296\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.1929 | Acc: 0.4580 | F1: 0.4360\n",
      "\n",
      ">>> Processing file: Cora_30_70_masked_indices_seed999.npy with encoder: SAGE\n",
      "Train size: 813 | Test size: 1895\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9957\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9991\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9996\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -0.9999\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.6843 | Acc: 0.2570 | F1: 0.1216\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.5920 | Acc: 0.2401 | F1: 0.1339\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.5302 | Acc: 0.2253 | F1: 0.1340\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.4829 | Acc: 0.2116 | F1: 0.1330\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.4446 | Acc: 0.2111 | F1: 0.1350\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.4126 | Acc: 0.2121 | F1: 0.1418\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.3852 | Acc: 0.2079 | F1: 0.1447\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.3616 | Acc: 0.2063 | F1: 0.1450\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.3409 | Acc: 0.2005 | F1: 0.1434\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.3227 | Acc: 0.1984 | F1: 0.1439\n",
      "\n",
      "===== Cora (30_70) Summary =====\n",
      "GAT -> Acc: 41.3404 ± 3.3192, BAcc: 34.9030 ± 5.5651, F1: 34.7977 ± 6.5372\n",
      "GCN -> Acc: 32.7493 ± 2.6806, BAcc: 20.7660 ± 4.1440, F1: 18.3285 ± 5.1772\n",
      "SAGE -> Acc: 20.5488 ± 0.6608, BAcc: 14.7868 ± 0.6616, F1: 14.4863 ± 0.7665\n",
      "Loaded CITESEER\n",
      "Data(x=[3327, 150], edge_index=[2, 9104], y=[3327], train_mask=[3327], val_mask=[3327], test_mask=[3327])\n",
      "Number of nodes: 3327, Number of features: 150, Number of classes: 6\n",
      "\n",
      ">>> Processing file: CiteSeer_70_30_masked_indices_seed123.npy with encoder: GCN\n",
      "Train size: 2329 | Test size: 998\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9353\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9581\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9731\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9845\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9919\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9957\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9974\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9983\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9989\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9992\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7512 | Acc: 0.2415 | F1: 0.1353\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7334 | Acc: 0.2595 | F1: 0.1550\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7236 | Acc: 0.2525 | F1: 0.1640\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.7160 | Acc: 0.2575 | F1: 0.1682\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.7091 | Acc: 0.2615 | F1: 0.1751\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.7030 | Acc: 0.2655 | F1: 0.1792\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6973 | Acc: 0.2705 | F1: 0.1828\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6922 | Acc: 0.2766 | F1: 0.1912\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6874 | Acc: 0.2715 | F1: 0.1895\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6829 | Acc: 0.2756 | F1: 0.1938\n",
      "\n",
      ">>> Processing file: CiteSeer_70_30_masked_indices_seed123.npy with encoder: GAT\n",
      "Train size: 2329 | Test size: 998\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9644\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9854\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9938\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9971\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9984\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9990\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9993\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7288 | Acc: 0.2485 | F1: 0.1585\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7074 | Acc: 0.2615 | F1: 0.1936\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.6941 | Acc: 0.2756 | F1: 0.2124\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6840 | Acc: 0.2776 | F1: 0.2182\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6752 | Acc: 0.2836 | F1: 0.2238\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6672 | Acc: 0.2856 | F1: 0.2273\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6598 | Acc: 0.2876 | F1: 0.2304\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6528 | Acc: 0.2886 | F1: 0.2349\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6463 | Acc: 0.2926 | F1: 0.2379\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6402 | Acc: 0.2916 | F1: 0.2373\n",
      "\n",
      ">>> Processing file: CiteSeer_70_30_masked_indices_seed123.npy with encoder: SAGE\n",
      "Train size: 2329 | Test size: 998\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9957\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9991\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9996\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -0.9999\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7070 | Acc: 0.1944 | F1: 0.1406\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6771 | Acc: 0.1794 | F1: 0.1469\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.6591 | Acc: 0.1824 | F1: 0.1492\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6462 | Acc: 0.1864 | F1: 0.1520\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6366 | Acc: 0.1794 | F1: 0.1469\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6291 | Acc: 0.1733 | F1: 0.1423\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6234 | Acc: 0.1733 | F1: 0.1429\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6188 | Acc: 0.1723 | F1: 0.1429\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6152 | Acc: 0.1743 | F1: 0.1453\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6123 | Acc: 0.1764 | F1: 0.1469\n",
      "\n",
      ">>> Processing file: CiteSeer_70_30_masked_indices_seed2025.npy with encoder: GCN\n",
      "Train size: 2329 | Test size: 998\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9315\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9547\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9699\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9819\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9905\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9955\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9978\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9988\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9993\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9995\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7634 | Acc: 0.1924 | F1: 0.0834\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7483 | Acc: 0.2184 | F1: 0.0745\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7426 | Acc: 0.2405 | F1: 0.1626\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.7383 | Acc: 0.2184 | F1: 0.1318\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.7344 | Acc: 0.2425 | F1: 0.1602\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.7307 | Acc: 0.2535 | F1: 0.1697\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.7273 | Acc: 0.2615 | F1: 0.1757\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.7241 | Acc: 0.2645 | F1: 0.1839\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.7210 | Acc: 0.2625 | F1: 0.1830\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.7181 | Acc: 0.2675 | F1: 0.1879\n",
      "\n",
      ">>> Processing file: CiteSeer_70_30_masked_indices_seed2025.npy with encoder: GAT\n",
      "Train size: 2329 | Test size: 998\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9699\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9880\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9948\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9974\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9985\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9991\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7117 | Acc: 0.3006 | F1: 0.2029\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6933 | Acc: 0.3056 | F1: 0.2243\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.6795 | Acc: 0.3136 | F1: 0.2370\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6679 | Acc: 0.3146 | F1: 0.2396\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6574 | Acc: 0.3166 | F1: 0.2511\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6475 | Acc: 0.3126 | F1: 0.2477\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6383 | Acc: 0.3186 | F1: 0.2542\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6297 | Acc: 0.3146 | F1: 0.2545\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6215 | Acc: 0.3156 | F1: 0.2598\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6138 | Acc: 0.3106 | F1: 0.2571\n",
      "\n",
      ">>> Processing file: CiteSeer_70_30_masked_indices_seed2025.npy with encoder: SAGE\n",
      "Train size: 2329 | Test size: 998\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9948\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9989\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9996\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9997\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -0.9999\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7158 | Acc: 0.1884 | F1: 0.1447\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6844 | Acc: 0.1924 | F1: 0.1559\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.6652 | Acc: 0.1814 | F1: 0.1512\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6517 | Acc: 0.1804 | F1: 0.1487\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6414 | Acc: 0.1743 | F1: 0.1414\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6331 | Acc: 0.1784 | F1: 0.1453\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6263 | Acc: 0.1764 | F1: 0.1432\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6207 | Acc: 0.1824 | F1: 0.1488\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6161 | Acc: 0.1784 | F1: 0.1459\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6121 | Acc: 0.1864 | F1: 0.1559\n",
      "\n",
      ">>> Processing file: CiteSeer_70_30_masked_indices_seed42.npy with encoder: GCN\n",
      "Train size: 2329 | Test size: 998\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9338\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9575\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9729\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9843\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9918\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9957\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9975\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9984\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9989\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9992\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7455 | Acc: 0.2535 | F1: 0.1491\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7334 | Acc: 0.2565 | F1: 0.1751\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7268 | Acc: 0.2685 | F1: 0.1735\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.7215 | Acc: 0.2756 | F1: 0.1885\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.7165 | Acc: 0.2806 | F1: 0.1981\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.7119 | Acc: 0.2786 | F1: 0.1982\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.7076 | Acc: 0.2816 | F1: 0.2037\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.7036 | Acc: 0.2766 | F1: 0.2013\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6999 | Acc: 0.2735 | F1: 0.2004\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6965 | Acc: 0.2776 | F1: 0.2040\n",
      "\n",
      ">>> Processing file: CiteSeer_70_30_masked_indices_seed42.npy with encoder: GAT\n",
      "Train size: 2329 | Test size: 998\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9670\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9873\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9948\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9975\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9985\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9991\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9993\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.6951 | Acc: 0.2826 | F1: 0.2043\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6747 | Acc: 0.2806 | F1: 0.2164\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.6618 | Acc: 0.2856 | F1: 0.2289\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6508 | Acc: 0.2946 | F1: 0.2362\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6408 | Acc: 0.3026 | F1: 0.2432\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6316 | Acc: 0.3086 | F1: 0.2488\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6231 | Acc: 0.3156 | F1: 0.2557\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6151 | Acc: 0.3176 | F1: 0.2640\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6077 | Acc: 0.3196 | F1: 0.2661\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6007 | Acc: 0.3156 | F1: 0.2616\n",
      "\n",
      ">>> Processing file: CiteSeer_70_30_masked_indices_seed42.npy with encoder: SAGE\n",
      "Train size: 2329 | Test size: 998\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9959\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9991\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9996\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -0.9999\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7044 | Acc: 0.1914 | F1: 0.1467\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6721 | Acc: 0.1984 | F1: 0.1667\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.6520 | Acc: 0.1954 | F1: 0.1684\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6378 | Acc: 0.1974 | F1: 0.1731\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6269 | Acc: 0.1924 | F1: 0.1664\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6182 | Acc: 0.1884 | F1: 0.1638\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6113 | Acc: 0.1894 | F1: 0.1643\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6057 | Acc: 0.1924 | F1: 0.1664\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6012 | Acc: 0.1984 | F1: 0.1711\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.5975 | Acc: 0.1994 | F1: 0.1755\n",
      "\n",
      ">>> Processing file: CiteSeer_70_30_masked_indices_seed46.npy with encoder: GCN\n",
      "Train size: 2329 | Test size: 998\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9338\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9568\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9722\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9840\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9918\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9958\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9976\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9985\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9990\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9993\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7550 | Acc: 0.2465 | F1: 0.2031\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7358 | Acc: 0.2445 | F1: 0.1764\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7287 | Acc: 0.2525 | F1: 0.1769\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.7224 | Acc: 0.2605 | F1: 0.1978\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.7166 | Acc: 0.2575 | F1: 0.1961\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.7110 | Acc: 0.2615 | F1: 0.1989\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.7058 | Acc: 0.2625 | F1: 0.2013\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.7009 | Acc: 0.2635 | F1: 0.2016\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6963 | Acc: 0.2605 | F1: 0.2012\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6920 | Acc: 0.2615 | F1: 0.2034\n",
      "\n",
      ">>> Processing file: CiteSeer_70_30_masked_indices_seed46.npy with encoder: GAT\n",
      "Train size: 2329 | Test size: 998\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9670\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9861\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9936\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9968\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9982\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9989\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9992\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7021 | Acc: 0.2515 | F1: 0.1937\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6782 | Acc: 0.2515 | F1: 0.2000\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.6620 | Acc: 0.2415 | F1: 0.1917\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6483 | Acc: 0.2555 | F1: 0.2075\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6362 | Acc: 0.2565 | F1: 0.2111\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6253 | Acc: 0.2605 | F1: 0.2151\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6152 | Acc: 0.2685 | F1: 0.2223\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6059 | Acc: 0.2735 | F1: 0.2272\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.5973 | Acc: 0.2756 | F1: 0.2291\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.5891 | Acc: 0.2745 | F1: 0.2276\n",
      "\n",
      ">>> Processing file: CiteSeer_70_30_masked_indices_seed46.npy with encoder: SAGE\n",
      "Train size: 2329 | Test size: 998\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9958\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9991\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9996\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -0.9999\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7092 | Acc: 0.2044 | F1: 0.1588\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6801 | Acc: 0.1854 | F1: 0.1526\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.6620 | Acc: 0.1894 | F1: 0.1552\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6488 | Acc: 0.1874 | F1: 0.1556\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6386 | Acc: 0.1804 | F1: 0.1508\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6304 | Acc: 0.1804 | F1: 0.1530\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6239 | Acc: 0.1784 | F1: 0.1546\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6185 | Acc: 0.1834 | F1: 0.1585\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6142 | Acc: 0.1774 | F1: 0.1540\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6106 | Acc: 0.1764 | F1: 0.1533\n",
      "\n",
      ">>> Processing file: CiteSeer_70_30_masked_indices_seed999.npy with encoder: GCN\n",
      "Train size: 2329 | Test size: 998\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9320\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9557\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9713\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9829\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9907\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9951\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9973\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9984\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9990\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9993\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7597 | Acc: 0.2094 | F1: 0.1068\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7482 | Acc: 0.2565 | F1: 0.1438\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7422 | Acc: 0.2325 | F1: 0.1267\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.7378 | Acc: 0.2565 | F1: 0.1513\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.7340 | Acc: 0.2595 | F1: 0.1530\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.7303 | Acc: 0.2575 | F1: 0.1584\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.7269 | Acc: 0.2525 | F1: 0.1607\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.7237 | Acc: 0.2515 | F1: 0.1631\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.7206 | Acc: 0.2485 | F1: 0.1647\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.7176 | Acc: 0.2495 | F1: 0.1681\n",
      "\n",
      ">>> Processing file: CiteSeer_70_30_masked_indices_seed999.npy with encoder: GAT\n",
      "Train size: 2329 | Test size: 998\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9648\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9857\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9938\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9970\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9983\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9986\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9992\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7386 | Acc: 0.2655 | F1: 0.1739\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7120 | Acc: 0.2675 | F1: 0.1950\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7002 | Acc: 0.2796 | F1: 0.2128\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6908 | Acc: 0.2866 | F1: 0.2198\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6820 | Acc: 0.2846 | F1: 0.2216\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6737 | Acc: 0.2896 | F1: 0.2265\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6659 | Acc: 0.2916 | F1: 0.2309\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6585 | Acc: 0.2956 | F1: 0.2343\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6515 | Acc: 0.2956 | F1: 0.2371\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6448 | Acc: 0.2936 | F1: 0.2360\n",
      "\n",
      ">>> Processing file: CiteSeer_70_30_masked_indices_seed999.npy with encoder: SAGE\n",
      "Train size: 2329 | Test size: 998\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9959\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9991\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9996\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -0.9999\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7098 | Acc: 0.1974 | F1: 0.1420\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6743 | Acc: 0.1844 | F1: 0.1551\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.6551 | Acc: 0.1904 | F1: 0.1598\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6415 | Acc: 0.1864 | F1: 0.1554\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6310 | Acc: 0.1884 | F1: 0.1606\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6228 | Acc: 0.1844 | F1: 0.1615\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6161 | Acc: 0.1834 | F1: 0.1611\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6107 | Acc: 0.1804 | F1: 0.1588\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6063 | Acc: 0.1824 | F1: 0.1612\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6027 | Acc: 0.1804 | F1: 0.1598\n",
      "\n",
      "===== Citeseer (70_30) Summary =====\n",
      "GAT -> Acc: 29.7194 ± 1.6413, BAcc: 26.0396 ± 1.4166, F1: 24.3931 ± 1.4660\n",
      "GCN -> Acc: 26.6333 ± 1.1389, BAcc: 22.5864 ± 1.3399, F1: 19.1436 ± 1.4664\n",
      "SAGE -> Acc: 18.3768 ± 0.9653, BAcc: 16.2828 ± 0.9832, F1: 15.8274 ± 1.0737\n",
      "\n",
      ">>> Processing file: CiteSeer_30_70_masked_indices_seed123.npy with encoder: GCN\n",
      "Train size: 999 | Test size: 2328\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9333\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9567\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9724\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9843\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9915\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9951\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9970\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9980\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9986\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9990\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7419 | Acc: 0.2367 | F1: 0.1689\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7226 | Acc: 0.2431 | F1: 0.1671\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7129 | Acc: 0.2517 | F1: 0.1783\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.7044 | Acc: 0.2599 | F1: 0.1857\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6962 | Acc: 0.2590 | F1: 0.1912\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6883 | Acc: 0.2625 | F1: 0.1965\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6806 | Acc: 0.2629 | F1: 0.2014\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6732 | Acc: 0.2616 | F1: 0.1997\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6661 | Acc: 0.2642 | F1: 0.2018\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6592 | Acc: 0.2637 | F1: 0.2025\n",
      "\n",
      ">>> Processing file: CiteSeer_30_70_masked_indices_seed123.npy with encoder: GAT\n",
      "Train size: 999 | Test size: 2328\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9666\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9859\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9936\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9968\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9982\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9988\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9992\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9996\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.6636 | Acc: 0.2702 | F1: 0.1947\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6295 | Acc: 0.2805 | F1: 0.2284\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.6069 | Acc: 0.2839 | F1: 0.2365\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.5868 | Acc: 0.2891 | F1: 0.2395\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.5686 | Acc: 0.2912 | F1: 0.2424\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.5519 | Acc: 0.2955 | F1: 0.2477\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.5364 | Acc: 0.2964 | F1: 0.2494\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.5220 | Acc: 0.2968 | F1: 0.2518\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.5085 | Acc: 0.2942 | F1: 0.2510\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.4958 | Acc: 0.2981 | F1: 0.2544\n",
      "\n",
      ">>> Processing file: CiteSeer_30_70_masked_indices_seed123.npy with encoder: SAGE\n",
      "Train size: 999 | Test size: 2328\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9946\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9989\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9995\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9997\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -0.9999\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.6539 | Acc: 0.2006 | F1: 0.1652\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.5931 | Acc: 0.1972 | F1: 0.1625\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.5529 | Acc: 0.2032 | F1: 0.1716\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.5215 | Acc: 0.1946 | F1: 0.1651\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.4955 | Acc: 0.1843 | F1: 0.1584\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.4734 | Acc: 0.1860 | F1: 0.1603\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.4542 | Acc: 0.1860 | F1: 0.1626\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.4375 | Acc: 0.1860 | F1: 0.1638\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.4229 | Acc: 0.1813 | F1: 0.1606\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.4099 | Acc: 0.1817 | F1: 0.1614\n",
      "\n",
      ">>> Processing file: CiteSeer_30_70_masked_indices_seed2025.npy with encoder: GCN\n",
      "Train size: 999 | Test size: 2328\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9380\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9609\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9759\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9866\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9931\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9962\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9978\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9985\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9990\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9992\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7416 | Acc: 0.1980 | F1: 0.1216\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7248 | Acc: 0.2058 | F1: 0.1583\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7131 | Acc: 0.2049 | F1: 0.1643\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.7030 | Acc: 0.2083 | F1: 0.1675\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6936 | Acc: 0.2143 | F1: 0.1730\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6849 | Acc: 0.2195 | F1: 0.1769\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6769 | Acc: 0.2320 | F1: 0.1884\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6694 | Acc: 0.2367 | F1: 0.1926\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6624 | Acc: 0.2405 | F1: 0.1958\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6558 | Acc: 0.2436 | F1: 0.1983\n",
      "\n",
      ">>> Processing file: CiteSeer_30_70_masked_indices_seed2025.npy with encoder: GAT\n",
      "Train size: 999 | Test size: 2328\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9664\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9866\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9944\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9973\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9985\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9990\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9993\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.6975 | Acc: 0.2693 | F1: 0.2107\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6707 | Acc: 0.2732 | F1: 0.2164\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.6528 | Acc: 0.2792 | F1: 0.2291\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6372 | Acc: 0.2887 | F1: 0.2407\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6231 | Acc: 0.2951 | F1: 0.2479\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6101 | Acc: 0.2973 | F1: 0.2507\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.5978 | Acc: 0.3033 | F1: 0.2566\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.5862 | Acc: 0.3088 | F1: 0.2617\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.5752 | Acc: 0.3106 | F1: 0.2638\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.5647 | Acc: 0.3106 | F1: 0.2638\n",
      "\n",
      ">>> Processing file: CiteSeer_30_70_masked_indices_seed2025.npy with encoder: SAGE\n",
      "Train size: 999 | Test size: 2328\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9953\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9990\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9996\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -0.9999\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.6339 | Acc: 0.1937 | F1: 0.1675\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.5636 | Acc: 0.1920 | F1: 0.1669\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.5190 | Acc: 0.1894 | F1: 0.1671\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.4857 | Acc: 0.1881 | F1: 0.1674\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.4595 | Acc: 0.1881 | F1: 0.1709\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.4383 | Acc: 0.1860 | F1: 0.1690\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.4210 | Acc: 0.1873 | F1: 0.1710\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.4065 | Acc: 0.1860 | F1: 0.1698\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.3944 | Acc: 0.1851 | F1: 0.1692\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.3841 | Acc: 0.1860 | F1: 0.1716\n",
      "\n",
      ">>> Processing file: CiteSeer_30_70_masked_indices_seed42.npy with encoder: GCN\n",
      "Train size: 999 | Test size: 2328\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9378\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9599\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9740\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9847\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9917\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9955\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9973\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9982\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9988\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9991\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7312 | Acc: 0.2268 | F1: 0.1379\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7077 | Acc: 0.2397 | F1: 0.1681\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.6913 | Acc: 0.2483 | F1: 0.1804\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6769 | Acc: 0.2534 | F1: 0.1895\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6642 | Acc: 0.2564 | F1: 0.1962\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6530 | Acc: 0.2586 | F1: 0.2007\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6431 | Acc: 0.2560 | F1: 0.2015\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6343 | Acc: 0.2590 | F1: 0.2040\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6263 | Acc: 0.2595 | F1: 0.2063\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6190 | Acc: 0.2603 | F1: 0.2077\n",
      "\n",
      ">>> Processing file: CiteSeer_30_70_masked_indices_seed42.npy with encoder: GAT\n",
      "Train size: 999 | Test size: 2328\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9651\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9850\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9934\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9969\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9983\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9989\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9992\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.6936 | Acc: 0.2573 | F1: 0.1984\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6590 | Acc: 0.2882 | F1: 0.2185\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.6339 | Acc: 0.2908 | F1: 0.2302\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6129 | Acc: 0.2869 | F1: 0.2280\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.5941 | Acc: 0.2904 | F1: 0.2345\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.5769 | Acc: 0.2925 | F1: 0.2389\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.5610 | Acc: 0.2981 | F1: 0.2486\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.5462 | Acc: 0.2973 | F1: 0.2503\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.5323 | Acc: 0.2951 | F1: 0.2495\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.5194 | Acc: 0.2951 | F1: 0.2503\n",
      "\n",
      ">>> Processing file: CiteSeer_30_70_masked_indices_seed42.npy with encoder: SAGE\n",
      "Train size: 999 | Test size: 2328\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9953\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9990\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9996\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -0.9999\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.6618 | Acc: 0.1860 | F1: 0.1562\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.5993 | Acc: 0.1967 | F1: 0.1675\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.5581 | Acc: 0.1894 | F1: 0.1660\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.5263 | Acc: 0.1800 | F1: 0.1577\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.5004 | Acc: 0.1821 | F1: 0.1623\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.4790 | Acc: 0.1796 | F1: 0.1630\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.4609 | Acc: 0.1830 | F1: 0.1670\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.4455 | Acc: 0.1791 | F1: 0.1645\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.4322 | Acc: 0.1821 | F1: 0.1678\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.4207 | Acc: 0.1804 | F1: 0.1681\n",
      "\n",
      ">>> Processing file: CiteSeer_30_70_masked_indices_seed46.npy with encoder: GCN\n",
      "Train size: 999 | Test size: 2328\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9324\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9555\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9709\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9830\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9912\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9955\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9975\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9985\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9990\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9993\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7369 | Acc: 0.2315 | F1: 0.1687\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7217 | Acc: 0.2367 | F1: 0.1588\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7133 | Acc: 0.2393 | F1: 0.1714\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.7058 | Acc: 0.2479 | F1: 0.1788\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6989 | Acc: 0.2461 | F1: 0.1785\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6924 | Acc: 0.2474 | F1: 0.1830\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6863 | Acc: 0.2513 | F1: 0.1905\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6804 | Acc: 0.2552 | F1: 0.1967\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6749 | Acc: 0.2526 | F1: 0.1962\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6696 | Acc: 0.2564 | F1: 0.2032\n",
      "\n",
      ">>> Processing file: CiteSeer_30_70_masked_indices_seed46.npy with encoder: GAT\n",
      "Train size: 999 | Test size: 2328\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9703\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9879\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9946\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9973\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9984\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9990\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9993\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.6713 | Acc: 0.2710 | F1: 0.2162\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6368 | Acc: 0.2796 | F1: 0.2304\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.6093 | Acc: 0.2895 | F1: 0.2384\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.5862 | Acc: 0.2857 | F1: 0.2350\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.5654 | Acc: 0.2857 | F1: 0.2370\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.5463 | Acc: 0.2861 | F1: 0.2379\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.5287 | Acc: 0.2925 | F1: 0.2446\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.5125 | Acc: 0.2973 | F1: 0.2494\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.4974 | Acc: 0.2994 | F1: 0.2522\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.4833 | Acc: 0.3024 | F1: 0.2562\n",
      "\n",
      ">>> Processing file: CiteSeer_30_70_masked_indices_seed46.npy with encoder: SAGE\n",
      "Train size: 999 | Test size: 2328\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9953\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9990\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9996\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -0.9999\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.6408 | Acc: 0.1899 | F1: 0.1516\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.5719 | Acc: 0.1847 | F1: 0.1607\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.5287 | Acc: 0.1838 | F1: 0.1618\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.4982 | Acc: 0.1838 | F1: 0.1621\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.4750 | Acc: 0.1847 | F1: 0.1635\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.4565 | Acc: 0.1808 | F1: 0.1614\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.4415 | Acc: 0.1796 | F1: 0.1603\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.4291 | Acc: 0.1783 | F1: 0.1591\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.4188 | Acc: 0.1765 | F1: 0.1583\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.4100 | Acc: 0.1748 | F1: 0.1570\n",
      "\n",
      ">>> Processing file: CiteSeer_30_70_masked_indices_seed999.npy with encoder: GCN\n",
      "Train size: 999 | Test size: 2328\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9320\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9560\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9725\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9849\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9924\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9959\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9975\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9983\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9988\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9991\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.7375 | Acc: 0.2384 | F1: 0.1764\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.7166 | Acc: 0.2530 | F1: 0.1871\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.7052 | Acc: 0.2625 | F1: 0.1963\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.6955 | Acc: 0.2689 | F1: 0.2036\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.6867 | Acc: 0.2710 | F1: 0.2055\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.6785 | Acc: 0.2732 | F1: 0.2071\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.6709 | Acc: 0.2779 | F1: 0.2111\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.6637 | Acc: 0.2745 | F1: 0.2065\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.6569 | Acc: 0.2753 | F1: 0.2079\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.6506 | Acc: 0.2775 | F1: 0.2106\n",
      "\n",
      ">>> Processing file: CiteSeer_30_70_masked_indices_seed999.npy with encoder: GAT\n",
      "Train size: 999 | Test size: 2328\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9651\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9855\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9936\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9969\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9982\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9989\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9992\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9996\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.6703 | Acc: 0.2814 | F1: 0.2237\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.6384 | Acc: 0.2826 | F1: 0.2352\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.6145 | Acc: 0.2899 | F1: 0.2414\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.5939 | Acc: 0.2917 | F1: 0.2437\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.5754 | Acc: 0.2934 | F1: 0.2450\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.5585 | Acc: 0.3003 | F1: 0.2519\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.5429 | Acc: 0.2981 | F1: 0.2505\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.5283 | Acc: 0.2990 | F1: 0.2515\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.5147 | Acc: 0.2981 | F1: 0.2509\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.5018 | Acc: 0.3024 | F1: 0.2552\n",
      "\n",
      ">>> Processing file: CiteSeer_30_70_masked_indices_seed999.npy with encoder: SAGE\n",
      "Train size: 999 | Test size: 2328\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9958\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9991\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9996\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -0.9999\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.6570 | Acc: 0.1972 | F1: 0.1660\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.5902 | Acc: 0.1997 | F1: 0.1685\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.5465 | Acc: 0.1993 | F1: 0.1687\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.5134 | Acc: 0.1980 | F1: 0.1703\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.4872 | Acc: 0.1937 | F1: 0.1672\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.4659 | Acc: 0.1946 | F1: 0.1705\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.4484 | Acc: 0.1924 | F1: 0.1690\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.4337 | Acc: 0.1899 | F1: 0.1666\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.4214 | Acc: 0.1873 | F1: 0.1663\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.4108 | Acc: 0.1851 | F1: 0.1668\n",
      "\n",
      "===== Citeseer (30_70) Summary =====\n",
      "GAT -> Acc: 30.1718 ± 0.5831, BAcc: 26.8784 ± 0.7035, F1: 25.5996 ± 0.4899\n",
      "GCN -> Acc: 26.0309 ± 1.2274, BAcc: 22.6532 ± 0.8966, F1: 20.4463 ± 0.4785\n",
      "SAGE -> Acc: 18.1615 ± 0.4447, BAcc: 16.6307 ± 0.5483, F1: 16.4955 ± 0.5770\n",
      "Loaded PUBMED\n",
      "Data(x=[19717, 150], edge_index=[2, 88648], y=[19717], train_mask=[19717], val_mask=[19717], test_mask=[19717])\n",
      "Number of nodes: 19717, Number of features: 150, Number of classes: 3\n",
      "\n",
      ">>> Processing file: PubMed_70_30_masked_indices_seed123.npy with encoder: GCN\n",
      "Train size: 13802 | Test size: 5915\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9182\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9411\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9610\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9853\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9979\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9998\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0733 | Acc: 0.4044 | F1: 0.1920\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0614 | Acc: 0.3909 | F1: 0.1874\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0612 | Acc: 0.4044 | F1: 0.1920\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0613 | Acc: 0.3909 | F1: 0.1874\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0612 | Acc: 0.4051 | F1: 0.1975\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0612 | Acc: 0.4042 | F1: 0.1937\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0612 | Acc: 0.4056 | F1: 0.1963\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0612 | Acc: 0.4041 | F1: 0.1992\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0612 | Acc: 0.4049 | F1: 0.2060\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0612 | Acc: 0.4061 | F1: 0.2147\n",
      "\n",
      ">>> Processing file: PubMed_70_30_masked_indices_seed123.npy with encoder: GAT\n",
      "Train size: 13802 | Test size: 5915\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9240\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9509\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9683\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9835\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9967\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0784 | Acc: 0.4044 | F1: 0.1920\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0613 | Acc: 0.4044 | F1: 0.1920\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0612 | Acc: 0.4044 | F1: 0.1920\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0613 | Acc: 0.4044 | F1: 0.1920\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0612 | Acc: 0.4044 | F1: 0.1920\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0612 | Acc: 0.4044 | F1: 0.1920\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0612 | Acc: 0.4044 | F1: 0.1920\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0612 | Acc: 0.4044 | F1: 0.1920\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0612 | Acc: 0.4044 | F1: 0.1920\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0612 | Acc: 0.4044 | F1: 0.1920\n",
      "\n",
      ">>> Processing file: PubMed_70_30_masked_indices_seed123.npy with encoder: SAGE\n",
      "Train size: 13802 | Test size: 5915\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9958\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9991\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9997\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0658 | Acc: 0.4144 | F1: 0.2975\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0589 | Acc: 0.3943 | F1: 0.2922\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0564 | Acc: 0.3980 | F1: 0.2948\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0548 | Acc: 0.3951 | F1: 0.2932\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0537 | Acc: 0.3932 | F1: 0.2917\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0528 | Acc: 0.3961 | F1: 0.2939\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0521 | Acc: 0.3959 | F1: 0.2938\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0516 | Acc: 0.3954 | F1: 0.2935\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0512 | Acc: 0.3943 | F1: 0.2926\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0509 | Acc: 0.3956 | F1: 0.2937\n",
      "\n",
      ">>> Processing file: PubMed_70_30_masked_indices_seed2025.npy with encoder: GCN\n",
      "Train size: 13802 | Test size: 5915\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9154\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9382\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9568\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9794\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9966\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9997\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0783 | Acc: 0.3836 | F1: 0.1848\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0615 | Acc: 0.3836 | F1: 0.1848\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0599 | Acc: 0.3836 | F1: 0.1848\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0596 | Acc: 0.4074 | F1: 0.2069\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0596 | Acc: 0.4061 | F1: 0.2635\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0596 | Acc: 0.4059 | F1: 0.2560\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0595 | Acc: 0.4061 | F1: 0.2620\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0595 | Acc: 0.4059 | F1: 0.2666\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0595 | Acc: 0.4041 | F1: 0.2683\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0595 | Acc: 0.4056 | F1: 0.2720\n",
      "\n",
      ">>> Processing file: PubMed_70_30_masked_indices_seed2025.npy with encoder: GAT\n",
      "Train size: 13802 | Test size: 5915\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9252\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9525\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9704\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9856\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9972\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0651 | Acc: 0.4056 | F1: 0.1924\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0603 | Acc: 0.3836 | F1: 0.1848\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0598 | Acc: 0.3836 | F1: 0.1848\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0596 | Acc: 0.4216 | F1: 0.3048\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0595 | Acc: 0.4064 | F1: 0.2251\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0595 | Acc: 0.4178 | F1: 0.2818\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0595 | Acc: 0.4122 | F1: 0.2618\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0595 | Acc: 0.4159 | F1: 0.2720\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0595 | Acc: 0.4162 | F1: 0.2730\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0595 | Acc: 0.4186 | F1: 0.2788\n",
      "\n",
      ">>> Processing file: PubMed_70_30_masked_indices_seed2025.npy with encoder: SAGE\n",
      "Train size: 13802 | Test size: 5915\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9963\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9992\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9997\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0650 | Acc: 0.3983 | F1: 0.2952\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0587 | Acc: 0.3877 | F1: 0.2889\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0558 | Acc: 0.3888 | F1: 0.2898\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0542 | Acc: 0.3873 | F1: 0.2884\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0531 | Acc: 0.3877 | F1: 0.2888\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0522 | Acc: 0.3872 | F1: 0.2884\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0515 | Acc: 0.3872 | F1: 0.2885\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0510 | Acc: 0.3895 | F1: 0.2903\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0505 | Acc: 0.3904 | F1: 0.2910\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0501 | Acc: 0.3882 | F1: 0.2894\n",
      "\n",
      ">>> Processing file: PubMed_70_30_masked_indices_seed42.npy with encoder: GCN\n",
      "Train size: 13802 | Test size: 5915\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9208\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9433\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9637\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9892\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9987\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9997\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0656 | Acc: 0.4054 | F1: 0.1923\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0634 | Acc: 0.4054 | F1: 0.1923\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0619 | Acc: 0.3915 | F1: 0.1876\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0619 | Acc: 0.4057 | F1: 0.1937\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0619 | Acc: 0.4054 | F1: 0.1934\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0619 | Acc: 0.4059 | F1: 0.1954\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0618 | Acc: 0.4068 | F1: 0.2002\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0618 | Acc: 0.4079 | F1: 0.2071\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0618 | Acc: 0.4063 | F1: 0.2110\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0618 | Acc: 0.4079 | F1: 0.2189\n",
      "\n",
      ">>> Processing file: PubMed_70_30_masked_indices_seed42.npy with encoder: GAT\n",
      "Train size: 13802 | Test size: 5915\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9266\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9533\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9703\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9842\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9959\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9997\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0771 | Acc: 0.4054 | F1: 0.1923\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0629 | Acc: 0.3915 | F1: 0.1876\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0620 | Acc: 0.3915 | F1: 0.1876\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0617 | Acc: 0.4054 | F1: 0.1923\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0617 | Acc: 0.4054 | F1: 0.1923\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0617 | Acc: 0.4054 | F1: 0.1923\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0617 | Acc: 0.4054 | F1: 0.1923\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0617 | Acc: 0.4054 | F1: 0.1923\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0617 | Acc: 0.4054 | F1: 0.1923\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0617 | Acc: 0.4054 | F1: 0.1923\n",
      "\n",
      ">>> Processing file: PubMed_70_30_masked_indices_seed42.npy with encoder: SAGE\n",
      "Train size: 13802 | Test size: 5915\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9964\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9993\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9997\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0664 | Acc: 0.3971 | F1: 0.2933\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0597 | Acc: 0.4014 | F1: 0.2978\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0574 | Acc: 0.4049 | F1: 0.3003\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0561 | Acc: 0.4002 | F1: 0.2968\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0551 | Acc: 0.4014 | F1: 0.2976\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0543 | Acc: 0.4032 | F1: 0.2989\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0537 | Acc: 0.4019 | F1: 0.2979\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0532 | Acc: 0.4019 | F1: 0.2979\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0528 | Acc: 0.4029 | F1: 0.2987\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0525 | Acc: 0.4005 | F1: 0.2969\n",
      "\n",
      ">>> Processing file: PubMed_70_30_masked_indices_seed46.npy with encoder: GCN\n",
      "Train size: 13802 | Test size: 5915\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9170\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9400\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9592\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9831\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9979\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9998\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0777 | Acc: 0.3892 | F1: 0.1868\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0643 | Acc: 0.3892 | F1: 0.1868\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0628 | Acc: 0.4101 | F1: 0.1939\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0624 | Acc: 0.4101 | F1: 0.1939\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0623 | Acc: 0.4101 | F1: 0.1939\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0623 | Acc: 0.4101 | F1: 0.1939\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0623 | Acc: 0.4101 | F1: 0.1939\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0623 | Acc: 0.4101 | F1: 0.1939\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0623 | Acc: 0.4101 | F1: 0.1939\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0623 | Acc: 0.4101 | F1: 0.1939\n",
      "\n",
      ">>> Processing file: PubMed_70_30_masked_indices_seed46.npy with encoder: GAT\n",
      "Train size: 13802 | Test size: 5915\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9253\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9521\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9697\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9846\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9964\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0798 | Acc: 0.4101 | F1: 0.1939\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0636 | Acc: 0.3892 | F1: 0.1868\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0626 | Acc: 0.3892 | F1: 0.1868\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0624 | Acc: 0.4101 | F1: 0.1939\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0623 | Acc: 0.4101 | F1: 0.1939\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0623 | Acc: 0.4101 | F1: 0.1939\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0623 | Acc: 0.4101 | F1: 0.1939\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0623 | Acc: 0.4101 | F1: 0.1939\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0623 | Acc: 0.4101 | F1: 0.1939\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0623 | Acc: 0.4101 | F1: 0.1939\n",
      "\n",
      ">>> Processing file: PubMed_70_30_masked_indices_seed46.npy with encoder: SAGE\n",
      "Train size: 13802 | Test size: 5915\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9958\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9991\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9996\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0658 | Acc: 0.4098 | F1: 0.3036\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0597 | Acc: 0.4068 | F1: 0.3014\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0575 | Acc: 0.4041 | F1: 0.2994\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0561 | Acc: 0.4076 | F1: 0.3021\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0552 | Acc: 0.4047 | F1: 0.3000\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0545 | Acc: 0.4003 | F1: 0.2967\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0539 | Acc: 0.3985 | F1: 0.2954\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0535 | Acc: 0.3992 | F1: 0.2959\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0531 | Acc: 0.3992 | F1: 0.2959\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0528 | Acc: 0.3998 | F1: 0.2964\n",
      "\n",
      ">>> Processing file: PubMed_70_30_masked_indices_seed999.npy with encoder: GCN\n",
      "Train size: 13802 | Test size: 5915\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9168\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9395\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9590\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9837\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9979\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9997\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0803 | Acc: 0.3951 | F1: 0.1888\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0611 | Acc: 0.3951 | F1: 0.1888\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0607 | Acc: 0.3951 | F1: 0.1888\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0606 | Acc: 0.3951 | F1: 0.1888\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0605 | Acc: 0.3951 | F1: 0.1888\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0605 | Acc: 0.3951 | F1: 0.1888\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0605 | Acc: 0.3951 | F1: 0.1888\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0604 | Acc: 0.3953 | F1: 0.1896\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0604 | Acc: 0.3963 | F1: 0.1920\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0604 | Acc: 0.3975 | F1: 0.1956\n",
      "\n",
      ">>> Processing file: PubMed_70_30_masked_indices_seed999.npy with encoder: GAT\n",
      "Train size: 13802 | Test size: 5915\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9227\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9498\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9671\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9820\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9958\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9997\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0680 | Acc: 0.3951 | F1: 0.1888\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0626 | Acc: 0.3951 | F1: 0.1888\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0606 | Acc: 0.3951 | F1: 0.1888\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0605 | Acc: 0.3951 | F1: 0.1888\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0605 | Acc: 0.3951 | F1: 0.1888\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0605 | Acc: 0.3951 | F1: 0.1888\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0605 | Acc: 0.3951 | F1: 0.1888\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0605 | Acc: 0.3951 | F1: 0.1888\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0605 | Acc: 0.3951 | F1: 0.1888\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0605 | Acc: 0.3951 | F1: 0.1888\n",
      "\n",
      ">>> Processing file: PubMed_70_30_masked_indices_seed999.npy with encoder: SAGE\n",
      "Train size: 13802 | Test size: 5915\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9963\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9992\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9997\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0655 | Acc: 0.3963 | F1: 0.2946\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0574 | Acc: 0.3883 | F1: 0.2871\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0550 | Acc: 0.3895 | F1: 0.2888\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0536 | Acc: 0.3851 | F1: 0.2852\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0526 | Acc: 0.3877 | F1: 0.2875\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0518 | Acc: 0.3848 | F1: 0.2855\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0512 | Acc: 0.3848 | F1: 0.2857\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0507 | Acc: 0.3843 | F1: 0.2854\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0503 | Acc: 0.3836 | F1: 0.2850\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0500 | Acc: 0.3853 | F1: 0.2868\n",
      "\n",
      "===== Pubmed (70_30) Summary =====\n",
      "GAT -> Acc: 40.6729 ± 0.8588, BAcc: 33.6229 ± 0.6476, F1: 20.9157 ± 3.8979\n",
      "GCN -> Acc: 40.5444 ± 0.4808, BAcc: 33.5382 ± 0.1387, F1: 21.9021 ± 3.1621\n",
      "SAGE -> Acc: 39.3880 ± 0.6869, BAcc: 33.0411 ± 0.4310, F1: 29.2644 ± 0.4445\n",
      "\n",
      ">>> Processing file: PubMed_30_70_masked_indices_seed123.npy with encoder: GCN\n",
      "Train size: 5916 | Test size: 13801\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9180\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9414\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9614\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9862\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9984\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9998\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0881 | Acc: 0.3913 | F1: 0.1875\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0630 | Acc: 0.3913 | F1: 0.1875\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0593 | Acc: 0.3998 | F1: 0.1904\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0592 | Acc: 0.3998 | F1: 0.1904\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0591 | Acc: 0.3998 | F1: 0.1904\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0591 | Acc: 0.3998 | F1: 0.1904\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0591 | Acc: 0.3998 | F1: 0.1904\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0591 | Acc: 0.3998 | F1: 0.1904\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0591 | Acc: 0.3998 | F1: 0.1904\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0591 | Acc: 0.3998 | F1: 0.1904\n",
      "\n",
      ">>> Processing file: PubMed_30_70_masked_indices_seed123.npy with encoder: GAT\n",
      "Train size: 5916 | Test size: 13801\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9260\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9528\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9701\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9849\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9961\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0779 | Acc: 0.3998 | F1: 0.1904\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0601 | Acc: 0.3913 | F1: 0.1875\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0592 | Acc: 0.3998 | F1: 0.1904\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0592 | Acc: 0.3998 | F1: 0.1904\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0591 | Acc: 0.3998 | F1: 0.1904\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0591 | Acc: 0.3998 | F1: 0.1904\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0591 | Acc: 0.3998 | F1: 0.1904\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0591 | Acc: 0.3998 | F1: 0.1904\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0591 | Acc: 0.3998 | F1: 0.1904\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0591 | Acc: 0.3998 | F1: 0.1904\n",
      "\n",
      ">>> Processing file: PubMed_30_70_masked_indices_seed123.npy with encoder: SAGE\n",
      "Train size: 5916 | Test size: 13801\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9960\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9992\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9997\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0643 | Acc: 0.4002 | F1: 0.3065\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0533 | Acc: 0.4022 | F1: 0.2971\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0479 | Acc: 0.4056 | F1: 0.3013\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0449 | Acc: 0.4061 | F1: 0.3025\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0427 | Acc: 0.4037 | F1: 0.3011\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0410 | Acc: 0.4034 | F1: 0.3010\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0396 | Acc: 0.4050 | F1: 0.3031\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0384 | Acc: 0.4041 | F1: 0.3033\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0375 | Acc: 0.4048 | F1: 0.3055\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0367 | Acc: 0.4033 | F1: 0.3049\n",
      "\n",
      ">>> Processing file: PubMed_30_70_masked_indices_seed2025.npy with encoder: GCN\n",
      "Train size: 5916 | Test size: 13801\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9173\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9397\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9584\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9827\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9979\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9998\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0648 | Acc: 0.4005 | F1: 0.1906\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0627 | Acc: 0.3910 | F1: 0.1874\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0601 | Acc: 0.3910 | F1: 0.1874\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0597 | Acc: 0.3910 | F1: 0.1874\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0597 | Acc: 0.4005 | F1: 0.1906\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0597 | Acc: 0.4005 | F1: 0.1906\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0597 | Acc: 0.4005 | F1: 0.1906\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0597 | Acc: 0.4005 | F1: 0.1906\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0597 | Acc: 0.4005 | F1: 0.1906\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0597 | Acc: 0.4005 | F1: 0.1906\n",
      "\n",
      ">>> Processing file: PubMed_30_70_masked_indices_seed2025.npy with encoder: GAT\n",
      "Train size: 5916 | Test size: 13801\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9247\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9516\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9690\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9839\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9964\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0691 | Acc: 0.4005 | F1: 0.1906\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0602 | Acc: 0.3910 | F1: 0.1874\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0598 | Acc: 0.4005 | F1: 0.1906\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0597 | Acc: 0.4005 | F1: 0.1906\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0597 | Acc: 0.4005 | F1: 0.1906\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0597 | Acc: 0.4005 | F1: 0.1906\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0597 | Acc: 0.4005 | F1: 0.1906\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0597 | Acc: 0.4005 | F1: 0.1906\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0597 | Acc: 0.4005 | F1: 0.1906\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0597 | Acc: 0.4005 | F1: 0.1906\n",
      "\n",
      ">>> Processing file: PubMed_30_70_masked_indices_seed2025.npy with encoder: SAGE\n",
      "Train size: 5916 | Test size: 13801\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9962\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9992\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9997\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0583 | Acc: 0.3900 | F1: 0.2879\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0505 | Acc: 0.3950 | F1: 0.2927\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0463 | Acc: 0.4002 | F1: 0.2992\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0438 | Acc: 0.3981 | F1: 0.2998\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0418 | Acc: 0.3968 | F1: 0.2998\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0403 | Acc: 0.3982 | F1: 0.3020\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0390 | Acc: 0.3992 | F1: 0.3036\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0379 | Acc: 0.3982 | F1: 0.3038\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0370 | Acc: 0.3990 | F1: 0.3054\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0363 | Acc: 0.4000 | F1: 0.3073\n",
      "\n",
      ">>> Processing file: PubMed_30_70_masked_indices_seed42.npy with encoder: GCN\n",
      "Train size: 5916 | Test size: 13801\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9183\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9417\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9617\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9870\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9984\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9998\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0784 | Acc: 0.3891 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0666 | Acc: 0.3891 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0657 | Acc: 0.3891 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0656 | Acc: 0.3891 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0655 | Acc: 0.3891 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0655 | Acc: 0.3891 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0655 | Acc: 0.3891 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0655 | Acc: 0.3891 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0655 | Acc: 0.3891 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0655 | Acc: 0.3891 | F1: 0.1867\n",
      "\n",
      ">>> Processing file: PubMed_30_70_masked_indices_seed42.npy with encoder: GAT\n",
      "Train size: 5916 | Test size: 13801\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9230\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9498\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9675\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9828\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9965\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0749 | Acc: 0.3891 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0658 | Acc: 0.4066 | F1: 0.1927\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0657 | Acc: 0.3891 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0655 | Acc: 0.3891 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0655 | Acc: 0.3891 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0655 | Acc: 0.3891 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0655 | Acc: 0.3891 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0655 | Acc: 0.3891 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0655 | Acc: 0.3891 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0655 | Acc: 0.3891 | F1: 0.1867\n",
      "\n",
      ">>> Processing file: PubMed_30_70_masked_indices_seed42.npy with encoder: SAGE\n",
      "Train size: 5916 | Test size: 13801\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9960\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9992\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9997\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0687 | Acc: 0.3972 | F1: 0.2948\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0578 | Acc: 0.3961 | F1: 0.2929\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0533 | Acc: 0.3973 | F1: 0.2944\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0504 | Acc: 0.3959 | F1: 0.2936\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0483 | Acc: 0.3961 | F1: 0.2942\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0466 | Acc: 0.3930 | F1: 0.2924\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0453 | Acc: 0.3924 | F1: 0.2925\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0442 | Acc: 0.3890 | F1: 0.2906\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0433 | Acc: 0.3886 | F1: 0.2908\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0426 | Acc: 0.3883 | F1: 0.2910\n",
      "\n",
      ">>> Processing file: PubMed_30_70_masked_indices_seed46.npy with encoder: GCN\n",
      "Train size: 5916 | Test size: 13801\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9152\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9389\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9580\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9813\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9974\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9998\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0691 | Acc: 0.3948 | F1: 0.1887\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0677 | Acc: 0.4003 | F1: 0.1906\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0652 | Acc: 0.4003 | F1: 0.1906\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0648 | Acc: 0.4005 | F1: 0.1919\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0647 | Acc: 0.4002 | F1: 0.1982\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0647 | Acc: 0.4003 | F1: 0.2043\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0646 | Acc: 0.4008 | F1: 0.2124\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0645 | Acc: 0.4011 | F1: 0.2200\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0645 | Acc: 0.4022 | F1: 0.2276\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0644 | Acc: 0.4028 | F1: 0.2337\n",
      "\n",
      ">>> Processing file: PubMed_30_70_masked_indices_seed46.npy with encoder: GAT\n",
      "Train size: 5916 | Test size: 13801\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9247\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9511\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9690\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9851\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9969\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0749 | Acc: 0.3948 | F1: 0.1887\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0650 | Acc: 0.3948 | F1: 0.1887\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0650 | Acc: 0.3948 | F1: 0.1887\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0649 | Acc: 0.4003 | F1: 0.2145\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0648 | Acc: 0.4003 | F1: 0.1906\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0648 | Acc: 0.4004 | F1: 0.2149\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0647 | Acc: 0.4048 | F1: 0.2378\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0647 | Acc: 0.4058 | F1: 0.2422\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0647 | Acc: 0.4063 | F1: 0.2474\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0646 | Acc: 0.4061 | F1: 0.2524\n",
      "\n",
      ">>> Processing file: PubMed_30_70_masked_indices_seed46.npy with encoder: SAGE\n",
      "Train size: 5916 | Test size: 13801\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9966\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9993\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9997\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0675 | Acc: 0.4064 | F1: 0.3019\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0585 | Acc: 0.3973 | F1: 0.2925\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0536 | Acc: 0.3948 | F1: 0.2935\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0506 | Acc: 0.3941 | F1: 0.2933\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0483 | Acc: 0.3938 | F1: 0.2942\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0464 | Acc: 0.3996 | F1: 0.2997\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0449 | Acc: 0.3998 | F1: 0.3006\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0437 | Acc: 0.3987 | F1: 0.3006\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0427 | Acc: 0.3978 | F1: 0.3010\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0418 | Acc: 0.3974 | F1: 0.3009\n",
      "\n",
      ">>> Processing file: PubMed_30_70_masked_indices_seed999.npy with encoder: GCN\n",
      "Train size: 5916 | Test size: 13801\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9153\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9387\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9577\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9804\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9971\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9997\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0797 | Acc: 0.4047 | F1: 0.1921\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0646 | Acc: 0.3890 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0629 | Acc: 0.3890 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0628 | Acc: 0.3890 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0628 | Acc: 0.3890 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0627 | Acc: 0.3890 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0627 | Acc: 0.3890 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0627 | Acc: 0.3890 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0627 | Acc: 0.3890 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0627 | Acc: 0.3890 | F1: 0.1867\n",
      "\n",
      ">>> Processing file: PubMed_30_70_masked_indices_seed999.npy with encoder: GAT\n",
      "Train size: 5916 | Test size: 13801\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9273\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9545\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9719\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9861\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9967\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0753 | Acc: 0.4047 | F1: 0.1921\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0626 | Acc: 0.4047 | F1: 0.1921\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0628 | Acc: 0.4047 | F1: 0.1921\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0625 | Acc: 0.3890 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0624 | Acc: 0.3890 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0623 | Acc: 0.3890 | F1: 0.1867\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0623 | Acc: 0.3893 | F1: 0.1874\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0622 | Acc: 0.3896 | F1: 0.1893\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0621 | Acc: 0.3892 | F1: 0.1927\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0621 | Acc: 0.3898 | F1: 0.2004\n",
      "\n",
      ">>> Processing file: PubMed_30_70_masked_indices_seed999.npy with encoder: SAGE\n",
      "Train size: 5916 | Test size: 13801\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9964\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9992\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9997\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.0635 | Acc: 0.3888 | F1: 0.2764\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.0526 | Acc: 0.3919 | F1: 0.2899\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.0482 | Acc: 0.3951 | F1: 0.2952\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.0453 | Acc: 0.3945 | F1: 0.2974\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.0432 | Acc: 0.3940 | F1: 0.2982\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.0415 | Acc: 0.3939 | F1: 0.2995\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.0402 | Acc: 0.3959 | F1: 0.3026\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.0392 | Acc: 0.3959 | F1: 0.3042\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.0384 | Acc: 0.3963 | F1: 0.3061\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.0377 | Acc: 0.3966 | F1: 0.3082\n",
      "\n",
      "===== Pubmed (30_70) Summary =====\n",
      "GAT -> Acc: 39.7044 ± 0.7365, BAcc: 33.4482 ± 0.2370, F1: 20.4106 ± 2.7452\n",
      "GCN -> Acc: 39.6232 ± 0.6667, BAcc: 33.3822 ± 0.1092, F1: 19.7646 ± 2.0270\n",
      "SAGE -> Acc: 39.7116 ± 0.5579, BAcc: 33.5860 ± 0.5480, F1: 30.2458 ± 0.7000\n",
      "Loaded WIKICS\n",
      "Data(x=[11701, 150], edge_index=[2, 431726], y=[11701], train_mask=[11701, 20], val_mask=[11701, 20], test_mask=[11701], stopping_mask=[11701, 20])\n",
      "Number of nodes: 11701, Number of features: 150, Number of classes: 10\n",
      "\n",
      ">>> Processing file: WikiCS_70_30_masked_indices_seed123.npy with encoder: GCN\n",
      "Train size: 8191 | Test size: 3510\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/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",
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9609\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9771\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9870\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9927\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9959\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9976\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9985\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9992\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9995\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0400 | Acc: 0.3302 | F1: 0.0925\n",
      "[Linear Classifier] Epoch 040 | Loss: 2.0049 | Acc: 0.3282 | F1: 0.0920\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.9894 | Acc: 0.3328 | F1: 0.0932\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.9812 | Acc: 0.3339 | F1: 0.0946\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.9761 | Acc: 0.3348 | F1: 0.0968\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.9723 | Acc: 0.3348 | F1: 0.0984\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.9693 | Acc: 0.3353 | F1: 0.1002\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.9667 | Acc: 0.3362 | F1: 0.1019\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.9642 | Acc: 0.3370 | F1: 0.1021\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.9619 | Acc: 0.3379 | F1: 0.1032\n",
      "\n",
      ">>> Processing file: WikiCS_70_30_masked_indices_seed123.npy with encoder: GAT\n",
      "Train size: 8191 | Test size: 3510\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9786\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9936\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9972\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9985\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9989\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9991\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9992\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9993\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9994\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.9653 | Acc: 0.3541 | F1: 0.1036\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.9186 | Acc: 0.3729 | F1: 0.1183\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.8867 | Acc: 0.3809 | F1: 0.1270\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.8609 | Acc: 0.3852 | F1: 0.1307\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.8393 | Acc: 0.3897 | F1: 0.1339\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.8209 | Acc: 0.3949 | F1: 0.1374\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.8052 | Acc: 0.4011 | F1: 0.1420\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.7918 | Acc: 0.4123 | F1: 0.1518\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.7802 | Acc: 0.4165 | F1: 0.1550\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.7700 | Acc: 0.4188 | F1: 0.1565\n",
      "\n",
      ">>> Processing file: WikiCS_70_30_masked_indices_seed123.npy with encoder: SAGE\n",
      "Train size: 8191 | Test size: 3510\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9970\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9993\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9997\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0915 | Acc: 0.2054 | F1: 0.0617\n",
      "[Linear Classifier] Epoch 040 | Loss: 2.0671 | Acc: 0.2182 | F1: 0.0636\n",
      "[Linear Classifier] Epoch 060 | Loss: 2.0551 | Acc: 0.2174 | F1: 0.0687\n",
      "[Linear Classifier] Epoch 080 | Loss: 2.0469 | Acc: 0.2194 | F1: 0.0733\n",
      "[Linear Classifier] Epoch 100 | Loss: 2.0404 | Acc: 0.2228 | F1: 0.0770\n",
      "[Linear Classifier] Epoch 120 | Loss: 2.0351 | Acc: 0.2202 | F1: 0.0774\n",
      "[Linear Classifier] Epoch 140 | Loss: 2.0306 | Acc: 0.2160 | F1: 0.0770\n",
      "[Linear Classifier] Epoch 160 | Loss: 2.0268 | Acc: 0.2177 | F1: 0.0792\n",
      "[Linear Classifier] Epoch 180 | Loss: 2.0235 | Acc: 0.2160 | F1: 0.0798\n",
      "[Linear Classifier] Epoch 200 | Loss: 2.0207 | Acc: 0.2137 | F1: 0.0795\n",
      "\n",
      ">>> Processing file: WikiCS_70_30_masked_indices_seed2025.npy with encoder: GCN\n",
      "Train size: 8191 | Test size: 3510\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9612\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9768\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9867\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9926\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9960\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9979\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9989\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9994\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9997\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9998\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0452 | Acc: 0.2632 | F1: 0.0930\n",
      "[Linear Classifier] Epoch 040 | Loss: 2.0083 | Acc: 0.3068 | F1: 0.0867\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.9951 | Acc: 0.3048 | F1: 0.0862\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.9893 | Acc: 0.3051 | F1: 0.0862\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.9859 | Acc: 0.3068 | F1: 0.0866\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.9836 | Acc: 0.3068 | F1: 0.0866\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.9816 | Acc: 0.3071 | F1: 0.0868\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.9799 | Acc: 0.3074 | F1: 0.0868\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.9782 | Acc: 0.3074 | F1: 0.0868\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.9766 | Acc: 0.3074 | F1: 0.0868\n",
      "\n",
      ">>> Processing file: WikiCS_70_30_masked_indices_seed2025.npy with encoder: GAT\n",
      "Train size: 8191 | Test size: 3510\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9794\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9933\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9970\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9985\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9992\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9997\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.9872 | Acc: 0.3379 | F1: 0.0995\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.9487 | Acc: 0.3436 | F1: 0.1008\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.9240 | Acc: 0.3467 | F1: 0.1017\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.9032 | Acc: 0.3481 | F1: 0.1012\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.8849 | Acc: 0.3524 | F1: 0.1037\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.8688 | Acc: 0.3533 | F1: 0.1050\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.8548 | Acc: 0.3547 | F1: 0.1054\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.8425 | Acc: 0.3561 | F1: 0.1072\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.8316 | Acc: 0.3558 | F1: 0.1100\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.8220 | Acc: 0.3573 | F1: 0.1135\n",
      "\n",
      ">>> Processing file: WikiCS_70_30_masked_indices_seed2025.npy with encoder: SAGE\n",
      "Train size: 8191 | Test size: 3510\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9972\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9993\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9997\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0765 | Acc: 0.2231 | F1: 0.0724\n",
      "[Linear Classifier] Epoch 040 | Loss: 2.0537 | Acc: 0.2168 | F1: 0.0674\n",
      "[Linear Classifier] Epoch 060 | Loss: 2.0418 | Acc: 0.2211 | F1: 0.0725\n",
      "[Linear Classifier] Epoch 080 | Loss: 2.0335 | Acc: 0.2117 | F1: 0.0730\n",
      "[Linear Classifier] Epoch 100 | Loss: 2.0272 | Acc: 0.2154 | F1: 0.0761\n",
      "[Linear Classifier] Epoch 120 | Loss: 2.0221 | Acc: 0.2134 | F1: 0.0765\n",
      "[Linear Classifier] Epoch 140 | Loss: 2.0179 | Acc: 0.2123 | F1: 0.0770\n",
      "[Linear Classifier] Epoch 160 | Loss: 2.0144 | Acc: 0.2111 | F1: 0.0772\n",
      "[Linear Classifier] Epoch 180 | Loss: 2.0116 | Acc: 0.2088 | F1: 0.0770\n",
      "[Linear Classifier] Epoch 200 | Loss: 2.0092 | Acc: 0.2037 | F1: 0.0758\n",
      "\n",
      ">>> Processing file: WikiCS_70_30_masked_indices_seed42.npy with encoder: GCN\n",
      "Train size: 8191 | Test size: 3510\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9576\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9744\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9849\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9912\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9949\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9971\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9984\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9991\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9995\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0509 | Acc: 0.2259 | F1: 0.0372\n",
      "[Linear Classifier] Epoch 040 | Loss: 2.0222 | Acc: 0.2835 | F1: 0.0808\n",
      "[Linear Classifier] Epoch 060 | Loss: 2.0086 | Acc: 0.2846 | F1: 0.0811\n",
      "[Linear Classifier] Epoch 080 | Loss: 2.0016 | Acc: 0.2843 | F1: 0.0810\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.9975 | Acc: 0.2852 | F1: 0.0812\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.9948 | Acc: 0.2852 | F1: 0.0812\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.9928 | Acc: 0.2852 | F1: 0.0812\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.9911 | Acc: 0.2852 | F1: 0.0812\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.9896 | Acc: 0.2855 | F1: 0.0813\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.9882 | Acc: 0.2858 | F1: 0.0814\n",
      "\n",
      ">>> Processing file: WikiCS_70_30_masked_indices_seed42.npy with encoder: GAT\n",
      "Train size: 8191 | Test size: 3510\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9836\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9951\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9980\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9988\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9990\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9992\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9993\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9993\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9994\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0021 | Acc: 0.2897 | F1: 0.0837\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.9723 | Acc: 0.3114 | F1: 0.1046\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.9516 | Acc: 0.3120 | F1: 0.0987\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.9352 | Acc: 0.3197 | F1: 0.1064\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.9210 | Acc: 0.3259 | F1: 0.1097\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.9086 | Acc: 0.3330 | F1: 0.1128\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.8978 | Acc: 0.3396 | F1: 0.1158\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.8883 | Acc: 0.3444 | F1: 0.1177\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.8800 | Acc: 0.3464 | F1: 0.1185\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.8727 | Acc: 0.3516 | F1: 0.1224\n",
      "\n",
      ">>> Processing file: WikiCS_70_30_masked_indices_seed42.npy with encoder: SAGE\n",
      "Train size: 8191 | Test size: 3510\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9971\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9993\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9997\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0855 | Acc: 0.2091 | F1: 0.0661\n",
      "[Linear Classifier] Epoch 040 | Loss: 2.0593 | Acc: 0.2154 | F1: 0.0620\n",
      "[Linear Classifier] Epoch 060 | Loss: 2.0471 | Acc: 0.2171 | F1: 0.0637\n",
      "[Linear Classifier] Epoch 080 | Loss: 2.0388 | Acc: 0.2091 | F1: 0.0646\n",
      "[Linear Classifier] Epoch 100 | Loss: 2.0324 | Acc: 0.2068 | F1: 0.0672\n",
      "[Linear Classifier] Epoch 120 | Loss: 2.0273 | Acc: 0.2040 | F1: 0.0685\n",
      "[Linear Classifier] Epoch 140 | Loss: 2.0231 | Acc: 0.2046 | F1: 0.0705\n",
      "[Linear Classifier] Epoch 160 | Loss: 2.0195 | Acc: 0.2046 | F1: 0.0724\n",
      "[Linear Classifier] Epoch 180 | Loss: 2.0165 | Acc: 0.2040 | F1: 0.0738\n",
      "[Linear Classifier] Epoch 200 | Loss: 2.0140 | Acc: 0.2054 | F1: 0.0754\n",
      "\n",
      ">>> Processing file: WikiCS_70_30_masked_indices_seed46.npy with encoder: GCN\n",
      "Train size: 8191 | Test size: 3510\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9580\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9751\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9859\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9922\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9957\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9975\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9985\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9991\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9995\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0343 | Acc: 0.2934 | F1: 0.0840\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.9986 | Acc: 0.2977 | F1: 0.0848\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.9883 | Acc: 0.2966 | F1: 0.0845\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.9838 | Acc: 0.2989 | F1: 0.0851\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.9805 | Acc: 0.2980 | F1: 0.0849\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.9778 | Acc: 0.2991 | F1: 0.0852\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.9752 | Acc: 0.2983 | F1: 0.0851\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.9727 | Acc: 0.2974 | F1: 0.0867\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.9704 | Acc: 0.2974 | F1: 0.0891\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.9682 | Acc: 0.2972 | F1: 0.0897\n",
      "\n",
      ">>> Processing file: WikiCS_70_30_masked_indices_seed46.npy with encoder: GAT\n",
      "Train size: 8191 | Test size: 3510\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9834\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9943\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9978\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9988\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9993\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9997\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.9464 | Acc: 0.3256 | F1: 0.0969\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.8964 | Acc: 0.3610 | F1: 0.1231\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.8649 | Acc: 0.3684 | F1: 0.1292\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.8417 | Acc: 0.3704 | F1: 0.1304\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.8232 | Acc: 0.3744 | F1: 0.1332\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.8080 | Acc: 0.3764 | F1: 0.1347\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.7952 | Acc: 0.3772 | F1: 0.1352\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.7843 | Acc: 0.3772 | F1: 0.1353\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.7749 | Acc: 0.3772 | F1: 0.1351\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.7667 | Acc: 0.3781 | F1: 0.1354\n",
      "\n",
      ">>> Processing file: WikiCS_70_30_masked_indices_seed46.npy with encoder: SAGE\n",
      "Train size: 8191 | Test size: 3510\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9974\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9994\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9997\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0800 | Acc: 0.2091 | F1: 0.0626\n",
      "[Linear Classifier] Epoch 040 | Loss: 2.0610 | Acc: 0.2177 | F1: 0.0613\n",
      "[Linear Classifier] Epoch 060 | Loss: 2.0482 | Acc: 0.2148 | F1: 0.0668\n",
      "[Linear Classifier] Epoch 080 | Loss: 2.0397 | Acc: 0.2131 | F1: 0.0691\n",
      "[Linear Classifier] Epoch 100 | Loss: 2.0330 | Acc: 0.2148 | F1: 0.0725\n",
      "[Linear Classifier] Epoch 120 | Loss: 2.0277 | Acc: 0.2140 | F1: 0.0737\n",
      "[Linear Classifier] Epoch 140 | Loss: 2.0233 | Acc: 0.2111 | F1: 0.0732\n",
      "[Linear Classifier] Epoch 160 | Loss: 2.0196 | Acc: 0.2123 | F1: 0.0746\n",
      "[Linear Classifier] Epoch 180 | Loss: 2.0166 | Acc: 0.2085 | F1: 0.0742\n",
      "[Linear Classifier] Epoch 200 | Loss: 2.0140 | Acc: 0.2094 | F1: 0.0761\n",
      "\n",
      ">>> Processing file: WikiCS_70_30_masked_indices_seed999.npy with encoder: GCN\n",
      "Train size: 8191 | Test size: 3510\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9561\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9745\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9868\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9932\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9962\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9977\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9985\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9991\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9994\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9996\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0385 | Acc: 0.3182 | F1: 0.0897\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.9957 | Acc: 0.3208 | F1: 0.0904\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.9837 | Acc: 0.3194 | F1: 0.0899\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.9778 | Acc: 0.3194 | F1: 0.0901\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.9742 | Acc: 0.3188 | F1: 0.0910\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.9715 | Acc: 0.3185 | F1: 0.0936\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.9691 | Acc: 0.3182 | F1: 0.0935\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.9668 | Acc: 0.3191 | F1: 0.0938\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.9646 | Acc: 0.3199 | F1: 0.0948\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.9625 | Acc: 0.3202 | F1: 0.0957\n",
      "\n",
      ">>> Processing file: WikiCS_70_30_masked_indices_seed999.npy with encoder: GAT\n",
      "Train size: 8191 | Test size: 3510\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9845\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9949\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9979\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9990\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9993\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9996\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.9911 | Acc: 0.3245 | F1: 0.1218\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.9532 | Acc: 0.3299 | F1: 0.1238\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.9296 | Acc: 0.3319 | F1: 0.1234\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.9128 | Acc: 0.3353 | F1: 0.1248\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.8991 | Acc: 0.3396 | F1: 0.1270\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.8877 | Acc: 0.3433 | F1: 0.1282\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.8781 | Acc: 0.3464 | F1: 0.1290\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.8699 | Acc: 0.3499 | F1: 0.1305\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.8628 | Acc: 0.3536 | F1: 0.1316\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.8566 | Acc: 0.3564 | F1: 0.1342\n",
      "\n",
      ">>> Processing file: WikiCS_70_30_masked_indices_seed999.npy with encoder: SAGE\n",
      "Train size: 8191 | Test size: 3510\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9973\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9994\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9997\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0969 | Acc: 0.2111 | F1: 0.0660\n",
      "[Linear Classifier] Epoch 040 | Loss: 2.0659 | Acc: 0.2162 | F1: 0.0661\n",
      "[Linear Classifier] Epoch 060 | Loss: 2.0540 | Acc: 0.2120 | F1: 0.0624\n",
      "[Linear Classifier] Epoch 080 | Loss: 2.0453 | Acc: 0.2145 | F1: 0.0670\n",
      "[Linear Classifier] Epoch 100 | Loss: 2.0385 | Acc: 0.2154 | F1: 0.0693\n",
      "[Linear Classifier] Epoch 120 | Loss: 2.0330 | Acc: 0.2125 | F1: 0.0695\n",
      "[Linear Classifier] Epoch 140 | Loss: 2.0286 | Acc: 0.2100 | F1: 0.0700\n",
      "[Linear Classifier] Epoch 160 | Loss: 2.0249 | Acc: 0.2097 | F1: 0.0709\n",
      "[Linear Classifier] Epoch 180 | Loss: 2.0218 | Acc: 0.2071 | F1: 0.0711\n",
      "[Linear Classifier] Epoch 200 | Loss: 2.0192 | Acc: 0.2048 | F1: 0.0708\n",
      "\n",
      "===== WikiCS (70_30) Summary =====\n",
      "GAT -> Acc: 37.2422 ± 2.7857, BAcc: 18.6552 ± 1.2203, F1: 13.2399 ± 1.6220\n",
      "GCN -> Acc: 30.9687 ± 2.0259, BAcc: 15.0975 ± 0.8204, F1: 9.1371 ± 0.8372\n",
      "SAGE -> Acc: 20.7407 ± 0.4109, BAcc: 10.0465 ± 0.2433, F1: 7.5513 ± 0.3071\n",
      "\n",
      ">>> Processing file: WikiCS_30_70_masked_indices_seed123.npy with encoder: GCN\n",
      "Train size: 3511 | Test size: 8190\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9604\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9764\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9862\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9921\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9956\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9975\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9987\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9994\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9996\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9998\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0550 | Acc: 0.3195 | F1: 0.0900\n",
      "[Linear Classifier] Epoch 040 | Loss: 2.0117 | Acc: 0.3147 | F1: 0.0889\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.9987 | Acc: 0.3216 | F1: 0.0907\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.9927 | Acc: 0.3222 | F1: 0.0909\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.9890 | Acc: 0.3225 | F1: 0.0909\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.9861 | Acc: 0.3226 | F1: 0.0910\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.9836 | Acc: 0.3220 | F1: 0.0908\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.9813 | Acc: 0.3219 | F1: 0.0907\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.9792 | Acc: 0.3221 | F1: 0.0912\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.9772 | Acc: 0.3223 | F1: 0.0915\n",
      "\n",
      ">>> Processing file: WikiCS_30_70_masked_indices_seed123.npy with encoder: GAT\n",
      "Train size: 3511 | Test size: 8190\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9852\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9957\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9983\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9990\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9992\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9993\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9995\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.9952 | Acc: 0.3469 | F1: 0.1237\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.9574 | Acc: 0.3258 | F1: 0.0940\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.9318 | Acc: 0.3480 | F1: 0.1177\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.9109 | Acc: 0.3523 | F1: 0.1196\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.8928 | Acc: 0.3585 | F1: 0.1228\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.8771 | Acc: 0.3646 | F1: 0.1255\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.8635 | Acc: 0.3702 | F1: 0.1289\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.8517 | Acc: 0.3740 | F1: 0.1321\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.8414 | Acc: 0.3752 | F1: 0.1338\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.8322 | Acc: 0.3783 | F1: 0.1352\n",
      "\n",
      ">>> Processing file: WikiCS_30_70_masked_indices_seed123.npy with encoder: SAGE\n",
      "Train size: 3511 | Test size: 8190\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9973\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9993\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9997\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0715 | Acc: 0.2186 | F1: 0.0676\n",
      "[Linear Classifier] Epoch 040 | Loss: 2.0278 | Acc: 0.2110 | F1: 0.0720\n",
      "[Linear Classifier] Epoch 060 | Loss: 2.0026 | Acc: 0.2038 | F1: 0.0753\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.9844 | Acc: 0.1996 | F1: 0.0767\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.9699 | Acc: 0.1991 | F1: 0.0783\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.9583 | Acc: 0.1971 | F1: 0.0803\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.9486 | Acc: 0.1945 | F1: 0.0809\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.9406 | Acc: 0.1945 | F1: 0.0823\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.9338 | Acc: 0.1929 | F1: 0.0830\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.9280 | Acc: 0.1929 | F1: 0.0846\n",
      "\n",
      ">>> Processing file: WikiCS_30_70_masked_indices_seed2025.npy with encoder: GCN\n",
      "Train size: 3511 | Test size: 8190\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9614\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9765\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9855\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9912\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9950\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9974\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9989\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9995\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9997\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9998\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0744 | Acc: 0.2549 | F1: 0.0705\n",
      "[Linear Classifier] Epoch 040 | Loss: 2.0350 | Acc: 0.3044 | F1: 0.0860\n",
      "[Linear Classifier] Epoch 060 | Loss: 2.0194 | Acc: 0.3104 | F1: 0.0876\n",
      "[Linear Classifier] Epoch 080 | Loss: 2.0106 | Acc: 0.3107 | F1: 0.0876\n",
      "[Linear Classifier] Epoch 100 | Loss: 2.0052 | Acc: 0.3104 | F1: 0.0875\n",
      "[Linear Classifier] Epoch 120 | Loss: 2.0016 | Acc: 0.3105 | F1: 0.0876\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.9989 | Acc: 0.3104 | F1: 0.0875\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.9968 | Acc: 0.3103 | F1: 0.0875\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.9949 | Acc: 0.3103 | F1: 0.0875\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.9933 | Acc: 0.3103 | F1: 0.0883\n",
      "\n",
      ">>> Processing file: WikiCS_30_70_masked_indices_seed2025.npy with encoder: GAT\n",
      "Train size: 3511 | Test size: 8190\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9788\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9942\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9975\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9986\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9990\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9991\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9992\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9992\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9993\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9993\n",
      "[Linear Classifier] Epoch 020 | Loss: 1.9648 | Acc: 0.3313 | F1: 0.0969\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.9243 | Acc: 0.3383 | F1: 0.0980\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.8976 | Acc: 0.3404 | F1: 0.0998\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.8753 | Acc: 0.3476 | F1: 0.1084\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.8564 | Acc: 0.3560 | F1: 0.1163\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.8401 | Acc: 0.3618 | F1: 0.1205\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.8259 | Acc: 0.3669 | F1: 0.1239\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.8135 | Acc: 0.3691 | F1: 0.1254\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.8023 | Acc: 0.3724 | F1: 0.1283\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.7923 | Acc: 0.3757 | F1: 0.1318\n",
      "\n",
      ">>> Processing file: WikiCS_30_70_masked_indices_seed2025.npy with encoder: SAGE\n",
      "Train size: 3511 | Test size: 8190\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9979\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9995\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0689 | Acc: 0.2231 | F1: 0.0615\n",
      "[Linear Classifier] Epoch 040 | Loss: 2.0232 | Acc: 0.2211 | F1: 0.0717\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.9956 | Acc: 0.2147 | F1: 0.0745\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.9760 | Acc: 0.2090 | F1: 0.0774\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.9605 | Acc: 0.2054 | F1: 0.0793\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.9480 | Acc: 0.2027 | F1: 0.0811\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.9378 | Acc: 0.1995 | F1: 0.0824\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.9294 | Acc: 0.1979 | F1: 0.0847\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.9224 | Acc: 0.1951 | F1: 0.0870\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.9166 | Acc: 0.1944 | F1: 0.0888\n",
      "\n",
      ">>> Processing file: WikiCS_30_70_masked_indices_seed42.npy with encoder: GCN\n",
      "Train size: 3511 | Test size: 8190\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9595\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9757\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9862\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9923\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9956\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9974\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9984\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9991\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9995\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0489 | Acc: 0.2874 | F1: 0.0803\n",
      "[Linear Classifier] Epoch 040 | Loss: 2.0208 | Acc: 0.2980 | F1: 0.0840\n",
      "[Linear Classifier] Epoch 060 | Loss: 2.0136 | Acc: 0.2980 | F1: 0.0841\n",
      "[Linear Classifier] Epoch 080 | Loss: 2.0097 | Acc: 0.2982 | F1: 0.0842\n",
      "[Linear Classifier] Epoch 100 | Loss: 2.0069 | Acc: 0.2984 | F1: 0.0843\n",
      "[Linear Classifier] Epoch 120 | Loss: 2.0047 | Acc: 0.2993 | F1: 0.0861\n",
      "[Linear Classifier] Epoch 140 | Loss: 2.0028 | Acc: 0.3000 | F1: 0.0890\n",
      "[Linear Classifier] Epoch 160 | Loss: 2.0010 | Acc: 0.3002 | F1: 0.0905\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.9992 | Acc: 0.3002 | F1: 0.0911\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.9974 | Acc: 0.3002 | F1: 0.0921\n",
      "\n",
      ">>> Processing file: WikiCS_30_70_masked_indices_seed42.npy with encoder: GAT\n",
      "Train size: 3511 | Test size: 8190\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9820\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9944\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9977\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9987\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9991\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9993\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9995\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0152 | Acc: 0.2861 | F1: 0.0883\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.9739 | Acc: 0.3182 | F1: 0.1157\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.9516 | Acc: 0.3217 | F1: 0.1154\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.9335 | Acc: 0.3238 | F1: 0.1162\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.9181 | Acc: 0.3287 | F1: 0.1177\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.9050 | Acc: 0.3339 | F1: 0.1191\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.8939 | Acc: 0.3405 | F1: 0.1210\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.8844 | Acc: 0.3453 | F1: 0.1224\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.8763 | Acc: 0.3470 | F1: 0.1228\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.8692 | Acc: 0.3497 | F1: 0.1237\n",
      "\n",
      ">>> Processing file: WikiCS_30_70_masked_indices_seed42.npy with encoder: SAGE\n",
      "Train size: 3511 | Test size: 8190\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9980\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9995\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0490 | Acc: 0.1991 | F1: 0.0761\n",
      "[Linear Classifier] Epoch 040 | Loss: 2.0036 | Acc: 0.2024 | F1: 0.0758\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.9793 | Acc: 0.2005 | F1: 0.0749\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.9614 | Acc: 0.1974 | F1: 0.0767\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.9475 | Acc: 0.1940 | F1: 0.0776\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.9363 | Acc: 0.1928 | F1: 0.0799\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.9271 | Acc: 0.1918 | F1: 0.0813\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.9195 | Acc: 0.1901 | F1: 0.0832\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.9131 | Acc: 0.1872 | F1: 0.0834\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.9076 | Acc: 0.1868 | F1: 0.0856\n",
      "\n",
      ">>> Processing file: WikiCS_30_70_masked_indices_seed46.npy with encoder: GCN\n",
      "Train size: 3511 | Test size: 8190\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9561\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9731\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9839\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9906\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9946\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9969\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9983\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9991\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9995\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0301 | Acc: 0.3049 | F1: 0.0864\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.9902 | Acc: 0.3053 | F1: 0.0865\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.9771 | Acc: 0.3070 | F1: 0.0870\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.9702 | Acc: 0.3070 | F1: 0.0870\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.9654 | Acc: 0.3074 | F1: 0.0871\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.9616 | Acc: 0.3072 | F1: 0.0871\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.9584 | Acc: 0.3067 | F1: 0.0883\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.9555 | Acc: 0.3065 | F1: 0.0908\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.9528 | Acc: 0.3071 | F1: 0.0934\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.9501 | Acc: 0.3068 | F1: 0.0936\n",
      "\n",
      ">>> Processing file: WikiCS_30_70_masked_indices_seed46.npy with encoder: GAT\n",
      "Train size: 3511 | Test size: 8190\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9839\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9944\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9975\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9983\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9986\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9988\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9988\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9989\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9989\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9989\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0284 | Acc: 0.3101 | F1: 0.1064\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.9913 | Acc: 0.3188 | F1: 0.1073\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.9682 | Acc: 0.3215 | F1: 0.1077\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.9503 | Acc: 0.3244 | F1: 0.1088\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.9355 | Acc: 0.3304 | F1: 0.1115\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.9233 | Acc: 0.3349 | F1: 0.1138\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.9131 | Acc: 0.3376 | F1: 0.1154\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.9046 | Acc: 0.3411 | F1: 0.1180\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.8974 | Acc: 0.3440 | F1: 0.1194\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.8912 | Acc: 0.3474 | F1: 0.1213\n",
      "\n",
      ">>> Processing file: WikiCS_30_70_masked_indices_seed46.npy with encoder: SAGE\n",
      "Train size: 3511 | Test size: 8190\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9976\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9994\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0518 | Acc: 0.2066 | F1: 0.0704\n",
      "[Linear Classifier] Epoch 040 | Loss: 2.0128 | Acc: 0.2103 | F1: 0.0676\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.9903 | Acc: 0.2082 | F1: 0.0726\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.9734 | Acc: 0.2028 | F1: 0.0763\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.9602 | Acc: 0.2022 | F1: 0.0810\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.9495 | Acc: 0.1982 | F1: 0.0808\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.9409 | Acc: 0.1965 | F1: 0.0823\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.9337 | Acc: 0.1946 | F1: 0.0832\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.9277 | Acc: 0.1913 | F1: 0.0831\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.9226 | Acc: 0.1901 | F1: 0.0838\n",
      "\n",
      ">>> Processing file: WikiCS_30_70_masked_indices_seed999.npy with encoder: GCN\n",
      "Train size: 3511 | Test size: 8190\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GCN Encoder] Epoch 020 | Contrastive Loss: -0.9575\n",
      "[GCN Encoder] Epoch 040 | Contrastive Loss: -0.9741\n",
      "[GCN Encoder] Epoch 060 | Contrastive Loss: -0.9850\n",
      "[GCN Encoder] Epoch 080 | Contrastive Loss: -0.9918\n",
      "[GCN Encoder] Epoch 100 | Contrastive Loss: -0.9956\n",
      "[GCN Encoder] Epoch 120 | Contrastive Loss: -0.9976\n",
      "[GCN Encoder] Epoch 140 | Contrastive Loss: -0.9987\n",
      "[GCN Encoder] Epoch 160 | Contrastive Loss: -0.9993\n",
      "[GCN Encoder] Epoch 180 | Contrastive Loss: -0.9996\n",
      "[GCN Encoder] Epoch 200 | Contrastive Loss: -0.9997\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0522 | Acc: 0.2905 | F1: 0.0823\n",
      "[Linear Classifier] Epoch 040 | Loss: 2.0176 | Acc: 0.2926 | F1: 0.0829\n",
      "[Linear Classifier] Epoch 060 | Loss: 2.0025 | Acc: 0.2907 | F1: 0.0824\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.9948 | Acc: 0.2907 | F1: 0.0824\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.9900 | Acc: 0.2906 | F1: 0.0823\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.9867 | Acc: 0.2907 | F1: 0.0828\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.9839 | Acc: 0.2911 | F1: 0.0856\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.9815 | Acc: 0.2906 | F1: 0.0869\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.9792 | Acc: 0.2904 | F1: 0.0875\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.9770 | Acc: 0.2907 | F1: 0.0890\n",
      "\n",
      ">>> Processing file: WikiCS_30_70_masked_indices_seed999.npy with encoder: GAT\n",
      "Train size: 3511 | Test size: 8190\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[GAT Encoder] Epoch 020 | Contrastive Loss: -0.9837\n",
      "[GAT Encoder] Epoch 040 | Contrastive Loss: -0.9932\n",
      "[GAT Encoder] Epoch 060 | Contrastive Loss: -0.9971\n",
      "[GAT Encoder] Epoch 080 | Contrastive Loss: -0.9985\n",
      "[GAT Encoder] Epoch 100 | Contrastive Loss: -0.9991\n",
      "[GAT Encoder] Epoch 120 | Contrastive Loss: -0.9994\n",
      "[GAT Encoder] Epoch 140 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 160 | Contrastive Loss: -0.9995\n",
      "[GAT Encoder] Epoch 180 | Contrastive Loss: -0.9996\n",
      "[GAT Encoder] Epoch 200 | Contrastive Loss: -0.9996\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0102 | Acc: 0.2668 | F1: 0.0928\n",
      "[Linear Classifier] Epoch 040 | Loss: 1.9766 | Acc: 0.3111 | F1: 0.1122\n",
      "[Linear Classifier] Epoch 060 | Loss: 1.9519 | Acc: 0.3188 | F1: 0.1154\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.9308 | Acc: 0.3327 | F1: 0.1192\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.9123 | Acc: 0.3407 | F1: 0.1211\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.8960 | Acc: 0.3479 | F1: 0.1230\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.8819 | Acc: 0.3520 | F1: 0.1243\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.8694 | Acc: 0.3559 | F1: 0.1259\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.8583 | Acc: 0.3589 | F1: 0.1270\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.8484 | Acc: 0.3606 | F1: 0.1282\n",
      "\n",
      ">>> Processing file: WikiCS_30_70_masked_indices_seed999.npy with encoder: SAGE\n",
      "Train size: 3511 | Test size: 8190\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sujan/miniforge3/envs/tf-gpu/lib/python3.10/site-packages/torch_geometric/deprecation.py:26: UserWarning: 'dropout_adj' is deprecated, use 'dropout_edge' instead\n",
      "  warnings.warn(out)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[SAGE Encoder] Epoch 020 | Contrastive Loss: -0.9973\n",
      "[SAGE Encoder] Epoch 040 | Contrastive Loss: -0.9993\n",
      "[SAGE Encoder] Epoch 060 | Contrastive Loss: -0.9997\n",
      "[SAGE Encoder] Epoch 080 | Contrastive Loss: -0.9998\n",
      "[SAGE Encoder] Epoch 100 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 120 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 140 | Contrastive Loss: -0.9999\n",
      "[SAGE Encoder] Epoch 160 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 180 | Contrastive Loss: -1.0000\n",
      "[SAGE Encoder] Epoch 200 | Contrastive Loss: -1.0000\n",
      "[Linear Classifier] Epoch 020 | Loss: 2.0750 | Acc: 0.2048 | F1: 0.0756\n",
      "[Linear Classifier] Epoch 040 | Loss: 2.0314 | Acc: 0.2037 | F1: 0.0710\n",
      "[Linear Classifier] Epoch 060 | Loss: 2.0061 | Acc: 0.2054 | F1: 0.0723\n",
      "[Linear Classifier] Epoch 080 | Loss: 1.9879 | Acc: 0.2051 | F1: 0.0755\n",
      "[Linear Classifier] Epoch 100 | Loss: 1.9733 | Acc: 0.2053 | F1: 0.0782\n",
      "[Linear Classifier] Epoch 120 | Loss: 1.9612 | Acc: 0.2020 | F1: 0.0784\n",
      "[Linear Classifier] Epoch 140 | Loss: 1.9511 | Acc: 0.1980 | F1: 0.0789\n",
      "[Linear Classifier] Epoch 160 | Loss: 1.9426 | Acc: 0.1946 | F1: 0.0788\n",
      "[Linear Classifier] Epoch 180 | Loss: 1.9354 | Acc: 0.1906 | F1: 0.0796\n",
      "[Linear Classifier] Epoch 200 | Loss: 1.9292 | Acc: 0.1884 | F1: 0.0793\n",
      "\n",
      "===== WikiCS (30_70) Summary =====\n",
      "GAT -> Acc: 36.2320 ± 1.4311, BAcc: 18.1592 ± 0.6350, F1: 12.8044 ± 0.5693\n",
      "GCN -> Acc: 30.6081 ± 1.1753, BAcc: 14.9212 ± 0.4380, F1: 9.0892 ± 0.2202\n",
      "SAGE -> Acc: 19.0525 ± 0.3126, BAcc: 9.9169 ± 0.1926, F1: 8.4413 ± 0.3457\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import glob\n",
    "import time\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch\n",
    "import torch.nn.functional as F\n",
    "from sklearn.metrics import accuracy_score, f1_score\n",
    "\n",
    "from src.utils import compute_accuracy\n",
    "from src.transform import get_graph_drop_transform\n",
    "from src.imbalance import Imbalance_\n",
    "from layers import GNN\n",
    "from layers.Classifier import Classifier\n",
    "\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "\n",
    "\n",
    "# =============================\n",
    "# ReVar training & evaluation\n",
    "# =============================\n",
    "def train_and_evaluate_revar(data, mask_file, emb_dir, split_name,\n",
    "                             dataset_name, net=\"GCN\", hidden_dim=150, n_head=1, epochs=200):\n",
    "    # Show file being processed\n",
    "    print(f\"\\n>>> Processing file: {os.path.basename(mask_file)} with encoder: {net}\")\n",
    "\n",
    "    imb = Imbalance_(name=dataset_name, data=data, ratio=0)\n",
    "    test_mask = imb.split_semi_dataset(mask_file=mask_file)\n",
    "    train_mask = ~test_mask\n",
    "    data.train_mask, data.test_mask = train_mask, test_mask\n",
    "\n",
    "    # Print mask sizes\n",
    "    print(f\"Train size: {train_mask.sum().item()} | Test size: {test_mask.sum().item()}\")\n",
    "\n",
    "    # Encoder\n",
    "    encoder_model = GNN(\n",
    "        layer_sizes=[data.num_features, hidden_dim, hidden_dim],\n",
    "        net=net, n_head=n_head\n",
    "    ).to(device)\n",
    "    optimizer = torch.optim.Adam(encoder_model.parameters(), lr=0.01)\n",
    "\n",
    "    # Encoder training\n",
    "    transform1 = get_graph_drop_transform(0.2, 0.3)\n",
    "    transform2 = get_graph_drop_transform(0.2, 0.3)\n",
    "    data_aug1, data_aug2 = transform1(data), transform2(data)\n",
    "\n",
    "    start_time = time.time()\n",
    "    for epoch in range(epochs):\n",
    "        encoder_model.train()\n",
    "        optimizer.zero_grad()\n",
    "        z1, z2 = encoder_model(data_aug1), encoder_model(data_aug2)\n",
    "        sim_loss = -torch.cosine_similarity(z1, z2, dim=-1).mean()\n",
    "        sim_loss.backward()\n",
    "        optimizer.step()\n",
    "        if (epoch + 1) % 20 == 0:\n",
    "            print(f\"[{net} Encoder] Epoch {epoch+1:03d} | Contrastive Loss: {sim_loss.item():.4f}\")\n",
    "    enc_time = time.time() - start_time\n",
    "\n",
    "    # Save embeddings\n",
    "    encoder_model.eval()\n",
    "    with torch.no_grad():\n",
    "        embeddings = encoder_model(data).cpu().numpy()\n",
    "    seed_id = os.path.basename(mask_file).split(\"seed\")[-1].replace(\".npy\", \"\")\n",
    "    emb_file = os.path.join(emb_dir, f\"{dataset_name}_{net}_{split_name}_seed{seed_id}.npy\")\n",
    "    np.save(emb_file, embeddings)\n",
    "\n",
    "    # Classifier\n",
    "    num_classes = int(data.y.max().item() + 1)\n",
    "    clf = Classifier(hidden_size=hidden_dim, num_class=num_classes).to(device)\n",
    "    opt_clf = torch.optim.Adam(clf.parameters(), lr=0.01)\n",
    "    criterion = torch.nn.CrossEntropyLoss()\n",
    "\n",
    "    clf_time_start = time.time()\n",
    "    for epoch in range(200):\n",
    "        clf.train()\n",
    "        opt_clf.zero_grad()\n",
    "        logits, preds = clf(torch.tensor(embeddings).to(device))\n",
    "        loss = criterion(logits[data.train_mask], data.y[data.train_mask])\n",
    "        loss.backward()\n",
    "        opt_clf.step()\n",
    "        if (epoch + 1) % 20 == 0:\n",
    "            clf.eval()\n",
    "            with torch.no_grad():\n",
    "                _, preds_eval = clf(torch.tensor(embeddings).to(device))\n",
    "                acc = accuracy_score(data.y[data.test_mask].cpu(),\n",
    "                                     preds_eval[data.test_mask].cpu())\n",
    "                f1 = f1_score(data.y[data.test_mask].cpu(),\n",
    "                              preds_eval[data.test_mask].cpu(),\n",
    "                              average=\"macro\")\n",
    "            print(f\"[Linear Classifier] Epoch {epoch+1:03d} | Loss: {loss.item():.4f} \"\n",
    "                  f\"| Acc: {acc:.4f} | F1: {f1:.4f}\")\n",
    "    clf_time = time.time() - clf_time_start\n",
    "\n",
    "    # Final Eval\n",
    "    clf.eval()\n",
    "    with torch.no_grad():\n",
    "        logits, preds = clf(torch.tensor(embeddings).to(device))\n",
    "        _, test_acc, _, test_bacc, _, test_f1 = compute_accuracy(\n",
    "            preds, data.y, data.train_mask, data.test_mask)\n",
    "\n",
    "    return {\"encoder\": net, \"seed\": seed_id,\n",
    "            \"accuracy\": test_acc, \"balanced_acc\": test_bacc,\n",
    "            \"f1\": test_f1, \"time\": enc_time + clf_time}\n",
    "\n",
    "\n",
    "# =============================\n",
    "# Run pipeline\n",
    "# =============================\n",
    "def run_pipeline(dataset_name, base_mask_dir, base_emb_dir, base_res_dir):\n",
    "    data, _ = load_dataset_revar(dataset_name, hidden_dim=150)\n",
    "\n",
    "    for split in [\"70_30\", \"30_70\"]:\n",
    "        mask_dir = os.path.join(base_mask_dir, dataset_name, split)\n",
    "        emb_dir = os.path.join(base_emb_dir, dataset_name, split)\n",
    "        save_dir = os.path.join(base_res_dir, dataset_name, split)\n",
    "        os.makedirs(emb_dir, exist_ok=True)\n",
    "        os.makedirs(save_dir, exist_ok=True)\n",
    "\n",
    "        results = []\n",
    "        mask_files = sorted(glob.glob(os.path.join(mask_dir, \"*.npy\")))\n",
    "        for mask_file in mask_files:\n",
    "            results.append(train_and_evaluate_revar(data, mask_file, emb_dir, split,\n",
    "                                                    dataset_name, net=\"GCN\"))\n",
    "            results.append(train_and_evaluate_revar(data, mask_file, emb_dir, split,\n",
    "                                                    dataset_name, net=\"GAT\", n_head=8))\n",
    "            results.append(train_and_evaluate_revar(data, mask_file, emb_dir, split,\n",
    "                                                    dataset_name, net=\"SAGE\"))\n",
    "\n",
    "        df = pd.DataFrame(results)\n",
    "        summary = df.groupby(\"encoder\").agg({\n",
    "            \"accuracy\": [\"mean\", \"std\"],\n",
    "            \"balanced_acc\": [\"mean\", \"std\"],\n",
    "            \"f1\": [\"mean\", \"std\"]\n",
    "        }).reset_index()\n",
    "        summary.columns = [\"encoder\",\n",
    "                           \"accuracy_mean\", \"accuracy_std\",\n",
    "                           \"balanced_acc_mean\", \"balanced_acc_std\",\n",
    "                           \"f1_mean\", \"f1_std\"]\n",
    "\n",
    "        print(f\"\\n===== {dataset_name} ({split}) Summary =====\")\n",
    "        for _, r in summary.iterrows():\n",
    "            print(f\"{r['encoder']} -> Acc: {r['accuracy_mean']:.4f} ± {r['accuracy_std']:.4f}, \"\n",
    "                  f\"BAcc: {r['balanced_acc_mean']:.4f} ± {r['balanced_acc_std']:.4f}, \"\n",
    "                  f\"F1: {r['f1_mean']:.4f} ± {r['f1_std']:.4f}\")\n",
    "\n",
    "        # Save summary\n",
    "        summary.to_csv(os.path.join(save_dir, f\"{dataset_name.lower()}_{split}_results.csv\"), index=False)\n",
    "\n",
    "        # Save average execution times\n",
    "        exec_times = df.groupby(\"encoder\")[\"time\"].mean().reset_index()\n",
    "        exec_times.rename(columns={\"time\": \"avg_execution_time\"}, inplace=True)\n",
    "        exec_times.to_csv(os.path.join(save_dir, f\"{dataset_name.lower()}_{split}_execution_times.csv\"), index=False)\n",
    "\n",
    "\n",
    "# =============================\n",
    "# Run all datasets\n",
    "# =============================\n",
    "base_mask_dir = \"/Users/sujan/Modularity based semi supervised learning/masks\"\n",
    "base_emb_dir = \"/Users/sujan/Downloads/ReVar/embeddings\"\n",
    "base_res_dir = \"/Users/sujan/Downloads/ReVar/results\"\n",
    "\n",
    "datasets = [\"Cora\", \"Citeseer\", \"Pubmed\", \"WikiCS\"]\n",
    "\n",
    "for name in datasets:\n",
    "    run_pipeline(name, base_mask_dir, base_emb_dir, base_res_dir)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "78761d3a-d7fb-4ad4-a6df-07c9b275feeb",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python (tf-gpu)",
   "language": "python",
   "name": "tf-gpu"
  },
  "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.10.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
