{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Using backend: pytorch\n"
     ]
    }
   ],
   "source": [
    "from train_ogbn_arxiv import main"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "class config:\n",
    "    model = 'GTAN' #choices=[\"GCN\", \"GAT\", \"APPNP\", \"DAGNN\", \"TreeLSTM\", \"GTCN\", \"GTAN\", \"GTCN2\"]\n",
    "    n_hid = 128\n",
    "    num_heads = 1\n",
    "    num_out_heads = 1\n",
    "    dropout = 0.2\n",
    "    dropout2 = 0\n",
    "    learning_rate = 0.01\n",
    "    weight_decay = 5e-5\n",
    "    num_iter = 1000\n",
    "    num_test = 10\n",
    "    hop = 4\n",
    "    alpha = 0.1 # used by APPNP only\n",
    "    eval_metric = 'acc'\n",
    "    log_steps = 100\n",
    "\n",
    "args = config()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "#Parameters: 38440\n",
      "Run: 01, Time elapsed: 62.89, Epoch: 100, Loss: 0.9397, Train: 72.43%, Valid: 71.31% Test: 70.28%\n",
      "Run: 01, Time elapsed: 61.96, Epoch: 200, Loss: 0.8764, Train: 74.21%, Valid: 72.64% Test: 71.63%\n",
      "Run: 01, Time elapsed: 61.96, Epoch: 300, Loss: 0.8370, Train: 75.22%, Valid: 72.36% Test: 70.54%\n",
      "Run: 01, Time elapsed: 61.94, Epoch: 400, Loss: 0.8149, Train: 76.02%, Valid: 73.14% Test: 72.06%\n",
      "Run: 01, Time elapsed: 61.99, Epoch: 500, Loss: 0.7932, Train: 76.73%, Valid: 73.38% Test: 72.25%\n",
      "Run: 01, Time elapsed: 61.94, Epoch: 600, Loss: 0.7803, Train: 77.05%, Valid: 73.05% Test: 71.44%\n",
      "Run: 01, Time elapsed: 61.98, Epoch: 700, Loss: 0.7723, Train: 77.31%, Valid: 72.69% Test: 70.99%\n",
      "Run: 01, Time elapsed: 61.98, Epoch: 800, Loss: 0.7594, Train: 77.48%, Valid: 73.27% Test: 71.89%\n",
      "Run: 01, Time elapsed: 61.96, Epoch: 900, Loss: 0.7516, Train: 78.01%, Valid: 73.50% Test: 71.95%\n",
      "Run: 01, Time elapsed: 61.98, Epoch: 1000, Loss: 0.7494, Train: 78.12%, Valid: 73.28% Test: 71.77%\n",
      "Run 01:\n",
      "Highest Train: 78.22\n",
      "Highest Valid: 73.66\n",
      "  Final Train: 78.00\n",
      "   Final Test: 72.99\n",
      "Run: 02, Time elapsed: 62.23, Epoch: 100, Loss: 0.9981, Train: 70.81%, Valid: 69.96% Test: 68.61%\n",
      "Run: 02, Time elapsed: 61.93, Epoch: 200, Loss: 0.9205, Train: 72.91%, Valid: 71.30% Test: 69.89%\n",
      "Run: 02, Time elapsed: 61.99, Epoch: 300, Loss: 0.8827, Train: 74.02%, Valid: 71.92% Test: 70.54%\n",
      "Run: 02, Time elapsed: 61.96, Epoch: 400, Loss: 0.8509, Train: 74.82%, Valid: 72.81% Test: 71.64%\n",
      "Run: 02, Time elapsed: 61.99, Epoch: 500, Loss: 0.8358, Train: 75.42%, Valid: 73.01% Test: 71.96%\n",
      "Run: 02, Time elapsed: 61.95, Epoch: 600, Loss: 0.8182, Train: 75.86%, Valid: 72.69% Test: 71.35%\n",
      "Run: 02, Time elapsed: 61.96, Epoch: 700, Loss: 0.8111, Train: 75.83%, Valid: 71.05% Test: 68.38%\n",
      "Run: 02, Time elapsed: 61.98, Epoch: 800, Loss: 0.7933, Train: 76.57%, Valid: 72.96% Test: 71.62%\n",
      "Run: 02, Time elapsed: 62.38, Epoch: 900, Loss: 0.7846, Train: 76.87%, Valid: 72.52% Test: 70.73%\n",
      "Run: 02, Time elapsed: 61.96, Epoch: 1000, Loss: 0.7774, Train: 77.24%, Valid: 73.25% Test: 72.12%\n",
      "Run 02:\n",
      "Highest Train: 77.26\n",
      "Highest Valid: 73.58\n",
      "  Final Train: 77.11\n",
      "   Final Test: 72.71\n",
      "Run: 03, Time elapsed: 62.50, Epoch: 100, Loss: 0.9572, Train: 71.94%, Valid: 70.81% Test: 69.75%\n",
      "Run: 03, Time elapsed: 62.00, Epoch: 200, Loss: 0.8896, Train: 73.82%, Valid: 71.97% Test: 70.61%\n",
      "Run: 03, Time elapsed: 61.96, Epoch: 300, Loss: 0.8523, Train: 74.82%, Valid: 72.24% Test: 70.70%\n",
      "Run: 03, Time elapsed: 61.96, Epoch: 400, Loss: 0.8291, Train: 75.53%, Valid: 72.36% Test: 70.62%\n",
      "Run: 03, Time elapsed: 61.94, Epoch: 500, Loss: 0.8074, Train: 76.16%, Valid: 73.20% Test: 71.91%\n",
      "Run: 03, Time elapsed: 61.97, Epoch: 600, Loss: 0.8030, Train: 76.52%, Valid: 73.16% Test: 71.58%\n",
      "Run: 03, Time elapsed: 62.33, Epoch: 700, Loss: 0.7867, Train: 76.94%, Valid: 73.30% Test: 72.52%\n",
      "Run: 03, Time elapsed: 62.74, Epoch: 800, Loss: 0.7744, Train: 77.09%, Valid: 72.86% Test: 71.15%\n",
      "Run: 03, Time elapsed: 62.28, Epoch: 900, Loss: 0.7659, Train: 77.46%, Valid: 72.94% Test: 71.23%\n",
      "Run: 03, Time elapsed: 63.03, Epoch: 1000, Loss: 0.7612, Train: 77.65%, Valid: 73.28% Test: 72.20%\n",
      "Run 03:\n",
      "Highest Train: 77.82\n",
      "Highest Valid: 73.56\n",
      "  Final Train: 77.48\n",
      "   Final Test: 72.47\n",
      "Run: 04, Time elapsed: 63.11, Epoch: 100, Loss: 0.9211, Train: 72.84%, Valid: 71.29% Test: 69.95%\n",
      "Run: 04, Time elapsed: 62.26, Epoch: 200, Loss: 0.8601, Train: 74.80%, Valid: 72.72% Test: 72.06%\n",
      "Run: 04, Time elapsed: 62.18, Epoch: 300, Loss: 0.8253, Train: 75.78%, Valid: 73.05% Test: 72.28%\n",
      "Run: 04, Time elapsed: 61.96, Epoch: 400, Loss: 0.7991, Train: 76.44%, Valid: 73.20% Test: 71.82%\n",
      "Run: 04, Time elapsed: 62.48, Epoch: 500, Loss: 0.7890, Train: 76.84%, Valid: 73.46% Test: 72.72%\n",
      "Run: 04, Time elapsed: 62.26, Epoch: 600, Loss: 0.7728, Train: 77.33%, Valid: 73.61% Test: 72.73%\n",
      "Run: 04, Time elapsed: 62.99, Epoch: 700, Loss: 0.7615, Train: 77.56%, Valid: 72.72% Test: 70.94%\n",
      "Run: 04, Time elapsed: 62.72, Epoch: 800, Loss: 0.7598, Train: 77.85%, Valid: 72.74% Test: 70.69%\n",
      "Run: 04, Time elapsed: 62.46, Epoch: 900, Loss: 0.7498, Train: 78.04%, Valid: 73.46% Test: 71.73%\n",
      "Run: 04, Time elapsed: 62.20, Epoch: 1000, Loss: 0.7467, Train: 78.19%, Valid: 73.20% Test: 71.77%\n",
      "Run 04:\n",
      "Highest Train: 78.48\n",
      "Highest Valid: 73.70\n",
      "  Final Train: 77.44\n",
      "   Final Test: 72.73\n",
      "Run: 05, Time elapsed: 62.70, Epoch: 100, Loss: 0.9547, Train: 72.01%, Valid: 71.10% Test: 69.90%\n",
      "Run: 05, Time elapsed: 62.72, Epoch: 200, Loss: 0.8848, Train: 73.91%, Valid: 72.28% Test: 71.16%\n",
      "Run: 05, Time elapsed: 62.80, Epoch: 300, Loss: 0.8504, Train: 74.97%, Valid: 72.51% Test: 71.28%\n",
      "Run: 05, Time elapsed: 62.13, Epoch: 400, Loss: 0.8263, Train: 75.67%, Valid: 72.57% Test: 71.14%\n",
      "Run: 05, Time elapsed: 62.07, Epoch: 500, Loss: 0.8076, Train: 76.19%, Valid: 73.10% Test: 72.28%\n",
      "Run: 05, Time elapsed: 62.11, Epoch: 600, Loss: 0.7985, Train: 76.58%, Valid: 73.01% Test: 72.00%\n",
      "Run: 05, Time elapsed: 62.14, Epoch: 700, Loss: 0.7781, Train: 76.99%, Valid: 73.20% Test: 71.94%\n",
      "Run: 05, Time elapsed: 61.92, Epoch: 800, Loss: 0.7651, Train: 77.24%, Valid: 73.13% Test: 71.26%\n",
      "Run: 05, Time elapsed: 62.00, Epoch: 900, Loss: 0.7705, Train: 77.46%, Valid: 72.43% Test: 70.42%\n",
      "Run: 05, Time elapsed: 61.95, Epoch: 1000, Loss: 0.7519, Train: 77.88%, Valid: 73.29% Test: 72.06%\n",
      "Run 05:\n",
      "Highest Train: 77.89\n",
      "Highest Valid: 73.62\n",
      "  Final Train: 77.67\n",
      "   Final Test: 72.47\n",
      "Run: 06, Time elapsed: 62.74, Epoch: 100, Loss: 0.9388, Train: 72.50%, Valid: 71.44% Test: 70.24%\n",
      "Run: 06, Time elapsed: 62.27, Epoch: 200, Loss: 0.8706, Train: 74.31%, Valid: 72.44% Test: 71.42%\n",
      "Run: 06, Time elapsed: 62.01, Epoch: 300, Loss: 0.8362, Train: 75.29%, Valid: 72.97% Test: 71.92%\n",
      "Run: 06, Time elapsed: 62.57, Epoch: 400, Loss: 0.8154, Train: 76.06%, Valid: 73.08% Test: 72.17%\n",
      "Run: 06, Time elapsed: 62.59, Epoch: 500, Loss: 0.7963, Train: 76.54%, Valid: 72.51% Test: 71.15%\n",
      "Run: 06, Time elapsed: 62.30, Epoch: 600, Loss: 0.7792, Train: 76.97%, Valid: 73.22% Test: 72.63%\n",
      "Run: 06, Time elapsed: 62.07, Epoch: 700, Loss: 0.7752, Train: 77.24%, Valid: 72.55% Test: 70.99%\n",
      "Run: 06, Time elapsed: 62.43, Epoch: 800, Loss: 0.7602, Train: 77.59%, Valid: 73.24% Test: 71.92%\n",
      "Run: 06, Time elapsed: 62.27, Epoch: 900, Loss: 0.7567, Train: 77.45%, Valid: 71.77% Test: 69.37%\n",
      "Run: 06, Time elapsed: 61.93, Epoch: 1000, Loss: 0.7467, Train: 78.10%, Valid: 73.37% Test: 72.68%\n",
      "Run 06:\n",
      "Highest Train: 78.14\n",
      "Highest Valid: 73.57\n",
      "  Final Train: 78.00\n",
      "   Final Test: 72.74\n",
      "Run: 07, Time elapsed: 62.34, Epoch: 100, Loss: 0.9723, Train: 71.76%, Valid: 70.63% Test: 69.26%\n",
      "Run: 07, Time elapsed: 62.19, Epoch: 200, Loss: 0.8951, Train: 73.69%, Valid: 72.05% Test: 70.56%\n",
      "Run: 07, Time elapsed: 62.31, Epoch: 300, Loss: 0.8598, Train: 74.70%, Valid: 72.29% Test: 70.74%\n",
      "Run: 07, Time elapsed: 62.08, Epoch: 400, Loss: 0.8342, Train: 75.41%, Valid: 72.63% Test: 70.86%\n",
      "Run: 07, Time elapsed: 62.23, Epoch: 500, Loss: 0.8171, Train: 75.93%, Valid: 72.60% Test: 70.94%\n",
      "Run: 07, Time elapsed: 62.32, Epoch: 600, Loss: 0.8019, Train: 76.23%, Valid: 72.85% Test: 71.43%\n",
      "Run: 07, Time elapsed: 62.41, Epoch: 700, Loss: 0.7910, Train: 76.77%, Valid: 73.15% Test: 71.66%\n",
      "Run: 07, Time elapsed: 62.11, Epoch: 800, Loss: 0.7790, Train: 77.05%, Valid: 72.86% Test: 71.16%\n",
      "Run: 07, Time elapsed: 62.12, Epoch: 900, Loss: 0.7720, Train: 76.99%, Valid: 73.19% Test: 71.97%\n",
      "Run: 07, Time elapsed: 62.61, Epoch: 1000, Loss: 0.7599, Train: 77.31%, Valid: 72.23% Test: 69.79%\n",
      "Run 07:\n",
      "Highest Train: 77.61\n",
      "Highest Valid: 73.68\n",
      "  Final Train: 77.54\n",
      "   Final Test: 72.64\n",
      "Run: 08, Time elapsed: 62.48, Epoch: 100, Loss: 0.9285, Train: 72.71%, Valid: 71.32% Test: 69.84%\n",
      "Run: 08, Time elapsed: 62.29, Epoch: 200, Loss: 0.8641, Train: 74.65%, Valid: 72.61% Test: 72.03%\n",
      "Run: 08, Time elapsed: 62.55, Epoch: 300, Loss: 0.8258, Train: 75.63%, Valid: 72.89% Test: 71.73%\n",
      "Run: 08, Time elapsed: 62.94, Epoch: 400, Loss: 0.8076, Train: 75.88%, Valid: 73.05% Test: 72.56%\n",
      "Run: 08, Time elapsed: 63.00, Epoch: 500, Loss: 0.7899, Train: 76.77%, Valid: 73.13% Test: 72.21%\n",
      "Run: 08, Time elapsed: 62.78, Epoch: 600, Loss: 0.7746, Train: 77.22%, Valid: 73.51% Test: 72.30%\n",
      "Run: 08, Time elapsed: 62.50, Epoch: 700, Loss: 0.7638, Train: 77.55%, Valid: 72.97% Test: 71.36%\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run: 08, Time elapsed: 62.83, Epoch: 800, Loss: 0.7543, Train: 77.85%, Valid: 73.37% Test: 72.31%\n",
      "Run: 08, Time elapsed: 62.72, Epoch: 900, Loss: 0.7460, Train: 78.07%, Valid: 73.11% Test: 71.60%\n",
      "Run: 08, Time elapsed: 63.00, Epoch: 1000, Loss: 0.7425, Train: 78.29%, Valid: 73.04% Test: 71.69%\n",
      "Run 08:\n",
      "Highest Train: 78.32\n",
      "Highest Valid: 73.73\n",
      "  Final Train: 77.82\n",
      "   Final Test: 72.84\n",
      "Run: 09, Time elapsed: 62.33, Epoch: 100, Loss: 0.9320, Train: 72.57%, Valid: 71.41% Test: 70.15%\n",
      "Run: 09, Time elapsed: 62.13, Epoch: 200, Loss: 0.8664, Train: 74.29%, Valid: 71.61% Test: 69.89%\n",
      "Run: 09, Time elapsed: 63.34, Epoch: 300, Loss: 0.8332, Train: 75.52%, Valid: 72.55% Test: 71.18%\n",
      "Run: 09, Time elapsed: 63.34, Epoch: 400, Loss: 0.8089, Train: 76.17%, Valid: 72.92% Test: 71.44%\n",
      "Run: 09, Time elapsed: 61.98, Epoch: 500, Loss: 0.7887, Train: 76.67%, Valid: 73.45% Test: 72.19%\n",
      "Run: 09, Time elapsed: 62.02, Epoch: 600, Loss: 0.7774, Train: 76.94%, Valid: 73.03% Test: 71.49%\n",
      "Run: 09, Time elapsed: 62.01, Epoch: 700, Loss: 0.7655, Train: 77.46%, Valid: 73.75% Test: 72.63%\n",
      "Run: 09, Time elapsed: 62.04, Epoch: 800, Loss: 0.7609, Train: 77.53%, Valid: 73.20% Test: 71.53%\n",
      "Run: 09, Time elapsed: 62.00, Epoch: 900, Loss: 0.7464, Train: 77.93%, Valid: 73.16% Test: 71.71%\n",
      "Run: 09, Time elapsed: 62.03, Epoch: 1000, Loss: 0.7459, Train: 78.19%, Valid: 72.34% Test: 70.15%\n",
      "Run 09:\n",
      "Highest Train: 78.26\n",
      "Highest Valid: 73.75\n",
      "  Final Train: 77.46\n",
      "   Final Test: 72.63\n",
      "Run: 10, Time elapsed: 62.24, Epoch: 100, Loss: 0.9915, Train: 71.04%, Valid: 70.21% Test: 69.26%\n",
      "Run: 10, Time elapsed: 62.03, Epoch: 200, Loss: 0.9134, Train: 73.14%, Valid: 71.70% Test: 70.26%\n",
      "Run: 10, Time elapsed: 62.00, Epoch: 300, Loss: 0.8732, Train: 74.26%, Valid: 72.55% Test: 71.62%\n",
      "Run: 10, Time elapsed: 62.01, Epoch: 400, Loss: 0.8492, Train: 74.95%, Valid: 71.56% Test: 69.73%\n",
      "Run: 10, Time elapsed: 62.04, Epoch: 500, Loss: 0.8282, Train: 75.68%, Valid: 72.60% Test: 71.32%\n",
      "Run: 10, Time elapsed: 62.00, Epoch: 600, Loss: 0.8142, Train: 76.13%, Valid: 72.28% Test: 70.77%\n",
      "Run: 10, Time elapsed: 62.01, Epoch: 700, Loss: 0.7969, Train: 76.54%, Valid: 72.95% Test: 71.51%\n",
      "Run: 10, Time elapsed: 62.29, Epoch: 800, Loss: 0.7899, Train: 76.88%, Valid: 73.07% Test: 72.07%\n",
      "Run: 10, Time elapsed: 62.63, Epoch: 900, Loss: 0.7834, Train: 76.95%, Valid: 72.23% Test: 70.32%\n",
      "Run: 10, Time elapsed: 62.29, Epoch: 1000, Loss: 0.7741, Train: 77.36%, Valid: 73.02% Test: 71.85%\n",
      "Run 10:\n",
      "Highest Train: 77.37\n",
      "Highest Valid: 73.41\n",
      "  Final Train: 77.25\n",
      "   Final Test: 72.45\n",
      "All runs:\n",
      "Highest Train: 77.94 ± 0.42\n",
      "Highest Valid: 73.63 ± 0.10\n",
      "  Final Train: 77.58 ± 0.30\n",
      "   Final Test: 72.67 ± 0.18\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<train_obgn_arxiv.Logger at 0x1dafd53dfd0>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "main(args)"
   ]
  }
 ],
 "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
}
