{
 "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 = 'acc' # 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 = 2.522, best val acc = 0.802, test acc = 0.820\n",
      "time duration = 1.741, best val acc = 0.808, test acc = 0.812\n",
      "time duration = 2.089, best val acc = 0.798, test acc = 0.810\n",
      "time duration = 2.360, best val acc = 0.800, test acc = 0.808\n",
      "time duration = 3.813, best val acc = 0.806, test acc = 0.817\n",
      "time duration = 2.115, best val acc = 0.802, test acc = 0.814\n",
      "time duration = 3.800, best val acc = 0.804, test acc = 0.810\n",
      "time duration = 1.845, best val acc = 0.808, test acc = 0.814\n",
      "time duration = 1.870, best val acc = 0.806, test acc = 0.816\n",
      "time duration = 4.813, best val acc = 0.804, test acc = 0.818\n",
      "time duration = 1.908, best val acc = 0.810, test acc = 0.817\n",
      "time duration = 3.066, best val acc = 0.804, test acc = 0.813\n",
      "time duration = 3.376, best val acc = 0.804, test acc = 0.815\n",
      "time duration = 1.783, best val acc = 0.808, test acc = 0.820\n",
      "time duration = 2.138, best val acc = 0.800, test acc = 0.814\n",
      "time duration = 1.919, best val acc = 0.810, test acc = 0.814\n",
      "time duration = 3.277, best val acc = 0.808, test acc = 0.815\n",
      "time duration = 4.143, best val acc = 0.804, test acc = 0.814\n",
      "time duration = 2.602, best val acc = 0.802, test acc = 0.813\n",
      "time duration = 2.767, best val acc = 0.800, test acc = 0.813\n",
      "time duration = 1.880, best val acc = 0.798, test acc = 0.821\n",
      "time duration = 1.741, best val acc = 0.810, test acc = 0.824\n",
      "time duration = 1.886, best val acc = 0.808, test acc = 0.810\n",
      "time duration = 2.433, best val acc = 0.804, test acc = 0.815\n",
      "time duration = 3.140, best val acc = 0.804, test acc = 0.815\n",
      "time duration = 1.840, best val acc = 0.800, test acc = 0.819\n",
      "time duration = 2.524, best val acc = 0.800, test acc = 0.816\n",
      "time duration = 1.910, best val acc = 0.802, test acc = 0.816\n",
      "time duration = 2.112, best val acc = 0.798, test acc = 0.809\n",
      "time duration = 1.857, best val acc = 0.806, test acc = 0.812\n",
      "test acc (mean, std):  0.8148000379403432 0.003636852872822477\n",
      "test acc (mean, std) after filter:  0.8146667033433914 0.0024438147842428272\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 = 2.927, best val acc = 0.730, test acc = 0.719\n",
      "time duration = 2.824, best val acc = 0.726, test acc = 0.715\n",
      "time duration = 3.220, best val acc = 0.732, test acc = 0.714\n",
      "time duration = 2.565, best val acc = 0.728, test acc = 0.712\n",
      "time duration = 3.346, best val acc = 0.724, test acc = 0.716\n",
      "time duration = 5.027, best val acc = 0.730, test acc = 0.715\n",
      "time duration = 2.592, best val acc = 0.730, test acc = 0.712\n",
      "time duration = 3.703, best val acc = 0.730, test acc = 0.722\n",
      "time duration = 2.930, best val acc = 0.726, test acc = 0.718\n",
      "time duration = 3.774, best val acc = 0.728, test acc = 0.717\n",
      "time duration = 2.802, best val acc = 0.724, test acc = 0.716\n",
      "time duration = 4.034, best val acc = 0.730, test acc = 0.718\n",
      "time duration = 2.679, best val acc = 0.732, test acc = 0.707\n",
      "time duration = 3.222, best val acc = 0.728, test acc = 0.712\n",
      "time duration = 3.385, best val acc = 0.730, test acc = 0.715\n",
      "time duration = 3.257, best val acc = 0.728, test acc = 0.711\n",
      "time duration = 3.049, best val acc = 0.732, test acc = 0.719\n",
      "time duration = 3.171, best val acc = 0.730, test acc = 0.719\n",
      "time duration = 3.869, best val acc = 0.724, test acc = 0.715\n",
      "time duration = 3.592, best val acc = 0.736, test acc = 0.714\n",
      "time duration = 3.270, best val acc = 0.732, test acc = 0.718\n",
      "time duration = 3.785, best val acc = 0.722, test acc = 0.711\n",
      "time duration = 3.268, best val acc = 0.734, test acc = 0.722\n",
      "time duration = 3.021, best val acc = 0.730, test acc = 0.713\n",
      "time duration = 3.741, best val acc = 0.726, test acc = 0.721\n",
      "time duration = 2.768, best val acc = 0.728, test acc = 0.710\n",
      "time duration = 4.150, best val acc = 0.726, test acc = 0.721\n",
      "time duration = 3.801, best val acc = 0.724, test acc = 0.717\n",
      "time duration = 4.146, best val acc = 0.728, test acc = 0.718\n",
      "time duration = 3.473, best val acc = 0.728, test acc = 0.715\n",
      "test acc (mean, std):  0.7157333672046662 0.0036600001874969204\n",
      "test acc (mean, std) after filter:  0.715791699786981 0.0026137366295371153\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 = 7.084, best val acc = 0.802, test acc = 0.785\n",
      "time duration = 7.149, best val acc = 0.802, test acc = 0.780\n",
      "time duration = 7.811, best val acc = 0.802, test acc = 0.788\n",
      "time duration = 5.747, best val acc = 0.800, test acc = 0.789\n",
      "time duration = 6.444, best val acc = 0.802, test acc = 0.792\n",
      "time duration = 6.204, best val acc = 0.798, test acc = 0.797\n",
      "time duration = 5.712, best val acc = 0.802, test acc = 0.788\n",
      "time duration = 6.038, best val acc = 0.802, test acc = 0.791\n",
      "time duration = 6.075, best val acc = 0.798, test acc = 0.791\n",
      "time duration = 5.862, best val acc = 0.800, test acc = 0.795\n",
      "time duration = 5.962, best val acc = 0.804, test acc = 0.795\n",
      "time duration = 6.035, best val acc = 0.800, test acc = 0.793\n",
      "time duration = 5.961, best val acc = 0.802, test acc = 0.793\n",
      "time duration = 5.938, best val acc = 0.804, test acc = 0.793\n",
      "time duration = 6.855, best val acc = 0.800, test acc = 0.787\n",
      "time duration = 5.720, best val acc = 0.800, test acc = 0.792\n",
      "time duration = 5.870, best val acc = 0.800, test acc = 0.797\n",
      "time duration = 5.660, best val acc = 0.800, test acc = 0.791\n",
      "time duration = 5.730, best val acc = 0.800, test acc = 0.784\n",
      "time duration = 10.343, best val acc = 0.800, test acc = 0.781\n",
      "time duration = 6.997, best val acc = 0.800, test acc = 0.799\n",
      "time duration = 5.845, best val acc = 0.804, test acc = 0.787\n",
      "time duration = 5.690, best val acc = 0.800, test acc = 0.791\n",
      "time duration = 5.577, best val acc = 0.798, test acc = 0.785\n",
      "time duration = 6.802, best val acc = 0.802, test acc = 0.796\n",
      "time duration = 5.592, best val acc = 0.802, test acc = 0.790\n",
      "time duration = 5.564, best val acc = 0.802, test acc = 0.789\n",
      "time duration = 5.556, best val acc = 0.804, test acc = 0.791\n",
      "time duration = 6.554, best val acc = 0.798, test acc = 0.790\n",
      "time duration = 5.713, best val acc = 0.802, test acc = 0.787\n",
      "test acc (mean, std):  0.7902333676815033 0.0044995070033525516\n",
      "test acc (mean, std) after filter:  0.7903750340143839 0.0029553951641085262\n",
      "\n",
      "start testing on Coauthor-CS dataset with random split: 0\n",
      "Downloading C:\\Users\\Nan Wu\\.dgl\\coauthor_cs.zip from https://data.dgl.ai/dataset/coauthor_cs.zip...\n",
      "Extracting file to C:\\Users\\Nan Wu\\.dgl\\coauthor_cs\n",
      "time duration = 19.666, best val acc = 0.889, test acc = 0.907\n",
      "time duration = 22.997, best val acc = 0.893, test acc = 0.901\n",
      "time duration = 27.965, best val acc = 0.889, test acc = 0.908\n",
      "time duration = 14.069, best val acc = 0.884, test acc = 0.904\n",
      "time duration = 20.137, best val acc = 0.887, test acc = 0.904\n",
      "time duration = 24.283, best val acc = 0.889, test acc = 0.905\n",
      "time duration = 22.667, best val acc = 0.887, test acc = 0.907\n",
      "time duration = 31.779, best val acc = 0.887, test acc = 0.905\n",
      "time duration = 14.720, best val acc = 0.891, test acc = 0.913\n",
      "time duration = 29.925, best val acc = 0.893, test acc = 0.904\n",
      "time duration = 19.476, best val acc = 0.887, test acc = 0.910\n",
      "time duration = 40.494, best val acc = 0.889, test acc = 0.910\n",
      "time duration = 25.615, best val acc = 0.889, test acc = 0.901\n",
      "time duration = 24.819, best val acc = 0.887, test acc = 0.904\n",
      "time duration = 21.773, best val acc = 0.891, test acc = 0.909\n",
      "time duration = 31.727, best val acc = 0.891, test acc = 0.905\n",
      "time duration = 31.456, best val acc = 0.889, test acc = 0.905\n",
      "time duration = 28.292, best val acc = 0.891, test acc = 0.911\n",
      "time duration = 29.196, best val acc = 0.884, test acc = 0.910\n",
      "time duration = 30.584, best val acc = 0.891, test acc = 0.908\n",
      "time duration = 27.627, best val acc = 0.896, test acc = 0.908\n",
      "time duration = 27.192, best val acc = 0.884, test acc = 0.905\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "time duration = 14.026, best val acc = 0.882, test acc = 0.910\n",
      "time duration = 13.606, best val acc = 0.887, test acc = 0.908\n",
      "time duration = 37.212, best val acc = 0.884, test acc = 0.907\n",
      "time duration = 17.395, best val acc = 0.891, test acc = 0.907\n",
      "time duration = 27.436, best val acc = 0.891, test acc = 0.910\n",
      "time duration = 15.654, best val acc = 0.887, test acc = 0.909\n",
      "time duration = 37.665, best val acc = 0.889, test acc = 0.904\n",
      "time duration = 32.111, best val acc = 0.889, test acc = 0.907\n",
      "test acc (mean, std):  0.9069214522838592 0.002847463365094095\n",
      "test acc (mean, std) after filter:  0.9070029730598131 0.0020441088519268444\n",
      "\n",
      "start testing on Coauthor-CS dataset with random split: 1\n",
      "time duration = 13.584, best val acc = 0.902, test acc = 0.904\n",
      "time duration = 12.289, best val acc = 0.902, test acc = 0.900\n",
      "time duration = 12.329, best val acc = 0.907, test acc = 0.908\n",
      "time duration = 15.086, best val acc = 0.907, test acc = 0.906\n",
      "time duration = 14.652, best val acc = 0.907, test acc = 0.902\n",
      "time duration = 12.571, best val acc = 0.898, test acc = 0.900\n",
      "time duration = 14.693, best val acc = 0.909, test acc = 0.901\n",
      "time duration = 15.398, best val acc = 0.900, test acc = 0.906\n",
      "time duration = 13.576, best val acc = 0.907, test acc = 0.903\n",
      "time duration = 12.376, best val acc = 0.904, test acc = 0.902\n",
      "time duration = 12.316, best val acc = 0.902, test acc = 0.910\n",
      "time duration = 18.435, best val acc = 0.907, test acc = 0.899\n",
      "time duration = 12.555, best val acc = 0.909, test acc = 0.901\n",
      "time duration = 12.426, best val acc = 0.900, test acc = 0.899\n",
      "time duration = 14.797, best val acc = 0.911, test acc = 0.909\n",
      "time duration = 21.489, best val acc = 0.904, test acc = 0.900\n",
      "time duration = 19.790, best val acc = 0.904, test acc = 0.903\n",
      "time duration = 12.402, best val acc = 0.904, test acc = 0.905\n",
      "time duration = 14.563, best val acc = 0.904, test acc = 0.903\n",
      "time duration = 14.904, best val acc = 0.907, test acc = 0.904\n",
      "time duration = 12.548, best val acc = 0.913, test acc = 0.900\n",
      "time duration = 12.479, best val acc = 0.909, test acc = 0.897\n",
      "time duration = 12.580, best val acc = 0.909, test acc = 0.895\n",
      "time duration = 14.861, best val acc = 0.900, test acc = 0.901\n",
      "time duration = 23.507, best val acc = 0.902, test acc = 0.900\n",
      "time duration = 14.426, best val acc = 0.904, test acc = 0.902\n",
      "time duration = 13.846, best val acc = 0.904, test acc = 0.906\n",
      "time duration = 12.317, best val acc = 0.913, test acc = 0.902\n",
      "time duration = 12.561, best val acc = 0.907, test acc = 0.901\n",
      "time duration = 20.745, best val acc = 0.909, test acc = 0.907\n",
      "test acc (mean, std):  0.9025403201580048 0.0034779939136533153\n",
      "test acc (mean, std) after filter:  0.9023962418238322 0.002290371733728758\n",
      "\n",
      "start testing on Coauthor-CS dataset with random split: 2\n",
      "time duration = 32.562, best val acc = 0.893, test acc = 0.890\n",
      "time duration = 29.965, best val acc = 0.893, test acc = 0.895\n",
      "time duration = 23.999, best val acc = 0.893, test acc = 0.894\n",
      "time duration = 17.961, best val acc = 0.891, test acc = 0.897\n",
      "time duration = 19.978, best val acc = 0.891, test acc = 0.901\n",
      "time duration = 14.275, best val acc = 0.889, test acc = 0.899\n",
      "time duration = 31.032, best val acc = 0.896, test acc = 0.896\n",
      "time duration = 26.095, best val acc = 0.893, test acc = 0.897\n",
      "time duration = 19.850, best val acc = 0.896, test acc = 0.896\n",
      "time duration = 23.020, best val acc = 0.898, test acc = 0.897\n",
      "time duration = 20.742, best val acc = 0.893, test acc = 0.900\n",
      "time duration = 21.589, best val acc = 0.891, test acc = 0.894\n",
      "time duration = 20.458, best val acc = 0.896, test acc = 0.899\n",
      "time duration = 21.922, best val acc = 0.893, test acc = 0.901\n",
      "time duration = 22.769, best val acc = 0.893, test acc = 0.900\n",
      "time duration = 17.169, best val acc = 0.893, test acc = 0.896\n",
      "time duration = 13.751, best val acc = 0.896, test acc = 0.894\n",
      "time duration = 21.819, best val acc = 0.891, test acc = 0.895\n",
      "time duration = 26.580, best val acc = 0.896, test acc = 0.895\n",
      "time duration = 30.074, best val acc = 0.893, test acc = 0.898\n",
      "time duration = 25.727, best val acc = 0.893, test acc = 0.900\n",
      "time duration = 20.616, best val acc = 0.891, test acc = 0.901\n",
      "time duration = 17.683, best val acc = 0.896, test acc = 0.893\n",
      "time duration = 26.133, best val acc = 0.893, test acc = 0.894\n",
      "time duration = 17.232, best val acc = 0.896, test acc = 0.897\n",
      "time duration = 28.019, best val acc = 0.891, test acc = 0.903\n",
      "time duration = 32.113, best val acc = 0.896, test acc = 0.892\n",
      "time duration = 18.001, best val acc = 0.896, test acc = 0.895\n",
      "time duration = 16.655, best val acc = 0.896, test acc = 0.897\n",
      "time duration = 36.185, best val acc = 0.898, test acc = 0.891\n",
      "test acc (mean, std):  0.8966217299302419 0.003187466362859539\n",
      "test acc (mean, std) after filter:  0.8966804966330528 0.0022819974935717278\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('acc_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
}
