{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "class config:\n",
    "    data = 'Cora' #choices=[\"Cora\", \"Citeseer\", \"Pubmed\", \"Coauthor-CS\"]\n",
    "    model = 'APPNP' #choices=[\"GCN\", \"GAT\", \"APPNP\", \"DAGNN\", \"TreeLSTM\", \"GTCN\", \"GTAN\", \"GTCN2\"]\n",
    "    n_in = 0\n",
    "    n_hid = 64\n",
    "    n_out = 0\n",
    "    num_heads = 1\n",
    "    num_out_heads = 1\n",
    "    device = 'cpu'\n",
    "    dropout = 0.5\n",
    "    dropout2 = 0.5\n",
    "    learning_rate = 0.01\n",
    "    weight_decay = 5e-4\n",
    "    patience = 200\n",
    "    num_iter = 1000\n",
    "    num_test = 30\n",
    "    hop = 10\n",
    "    alpha = 0.1 # used by APPNP only\n",
    "    random_label_split = False\n",
    "    num_train = 20 # for random label split only\n",
    "    num_val = 30 # for random label split only\n",
    "    data_load = True # load the saved label split to rerun the test (for reproduce purpose)\n",
    "    test_id = 1 # number of the test, only used to record the ith number of the random label split (for reproduce purpose)\n",
    "    filter_pct = 0.1 # remove the top and bottom filer_pct points before obtaining statistics of test accuracy\n",
    "    log = False # whether to show the training log or not\n",
    "    eval_metric = 'f1-macro' # evaluation metrics, choices=[\"acc\", \"f1-macro\", \"f1-micro\"]\n",
    "    root_dir = '../..' # dir of the source code\n",
    "\n",
    "args = config()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Using backend: pytorch\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "sys.path.append(args.root_dir)\n",
    "from train import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "start testing on Cora dataset\n",
      "  NumNodes: 2708\n",
      "  NumEdges: 10556\n",
      "  NumFeats: 1433\n",
      "  NumClasses: 7\n",
      "  NumTrainingSamples: 140\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n",
      "time duration = 11.970, best val f1-macro = 0.813, test f1-macro = 0.828\n",
      "time duration = 11.497, best val f1-macro = 0.809, test f1-macro = 0.828\n",
      "time duration = 18.176, best val f1-macro = 0.804, test f1-macro = 0.827\n",
      "time duration = 19.463, best val f1-macro = 0.811, test f1-macro = 0.815\n",
      "time duration = 15.853, best val f1-macro = 0.804, test f1-macro = 0.807\n",
      "time duration = 9.621, best val f1-macro = 0.809, test f1-macro = 0.822\n",
      "time duration = 11.154, best val f1-macro = 0.813, test f1-macro = 0.822\n",
      "time duration = 15.290, best val f1-macro = 0.811, test f1-macro = 0.815\n",
      "time duration = 12.791, best val f1-macro = 0.810, test f1-macro = 0.815\n",
      "time duration = 12.451, best val f1-macro = 0.814, test f1-macro = 0.821\n",
      "time duration = 9.115, best val f1-macro = 0.801, test f1-macro = 0.817\n",
      "time duration = 11.060, best val f1-macro = 0.811, test f1-macro = 0.813\n",
      "time duration = 15.884, best val f1-macro = 0.806, test f1-macro = 0.818\n",
      "time duration = 10.112, best val f1-macro = 0.806, test f1-macro = 0.812\n",
      "time duration = 11.373, best val f1-macro = 0.801, test f1-macro = 0.810\n",
      "time duration = 10.703, best val f1-macro = 0.804, test f1-macro = 0.834\n",
      "time duration = 14.345, best val f1-macro = 0.808, test f1-macro = 0.822\n",
      "time duration = 9.713, best val f1-macro = 0.804, test f1-macro = 0.816\n",
      "time duration = 14.265, best val f1-macro = 0.805, test f1-macro = 0.817\n",
      "time duration = 10.613, best val f1-macro = 0.813, test f1-macro = 0.820\n",
      "time duration = 8.846, best val f1-macro = 0.817, test f1-macro = 0.815\n",
      "time duration = 18.277, best val f1-macro = 0.810, test f1-macro = 0.825\n",
      "time duration = 10.300, best val f1-macro = 0.806, test f1-macro = 0.821\n",
      "time duration = 10.349, best val f1-macro = 0.812, test f1-macro = 0.822\n",
      "time duration = 13.675, best val f1-macro = 0.805, test f1-macro = 0.802\n",
      "time duration = 19.679, best val f1-macro = 0.807, test f1-macro = 0.809\n",
      "time duration = 11.086, best val f1-macro = 0.807, test f1-macro = 0.817\n",
      "time duration = 8.807, best val f1-macro = 0.812, test f1-macro = 0.822\n",
      "time duration = 16.827, best val f1-macro = 0.807, test f1-macro = 0.816\n",
      "time duration = 13.332, best val f1-macro = 0.808, test f1-macro = 0.820\n",
      "test f1-macro (mean, std):  0.8182617082181095 0.006686522236269356\n",
      "test f1-macro (mean, std) after filter:  0.8183435706233099 0.004091082602680273\n",
      "\n",
      "start testing on Citeseer dataset\n",
      "  NumNodes: 3327\n",
      "  NumEdges: 9228\n",
      "  NumFeats: 3703\n",
      "  NumClasses: 6\n",
      "  NumTrainingSamples: 120\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n",
      "time duration = 21.038, best val f1-macro = 0.700, test f1-macro = 0.679\n",
      "time duration = 11.354, best val f1-macro = 0.708, test f1-macro = 0.688\n",
      "time duration = 16.891, best val f1-macro = 0.700, test f1-macro = 0.677\n",
      "time duration = 10.310, best val f1-macro = 0.718, test f1-macro = 0.687\n",
      "time duration = 12.020, best val f1-macro = 0.713, test f1-macro = 0.689\n",
      "time duration = 13.869, best val f1-macro = 0.705, test f1-macro = 0.683\n",
      "time duration = 9.794, best val f1-macro = 0.706, test f1-macro = 0.678\n",
      "time duration = 14.491, best val f1-macro = 0.708, test f1-macro = 0.681\n",
      "time duration = 14.746, best val f1-macro = 0.711, test f1-macro = 0.688\n",
      "time duration = 13.628, best val f1-macro = 0.714, test f1-macro = 0.690\n",
      "time duration = 12.705, best val f1-macro = 0.714, test f1-macro = 0.684\n",
      "time duration = 9.951, best val f1-macro = 0.716, test f1-macro = 0.694\n",
      "time duration = 9.384, best val f1-macro = 0.700, test f1-macro = 0.684\n",
      "time duration = 9.211, best val f1-macro = 0.703, test f1-macro = 0.679\n",
      "time duration = 10.484, best val f1-macro = 0.705, test f1-macro = 0.681\n",
      "time duration = 12.738, best val f1-macro = 0.708, test f1-macro = 0.680\n",
      "time duration = 11.311, best val f1-macro = 0.704, test f1-macro = 0.681\n",
      "time duration = 9.718, best val f1-macro = 0.706, test f1-macro = 0.673\n",
      "time duration = 14.125, best val f1-macro = 0.710, test f1-macro = 0.685\n",
      "time duration = 11.022, best val f1-macro = 0.711, test f1-macro = 0.694\n",
      "time duration = 12.211, best val f1-macro = 0.705, test f1-macro = 0.682\n",
      "time duration = 16.548, best val f1-macro = 0.705, test f1-macro = 0.681\n",
      "time duration = 14.930, best val f1-macro = 0.702, test f1-macro = 0.675\n",
      "time duration = 15.403, best val f1-macro = 0.708, test f1-macro = 0.684\n",
      "time duration = 14.531, best val f1-macro = 0.713, test f1-macro = 0.686\n",
      "time duration = 11.887, best val f1-macro = 0.708, test f1-macro = 0.678\n",
      "time duration = 10.651, best val f1-macro = 0.715, test f1-macro = 0.679\n",
      "time duration = 16.127, best val f1-macro = 0.708, test f1-macro = 0.689\n",
      "time duration = 14.199, best val f1-macro = 0.714, test f1-macro = 0.680\n",
      "time duration = 11.352, best val f1-macro = 0.709, test f1-macro = 0.680\n",
      "test f1-macro (mean, std):  0.6829717328545669 0.005148118639694797\n",
      "test f1-macro (mean, std) after filter:  0.6827605883425275 0.0033822460256448415\n",
      "\n",
      "start testing on Pubmed dataset\n",
      "  NumNodes: 19717\n",
      "  NumEdges: 88651\n",
      "  NumFeats: 500\n",
      "  NumClasses: 3\n",
      "  NumTrainingSamples: 60\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n",
      "time duration = 30.326, best val f1-macro = 0.824, test f1-macro = 0.787\n",
      "time duration = 30.671, best val f1-macro = 0.821, test f1-macro = 0.779\n",
      "time duration = 32.297, best val f1-macro = 0.819, test f1-macro = 0.784\n",
      "time duration = 35.689, best val f1-macro = 0.827, test f1-macro = 0.784\n",
      "time duration = 35.752, best val f1-macro = 0.823, test f1-macro = 0.792\n",
      "time duration = 29.065, best val f1-macro = 0.826, test f1-macro = 0.794\n",
      "time duration = 27.822, best val f1-macro = 0.825, test f1-macro = 0.790\n",
      "time duration = 29.610, best val f1-macro = 0.824, test f1-macro = 0.787\n",
      "time duration = 37.923, best val f1-macro = 0.821, test f1-macro = 0.786\n",
      "time duration = 29.289, best val f1-macro = 0.818, test f1-macro = 0.790\n",
      "time duration = 28.545, best val f1-macro = 0.827, test f1-macro = 0.790\n",
      "time duration = 30.320, best val f1-macro = 0.824, test f1-macro = 0.792\n",
      "time duration = 31.261, best val f1-macro = 0.821, test f1-macro = 0.789\n",
      "time duration = 30.957, best val f1-macro = 0.826, test f1-macro = 0.784\n",
      "time duration = 27.326, best val f1-macro = 0.821, test f1-macro = 0.789\n",
      "time duration = 28.340, best val f1-macro = 0.827, test f1-macro = 0.789\n",
      "time duration = 33.297, best val f1-macro = 0.827, test f1-macro = 0.789\n",
      "time duration = 46.420, best val f1-macro = 0.825, test f1-macro = 0.794\n",
      "time duration = 28.452, best val f1-macro = 0.822, test f1-macro = 0.788\n",
      "time duration = 35.963, best val f1-macro = 0.825, test f1-macro = 0.791\n",
      "time duration = 41.121, best val f1-macro = 0.815, test f1-macro = 0.791\n",
      "time duration = 34.142, best val f1-macro = 0.822, test f1-macro = 0.794\n",
      "time duration = 31.603, best val f1-macro = 0.820, test f1-macro = 0.795\n",
      "time duration = 32.971, best val f1-macro = 0.820, test f1-macro = 0.788\n",
      "time duration = 34.749, best val f1-macro = 0.822, test f1-macro = 0.784\n",
      "time duration = 30.360, best val f1-macro = 0.824, test f1-macro = 0.788\n",
      "time duration = 30.496, best val f1-macro = 0.825, test f1-macro = 0.790\n",
      "time duration = 34.001, best val f1-macro = 0.825, test f1-macro = 0.791\n",
      "time duration = 27.464, best val f1-macro = 0.821, test f1-macro = 0.790\n",
      "time duration = 31.164, best val f1-macro = 0.825, test f1-macro = 0.791\n",
      "test f1-macro (mean, std):  0.7888859876606292 0.003582488456248629\n",
      "test f1-macro (mean, std) after filter:  0.7890202223406062 0.0023602627826322204\n",
      "\n",
      "start testing on Coauthor-CS dataset with random split: 0\n",
      "time duration = 69.067, best val f1-macro = 0.908, test f1-macro = 0.888\n",
      "time duration = 162.199, best val f1-macro = 0.910, test f1-macro = 0.900\n",
      "time duration = 72.750, best val f1-macro = 0.911, test f1-macro = 0.893\n",
      "time duration = 62.198, best val f1-macro = 0.907, test f1-macro = 0.884\n",
      "time duration = 98.598, best val f1-macro = 0.907, test f1-macro = 0.885\n",
      "time duration = 46.048, best val f1-macro = 0.907, test f1-macro = 0.906\n",
      "time duration = 55.732, best val f1-macro = 0.909, test f1-macro = 0.888\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "time duration = 50.926, best val f1-macro = 0.908, test f1-macro = 0.894\n",
      "time duration = 53.956, best val f1-macro = 0.909, test f1-macro = 0.892\n",
      "time duration = 82.522, best val f1-macro = 0.915, test f1-macro = 0.888\n",
      "time duration = 86.301, best val f1-macro = 0.916, test f1-macro = 0.881\n",
      "time duration = 69.494, best val f1-macro = 0.908, test f1-macro = 0.894\n",
      "time duration = 116.436, best val f1-macro = 0.916, test f1-macro = 0.903\n",
      "time duration = 54.079, best val f1-macro = 0.909, test f1-macro = 0.897\n",
      "time duration = 51.900, best val f1-macro = 0.913, test f1-macro = 0.890\n",
      "time duration = 88.597, best val f1-macro = 0.910, test f1-macro = 0.886\n",
      "time duration = 81.501, best val f1-macro = 0.911, test f1-macro = 0.896\n",
      "time duration = 49.044, best val f1-macro = 0.910, test f1-macro = 0.896\n",
      "time duration = 71.253, best val f1-macro = 0.913, test f1-macro = 0.892\n",
      "time duration = 71.799, best val f1-macro = 0.911, test f1-macro = 0.880\n",
      "time duration = 102.818, best val f1-macro = 0.913, test f1-macro = 0.884\n",
      "time duration = 135.432, best val f1-macro = 0.910, test f1-macro = 0.897\n",
      "time duration = 63.510, best val f1-macro = 0.913, test f1-macro = 0.898\n",
      "time duration = 97.253, best val f1-macro = 0.915, test f1-macro = 0.884\n",
      "time duration = 60.433, best val f1-macro = 0.917, test f1-macro = 0.902\n",
      "time duration = 137.925, best val f1-macro = 0.917, test f1-macro = 0.886\n",
      "time duration = 137.844, best val f1-macro = 0.913, test f1-macro = 0.896\n",
      "time duration = 130.003, best val f1-macro = 0.919, test f1-macro = 0.886\n",
      "time duration = 52.888, best val f1-macro = 0.907, test f1-macro = 0.883\n",
      "time duration = 99.618, best val f1-macro = 0.910, test f1-macro = 0.893\n",
      "test f1-macro (mean, std):  0.8913914661897098 0.006847860171160061\n",
      "test f1-macro (mean, std) after filter:  0.8910802558514237 0.005061627252448031\n",
      "\n",
      "start testing on Coauthor-CS dataset with random split: 1\n",
      "time duration = 61.791, best val f1-macro = 0.931, test f1-macro = 0.896\n",
      "time duration = 75.514, best val f1-macro = 0.940, test f1-macro = 0.901\n",
      "time duration = 50.680, best val f1-macro = 0.934, test f1-macro = 0.887\n",
      "time duration = 49.384, best val f1-macro = 0.931, test f1-macro = 0.899\n",
      "time duration = 58.730, best val f1-macro = 0.933, test f1-macro = 0.898\n",
      "time duration = 137.318, best val f1-macro = 0.940, test f1-macro = 0.895\n",
      "time duration = 126.734, best val f1-macro = 0.936, test f1-macro = 0.892\n",
      "time duration = 55.392, best val f1-macro = 0.936, test f1-macro = 0.901\n",
      "time duration = 43.473, best val f1-macro = 0.931, test f1-macro = 0.892\n",
      "time duration = 46.303, best val f1-macro = 0.931, test f1-macro = 0.893\n",
      "time duration = 62.763, best val f1-macro = 0.936, test f1-macro = 0.893\n",
      "time duration = 64.771, best val f1-macro = 0.931, test f1-macro = 0.896\n",
      "time duration = 57.526, best val f1-macro = 0.936, test f1-macro = 0.901\n",
      "time duration = 71.345, best val f1-macro = 0.931, test f1-macro = 0.898\n",
      "time duration = 57.442, best val f1-macro = 0.936, test f1-macro = 0.897\n",
      "time duration = 43.633, best val f1-macro = 0.934, test f1-macro = 0.891\n",
      "time duration = 44.844, best val f1-macro = 0.927, test f1-macro = 0.891\n",
      "time duration = 55.253, best val f1-macro = 0.938, test f1-macro = 0.902\n",
      "time duration = 49.799, best val f1-macro = 0.932, test f1-macro = 0.892\n",
      "time duration = 44.398, best val f1-macro = 0.936, test f1-macro = 0.889\n",
      "time duration = 97.290, best val f1-macro = 0.929, test f1-macro = 0.896\n",
      "time duration = 100.229, best val f1-macro = 0.938, test f1-macro = 0.899\n",
      "time duration = 85.889, best val f1-macro = 0.935, test f1-macro = 0.899\n",
      "time duration = 71.218, best val f1-macro = 0.933, test f1-macro = 0.895\n",
      "time duration = 125.190, best val f1-macro = 0.940, test f1-macro = 0.895\n",
      "time duration = 43.596, best val f1-macro = 0.940, test f1-macro = 0.904\n",
      "time duration = 57.434, best val f1-macro = 0.935, test f1-macro = 0.896\n",
      "time duration = 134.442, best val f1-macro = 0.936, test f1-macro = 0.883\n",
      "time duration = 59.146, best val f1-macro = 0.934, test f1-macro = 0.893\n",
      "time duration = 110.699, best val f1-macro = 0.936, test f1-macro = 0.896\n",
      "test f1-macro (mean, std):  0.8954017060966655 0.004678441726956947\n",
      "test f1-macro (mean, std) after filter:  0.895665579184923 0.003016057241372268\n",
      "\n",
      "start testing on Coauthor-CS dataset with random split: 2\n",
      "time duration = 83.763, best val f1-macro = 0.915, test f1-macro = 0.884\n",
      "time duration = 59.490, best val f1-macro = 0.916, test f1-macro = 0.883\n",
      "time duration = 53.869, best val f1-macro = 0.923, test f1-macro = 0.896\n",
      "time duration = 55.039, best val f1-macro = 0.921, test f1-macro = 0.897\n",
      "time duration = 65.577, best val f1-macro = 0.916, test f1-macro = 0.892\n",
      "time duration = 55.202, best val f1-macro = 0.919, test f1-macro = 0.886\n",
      "time duration = 144.704, best val f1-macro = 0.918, test f1-macro = 0.877\n",
      "time duration = 54.276, best val f1-macro = 0.919, test f1-macro = 0.879\n",
      "time duration = 65.972, best val f1-macro = 0.921, test f1-macro = 0.884\n",
      "time duration = 73.894, best val f1-macro = 0.918, test f1-macro = 0.891\n",
      "time duration = 72.980, best val f1-macro = 0.918, test f1-macro = 0.892\n",
      "time duration = 70.497, best val f1-macro = 0.920, test f1-macro = 0.890\n",
      "time duration = 118.568, best val f1-macro = 0.918, test f1-macro = 0.878\n",
      "time duration = 46.280, best val f1-macro = 0.916, test f1-macro = 0.886\n",
      "time duration = 65.644, best val f1-macro = 0.918, test f1-macro = 0.884\n",
      "time duration = 55.824, best val f1-macro = 0.916, test f1-macro = 0.897\n",
      "time duration = 62.172, best val f1-macro = 0.921, test f1-macro = 0.891\n",
      "time duration = 77.657, best val f1-macro = 0.923, test f1-macro = 0.881\n",
      "time duration = 52.802, best val f1-macro = 0.914, test f1-macro = 0.893\n",
      "time duration = 59.561, best val f1-macro = 0.919, test f1-macro = 0.877\n",
      "time duration = 70.838, best val f1-macro = 0.922, test f1-macro = 0.890\n",
      "time duration = 88.361, best val f1-macro = 0.920, test f1-macro = 0.892\n",
      "time duration = 81.523, best val f1-macro = 0.916, test f1-macro = 0.896\n",
      "time duration = 64.684, best val f1-macro = 0.916, test f1-macro = 0.891\n",
      "time duration = 61.954, best val f1-macro = 0.918, test f1-macro = 0.886\n",
      "time duration = 98.077, best val f1-macro = 0.916, test f1-macro = 0.885\n",
      "time duration = 127.515, best val f1-macro = 0.919, test f1-macro = 0.875\n",
      "time duration = 53.685, best val f1-macro = 0.923, test f1-macro = 0.894\n",
      "time duration = 46.890, best val f1-macro = 0.921, test f1-macro = 0.890\n",
      "time duration = 50.059, best val f1-macro = 0.915, test f1-macro = 0.891\n",
      "test f1-macro (mean, std):  0.8875835660333724 0.006256941438416374\n",
      "test f1-macro (mean, std) after filter:  0.887839244445142 0.004803719714824467\n"
     ]
    }
   ],
   "source": [
    "accs = []\n",
    "datasets = ['Cora', 'Citeseer', 'Pubmed', 'Coauthor-CS']\n",
    "for dataset in datasets:\n",
    "    args.data = dataset\n",
    "    if dataset != 'Coauthor-CS':\n",
    "        args.alpha = 0.1\n",
    "        print('\\nstart testing on ' + dataset + ' dataset')\n",
    "        accs.append(main(args))\n",
    "    else:\n",
    "        args.alpha = 0.2\n",
    "        for i in range(3):\n",
    "            print('\\nstart testing on ' + dataset + ' dataset with random split: ' + str(i))\n",
    "            args.test_id = i\n",
    "            args.random_label_split = True\n",
    "            accs.append(main(args))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "accs = np.array(accs)\n",
    "np.savetxt('log_f1_macro/f1-macro_APPNP.txt', accs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "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.8.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
