{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b512a328",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using device: cuda:1\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.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 typing import Optional, Tuple\n",
    "gpu_id = 1 # 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",
    "        self.bns = torch.nn.ModuleList()\n",
    "        self.bns.append(torch.nn.BatchNorm1d(hidden_channels))\n",
    "        for _ in range(num_layers - 2):\n",
    "            self.lins.append(torch.nn.Linear(hidden_channels, hidden_channels))\n",
    "            self.bns.append(torch.nn.BatchNorm1d(hidden_channels))\n",
    "        self.lins.append(torch.nn.Linear(hidden_channels, out_channels))\n",
    "\n",
    "        self.dropout = 0.5\n",
    "\n",
    "    def reset_parameters(self):\n",
    "        for lin in self.lins:\n",
    "            lin.reset_parameters()\n",
    "        for bn in self.bns:\n",
    "            bn.reset_parameters()\n",
    "\n",
    "    def forward(self, data):\n",
    "        x = data.x\n",
    "        for i, lin in enumerate(self.lins[:-1]):\n",
    "            x = lin(x)\n",
    "            x = self.bns[i](x)\n",
    "            x = F.relu(x)\n",
    "            x = F.dropout(x, p=self.dropout, training=self.training)\n",
    "        x = self.lins[-1](x)\n",
    "        return 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",
    "        if isinstance(edge_index, Tensor):\n",
    "            cache = self._cached_edge_index\n",
    "            if cache is None:\n",
    "                edge_index, edge_weight = gcn_norm(\n",
    "                    edge_index, edge_weight, x.size(self.node_dim),\n",
    "                    False, True)\n",
    "                if self.cached:\n",
    "                    self._cached_edge_index = (edge_index, edge_weight)\n",
    "            else:\n",
    "                edge_index, edge_weight = cache[0], cache[1]\n",
    "\n",
    "        elif isinstance(edge_index, SparseTensor):\n",
    "            cache = self._cached_adj_t\n",
    "            if cache is None:\n",
    "                edge_index = gcn_norm(\n",
    "                    edge_index, edge_weight, x.size(self.node_dim),\n",
    "                    False, True)\n",
    "                if self.cached:\n",
    "                    self._cached_adj_t = edge_index\n",
    "            else:\n",
    "                edge_index = cache\n",
    "\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(GCNConv(in_channels, hidden_channels, cached=True))\n",
    "        self.convs.append(GraphConv(in_channels, hidden_channels, num_convs=num_convs[0], cached=True))\n",
    "        self.bns = torch.nn.ModuleList()\n",
    "        self.bns.append(torch.nn.BatchNorm1d(hidden_channels))\n",
    "        for _ in range(num_layers - 2):\n",
    "            # self.convs.append(GCNConv(hidden_channels, hidden_channels, cached=True))\n",
    "            self.convs.append(\n",
    "                GraphConv(hidden_channels, hidden_channels, num_convs=num_convs[_+1], cached=True))\n",
    "            self.bns.append(torch.nn.BatchNorm1d(hidden_channels))\n",
    "        # self.convs.append(GCNConv(hidden_channels, out_channels, cached=True))\n",
    "        self.convs.append(GraphConv(hidden_channels, out_channels, num_convs=num_convs[-1], cached=True))\n",
    "\n",
    "        self.dropout = 0.5\n",
    "\n",
    "    def reset_parameters(self):\n",
    "        for conv in self.convs:\n",
    "            conv.reset_parameters()\n",
    "        for bn in self.bns:\n",
    "            bn.reset_parameters()\n",
    "\n",
    "    def forward(self, data):\n",
    "        x, adj_t = data.x, data.adj_t\n",
    "        for i, conv in enumerate(self.convs[:-1]):\n",
    "            x = conv(x, adj_t)\n",
    "            x = self.bns[i](x)\n",
    "            x = F.relu(x)\n",
    "            x = F.dropout(x, p=self.dropout, training=self.training)\n",
    "        return self.convs[-1](x, adj_t)\n",
    "    \n",
    "# Function to train a model, 1 epoch.\n",
    "def train(model, data, train_idx, optimizer):\n",
    "    model.train()\n",
    "\n",
    "    optimizer.zero_grad()\n",
    "    out = model(data)[train_idx]\n",
    "    loss = F.cross_entropy(out, data.y.squeeze(1)[train_idx])\n",
    "    loss.backward()\n",
    "    optimizer.step()\n",
    "\n",
    "    return loss.item()\n",
    "\n",
    "# Function to evaluate a model.\n",
    "@torch.no_grad()\n",
    "def test(model, data, split_idx, evaluator):\n",
    "    model.eval()\n",
    "\n",
    "    out =  torch.log_softmax(model(data), dim=-1)\n",
    "    y_pred = out.argmax(dim=-1, keepdim=True)\n",
    "\n",
    "    train_acc = evaluator.eval({\n",
    "        'y_true': data.y[split_idx['train']],\n",
    "        'y_pred': y_pred[split_idx['train']],\n",
    "    })['acc']\n",
    "    valid_acc = evaluator.eval({\n",
    "        'y_true': data.y[split_idx['valid']],\n",
    "        'y_pred': y_pred[split_idx['valid']],\n",
    "    })['acc']\n",
    "    test_acc = evaluator.eval({\n",
    "        'y_true': data.y[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": 9,
   "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-.32, 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": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Working on ogbn-arxiv: Classes = 40 | Points = 169343 | Features = 128\n",
      "Trial: 10 with 3L-300, Epoch: 500, Loss: 0.8506, Train: 76.75%, Valid: 72.52% Test: 70.87%           METRICS FOR DATASET: OGBN-ARXIV\n",
      "+------------+--------------+----------------+\n",
      "| Model Name |   Accuracy   | Accuracy (max) |\n",
      "+------------+--------------+----------------+\n",
      "|    MLP3    | 55.69 ± 0.18 |     55.88      |\n",
      "|   3L-001   | 68.40 ± 0.25 |     68.77      |\n",
      "|   3L-010   | 68.88 ± 0.25 |     69.26      |\n",
      "|   3L-100   | 67.97 ± 0.18 |     68.28      |\n",
      "|   3L-011   | 71.84 ± 0.27 |     72.19      |\n",
      "|   3L-110   | 71.68 ± 0.22 |     72.01      |\n",
      "|   3L-002   | 71.68 ± 0.27 |     72.12      |\n",
      "|   3L-020   | 71.93 ± 0.17 |     72.23      |\n",
      "|   3L-111   | 71.84 ± 0.30 |     72.47      |\n",
      "|   3L-021   | 71.80 ± 0.16 |     72.10      |\n",
      "|   3L-012   | 72.06 ± 0.21 |     72.44      |\n",
      "|   3L-102   | 71.97 ± 0.20 |     72.22      |\n",
      "|   3L-003   | 71.83 ± 0.23 |     72.13      |\n",
      "|   3L-030   | 72.37 ± 0.24 |     72.85      |\n",
      "|   3L-300   | 71.60 ± 0.31 |     72.04      |\n",
      "+------------+--------------+----------------+\n"
     ]
    },
    {
     "data": {
      "image/png": "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+aV5++23b9nOjRo1Ml999ZW5fv26ad++vVm9erUdsvrD3eS2a9cus3v3btOyZUvz7bffWqfnte0cmZsxjt92rrRv5rb93GHfzO/nyoULF8znn39ujDHm8uXLpnnz5i65b3733XfmyJEjxhhjfvrpJ1O5cmXrMq6y7e5kv3Sl4+5Otp075Jfb9nP0sefIc567fK7kdU535LWnPXK7cOGCuXr1qjHGmKNHjxofHx/r7650vXJjOxhjzFtvvWX+8Y9/GGMK1/WYvXGH1ok6dOigf//735KkxMRE9e7dO1/Lt2jRQnv37pUklSlTRtIfd3qvXLkii8VSsMHmwWKxWP9yfPXqVV29etXm9SclJSk6OlqSFB0drZUrV1qnP/bYYypevLj+9re/qXr16tq2bZskqWnTpvLz8yv4RHJhj/y8vb3VvHlzlShRItv86enp+v3333X//ffLYrGoX79+1mXs4W5yCwkJUc2aNW+Zntu2c3RukmO3neRa+2Zu288d9s38fq54eXmpdevWkqRixYqpQYMGOnz4cMEndRN75Fe/fn3re9tDQ0OVmZmpy5cvu9S2y+9+KbnWcZffbSe5R365bT9HH3uOPOe5y+dKXtdjjrz2tEduXl5e8vT844UvmZmZ1v5c7XrlxnaQpAsXLliXK0zXY/ZGQetEjz32mJYsWaLMzEz9+OOPatKkSb6W//TTT1W3bl3r7+3atZOvr69Kly6t7t27F3S4ebp27ZrCw8Pl6+urqKgom3M5fvy49UTt5+enEydOSJKOHDmiKlWqWOcLCAjQkSNHCj5wGxV0frk5cuSIAgICrL87Iu87zS03uW07Z+QmOW7bOUtBb7/cuNK+eTefK2fOnNH//d//KTIysoCyyJ09983ly5erfv36Kl68uEttO1fhqG3nLM743HTUseeoc97NXPlz5Xb5OfLa0x775TfffKPQ0FDVrVtXc+fOlaenp8tdr0j/+2rCBx98oIkTJ0oqfNdj9kRB60T16tXTgQMHlJiYqI4dO9q8XOvWrRUeHq7ff/9dL774onX6Z599pvT0dF2+fDnb928cwcPDQ6mpqTp8+LC2bdumHTt23FV/Jodn+R151/nPCjq/3Dgjb0dtO2dtU0dtO2dh37Td7XLIyspS7969NWzYMFWrVu2u1mULe227nTt36oUXXtC8efMkuce2K2wcte2cxdHb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\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": [
    "dataset = PygNodePropPredDataset(name='ogbn-arxiv', root='./arxiv', transform=T.ToSparseTensor())\n",
    "data = dataset[0]\n",
    "data.adj_t = data.adj_t.to_symmetric()\n",
    "data = data.to(device)\n",
    "\n",
    "n_classes = dataset.num_classes\n",
    "n_points, n_features = data.num_nodes, data.num_features\n",
    "\n",
    "# Common variables.\n",
    "split_idx = dataset.get_idx_split()\n",
    "train_idx = split_idx['train'].to(device)\n",
    "\n",
    "n_trials = 10\n",
    "epochs = 500\n",
    "print('\\nWorking on ' + dataset.name + ': Classes =', n_classes, '| Points =', n_points, '| 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",
    "wspace = ' '*10\n",
    "for m, model_type in enumerate(model_types):\n",
    "    model = learners[model_type]\n",
    "    evaluator = Evaluator(name='ogbn-arxiv')\n",
    "    logger = Logger(n_trials)\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.01)\n",
    "        for epoch in range(1, 1 + epochs):\n",
    "            loss = train(model, data, train_idx, optimizer)\n",
    "            result = test(model, data, split_idx, evaluator)\n",
    "            logger.add_result(t, result)\n",
    "            if epoch % 5 == 0:\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",
    "print('\\rExperiment completed.', wspace*8)\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": 10,
   "id": "2a235e19",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "METRICS FOR DATASET: OGBN-ARXIV\n",
      "+------------+--------------+----------------+\n",
      "| Model Name |   Accuracy   | Accuracy (max) |\n",
      "+------------+--------------+----------------+\n",
      "|    MLP3    | 55.69 ± 0.18 |     55.88      |\n",
      "|   3L-001   | 68.40 ± 0.25 |     68.77      |\n",
      "|   3L-010   | 68.88 ± 0.25 |     69.26      |\n",
      "|   3L-100   | 67.97 ± 0.18 |     68.28      |\n",
      "|   3L-011   | 71.84 ± 0.27 |     72.19      |\n",
      "|   3L-110   | 71.68 ± 0.22 |     72.01      |\n",
      "|   3L-002   | 71.68 ± 0.27 |     72.12      |\n",
      "|   3L-020   | 71.93 ± 0.17 |     72.23      |\n",
      "|   3L-111   | 71.84 ± 0.30 |     72.47      |\n",
      "|   3L-021   | 71.80 ± 0.16 |     72.10      |\n",
      "|   3L-012   | 72.06 ± 0.21 |     72.44      |\n",
      "|   3L-102   | 71.97 ± 0.20 |     72.22      |\n",
      "|   3L-003   | 71.83 ± 0.23 |     72.13      |\n",
      "|   3L-030   | 72.37 ± 0.24 |     72.85      |\n",
      "|   3L-300   | 71.60 ± 0.31 |     72.04      |\n",
      "+------------+--------------+----------------+\n"
     ]
    },
    {
     "data": {
      "image/png": "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vKgvv/xSn3zyiaZOnaqpU6eqSpUq6tWrl5599lmVLl3anrG6hZCQEE2ePFkHDx5U0aJFFR0drXHjxt237c8GDhyo33//XbNnz1bevHnVp08fjRw5UtIfj4dPmDBBV69eVb169TR16lQVLFjQYTkCAAAAgCNka9SmwoUL64UXXtC6deu0b98+jRo1Sjdu3NBrr72m8uXLq1WrVtla+blz59SpUydVqVJFwcHB2rhxo86cOaPIyEgFBQUpMjJSZ8+ezVafuV2/fv20e/duXb16VceOHdPMmTPl7e1937ZRo0bJGKNOnTpJkvLmzavp06fr/PnzOnXqlGbPni0vLy9J0ptvvqmzZ88qLS1N69atU/Xq1Z2TLAAAAADY0QMPQ1y+fHkNHz5cv/32mz777DN5e3srMTExW33885//VKtWrbR7925t27ZNwcHBio2NVUREhFJSUhQREaHY2NgHDREAAAAA4MYeuKC9ePGi5s6dq6ZNm6pHjx66cOGCQkJCbF7+woUL+s9//qMXXnhBkpQvXz4VK1ZMCQkJioqKkiRFRUVp6dKlDxoiAAAAAMCNZaugNcZo5cqV6t69u0qVKqU+ffpo165dGjBggLZs2aJffvnF5r727dsnHx8fPf/886pZs6b69Omjy5cv6/jx4/Lz85Mk+fn56cSJE5kuP2vWLIWHhys8PFwnT57MThoAAAAAADdg86BQQ4YM0eeff67jx48rb968atu2raKiotSmTRt5etrcjVV6erp+/vlnTZkyRfXq1dM///nPbD1eHB0drejoaElipGUAAAAA+Auy+Q7txIkTVbZsWU2ZMkWpqalavHix2rdv/0DFrCT5+/vL39/f+lqaTp066eeff1bJkiWVmpoqSUpNTZWvr+8D9Q8AAAAAcG82V6M7d+5UlSpVcmzFpUqVUtmyZbVnzx5VrlxZa9asUdWqVVW1alXFxcUpJiZGcXFx6tChQ46tEwAAAADgPmwuaHOymL1typQpevbZZ3X9+nVVqFBB8+bN061bt9SlSxfNmTNH5cqV08KFC3N8vQAAAAAA15ft54WTkpL0448/6uzZs7p161aGNovFouHDh9vcV1hYmJKSku6avmbNmuyGBQAAAAD4i7G5oL169ao6duyoVatWyRgji8UiY4wkWf+d3YIWAAAAAIAHZfOgUGPGjNGqVas0bNgwrV27VsYY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uZI998vPkdee9tgv69Wrpx07duinn37S+PHjlZaW5pLXK+PGjdOhQ4f07LPPaurUqZJy3/WYPVHQOln79u01ZMiQbD1uvHbtWiUnJ+uTTz5RsWLFMrQVKFBA7du3V0JCQg5HaptixYqpadOmWrlyZabtzz//vMLCwqwFfMmSJZWamirpj0c8fH19Jf3x16JDhw5Zlzt8+LD1cSxnyqn8suLv75/hkSRH5p3d3LKS1bZzZm6S/beds+XU9suKK+2bD/q5Eh0draCgIL388st2yiRzOblvHj58WE899ZQ++eQTBQYGSnKtbedq7L3tnM1Rn5vOOPbsfc67zdU/V2y5HnP0tac99svg4GB5e3tr+/btLne9cqfu3btr8eLFknLv9Zg9UNA6We/evTVixIgMjw5n16VLl6wHanp6upYvX64qVarkVIj3dfLkSZ07d06SdPXqVa1evTrL9c+bN0/Jyclavny5pD8K+ri4OElSXFycOnToYJ2+YMECXbt2Tfv371dKSorq1q1r/2QyYY/8suLn56fChQtr06ZNMsbok08+ue8yD+NhcstKVtvO0blJjt12zmCP7ZcVV9o3H+Rz5c0339T58+c1adIku+V0J3vkd+7cObVt21bjx4/XY489Zl3elbadK3DktnMGR39uOvLYc+Q5T3KPz5Ws8nP0tac9ctu/f7/S09MlSQcPHtSePXsUEBDgctcrKSkp1rZly5ZZl8tN12N25+hRqPCHzEYrXLt2bYZRjr29vU2ZMmWsP4cOHcowyvFtx44dM+Hh4aZ69eqmatWqZsCAAdZR2hxh27ZtJiwszFSvXt2EhISY0aNHG2OMiYqKMo888og1/vr169+17KlTp0zz5s1NxYoVTfPmzc3p06etbWPHjjUVKlQwlSpVyjD62quvvmrKlCljLBaLKVOmjBk5cqRL5le+fHlTvHhx63besWOHMcaYn376yYSEhJgKFSqY/v37m1u3buXK3JYsWWLKlClj8uXLZ3x9fU2LFi2sbVltO0fm9rD5Pci2c6V9817bz9X3zex+rhw6dMhIMlWqVDGhoaEmNDTUzJ4922652Su/f/3rX8bLy8uaQ2hoqDl+/LgxxnW23YPsl6503D3ItnOH/IzJfPs5+thz5DnPXT5XssrP0dee9sjtk08+MVWrVjWhoaGmZs2a5quvvrIu40rXKx07djQhISGmevXqpl27dubw4cPWttxyPWZvFmNc/cVDAAAAAIC/Ih45BgAAAAC4JApaAAAAAIBLoqAFAAAAALgkCloAAAAAgEuioAUAAAAAuCQKWgAA3MjHH38si8Wi77777oGW/+6772SxWPTxxx/naFwAANgDBS0AADnodkFosVg0YMCATOc5ceKE8uXLJ4vFoqZNmzo2QAAA3AgFLQAAdlCgQAF9/vnnunbt2l1t8+fPlzFGnp6eTogMAAD3QUELAIAdPPXUUzp79qwSEhLuaps3b57atGmj/PnzOyEyAADcBwUtAAB2UKtWLYWGhmrevHkZpm/evFk7duzQ888/n+lyS5cu1WOPPaZChQqpUKFCeuyxxzItiiXpo48+UpUqVZQ/f35VrFhRH3zwgYwxmc57/vx5vfbaa6pYsaLy588vHx8fdevWTfv27Xu4RAEAcCKedQIAwE6ef/55DRo0SIcPH5a/v78kae7cufL19VW7du3umn/69Onq37+/qlSpojfffNM6ONOTTz6pmTNnKjo62jrvpEmT9Morryg0NFRvvfWWrly5onfffVe+vr539Xv+/Hk1bNhQ//3vf9W7d2+FhIQoNTVV06dPV7169ZSUlKTy5cvb738EAAB2QkELAICdPPfccxo6dKg++eQTvfHGG7p69aoWLFigPn363PX92bNnz2ro0KEKDAzUjz/+qCJFikiS+vbtq5o1a2rw4MHq0qWLihUrpnPnzmnYsGEKDg7WDz/8IC8vL0l/FNBVqlS5K44RI0Zo37592rRpk0JDQ63Te/XqperVq2vkyJGMagwAcEk8cgwAgJ2UKFFC7du3txaLS5Ys0fnz59W7d++75k1MTNTly5c1cOBAazErSUWKFNFLL72kS5cuafXq1ZKkVatW6cqVK+rfv7+1mJUkf39/Pfvssxn6Ncbos88+U+PGjVWmTBmdOnXK+uPt7a369etr1apVdsgeAAD74w4tAAB29Pzzz6tt27Zav3695s6dq7p166pq1ap3zbd//35JUkhIyF1t1apVkyTr911v/zezu7F/7vvkyZM6ffq0Vq1aJR8fn0xjzJOHv28DAFwTBS0AAHbUsmVLlSlTRqNHj9batWv14YcfZjpfVoM53Wtei8Vy335u//7EE0/otddes3kdAAC4AgpaAADsyMPDQz179tT48eNVsGBBPfPMM5nOFxgYKEnasWOHIiIiMrTt3LlTklShQoUM8+7atUvNmzfPMO+uXbsy/O7j46NixYrpwoULeuKJJx4+IQAAchGeMQIAwM5efPFFjRw5UjNmzFDRokUznScyMlLe3t6aMmWKLl68aJ1+8eJFTZkyRYUKFVJkZKR13oIFC2ratGm6cuWKdd7Dhw/r888/z9Bvnjx59Oyzz2rz5s1atGhRpus+ceLEw6YIAIBTcIcWAAA7K1eunEaNGnXPeYoVK6Z33nlH/fv3V7169dSrVy9J0scff6y9e/dq5syZ1mK4ePHi+te//qUhQ4aoYcOG6tmzp65cuaIZM2YoKChIW7duzdD3uHHjtGHDBnXp0kVdunRR/fr1lS9fPh08eFDLly9X7dq1GeUYAOCSKGgBAMgl+vXrJz8/P7377rsaPXq0JCk0NFRfffWVnnzyyQzzDh48WIUKFdLEiRP1+uuvq2zZshoyZIiKFi161yjKRYsW1YYNGzRhwgR9+eWXSkhIkKenp/z9/dWoUSP16dPHUSkCAJCjLCY7o1AAAAAAAJBL8B1aAAAAAIBLoqAFAAAAALgkCloAAAAAgEuioAUAAAAAuCQKWgAAAACAS6KgBQAAAAC4JApaAAAAAIBLoqAFAAAAALgkCloAAAAAgEv6/wCd4/Hp55gq1gAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 1152x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA7QAAAEOCAYAAAC5CVuUAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAABA6UlEQVR4nO3deXxMd////+cIgtg1IQRpIohQUbFU1ZbGvlSrtiKqPqmterV6abrYWiq62NdYItWWqxTxbamtXG1dVFVTFdRSeknFUrETJN6/P/ozlzSLCZlMZvq4325za3PeZ3m9vM+cOa85Z97HYowxAgAAAADAyRRwdAAAAAAAANwLCloAAAAAgFOioAUAAAAAOCUKWgAAAACAU6KgBQAAAAA4pYKODiA3PPDAA/L19XV0GAAAAAAAOzh27Jj++OOPDNNdoqD19fXVrl27HB0GAAAAAMAOQkJCMp3OLccAAAAAAKdEQQsAAAAAcEoUtAAAAAAAp0RBCwAAAABwShS0AAAAAACnREELAAAAAHBKFLQAAAAAAKdEQQsAAAAAcEoUtAAAAAAAp0RBCwAAAABwShS0AAAAAACnREELAAAAAHBKFLQAAAAAnIKvr68sFku6V//+/SVJ48ePV0BAgIoWLaoqVapo8uTJWa5n9+7datKkiTw8PFS2bFk9/fTTunDhgiRp7NixGbYRHx+fB9nhXlDQAgAAu8itE8/bRo8eLYvFouLFi1un/XX9FotFY8eOtVNGfx950Xe2tAF/NWPGDC1dulRLly7V008/LUl6+OGHJUk7d+7UE088oenTp6tw4cIaMWKE/v3vf2e6nhdeeEHbt2/Xq6++qubNm2vFihWaPn16unlub2fp0qXy9fW1a164dw4taKdMmaKgoCDVrl1bvXr1UkpKipKTkxUWFqaAgACFhYXp3LlzjgwRgIvIrZOzdevWqU6dOipQoIAsFov++OMPa9uBAwfUsmVLeXh4yN/fXytXrrR3WpJyL7dLly6pV69e8vDwUIUKFfT+++9b27LL297you+GDRsmX19fFSlSRNWrV9fHH39s77Ssciu/7HKYNGmSKlSooMKFC6ty5cp5VvDl1omnJCUkJOi9995TkSJF0k2/84SzRYsW6bZhb3mxbzpKXvTd3drsKS/ed65wXMlu33TUcaVTp07q2bOnevbsqf3796to0aLq16+fJGnFihV677339H//93968cUXJf25j2Xm1q1bslgsCg0NVb169SRJpUuXTjdP586d9fTTT6tnz54Z2uwlLz7Tb3OZL5OMgyQmJhpfX19z9epVY4wxTz/9tImJiTH//Oc/zcSJE40xxkycONGMHDnyruuqX7++XWMF4PzWrFljli5dapYuXWqefvppI8lMmzbNGGNMp06dzCuvvGKio6ONv7+/kWS2bt2a6XpWrFhhhgwZYqpVq2YkmTNnzljbateubTw8PMysWbNMSEiIcXd3NydOnHCa3IYPH24kmTFjxpgnnnjCSDKbN2++a97Okl92OTRs2NCMHj3azJo1y3h6eho3Nzdz5MgRp8ovuxwWLlxoZsyYYRYuXGhq1aplJJlt27blSX631a5d2xQtWtScO3fOGGPM9evXrW3Tp083ksysWbMyXTYtLc00btzYDB8+3FStWtV4eHhkmCclJcWUK1fO+Pj4mNTUVLvk8Fd5sW/mB/bqO1v61V7y4n3nCseV7PZNRx9Xvv32WyPJDBgwINP2jh07mgIFCpj4+PhM2+Pj4423t7eRZCSZNm3aWI8dY8aMMZKMxWIxhQoVMt27dzdXrlyxWy53yovPdGOM2bt3rylSpIgpUqRInr737kdWNZ9DC1ofHx9z9uxZc/PmTdOhQwezfv16U716desJ4IkTJ0z16tXvui4KWgA5cT8nZ7c1b9483Yf72bNnjSTz+OOPG2OMmTt3rpFkPvjgA/skkYX7ya1UqVKmVq1axhhjjhw5YiSZPn36pJvnr3nnNXv03V/X8/LLLxtJ5osvvsjd4G1wP/ndLYeLFy+a3377zXTo0MFIMtu3b7dPEpm43xPP6dOnm6pVq5pLly5lWfh89NFHRpJ56623cjV2W9lr33Q0e/adLf2aF+z1vnOF48ptWe2bjjyu9O3b10gyO3fuzNB2+9/79kWyzERERBg3NzezYMECM2LECCPJTJ061RhjTFxcnJk3b55Zs2aNtRh0xLHFXp/pjvwy6X7ku4LWGGOmTp1qPDw8zAMPPGB69+5tjPnzH/9OpUuXznTZefPmmfr165v69eubKlWq2DtUAC7ifk/Obvvrh/uNGzdMkSJFjI+Pjzl48KDp06ePkWSGDRuW6zlk5X5yu12Qh4WFGWP+/NCUZJo0aZJuPkeecNur7+5048YNU69ePVOsWDFz8uTJXInbVrmVX1Y5dOnSxXolYsSIEbka+93cz4nnuXPnTPHixc3MmTPNoUOHTKVKlUyxYsXM4cOH08332GOPmYIFC+bJXRF/lRf7pqPYq+9s7Vd7s/f77m5t9mbvfdNRx5WzZ8+aIkWKZFrg3L4yOWrUqHTTb968aa5du2bS0tKMMcYULVrU+Pv7G2OMOX78uJFk2rdvn2F9e/bsMZJMz5497ZBJ1uz5mZ5fvkzKqXxX0CYnJ5uWLVua06dPmxs3bpguXbqYJUuW2FzQ3okrtABsdb/f6N6W2Yf71KlTjZubm5FkSpQoYSSZV155JVfjz8795PbXD7+UlBQjyTz66KPp5nPkCbc9+86YP092unfvbiwWi/n4449zLW5b5UZ+2eXw008/mRUrVpj69eub4sWLm4SEhFyNPyv3e+J59OhR6wnznS83Nzfr/AkJCUaSeeqpp+yeT2bsvW86ij37zpZ+zQv2ft+5wnHFmKz3TUcdVyZPnmwkmfnz56eb/uqrrxpJpmHDhtbbdn/++WdjzP9uI16+fLkx5s+rnxaLxURFRZlnn33WSDIvvfSSMcaYbt26mXHjxpmYmBgTGhpqJJkpU6bkSW632eszPb98mXQv8l1B++mnn6b7xiE2NtYMHjyYW44B2E1ufKN7W1Yf7omJiWb79u1m/vz5RpJZtGhR7ieSidzIrVSpUiYwMNAYk/9uObZ33924ccM8+eSTxmKxmOjoaPskkY3cyM/WHBYtWmQkmffeey93k8jC/Z54XrlyxSxfvtz68vT0NEWKFDGfffaZdV23/402btyYJzndKS+OK45iz76zpV/tzd7vO1c4rtx2t30zr48rNWvWNCVLljSXL19ON/12nHe+xowZY4zJWNB+//33pkmTJsbDw8OULVvW9OjRwyQnJxtjjBk1apR58MEHjbu7u6lcubKJjIzMs9/mG2Pfz/T88mXSvch3Be2OHTtMrVq1zJUrV8ytW7dMv379zPTp080rr7ySblCof/7zn3ddFwUtAFvkxje6Bw8eNPPnzzfVq1e3fmP7+eefG2OMmT17tpkzZ46ZMmWK8fLyMpUqVbIOfOcMub3wwgtGkhk7dqz1N0ObNm26a97Okl92OfTo0cNIMh06dLCu59dff3Wq/LLLoX379mby5MkmOjra1KxZ00h591u+3DjxvNNfb4+7evWqKVOmjKlWrZq5deuWXXPJjL33TUeyd9/Z2mYv9n7fucJxJbt905HHFVdnz8/0/PBl0r3KdwWtMcaMHj3a1KhRwwQFBZk+ffqYlJQU88cff5hWrVqZatWqmVatWpmzZ8/edT0UtMhLK1euNLVq1TKFCxc2Pj4+5l//+pcxxpjff//ddO7c2ZQoUcJUrFjRzJ49O8t1DB061FStWtW4u7ubgIAA89FHH6VrnzNnjvHz8zOFCxc2fn5+5uuvv7ZrTn8XuXFyFhMTk2He5s2bG2OMefvtt03p0qWNu7u7adasmdmzZ49T5XbhwgXTvXt3U7RoUePl5WWioqKs68ku77xg776rWrVqhraYmBinyi+7HDp27GjdNwMCAszkyZPzLDdXZ+99E/Zj7/edKxxXsts3Oa7Yj70/0+/kCr+htRhjjJxcSEiIdu3a5egw8P9btWqV3nzzTR0+fFheXl764IMP1L17dx09elTPP/+8duzYIUl65JFHNH/+fFWpUiXDOiwWS4ZpY8aM0dixY7Nts7f4+HjVr19fQUFBGjZsmM6cOSM/Pz/16tVLnTp10hdffKH33ntPGzdu1Pr16/XDDz9k+jzERo0aqW3btipfvrzGjh2r5ORkHTx4UH5+flqzZo26dOmiZs2aqW/fvjp27Jhatmyp0NBQu+cHAAAA5EdZ1XwFHRALXFh8fLy6deumoKAgzZgxQ2fOnFFaWpok6c0339TGjRs1bNgwpaSkaMGCBRo3bpwWLlyYYT1Lly61/v+8efO0detWa2GYXZu9TZ48Wbdu3dLKlStVqVIlFS1a1Nq2detW+fv7a8SIEapdu7bWr1+vxYsXZxrbN998o8KFC0uSjhw5osmTJ+vAgQPy8/PT+++/r2LFimnNmjVyd3fP84fNAwAAAM6igKMDgGu5s+Dr27ev3njjDfXq1UuSdOvWLUnSY489piZNmkiSSpcunel6evbsqZ49e6pr1676+eef5ePjow4dOty1zd727dunQoUKqV27dipWrJhq166tn3/+WZLk5eWlEydOaM+ePdq6dask6ejRo5mu53Yxe/PmTW3ZskXFihVT/fr1rdsoXLiwAgMDVaxYMTVp0kSJiYn2T05/Xl0PCgqSu7u7KleurE8//dSaR+vWrVWyZEmVLFlSbdq00X//+99M1zFs2DD5+vqqSJEiql69uj7++GNr2+7du9WkSRN5eHiobNmyevrpp3XhwoU8yQ0AAACuh4IWuSq7gi8qKko1a9ZUjx49NGDAAAUHB2vcuHHZrm/FihU6e/asIiIi5ObmZnObvVy/fl03b95U+/btNX/+fO3fv1+DBw+WJE2aNEm3bt1S3bp1NWvWLEnK9upqamqq+vTpo/j4eM2fP1/ly5e3buP8+fMaNmyYJkyYoO3btysyMtLuud2+uu7m5qYZM2Zo0KBBGa6uh4eHq0ePHtqwYUOWfff9998rPDxckydP1vnz5xUeHq5ff/1VkvTCCy9o+/btevXVV9W8eXOtWLFC06dPt3tuAAAAcE3ccoxcdWfBV6dOHT3//PMaPHiwvv32W33yySc6cOCAJk2aJIvFopEjR2rUqFGaMmVKluubN2+eChYsqIEDB+aozV58fX21d+9eDRkyRDVq1NCoUaN05MgRSVK3bt3UvHlzHT58WOfOnVOHDh1Uq1YtSX8Wr6mpqSpcuLAKFCigmzdvqmfPnlq1apXmzZun3r17Z9jGiBEjJEmvv/66dRv2lN3t1HdeXb9y5YoWLFiQ5dX17G6nvnXrliwWi/X3wKtXr85yPQAAAMBd5enQVHbCKMf5R8eOHY0kc+DAAWOMMRUqVDAVKlQwxhgTGBhoChYsaJ23YMGCplatWsaYzJ97lpCQYCSZp556KsN2smuzpxUrVhhJpl+/fmbixIlGkunevbsxxphly5aZadOmmTlz5phq1aqZYsWKmaSkJGNMzob5f//9940kM2LECDNixAgjyYwcOdLuudWvX98UKlTIVKtWzUgyQUFB1lF6jx07Zh2SX5IJDg42ly5dynZ9N27cMPXq1TPFihUzJ0+eNMYYEx8fb7y9va3radOmTZ4+1w0AAADOKauaj1uOkav69+8vSXrnnXcUFRWlkydPqlmzZpIkf39/paamauTIkXr11VeVmpqqGjVqSJLGjx+vokWLauXKldZ1zZs3T5I0aNCgDNvJrs2ennrqKY0ePVpffPGFoqKi1K1bN82cOVOSdOXKFY0fP17Dhw9XyZIltXbtWlWoUCHT9dwe6fmLL75Qr1691KtXL/373/+WJA0fPlyDBw/W/PnztXjxYg0cOFBjxoyxe27Z3U5959X1d999V/Hx8Ro1alSW68rqdurZs2fr9OnTWrBggUaMGKH169db//0AAACAnOKxPch1Y8aM0axZs5SamqqwsDDNnj1bnp6eOnLkiIYMGWIt5h599FHNmTNHVatW1dixYzVu3DgtX75c3bp107Vr11SpUiWVK1dOBw8eTPeonuzacO86deqkzz//XAcOHFCNGjXk7e0tSUpKSlKtWrV06NAh3bx5U5JUqFAhVa9eXQkJCXe9nfr//u//rNsoVqyYKlasqMOHDysxMVGVK1dW+/bt9cUXXzgkZwAAADgHHtuDPDNu3LhMBwzy9/fX+vXrM11m7Nix6Z4jW7RoUSUnJ2c6b3ZtuHf9+/fX559/rnfeeUeBgYE6efKkunfvLunPvtu/f79Gjhwpi8WS4er6nV9G9O3bVytXrlSHDh1UokQJLVu2TI0aNdKDDz4of39/JSQkaNKkSfrll18kyboeAAAAIKcoaAFI+t/t1LNmzVJcXFy626mnTp2qGzduWG/1bteuXZaDed15O/XtK68xMTF68MEHFRMToxdffFFvv/223N3d1aNHj2xvXQYAAACywy3HAAAAAIB8Lauaj0GhAAAAAABOiYIWAAAAAOCU+A0tAAAAgHyr3f52jg5BkrQucJ2jQ0AmKGgBuKyQl/c7OgTtmhzo6BCckqv3nSvn5+onnvkhP1fOTXLt/OxZELl6fkBWKGgBwAnlh4JIomAHAOB+8WXE/eE3tAAAAAAAp+SwgvaXX35RcHCw9VWyZElNnTpVycnJCgsLU0BAgMLCwnTu3DlHhQgAAAAAyMdsvuX44MGD2rp1qxISEnT69GlZLBZ5enqqdu3aat68uapXr56jDdeoUUPx8fGSpLS0NFWqVEldu3ZVVFSUQkNDFRkZqaioKEVFRWnSpEk5WjcAAAAAwPVlW9CmpKQoJiZG8+bN088//yxjTKbzWSwW1alTR4MGDVL//v1VpEiRHAWxefNm+fv7q2rVqoqLi9PWrVslSeHh4WrRogUFLQAAAAAggyxvOV6yZImqV6+uYcOGqXTp0nrnnXe0detWHT9+XFevXtWVK1d0/PhxbdmyRRMmTFDJkiU1dOhQVa9eXR999FGOgli2bJl69eolSTp16pS8vb0lSd7e3jp9+nSmy0RHRyskJEQhISE6c+ZMjrYHAAAAAHB+WV6hHTRokAYNGqThw4eratWqmc5TqVIlVapUSc2bN1dkZKR+++03TZ06VYMGDVKfPn1sCuDGjRtas2aNJk6cmKPAIyIiFBERIUkKCQnJ0bIAAAAAAOeXZUF75MgRVahQIUcrq1q1qqZMmaLIyEibl1m3bp0efvhhlS9fXpJUvnx5JSUlydvbW0lJSfLy8spRDEBu29/O8UOpB65z3qHUAQAAAHvJsqDNaTF7p9vFqS2WLl1qvd1Ykjp37qzY2FhFRkYqNjZWXbp0uec4kDco+AAAAAA4gs2jHO/fv1+BgYHZzrNq1Sp17drV5o1fvXpVGzdu1Lx586zTIiMj1b17dy1cuFBVqlTR8uXLbV4fgJzJD19GSHwhAQAAgHtj83NoGzRooAULFmTadv36dQ0aNEjdunXL0caLFSums2fPqlSpUtZp5cqV0+bNm3Xo0CFt3rxZZcuWzdE6AQAAAAB/DzYXtA8//LCef/559ejRQxcvXrROT0hIUEhIiKKjozV48GC7BAkAAAAAwF/ZXNBu3bpVb7zxhj777DPVq1dP27dv15w5c9SgQQMlJSVp1apVmjlzpj1jBQAAAADAyubf0BYoUEBvvfWWQkND1adPHzVt2lSS9Nhjj+mjjz6Sj4+P3YIEAAAAAOCvbC5obytSpIgKFSokY4wkqVq1anrggQdyPTAAAAAAALJj8y3HkjRp0iQ1a9ZMaWlp2rhxo4YNG6ZFixapQYMGSkhIsFeMAAAAAABkYHNB26ZNG7322mtq166d4uPjFRoaqunTpysuLk5JSUlq2LChoqOj7RkrAAAAAABWNhe0X3/9taZPn67Vq1erTJky1umdOnXSnj171KBBA0Y5BgAAAADkGZsL2u3bt2vYsGGZtlWsWFFbtmzR2LFjcysul7V48WJZLJZ0r9WrV9+17a92796tJk2ayMPDQ2XLltXTTz+tCxcu3LUNAAAAAFyFzYNCBQcHZ9tusVg0atSo+43nb2P69Ony9PSUJDVo0MDmttteeOEFbd++XePGjdOPP/6oFStW6KGHHtKoUaOybQMAAAAAV5HjUY6RO8LCwuTv769ChQrlqO22W7duyWKxKDQ0VJK0evVqlS5d+q5tAAAAAOAqcjTK8bZt29SxY0d5enqqYMGCcnNzS/cqWJD62Fa1atVS0aJF1bp1a506dcrmttvmzp2rChUqqGnTphozZozatGmjIUOG3LUNAAAAAFxFjgaFatmypb777js1atRIt27dUsuWLdWgQQMZY1S7dm317dvXnrG6hGrVqmn69Olas2aNBgwYoI0bN+r111+/a9tfzZ49W6dPn9aCBQs0YsQIrV+/XjNnzrxrGwAAAAC4CpsL2gkTJsjb21v79u3T4sWLJUmvv/66duzYoS+//FJHjx7VwIED7RWny2jatKleeOEFdezYUR988IEkad++fXdtS01NVUpKim7duiVJWrJkiXx9ffXcc8/pH//4hyRpw4YNd20DAAAAAFdh8z3CO3fu1MsvvyxPT08lJydLkrW4at26tfr27atRo0bpq6++sk+kLmLo0KEqVaqUqlevrnXr1kmSGjVqdNe28ePHa9y4cVq+fLm6desmf39/JSQkaNKkSfrll18kSTVq1JCkbNsAAAAAwFXYXNBev35dlSpVkiS5u7tLki5dumRtDw4O1kcffZTL4bmeoKAgTZ8+Xb/99ptKlSqliIgITZgw4a5tfxUTE6MXX3xRb7/9ttzd3dWjRw/rKMbZtQEAAACAq7C5oPX29lZiYqIkycPDQ6VLl9bevXvVtWtXSVJiYmKOB4U6f/68Bg4cqL1798pisWjRokWqUaOGevTooWPHjsnX11effvqpypQpk6P15mdDhgzJcoCm7NrGjh2b7jm/ISEh2rZtW6bzZtcGAAAAAK7C5t/QNmjQIF2R1Lp1a02ZMkUffvihFi9erJkzZ1pvj7XViy++qLZt2+rAgQP66aefFBgYqKioKIWGhurQoUMKDQ1VVFRUjtYJAAAAAPh7sLmgfe655/TAAw/o2rVrkqR33nlHRYsWVf/+/TVgwAC5u7vr3XfftXnDFy9e1Ndff63nnntOklS4cGGVLl1acXFxCg8PlySFh4dr9erVOUgHAAAAAPB3YfM9wmFhYQoLC7P+7efnp4MHD2rz5s1yc3NT06ZNVapUKZs3/Ouvv8rT01PPPvusfvrpJ9WvX1/Tpk3TqVOn5O3tLenP25xPnz6dg3QAAAAAAH8XNl+hzYyHh4c6d+6sDh065KiYlf58DM3u3bs1ePBg/fjjj/Lw8MjR7cXR0dEKCQlRSEiIzpw5k9PQAQAAAABO7r4K2vvh4+MjHx8f6+9uu3Xrpt27d6t8+fJKSkqSJCUlJcnLyyvT5SMiIrRr1y7t2rVLnp6eeRY3AAAAACB/yFFB+8knn+jRRx+Vl5eX3NzcMrxyMspxhQoVVLlyZetzUjdv3qxatWqpc+fOio2NlSTFxsaqS5cuOQkRAAAAAPA3YXMFOn78eI0ZM0bly5dXkyZNcuVROjNmzNAzzzyjGzduyM/PTzExMbp165a6d++uhQsXqkqVKlq+fPl9bwcAAAAA4HpsLmhnz56tFi1a6Msvv1ShQoVyZePBwcHatWtXhumbN2/OlfUDAAAAAFyXzbccX7x4Ud27d8+1YhYAAAAAgPthc0Fbr149HT9+3J6xAAAAAABgM5sL2vHjx2vu3LnavXu3PeMBAAAAAMAmNv+Gtnnz5lq4cKEaN26sRx55RL6+vnJzc0s3j8Vi0cKFC3M9SAAAAAAA/srmgva7775T//79lZqaqm+++UbffPNNhnkoaAEAAAAAecXmgvbFF19UoUKFFBcXp8cee0ylS5e2Y1iup2/fvo4OQUuWLHF0CAAAAACQa2wuaPfs2aOxY8eqU6dO9owHAAAAAACb2DwolJeXlwoXLmzPWAAAAAAAsJnNBe2AAQP00UcfKTU11Z7xAAAAAABgE5tvOW7atKk+//xzNW7cWEOGDNGDDz6YYZRjSWrWrFmuBggAAAAAQGZsLmgff/xx6/8PHDhQFoslXbsxRhaLRWlpabkXHQAAAAAAWbC5oI2JibFnHAAAAAAA5IjNBW14eLg94wAAAAAAIEdsHhQKAAAAAID8JMuCdvPmzfe80k2bNt3zsgAAAAAA2CLLgrZt27Zq1aqVPv/8c5sGerp586ZWrVql5s2bq3379rkaJAAAAAAAf5Xlb2h//PFHvfzyy+rcubMeeOABhYWFqWHDhvL391fZsmVljFFycrIOHTqkHTt26KuvvtK5c+fUunVrxcfH27RxX19flShRQm5ubipYsKB27dql5ORk9ejRQ8eOHZOvr68+/fRTlSlTJrfyBQAAAAC4iCwL2tq1a2vDhg3avn27Zs+erbi4OC1dujTTx/WULFlSTz75pAYPHqwGDRrkKIAtW7bogQcesP4dFRWl0NBQRUZGKioqSlFRUZo0aVIO0wIAAAAAuLq7jnL8yCOP6JFHHlFaWpp++OEH7du3T2fOnJHFYpGnp6dq166tevXqqUCB3BlfKi4uTlu3bpX058jKLVq0oKAFAAAAAGRg82N73Nzc1LBhQzVs2DDXNm6xWNS6dWtZLBY9//zzioiI0KlTp+Tt7S1J8vb21unTpzNdNjo6WtHR0ZKkM2fO5FpMAAAAAADnYHNBaw/btm1TxYoVdfr0aYWFhalmzZo2LxsREaGIiAhJUkhIiL1CBAAAAADkUw59Dm3FihUlSV5eXuratat27typ8uXLKykpSZKUlJQkLy8vR4YIAAAAAMinHFbQXrlyRZcuXbL+/4YNG1S7dm117txZsbGxkqTY2Fh16dLFUSECAAAAAPIxh91yfOrUKXXt2lWSlJqaqt69e6tt27Zq0KCBunfvroULF6pKlSpavny5o0IEAAAAAORjDito/fz89NNPP2WYXq5cOW3evNkBEQEAAAAAnIlDf0MLAAAAAMC9srmgnTBhgk6cOGHPWAAAAAAAsJnNBe2oUaNUtWpVderUSatXr1ZaWpo94wIAAAAAIFs2F7Q7duzQc889p2+++UZPPfWUfHx8FBkZqYMHD9ozPgAAAAAAMmVzQduwYUPNnTtXSUlJiomJUfXq1fXuu+8qMDBQzZo105IlS3Tt2jV7xgoAAAAAgFWOB4UqWrSo+vXrp3//+986ePCgRo4cqSNHjqh///7y9vbWkCFDFB8fb4dQAQAAAAD4n/sa5djX11f169dXYGCgjDG6fPmy5s+fr/r166tDhw5KSkrKrTgBAAAAAEjnngrahIQEvfzyy6pYsaJ69OihX375RW+++aZ+/fVXHT9+XG+88Ya2bNmiAQMG5Ha8AAAAAABIkgraOuPly5e1dOlSLVy4UN9//70KFCigtm3bKiIiQh06dFCBAv+rjd966y0VL15c48aNs0vQAAAAAADYXNBWqFBB165dk4+Pj0aPHq3nnntOPj4+Wc5ftWpVBokCAAAAANiNzQVtaGioIiIi1K5du3RXY7PSo0cP9ejR476CAwAAAAAgKzYXtHFxcfaMAwAAAACAHLF5UKjNmzfrtddey7L9tdde05YtW3IlKAAAAAAA7sbmgnbSpEk6fPhwlu1Hjx7VpEmTciUoAAAAAADuxuaC9qefflLjxo2zbG/UqJF++umnXAkKAAAAAIC7sbmgvXDhgjw8PLJsL1q0qM6dO5crQQEAAAAAcDc2F7SVKlXSDz/8kGX7Dz/8oAoVKuQ4gLS0NNWrV08dO3aUJCUnJyssLEwBAQEKCwujSAYAAAAAZMrmgrZDhw6KjY3Vpk2bMrRt3rxZsbGxat++fY4DmDZtmgIDA61/R0VFKTQ0VIcOHVJoaKiioqJyvE4AAAAAgOuzuaB944035OnpqTZt2qhjx4568803NWrUKHXs2FGtW7eWp6enRo0alaONJyYm6osvvtDAgQOt0+Li4hQeHi5JCg8P1+rVq3O0TgAAAADA34PNz6EtX768/vOf/2jw4MFat26d1q5dK0myWCxq166dZs6cKW9v7xxt/B//+IfeffddXbp0yTrt1KlT1vV4e3vr9OnTmS4bHR2t6OhoSdKZM2dytF0AAAAAgPOzuaCVpKpVq2rt2rU6d+6cDh8+LGOMAgICVKZMmRxv+PPPP5eXl5fq16+vrVu35nj5iIgIRURESJJCQkJyvDwAAAAAwLnlqKC9rUyZMmrQoMF9bXjbtm1as2aN1q5dq5SUFF28eFF9+vRR+fLllZSUJG9vbyUlJcnLy+u+tgMAAAAAcE02/4b2TpcvX1ZiYqL++9//ZnjZauLEiUpMTNSxY8e0bNkytWrVSh999JE6d+6s2NhYSVJsbKy6dOlyLyECAAAAAFxcjq7QLlu2TOPHj9f+/fuznCctLe2+AoqMjFT37t21cOFCValSRcuXL7+v9QEAAAAAXJPNBe3q1avVu3dvVa9eXc8//7zmzp2r3r17KzU1VatXr1adOnWsz5LNqRYtWqhFixaSpHLlymnz5s33tB4AAAAAwN+HzQXt+++/r8DAQP3www+6fPmy5s6dqwEDBqhVq1bau3evHn30UQUHB9sxVAAAAAAA/sfm39Du2bNH4eHhKlKkiAoU+HOx27cX165dWxEREZo4caJ9ogQAAAAA4C9sLmjT0tJUrlw5SVLRokUlSRcuXLC216hRQ3v37s3l8AAAAAAAyJzNBa2Pj49+++03SX8WtF5eXtq1a5e1/ZdffpGHh0fuRwgAAAAAQCZs/g1tkyZNtGnTJr311luSpM6dO2vatGkqVqyYbt26pVmzZqlTp052CxQAAAAAgDvZXNAOGTJEq1at0rVr11S0aFFNmDBBO3fu1NixYyVJQUFBev/99+0VJwAAAAAA6dhc0DZo0EANGjSw/u3p6an4+Hjt2bNHbm5uCgwMtA4WBQAAAACAvdlU0F65ckUffPCBGjVqpDZt2qRre+ihh+wSGAAAAAAA2bHpkqqHh4feeecdHT9+3N7xAAAAAABgE5vvEfb399fJkyftGQsAAAAAADazuaAdMmSI5s+fr7Nnz9ozHgAAAAAAbGLzoFAlSpRQ2bJlVaNGDYWHhysgIEDFihXLMF+/fv1yNUAAAAAAADJjc0Hbv39/6/9PmTIl03ksFgsFLQAAAAAgT9hc0G7ZssWecQAAAAAAkCM2F7TNmze3ZxwAAAAAAOSIzYNCAQAAAACQn9h8hfatt9666zwWi0WjRo2yaX0pKSlq1qyZrl+/rtTUVHXr1k3jxo1TcnKyevTooWPHjsnX11effvqpypQpY2uYAAAAAIC/CZsL2rFjx2bZZrFYZIzJUUHr7u6ur776SsWLF9fNmzfVtGlTtWvXTitXrlRoaKgiIyMVFRWlqKgoTZo0ydYwAQAAAAB/EzYXtEePHs0wLTU1VUeOHNGUKVN04cIFxcbG2rxhi8Wi4sWLS5Ju3rypmzdvymKxKC4uTlu3bpUkhYeHq0WLFhS0AAAAAIAMbP4NbdWqVTO8/P391bp1a61du1Zubm6KiYnJ0cbT0tIUHBwsLy8vhYWFqVGjRjp16pS8vb0lSd7e3jp9+nSmy0ZHRyskJEQhISE6c+ZMjrYLAAAAAHB+uTIolMViUbdu3fThhx/maDk3NzfFx8crMTFRO3fu1N69e21eNiIiQrt27dKuXbvk6emZ05ABAAAAAE4u10Y5vnHjhs6ePXtPy5YuXVotWrTQl19+qfLlyyspKUmSlJSUJC8vr9wKEQAAAADgQnKloN21a5emTZumwMBAm5c5c+aMzp8/L0m6du2aNm3apJo1a6pz587W3+LGxsaqS5cuuREiAAAAAMDF2DwolJ+fX6bTk5OTdenSJRUsWFALFiywecNJSUkKDw9XWlqabt26pe7du6tjx4565JFH1L17dy1cuFBVqlTR8uXLbV4nAAAAAODvw+aCtkqVKrJYLOmmWSwWPfzww6pevboiIiLk6+tr84Yfeugh/fjjjxmmlytXTps3b7Z5PQAAAACAvyebC9rbj9IBAAAAACA/yLVBoQAAAAAAyEs2F7T/+te/1K9fvyzbw8PDtWLFilwJCgAAAACAu7G5oJ05c6YKFMh6djc3N82YMSNXggIAAAAA4G5sLmj379+vevXqZdler1497du3L1eCAgAAAADgbmwuaK9cuSI3N7cs2y0Wiy5dupQrQQEAAAAAcDc2F7QPPvigvv322yzbv/32W1WpUiVXggIAAAAA4G5sLmi7du2q5cuXa+HChRnaFi1apOXLl+vJJ5/M1eAAAAAAAMiKzc+hjYyMVFxcnCIiIjRlyhQFBwfLYrEoPj5e+/btU40aNfT666/bM1YAAAAAAKxsLmhLlCihbdu26bXXXtO//vUv6wBQZcqU0eDBgzV+/HiVLFnSboECAAAAAHAnmwtaSSpVqpRmz56tWbNm6Y8//pAxRp6enrJYLPaKDwAAAACATOWooL3NYrHI09Mzt2MBAAAAAMBmNg8KNWvWLD3++ONZtrdu3Vrz5s3LlaAAAAAAALgbmwvaxYsXKyAgIMv26tWra9GiRbkSFAAAAAAAd2NzQXvo0CHVqVMny/agoCAdOnQoV4ICAAAAAOBubC5ob968qZSUlCzbU1JSsm0HAAAAACA32VzQVq9eXRs3bsyyfcOGDfL397d5w8ePH1fLli0VGBiooKAgTZs2TZKUnJyssLAwBQQEKCwsTOfOnbN5nQAAAACAvw+bC9pevXppw4YNGjVqlG7cuGGdfvPmTY0ZM0YbNmxQ7969bd5wwYIF9cEHH2j//v3asWOHZs2apX379ikqKkqhoaE6dOiQQkNDFRUVlbOMAAAAAAB/CzY/tuell17SunXrNGHCBM2ZM0c1a9aUxWLR/v37lZycrMcee0wjRoywecPe3t7y9vaWJJUoUUKBgYH6/fffFRcXp61bt0qSwsPD1aJFC02aNClnWQEAAAAAXJ7NV2gLFSqkDRs2KCoqSj4+Pvrxxx+1e/duVa5cWe+++642bdqkwoUL31MQx44d048//qhGjRrp1KlT1kLX29tbp0+fznSZ6OhohYSEKCQkRGfOnLmn7QIAAAAAnJfNV2ilP4vakSNHauTIkZm2X79+Xe7u7jkK4PLly3rqqac0depUlSxZ0ublIiIiFBERIUkKCQnJ0TYBAAAAAM7P5iu02fnhhx80ZMgQVaxYMUfL3bx5U0899ZSeeeYZPfnkk5Kk8uXLKykpSZKUlJQkLy+v3AgRAAAAAOBi7rmgTU5O1vTp01W3bl01bNhQc+fOlaenp83LG2P03HPPKTAwUC+//LJ1eufOnRUbGytJio2NVZcuXe41RAAAAACAC8txQbt+/Xr16NFDlSpV0ksvvaQbN25ozJgx+vnnn3XgwAGb17Nt2zYtWbJEX331lYKDgxUcHKy1a9cqMjJSGzduVEBAgDZu3KjIyMichggAAAAA+Buw6Te0R48eVUxMjGJjY5WYmChPT09169ZNn3zyiSZMmGC9XTgnmjZtKmNMpm2bN2/O8foAAAAAAH8v2V6h/eSTTxQaGqqAgAC9++67CgkJ0apVq/T7779rzJgxWRakAAAAAADYW7ZXaPv06SM/Pz9NnTpVvXv3VtmyZa1tFovF7sEBAAAAAJCVbK/QFi5cWMeOHVNcXJzWrVuna9eu5VVcAAAAAABkK9uC9uTJk5o6darOnj2rvn37qnz58nruuef09ddfc7sxAAAAAMChsi1oS5curWHDhmn37t3atWuX+vbtq9WrV6tly5Zq2rSpLBaLLly4kFexAgAAAABgZfNjex5++GHNmjVLJ06c0JIlSxQUFCRJGjhwoIKDgzV+/HglJCTYLVAAAAAAAO6U4+fQuru7q3fv3tq8ebOOHDmiN954Q+fOndPo0aNVt25de8QIAAAAAEAGOS5o7+Tr66u33npLx44d09q1a+/pebQAAAAAANyLbB/bYyuLxaK2bduqbdu2ubE6AAAAAADu6r6u0AIAAAAA4CgUtAAAAAAAp0RBCwAAAABwShS0AAAAAACnREELAAAAAHBKFLQAAAAAAKdEQQsAAAAAcEoOK2gHDBggLy8v1a5d2zotOTlZYWFhCggIUFhYmM6dO+eo8AAAAAAA+ZzDCtr+/fvryy+/TDctKipKoaGhOnTokEJDQxUVFeWg6AAAAAAA+Z3DCtpmzZqpbNmy6abFxcUpPDxckhQeHq7Vq1c7IDIAAAAAgDMo6OgA7nTq1Cl5e3tLkry9vXX69Oks542OjlZ0dLQk6cyZM3kSHwAAAAAg/3DaQaEiIiK0a9cu7dq1S56eno4OBwAAAACQx/JVQVu+fHklJSVJkpKSkuTl5eXgiAAAAAAA+VW+Kmg7d+6s2NhYSVJsbKy6dOni4IgAAAAAAPmVwwraXr166ZFHHtEvv/wiHx8fLVy4UJGRkdq4caMCAgK0ceNGRUZGOio8AAAAAEA+57BBoZYuXZrp9M2bN+dxJAAAAAAAZ5SvbjkGAAAAAMBWFLQAAAAAAKdEQQsAAAAAcEoUtAAAAAAAp0RBCwAAAABwShS0AAAAAACnREELAAAAAHBKFLQAAAAAAKdEQQsAAAAAcEoUtAAAAAAAp0RBCwAAAABwShS0AAAAAACnREELAAAAAHBKFLQAAAAAAKdEQQsAAAAAcEoUtAAAAAAAp5QvC9ovv/xSNWrUULVq1RQVFeXocAAAAAAA+VC+K2jT0tI0dOhQrVu3Tvv27dPSpUu1b98+R4cFAAAAAMhn8l1Bu3PnTlWrVk1+fn4qXLiwevbsqbi4OEeHBQAAAADIZyzGGOPoIO60YsUKffnll1qwYIEkacmSJfruu+80c+bMdPNFR0crOjpaknTgwAHVrFkzz2PNS2fOnJGnp6ejw7AbV87PlXOTyM+ZuXJukmvn58q5SeTnzFw5N8m183Pl3CTXzs+Vc7vTsWPH9Mcff2SYXtABsWQrs/raYrFkmBYREaGIiIi8CClfCAkJ0a5duxwdht24cn6unJtEfs7MlXOTXDs/V85NIj9n5sq5Sa6dnyvnJrl2fq6cmy3y3S3HPj4+On78uPXvxMREVaxY0YERAQAAAADyo3xX0DZo0ECHDh3S0aNHdePGDS1btkydO3d2dFgAAAAAgHwm391yXLBgQc2cOVNt2rRRWlqaBgwYoKCgIEeH5XCufnu1K+fnyrlJ5OfMXDk3ybXzc+XcJPJzZq6cm+Ta+blybpJr5+fKudki3w0KBQAAAACALfLdLccAAAAAANiCghYAAAAA4JQoaB3EYrGob9++1r9TU1Pl6empjh07SpIWL16sYcOGZVjO19dXderUUd26ddW6dWudPHlSktS2bVvVrVtXQUFBGjRokNLS0vImEUkpKSlq2LChdftjxoyRJPXv318rVqzIdtnk5GSFhYUpICBAYWFhOnfunLVt4sSJqlatmmrUqKH169dbp7/xxhuqXLmyihcvbp+E/sIe+Z09e1YtW7ZU8eLFM/TzDz/8oDp16qhatWoaPnx4po+yyi33k9vy5csVFBSkAgUKZBgqPqu+y8vcpLzvO2faN7PqP1fYN3N6XLl69ao6dOigmjVrKigoSJGRkXbL6zZ75Ldx40bVr19fderUUf369fXVV19Zl3GWvruX/dKZ3nf30neukF9W/ZfX7728/MxzleOKlPVnel6ee9ojt507dyo4OFjBwcGqW7euVq1aZV3Gmc5XRo0apYceekjBwcFq3bq1Tpw4YW3LL+djdmfgEB4eHiY4ONhcvXrVGGPM2rVrTd26dU2HDh2MMcbExMSYoUOHZliuatWq5syZM8YYY1577TXzwgsvGGOMuXDhgjHGmFu3bpknn3zSLF26NC/SsG7z0qVLxhhjbty4YRo2bGi2b99uwsPDzfLly7Nd9p///KeZOHGiMcaYiRMnmpEjRxpjjElISDAPPfSQSUlJMb/++qvx8/Mzqampxhhjtm/fbk6cOGE8PDzsmNX/2CO/y5cvm2+++cbMmTMnQz83aNDA/Oc//zG3bt0ybdu2NWvXrrVDVn+6n9z27dtnDhw4YJo3b26+//576/Ts+i4vczMm7/vOmfbNrPrPFfbNnB5Xrly5Yr766itjjDHXr183TZs2dcp9c/fu3eb33383xhjz888/m4oVK1qXcZa+u5f90pned/fSd66QX1b9l9fvvbz8zHOV40p2n+l5ee5pj9yuXLlibt68aYwx5sSJE8bT09P6tzOdr9zuB2OMmTZtmnn++eeNMfnrfMzeuELrQO3atdMXX3whSVq6dKl69eqVo+WbNWumw4cPS5JKliwp6c8rvTdu3JDFYsndYLNhsVis3xzfvHlTN2/etHn7cXFxCg8PlySFh4dr9erV1uk9e/aUu7u7HnzwQVWrVk07d+6UJDVu3Fje3t65n0gW7JGfh4eHmjZtqiJFiqSbPykpSRcvXtQjjzwii8Wifv36WZexh/vJLTAwUDVq1MgwPau+y+vcpLztO8m59s2s+s8V9s2cHleKFSumli1bSpIKFy6shx9+WImJibmf1B3skV+9evWsz20PCgpSSkqKrl+/7lR9l9P9UnKu911O+05yjfyy6r+8fu/l5WeeqxxXsjsfy8tzT3vkVqxYMRUs+OcDX1JSUqzrc7bzldv9IElXrlyxLpefzsfsjYLWgXr27Klly5YpJSVFe/bsUaNGjXK0/Oeff646depY/27Tpo28vLxUokQJdevWLbfDzVZaWpqCg4Pl5eWlsLAwm3M5deqU9YPa29tbp0+fliT9/vvvqly5snU+Hx8f/f7777kfuI1yO7+s/P777/Lx8bH+nRd532tuWcmq7xyRm5R3fecoud1/WXGmffN+jivnz5/X//t//0+hoaG5lEXW7LlvfvbZZ6pXr57c3d2dqu+cRV71naM44riZV++9vPrMu5MzH1full9ennvaY7/87rvvFBQUpDp16mju3LkqWLCg052vSP/7acLHH3+st956S1L+Ox+zJwpaB3rooYd07NgxLV26VO3bt7d5uZYtWyo4OFgXL17Ua6+9Zp2+fv16JSUl6fr16+l+f5MX3NzcFB8fr8TERO3cuVN79+69r/WZTO7lz8urzn+V2/llxRF551XfOapP86rv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q8GcspvXYrHcdT23/3788cf16quv2rwNAACcAQUtAAB25Obmpn79+mnixIkqWrSoevbsmel8/v7+kqSEhASFhoama9u3b58kyc/PL928+/fvV6tWrdLNu3///nR/e3p6qnTp0rp48aIef/zx+08IAIB8hHuMAACws0GDBmnMmDGaO3euSpUqlek8YWFh8vDw0IwZM3Tp0iXr9EuXLmnGjBkqXry4wsLCrPMWLVpUs2bN0tWrV63zJiYm6pNPPkm33gIFCuiZZ57Rzp07tWLFiky3ffr06ftNEQAAh+AKLQAAdlalShWNHTs223lKly6td999V0OHDlWjRo3Uv39/SdLixYt1+PBhzZs3z1oMlylTRm+//bZeeeUVNWnSRP369dPVq1c1d+5cBQQE6Mcff0y37gkTJmjbtm3q3r27unfvrsaNG6tw4cL67bfftHbtWtWvX59RjgEATomCFgCAfGLIkCHy9vbWe++9p3HjxkmS6tatq1WrVumJJ55IN++IESNUvHhxTZ48Wa+99poqV66sV155RaVKlcowinKpUqW0bds2ffDBB/r0008VFxenggULysfHR02bNtXAgQPzKkUAAHKVxeRkFAoAAAAAAPIJfkMLAAAAAHBKFLQAAAAAAKdEQQsAAAAAcEoUtAAAAAAAp0RBCwAAAABwShS0AAAAAACnREELAAAAAHBKFLQAAAAAAKdEQQsAAAAAcEr/H2Pt91hiFoLpAAAAAElFTkSuQmCC\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
}
