{
 "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 = 5\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 = 4.387, best val acc = 0.808, test acc = 0.795\n",
      "time duration = 4.664, best val acc = 0.798, test acc = 0.772\n",
      "time duration = 3.716, best val acc = 0.788, test acc = 0.781\n",
      "time duration = 8.190, best val acc = 0.786, test acc = 0.794\n",
      "time duration = 3.844, best val acc = 0.780, test acc = 0.774\n",
      "time duration = 3.730, best val acc = 0.804, test acc = 0.804\n",
      "time duration = 3.924, best val acc = 0.782, test acc = 0.780\n",
      "time duration = 4.222, best val acc = 0.792, test acc = 0.788\n",
      "time duration = 3.657, best val acc = 0.788, test acc = 0.782\n",
      "time duration = 5.945, best val acc = 0.790, test acc = 0.778\n",
      "time duration = 6.985, best val acc = 0.788, test acc = 0.778\n",
      "time duration = 5.297, best val acc = 0.788, test acc = 0.793\n",
      "time duration = 5.741, best val acc = 0.762, test acc = 0.767\n",
      "time duration = 3.578, best val acc = 0.784, test acc = 0.781\n",
      "time duration = 6.918, best val acc = 0.780, test acc = 0.776\n",
      "time duration = 6.195, best val acc = 0.770, test acc = 0.782\n",
      "time duration = 3.629, best val acc = 0.790, test acc = 0.777\n",
      "time duration = 4.247, best val acc = 0.782, test acc = 0.769\n",
      "time duration = 4.912, best val acc = 0.778, test acc = 0.771\n",
      "time duration = 3.752, best val acc = 0.778, test acc = 0.786\n",
      "time duration = 7.736, best val acc = 0.788, test acc = 0.774\n",
      "time duration = 5.100, best val acc = 0.794, test acc = 0.783\n",
      "time duration = 3.768, best val acc = 0.784, test acc = 0.778\n",
      "time duration = 4.911, best val acc = 0.778, test acc = 0.770\n",
      "time duration = 3.455, best val acc = 0.774, test acc = 0.779\n",
      "time duration = 9.130, best val acc = 0.788, test acc = 0.782\n",
      "time duration = 4.417, best val acc = 0.784, test acc = 0.778\n",
      "time duration = 6.216, best val acc = 0.784, test acc = 0.790\n",
      "time duration = 3.500, best val acc = 0.790, test acc = 0.799\n",
      "time duration = 4.245, best val acc = 0.782, test acc = 0.782\n",
      "test acc (mean, std):  0.78143337170283 0.008834336109002111\n",
      "test acc (mean, std) after filter:  0.7807917073369026 0.00590183003123697\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 = 5.291, best val acc = 0.678, test acc = 0.652\n",
      "time duration = 5.171, best val acc = 0.648, test acc = 0.632\n",
      "time duration = 3.866, best val acc = 0.662, test acc = 0.655\n",
      "time duration = 4.148, best val acc = 0.672, test acc = 0.660\n",
      "time duration = 3.856, best val acc = 0.654, test acc = 0.649\n",
      "time duration = 7.241, best val acc = 0.662, test acc = 0.632\n",
      "time duration = 3.986, best val acc = 0.692, test acc = 0.689\n",
      "time duration = 3.925, best val acc = 0.646, test acc = 0.634\n",
      "time duration = 4.097, best val acc = 0.638, test acc = 0.631\n",
      "time duration = 3.911, best val acc = 0.670, test acc = 0.648\n",
      "time duration = 4.652, best val acc = 0.654, test acc = 0.652\n",
      "time duration = 5.187, best val acc = 0.644, test acc = 0.641\n",
      "time duration = 9.245, best val acc = 0.666, test acc = 0.661\n",
      "time duration = 4.000, best val acc = 0.684, test acc = 0.679\n",
      "time duration = 3.912, best val acc = 0.652, test acc = 0.640\n",
      "time duration = 7.166, best val acc = 0.656, test acc = 0.631\n",
      "time duration = 3.855, best val acc = 0.648, test acc = 0.656\n",
      "time duration = 5.406, best val acc = 0.652, test acc = 0.642\n",
      "time duration = 3.857, best val acc = 0.650, test acc = 0.644\n",
      "time duration = 4.502, best val acc = 0.666, test acc = 0.653\n",
      "time duration = 3.860, best val acc = 0.642, test acc = 0.641\n",
      "time duration = 9.421, best val acc = 0.640, test acc = 0.613\n",
      "time duration = 3.956, best val acc = 0.678, test acc = 0.665\n",
      "time duration = 4.847, best val acc = 0.656, test acc = 0.629\n",
      "time duration = 4.217, best val acc = 0.658, test acc = 0.653\n",
      "time duration = 13.206, best val acc = 0.660, test acc = 0.638\n",
      "time duration = 5.352, best val acc = 0.676, test acc = 0.653\n",
      "time duration = 3.827, best val acc = 0.690, test acc = 0.662\n",
      "time duration = 3.908, best val acc = 0.680, test acc = 0.660\n",
      "time duration = 3.839, best val acc = 0.662, test acc = 0.657\n",
      "test acc (mean, std):  0.6484000285466512 0.015348396336175326\n",
      "test acc (mean, std) after filter:  0.6477500299612681 0.009713608411043597\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 = 12.952, best val acc = 0.796, test acc = 0.769\n",
      "time duration = 13.620, best val acc = 0.794, test acc = 0.759\n",
      "time duration = 13.618, best val acc = 0.800, test acc = 0.765\n",
      "time duration = 12.964, best val acc = 0.798, test acc = 0.772\n",
      "time duration = 13.303, best val acc = 0.806, test acc = 0.774\n",
      "time duration = 13.266, best val acc = 0.794, test acc = 0.761\n",
      "time duration = 25.006, best val acc = 0.794, test acc = 0.758\n",
      "time duration = 13.769, best val acc = 0.798, test acc = 0.774\n",
      "time duration = 13.405, best val acc = 0.792, test acc = 0.755\n",
      "time duration = 12.999, best val acc = 0.796, test acc = 0.764\n",
      "time duration = 13.935, best val acc = 0.792, test acc = 0.767\n",
      "time duration = 24.771, best val acc = 0.800, test acc = 0.772\n",
      "time duration = 13.085, best val acc = 0.800, test acc = 0.768\n",
      "time duration = 13.029, best val acc = 0.782, test acc = 0.759\n",
      "time duration = 13.612, best val acc = 0.788, test acc = 0.757\n",
      "time duration = 12.769, best val acc = 0.810, test acc = 0.783\n",
      "time duration = 13.553, best val acc = 0.796, test acc = 0.759\n",
      "time duration = 13.111, best val acc = 0.800, test acc = 0.777\n",
      "time duration = 13.235, best val acc = 0.790, test acc = 0.778\n",
      "time duration = 15.063, best val acc = 0.786, test acc = 0.762\n",
      "time duration = 12.799, best val acc = 0.796, test acc = 0.761\n",
      "time duration = 13.577, best val acc = 0.800, test acc = 0.769\n",
      "time duration = 13.484, best val acc = 0.790, test acc = 0.775\n",
      "time duration = 13.123, best val acc = 0.790, test acc = 0.762\n",
      "time duration = 13.306, best val acc = 0.804, test acc = 0.766\n",
      "time duration = 13.729, best val acc = 0.796, test acc = 0.775\n",
      "time duration = 13.588, best val acc = 0.796, test acc = 0.780\n",
      "time duration = 13.257, best val acc = 0.782, test acc = 0.765\n",
      "time duration = 13.369, best val acc = 0.798, test acc = 0.768\n",
      "time duration = 13.353, best val acc = 0.802, test acc = 0.764\n",
      "test acc (mean, std):  0.767266704638799 0.007293525707628283\n",
      "test acc (mean, std) after filter:  0.7669583708047867 0.005503621303329274\n",
      "\n",
      "start testing on Coauthor-CS dataset with random split: 2\n",
      "time duration = 23.499, best val acc = 0.864, test acc = 0.873\n",
      "time duration = 33.709, best val acc = 0.858, test acc = 0.861\n",
      "time duration = 22.991, best val acc = 0.864, test acc = 0.883\n",
      "time duration = 25.099, best val acc = 0.858, test acc = 0.871\n",
      "time duration = 24.548, best val acc = 0.858, test acc = 0.854\n",
      "time duration = 35.707, best val acc = 0.862, test acc = 0.865\n",
      "time duration = 23.523, best val acc = 0.862, test acc = 0.867\n",
      "time duration = 23.915, best val acc = 0.860, test acc = 0.880\n",
      "time duration = 25.179, best val acc = 0.860, test acc = 0.861\n",
      "time duration = 24.134, best val acc = 0.873, test acc = 0.858\n",
      "time duration = 23.666, best val acc = 0.858, test acc = 0.876\n",
      "time duration = 24.461, best val acc = 0.858, test acc = 0.876\n",
      "time duration = 23.713, best val acc = 0.860, test acc = 0.877\n",
      "time duration = 22.765, best val acc = 0.853, test acc = 0.851\n",
      "time duration = 24.133, best val acc = 0.858, test acc = 0.858\n",
      "time duration = 39.117, best val acc = 0.860, test acc = 0.864\n",
      "time duration = 27.264, best val acc = 0.858, test acc = 0.864\n",
      "time duration = 42.624, best val acc = 0.860, test acc = 0.863\n",
      "time duration = 22.883, best val acc = 0.853, test acc = 0.876\n",
      "time duration = 23.623, best val acc = 0.860, test acc = 0.873\n",
      "time duration = 24.889, best val acc = 0.856, test acc = 0.869\n",
      "time duration = 25.923, best val acc = 0.858, test acc = 0.879\n",
      "time duration = 23.068, best val acc = 0.858, test acc = 0.875\n",
      "time duration = 26.005, best val acc = 0.858, test acc = 0.876\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "time duration = 23.060, best val acc = 0.867, test acc = 0.882\n",
      "time duration = 22.439, best val acc = 0.862, test acc = 0.876\n",
      "time duration = 23.780, best val acc = 0.871, test acc = 0.879\n",
      "time duration = 24.505, best val acc = 0.853, test acc = 0.873\n",
      "time duration = 23.076, best val acc = 0.853, test acc = 0.880\n",
      "time duration = 50.661, best val acc = 0.856, test acc = 0.860\n",
      "test acc (mean, std):  0.8700240691502888 0.008683582954097682\n",
      "test acc (mean, std) after filter:  0.8705354531606039 0.006673102499189789\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 [2]:\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_hop5.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
}
