{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "a2be459f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using device: cuda:3\n"
     ]
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch_geometric.nn as pyg_nn\n",
    "import torch.nn.functional as F\n",
    "import torch_geometric.transforms as T\n",
    "from ogb.nodeproppred import PygNodePropPredDataset, Evaluator\n",
    "from prettytable import PrettyTable\n",
    "from torch import Tensor\n",
    "from torch_geometric.loader import ClusterData, ClusterLoader, NeighborSampler\n",
    "from torch_geometric.nn import GCNConv\n",
    "from torch_geometric.nn.conv import MessagePassing\n",
    "from torch_geometric.nn.inits import zeros\n",
    "from torch_geometric.typing import Adj, OptTensor, PairTensor\n",
    "from torch_sparse import SparseTensor, fill_diag, matmul, mul\n",
    "from tqdm import tqdm\n",
    "from typing import Optional, Tuple\n",
    "gpu_id = 3 # replace with index in [0, torch.cuda.device_count()]\n",
    "device = torch.device(\"cuda:\" + str(gpu_id) if torch.cuda.is_available() else \"cpu\")\n",
    "print('Using device:', device)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "288f9cbf",
   "metadata": {},
   "source": [
    "## Helpers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "da820b7c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Logger object.\n",
    "class Logger(object):\n",
    "    def __init__(self, runs):\n",
    "        self.results = [[] for _ in range(runs)]\n",
    "\n",
    "    def add_result(self, run, result):\n",
    "        assert len(result) == 3\n",
    "        assert run >= 0 and run < len(self.results)\n",
    "        self.results[run].append(result)\n",
    "\n",
    "    def get_stats(self):\n",
    "        result = 100 * torch.tensor(self.results)\n",
    "\n",
    "        best_results = []\n",
    "        for r in result:\n",
    "            test = r[r[:, 1].argmax(), 2].item()\n",
    "            best_results.append(test)\n",
    "\n",
    "        return torch.tensor(best_results)\n",
    "\n",
    "# MLP with ReLU activations.\n",
    "class MLP(torch.nn.Module):\n",
    "    def __init__(self, num_layers, in_channels, hidden_channels, out_channels):\n",
    "        super(MLP, self).__init__()\n",
    "\n",
    "        self.lins = torch.nn.ModuleList()\n",
    "        self.lins.append(torch.nn.Linear(in_channels, hidden_channels))\n",
    "        for _ in range(num_layers - 2):\n",
    "            self.lins.append(torch.nn.Linear(hidden_channels, hidden_channels))\n",
    "        self.lins.append(torch.nn.Linear(hidden_channels, out_channels))\n",
    "        self.dropout = 0.5\n",
    "\n",
    "    def reset_parameters(self):\n",
    "        for lin in self.lins:\n",
    "            lin.reset_parameters()\n",
    "\n",
    "    def forward(self, x):\n",
    "        for lin in self.lins[:-1]:\n",
    "            x = lin(x)\n",
    "            x = F.relu(x)\n",
    "            x = F.dropout(x, p=self.dropout, training=self.training)\n",
    "        return self.lins[-1](x)\n",
    "    \n",
    "gcn_norm = pyg_nn.conv.gcn_conv.gcn_norm\n",
    "\n",
    "# GCNConv module modified to consider multiple convolutions.\n",
    "class GraphConv(MessagePassing):\n",
    "    _cached_edge_index: Optional[Tuple[Tensor, Tensor]]\n",
    "    _cached_adj_t: Optional[SparseTensor]\n",
    "\n",
    "    def __init__(\n",
    "        self, in_channels: int, out_channels: int, bias: bool = True,\n",
    "        num_convs: int = 1, cached: bool = False, **kwargs):\n",
    "        kwargs.setdefault('aggr', 'add')\n",
    "        super().__init__(**kwargs)\n",
    "\n",
    "        self.in_channels = in_channels\n",
    "        self.out_channels = out_channels\n",
    "        self.num_convs = num_convs\n",
    "        self.cached = cached\n",
    "        self._cached_edge_index = None\n",
    "        self._cached_adj_t = None\n",
    "\n",
    "        self.lin = nn.Linear(in_channels, out_channels, bias=False)\n",
    "\n",
    "        if bias:\n",
    "            self.bias = nn.Parameter(torch.Tensor(out_channels))\n",
    "        else:\n",
    "            self.register_parameter('bias', None)\n",
    "\n",
    "        self.reset_parameters()\n",
    "\n",
    "    def reset_parameters(self):\n",
    "        self.lin.reset_parameters()\n",
    "        zeros(self.bias)\n",
    "        self._cached_edge_index = None\n",
    "        self._cached_adj_t = None\n",
    "\n",
    "    def forward(self, x: Tensor, edge_index: Adj, edge_weight: OptTensor = None) -> Tensor:\n",
    "        edge_index, edge_weight = gcn_norm(\n",
    "            edge_index, edge_weight, x.size(self.node_dim),\n",
    "            False, True)\n",
    "        x = self.lin(x)\n",
    "\n",
    "        # propagate_type: (x: Tensor, edge_weight: OptTensor)\n",
    "        out = x\n",
    "        for i in range(self.num_convs):\n",
    "            out = self.propagate(edge_index, x=out, edge_weight=edge_weight, size=None)\n",
    "\n",
    "        if self.bias is not None:\n",
    "            out += self.bias\n",
    "\n",
    "        return out\n",
    "\n",
    "    def message(self, x_j: Tensor, edge_weight: OptTensor) -> Tensor:\n",
    "        return x_j if edge_weight is None else edge_weight.view(-1, 1) * x_j\n",
    "\n",
    "    def message_and_aggregate(self, adj_t: SparseTensor, x: Tensor) -> Tensor:\n",
    "        return matmul(adj_t, x, reduce=self.aggr)\n",
    "    \n",
    "# GCN with ReLU activations and sigmoidal output.\n",
    "class GCN(torch.nn.Module):\n",
    "    def __init__(self, num_layers, in_channels, hidden_channels, out_channels, num_convs):\n",
    "        super(GCN, self).__init__()\n",
    "\n",
    "        self.convs = torch.nn.ModuleList()\n",
    "        self.convs.append(GraphConv(in_channels, hidden_channels, num_convs=num_convs[0], cached=False))\n",
    "        for _ in range(num_layers - 2):\n",
    "            self.convs.append(\n",
    "                GraphConv(hidden_channels, hidden_channels, num_convs=num_convs[_+1], cached=False))\n",
    "        self.convs.append(GraphConv(hidden_channels, out_channels, num_convs=num_convs[-1], cached=False))\n",
    "        self.dropout = 0.5\n",
    "\n",
    "    def reset_parameters(self):\n",
    "        for conv in self.convs:\n",
    "            conv.reset_parameters()\n",
    "\n",
    "    def forward(self, x, edge_index):\n",
    "        for i, conv in enumerate(self.convs[:-1]):\n",
    "            x = conv(x, edge_index)\n",
    "            x = F.relu(x)\n",
    "            x = F.dropout(x, p=self.dropout, training=self.training)\n",
    "        return self.convs[-1](x, edge_index)\n",
    "    \n",
    "# Function to train a model, 1 epoch.\n",
    "def train(model, loader, optimizer, device):\n",
    "    model.train()\n",
    "    total_loss = total_examples = 0\n",
    "    total_correct = total_examples = 0\n",
    "    for data in loader:\n",
    "        data = data.to(device)\n",
    "        if data.train_mask.sum() == 0:\n",
    "            continue\n",
    "        optimizer.zero_grad()\n",
    "        out = model(data.x, data.edge_index)[data.train_mask]\n",
    "        y = data.y.squeeze(1)[data.train_mask]\n",
    "        loss = F.cross_entropy(out, y)\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "        num_examples = data.train_mask.sum().item()\n",
    "        total_loss += loss.item() * num_examples\n",
    "        total_examples += num_examples\n",
    "\n",
    "        total_correct += out.argmax(dim=-1).eq(y).sum().item()\n",
    "        total_examples += y.size(0)\n",
    "\n",
    "    return total_loss / total_examples, total_correct / total_examples\n",
    "\n",
    "# Function to evaluate a model.\n",
    "@torch.no_grad()\n",
    "def test(model, loader, evaluator, device):\n",
    "    model.eval()\n",
    "    train_accs = []\n",
    "    valid_accs = []\n",
    "    test_accs = []\n",
    "    total_nodes = 0\n",
    "    for data in loader:\n",
    "        data = data.to(device)\n",
    "        out = torch.log_softmax(model(data.x, data.edge_index), dim=-1)\n",
    "\n",
    "        y_true = data.y\n",
    "        y_pred = out.argmax(dim=-1, keepdim=True)\n",
    "        total_nodes += data.x.size(0)\n",
    "\n",
    "        train_accs.append(data.x.size(0)*evaluator.eval({\n",
    "            'y_true': y_true[data.train_mask],\n",
    "            'y_pred': y_pred[data.train_mask]\n",
    "        })['acc'])\n",
    "        valid_accs.append(data.x.size(0)*evaluator.eval({\n",
    "            'y_true': y_true[data.valid_mask],\n",
    "            'y_pred': y_pred[data.valid_mask]\n",
    "        })['acc'])\n",
    "        test_accs.append(data.x.size(0)*evaluator.eval({\n",
    "            'y_true': y_true[data.test_mask],\n",
    "            'y_pred': y_pred[data.test_mask]\n",
    "        })['acc'])\n",
    "    \n",
    "    train_acc = torch.tensor(train_accs).sum()/total_nodes\n",
    "    valid_acc = torch.tensor(valid_accs).sum()/total_nodes\n",
    "    test_acc = torch.tensor(test_accs).sum()/total_nodes\n",
    "\n",
    "    return train_acc, valid_acc, test_acc\n",
    "\n",
    "\n",
    "def train_mlp(model, x, y_true, train_idx, optimizer):\n",
    "    model.train()\n",
    "\n",
    "    optimizer.zero_grad()\n",
    "    out = model(x[train_idx])\n",
    "    loss = F.cross_entropy(out, y_true.squeeze(1)[train_idx])\n",
    "    loss.backward()\n",
    "    optimizer.step()\n",
    "\n",
    "    return loss.item()\n",
    "\n",
    "\n",
    "@torch.no_grad()\n",
    "def test_mlp(model, x, y_true, split_idx, evaluator):\n",
    "    model.eval()\n",
    "\n",
    "    out = torch.log_softmax(model(x), dim=-1)\n",
    "    y_pred = out.argmax(dim=-1, keepdim=True)\n",
    "\n",
    "    train_acc = evaluator.eval({\n",
    "        'y_true': y_true[split_idx['train']],\n",
    "        'y_pred': y_pred[split_idx['train']],\n",
    "    })['acc']\n",
    "    valid_acc = evaluator.eval({\n",
    "        'y_true': y_true[split_idx['valid']],\n",
    "        'y_pred': y_pred[split_idx['valid']],\n",
    "    })['acc']\n",
    "    test_acc = evaluator.eval({\n",
    "        'y_true': y_true[split_idx['test']],\n",
    "        'y_pred': y_pred[split_idx['test']],\n",
    "    })['acc']\n",
    "\n",
    "    return train_acc, valid_acc, test_acc"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c5482dd5-5833-40b8-a8fd-974a85855c5d",
   "metadata": {
    "tags": []
   },
   "source": [
    "## Learners and Plot Helpers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "supported-machinery",
   "metadata": {},
   "outputs": [],
   "source": [
    "model_types = [\n",
    "    'MLP3', # 3 layer MLP\n",
    "    '3L-001', # 3 layer GCN with 1 GC at layer 3\n",
    "    '3L-010', # 3 layer GCN with 1 GC at layer 2\n",
    "    '3L-100', # 3 layer GCN with 1 GC at layer 1\n",
    "    '3L-011', # 3 layer GCN with 1 GC each at layers 2 and 3\n",
    "    '3L-110', # 3 layer GCN with 1 GC each at layers 1 and 2\n",
    "    '3L-002', # 3 layer GCN with 2 GCs at layer 3\n",
    "    '3L-020', # 3 layer GCN with 2 GCs at layer 2\n",
    "    '3L-111', # 3 layer GCN with 1 GC at each layer\n",
    "    '3L-021', # 3 layer GCN\n",
    "    '3L-012', # 3 layer GCN\n",
    "    '3L-102', # 3 layer GCN\n",
    "    '3L-003', # 3 layer GCN with 3 GCs at layer 3\n",
    "    '3L-030', # 3 layer GCN with 3 GCs at layer 2\n",
    "    '3L-300', # 3 layer GCN with 3 GCs at layer 1\n",
    "]\n",
    "\n",
    "# Initialize all learning models.\n",
    "def init_learners(n_features, n_classes, hidden_channels=256):\n",
    "    learners = {}\n",
    "    learners['MLP3'] = MLP(3, n_features, hidden_channels, n_classes).to(device)\n",
    "    learners['3L-001'] = GCN(3, n_features, hidden_channels, n_classes, [0, 0, 1]).to(device)\n",
    "    learners['3L-010'] = GCN(3, n_features, hidden_channels, n_classes, [0, 1, 0]).to(device)\n",
    "    learners['3L-100'] = GCN(3, n_features, hidden_channels, n_classes, [1, 0, 0]).to(device)\n",
    "    learners['3L-011'] = GCN(3, n_features, hidden_channels, n_classes, [0, 1, 1]).to(device)\n",
    "    learners['3L-110'] = GCN(3, n_features, hidden_channels, n_classes, [1, 1, 0]).to(device)\n",
    "    learners['3L-002'] = GCN(3, n_features, hidden_channels, n_classes, [0, 0, 2]).to(device)\n",
    "    learners['3L-020'] = GCN(3, n_features, hidden_channels, n_classes, [0, 2, 0]).to(device)\n",
    "    learners['3L-111'] = GCN(3, n_features, hidden_channels, n_classes, [1, 1, 1]).to(device)\n",
    "    learners['3L-021'] = GCN(3, n_features, hidden_channels, n_classes, [0, 2, 1]).to(device)\n",
    "    learners['3L-012'] = GCN(3, n_features, hidden_channels, n_classes, [0, 1, 2]).to(device)\n",
    "    learners['3L-102'] = GCN(3, n_features, hidden_channels, n_classes, [1, 0, 2]).to(device)\n",
    "    learners['3L-003'] = GCN(3, n_features, hidden_channels, n_classes, [0, 0, 3]).to(device)\n",
    "    learners['3L-030'] = GCN(3, n_features, hidden_channels, n_classes, [0, 3, 0]).to(device)\n",
    "    learners['3L-300'] = GCN(3, n_features, hidden_channels, n_classes, [3, 0, 0]).to(device)\n",
    "    return learners\n",
    "\n",
    "alph = .8\n",
    "black = (.2, .2, .2, alph)\n",
    "red = (.8, .1, .1, alph)\n",
    "green = (.1, .8, .1, alph)\n",
    "blue = (0., .3, .8, alph)\n",
    "orange = (1., .6, .1, alph)\n",
    "colors=[black] + [red]*3 + [blue]*4 + [green]*7\n",
    "\n",
    "colors_std = []\n",
    "for color in colors:\n",
    "    color_std = (color[0], color[1], color[2], alph/3.)\n",
    "    colors_std.append(color_std)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "5a43c6e1",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_for_models(ds_name, x_axis, y_axis, y_err, y_label, filename=None):\n",
    "    fig = plt.figure(figsize=(16,4), facecolor=[1,1,1])\n",
    "    y_axis = np.asarray(y_axis)\n",
    "    if y_err is None:\n",
    "        y_err = np.zeros(len(x_axis))\n",
    "    else:\n",
    "        y_err = np.asarray(y_err)\n",
    "    plt.ylim((0, 1.2*np.max(y_axis+y_err)))\n",
    "    plt.bar(x_axis, y_axis, color=colors, width=0.6)\n",
    "    plt.bar(x_axis, 2*y_err, color=colors_std, width=0.6, bottom=np.maximum(y_axis-y_err, np.zeros(y_axis.shape)))\n",
    "    plt.xticks(x_axis, [s.upper() for s in model_types])\n",
    "    txt_gap = .1*np.max(y_axis)\n",
    "    for i, v in enumerate(y_axis):\n",
    "        plt.text(i-.25, v + txt_gap, \" \"+str(round(v, 2)), color='black', va='center', fontweight='bold')\n",
    "    plt.xlabel('Model', fontsize=18)\n",
    "    plt.ylabel(y_label, fontsize=18)\n",
    "    plt.show()\n",
    "    if filename is not None:\n",
    "        fig.savefig(\"figures/custom-gcnconv/\" + filename, dpi=400, bbox_inches='tight')\n",
    "\n",
    "def plot_metrics(ds, x_axis, t_acc_avg, t_acc_std, t_acc_max):\n",
    "    fname = ds + '_test_acc_avg.pdf'\n",
    "    plot_for_models(ds, x_axis, t_acc_avg, t_acc_std, 'Accuracy (avg)', fname)\n",
    "    fname = ds + '_test_acc_max.pdf'\n",
    "    plot_for_models(ds, x_axis, t_acc_max, None, 'Accuracy (max)', fname)\n",
    "\n",
    "def print_metrics(ds, t_acc_avg, t_acc_std, t_acc_max):\n",
    "    t = PrettyTable(['Model Name', 'Accuracy', 'Accuracy (max)'])\n",
    "    for m, mtype in enumerate(model_types):\n",
    "        t.add_row([\n",
    "            mtype,\n",
    "            f'{t_acc_avg[m].item():.2f}' + u' \\u00B1 ' + f'{t_acc_std[m].item():.2f}',\n",
    "            f'{t_acc_max[m].item():.2f}'])\n",
    "    print('METRICS FOR DATASET:', ds.upper())\n",
    "    print(t)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d57c83d3-db7a-4870-a111-440c21d52338",
   "metadata": {},
   "source": [
    "## Train and test all models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "e2b2ebf1",
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "dataset = PygNodePropPredDataset(name='ogbn-products', root='./products')\n",
    "split_idx = dataset.get_idx_split()\n",
    "data = dataset[0]\n",
    "\n",
    "# Convert split indices to boolean masks and add them to `data`.\n",
    "for key, idx in split_idx.items():\n",
    "    mask = torch.zeros(data.num_nodes, dtype=torch.bool)\n",
    "    mask[idx] = True\n",
    "    data[f'{key}_mask'] = mask\n",
    "\n",
    "cluster_data = ClusterData(\n",
    "    data, num_parts=15000, recursive=False, save_dir=dataset.processed_dir)\n",
    "\n",
    "loader = ClusterLoader(\n",
    "    cluster_data, batch_size=320, shuffle=True, num_workers=12)\n",
    "\n",
    "subgraph_loader = NeighborSampler(\n",
    "    data.edge_index, sizes=[-1], batch_size=1024, shuffle=False, num_workers=12)\n",
    "\n",
    "\n",
    "n_classes = dataset.num_classes\n",
    "n_points, n_features = data.num_nodes, data.num_features\n",
    "train_idx = split_idx['train'].to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "4de25ee1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Working on ogbn-products: Classes=47 | Points=2449029 | Features=100.\n",
      "Trial: 5 with 3L-300, Epoch: 50, Loss: 0.2338, Train: 89.64%, Valid: 88.63% Test: 71.11%           METRICS FOR DATASET: OGBN-PRODUCTS\n",
      "+------------+--------------+----------------+\n",
      "| Model Name |   Accuracy   | Accuracy (max) |\n",
      "+------------+--------------+----------------+\n",
      "|    MLP3    | 43.93 ± 0.29 |     44.30      |\n",
      "|   3L-001   | 70.76 ± 0.39 |     71.27      |\n",
      "|   3L-010   | 71.05 ± 0.12 |     71.22      |\n",
      "|   3L-100   | 69.04 ± 0.04 |     69.08      |\n",
      "|   3L-011   | 74.35 ± 0.38 |     74.64      |\n",
      "|   3L-110   | 73.65 ± 0.16 |     73.81      |\n",
      "|   3L-002   | 73.97 ± 0.42 |     74.64      |\n",
      "|   3L-020   | 73.39 ± 0.11 |     73.51      |\n",
      "|   3L-111   | 74.47 ± 0.22 |     74.85      |\n",
      "|   3L-021   | 74.26 ± 0.25 |     74.55      |\n",
      "|   3L-012   | 74.42 ± 0.25 |     74.72      |\n",
      "|   3L-102   | 74.02 ± 0.18 |     74.29      |\n",
      "|   3L-003   | 74.19 ± 0.21 |     74.36      |\n",
      "|   3L-030   | 73.05 ± 0.29 |     73.40      |\n",
      "|   3L-300   | 71.19 ± 0.06 |     71.25      |\n",
      "+------------+--------------+----------------+\n"
     ]
    },
    {
     "data": {
      "image/png": "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F9b5CtPxmNMV9F2ocFVOdytctWpVlrsc+/j4mMqVK1t/9u3bl+Uux9ccPHjQNGrUyISHh5s6deqYfv36We/SVhA2bdpkIiMjTXh4uAkLCzMjR440xhgTGxtr7rjjDmv9zZo1yzbvX3/9Ze6//35To0YNc//995ujR49ax40ePdpUq1bN1KxZM8vd11599VVTuXJlY7FYTOXKlc3w4cPdsr+goCBTvnx563besmWLMcaY9evXm7CwMFOtWjXTt29fc+XKlULZ26JFi0zlypWNp6en8ff3Nw888IB1nK1tV5C95be/W9l27vTazG37uftrM6/7lX379hlJpnbt2iYiIsJERESYmTNnOq03Z/X397//3Xh7e1t7iIiIMIcOHTLGuM+2u5XXpTu9725l2xWF/ozJefsV9HuvIP/mFZX9iq3+CvrY0xm9zZs3z9SpU8dERESY+vXrm88++8w6jzsdr3Tq1MmEhYWZ8PBw06FDB5OWlmYdV1iOx5zNYoy7P3gIAAAAAHA74pJjAAAAAIBbItACAAAAANwSgRYAAAAA4JYItAAAAAAAt0SgBQAAAAC4JQItAABFyNy5c2WxWPTtt9/e0vzffvutLBaL5s6d69C6AABwBgItAAAOdC0QWiwW9evXL8dpDh8+LE9PT1ksFrVp06ZgCwQAoAgh0AIA4AReXl76+OOPdeHChWzjPvzwQxljVLx4cRdUBgBA0UGgBQDACR577DEdP35cKSkp2cbNmTNHDz/8sEqWLOmCygAAKDoItAAAOEGDBg0UERGhOXPmZBm+bt06bdmyRc8991yO833++edq0aKFfH195evrqxYtWuQYiiXpgw8+UO3atVWyZEnVqFFDEydOlDEmx2lPnjyp1157TTVq1FDJkiXl5+en7t27a9euXflrFAAAF+JaJwAAnOS5557TgAEDlJaWpsDAQEnS7Nmz5e/vrw4dOmSbfurUqerbt69q166tN954w3pzpkcffVQzZsxQXFycddr3339fr7zyiiIiIvTWW2/p3Llzeuedd+Tv759tuSdPntQ999yj//73v+rZs6fCwsKUnp6uqVOnqmnTpkpNTVVQUJDz/kcAAOAkBFoAAJzk6aef1uDBgzVv3jy9/vrrOn/+vObPn6/evXtn+/7s8ePHNXjwYFWvXl0///yzypQpI0l68cUXVb9+fQ0cOFBdunRRuXLldOLECQ0dOlShoaH68ccf5e3tLelqgK5du3a2OoYNG6Zdu3bpp59+UkREhHV4jx49FB4eruHDh3NXYwCAW+KSYwAAnKRChQqKiYmxhsVFixbp5MmT6tmzZ7Zply9frrNnz+rll1+2hllJKlOmjF566SWdOXNGK1askCQtW7ZM586dU9++fa1hVpICAwP11FNPZVmuMUYfffSRWrVqpcqVK+uvv/6y/vj4+KhZs2ZatmyZE7oHAMD5OEMLAIATPffcc2rfvr1Wr16t2bNnq0mTJqpTp0626Xbv3i1JCgsLyzaubt26kmT9vuu1/+Z0NvbGZR85ckRHjx7VsmXL5Ofnl2ONxYrx+TYAwD0RaAEAcKIHH3xQlStX1siRI7Vq1SpNmzYtx+ls3cwpt2ktFstNl3Pt97Zt2+q1116zex0AALgDAi0AAE7k4eGhZ599VmPHjlWpUqXUrVu3HKerXr26JGnLli2KiorKMm7r1q2SpGrVqmWZdtu2bbr//vuzTLtt27Ysv/v5+alcuXI6deqU2rZtm/+GAAAoRLjGCAAAJ3vhhRc0fPhwTZ8+XWXLls1xmujoaPn4+GjSpEk6ffq0dfjp06c1adIk+fr6Kjo62jptqVKlNGXKFJ07d846bVpamj7++OMsyy1WrJieeuoprVu3TgsXLsxx3YcPH85viwAAuARnaAEAcLKqVatqxIgRuU5Trlw5vf322+rbt6+aNm2qHj16SJLmzp2rP/74QzNmzLCG4fLly+vvf/+7Bg0apHvuuUfPPvuszp07p+nTpyskJEQbNmzIsuwxY8ZozZo16tKli7p06aJmzZrJ09NTe/fu1eLFi9WwYUPucgwAcEsEWgAACok+ffooICBA77zzjkaOHClJioiI0GeffaZHH300y7QDBw6Ur6+vJkyYoCFDhqhKlSoaNGiQypYtm+0uymXLltWaNWs0fvx4ffLJJ0pJSVHx4sUVGBioli1bqnfv3gXVIgAADmUxebkLBQAAAAAAhQTfoQUAAAAAuCUCLQAAAADALRFoAQAAAABuiUALAAAAAHBLBFoAAAAAgFsi0AIAAAAA3BKBFgAAAADglgi0AAAAAAC3RKAFAAAAALil/wc+sEJcMRCzpQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 1152x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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fVoeHh6FtlssFp08edIuQQEAAAAAcDU2F7TXX3+9vv7660Lbv/76azVs2NAuQQEAAAAAcDU2F7R33323UlJStGjRonxtixcvVkpKivr27WvX4AAAAAAAKIzNr+2Ji4tTamqqYmNj9corrygsLEwWi0UZGRnavn27brjhBj399NOOjBUAAAAAACubC9pq1appw4YNeuqpp/Tuu+9aB4CqWbOmRo4cqalTp6p69eoOCxQAAAAAgCvZXNBKUo0aNTR//nzNmzdPhw4dkjFGfn5+slgsjooPAAAAAIACFaugvcxiscjPz8/esQAAAAAAYDObB4WaN2+ebr311kLbe/XqpQULFtglKAAAAAAArsbmgvbNN99U06ZNC21v1qyZFi9ebJegAAAAAAC4GpsL2szMTIWGhhbaHhISoszMTLsEBQAAAADA1dhc0F68eFHnzp0rtP3cuXNFtgMAAAAAYE82F7TNmjXTmjVrCm1fvXq1GjdubJegAAAAAAC4GpsL2kGDBmn16tUaP368Lly4YJ1+8eJFTZw4UatXr9a9995r84b37Nmjnj17qkWLFgoJCdHs2bMlSUeOHFFERISaNm2qiIgIHT16tBjpAAAAAACuFTYXtI8++qi6d++uadOmqV69eurWrZv+8Y9/KCAgQM8995y6deumsWPH2rxhT09Pvfzyy9qxY4c2bdqkefPmafv27YqPj1d4eLgyMzMVHh6u+Pj4EiUGAAAAACjfbC5oK1asqNWrVys+Pl6BgYH68ccf9cMPP6hBgwZ64YUXtHbtWlWqVMnmDQcEBKht27aSpGrVqqlFixb6888/lZqaqpiYGElSTEyMVqxYUbyMAAAAAADXBM/izFyxYkWNGzdO48aNK7D9/Pnz8vLyKnYQu3fv1o8//qhOnTpp//79CggIkPRX0XvgwIECl0lISFBCQoIk6eDBg8XeJgAAAADAvdl8hbYo33//vUaNGqV69eoVe9lTp07pnnvu0axZs1S9enWbl4uNjVV6errS09Pl5+dX7O0CAAAAANxbsa7QXunIkSNaunSpFi1apJ9++knGGDVr1qxY67h48aLuuece3Xffferbt68kqU6dOsrOzlZAQICys7Pl7+9f0hABAAAAAOVYsa/Qfv7554qOjlb9+vX16KOP6sKFC5o4caL++9//6ueff7Z5PcYYPfjgg2rRooUee+wx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\n",
      "text/plain": [
       "<Figure size 1152x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "n_trials = 5\n",
    "epochs = 50\n",
    "print(f'\\nWorking on {dataset.name}:',\n",
    "      f'Classes={n_classes} |',\n",
    "      f'Points={n_points} |',\n",
    "      f'Features={n_features}.')\n",
    "test_acc_avg = torch.zeros(len(model_types))\n",
    "test_acc_std = torch.zeros(len(model_types))\n",
    "test_acc_max = torch.zeros(len(model_types))\n",
    "learners = init_learners(n_features, n_classes)\n",
    "for m, model_type in enumerate(model_types):\n",
    "    model = learners[model_type]\n",
    "    evaluator = Evaluator(name='ogbn-products')\n",
    "    logger = Logger(n_trials)\n",
    "    if model_type == 'MLP3':\n",
    "        x = data.x\n",
    "        x = x.to(device)\n",
    "        y_true = data.y.to(device)\n",
    "        train_idx = split_idx['train'].to(device)\n",
    "        \n",
    "    for t in range(n_trials):\n",
    "        # Reset and train model.\n",
    "        model.reset_parameters()\n",
    "        optimizer = torch.optim.Adam(model.parameters(), lr=0.001)\n",
    "        for epoch in range(1, 1 + epochs):\n",
    "            if model_type == 'MLP3':\n",
    "                loss = train_mlp(model, x, y_true, train_idx, optimizer)\n",
    "                result = test_mlp(model, x, y_true, split_idx, evaluator)\n",
    "            else:\n",
    "                loss, train_acc = train(model, loader, optimizer, device)\n",
    "                result = test(model, loader, evaluator, device)\n",
    "            logger.add_result(t, result)\n",
    "            wspace = ' '*10\n",
    "            train_acc, valid_acc, test_acc = result\n",
    "            print(f'\\rTrial: {t + 1} with {model_type}, '\n",
    "                  f'Epoch: {epoch:02d}, '\n",
    "                  f'Loss: {loss:.4f}, '\n",
    "                  f'Train: {100 * train_acc:.2f}%, '\n",
    "                  f'Valid: {100 * valid_acc:.2f}% '\n",
    "                  f'Test: {100 * test_acc:.2f}%', wspace, end='')\n",
    "    \n",
    "    # Get test metrics from accumulated test results.\n",
    "    test_acc_list = logger.get_stats()\n",
    "    test_acc_avg[m] = test_acc_list.mean().item()\n",
    "    test_acc_std[m] = test_acc_list.std().item()\n",
    "    test_acc_max[m] = test_acc_list.max().item()\n",
    "\n",
    "x_axis = torch.arange(len(model_types))\n",
    "print_metrics(dataset.name, test_acc_avg, test_acc_std, test_acc_max)\n",
    "plot_metrics(dataset.name, x_axis, test_acc_avg, test_acc_std, test_acc_max)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1c9e3df8",
   "metadata": {},
   "source": [
    "## Plot and print metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "2a235e19",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "METRICS FOR DATASET: OGBN-PRODUCTS\n",
      "+------------+--------------+----------------+\n",
      "| Model Name |   Accuracy   | Accuracy (max) |\n",
      "+------------+--------------+----------------+\n",
      "|    MLP3    | 43.93 ± 0.29 |     44.30      |\n",
      "|   3L-001   | 70.76 ± 0.39 |     71.27      |\n",
      "|   3L-010   | 71.05 ± 0.12 |     71.22      |\n",
      "|   3L-100   | 69.04 ± 0.04 |     69.08      |\n",
      "|   3L-011   | 74.35 ± 0.38 |     74.64      |\n",
      "|   3L-110   | 73.65 ± 0.16 |     73.81      |\n",
      "|   3L-002   | 73.97 ± 0.42 |     74.64      |\n",
      "|   3L-020   | 73.39 ± 0.11 |     73.51      |\n",
      "|   3L-111   | 74.47 ± 0.22 |     74.85      |\n",
      "|   3L-021   | 74.26 ± 0.25 |     74.55      |\n",
      "|   3L-012   | 74.42 ± 0.25 |     74.72      |\n",
      "|   3L-102   | 74.02 ± 0.18 |     74.29      |\n",
      "|   3L-003   | 74.19 ± 0.21 |     74.36      |\n",
      "|   3L-030   | 73.05 ± 0.29 |     73.40      |\n",
      "|   3L-300   | 71.19 ± 0.06 |     71.25      |\n",
      "+------------+--------------+----------------+\n"
     ]
    },
    {
     "data": {
      "image/png": "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F9b5CtPxmNMV9F2ocFVOdytctWpVlrsc+/j4mMqVK1t/9u3bl+Uux9ccPHjQNGrUyISHh5s6deqYfv36We/SVhA2bdpkIiMjTXh4uAkLCzMjR440xhgTGxtr7rjjDmv9zZo1yzbvX3/9Ze6//35To0YNc//995ujR49ax40ePdpUq1bN1KxZM8vd11599VVTuXJlY7FYTOXKlc3w4cPdsr+goCBTvnx563besmWLMcaY9evXm7CwMFOtWjXTt29fc+XKlULZ26JFi0zlypWNp6en8ff3Nw888IB1nK1tV5C95be/W9l27vTazG37uftrM6/7lX379hlJpnbt2iYiIsJERESYmTNnOq03Z/X397//3Xh7e1t7iIiIMIcOHTLGuM+2u5XXpTu9725l2xWF/ozJefsV9HuvIP/mFZX9iq3+CvrY0xm9zZs3z9SpU8dERESY+vXrm88++8w6jzsdr3Tq1MmEhYWZ8PBw06FDB5OWlmYdV1iOx5zNYoy7P3gIAAAAAHA74pJjAAAAAIBbItACAAAAANwSgRYAAAAA4JYItAAAAAAAt0SgBQAAAAC4JQItAABFyNy5c2WxWPTtt9/e0vzffvutLBaL5s6d69C6AABwBgItAAAOdC0QWiwW9evXL8dpDh8+LE9PT1ksFrVp06ZgCwQAoAgh0AIA4AReXl76+OOPdeHChWzjPvzwQxljVLx4cRdUBgBA0UGgBQDACR577DEdP35cKSkp2cbNmTNHDz/8sEqWLOmCygAAKDoItAAAOEGDBg0UERGhOXPmZBm+bt06bdmyRc8991yO833++edq0aKFfH195evrqxYtWuQYiiXpgw8+UO3atVWyZEnVqFFDEydOlDEmx2lPnjyp1157TTVq1FDJkiXl5+en7t27a9euXflrFAAAF+JaJwAAnOS5557TgAEDlJaWpsDAQEnS7Nmz5e/vrw4dOmSbfurUqerbt69q166tN954w3pzpkcffVQzZsxQXFycddr3339fr7zyiiIiIvTWW2/p3Llzeuedd+Tv759tuSdPntQ999yj//73v+rZs6fCwsKUnp6uqVOnqmnTpkpNTVVQUJDz/kcAAOAkBFoAAJzk6aef1uDBgzVv3jy9/vrrOn/+vObPn6/evXtn+/7s8ePHNXjwYFWvXl0///yzypQpI0l68cUXVb9+fQ0cOFBdunRRuXLldOLECQ0dOlShoaH68ccf5e3tLelqgK5du3a2OoYNG6Zdu3bpp59+UkREhHV4jx49FB4eruHDh3NXYwCAW+KSYwAAnKRChQqKiYmxhsVFixbp5MmT6tmzZ7Zply9frrNnz+rll1+2hllJKlOmjF566SWdOXNGK1askCQtW7ZM586dU9++fa1hVpICAwP11FNPZVmuMUYfffSRWrVqpcqVK+uvv/6y/vj4+KhZs2ZatmyZE7oHAMD5OEMLAIATPffcc2rfvr1Wr16t2bNnq0mTJqpTp0626Xbv3i1JCgsLyzaubt26kmT9vuu1/+Z0NvbGZR85ckRHjx7VsmXL5Ofnl2ONxYrx+TYAwD0RaAEAcKIHH3xQlStX1siRI7Vq1SpNmzYtx+ls3cwpt2ktFstNl3Pt97Zt2+q1116zex0AALgDAi0AAE7k4eGhZ599VmPHjlWpUqXUrVu3HKerXr26JGnLli2KiorKMm7r1q2SpGrVqmWZdtu2bbr//vuzTLtt27Ysv/v5+alcuXI6deqU2rZtm/+GAAAoRLjGCAAAJ3vhhRc0fPhwTZ8+XWXLls1xmujoaPn4+GjSpEk6ffq0dfjp06c1adIk+fr6Kjo62jptqVKlNGXKFJ07d846bVpamj7++OMsyy1WrJieeuoprVu3TgsXLsxx3YcPH85viwAAuARnaAEAcLKqVatqxIgRuU5Trlw5vf322+rbt6+aNm2qHj16SJLmzp2rP/74QzNmzLCG4fLly+vvf/+7Bg0apHvuuUfPPvuszp07p+nTpyskJEQbNmzIsuwxY8ZozZo16tKli7p06aJmzZrJ09NTe/fu1eLFi9WwYUPucgwAcEsEWgAACok+ffooICBA77zzjkaOHClJioiI0GeffaZHH300y7QDBw6Ur6+vJkyYoCFDhqhKlSoaNGiQypYtm+0uymXLltWaNWs0fvx4ffLJJ0pJSVHx4sUVGBioli1bqnfv3gXVIgAADmUxebkLBQAAAAAAhQTfoQUAAAAAuCUCLQAAAADALRFoAQAAAABuiUALAAAAAHBLBFoAAAAAgFsi0AIAAAAA3BKBFgAAAADglgi0AAAAAAC3RKAFAAAAALil/wc+sEJcMRCzpQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 1152x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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fVoeHh6FtlssFp08edIuQQEAAAAAcDU2F7TXX3+9vv7660Lbv/76azVs2NAuQQEAAAAAcDU2F7R33323UlJStGjRonxtixcvVkpKivr27WvX4AAAAAAAKIzNr+2Ji4tTamqqYmNj9corrygsLEwWi0UZGRnavn27brjhBj399NOOjBUAAAAAACubC9pq1appw4YNeuqpp/Tuu+9aB4CqWbOmRo4cqalTp6p69eoOCxQAAAAAgCvZXNBKUo0aNTR//nzNmzdPhw4dkjFGfn5+slgsjooPAAAAAIACFaugvcxiscjPz8/esQAAAAAAYDObB4WaN2+ebr311kLbe/XqpQULFtglKAAAAAAArsbmgvbNN99U06ZNC21v1qyZFi9ebJegAAAAAAC4GpsL2szMTIWGhhbaHhISoszMTLsEBQAAAADA1dhc0F68eFHnzp0rtP3cuXNFtgMAAAAAYE82F7TNmjXTmjVrCm1fvXq1GjdubJegAAAAAAC4GpsL2kGDBmn16tUaP368Lly4YJ1+8eJFTZw4UatXr9a9995r84b37Nmjnj17qkWLFgoJCdHs2bMlSUeOHFFERISaNm2qiIgIHT16tBjpAAAAAACuFTYXtI8++qi6d++uadOmqV69eurWrZv+8Y9/KCAgQM8995y6deumsWPH2rxhT09Pvfzyy9qxY4c2bdqkefPmafv27YqPj1d4eLgyMzMVHh6u+Pj4EiUGAAAAACjfbC5oK1asqNWrVys+Pl6BgYH68ccf9cMPP6hBgwZ64YUXtHbtWlWqVMnmDQcEBKht27aSpGrVqqlFixb6888/lZqaqpiYGElSTEyMVqxYUbyMAAAAAADXBM/izFyxYkWNGzdO48aNK7D9/Pnz8vLyKnYQu3fv1o8//qhOnTpp//79CggIkPRX0XvgwIECl0lISFBCQoIk6eDBg8XeJgAAAADAvdl8hbYo33//vUaNGqV69eoVe9lTp07pnnvu0axZs1S9enWbl4uNjVV6errS09Pl5+dX7O0CAAAAANxbsa7QXunIkSNaunSpFi1apJ9++knGGDVr1qxY67h48aLuuece3Xffferbt68kqU6dOsrOzlZAQICys7Pl7+9f0hABAAAAAOVYsa/Qfv7554qOjlb9+vX16KOP6sKFC5o4caL++9//6ueff7Z5PcYYPfjgg2rRooUee+wx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\n",
      "text/plain": [
       "<Figure size 1152x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x_axis = torch.arange(len(model_types))\n",
    "print_metrics(dataset.name, test_acc_avg, test_acc_std, test_acc_max)\n",
    "plot_metrics(dataset.name, x_axis, test_acc_avg, test_acc_std, test_acc_max)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6112ea61",
   "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.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
