{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_FEMNIST,get_FashionMNIST, get_MNIST\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "\n",
    "class CNNmnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(1, 10, kernel_size=5)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(10, 20, kernel_size=5)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(320, 50)\n",
    "        self.fc2 = nn.Linear(50, 10)        \n",
    "        # self.out = nn.Linear(64 * 7 * 7, 10)\n",
    "\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(-1, 320)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([60000])\n",
      "6006\n",
      "[[  0 568]\n",
      " [  1 689]\n",
      " [  2 607]\n",
      " [  3 623]\n",
      " [  4 555]\n",
      " [  5 552]\n",
      " [  6 612]\n",
      " [  7 639]\n",
      " [  8 596]\n",
      " [  9 604]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([5, 0, 4,  ..., 5, 6, 8])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_MNIST()\n",
    "\n",
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "print(tag1.shape)\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t ==0:\n",
    "        list0[0].append(train_set[0][z])\n",
    "        list0[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==1:\n",
    "        list1[0].append(train_set[0][z])\n",
    "        list1[1].append(train_set[1][z])\n",
    "\n",
    "    elif t ==2:\n",
    "        list2[0].append(train_set[0][z])\n",
    "        list2[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==3:\n",
    "        list3[0].append(train_set[0][z])\n",
    "        list3[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==4:\n",
    "        list4[0].append(train_set[0][z])\n",
    "        list4[1].append(train_set[1][z])        \n",
    "        \n",
    "        \n",
    "    elif t ==5:\n",
    "        list5[0].append(train_set[0][z])\n",
    "        list5[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==6:\n",
    "        list6[0].append(train_set[0][z])\n",
    "        list6[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==7:\n",
    "        list7[0].append(train_set[0][z])\n",
    "        list7[1].append(train_set[1][z])   \n",
    "        \n",
    "        \n",
    "    elif t ==8:\n",
    "        list8[0].append(train_set[0][z])\n",
    "        list8[1].append(train_set[1][z])   \n",
    "        \n",
    "    elif t ==9:\n",
    "        list9[0].append(train_set[0][z])\n",
    "        list9[1].append(train_set[1][z])   \n",
    "\n",
    "\n",
    "print(len(list0[0]))\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([5, 2, 9,  ..., 3, 2, 9])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "fb85c984-e99f-433e-9cca-7bc7c93c10dd",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<3:\n",
    "        tag1[z]=(tag1[z] - 1) % 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is my idx\n",
      "0\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "1\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "2\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "3\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "4\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "5\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "6\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "7\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "8\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "9\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-20:49:50 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Simulation started.                                                           <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:372</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-20:49:50\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Simulation started.                                                           \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m372\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e115d1b3bab74e2aa66921aa08d118e6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output()"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"></pre>\n"
      ],
      "text/plain": []
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-23:29:01 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3278</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-23:29:01\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3278\u001b[0m                                                         \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m239\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Failed messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0</span>                                                          <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:240</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Failed messages: \u001b[1;36m0\u001b[0m                                                          \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m240\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Total size: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">71591520</span>                                                          <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:241</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Total size: \u001b[1;36m71591520\u001b[0m                                                          \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m241\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n"
     ]
    }
   ],
   "source": [
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CNNmnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(True)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.98</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:172</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.98\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m172\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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W4a4uDhcddVVAIDDhw9DCIGpU6ciMDDQ7jV9+nQAQEFBgd1xunTpUufYVVVVmDZtmm3MS0BAAAIDA1FSUoLS0tLL/OSNc+jQIaxatapO/UlJSXb1T5gwAVdddRVuueUWdOzYEQ899BBWrVp1xcd3c3OzjT36c02lpaUICgqqU1dFRYWtpoEDB+LOO+/EK6+8goCAAIwYMQKLFy+G0Wi84rouZebMmdi9ezfCw8PRt29fvPzyyzh69KjTj0vkahxzQ9QM+fr6okOHDti5c+dFt9u5cyfCwsLg4+MDANDpdBg5ciRWrlyJd955B/n5+di4cSPeeOMN2z61A26fffZZJCcn1/u+0dHRdj//uZWm1hNPPIHFixfjqaeeQmJiInx9fSFJEu699946g3odTZZl3HTTTXj++efrXV8b5IKCgpCdnY3Vq1fjhx9+wA8//IDFixdjzJgx+PDDDy/7+DqdDiqV/e+GsiwjKCgI//3vf+vdp3ZQuCRJWL58OX777Td88803WL16NR566CHMmjULv/32G7y8vBqclM9qtV52zQBwzz33YMCAAVi5ciV+/PFHvPXWW3jzzTexYsUK3HLLLVf03kTNCcMNUTN122234f3338eGDRvQv3//Out//fVXHD9+HOPHj7dbnpKSgg8//BCZmZnYt28fhBC2LikAttvGNRqNraXjcixfvhypqamYNWuWbVl1dTVKSkou+z3/qqGLfFRUFCoqKhpVv1arxfDhwzF8+HDIsowJEyZg4cKFmDp1KqKjox02u29UVBR++uknXH/99fWGwb+67rrrcN111+H111/Hp59+ivvvvx9Lly7F2LFj0a5dOwCocy5PnDjRqFou9pk6dOiACRMmYMKECSgoKEDv3r3x+uuvM9xQq8JuKaJm6rnnnoO7uzvGjx+Ps2fP2q0rLi7Go48+Cg8PDzz33HN265KSkuDv749ly5Zh2bJl6Nu3r123UlBQEAYNGoSFCxciNze3znELCwsbVZ9arYYQwm7Z22+/fcWtC3/m6elZb1i65557kJWVhdWrV9dZV1JSAovFAgB1zptKpULPnj0BwNYNVDs/zZWGsnvuuQdWqxWvvfZanXUWi8X2/ufOnatz3uLi4uxq6ty5M9RqtW3sUK133nmnUbXUd96sVmud7sKgoCCEhoa6pEuMyJXYckPUTHXt2hUffvgh7r//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4YnBXRWshoiIqHViy40LlVdbAACx4X5Y/mgiNGpmSyIiIkfj1dWFyqtrWm589G4MNkRERE7CK6wL1bbceOvZYEZEROQsDDcuVNty463TKFwJERFR68Vw40JsuSEiInI+hhsXKrOFG7bcEBEROQvDjQvZuqXYckNEROQ0DDcuxG4pIiIi52O4caELLTfsliIiInIWhhsXqm258WHLDRERkdMw3LhQOQcUExEROR3DjQtVGDnmhoiIyNkYblzEKguGGyIiIhdguHGR2mADsFuKiIjImRhuXKT2TimdmwpaN552IiIiZ+FV1kU4mJiIiMg1GG5chBP4ERERuQbDjYvw0QtERESuwXDjImy5ISIicg2GGxextdzoOOaGiIjImRhuXKSMLTdEREQuwXDjIrxbioiIyDUYblyEA4qJiIhcg+HGBY4VGbAjpwQAww0REZGz8UrrZAXl1bhl7i+oNsuQJKB7qI/SJREREbVqDDdOdrigAtVmGQFeWix+sC9iOvoqXRIREVGrxm4pJyuqMAEAIgO9GGyIiIhcgOHGyc5WGAEAgV46hSshIiJqGxhunKzofLgJ8NIqXAkREVHbwHDjZEXlNd1SAWy5ISIicgmGGyeztdx4M9wQERG5guLhZv78+YiIiIBer0dCQgI2b9580e3nzJmDbt26wd3dHeHh4Xj66adRXV3tomqbrjbctPdktxQREZErKBpuli1bhvT0dEyfPh3bt29HbGwskpOTUVBQUO/2n376KSZPnozp06dj3759+OCDD7Bs2TL84x//cHHljVd7txRbboiIiFxD0XAze/ZsjBs3DmlpaejevTsWLFgADw8PLFq0qN7tN23ahOuvvx733XcfIiIiMHToUIwePfqSrT1KEUKgkHdLERERuZRi4cZkMmHbtm1ISkq6UIxKhaSkJGRlZdW7T79+/bBt2zZbmDl69Ci+//57DBs2rMHjGI1GlJWV2b1cpcJogckiA+CAYiIiIldRbIbioqIiWK1WBAcH2y0PDg7G/v37693nvvvuQ1FREfr37w8hBCwWCx599NGLdktlZGTglVdecWjtjVXbJeWpVcNdq1akBiIiorZG8QHFTbFu3Tq88cYbeOedd7B9+3asWLEC3333HV577bUG95kyZQpKS0ttr5MnT7qsXt4pRURE5HqKtdwEBARArVYjPz/fbnl+fj5CQkLq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ByIsLAxff/01QkJCsH37dsjnH2z43XffYdSoUXjxxRfx0UcfwWQy4fvvv29yzZMnT8asWbPQq1cv6PV6VFdXIz4+Hi+88AJ8fHzw3Xff4YEHHkBUVBT69u0LAJgyZQref/99/Pvf/0b//v2Rm5uL/fv3AwDGjh2LiRMnYtasWdDpdACATz75BGFhYRg8eHCT62sshhsHYbcUEVHzU2W2ovu01Yoce++ryfDQNv4ye+edd9r9vGjRIgQGBmLv3r3YtGkTCgsLsWXLFvj7+wMAoqOjbdu+/vrruPfee/HKK6/YlsXGxja55qeeegp33HGH3bJnn33W9ucnnngCq1evxueff46+ffuivLwcc+fOxbx585CamgoAiIqKQv/+/QEAd9xxByZOnIivvvoK99xzDwBgyZIlePDBB506wSK7pRzE1i3FlhsiIroMhw4dwujRoxEZGQkfHx9EREQAAHJycpCdnY1evXrZgs1fZWdnY8iQIVdcQ58+fex+tlqteO211xATEwN/f394eXlh9erVyMnJAQDs27cPRqOxwWPr9Xo88MADWLRoEQBg+/bt2L17Nx588MErrvVi2HLjIOdbBvnoBSKiZsRdo8beV5MVO3ZTDB8+HJ07d8b777+P0NBQyLKMHj16wGQywd3d/eLHusR6SZJswydq1Tdg2NPT0+7nt956C3PnzsWcOXMQExMDT09PPPXUUzCZTI06LlDTNRUXF4dTp05h8eLFGDx4MDp37nzJ/a4EW24cRBYcUExE1NxIkgQPrZsir6Z0u5w9exYHDhzASy+9hCFDhuCaa67BuXPnbOt79uyJ7OxsFBcX17t/z549LzpANzAwELm5ubafDx061KiHi27cuBEjRozA3//+d8TGxiIyMhIHDx60re/atSvc3d0veuyYmBj06dMH77//Pj799FM89NBDlzzulWK4cRDbmBumGyIiaqJ27dqhffv2eO+993D48GH8/PPPSE9Pt60fPXo0QkJCMHLkSGzcuBFHjx7F//73P2RlZQEApk+fjs8++wzTp0/Hvn37sGvXLrz55pu2/QcPHox58+Zhx44d2Lp1Kx599FFoNJpL1tW1a1esWbMGmzZtwr59+zB+/Hjk5+fb1uv1erzwwgt4/vnn8dFHH+HIkSP47bff8MEHH9i9z9ixYzFjxgwIIezu4nIWhhsH0mtU0DexGZKI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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.22998000000000002}, {'accuracy': 0.5491900000000001}, {'accuracy': 0.7382500000000001}, {'accuracy': 0.78603}, {'accuracy': 0.8236800000000001}, {'accuracy': 0.82538}, {'accuracy': 0.8829799999999999}, {'accuracy': 0.8812300000000001}, {'accuracy': 0.88927}, {'accuracy': 0.8932300000000002}, {'accuracy': 0.9096299999999999}, {'accuracy': 0.9120100000000001}, {'accuracy': 0.9239200000000001}, {'accuracy': 0.92545}, {'accuracy': 0.92692}, {'accuracy': 0.93116}, {'accuracy': 0.9360900000000001}, {'accuracy': 0.9325899999999999}, {'accuracy': 0.92919}, {'accuracy': 0.9312699999999999}, {'accuracy': 0.9281200000000001}, {'accuracy': 0.94209}, {'accuracy': 0.9451500000000002}, {'accuracy': 0.94561}, {'accuracy': 0.94431}, {'accuracy': 0.9473400000000002}, {'accuracy': 0.9531400000000001}, {'accuracy': 0.9521600000000001}, {'accuracy': 0.95197}, {'accuracy': 0.9545499999999999}, {'accuracy': 0.9539000000000002}, {'accuracy': 0.9570299999999999}, {'accuracy': 0.95686}, {'accuracy': 0.95669}, {'accuracy': 0.9582499999999999}, {'accuracy': 0.9566800000000001}, {'accuracy': 0.9568000000000001}, {'accuracy': 0.9582200000000001}, {'accuracy': 0.9602200000000002}, {'accuracy': 0.9599999999999997}, {'accuracy': 0.9612399999999999}, {'accuracy': 0.96282}, {'accuracy': 0.9622299999999999}, {'accuracy': 0.9640599999999999}, {'accuracy': 0.9572600000000001}, {'accuracy': 0.96208}, {'accuracy': 0.96234}, {'accuracy': 0.9634199999999999}, {'accuracy': 0.96348}, {'accuracy': 0.9639}, {'accuracy': 0.9635300000000001}, {'accuracy': 0.96545}, {'accuracy': 0.9663}, {'accuracy': 0.96713}, {'accuracy': 0.9657599999999998}, {'accuracy': 0.9664800000000001}, {'accuracy': 0.9670900000000001}, {'accuracy': 0.96681}, {'accuracy': 0.96133}, {'accuracy': 0.9570500000000001}, {'accuracy': 0.9684699999999999}, {'accuracy': 0.9667899999999999}, {'accuracy': 0.96656}, {'accuracy': 0.9684099999999999}, {'accuracy': 0.96796}, {'accuracy': 0.9675799999999999}, {'accuracy': 0.96822}, {'accuracy': 0.9680699999999998}, {'accuracy': 0.9686299999999999}, {'accuracy': 0.9697500000000001}, {'accuracy': 0.96886}, {'accuracy': 0.96932}, {'accuracy': 0.96771}, {'accuracy': 0.96915}, {'accuracy': 0.9686200000000001}, {'accuracy': 0.9689099999999999}, {'accuracy': 0.9681900000000001}, {'accuracy': 0.96965}, {'accuracy': 0.9699199999999999}, {'accuracy': 0.9687100000000001}, {'accuracy': 0.9706300000000001}, {'accuracy': 0.96926}, {'accuracy': 0.96932}, {'accuracy': 0.96994}, {'accuracy': 0.9697799999999999}, {'accuracy': 0.9703799999999999}, {'accuracy': 0.9693200000000001}, {'accuracy': 0.97044}, {'accuracy': 0.97112}, {'accuracy': 0.9714}, {'accuracy': 0.97217}, {'accuracy': 0.97066}, {'accuracy': 0.9711000000000001}, {'accuracy': 0.9673200000000002}, {'accuracy': 0.9719599999999999}, {'accuracy': 0.9722899999999999}, {'accuracy': 0.97285}, {'accuracy': 0.9720799999999998}, {'accuracy': 0.9720500000000001}, {'accuracy': 0.9709199999999999}, {'accuracy': 0.9720600000000001}, {'accuracy': 0.9722099999999999}, {'accuracy': 0.9724499999999999}, {'accuracy': 0.97231}, {'accuracy': 0.97118}, {'accuracy': 0.9719700000000001}, {'accuracy': 0.9730700000000001}, {'accuracy': 0.9734399999999999}, {'accuracy': 0.97316}, {'accuracy': 0.9738999999999999}, {'accuracy': 0.9743}, {'accuracy': 0.97338}, {'accuracy': 0.97285}, {'accuracy': 0.97165}, {'accuracy': 0.9736200000000002}, {'accuracy': 0.9739000000000001}, {'accuracy': 0.97258}, {'accuracy': 0.9727800000000002}, {'accuracy': 0.97252}, {'accuracy': 0.9734999999999999}, {'accuracy': 0.9724}, {'accuracy': 0.9736999999999998}, {'accuracy': 0.9739899999999999}, {'accuracy': 0.9728700000000001}, {'accuracy': 0.9729699999999999}, {'accuracy': 0.9742299999999998}, {'accuracy': 0.9744299999999999}, {'accuracy': 0.9743499999999999}, {'accuracy': 0.9747800000000002}, {'accuracy': 0.97454}, {'accuracy': 0.9731500000000001}, {'accuracy': 0.9731399999999999}, {'accuracy': 0.97348}, {'accuracy': 0.9749799999999998}, {'accuracy': 0.97414}, {'accuracy': 0.97381}, {'accuracy': 0.9743299999999999}, {'accuracy': 0.97392}, {'accuracy': 0.9738899999999999}, {'accuracy': 0.97508}, {'accuracy': 0.9743400000000001}, {'accuracy': 0.9750300000000001}, {'accuracy': 0.9751099999999999}, {'accuracy': 0.9739699999999999}, {'accuracy': 0.9738900000000001}, {'accuracy': 0.9747200000000001}, {'accuracy': 0.9728299999999999}, {'accuracy': 0.97482}, {'accuracy': 0.9758200000000002}, {'accuracy': 0.97333}, {'accuracy': 0.9683599999999999}, {'accuracy': 0.97266}, {'accuracy': 0.97646}, {'accuracy': 0.9772399999999999}, {'accuracy': 0.9771599999999999}, {'accuracy': 0.9772700000000001}, {'accuracy': 0.9776800000000001}, {'accuracy': 0.97779}, {'accuracy': 0.9773200000000001}, {'accuracy': 0.9782699999999999}, {'accuracy': 0.9774499999999999}, {'accuracy': 0.9786699999999999}, {'accuracy': 0.97804}, {'accuracy': 0.9781700000000001}, {'accuracy': 0.97807}, {'accuracy': 0.9781599999999999}, {'accuracy': 0.9777800000000001}, {'accuracy': 0.97779}, {'accuracy': 0.97793}, {'accuracy': 0.97797}, {'accuracy': 0.97761}, {'accuracy': 0.9777999999999999}, {'accuracy': 0.97804}, {'accuracy': 0.97827}, {'accuracy': 0.97815}, {'accuracy': 0.9778200000000001}, {'accuracy': 0.97854}, {'accuracy': 0.9783999999999999}, {'accuracy': 0.9782}, {'accuracy': 0.9783199999999999}, {'accuracy': 0.9780599999999998}, {'accuracy': 0.97774}, {'accuracy': 0.97759}, {'accuracy': 0.9778399999999999}, {'accuracy': 0.97776}, {'accuracy': 0.97796}, {'accuracy': 0.9775600000000001}, {'accuracy': 0.9770299999999998}, {'accuracy': 0.9780800000000001}, {'accuracy': 0.97857}, {'accuracy': 0.9784500000000002}, {'accuracy': 0.9786300000000001}, {'accuracy': 0.9779500000000001}, {'accuracy': 0.97808}, {'accuracy': 0.9780899999999999}, {'accuracy': 0.97826}, {'accuracy': 0.9780099999999999}, {'accuracy': 0.9784499999999999}, {'accuracy': 0.97844}, {'accuracy': 0.9783600000000001}, {'accuracy': 0.9780000000000001}, {'accuracy': 0.9781899999999999}, {'accuracy': 0.97814}, {'accuracy': 0.97837}, {'accuracy': 0.9783199999999999}, {'accuracy': 0.97791}, {'accuracy': 0.9784799999999999}, {'accuracy': 0.9783800000000001}, {'accuracy': 0.97848}, {'accuracy': 0.97826}, {'accuracy': 0.97812}, {'accuracy': 0.9780999999999999}, {'accuracy': 0.9783899999999999}, {'accuracy': 0.9782200000000001}, {'accuracy': 0.9784499999999999}, {'accuracy': 0.9783299999999999}, {'accuracy': 0.9785300000000001}, {'accuracy': 0.9785299999999998}, {'accuracy': 0.97837}, {'accuracy': 0.9783299999999999}, {'accuracy': 0.9786300000000001}, {'accuracy': 0.97843}, {'accuracy': 0.9785600000000001}, {'accuracy': 0.9779399999999999}, {'accuracy': 0.97822}, {'accuracy': 0.9784599999999999}, {'accuracy': 0.9785299999999999}, {'accuracy': 0.97895}, {'accuracy': 0.9779899999999999}, {'accuracy': 0.97827}, {'accuracy': 0.97844}, {'accuracy': 0.9784700000000001}, {'accuracy': 0.97888}, {'accuracy': 0.9785499999999999}, {'accuracy': 0.97855}, {'accuracy': 0.9786900000000001}, {'accuracy': 0.9786699999999999}, {'accuracy': 0.97873}, {'accuracy': 0.9787100000000001}, {'accuracy': 0.97883}, {'accuracy': 0.97828}, {'accuracy': 0.9784899999999999}, {'accuracy': 0.9789899999999999}, {'accuracy': 0.9786599999999999}, {'accuracy': 0.9791000000000001}, {'accuracy': 0.97866}, {'accuracy': 0.9785599999999999}, {'accuracy': 0.9790599999999999}, {'accuracy': 0.97829}, {'accuracy': 0.9785800000000002}, {'accuracy': 0.97843}, {'accuracy': 0.9785600000000001}, {'accuracy': 0.97927}, {'accuracy': 0.9789}, {'accuracy': 0.9790999999999999}, {'accuracy': 0.97915}, {'accuracy': 0.97882}, {'accuracy': 0.97883}, {'accuracy': 0.97883}, {'accuracy': 0.97872}, {'accuracy': 0.9787699999999999}, {'accuracy': 0.9785299999999999}, {'accuracy': 0.97889}, {'accuracy': 0.9789699999999998}, {'accuracy': 0.97937}, {'accuracy': 0.9794499999999999}, {'accuracy': 0.97949}, {'accuracy': 0.9793999999999998}, {'accuracy': 0.97908}, {'accuracy': 0.9787000000000001}, {'accuracy': 0.9789300000000001}, {'accuracy': 0.9788}, {'accuracy': 0.9791300000000002}, {'accuracy': 0.97934}, {'accuracy': 0.9794}, {'accuracy': 0.97923}, {'accuracy': 0.97941}, {'accuracy': 0.97909}, {'accuracy': 0.97897}, {'accuracy': 0.9788499999999999}, {'accuracy': 0.9789800000000002}, {'accuracy': 0.9791799999999998}, {'accuracy': 0.9791000000000001}, {'accuracy': 0.9792100000000001}, {'accuracy': 0.9796299999999999}, {'accuracy': 0.9792099999999999}, {'accuracy': 0.9794599999999999}, {'accuracy': 0.97922}, {'accuracy': 0.97879}, {'accuracy': 0.9796000000000001}, {'accuracy': 0.9797399999999999}, {'accuracy': 0.9796499999999998}, {'accuracy': 0.97908}, {'accuracy': 0.97929}, {'accuracy': 0.9793199999999999}, {'accuracy': 0.9788599999999998}, {'accuracy': 0.97896}, {'accuracy': 0.9794499999999999}, {'accuracy': 0.9792799999999998}, {'accuracy': 0.9797300000000002}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "918b3aa8-d15e-4315-8b2d-bbdc0a8f2ac1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f0629290-f470-4583-a052-37dc2fa6b1b7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "80ddc0bb-aa14-43ac-a191-32e5c0fb983d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9ec0da6a-dd92-45d1-90b3-be6f1df3e969",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "06b3bdf7-e0cb-4239-842f-5c6c81df6152",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c4c7f60c-2317-475d-a4ef-554f3c9670e4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8539ed13-73be-4672-9ce4-ef4787d749b6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b181092e-9628-4ac3-91ee-130d10988c29",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c52d1ae3-ab90-4b40-903c-6f69a63222c0",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.10.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
