{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "class config:\n",
    "    data = 'Cora' #choices=[\"Cora\", \"Citeseer\", \"Pubmed\", \"Coauthor-CS\"]\n",
    "    model = 'DAGNN' #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.8\n",
    "    dropout2 = 0.6\n",
    "    learning_rate = 0.01\n",
    "    weight_decay = 5e-3\n",
    "    patience = 100\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 = 3.587, best val f1-macro = 0.817, test f1-macro = 0.830\n",
      "time duration = 3.371, best val f1-macro = 0.805, test f1-macro = 0.823\n",
      "time duration = 4.999, best val f1-macro = 0.826, test f1-macro = 0.832\n",
      "time duration = 3.689, best val f1-macro = 0.812, test f1-macro = 0.834\n",
      "time duration = 4.981, best val f1-macro = 0.806, test f1-macro = 0.823\n",
      "time duration = 4.688, best val f1-macro = 0.821, test f1-macro = 0.823\n",
      "time duration = 5.238, best val f1-macro = 0.820, test f1-macro = 0.819\n",
      "time duration = 4.132, best val f1-macro = 0.822, test f1-macro = 0.817\n",
      "time duration = 4.478, best val f1-macro = 0.826, test f1-macro = 0.834\n",
      "time duration = 7.929, best val f1-macro = 0.821, test f1-macro = 0.831\n",
      "time duration = 3.357, best val f1-macro = 0.824, test f1-macro = 0.824\n",
      "time duration = 3.086, best val f1-macro = 0.809, test f1-macro = 0.831\n",
      "time duration = 3.718, best val f1-macro = 0.825, test f1-macro = 0.826\n",
      "time duration = 4.752, best val f1-macro = 0.819, test f1-macro = 0.834\n",
      "time duration = 5.697, best val f1-macro = 0.818, test f1-macro = 0.825\n",
      "time duration = 2.443, best val f1-macro = 0.815, test f1-macro = 0.822\n",
      "time duration = 5.891, best val f1-macro = 0.824, test f1-macro = 0.828\n",
      "time duration = 4.416, best val f1-macro = 0.822, test f1-macro = 0.821\n",
      "time duration = 3.015, best val f1-macro = 0.813, test f1-macro = 0.810\n",
      "time duration = 4.944, best val f1-macro = 0.817, test f1-macro = 0.809\n",
      "time duration = 3.470, best val f1-macro = 0.818, test f1-macro = 0.828\n",
      "time duration = 3.736, best val f1-macro = 0.816, test f1-macro = 0.831\n",
      "time duration = 2.949, best val f1-macro = 0.815, test f1-macro = 0.828\n",
      "time duration = 3.019, best val f1-macro = 0.812, test f1-macro = 0.822\n",
      "time duration = 4.297, best val f1-macro = 0.819, test f1-macro = 0.823\n",
      "time duration = 3.614, best val f1-macro = 0.815, test f1-macro = 0.822\n",
      "time duration = 2.240, best val f1-macro = 0.811, test f1-macro = 0.805\n",
      "time duration = 3.553, best val f1-macro = 0.808, test f1-macro = 0.822\n",
      "time duration = 5.299, best val f1-macro = 0.820, test f1-macro = 0.826\n",
      "time duration = 4.201, best val f1-macro = 0.823, test f1-macro = 0.832\n",
      "test f1-macro (mean, std):  0.8244943522607245 0.007136343323794572\n",
      "test f1-macro (mean, std) after filter:  0.8253477553876745 0.004222400421518602\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.792, best val f1-macro = 0.711, test f1-macro = 0.689\n",
      "time duration = 8.261, best val f1-macro = 0.717, test f1-macro = 0.683\n",
      "time duration = 6.346, best val f1-macro = 0.712, test f1-macro = 0.688\n",
      "time duration = 8.761, best val f1-macro = 0.712, test f1-macro = 0.691\n",
      "time duration = 6.387, best val f1-macro = 0.710, test f1-macro = 0.692\n",
      "time duration = 6.696, best val f1-macro = 0.713, test f1-macro = 0.682\n",
      "time duration = 7.884, best val f1-macro = 0.719, test f1-macro = 0.697\n",
      "time duration = 4.374, best val f1-macro = 0.708, test f1-macro = 0.697\n",
      "time duration = 9.453, best val f1-macro = 0.719, test f1-macro = 0.695\n",
      "time duration = 8.719, best val f1-macro = 0.715, test f1-macro = 0.685\n",
      "time duration = 4.934, best val f1-macro = 0.722, test f1-macro = 0.693\n",
      "time duration = 7.268, best val f1-macro = 0.709, test f1-macro = 0.677\n",
      "time duration = 5.296, best val f1-macro = 0.709, test f1-macro = 0.670\n",
      "time duration = 7.514, best val f1-macro = 0.713, test f1-macro = 0.694\n",
      "time duration = 5.288, best val f1-macro = 0.711, test f1-macro = 0.687\n",
      "time duration = 7.361, best val f1-macro = 0.714, test f1-macro = 0.690\n",
      "time duration = 4.787, best val f1-macro = 0.710, test f1-macro = 0.691\n",
      "time duration = 7.342, best val f1-macro = 0.707, test f1-macro = 0.689\n",
      "time duration = 6.884, best val f1-macro = 0.707, test f1-macro = 0.686\n",
      "time duration = 5.848, best val f1-macro = 0.707, test f1-macro = 0.686\n",
      "time duration = 7.010, best val f1-macro = 0.712, test f1-macro = 0.698\n",
      "time duration = 6.511, best val f1-macro = 0.720, test f1-macro = 0.688\n",
      "time duration = 9.715, best val f1-macro = 0.719, test f1-macro = 0.690\n",
      "time duration = 7.279, best val f1-macro = 0.711, test f1-macro = 0.680\n",
      "time duration = 5.860, best val f1-macro = 0.719, test f1-macro = 0.687\n",
      "time duration = 6.201, best val f1-macro = 0.707, test f1-macro = 0.686\n",
      "time duration = 7.172, best val f1-macro = 0.713, test f1-macro = 0.694\n",
      "time duration = 6.504, best val f1-macro = 0.711, test f1-macro = 0.688\n",
      "time duration = 6.030, best val f1-macro = 0.713, test f1-macro = 0.695\n",
      "time duration = 9.159, best val f1-macro = 0.718, test f1-macro = 0.690\n",
      "test f1-macro (mean, std):  0.6885221603168208 0.005985725980379877\n",
      "test f1-macro (mean, std) after filter:  0.6890518722198928 0.003424565269934076\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 = 4.082, best val f1-macro = 0.827, test f1-macro = 0.785\n",
      "time duration = 4.630, best val f1-macro = 0.824, test f1-macro = 0.790\n",
      "time duration = 3.782, best val f1-macro = 0.822, test f1-macro = 0.777\n",
      "time duration = 4.592, best val f1-macro = 0.828, test f1-macro = 0.790\n",
      "time duration = 6.412, best val f1-macro = 0.827, test f1-macro = 0.791\n",
      "time duration = 6.138, best val f1-macro = 0.829, test f1-macro = 0.792\n",
      "time duration = 4.005, best val f1-macro = 0.827, test f1-macro = 0.793\n",
      "time duration = 7.418, best val f1-macro = 0.823, test f1-macro = 0.783\n",
      "time duration = 3.964, best val f1-macro = 0.826, test f1-macro = 0.782\n",
      "time duration = 4.454, best val f1-macro = 0.829, test f1-macro = 0.790\n",
      "time duration = 3.652, best val f1-macro = 0.830, test f1-macro = 0.784\n",
      "time duration = 7.133, best val f1-macro = 0.823, test f1-macro = 0.789\n",
      "time duration = 3.998, best val f1-macro = 0.824, test f1-macro = 0.785\n",
      "time duration = 4.065, best val f1-macro = 0.832, test f1-macro = 0.782\n",
      "time duration = 4.466, best val f1-macro = 0.823, test f1-macro = 0.786\n",
      "time duration = 5.084, best val f1-macro = 0.828, test f1-macro = 0.792\n",
      "time duration = 5.540, best val f1-macro = 0.834, test f1-macro = 0.785\n",
      "time duration = 3.540, best val f1-macro = 0.825, test f1-macro = 0.779\n",
      "time duration = 4.119, best val f1-macro = 0.828, test f1-macro = 0.795\n",
      "time duration = 3.709, best val f1-macro = 0.823, test f1-macro = 0.793\n",
      "time duration = 4.555, best val f1-macro = 0.823, test f1-macro = 0.790\n",
      "time duration = 4.032, best val f1-macro = 0.820, test f1-macro = 0.784\n",
      "time duration = 4.371, best val f1-macro = 0.824, test f1-macro = 0.802\n",
      "time duration = 3.817, best val f1-macro = 0.825, test f1-macro = 0.791\n",
      "time duration = 3.942, best val f1-macro = 0.831, test f1-macro = 0.790\n",
      "time duration = 4.735, best val f1-macro = 0.826, test f1-macro = 0.788\n",
      "time duration = 3.873, best val f1-macro = 0.828, test f1-macro = 0.795\n",
      "time duration = 4.469, best val f1-macro = 0.823, test f1-macro = 0.789\n",
      "time duration = 5.657, best val f1-macro = 0.822, test f1-macro = 0.793\n",
      "time duration = 6.019, best val f1-macro = 0.830, test f1-macro = 0.791\n",
      "test f1-macro (mean, std):  0.7884960492598464 0.005249416798584788\n",
      "test f1-macro (mean, std) after filter:  0.7885657336736728 0.0033257016653393157\n",
      "\n",
      "start testing on Coauthor-CS dataset with random split: 0\n",
      "time duration = 12.820, best val f1-macro = 0.889, test f1-macro = 0.852\n",
      "time duration = 16.725, best val f1-macro = 0.893, test f1-macro = 0.864\n",
      "time duration = 9.936, best val f1-macro = 0.890, test f1-macro = 0.886\n",
      "time duration = 6.618, best val f1-macro = 0.887, test f1-macro = 0.867\n",
      "time duration = 8.506, best val f1-macro = 0.893, test f1-macro = 0.859\n",
      "time duration = 8.715, best val f1-macro = 0.899, test f1-macro = 0.884\n",
      "time duration = 6.962, best val f1-macro = 0.887, test f1-macro = 0.881\n",
      "time duration = 7.138, best val f1-macro = 0.893, test f1-macro = 0.874\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "time duration = 6.791, best val f1-macro = 0.893, test f1-macro = 0.875\n",
      "time duration = 9.374, best val f1-macro = 0.888, test f1-macro = 0.879\n",
      "time duration = 16.992, best val f1-macro = 0.894, test f1-macro = 0.883\n",
      "time duration = 10.280, best val f1-macro = 0.887, test f1-macro = 0.862\n",
      "time duration = 6.657, best val f1-macro = 0.888, test f1-macro = 0.849\n",
      "time duration = 12.465, best val f1-macro = 0.894, test f1-macro = 0.886\n",
      "time duration = 7.464, best val f1-macro = 0.884, test f1-macro = 0.871\n",
      "time duration = 8.141, best val f1-macro = 0.899, test f1-macro = 0.880\n",
      "time duration = 10.994, best val f1-macro = 0.896, test f1-macro = 0.884\n",
      "time duration = 11.903, best val f1-macro = 0.901, test f1-macro = 0.875\n",
      "time duration = 13.872, best val f1-macro = 0.897, test f1-macro = 0.865\n",
      "time duration = 7.584, best val f1-macro = 0.890, test f1-macro = 0.866\n",
      "time duration = 9.617, best val f1-macro = 0.898, test f1-macro = 0.871\n",
      "time duration = 9.752, best val f1-macro = 0.892, test f1-macro = 0.879\n",
      "time duration = 7.203, best val f1-macro = 0.886, test f1-macro = 0.871\n",
      "time duration = 11.769, best val f1-macro = 0.890, test f1-macro = 0.876\n",
      "time duration = 12.939, best val f1-macro = 0.888, test f1-macro = 0.886\n",
      "time duration = 11.254, best val f1-macro = 0.894, test f1-macro = 0.878\n",
      "time duration = 11.078, best val f1-macro = 0.894, test f1-macro = 0.885\n",
      "time duration = 6.119, best val f1-macro = 0.890, test f1-macro = 0.869\n",
      "time duration = 6.911, best val f1-macro = 0.895, test f1-macro = 0.874\n",
      "time duration = 15.580, best val f1-macro = 0.891, test f1-macro = 0.887\n",
      "test f1-macro (mean, std):  0.8739752441921718 0.009953274297830836\n",
      "test f1-macro (mean, std) after filter:  0.8749989916642811 0.006925424227420756\n",
      "\n",
      "start testing on Coauthor-CS dataset with random split: 1\n",
      "time duration = 6.015, best val f1-macro = 0.922, test f1-macro = 0.880\n",
      "time duration = 8.002, best val f1-macro = 0.916, test f1-macro = 0.880\n",
      "time duration = 17.056, best val f1-macro = 0.911, test f1-macro = 0.872\n",
      "time duration = 8.497, best val f1-macro = 0.913, test f1-macro = 0.885\n",
      "time duration = 8.763, best val f1-macro = 0.911, test f1-macro = 0.883\n",
      "time duration = 10.757, best val f1-macro = 0.915, test f1-macro = 0.867\n",
      "time duration = 10.686, best val f1-macro = 0.920, test f1-macro = 0.863\n",
      "time duration = 19.015, best val f1-macro = 0.908, test f1-macro = 0.861\n",
      "time duration = 10.893, best val f1-macro = 0.918, test f1-macro = 0.873\n",
      "time duration = 6.594, best val f1-macro = 0.913, test f1-macro = 0.874\n",
      "time duration = 10.296, best val f1-macro = 0.917, test f1-macro = 0.881\n",
      "time duration = 9.284, best val f1-macro = 0.920, test f1-macro = 0.880\n",
      "time duration = 6.601, best val f1-macro = 0.913, test f1-macro = 0.868\n",
      "time duration = 7.338, best val f1-macro = 0.909, test f1-macro = 0.884\n",
      "time duration = 11.348, best val f1-macro = 0.913, test f1-macro = 0.870\n",
      "time duration = 12.364, best val f1-macro = 0.917, test f1-macro = 0.874\n",
      "time duration = 7.634, best val f1-macro = 0.913, test f1-macro = 0.873\n",
      "time duration = 14.267, best val f1-macro = 0.917, test f1-macro = 0.868\n",
      "time duration = 8.284, best val f1-macro = 0.911, test f1-macro = 0.873\n",
      "time duration = 10.158, best val f1-macro = 0.918, test f1-macro = 0.879\n",
      "time duration = 9.786, best val f1-macro = 0.923, test f1-macro = 0.872\n",
      "time duration = 10.288, best val f1-macro = 0.915, test f1-macro = 0.871\n",
      "time duration = 7.268, best val f1-macro = 0.908, test f1-macro = 0.860\n",
      "time duration = 7.111, best val f1-macro = 0.917, test f1-macro = 0.876\n",
      "time duration = 10.199, best val f1-macro = 0.915, test f1-macro = 0.881\n",
      "time duration = 8.317, best val f1-macro = 0.918, test f1-macro = 0.876\n",
      "time duration = 13.087, best val f1-macro = 0.923, test f1-macro = 0.873\n",
      "time duration = 7.489, best val f1-macro = 0.920, test f1-macro = 0.879\n",
      "time duration = 9.992, best val f1-macro = 0.911, test f1-macro = 0.862\n",
      "time duration = 6.424, best val f1-macro = 0.917, test f1-macro = 0.868\n",
      "test f1-macro (mean, std):  0.8735987416737374 0.006759068724773899\n",
      "test f1-macro (mean, std) after filter:  0.8738821544305336 0.00487728639735832\n",
      "\n",
      "start testing on Coauthor-CS dataset with random split: 2\n",
      "time duration = 9.746, best val f1-macro = 0.894, test f1-macro = 0.866\n",
      "time duration = 9.633, best val f1-macro = 0.897, test f1-macro = 0.858\n",
      "time duration = 7.089, best val f1-macro = 0.901, test f1-macro = 0.870\n",
      "time duration = 7.101, best val f1-macro = 0.905, test f1-macro = 0.876\n",
      "time duration = 7.586, best val f1-macro = 0.901, test f1-macro = 0.869\n",
      "time duration = 8.060, best val f1-macro = 0.895, test f1-macro = 0.866\n",
      "time duration = 9.069, best val f1-macro = 0.901, test f1-macro = 0.872\n",
      "time duration = 6.890, best val f1-macro = 0.898, test f1-macro = 0.875\n",
      "time duration = 7.416, best val f1-macro = 0.898, test f1-macro = 0.863\n",
      "time duration = 9.997, best val f1-macro = 0.894, test f1-macro = 0.857\n",
      "time duration = 13.494, best val f1-macro = 0.890, test f1-macro = 0.867\n",
      "time duration = 10.969, best val f1-macro = 0.894, test f1-macro = 0.868\n",
      "time duration = 8.119, best val f1-macro = 0.892, test f1-macro = 0.874\n",
      "time duration = 6.594, best val f1-macro = 0.894, test f1-macro = 0.867\n",
      "time duration = 7.316, best val f1-macro = 0.896, test f1-macro = 0.874\n",
      "time duration = 11.678, best val f1-macro = 0.894, test f1-macro = 0.864\n",
      "time duration = 6.454, best val f1-macro = 0.907, test f1-macro = 0.879\n",
      "time duration = 7.354, best val f1-macro = 0.893, test f1-macro = 0.846\n",
      "time duration = 7.915, best val f1-macro = 0.897, test f1-macro = 0.849\n",
      "time duration = 6.909, best val f1-macro = 0.904, test f1-macro = 0.862\n",
      "time duration = 9.640, best val f1-macro = 0.898, test f1-macro = 0.862\n",
      "time duration = 8.297, best val f1-macro = 0.899, test f1-macro = 0.871\n",
      "time duration = 10.701, best val f1-macro = 0.893, test f1-macro = 0.879\n",
      "time duration = 6.593, best val f1-macro = 0.890, test f1-macro = 0.866\n",
      "time duration = 12.576, best val f1-macro = 0.902, test f1-macro = 0.872\n",
      "time duration = 7.441, best val f1-macro = 0.902, test f1-macro = 0.878\n",
      "time duration = 11.266, best val f1-macro = 0.891, test f1-macro = 0.865\n",
      "time duration = 10.537, best val f1-macro = 0.896, test f1-macro = 0.872\n",
      "time duration = 12.264, best val f1-macro = 0.899, test f1-macro = 0.872\n",
      "time duration = 7.274, best val f1-macro = 0.893, test f1-macro = 0.874\n",
      "test f1-macro (mean, std):  0.8678346142671093 0.00786389391429703\n",
      "test f1-macro (mean, std) after filter:  0.8686092864659223 0.004693132334052769\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",
    "        if dataset == 'Citeseer':\n",
    "            args.dropout = 0.5\n",
    "            args.weight_decay = 0.02\n",
    "        else:\n",
    "            args.dropout = 0.8\n",
    "            args.weight_decay = 0.005\n",
    "        print('\\nstart testing on ' + dataset + ' dataset')\n",
    "        accs.append(main(args))\n",
    "    else:\n",
    "        args.dropout = 0.8\n",
    "        args.weight_decay = 0.005\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_DAGNN.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
}
