{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "class config:\n",
    "    data = 'Cora' #choices=[\"Cora\", \"Citeseer\", \"Pubmed\", \"Coauthor-CS\"]\n",
    "    model = 'GTCN' #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.6\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 = '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 = 8.283, best val f1-macro = 0.811, test f1-macro = 0.816\n",
      "time duration = 8.858, best val f1-macro = 0.817, test f1-macro = 0.842\n",
      "time duration = 15.173, best val f1-macro = 0.819, test f1-macro = 0.821\n",
      "time duration = 19.765, best val f1-macro = 0.824, test f1-macro = 0.827\n",
      "time duration = 20.723, best val f1-macro = 0.833, test f1-macro = 0.834\n",
      "time duration = 13.574, best val f1-macro = 0.825, test f1-macro = 0.822\n",
      "time duration = 10.234, best val f1-macro = 0.819, test f1-macro = 0.834\n",
      "time duration = 9.485, best val f1-macro = 0.830, test f1-macro = 0.836\n",
      "time duration = 10.093, best val f1-macro = 0.821, test f1-macro = 0.834\n",
      "time duration = 14.508, best val f1-macro = 0.830, test f1-macro = 0.838\n",
      "time duration = 8.360, best val f1-macro = 0.823, test f1-macro = 0.831\n",
      "time duration = 7.027, best val f1-macro = 0.818, test f1-macro = 0.817\n",
      "time duration = 10.579, best val f1-macro = 0.819, test f1-macro = 0.824\n",
      "time duration = 5.638, best val f1-macro = 0.830, test f1-macro = 0.799\n",
      "time duration = 14.438, best val f1-macro = 0.817, test f1-macro = 0.828\n",
      "time duration = 11.132, best val f1-macro = 0.823, test f1-macro = 0.838\n",
      "time duration = 17.480, best val f1-macro = 0.829, test f1-macro = 0.833\n",
      "time duration = 6.030, best val f1-macro = 0.818, test f1-macro = 0.824\n",
      "time duration = 10.256, best val f1-macro = 0.827, test f1-macro = 0.844\n",
      "time duration = 11.301, best val f1-macro = 0.822, test f1-macro = 0.834\n",
      "time duration = 7.719, best val f1-macro = 0.820, test f1-macro = 0.825\n",
      "time duration = 18.836, best val f1-macro = 0.819, test f1-macro = 0.827\n",
      "time duration = 5.006, best val f1-macro = 0.822, test f1-macro = 0.804\n",
      "time duration = 17.836, best val f1-macro = 0.825, test f1-macro = 0.818\n",
      "time duration = 5.749, best val f1-macro = 0.811, test f1-macro = 0.810\n",
      "time duration = 8.474, best val f1-macro = 0.820, test f1-macro = 0.838\n",
      "time duration = 9.391, best val f1-macro = 0.821, test f1-macro = 0.837\n",
      "time duration = 19.511, best val f1-macro = 0.827, test f1-macro = 0.830\n",
      "time duration = 5.901, best val f1-macro = 0.820, test f1-macro = 0.822\n",
      "time duration = 7.435, best val f1-macro = 0.815, test f1-macro = 0.817\n",
      "test f1-macro (mean, std):  0.8267631159253163 0.010680184486197036\n",
      "test f1-macro (mean, std) after filter:  0.827753472537752 0.00691739774903441\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 = 8.970, best val f1-macro = 0.683, test f1-macro = 0.698\n",
      "time duration = 7.534, best val f1-macro = 0.705, test f1-macro = 0.689\n",
      "time duration = 9.944, best val f1-macro = 0.698, test f1-macro = 0.677\n",
      "time duration = 10.107, best val f1-macro = 0.696, test f1-macro = 0.689\n",
      "time duration = 10.840, best val f1-macro = 0.710, test f1-macro = 0.696\n",
      "time duration = 7.251, best val f1-macro = 0.712, test f1-macro = 0.704\n",
      "time duration = 7.958, best val f1-macro = 0.696, test f1-macro = 0.697\n",
      "time duration = 9.120, best val f1-macro = 0.705, test f1-macro = 0.699\n",
      "time duration = 8.744, best val f1-macro = 0.699, test f1-macro = 0.683\n",
      "time duration = 5.651, best val f1-macro = 0.706, test f1-macro = 0.684\n",
      "time duration = 7.929, best val f1-macro = 0.707, test f1-macro = 0.680\n",
      "time duration = 7.308, best val f1-macro = 0.695, test f1-macro = 0.687\n",
      "time duration = 8.614, best val f1-macro = 0.706, test f1-macro = 0.699\n",
      "time duration = 9.030, best val f1-macro = 0.693, test f1-macro = 0.689\n",
      "time duration = 10.158, best val f1-macro = 0.722, test f1-macro = 0.716\n",
      "time duration = 6.861, best val f1-macro = 0.713, test f1-macro = 0.696\n",
      "time duration = 7.487, best val f1-macro = 0.692, test f1-macro = 0.668\n",
      "time duration = 13.292, best val f1-macro = 0.695, test f1-macro = 0.684\n",
      "time duration = 5.565, best val f1-macro = 0.707, test f1-macro = 0.689\n",
      "time duration = 10.021, best val f1-macro = 0.699, test f1-macro = 0.688\n",
      "time duration = 6.448, best val f1-macro = 0.708, test f1-macro = 0.681\n",
      "time duration = 9.091, best val f1-macro = 0.700, test f1-macro = 0.704\n",
      "time duration = 7.638, best val f1-macro = 0.706, test f1-macro = 0.692\n",
      "time duration = 9.417, best val f1-macro = 0.701, test f1-macro = 0.711\n",
      "time duration = 8.840, best val f1-macro = 0.697, test f1-macro = 0.695\n",
      "time duration = 11.042, best val f1-macro = 0.706, test f1-macro = 0.678\n",
      "time duration = 6.493, best val f1-macro = 0.699, test f1-macro = 0.698\n",
      "time duration = 6.929, best val f1-macro = 0.703, test f1-macro = 0.686\n",
      "time duration = 7.470, best val f1-macro = 0.695, test f1-macro = 0.684\n",
      "time duration = 8.618, best val f1-macro = 0.714, test f1-macro = 0.693\n",
      "test f1-macro (mean, std):  0.6911481973925253 0.010182163878540066\n",
      "test f1-macro (mean, std) after filter:  0.6908169110617225 0.006413388875729617\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 = 10.242, best val f1-macro = 0.823, test f1-macro = 0.791\n",
      "time duration = 13.939, best val f1-macro = 0.827, test f1-macro = 0.792\n",
      "time duration = 13.221, best val f1-macro = 0.826, test f1-macro = 0.787\n",
      "time duration = 14.718, best val f1-macro = 0.824, test f1-macro = 0.787\n",
      "time duration = 12.563, best val f1-macro = 0.827, test f1-macro = 0.792\n",
      "time duration = 10.904, best val f1-macro = 0.823, test f1-macro = 0.794\n",
      "time duration = 17.204, best val f1-macro = 0.828, test f1-macro = 0.780\n",
      "time duration = 12.462, best val f1-macro = 0.829, test f1-macro = 0.788\n",
      "time duration = 22.320, best val f1-macro = 0.830, test f1-macro = 0.787\n",
      "time duration = 17.865, best val f1-macro = 0.826, test f1-macro = 0.787\n",
      "time duration = 24.238, best val f1-macro = 0.826, test f1-macro = 0.787\n",
      "time duration = 17.107, best val f1-macro = 0.827, test f1-macro = 0.795\n",
      "time duration = 14.175, best val f1-macro = 0.827, test f1-macro = 0.787\n",
      "time duration = 17.004, best val f1-macro = 0.825, test f1-macro = 0.791\n",
      "time duration = 21.374, best val f1-macro = 0.831, test f1-macro = 0.793\n",
      "time duration = 17.892, best val f1-macro = 0.830, test f1-macro = 0.790\n",
      "time duration = 12.038, best val f1-macro = 0.829, test f1-macro = 0.785\n",
      "time duration = 10.517, best val f1-macro = 0.823, test f1-macro = 0.791\n",
      "time duration = 12.237, best val f1-macro = 0.830, test f1-macro = 0.782\n",
      "time duration = 11.294, best val f1-macro = 0.831, test f1-macro = 0.794\n",
      "time duration = 8.341, best val f1-macro = 0.820, test f1-macro = 0.776\n",
      "time duration = 23.688, best val f1-macro = 0.829, test f1-macro = 0.793\n",
      "time duration = 10.394, best val f1-macro = 0.820, test f1-macro = 0.791\n",
      "time duration = 12.110, best val f1-macro = 0.830, test f1-macro = 0.785\n",
      "time duration = 14.381, best val f1-macro = 0.825, test f1-macro = 0.793\n",
      "time duration = 17.881, best val f1-macro = 0.832, test f1-macro = 0.784\n",
      "time duration = 10.207, best val f1-macro = 0.832, test f1-macro = 0.786\n",
      "time duration = 18.919, best val f1-macro = 0.827, test f1-macro = 0.790\n",
      "time duration = 14.228, best val f1-macro = 0.827, test f1-macro = 0.793\n",
      "time duration = 21.159, best val f1-macro = 0.832, test f1-macro = 0.787\n",
      "test f1-macro (mean, std):  0.788612230992979 0.004415397244037728\n",
      "test f1-macro (mean, std) after filter:  0.788992159756205 0.002866424014574188\n",
      "\n",
      "start testing on Coauthor-CS dataset with random split: 0\n",
      "time duration = 11.454, best val f1-macro = 0.928, test f1-macro = 0.906\n",
      "time duration = 16.497, best val f1-macro = 0.926, test f1-macro = 0.910\n",
      "time duration = 12.379, best val f1-macro = 0.928, test f1-macro = 0.907\n",
      "time duration = 15.073, best val f1-macro = 0.929, test f1-macro = 0.906\n",
      "time duration = 11.433, best val f1-macro = 0.927, test f1-macro = 0.906\n",
      "time duration = 14.628, best val f1-macro = 0.924, test f1-macro = 0.910\n",
      "time duration = 11.445, best val f1-macro = 0.926, test f1-macro = 0.902\n",
      "time duration = 16.692, best val f1-macro = 0.928, test f1-macro = 0.910\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "time duration = 21.718, best val f1-macro = 0.926, test f1-macro = 0.910\n",
      "time duration = 16.194, best val f1-macro = 0.924, test f1-macro = 0.908\n",
      "time duration = 18.350, best val f1-macro = 0.926, test f1-macro = 0.910\n",
      "time duration = 13.097, best val f1-macro = 0.931, test f1-macro = 0.911\n",
      "time duration = 11.994, best val f1-macro = 0.927, test f1-macro = 0.910\n",
      "time duration = 12.842, best val f1-macro = 0.927, test f1-macro = 0.910\n",
      "time duration = 11.252, best val f1-macro = 0.926, test f1-macro = 0.904\n",
      "time duration = 13.161, best val f1-macro = 0.924, test f1-macro = 0.907\n",
      "time duration = 13.015, best val f1-macro = 0.924, test f1-macro = 0.906\n",
      "time duration = 11.386, best val f1-macro = 0.929, test f1-macro = 0.904\n",
      "time duration = 11.135, best val f1-macro = 0.931, test f1-macro = 0.903\n",
      "time duration = 18.332, best val f1-macro = 0.929, test f1-macro = 0.903\n",
      "time duration = 30.600, best val f1-macro = 0.924, test f1-macro = 0.902\n",
      "time duration = 16.119, best val f1-macro = 0.929, test f1-macro = 0.902\n",
      "time duration = 12.396, best val f1-macro = 0.925, test f1-macro = 0.906\n",
      "time duration = 12.319, best val f1-macro = 0.927, test f1-macro = 0.905\n",
      "time duration = 12.925, best val f1-macro = 0.929, test f1-macro = 0.906\n",
      "time duration = 16.245, best val f1-macro = 0.931, test f1-macro = 0.902\n",
      "time duration = 27.813, best val f1-macro = 0.927, test f1-macro = 0.904\n",
      "time duration = 17.857, best val f1-macro = 0.929, test f1-macro = 0.907\n",
      "time duration = 16.809, best val f1-macro = 0.935, test f1-macro = 0.910\n",
      "time duration = 13.156, best val f1-macro = 0.929, test f1-macro = 0.903\n",
      "test f1-macro (mean, std):  0.9064269642882797 0.002924301802184635\n",
      "test f1-macro (mean, std) after filter:  0.9064426981742885 0.002434058379242872\n",
      "\n",
      "start testing on Coauthor-CS dataset with random split: 1\n",
      "time duration = 11.469, best val f1-macro = 0.935, test f1-macro = 0.907\n",
      "time duration = 11.851, best val f1-macro = 0.936, test f1-macro = 0.903\n",
      "time duration = 13.673, best val f1-macro = 0.934, test f1-macro = 0.909\n",
      "time duration = 21.533, best val f1-macro = 0.936, test f1-macro = 0.899\n",
      "time duration = 27.520, best val f1-macro = 0.934, test f1-macro = 0.902\n",
      "time duration = 24.739, best val f1-macro = 0.940, test f1-macro = 0.904\n",
      "time duration = 28.296, best val f1-macro = 0.942, test f1-macro = 0.904\n",
      "time duration = 14.016, best val f1-macro = 0.936, test f1-macro = 0.902\n",
      "time duration = 19.118, best val f1-macro = 0.940, test f1-macro = 0.904\n",
      "time duration = 16.670, best val f1-macro = 0.936, test f1-macro = 0.911\n",
      "time duration = 19.326, best val f1-macro = 0.942, test f1-macro = 0.905\n",
      "time duration = 18.857, best val f1-macro = 0.936, test f1-macro = 0.906\n",
      "time duration = 13.637, best val f1-macro = 0.938, test f1-macro = 0.906\n",
      "time duration = 36.121, best val f1-macro = 0.940, test f1-macro = 0.903\n",
      "time duration = 37.093, best val f1-macro = 0.936, test f1-macro = 0.905\n",
      "time duration = 11.633, best val f1-macro = 0.936, test f1-macro = 0.899\n",
      "time duration = 12.529, best val f1-macro = 0.945, test f1-macro = 0.910\n",
      "time duration = 14.703, best val f1-macro = 0.936, test f1-macro = 0.903\n",
      "time duration = 36.168, best val f1-macro = 0.938, test f1-macro = 0.904\n",
      "time duration = 23.979, best val f1-macro = 0.938, test f1-macro = 0.904\n",
      "time duration = 12.348, best val f1-macro = 0.938, test f1-macro = 0.904\n",
      "time duration = 14.530, best val f1-macro = 0.938, test f1-macro = 0.907\n",
      "time duration = 16.230, best val f1-macro = 0.936, test f1-macro = 0.907\n",
      "time duration = 14.263, best val f1-macro = 0.938, test f1-macro = 0.905\n",
      "time duration = 13.595, best val f1-macro = 0.934, test f1-macro = 0.909\n",
      "time duration = 15.033, best val f1-macro = 0.934, test f1-macro = 0.902\n",
      "time duration = 19.451, best val f1-macro = 0.938, test f1-macro = 0.905\n",
      "time duration = 11.540, best val f1-macro = 0.938, test f1-macro = 0.909\n",
      "time duration = 10.892, best val f1-macro = 0.936, test f1-macro = 0.904\n",
      "time duration = 13.323, best val f1-macro = 0.936, test f1-macro = 0.904\n",
      "test f1-macro (mean, std):  0.9048396691228107 0.0027906014025735463\n",
      "test f1-macro (mean, std) after filter:  0.904824805449412 0.001782544263514476\n",
      "\n",
      "start testing on Coauthor-CS dataset with random split: 2\n",
      "time duration = 19.078, best val f1-macro = 0.929, test f1-macro = 0.905\n",
      "time duration = 11.420, best val f1-macro = 0.927, test f1-macro = 0.904\n",
      "time duration = 16.276, best val f1-macro = 0.925, test f1-macro = 0.896\n",
      "time duration = 28.712, best val f1-macro = 0.932, test f1-macro = 0.906\n",
      "time duration = 23.055, best val f1-macro = 0.932, test f1-macro = 0.904\n",
      "time duration = 11.959, best val f1-macro = 0.928, test f1-macro = 0.898\n",
      "time duration = 17.640, best val f1-macro = 0.929, test f1-macro = 0.908\n",
      "time duration = 17.534, best val f1-macro = 0.925, test f1-macro = 0.900\n",
      "time duration = 14.200, best val f1-macro = 0.925, test f1-macro = 0.902\n",
      "time duration = 11.342, best val f1-macro = 0.927, test f1-macro = 0.899\n",
      "time duration = 15.842, best val f1-macro = 0.932, test f1-macro = 0.899\n",
      "time duration = 13.533, best val f1-macro = 0.929, test f1-macro = 0.909\n",
      "time duration = 26.678, best val f1-macro = 0.927, test f1-macro = 0.907\n",
      "time duration = 12.935, best val f1-macro = 0.932, test f1-macro = 0.897\n",
      "time duration = 23.981, best val f1-macro = 0.927, test f1-macro = 0.905\n",
      "time duration = 21.062, best val f1-macro = 0.930, test f1-macro = 0.902\n",
      "time duration = 20.273, best val f1-macro = 0.925, test f1-macro = 0.904\n",
      "time duration = 12.300, best val f1-macro = 0.930, test f1-macro = 0.901\n",
      "time duration = 28.922, best val f1-macro = 0.927, test f1-macro = 0.910\n",
      "time duration = 23.021, best val f1-macro = 0.930, test f1-macro = 0.900\n",
      "time duration = 27.103, best val f1-macro = 0.929, test f1-macro = 0.902\n",
      "time duration = 24.976, best val f1-macro = 0.927, test f1-macro = 0.903\n",
      "time duration = 24.545, best val f1-macro = 0.925, test f1-macro = 0.907\n",
      "time duration = 13.634, best val f1-macro = 0.934, test f1-macro = 0.900\n",
      "time duration = 17.299, best val f1-macro = 0.925, test f1-macro = 0.901\n",
      "time duration = 18.096, best val f1-macro = 0.930, test f1-macro = 0.899\n",
      "time duration = 22.462, best val f1-macro = 0.932, test f1-macro = 0.904\n",
      "time duration = 13.430, best val f1-macro = 0.929, test f1-macro = 0.902\n",
      "time duration = 13.691, best val f1-macro = 0.923, test f1-macro = 0.903\n",
      "time duration = 15.092, best val f1-macro = 0.932, test f1-macro = 0.902\n",
      "test f1-macro (mean, std):  0.9025705254463253 0.0034795277376479766\n",
      "test f1-macro (mean, std) after filter:  0.9024645169100985 0.002434032658070498\n"
     ]
    }
   ],
   "source": [
    "accs = []\n",
    "datasets = ['Cora', 'Citeseer', 'Pubmed', 'Coauthor-CS']\n",
    "for dataset in datasets:\n",
    "    args.data = dataset\n",
    "    if dataset == 'Cora':\n",
    "        args.dropout = 0.6\n",
    "        args.dropout2 = 0.6\n",
    "        args.weight_decay = 5e-4\n",
    "        args.learning_rate = 0.01\n",
    "        print('\\nstart testing on ' + dataset + ' dataset')\n",
    "        accs.append(main(args))\n",
    "    elif dataset == 'Citeseer':\n",
    "        args.dropout = 0.8\n",
    "        args.dropout2 = 0.6\n",
    "        args.weight_decay = 5e-4\n",
    "        args.learning_rate = 0.01\n",
    "        print('\\nstart testing on ' + dataset + ' dataset')\n",
    "        accs.append(main(args))\n",
    "    elif dataset == 'Pubmed':\n",
    "        args.dropout = 0.8\n",
    "        args.dropout2 = 0.5\n",
    "        args.weight_decay = 5e-4\n",
    "        args.learning_rate = 0.02\n",
    "        print('\\nstart testing on ' + dataset + ' dataset')\n",
    "        accs.append(main(args))\n",
    "    elif dataset == 'Coauthor-CS':\n",
    "        args.dropout = 0.6\n",
    "        args.dropout2 = 0.2\n",
    "        args.weight_decay = 5e-3\n",
    "        args.learning_rate = 0.01\n",
    "        for i in range(3):\n",
    "            print('\\nstart testing on ' + dataset + ' dataset with random split: ' + str(i))\n",
    "            args.test_id = i\n",
    "            accs.append(main(args))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "accs = np.array(accs)\n",
    "np.savetxt('log_f1_macro/f1-macro_GTCN_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
}
