{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "class config:\n",
    "    data = 'Cora' #choices=[\"Cora\", \"Citeseer\", \"Pubmed\", \"Coauthor-CS\"]\n",
    "    model = 'GCN' #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.6\n",
    "    learning_rate = 0.01\n",
    "    weight_decay = 5e-4\n",
    "    patience = 200\n",
    "    num_iter = 1000\n",
    "    num_test = 30\n",
    "    hop = 2\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 = 3.068, best val f1-macro = 0.794, test f1-macro = 0.799\n",
      "time duration = 2.223, best val f1-macro = 0.791, test f1-macro = 0.805\n",
      "time duration = 2.334, best val f1-macro = 0.791, test f1-macro = 0.812\n",
      "time duration = 3.337, best val f1-macro = 0.791, test f1-macro = 0.793\n",
      "time duration = 2.124, best val f1-macro = 0.793, test f1-macro = 0.803\n",
      "time duration = 2.782, best val f1-macro = 0.798, test f1-macro = 0.802\n",
      "time duration = 2.892, best val f1-macro = 0.790, test f1-macro = 0.810\n",
      "time duration = 2.458, best val f1-macro = 0.793, test f1-macro = 0.793\n",
      "time duration = 2.086, best val f1-macro = 0.793, test f1-macro = 0.807\n",
      "time duration = 2.452, best val f1-macro = 0.796, test f1-macro = 0.800\n",
      "time duration = 2.503, best val f1-macro = 0.788, test f1-macro = 0.805\n",
      "time duration = 2.351, best val f1-macro = 0.792, test f1-macro = 0.807\n",
      "time duration = 2.106, best val f1-macro = 0.794, test f1-macro = 0.798\n",
      "time duration = 2.332, best val f1-macro = 0.795, test f1-macro = 0.811\n",
      "time duration = 2.171, best val f1-macro = 0.792, test f1-macro = 0.805\n",
      "time duration = 2.116, best val f1-macro = 0.791, test f1-macro = 0.803\n",
      "time duration = 2.613, best val f1-macro = 0.794, test f1-macro = 0.808\n",
      "time duration = 3.396, best val f1-macro = 0.788, test f1-macro = 0.802\n",
      "time duration = 2.287, best val f1-macro = 0.793, test f1-macro = 0.812\n",
      "time duration = 4.388, best val f1-macro = 0.789, test f1-macro = 0.808\n",
      "time duration = 2.271, best val f1-macro = 0.789, test f1-macro = 0.813\n",
      "time duration = 2.775, best val f1-macro = 0.797, test f1-macro = 0.804\n",
      "time duration = 2.260, best val f1-macro = 0.790, test f1-macro = 0.806\n",
      "time duration = 2.455, best val f1-macro = 0.794, test f1-macro = 0.812\n",
      "time duration = 2.335, best val f1-macro = 0.804, test f1-macro = 0.807\n",
      "time duration = 2.690, best val f1-macro = 0.794, test f1-macro = 0.805\n",
      "time duration = 2.261, best val f1-macro = 0.794, test f1-macro = 0.812\n",
      "time duration = 4.202, best val f1-macro = 0.795, test f1-macro = 0.801\n",
      "time duration = 2.458, best val f1-macro = 0.795, test f1-macro = 0.802\n",
      "time duration = 3.531, best val f1-macro = 0.791, test f1-macro = 0.801\n",
      "test f1-macro (mean, std):  0.8049271098345474 0.005175360286121096\n",
      "test f1-macro (mean, std) after filter:  0.8052271658593085 0.0036183523034350705\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 = 4.005, best val f1-macro = 0.704, test f1-macro = 0.684\n",
      "time duration = 3.464, best val f1-macro = 0.692, test f1-macro = 0.689\n",
      "time duration = 4.791, best val f1-macro = 0.691, test f1-macro = 0.689\n",
      "time duration = 3.934, best val f1-macro = 0.695, test f1-macro = 0.689\n",
      "time duration = 3.262, best val f1-macro = 0.702, test f1-macro = 0.683\n",
      "time duration = 3.953, best val f1-macro = 0.697, test f1-macro = 0.688\n",
      "time duration = 4.216, best val f1-macro = 0.698, test f1-macro = 0.694\n",
      "time duration = 4.148, best val f1-macro = 0.693, test f1-macro = 0.693\n",
      "time duration = 4.318, best val f1-macro = 0.695, test f1-macro = 0.688\n",
      "time duration = 4.730, best val f1-macro = 0.692, test f1-macro = 0.693\n",
      "time duration = 4.451, best val f1-macro = 0.693, test f1-macro = 0.688\n",
      "time duration = 6.290, best val f1-macro = 0.688, test f1-macro = 0.681\n",
      "time duration = 4.955, best val f1-macro = 0.694, test f1-macro = 0.693\n",
      "time duration = 4.000, best val f1-macro = 0.695, test f1-macro = 0.688\n",
      "time duration = 4.330, best val f1-macro = 0.695, test f1-macro = 0.681\n",
      "time duration = 4.783, best val f1-macro = 0.694, test f1-macro = 0.683\n",
      "time duration = 5.818, best val f1-macro = 0.690, test f1-macro = 0.687\n",
      "time duration = 3.852, best val f1-macro = 0.693, test f1-macro = 0.690\n",
      "time duration = 3.833, best val f1-macro = 0.699, test f1-macro = 0.688\n",
      "time duration = 3.951, best val f1-macro = 0.694, test f1-macro = 0.687\n",
      "time duration = 4.718, best val f1-macro = 0.693, test f1-macro = 0.687\n",
      "time duration = 7.037, best val f1-macro = 0.689, test f1-macro = 0.687\n",
      "time duration = 3.338, best val f1-macro = 0.701, test f1-macro = 0.689\n",
      "time duration = 2.914, best val f1-macro = 0.703, test f1-macro = 0.674\n",
      "time duration = 2.885, best val f1-macro = 0.697, test f1-macro = 0.687\n",
      "time duration = 3.935, best val f1-macro = 0.699, test f1-macro = 0.690\n",
      "time duration = 4.008, best val f1-macro = 0.690, test f1-macro = 0.692\n",
      "time duration = 3.355, best val f1-macro = 0.700, test f1-macro = 0.682\n",
      "time duration = 3.395, best val f1-macro = 0.696, test f1-macro = 0.687\n",
      "time duration = 4.155, best val f1-macro = 0.696, test f1-macro = 0.686\n",
      "test f1-macro (mean, std):  0.6872503202429281 0.004197150825502411\n",
      "test f1-macro (mean, std) after filter:  0.6875679898208048 0.002549562218842077\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 = 6.682, best val f1-macro = 0.809, test f1-macro = 0.790\n",
      "time duration = 6.908, best val f1-macro = 0.805, test f1-macro = 0.788\n",
      "time duration = 5.951, best val f1-macro = 0.806, test f1-macro = 0.786\n",
      "time duration = 6.312, best val f1-macro = 0.803, test f1-macro = 0.791\n",
      "time duration = 9.202, best val f1-macro = 0.805, test f1-macro = 0.781\n",
      "time duration = 6.380, best val f1-macro = 0.801, test f1-macro = 0.786\n",
      "time duration = 7.070, best val f1-macro = 0.806, test f1-macro = 0.790\n",
      "time duration = 6.285, best val f1-macro = 0.805, test f1-macro = 0.791\n",
      "time duration = 6.407, best val f1-macro = 0.802, test f1-macro = 0.789\n",
      "time duration = 7.895, best val f1-macro = 0.804, test f1-macro = 0.789\n",
      "time duration = 7.457, best val f1-macro = 0.805, test f1-macro = 0.795\n",
      "time duration = 6.115, best val f1-macro = 0.806, test f1-macro = 0.788\n",
      "time duration = 8.575, best val f1-macro = 0.809, test f1-macro = 0.779\n",
      "time duration = 7.916, best val f1-macro = 0.804, test f1-macro = 0.781\n",
      "time duration = 6.035, best val f1-macro = 0.811, test f1-macro = 0.788\n",
      "time duration = 6.133, best val f1-macro = 0.809, test f1-macro = 0.788\n",
      "time duration = 7.971, best val f1-macro = 0.808, test f1-macro = 0.784\n",
      "time duration = 7.273, best val f1-macro = 0.805, test f1-macro = 0.781\n",
      "time duration = 6.192, best val f1-macro = 0.805, test f1-macro = 0.791\n",
      "time duration = 7.023, best val f1-macro = 0.807, test f1-macro = 0.793\n",
      "time duration = 6.522, best val f1-macro = 0.803, test f1-macro = 0.786\n",
      "time duration = 6.863, best val f1-macro = 0.807, test f1-macro = 0.790\n",
      "time duration = 7.329, best val f1-macro = 0.804, test f1-macro = 0.792\n",
      "time duration = 6.403, best val f1-macro = 0.807, test f1-macro = 0.790\n",
      "time duration = 9.281, best val f1-macro = 0.804, test f1-macro = 0.779\n",
      "time duration = 7.752, best val f1-macro = 0.809, test f1-macro = 0.794\n",
      "time duration = 6.257, best val f1-macro = 0.805, test f1-macro = 0.787\n",
      "time duration = 6.719, best val f1-macro = 0.805, test f1-macro = 0.789\n",
      "time duration = 8.752, best val f1-macro = 0.807, test f1-macro = 0.782\n",
      "time duration = 7.210, best val f1-macro = 0.807, test f1-macro = 0.795\n",
      "test f1-macro (mean, std):  0.7877845224669345 0.004398075030052385\n",
      "test f1-macro (mean, std) after filter:  0.7879411647349636 0.0031839680055449353\n",
      "\n",
      "start testing on Coauthor-CS dataset with random split: 0\n",
      "time duration = 22.365, best val f1-macro = 0.890, test f1-macro = 0.880\n",
      "time duration = 38.860, best val f1-macro = 0.888, test f1-macro = 0.882\n",
      "time duration = 24.389, best val f1-macro = 0.888, test f1-macro = 0.879\n",
      "time duration = 41.018, best val f1-macro = 0.892, test f1-macro = 0.869\n",
      "time duration = 37.795, best val f1-macro = 0.888, test f1-macro = 0.879\n",
      "time duration = 34.969, best val f1-macro = 0.889, test f1-macro = 0.872\n",
      "time duration = 22.550, best val f1-macro = 0.889, test f1-macro = 0.877\n",
      "time duration = 60.635, best val f1-macro = 0.893, test f1-macro = 0.874\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "time duration = 19.793, best val f1-macro = 0.893, test f1-macro = 0.882\n",
      "time duration = 52.427, best val f1-macro = 0.892, test f1-macro = 0.864\n",
      "time duration = 29.705, best val f1-macro = 0.892, test f1-macro = 0.873\n",
      "time duration = 26.539, best val f1-macro = 0.885, test f1-macro = 0.882\n",
      "time duration = 42.761, best val f1-macro = 0.894, test f1-macro = 0.878\n",
      "time duration = 19.309, best val f1-macro = 0.888, test f1-macro = 0.882\n",
      "time duration = 33.868, best val f1-macro = 0.887, test f1-macro = 0.876\n",
      "time duration = 23.081, best val f1-macro = 0.888, test f1-macro = 0.880\n",
      "time duration = 17.399, best val f1-macro = 0.883, test f1-macro = 0.880\n",
      "time duration = 42.516, best val f1-macro = 0.892, test f1-macro = 0.876\n",
      "time duration = 28.778, best val f1-macro = 0.884, test f1-macro = 0.867\n",
      "time duration = 41.370, best val f1-macro = 0.893, test f1-macro = 0.872\n",
      "time duration = 26.316, best val f1-macro = 0.893, test f1-macro = 0.877\n",
      "time duration = 22.611, best val f1-macro = 0.886, test f1-macro = 0.878\n",
      "time duration = 28.593, best val f1-macro = 0.887, test f1-macro = 0.871\n",
      "time duration = 27.222, best val f1-macro = 0.887, test f1-macro = 0.873\n",
      "time duration = 36.223, best val f1-macro = 0.899, test f1-macro = 0.876\n",
      "time duration = 16.200, best val f1-macro = 0.884, test f1-macro = 0.874\n",
      "time duration = 31.382, best val f1-macro = 0.892, test f1-macro = 0.876\n",
      "time duration = 22.257, best val f1-macro = 0.890, test f1-macro = 0.882\n",
      "time duration = 16.949, best val f1-macro = 0.888, test f1-macro = 0.887\n",
      "time duration = 28.689, best val f1-macro = 0.892, test f1-macro = 0.879\n",
      "test f1-macro (mean, std):  0.8765185992082964 0.004961609763520241\n",
      "test f1-macro (mean, std) after filter:  0.8768550062178 0.0032608253460046713\n",
      "\n",
      "start testing on Coauthor-CS dataset with random split: 1\n",
      "time duration = 17.906, best val f1-macro = 0.912, test f1-macro = 0.878\n",
      "time duration = 24.645, best val f1-macro = 0.903, test f1-macro = 0.876\n",
      "time duration = 13.830, best val f1-macro = 0.907, test f1-macro = 0.891\n",
      "time duration = 14.750, best val f1-macro = 0.909, test f1-macro = 0.880\n",
      "time duration = 20.156, best val f1-macro = 0.905, test f1-macro = 0.877\n",
      "time duration = 23.622, best val f1-macro = 0.903, test f1-macro = 0.873\n",
      "time duration = 13.784, best val f1-macro = 0.909, test f1-macro = 0.886\n",
      "time duration = 21.097, best val f1-macro = 0.903, test f1-macro = 0.871\n",
      "time duration = 24.606, best val f1-macro = 0.901, test f1-macro = 0.874\n",
      "time duration = 18.839, best val f1-macro = 0.906, test f1-macro = 0.876\n",
      "time duration = 17.813, best val f1-macro = 0.910, test f1-macro = 0.881\n",
      "time duration = 21.254, best val f1-macro = 0.905, test f1-macro = 0.870\n",
      "time duration = 13.574, best val f1-macro = 0.910, test f1-macro = 0.881\n",
      "time duration = 13.746, best val f1-macro = 0.903, test f1-macro = 0.875\n",
      "time duration = 13.882, best val f1-macro = 0.903, test f1-macro = 0.873\n",
      "time duration = 20.659, best val f1-macro = 0.903, test f1-macro = 0.880\n",
      "time duration = 13.647, best val f1-macro = 0.909, test f1-macro = 0.879\n",
      "time duration = 13.755, best val f1-macro = 0.907, test f1-macro = 0.873\n",
      "time duration = 25.991, best val f1-macro = 0.910, test f1-macro = 0.875\n",
      "time duration = 13.718, best val f1-macro = 0.909, test f1-macro = 0.871\n",
      "time duration = 13.902, best val f1-macro = 0.909, test f1-macro = 0.874\n",
      "time duration = 13.726, best val f1-macro = 0.907, test f1-macro = 0.862\n",
      "time duration = 13.644, best val f1-macro = 0.905, test f1-macro = 0.878\n",
      "time duration = 14.171, best val f1-macro = 0.904, test f1-macro = 0.866\n",
      "time duration = 32.350, best val f1-macro = 0.905, test f1-macro = 0.871\n",
      "time duration = 18.077, best val f1-macro = 0.905, test f1-macro = 0.868\n",
      "time duration = 13.986, best val f1-macro = 0.907, test f1-macro = 0.857\n",
      "time duration = 27.050, best val f1-macro = 0.905, test f1-macro = 0.858\n",
      "time duration = 13.598, best val f1-macro = 0.908, test f1-macro = 0.873\n",
      "time duration = 17.555, best val f1-macro = 0.907, test f1-macro = 0.883\n",
      "test f1-macro (mean, std):  0.8742416686285915 0.007263275587509057\n",
      "test f1-macro (mean, std) after filter:  0.8745635308117986 0.004002967618871538\n",
      "\n",
      "start testing on Coauthor-CS dataset with random split: 2\n",
      "time duration = 37.509, best val f1-macro = 0.894, test f1-macro = 0.852\n",
      "time duration = 31.163, best val f1-macro = 0.898, test f1-macro = 0.863\n",
      "time duration = 53.368, best val f1-macro = 0.894, test f1-macro = 0.866\n",
      "time duration = 17.111, best val f1-macro = 0.896, test f1-macro = 0.870\n",
      "time duration = 25.558, best val f1-macro = 0.889, test f1-macro = 0.862\n",
      "time duration = 51.324, best val f1-macro = 0.894, test f1-macro = 0.866\n",
      "time duration = 34.451, best val f1-macro = 0.898, test f1-macro = 0.862\n",
      "time duration = 34.774, best val f1-macro = 0.894, test f1-macro = 0.868\n",
      "time duration = 48.903, best val f1-macro = 0.892, test f1-macro = 0.863\n",
      "time duration = 21.454, best val f1-macro = 0.892, test f1-macro = 0.861\n",
      "time duration = 39.664, best val f1-macro = 0.898, test f1-macro = 0.858\n",
      "time duration = 24.400, best val f1-macro = 0.900, test f1-macro = 0.864\n",
      "time duration = 14.238, best val f1-macro = 0.890, test f1-macro = 0.866\n",
      "time duration = 19.283, best val f1-macro = 0.896, test f1-macro = 0.870\n",
      "time duration = 34.498, best val f1-macro = 0.894, test f1-macro = 0.860\n",
      "time duration = 23.453, best val f1-macro = 0.897, test f1-macro = 0.865\n",
      "time duration = 21.207, best val f1-macro = 0.896, test f1-macro = 0.871\n",
      "time duration = 33.824, best val f1-macro = 0.894, test f1-macro = 0.872\n",
      "time duration = 23.689, best val f1-macro = 0.896, test f1-macro = 0.869\n",
      "time duration = 29.415, best val f1-macro = 0.899, test f1-macro = 0.859\n",
      "time duration = 15.460, best val f1-macro = 0.899, test f1-macro = 0.868\n",
      "time duration = 15.511, best val f1-macro = 0.896, test f1-macro = 0.868\n",
      "time duration = 16.332, best val f1-macro = 0.896, test f1-macro = 0.864\n",
      "time duration = 42.571, best val f1-macro = 0.896, test f1-macro = 0.862\n",
      "time duration = 22.144, best val f1-macro = 0.896, test f1-macro = 0.866\n",
      "time duration = 29.416, best val f1-macro = 0.893, test f1-macro = 0.856\n",
      "time duration = 48.664, best val f1-macro = 0.896, test f1-macro = 0.865\n",
      "time duration = 29.796, best val f1-macro = 0.894, test f1-macro = 0.851\n",
      "time duration = 29.048, best val f1-macro = 0.892, test f1-macro = 0.861\n",
      "time duration = 41.122, best val f1-macro = 0.892, test f1-macro = 0.868\n",
      "test f1-macro (mean, std):  0.8638762373983927 0.005070531259093938\n",
      "test f1-macro (mean, std) after filter:  0.8643288956560736 0.003213093710905453\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",
    "        print('\\nstart testing on ' + dataset + ' dataset')\n",
    "        accs.append(main(args))\n",
    "    else:\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_GCN_hop2.txt',accs)"
   ]
  }
 ],
 "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
}
