{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "a2be459f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using device: cuda:5\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 = 5 # 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",
    "    'MLP2', # 2 layer MLP\n",
    "    '2L-01', # 2 layer GCN with 1 GC at layer 2\n",
    "    '2L-10', # 2 layer GCN with 1 GC at layer 1\n",
    "    '2L-02', # 2 layer GCN with 2 GCs at layer 2\n",
    "    '2L-20', # 2 layer GCN with 2 GCs at layer 1\n",
    "    '2L-11', # 2 layer GCN with 1 GC each at layers 1 and 2\n",
    "    '2L-03', # 2 layer GCN with 3 GCs at layer 2\n",
    "    '2L-30', # 2 layer GCN with 3 GCs at layer 1\n",
    "    '2L-12', # 2 layer GCN with 1 GC at layer 1 and 2 at layer 2\n",
    "    '2L-21', # 2 layer GCN with 2 GCs at layer 1 and 1 at layer 2\n",
    "]\n",
    "\n",
    "# Initialize all learning models.\n",
    "def init_learners(n_features, n_classes, hidden_channels=256):\n",
    "    learners = {}\n",
    "    learners['MLP2'] = MLP(2, n_features, hidden_channels, n_classes).to(device)\n",
    "    learners['2L-01'] = GCN(2, n_features, hidden_channels, n_classes, [0, 1]).to(device)\n",
    "    learners['2L-10'] = GCN(2, n_features, hidden_channels, n_classes, [1, 0]).to(device)\n",
    "    learners['2L-02'] = GCN(2, n_features, hidden_channels, n_classes, [0, 2]).to(device)\n",
    "    learners['2L-20'] = GCN(2, n_features, hidden_channels, n_classes, [2, 0]).to(device)\n",
    "    learners['2L-11'] = GCN(2, n_features, hidden_channels, n_classes, [1, 1]).to(device)\n",
    "    learners['2L-03'] = GCN(2, n_features, hidden_channels, n_classes, [0, 3]).to(device)\n",
    "    learners['2L-30'] = GCN(2, n_features, hidden_channels, n_classes, [3, 0]).to(device)\n",
    "    learners['2L-12'] = GCN(2, n_features, hidden_channels, n_classes, [1, 2]).to(device)\n",
    "    learners['2L-21'] = GCN(2, n_features, hidden_channels, n_classes, [2, 1]).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]*2 + [blue]*3 + [green]*4\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 2L-21, Epoch: 50, Loss: 0.2025, Train: 90.12%, Valid: 88.98% Test: 72.83%           METRICS FOR DATASET: OGBN-PRODUCTS\n",
      "+------------+--------------+----------------+\n",
      "| Model Name |   Accuracy   | Accuracy (max) |\n",
      "+------------+--------------+----------------+\n",
      "|    MLP2    | 42.80 ± 0.31 |     43.20      |\n",
      "|   2L-01    | 69.16 ± 0.21 |     69.45      |\n",
      "|   2L-10    | 67.59 ± 0.19 |     67.90      |\n",
      "|   2L-02    | 72.69 ± 0.22 |     72.97      |\n",
      "|   2L-20    | 70.50 ± 0.16 |     70.76      |\n",
      "|   2L-11    | 72.93 ± 0.16 |     73.10      |\n",
      "|   2L-03    | 72.34 ± 0.17 |     72.59      |\n",
      "|   2L-30    | 70.29 ± 0.06 |     70.36      |\n",
      "|   2L-12    | 72.99 ± 0.14 |     73.11      |\n",
      "|   2L-21    | 72.85 ± 0.08 |     72.98      |\n",
      "+------------+--------------+----------------+\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA7QAAAEOCAYAAAC5CVuUAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAA/L0lEQVR4nO3de3zP9f//8fvbZrMDiTaWYZlhZobNocihWYQmcppiklZ0RrW+fRxL1sGZYkLrtBXJOpFD+JQPaWXkVFP0IYtlI6fFeP7+8PP+tGy8x/u97b3drpfLLtnr+Hg+e7323n2v1+v5shhjjAAAAAAAcDIVSroAAAAAAACuBoEWAAAAAOCUCLQAAAAAAKdEoAUAAAAAOCUCLQAAAADAKbmWdAH2cMMNNyggIKCkywAAAAAAOMC+ffv0xx9/XDK9TATagIAApaWllXQZAAAAAAAHiIiIKHA6txwDAAAAAJwSgRYAAAAA4JQItAAAAAAAp0SgBQAAAAA4JQItAAAAAMApEWgBAAAAAE6JQAsAAAAAcEoEWgAAAACAUyLQAgAAAACcEoEWAAAAAOCUCLQAAAAAAKdEoAUAAAAAOCUCLQAAAADAKRFoAaAEBAQEyGKx5PsaMmSIJOmFF15QUFCQPDw8VKdOHU2dOvWy25o7d64CAwPl7u6uwMBAffXVV5Kk3bt3q1OnTvLy8lJgYKCWLl3q6GahDLHXMXq54/Cll15SzZo15ebmptq1a2v8+PEObhWAyymO8768fTbZq0+///573XLLLfLy8lK1atXUt29fHTt2TJI0fvz4S/aRnp5eDK0rHUo00E6bNk0hISFq0qSJYmJilJubq+zsbEVFRSkoKEhRUVHKyckpyRIBwCFmzZql5ORkJScnq2/fvpKkFi1aSJI2b96su+66SzNnzpSbm5tGjRql9evXF7idjz/+WMOHD5e/v7/mzJmjmJgYnTlzRpLUt29fffvtt3rllVdUrVo1DRw4UJmZmcXTQDg9ex2jlzsOfXx89K9//Utz585VlSpVNGHCBP3nP/8pngaWAHv9YmvLHwLGjh0ri8Uib29vB7UGZVFxnPfl7bPJXn366KOPauPGjXrmmWfUoUMHLVmyRDNnzsy3zMX9JCcnKyAgwKHtKlVMCTlw4IAJCAgwp06dMsYY07dvX7No0SLz1FNPmcmTJxtjjJk8ebJ5+umnr7it8PBwh9YKAI7UpEkT4+HhYXJycowxxvz111/WeTNnzjSSzJw5cwpc99ZbbzWenp7m6NGj5vTp09bpR44cMZJM586djTHGzJ0710gyU6ZMcVxDUGZd7TFqy3H4559/ml9//dV0797dSDIbN250bGNK0Mcff2ySk5NNcnKy6du3r5FkZsyYYYwx5s477zSjR482iYmJJjAw0Egy69atK3A7CxYsMLNmzTILFiwwjRs3NpLMhg0brPO3b99uKlWqZCpVqmS8vLyKpW0oexxx3pf3z6Zr+bxv06aNsVgs5uuvvzYTJkwwkszMmTONMcaMGzfOSDInT540eXl5Dm9HSSks85XoFdq8vDydPn1aeXl5OnXqlG688UalpqYqNjZWkhQbG6tly5aVZIkA4FAbNmzQ9u3bFRMTo6pVq0qS3NzcrPNXrlypChUqqG3btgWuv3PnTrm5uSk4OFienp665ZZbdODAAVWuXFmVKlXS7t27lZGRoa+//lqStHfvXoe3CWXLtRyjthyHgwYNUt26dfXZZ59p1KhRatOmjWMbVILuvPNODRgwQAMGDNCuXbvk4eGhwYMHS5KWLFmiV155RQ888IAef/xxSdKOHTsK3M7QoUMVGxurzp0766abbpIkVahw4Ve68+fPa9iwYYqLi1ONGjWKoVUoixx13pfnz6Zr/byfO3euatasqXbt2mncuHHq0qWLRowYkW8Zb29veXh4qH///jp16pTD2lLqFHOwzmf69OnGy8vL3HDDDWbgwIHGGGOuu+66fMtUrVr1itvhCi0AZzVo0CAjyWzevPmSeSNHjjSSrHetFMTb29tIMpMmTTIvvviikWTuueceY8yFn7EuLi5GkqlcubKRZEaPHu2wtqBsutZj9ErH4datW82SJUtMeHi48fb2Njt27HBIO0qTr7/+2kgyQ4cOLXB+jx49TIUKFUx6enqh2+jZs6eRZCSZUaNGWafPnDnT1K1b1xw/ftzUrVuXK7S4Ko4878vrZ9O19mlcXJxxcXExb7zxhhk1apSRZKZPn26MMSY1NdXMmzfPfPzxx+auu+4ykszEiRMd1paSUljmK7FAm52dbTp16mQOHz5szpw5Y3r27GnefvttmwPtvHnzTHh4uAkPDzd16tQphooBwL6OHDliKlWqVOAP6Mcee8xIMmPGjMk3/ezZs+b06dPm3LlzxpgL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Jnt/LkEqf/egOKGhQ4fquuuuU2hoqNatW3fV2/nXv/6lY8eO6Y033rBfcU7CGKP7779fwcHBGjly5GWXXbRoUb7vo6OjlZSUpPj4eCUlJalnz56OLNVpXEufFiY6OloDBw7UyJEjdfDgQWVkZKhVq1b2KLfUc8QxevToUXXv3l2TJ09W27ZtHVZ7aXUtfbpixQq99NJLWr9+vTw9Pa3TOUbte86Xd4447/fu3avatWvL1dVVv/76q3788UcFBAQ4qgmlyrX0Z0ZGhoKCgiRJH3/8sRo1aiSpfJ/zkmPO+/L82eSIzyVIMii1vLy8Lpm2du1a0717d2OMMYsWLTJeXl6mVq1a1q/9+/ebunXrmqysrHzr7d+/30gyjRo1MmFhYSYsLMzMnz+/WNpRGnz11VdGkgkNDbW2/7PPPjOxsbGmWrVq1v5r06bNJev+8ccf5rbbbjP169c3t912mzly5Ih1Xt26dc31119v/f+wY8eO4mxWibqWPl26dKmpVauWcXNzM76+vub222+3znvhhRdMvXr1TIMGDcznn39enE0qUY44Rp9//nnj6elp3V5YWJg5dOhQcTetxFxLnwYGBhp/f3/reg8++KB1Hseofc95fo7a97x/6623TOPGjU1YWJhp3ry5+eijj4q5VSXnWvqzd+/eJiQkxISGhpoePXqYAwcOWOeV13PeGMec9+X5s8lRn0vl+eeoMcZYjCng4QAAAAAAAEo5nqEFAAAAADglAi0AAAAAwCkRaAEAAAAATolACwAAAABwSgRaAAAAAIBTItACAFCGvPnmm7JYLFf93vJ169bJYrHozTfftGtdAAA4AoEWAAA7uhgILRaLHnnkkQKXOXz4sNzc3GSxWNSxY8fiLRAAgDKEQAsAgANUqlRJ7733nv76669L5r399tsyxsjV1bUEKgMAoOwg0AIA4AC9evVSTk6OUlNTL5m3aNEidevWTe7u7iVQGQAAZQeBFgAAB2jRooXCwsK0aNGifNM3b96sHTt26L777itwvWXLlqlt27by9vaWt7e32rZtW2AolqQ33nhDjRo1kru7u+rXr68ZM2bIGFPgsseOHdMzzzyj+vXry93dXT4+PoqJidEvv/xybQ0FAKAEca8TAAAOct9992nkyJE6cOCA/P39JUkLFy6Ur6+vevToccnyr732mh5++GE1atRI//rXv6yDM911112aN2+e4uLirMtOnz5dTz75pMLCwvTiiy/q1KlTeuWVV+Tr63vJdo8dO6ZbbrlF//3vfzV06FCFhIQoMzNTr732mlq3bq20tDTVrVvXcR0BAICDEGgBAHCQe++9V08//bTeeust/d///Z9Onz6tlJQUDRs27JLnZ3NycvT0008rMDBQ33zzjapUqSJJGj58uJo3b65Ro0apX79+qlq1qo4eParnnntOwcHB+s9//iNPT09JFwJ0o0aNLqlj7Nix+uWXX7Rp0yaFhYVZpw8ZMkShoaEaN24coxoDAJwStxwDAOAg1atXV3R0tDUsLl26VMeOHdPQoUMvWXbVqlU6efKkHnvsMWuYlaQqVaro0Ucf1YkTJ7R69WpJ0sqVK3Xq1Ck9/PDD1jArSf7+/rrnnnvybdcYo3fffVft27dXrVq19Mcff1i/vLy81KZNG61cudIBrQcAwPG4QgsAgAPdd9996t69u77++mstXLhQrVq1UuPGjS9Zbu/evZKkkJCQS+Y1adJEkqzPu178b0FXY/+57aysLB05ckQrV66Uj49PgTVWqMDftwEAzolACwCAA3Xp0kW1atXShAkTtHbtWr3++usFLlfYYE6XW9ZisVxxOxe/79y5s5555hmb9wEAgDMg0AIA4EAuLi4aPHiwJk+eLA8PDw0YMKDA5QIDAyVJO3bsUGRkZL55O3fulCTVq1cv37K7du3Sbbfdlm/ZXbt25fvex8dHVatW1Z9//qnOnTtfe4MAAChFuMcIAAAHe+ihhzRu3DjNnTtX1113XYHLREVFycvLS7NmzdLx48et048fP65Zs2bJ29tbUVFR1mU9PDw0Z84cnTp1yrrsgQMH9N577+XbboUKFXTPPfdo8+bNWrJkSYH7Pnz48LU2EQCAEsEVWgAAHKxOnToaP378ZZepWrWqXn75ZT388MNq3bq1hgwZIkl68803tWfPHs2bN88ahq+//no9//zzGj16tG655RYNHjxYp06d0ty5cxUUFKQtW7bk2/akSZO0YcMG9evXT/369VObNm3k5uamX3/9VZ9//rnCw8MZ5RgA4JQItAAAlBIjRoyQn5+fXnnlFU2YMEGSFBYWpo8++kh33XVXvmVHjRolb29vTZ06Vc8++6xq166t0aNH67rrrrtkFOXrrrtOGzZs0JQpU/TBBx8oNTVVrq6u8vf3V7t27TRs2LDiaiIAAHZlMUUZhQIAAAAAgFKCZ2gBAAAAAE6JQAsAAAAAcEoEWgAAAACAUyLQAgAAAACcEoEWAAAAAOCUCLQAAAAAAKdEoAUAAAAAOCUCLQAAAADAKRFoAQAAAABO6f8B4WnFVJndI+AAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 1152x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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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 == 'MLP2':\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 == 'MLP2':\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",
      "|    MLP2    | 42.80 ± 0.31 |     43.20      |\n",
      "|   2L-01    | 69.16 ± 0.21 |     69.45      |\n",
      "|   2L-10    | 67.59 ± 0.19 |     67.90      |\n",
      "|   2L-02    | 72.69 ± 0.22 |     72.97      |\n",
      "|   2L-20    | 70.50 ± 0.16 |     70.76      |\n",
      "|   2L-11    | 72.93 ± 0.16 |     73.10      |\n",
      "|   2L-03    | 72.34 ± 0.17 |     72.59      |\n",
      "|   2L-30    | 70.29 ± 0.06 |     70.36      |\n",
      "|   2L-12    | 72.99 ± 0.14 |     73.11      |\n",
      "|   2L-21    | 72.85 ± 0.08 |     72.98      |\n",
      "+------------+--------------+----------------+\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA7QAAAEOCAYAAAC5CVuUAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAA/L0lEQVR4nO3de3zP9f//8fvbZrMDiTaWYZlhZobNocihWYQmcppiklZ0RrW+fRxL1sGZYkLrtBXJOpFD+JQPaWXkVFP0IYtlI6fFeP7+8PP+tGy8x/u97b3drpfLLtnr+Hg+e7323n2v1+v5shhjjAAAAAAAcDIVSroAAAAAAACuBoEWAAAAAOCUCLQAAAAAAKdEoAUAAAAAOCUCLQAAAADAKbmWdAH2cMMNNyggIKCkywAAAAAAOMC+ffv0xx9/XDK9TATagIAApaWllXQZAAAAAAAHiIiIKHA6txwDAAAAAJwSgRYAAAAA4JQItAAAAAAAp0SgBQAAAAA4JQItAAAAAMApEWgBAAAAAE6JQAsAAAAAcEoEWgAAAACAUyLQAgAAAACcEoEWAAAAAOCUCLQAAAAAAKdEoAUAAAAAOCUCLQAAAADAKRFoAaAEBAQEyGKx5PsaMmSIJOmFF15QUFCQPDw8VKdOHU2dOvWy25o7d64CAwPl7u6uwMBAffXVV5Kk3bt3q1OnTvLy8lJgYKCWLl3q6GahDLHXMXq54/Cll15SzZo15ebmptq1a2v8+PEObhWAyymO8768fTbZq0+///573XLLLfLy8lK1atXUt29fHTt2TJI0fvz4S/aRnp5eDK0rHUo00E6bNk0hISFq0qSJYmJilJubq+zsbEVFRSkoKEhRUVHKyckpyRIBwCFmzZql5ORkJScnq2/fvpKkFi1aSJI2b96su+66SzNnzpSbm5tGjRql9evXF7idjz/+WMOHD5e/v7/mzJmjmJgYnTlzRpLUt29fffvtt3rllVdUrVo1DRw4UJmZmcXTQDg9ex2jlzsOfXx89K9//Utz585VlSpVNGHCBP3nP/8pngaWAHv9YmvLHwLGjh0ri8Uib29vB7UGZVFxnPfl7bPJXn366KOPauPGjXrmmWfUoUMHLVmyRDNnzsy3zMX9JCcnKyAgwKHtKlVMCTlw4IAJCAgwp06dMsYY07dvX7No0SLz1FNPmcmTJxtjjJk8ebJ5+umnr7it8PBwh9YKAI7UpEkT4+HhYXJycowxxvz111/WeTNnzjSSzJw5cwpc99ZbbzWenp7m6NGj5vTp09bpR44cMZJM586djTHGzJ0710gyU6ZMcVxDUGZd7TFqy3H4559/ml9//dV0797dSDIbN250bGNK0Mcff2ySk5NNcnKy6du3r5FkZsyYYYwx5s477zSjR482iYmJJjAw0Egy69atK3A7CxYsMLNmzTILFiwwjRs3NpLMhg0brPO3b99uKlWqZCpVqmS8vLyKpW0oexxx3pf3z6Zr+bxv06aNsVgs5uuvvzYTJkwwkszMmTONMcaMGzfOSDInT540eXl5Dm9HSSks85XoFdq8vDydPn1aeXl5OnXqlG688UalpqYqNjZWkhQbG6tly5aVZIkA4FAbNmzQ9u3bFRMTo6pVq0qS3NzcrPNXrlypChUqqG3btgWuv3PnTrm5uSk4OFienp665ZZbdODAAVWuXFmVKlXS7t27lZGRoa+//lqStHfvXoe3CWXLtRyjthyHgwYNUt26dfXZZ59p1KhRatOmjWMbVILuvPNODRgwQAMGDNCuXbvk4eGhwYMHS5KWLFmiV155RQ888IAef/xxSdKOHTsK3M7QoUMVGxurzp0766abbpIkVahw4Ve68+fPa9iwYYqLi1ONGjWKoVUoixx13pfnz6Zr/byfO3euatasqXbt2mncuHHq0qWLRowYkW8Zb29veXh4qH///jp16pTD2lLqFHOwzmf69OnGy8vL3HDDDWbgwIHGGGOuu+66fMtUrVr1itvhCi0AZzVo0CAjyWzevPmSeSNHjjSSrHetFMTb29tIMpMmTTIvvviikWTuueceY8yFn7EuLi5GkqlcubKRZEaPHu2wtqBsutZj9ErH4datW82SJUtMeHi48fb2Njt27HBIO0qTr7/+2kgyQ4cOLXB+jx49TIUKFUx6enqh2+jZs6eRZCSZUaNGWafPnDnT1K1b1xw/ftzUrVuXK7S4Ko4878vrZ9O19mlcXJxxcXExb7zxhhk1apSRZKZPn26MMSY1NdXMmzfPfPzxx+auu+4ykszEiRMd1paSUljmK7FAm52dbTp16mQOHz5szpw5Y3r27GnefvttmwPtvHnzTHh4uAkPDzd16tQphooBwL6OHDliKlWqVOAP6Mcee8xIMmPGjMk3/ezZs+b06dPm3LlzxpgL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Jnt/LkEqf/egOKGhQ4fquuuuU2hoqNatW3fV2/nXv/6lY8eO6Y033rBfcU7CGKP7779fwcHBGjly5GWXXbRoUb7vo6OjlZSUpPj4eCUlJalnz56OLNVpXEufFiY6OloDBw7UyJEjdfDgQWVkZKhVq1b2KLfUc8QxevToUXXv3l2TJ09W27ZtHVZ7aXUtfbpixQq99NJLWr9+vTw9Pa3TOUbte86Xd4447/fu3avatWvL1dVVv/76q3788UcFBAQ4qgmlyrX0Z0ZGhoKCgiRJH3/8sRo1aiSpfJ/zkmPO+/L82eSIzyVIMii1vLy8Lpm2du1a0717d2OMMYsWLTJeXl6mVq1a1q/9+/ebunXrmqysrHzr7d+/30gyjRo1MmFhYSYsLMzMnz+/WNpRGnz11VdGkgkNDbW2/7PPPjOxsbGmWrVq1v5r06bNJev+8ccf5rbbbjP169c3t912mzly5Ih1Xt26dc31119v/f+wY8eO4mxWibqWPl26dKmpVauWcXNzM76+vub222+3znvhhRdMvXr1TIMGDcznn39enE0qUY44Rp9//nnj6elp3V5YWJg5dOhQcTetxFxLnwYGBhp/f3/reg8++KB1Hseofc95fo7a97x/6623TOPGjU1YWJhp3ry5+eijj4q5VSXnWvqzd+/eJiQkxISGhpoePXqYAwcOWOeV13PeGMec9+X5s8lRn0vl+eeoMcZYjCng4QAAAAAAAEo5nqEFAAAAADglAi0AAAAAwCkRaAEAAAAATolACwAAAABwSgRaAAAAAIBTItACAFCGvPnmm7JYLFf93vJ169bJYrHozTfftGtdAAA4AoEWAAA7uhgILRaLHnnkkQKXOXz4sNzc3GSxWNSxY8fiLRAAgDKEQAsAgANUqlRJ7733nv76669L5r399tsyxsjV1bUEKgMAoOwg0AIA4AC9evVSTk6OUlNTL5m3aNEidevWTe7u7iVQGQAAZQeBFgAAB2jRooXCwsK0aNGifNM3b96sHTt26L777itwvWXLlqlt27by9vaWt7e32rZtW2AolqQ33nhDjRo1kru7u+rXr68ZM2bIGFPgsseOHdMzzzyj+vXry93dXT4+PoqJidEvv/xybQ0FAKAEca8TAAAOct9992nkyJE6cOCA/P39JUkLFy6Ur6+vevToccnyr732mh5++GE1atRI//rXv6yDM911112aN2+e4uLirMtOnz5dTz75pMLCwvTiiy/q1KlTeuWVV+Tr63vJdo8dO6ZbbrlF//3vfzV06FCFhIQoMzNTr732mlq3bq20tDTVrVvXcR0BAICDEGgBAHCQe++9V08//bTeeust/d///Z9Onz6tlJQUDRs27JLnZ3NycvT0008rMDBQ33zzjapUqSJJGj58uJo3b65Ro0apX79+qlq1qo4eParnnntOwcHB+s9//iNPT09JFwJ0o0aNLqlj7Nix+uWXX7Rp0yaFhYVZpw8ZMkShoaEaN24coxoDAJwStxwDAOAg1atXV3R0tDUsLl26VMeOHdPQoUMvWXbVqlU6efKkHnvsMWuYlaQqVaro0Ucf1YkTJ7R69WpJ0sqVK3Xq1Ck9/PDD1jArSf7+/rrnnnvybdcYo3fffVft27dXrVq19Mcff1i/vLy81KZNG61cudIBrQcAwPG4QgsAgAPdd9996t69u77++mstXLhQrVq1UuPGjS9Zbu/evZKkkJCQS+Y1adJEkqzPu178b0FXY/+57aysLB05ckQrV66Uj49PgTVWqMDftwEAzolACwCAA3Xp0kW1atXShAkTtHbtWr3++usFLlfYYE6XW9ZisVxxOxe/79y5s5555hmb9wEAgDMg0AIA4EAuLi4aPHiwJk+eLA8PDw0YMKDA5QIDAyVJO3bsUGRkZL55O3fulCTVq1cv37K7du3Sbbfdlm/ZXbt25fvex8dHVatW1Z9//qnOnTtfe4MAAChFuMcIAAAHe+ihhzRu3DjNnTtX1113XYHLREVFycvLS7NmzdLx48et048fP65Zs2bJ29tbUVFR1mU9PDw0Z84cnTp1yrrsgQMH9N577+XbboUKFXTPPfdo8+bNWrJkSYH7Pnz48LU2EQCAEsEVWgAAHKxOnToaP378ZZepWrWqXn75ZT388MNq3bq1hgwZIkl68803tWfPHs2bN88ahq+//no9//zzGj16tG655RYNHjxYp06d0ty5cxUUFKQtW7bk2/akSZO0YcMG9evXT/369VObNm3k5uamX3/9VZ9//rnCw8MZ5RgA4JQItAAAlBIjRoyQn5+fXnnlFU2YMEGSFBYWpo8++kh33XVXvmVHjRolb29vTZ06Vc8++6xq166t0aNH67rrrrtkFOXrrrtOGzZs0JQpU/TBBx8oNTVVrq6u8vf3V7t27TRs2LDiaiIAAHZlMUUZhQIAAAAAgFKCZ2gBAAAAAE6JQAsAAAAAcEoEWgAAAACAUyLQAgAAAACcEoEWAAAAAOCUCLQAAAAAAKdEoAUAAAAAOCUCLQAAAADAKRFoAQAAAABO6f8B4WnFVJndI+AAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 1152x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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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
}
