{
 "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 = 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 = '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 = 14.785, best val acc = 0.744, test acc = 0.719\n",
      "time duration = 17.437, best val acc = 0.762, test acc = 0.740\n",
      "time duration = 24.357, best val acc = 0.740, test acc = 0.726\n",
      "time duration = 24.522, best val acc = 0.708, test acc = 0.716\n",
      "time duration = 29.596, best val acc = 0.734, test acc = 0.730\n",
      "time duration = 20.847, best val acc = 0.736, test acc = 0.702\n",
      "time duration = 22.666, best val acc = 0.706, test acc = 0.694\n",
      "time duration = 21.687, best val acc = 0.740, test acc = 0.751\n",
      "time duration = 29.133, best val acc = 0.758, test acc = 0.764\n",
      "time duration = 21.738, best val acc = 0.720, test acc = 0.709\n",
      "time duration = 17.600, best val acc = 0.744, test acc = 0.743\n",
      "time duration = 14.343, best val acc = 0.712, test acc = 0.705\n",
      "time duration = 28.939, best val acc = 0.730, test acc = 0.727\n",
      "time duration = 29.022, best val acc = 0.730, test acc = 0.702\n",
      "time duration = 29.076, best val acc = 0.738, test acc = 0.713\n",
      "time duration = 27.777, best val acc = 0.766, test acc = 0.761\n",
      "time duration = 28.021, best val acc = 0.716, test acc = 0.703\n",
      "time duration = 26.994, best val acc = 0.740, test acc = 0.749\n",
      "time duration = 20.925, best val acc = 0.726, test acc = 0.708\n",
      "time duration = 13.476, best val acc = 0.728, test acc = 0.713\n",
      "time duration = 15.602, best val acc = 0.746, test acc = 0.721\n",
      "time duration = 25.781, best val acc = 0.752, test acc = 0.736\n",
      "time duration = 18.286, best val acc = 0.750, test acc = 0.737\n",
      "time duration = 12.390, best val acc = 0.726, test acc = 0.713\n",
      "time duration = 14.461, best val acc = 0.754, test acc = 0.742\n",
      "time duration = 20.423, best val acc = 0.724, test acc = 0.724\n",
      "time duration = 23.674, best val acc = 0.768, test acc = 0.743\n",
      "time duration = 21.506, best val acc = 0.706, test acc = 0.715\n",
      "time duration = 17.376, best val acc = 0.700, test acc = 0.671\n",
      "time duration = 20.416, best val acc = 0.714, test acc = 0.721\n",
      "test acc (mean, std):  0.7232666989167531 0.020397609655274523\n",
      "test acc (mean, std) after filter:  0.7231250330805779 0.013827244357188758\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 = 30.626, best val acc = 0.638, test acc = 0.608\n",
      "time duration = 28.791, best val acc = 0.650, test acc = 0.608\n",
      "time duration = 15.487, best val acc = 0.594, test acc = 0.564\n",
      "time duration = 30.463, best val acc = 0.624, test acc = 0.601\n",
      "time duration = 30.453, best val acc = 0.628, test acc = 0.613\n",
      "time duration = 28.584, best val acc = 0.626, test acc = 0.586\n",
      "time duration = 32.453, best val acc = 0.630, test acc = 0.599\n",
      "time duration = 32.395, best val acc = 0.642, test acc = 0.622\n",
      "time duration = 22.304, best val acc = 0.626, test acc = 0.616\n",
      "time duration = 28.311, best val acc = 0.516, test acc = 0.516\n",
      "time duration = 19.925, best val acc = 0.632, test acc = 0.604\n",
      "time duration = 18.900, best val acc = 0.620, test acc = 0.588\n",
      "time duration = 17.050, best val acc = 0.580, test acc = 0.550\n",
      "time duration = 18.971, best val acc = 0.628, test acc = 0.583\n",
      "time duration = 25.581, best val acc = 0.614, test acc = 0.593\n",
      "time duration = 22.754, best val acc = 0.616, test acc = 0.561\n",
      "time duration = 26.092, best val acc = 0.632, test acc = 0.611\n",
      "time duration = 16.048, best val acc = 0.456, test acc = 0.425\n",
      "time duration = 21.290, best val acc = 0.606, test acc = 0.588\n",
      "time duration = 30.601, best val acc = 0.616, test acc = 0.572\n",
      "time duration = 16.154, best val acc = 0.538, test acc = 0.550\n",
      "time duration = 7.580, best val acc = 0.438, test acc = 0.411\n",
      "time duration = 22.036, best val acc = 0.614, test acc = 0.602\n",
      "time duration = 20.358, best val acc = 0.608, test acc = 0.590\n",
      "time duration = 18.303, best val acc = 0.640, test acc = 0.611\n",
      "time duration = 30.500, best val acc = 0.628, test acc = 0.605\n",
      "time duration = 22.491, best val acc = 0.578, test acc = 0.574\n",
      "time duration = 30.508, best val acc = 0.626, test acc = 0.603\n",
      "time duration = 24.784, best val acc = 0.604, test acc = 0.567\n",
      "time duration = 25.697, best val acc = 0.606, test acc = 0.602\n",
      "test acc (mean, std):  0.5774333596229553 0.048563148453667646\n",
      "test acc (mean, std) after filter:  0.5883333583672842 0.018765368113735588\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 = 36.863, best val acc = 0.784, test acc = 0.761\n",
      "time duration = 73.126, best val acc = 0.780, test acc = 0.764\n",
      "time duration = 27.571, best val acc = 0.806, test acc = 0.776\n",
      "time duration = 37.979, best val acc = 0.776, test acc = 0.750\n",
      "time duration = 33.409, best val acc = 0.798, test acc = 0.762\n",
      "time duration = 61.736, best val acc = 0.784, test acc = 0.765\n",
      "time duration = 30.474, best val acc = 0.708, test acc = 0.685\n",
      "time duration = 39.555, best val acc = 0.766, test acc = 0.735\n",
      "time duration = 43.341, best val acc = 0.788, test acc = 0.769\n",
      "time duration = 45.338, best val acc = 0.776, test acc = 0.747\n",
      "time duration = 51.310, best val acc = 0.778, test acc = 0.748\n",
      "time duration = 61.403, best val acc = 0.756, test acc = 0.757\n",
      "time duration = 49.441, best val acc = 0.778, test acc = 0.756\n",
      "time duration = 66.150, best val acc = 0.788, test acc = 0.769\n",
      "time duration = 67.619, best val acc = 0.784, test acc = 0.754\n",
      "time duration = 58.868, best val acc = 0.788, test acc = 0.772\n",
      "time duration = 93.298, best val acc = 0.766, test acc = 0.746\n",
      "time duration = 38.890, best val acc = 0.774, test acc = 0.742\n",
      "time duration = 36.573, best val acc = 0.766, test acc = 0.729\n",
      "time duration = 45.070, best val acc = 0.620, test acc = 0.625\n",
      "time duration = 69.902, best val acc = 0.770, test acc = 0.759\n",
      "time duration = 46.313, best val acc = 0.780, test acc = 0.758\n",
      "time duration = 40.520, best val acc = 0.772, test acc = 0.744\n",
      "time duration = 39.903, best val acc = 0.786, test acc = 0.756\n",
      "time duration = 50.315, best val acc = 0.786, test acc = 0.752\n",
      "time duration = 57.422, best val acc = 0.792, test acc = 0.762\n",
      "time duration = 72.250, best val acc = 0.790, test acc = 0.758\n",
      "time duration = 34.115, best val acc = 0.766, test acc = 0.734\n",
      "time duration = 41.292, best val acc = 0.780, test acc = 0.738\n",
      "time duration = 54.447, best val acc = 0.778, test acc = 0.751\n",
      "test acc (mean, std):  0.7474667012691498 0.02823441927862483\n",
      "test acc (mean, std) after filter:  0.7528333688775698 0.009361568296905473\n",
      "\n",
      "start testing on Coauthor-CS dataset with random split: 2\n",
      "time duration = 67.135, best val acc = 0.831, test acc = 0.842\n",
      "time duration = 62.277, best val acc = 0.824, test acc = 0.820\n",
      "time duration = 59.483, best val acc = 0.827, test acc = 0.819\n",
      "time duration = 53.337, best val acc = 0.820, test acc = 0.835\n",
      "time duration = 104.557, best val acc = 0.831, test acc = 0.829\n",
      "time duration = 71.380, best val acc = 0.831, test acc = 0.829\n",
      "time duration = 95.468, best val acc = 0.831, test acc = 0.837\n",
      "time duration = 52.690, best val acc = 0.836, test acc = 0.849\n",
      "time duration = 97.782, best val acc = 0.840, test acc = 0.838\n",
      "time duration = 76.427, best val acc = 0.838, test acc = 0.810\n",
      "time duration = 64.360, best val acc = 0.833, test acc = 0.835\n",
      "time duration = 79.562, best val acc = 0.840, test acc = 0.834\n",
      "time duration = 60.438, best val acc = 0.833, test acc = 0.836\n",
      "time duration = 133.688, best val acc = 0.833, test acc = 0.812\n",
      "time duration = 86.113, best val acc = 0.831, test acc = 0.833\n",
      "time duration = 114.447, best val acc = 0.838, test acc = 0.813\n",
      "time duration = 60.949, best val acc = 0.831, test acc = 0.844\n",
      "time duration = 93.219, best val acc = 0.827, test acc = 0.832\n",
      "time duration = 76.801, best val acc = 0.838, test acc = 0.820\n",
      "time duration = 80.414, best val acc = 0.822, test acc = 0.821\n",
      "time duration = 151.629, best val acc = 0.833, test acc = 0.819\n",
      "time duration = 93.085, best val acc = 0.827, test acc = 0.834\n",
      "time duration = 70.868, best val acc = 0.833, test acc = 0.830\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "time duration = 122.726, best val acc = 0.831, test acc = 0.819\n",
      "time duration = 68.173, best val acc = 0.836, test acc = 0.822\n",
      "time duration = 73.137, best val acc = 0.820, test acc = 0.843\n",
      "time duration = 55.544, best val acc = 0.842, test acc = 0.808\n",
      "time duration = 50.721, best val acc = 0.824, test acc = 0.827\n",
      "time duration = 110.572, best val acc = 0.838, test acc = 0.831\n",
      "time duration = 65.540, best val acc = 0.822, test acc = 0.836\n",
      "test acc (mean, std):  0.828535133600235 0.01052836781663588\n",
      "test acc (mean, std) after filter:  0.8287479355931282 0.007564786891800331\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_hop10.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
}
