{
 "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",
      "5919\n",
      "[[  0 571]\n",
      " [  1 693]\n",
      " [  2 585]\n",
      " [  3 553]\n",
      " [  4 608]\n",
      " [  5 559]\n",
      " [  6 624]\n",
      " [  7 636]\n",
      " [  8 555]\n",
      " [  9 621]]\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": "0c21f936-247b-47ad-974c-af7e1368a4e1",
   "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",
    "        pa=random.randint(0,9)\n",
    "        while pa == tag1[z]:\n",
    "            pa=random.randint(0,9)\n",
    "        tag1[z]=pa"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([1, 9, 1,  ..., 8, 3, 6])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1c1faaf3-0a08-4288-b494-d3059924b666",
   "metadata": {
    "tags": []
   },
   "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\">141023-22:10:46 </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;36m141023-22:10:46\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": {
      "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": [
       "\u001b[?25l"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "13dd3b27fb76478ea6bb84992f092052",
       "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\">\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\n",
       "\u001b[?25h"
      ]
     },
     "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-00:13:04 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3656</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-00:13:04\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3656\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\">79847040</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;36m79847040\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": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAABYTElEQVR4nO3deVxU5eIG8GdmmI1lBpRNEMWtxURQuHgpTVOSdrWNvN4kSrPUsmjTm2nLLcquXr1paf5SW25pmdmuGamlkjvX3dwQF3aFgQFmmDnv7w9gdAIVdGYOy/P9fOYjnPWd48B5eM+7KIQQAkRERESthFLuAhARERG5EsMNERERtSoMN0RERNSqMNwQERFRq8JwQ0RERK0Kww0RERG1Kgw3RERE1Kow3BAREVGrwnBDRERErQrDDRG51bp166BQKLBu3TrHsoceegiRkZGylak1efnll6FQKOQuBlGzwnBD1Mzt3bsXf//73xEeHg6tVouwsDCMGjUKe/fulbtobvfuu+9iyZIlbj3Hvn378PLLLyM7O9ut5/GkN954AytXrpS7GESyYbghasZWrFiBvn37IiMjA6mpqXj33XfxyCOPYO3atejbty+++uoruYvoVp4KN6+88grDDVEr4iV3AYioYUeOHMGDDz6Irl274tdff0VQUJBj3aRJkzBgwAA8+OCD2LVrF7p27eqxcpnNZvj4+HjsfC0BrwlR88KaG6Jm6u2330ZFRQXef/99p2ADAIGBgViwYAHMZjNmzJgBAFi+fDkUCgXWr19f71gLFiyAQqHAnj17HMsOHDiAe++9F+3atYNOp0NcXBy++eYbp/2WLFniOOb48eMRHByMjh07AgCOHz+O8ePH4+qrr4Zer0f79u1x3333uawGJDIyEnv37sX69euhUCigUCgwaNAgx/qSkhI89dRTiIiIgFarRffu3fHWW29BkiSn4yxduhSxsbHw8/ODwWBAVFQU5syZ43h/9913HwDgpptucpzn/PZBf/bQQw/B19cXR44cwW233QY/Pz+MGjUKACBJEmbPno3rrrsOOp0OISEhGDduHM6ePet0jG3btiEpKQmBgYHQ6/Xo0qULHn74Ycf6htopAUB2djYUCsVFa7MUCgXMZjM+/PBDx/t56KGHAABlZWV46qmnEBkZCa1Wi+DgYNx8883YsWPHBY9H1BKx5oaomfr2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CkJubq7j+0OHDjVqctGNGzdi2LBh+Pvf/47o6Gh07doVf/zxh2N9jx49oNfrL3ruqKgoxMXFYeHChfj000/x8MMPX/K8V4rhxkXqBvFTqRhuiIioaQICAtC+fXu8//77OHz4MH755RekpaU51o8cORKhoaEYPnw4Nm7ciKNHj+LLL79EZmYmAGD69On47LPPMH36dOzfvx+7d+/GW2+95dh/8ODBmDt3Lnbu3Ilt27bhscceg1qtvmS5evTogTVr1mDTpk3Yv38/xo0bh/z8fMd6nU6HF154Ac8//zw++ugjHDlyBL///js++OADp+OMGTMGb775JoQQTr243IXhxkUEaqogdV6XP9EXERG1TUqlEkuXLsX27dvRq1cvPP3003j77bcd6zUaDX766ScEBwfjtttuQ1RUFN58803H5JKDBg3CF198gW+++QYxMTEYPHgwtmzZ4th/5syZiIiIwIABA/C3v/0Nzz77bKMmF506dSr69u2LpKQkDBo0yBGwzvfSSy/hmWeewbRp03DttdciOTkZBQUFTtuMHDkSXl5eGDlyJHQ63RVcqcZRiD8/hGvlTCYTjEYjSktLYTAY5C4OERG5SFVVFY4dO4YuXbp45AZKjZednY1u3bph69at6Nu37wW3u9j/YVPu32xQTERERG5RXV2N4uJiTJ06FX/9618vGmxciY+liIiIyC02btyIDh06YOvWrZg/f77HzsuaGyIiInKLQYMG1euC7gmsuSEiIqJWheGGiIiIWhWGGyIialXaWCfgVsVV/3cMN0RE1CrUDUrXmJF3qXmqm9ahbvyey8UGxURE1CqoVCr4+/s7BpDz9vZ268zT5FqSJKGwsBDe3t7w8rqyeMJwQ0RErUZoaCgA1Bshl1oGpVKJTp06XXEobRbhZt68eXj77beRl5eH6OhovPPOO4iPj29w24ULF+Kjjz7Cnj17AACxsbF44403Lrg9ERG1HQqFAh06dEBwcHCDs15T86bRaKBUXnmLGdnDzbJly5CWlob58+ejX79+mD17NpKSknDw4EEEBwfX237dunUYOXIkrr/+euh0Orz11lsYOnQo9u7di/DwcBneARERNTcqleqK221QyyX73FL9+vXDX/7yF8ydOxdAzTO3iIgIPPHEE5g8efIl97fb7QgICMDcuXMxevToS27PuaWIiIhanqbcv2XtLWW1WrF9+3YkJiY6limVSiQmJjqmcb+UiooKVFdXo127dg2ut1gsMJlMTi8iIiJqvWQNN0VFRbDb7QgJCXFaHhISgry8vEYd44UXXkBYWJhTQDpfeno6jEaj4xUREXHF5SYiIqLmS/Y2N1fizTffxNKlS7Fu3boLTm8/ZcoUpKWlOb4vLS1Fp06dWINDRETUgtTdtxvTmkbWcBMYGAiVSoX8/Hyn5fn5+Y7ufBfyr3/9C2+++SZ+/vln9O7d+4LbabVaaLVax/d1F4c1OERERC1PWVkZjEbjRbeRNdxoNBrExsYiIyMDw4cPB1DToDgjIwMTJ0684H4zZszA66+/jtWrVyMuLq5J5wwLC8OJEyfg5+fnssGdTCYTIiIicOLECTZSbgRer8bjtWoaXq/G47VqPF6rpnHX9RJCoKysDGFhYZfcVvbHUmlpaUhJSUFcXBzi4+Mxe/ZsmM1mpKamAgBGjx6N8PBwpKenAwDeeustTJs2DZ9++ikiIyMdbXN8fX3h6+t7yfMplUp07NjRLe/FYDDwg98EvF6Nx2vVNLxejcdr1Xi8Vk3jjut1qRqbOrKHm+TkZBQWFmLatGnIy8tDTEwMVq1a5WhknJOT4zSgz3vvvQer1Yp7773X6TjTp0/Hyy+/7MmiExERUTMke7gBgIkTJ17wMdS6deucvs/OznZ/gYiIiKjF4qzgLqDVajF9+nSnhst0Ybxejcdr1TS8Xo3Ha9V4vFZN0xyul+wjFBMRERG5EmtuiIiIqFVhuCEiIqJWheGGiIiIWhWGGyIiImpVGG5cYN68eYiMjIROp0O/fv2wZcsWuYsku5dffhkKhcLpdc011zjWV1VVYcKECWjfvj18fX1xzz331JuGo7X69ddfceeddyIsLAwKhQIrV650Wi+EwLRp09ChQwfo9XokJibi0KFDTtucOXMGo0aNgsFggL+/Px555BGUl5d78F14zqWu10MPPVTvs3bLLbc4bdNWrld6ejr+8pe/wM/PD8HBwRg+fDgOHjzotE1jfvZycnJw++23w9vbG8HBwXjuuedgs9k8+VbcrjHXatCgQfU+W4899pjTNm3hWgE1Y8z17t3bMTBfQkICfvzxR8f65va5Yri5QsuWLUNaWhqmT5+OHTt2IDo6GklJSSgoKJC7aLK77rrrkJub63ht2LDBse7pp5/Gt99+iy+++ALr16/H6dOncffdd8tYWs8xm82Ijo7GvHnzGlw/Y8YM/Oc//8H8+fOxefNm+Pj4ICkpCVVVVY5tRo0ahb1792LNmjX47rvv8Ouvv+LRRx/11FvwqEtdLwC45ZZbnD5rn332mdP6tnK91q9fjwkTJuD333/HmjVrUF1djaFDh8JsNju2udTPnt1ux+233w6r1YpNmzbhww8/xJIlSzBt2jQ53pLbNOZaAcDYsWOdPlszZsxwrGsr1woAOnbsiDfffBPbt2/Htm3bMHjwYAwbNgx79+4F0Aw/V4KuSHx8vJgwYYLje7vdLsLCwkR6erqMpZLf9OnTRXR0dIPrSkpKhFqtFl988YVj2f79+wUAkZmZ6aESNg8AxFdffeX4XpIkERoaKt5++23HspKSEqHVasVnn30mhBBi3759AoDYunWrY5sff/xRKBQKcerUKY+VXQ5/vl5CCJGSkiKGDRt2wX3a8vUqKCgQAMT69euFEI372fvhhx+EUqkUeXl5jm3ee+89YTAYhMVi8ewb8KA/XyshhBg4cKCYNGnSBfdpq9eqTkBAgPi///u/Zvm5Ys3NFbBardi+fTsSExMdy5RKJRITE5GZmSljyZqHQ4cOISwsDF27dsWoUaOQk5MDANi+fTuqq6udrts111yDTp06tfnrduzYMeTl5TldG6PRiH79+jmuTWZmJvz9/Z0mjU1MTIRSqcTmzZs9XubmYN26dQgODsbVV1+Nxx9/HMXFxY51bfl6lZaWAgDatWsHoHE/e5mZmYiKinJMgQMASUlJMJlMjr/SW6M/X6s6//3vfxEYGIhevXphypQpqKiocKxrq9fKbrdj6dKlMJvNSEhIaJafq2Yx/UJLVVRUBLvd7vSfBQAhISE4cOCATKVqHvr164clS5bg6quvRm5uLl555RUMGDAAe/bsQV5eHjQaDfz9/Z32CQkJcUyE2lbVvf+GPlN16/Ly8hAcHOy03svLC+3atWuT1++WW27B3XffjS5duuDIkSP4xz/+gVtvvRWZmZlQqVRt9npJkoSnnnoKN9xwA3r16gUAjfrZy8vLa/DzV7euNWroWgHA3/72N3Tu3BlhYWHYtWsXXnjhBRw8eBArVqwA0Pau1e7du5GQkICqqir4+vriq6++Qs+ePZGVldXsPlcMN+QWt956q+Pr3r17o1+/fujcuTM+//xz6PV6GUtGrc0DDzzg+DoqKgq9e/dGt27dsG7dOgwZMkTGkslrwoQJ2LNnj1NbN2rYha7V+e2yoqKi0KFDBwwZMgRHjhxBt27dPF1M2V199dXIyspCaWkpli9fjpSUFKxfv17uYjWIj6WuQGBgIFQqVb0W4fn5+QgNDZWpVM2Tv78/rrrqKhw+fBihoaGwWq0oKSlx2obXDY73f7HPVGhoaL0G6zabDWfOnGnz1w8AunbtisDAQBw+fBhA27xeEydOxHfffYe1a9eiY8eOjuWN+dkLDQ1t8PNXt661udC1aki/fv0AwOmz1ZaulUajQffu3REbG4v09HRER0djzpw5zfJzxXBzBTQaDWJjY5GRkeFYJkkSMjIykJCQIGPJmp/y8nIcOXIEHTp0QGxsLNRqtdN1O3jwIHJyctr8devSpQtCQ0Odro3JZMLmzZsd1yYhIQElJSXYvn27Y5tffvkFkiQ5fvm2ZSdPnkRxcTE6dOgAoG1dLyEEJk6ciK+++gq//PILunTp4rS+MT97CQkJ2L17t1MgXLNmDQwGA3r27OmZN+IBl7pWDcnKygIAp89WW7hWFyJJEiwWS/P8XLm8iXIbs3TpUqHVasWSJUvEvn37xKOPPir8/f2dWoS3Rc8884xYt26dOHbsmNi4caNITEwUgYGBoqCgQAghxGOPPSY6deokfvnlF7Ft2zaRkJAgEhISZC61Z5SVlYmdO3eKnTt3CgBi1qxZYufOneL48eNCCCHefPNN4e/vL77++muxa9cuMWzYMNGlSxdRWVnpOMYtt9wi+vTpIzZv3iw2bNggevToIUaOHCnXW3Kri12vsrIy8eyzz4rMzExx7Ngx8fPPP4u+ffuKHj16iKqqKscx2sr1evzxx4XRaBTr1q0Tubm5jldFRYVjm0v97NlsNtGrVy8xdOhQkZWVJVatWiWCgoLElClT5HhLbnOpa3X48GHx6quvim3btoljx46Jr7/+WnTt2lXceOONjmO0lWslhBCTJ08W69evF8eOHRO7du0SkydPFgqFQvz0009CiOb3uWK4cYF33nlHdOrUSWg0GhEfHy9+//13uYsku+TkZNGhQweh0WhEeHi4SE5OFocPH3asr6ysFOPHjxcBAQHC29tbjBgxQuTm5spYYs9Zu3atAFDvlZKSIoSo6Q7+0ksviZCQEKHVasWQIUPEwYMHnY5RXFwsRo4cKXx9fYXBYBCpqamirKxMhnfjfhe7XhUVFWLo0KEiKChIqNVq0blzZzF27Nh6f1y0levV0HUCIBYvXuzYpjE/e9nZ2eLWW28Ver1eBAYGimeeeUZUV1d7+N2416WuVU5OjrjxxhtFu3bthFarFd27dxfPPfecKC0tdTpOW7hWQgjx8MMPi86dOwuNRiOCgoLEkCFDHMFGiOb3uVIIIYTr64OIiIiI5ME2N0RERNSqMNwQERFRq8JwQ0RERK0Kww0RERG1Kgw3RERE1Kow3BAREVGrwnBDRERErQrDDRG1CevWrYNCoag3/w0RtT4MN0RERNSqMNwQERFRq8JwQ0TNiiRJmDFjBrp37w6tVotOnTrh9ddfx+DBgzFx4kSnbQsLC6HRaByzEVssFrzwwguIiIiAVqtF9+7d8cEHH1zwXBs2bMCAAQOg1+sRERGBJ598Emaz2a3vj4jcj+GGiJqVKVOm4M0338RLL72Effv24dNPP0VISAjGjBmDTz/9FBaLxbHtJ598gvDwcAwePBgAMHr0aHz22Wf4z3/+g/3792PBggXw9fVt8DxHjhzBLbfcgnvuuQe7du3CsmXLsGHDhnoBiohaHk6cSUTNRllZGYKCgjB37lyMGTPGaV1VVRXCwsIwf/583H///QCA6Oho3H333Zg+fTr++OMPXH311VizZg0SExPrHXvdunW46aabcPbsWfj7+2PMmDFQqVRYsGCBY5sNGzZg4MCBMJvN0Ol07n2zROQ2rLkhomZj//79sFgsGDJkSL11Op0ODz74IBYtWgQA2LFjB/bs2YOHHnoIAJCVlQWVSoWBAwc26lz/+9//sGTJEvj6+jpeSUlJkCQJx44dc9l7IiLP85K7AEREdfR6/UXXjxkzBjExMTh58iQWL16MwYMHo3Pnzo3a98/Ky8sxbtw4PPnkk/XWderUqUnHIqLmhTU3RNRs9OjRA3q93tFA+M+ioqIQFxeHhQsX4tNPP8XDDz/stE6SJKxfv75R5+rbty/27duH7t2713tpNBqXvB8ikgfDDRE1GzqdDi+88AKef/55fPTRRzhy5Ah+//13px5PY8aMwZtvvgkhBEaMGOFYHhkZiZSUFDz88MNYuXIljh07hnXr1uHzzz9v8FwvvPACNm3ahIkTJyIrKwuHDh3C119/zQbFRK0Aww0RNSsvvfQSnnnmGUybNg3XXnstkpOTUVBQ4Fg/cuRIeHl5YeTIkfUa/b733nu49957MX78eFxzzTUYO3bsBbt29+7dG+vXr8cff/yBAQMGoE+fPpg2bRrCwsLc+v6IyP3YW4qIWpTs7Gx069YNW7duRd++feUuDhE1Qww3RNQiVFdXo7i4GM8++yyOHTuGjRs3yl0kImqm+FiKiFqEjRs3okOHDti6dSvmz58vd3GIqBljzQ0RERG1Kqy5ISIiolaF4YaIiIhaFYYbIiIialUYboiIiKhVYbghIiKiVoXhhoiIiFoVhhsiIiJqVRhuiIiIqFVhuCEiIqJW5f8Bf6DJ+3yrRcgAAAAASUVORK5CYII=\n",
      "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.23450000000000001}, {'accuracy': 0.45964}, {'accuracy': 0.5443}, {'accuracy': 0.8157399999999999}, {'accuracy': 0.8836600000000001}, {'accuracy': 0.8981800000000002}, {'accuracy': 0.9079}, {'accuracy': 0.91713}, {'accuracy': 0.9239900000000001}, {'accuracy': 0.92972}, {'accuracy': 0.93315}, {'accuracy': 0.9358799999999998}, {'accuracy': 0.94047}, {'accuracy': 0.9431600000000001}, {'accuracy': 0.9459799999999999}, {'accuracy': 0.94788}, {'accuracy': 0.9497199999999999}, {'accuracy': 0.9514100000000001}, {'accuracy': 0.9506}, {'accuracy': 0.9516600000000001}, {'accuracy': 0.95164}, {'accuracy': 0.9542300000000001}, {'accuracy': 0.95577}, {'accuracy': 0.95619}, {'accuracy': 0.9574500000000002}, {'accuracy': 0.95888}, {'accuracy': 0.9591900000000001}, {'accuracy': 0.96052}, {'accuracy': 0.9603299999999999}, {'accuracy': 0.9601200000000001}, {'accuracy': 0.9610499999999998}, {'accuracy': 0.96237}, {'accuracy': 0.9625199999999999}, {'accuracy': 0.96273}, {'accuracy': 0.9634}, {'accuracy': 0.96387}, {'accuracy': 0.9641300000000002}, {'accuracy': 0.96445}, {'accuracy': 0.9651000000000002}, {'accuracy': 0.9654900000000002}, {'accuracy': 0.96645}, {'accuracy': 0.9667600000000001}, {'accuracy': 0.9672499999999999}, {'accuracy': 0.96771}, {'accuracy': 0.96782}, {'accuracy': 0.9675}, {'accuracy': 0.9681000000000001}, {'accuracy': 0.9687700000000001}, {'accuracy': 0.96937}, {'accuracy': 0.9689599999999998}, {'accuracy': 0.96897}, {'accuracy': 0.9705800000000002}, {'accuracy': 0.9705499999999999}, {'accuracy': 0.9705199999999999}, {'accuracy': 0.9703799999999999}, {'accuracy': 0.97097}, {'accuracy': 0.9709199999999999}, {'accuracy': 0.97151}, {'accuracy': 0.97142}, {'accuracy': 0.9715}, {'accuracy': 0.9716999999999999}, {'accuracy': 0.97237}, {'accuracy': 0.9723499999999999}, {'accuracy': 0.9727300000000001}, {'accuracy': 0.9731500000000001}, {'accuracy': 0.97394}, {'accuracy': 0.9727399999999999}, {'accuracy': 0.97394}, {'accuracy': 0.97334}, {'accuracy': 0.9737600000000001}, {'accuracy': 0.97342}, {'accuracy': 0.9738}, {'accuracy': 0.9741}, {'accuracy': 0.97474}, {'accuracy': 0.9747300000000001}, {'accuracy': 0.9751800000000002}, {'accuracy': 0.97493}, {'accuracy': 0.97499}, {'accuracy': 0.9756500000000001}, {'accuracy': 0.9759499999999999}, {'accuracy': 0.9756499999999999}, {'accuracy': 0.9761599999999999}, {'accuracy': 0.976}, {'accuracy': 0.9760499999999999}, {'accuracy': 0.9765699999999999}, {'accuracy': 0.97679}, {'accuracy': 0.9765}, {'accuracy': 0.97665}, {'accuracy': 0.97653}, {'accuracy': 0.9770199999999999}, {'accuracy': 0.9769}, {'accuracy': 0.9768700000000001}, {'accuracy': 0.9767199999999999}, {'accuracy': 0.97729}, {'accuracy': 0.97736}, {'accuracy': 0.97737}, {'accuracy': 0.97758}, {'accuracy': 0.97757}, {'accuracy': 0.9773799999999999}, {'accuracy': 0.9775600000000001}, {'accuracy': 0.9774999999999998}, {'accuracy': 0.97787}, {'accuracy': 0.97805}, {'accuracy': 0.97837}, {'accuracy': 0.97827}, {'accuracy': 0.97834}, {'accuracy': 0.97828}, {'accuracy': 0.9780200000000001}, {'accuracy': 0.97822}, {'accuracy': 0.97834}, {'accuracy': 0.97882}, {'accuracy': 0.9786199999999999}, {'accuracy': 0.97904}, {'accuracy': 0.97861}, {'accuracy': 0.9787399999999999}, {'accuracy': 0.9791399999999999}, {'accuracy': 0.9798199999999999}, {'accuracy': 0.97918}, {'accuracy': 0.97902}, {'accuracy': 0.9795800000000001}, {'accuracy': 0.97962}, {'accuracy': 0.97942}, {'accuracy': 0.9792400000000001}, {'accuracy': 0.9796400000000001}, {'accuracy': 0.9795999999999999}, {'accuracy': 0.9794500000000002}, {'accuracy': 0.97911}, {'accuracy': 0.9799200000000001}, {'accuracy': 0.9802200000000001}, {'accuracy': 0.9801499999999999}, {'accuracy': 0.98016}, {'accuracy': 0.9799599999999999}, {'accuracy': 0.9800600000000002}, {'accuracy': 0.9798899999999999}, {'accuracy': 0.98041}, {'accuracy': 0.9795999999999999}, {'accuracy': 0.9800700000000001}, {'accuracy': 0.9803900000000001}, {'accuracy': 0.98055}, {'accuracy': 0.9801599999999999}, {'accuracy': 0.9804600000000001}, {'accuracy': 0.9799199999999999}, {'accuracy': 0.98034}, {'accuracy': 0.9804300000000001}, {'accuracy': 0.98065}, {'accuracy': 0.98034}, {'accuracy': 0.9808299999999999}, {'accuracy': 0.9809100000000001}, {'accuracy': 0.9804799999999998}, {'accuracy': 0.9802500000000001}, {'accuracy': 0.97377}, {'accuracy': 0.9741099999999999}, {'accuracy': 0.9757099999999997}, {'accuracy': 0.97468}, {'accuracy': 0.9764099999999999}, {'accuracy': 0.97608}, {'accuracy': 0.9757900000000002}, {'accuracy': 0.97622}, {'accuracy': 0.9771599999999999}, {'accuracy': 0.97671}, {'accuracy': 0.97637}, {'accuracy': 0.9767300000000001}, {'accuracy': 0.9770800000000002}, {'accuracy': 0.9772699999999999}, {'accuracy': 0.97747}, {'accuracy': 0.97707}, {'accuracy': 0.9772299999999999}, {'accuracy': 0.9774700000000001}, {'accuracy': 0.9781300000000002}, {'accuracy': 0.9778800000000001}, {'accuracy': 0.9780900000000001}, {'accuracy': 0.97835}, {'accuracy': 0.97837}, {'accuracy': 0.97829}, {'accuracy': 0.97836}, {'accuracy': 0.97826}, {'accuracy': 0.9785699999999998}, {'accuracy': 0.97859}, {'accuracy': 0.9789299999999999}, {'accuracy': 0.9781899999999999}, {'accuracy': 0.97913}, {'accuracy': 0.9789199999999999}, {'accuracy': 0.9790599999999999}, {'accuracy': 0.9790800000000001}, {'accuracy': 0.9790800000000001}, {'accuracy': 0.9788500000000001}, {'accuracy': 0.9790600000000002}, {'accuracy': 0.9790000000000001}, {'accuracy': 0.9795300000000001}, {'accuracy': 0.97948}, {'accuracy': 0.97972}, {'accuracy': 0.9798800000000002}, {'accuracy': 0.9797499999999999}, {'accuracy': 0.9797300000000002}, {'accuracy': 0.9797499999999999}, {'accuracy': 0.9798899999999999}, {'accuracy': 0.9799499999999999}, {'accuracy': 0.98016}, {'accuracy': 0.9803799999999999}, {'accuracy': 0.9796800000000001}, {'accuracy': 0.9800599999999999}, {'accuracy': 0.9794699999999998}, {'accuracy': 0.9801500000000001}, {'accuracy': 0.9796800000000001}, {'accuracy': 0.9801399999999999}, {'accuracy': 0.97979}, {'accuracy': 0.98003}, {'accuracy': 0.9801900000000001}, {'accuracy': 0.9802699999999998}, {'accuracy': 0.9798499999999999}, {'accuracy': 0.97976}, {'accuracy': 0.9802099999999999}, {'accuracy': 0.9798399999999999}, {'accuracy': 0.9804600000000001}, {'accuracy': 0.9797100000000001}, {'accuracy': 0.9803}, {'accuracy': 0.98026}, {'accuracy': 0.9798600000000001}, {'accuracy': 0.98066}, {'accuracy': 0.9805699999999999}, {'accuracy': 0.9804100000000002}, {'accuracy': 0.9804700000000001}, {'accuracy': 0.98009}, {'accuracy': 0.97987}, {'accuracy': 0.98048}, {'accuracy': 0.98013}, {'accuracy': 0.98048}, {'accuracy': 0.9804}, {'accuracy': 0.98045}, {'accuracy': 0.9802099999999999}, {'accuracy': 0.9800800000000001}, {'accuracy': 0.9803200000000001}, {'accuracy': 0.9808600000000001}, {'accuracy': 0.9806000000000001}, {'accuracy': 0.98055}, {'accuracy': 0.9804700000000001}, {'accuracy': 0.9803400000000002}, {'accuracy': 0.9803900000000001}, {'accuracy': 0.9801300000000002}, {'accuracy': 0.9806299999999999}, {'accuracy': 0.9809600000000002}, {'accuracy': 0.98087}, {'accuracy': 0.98073}, {'accuracy': 0.9807500000000001}, {'accuracy': 0.9809900000000003}, {'accuracy': 0.9807500000000001}, {'accuracy': 0.98077}, {'accuracy': 0.98101}, {'accuracy': 0.9805699999999999}, {'accuracy': 0.9812900000000001}, {'accuracy': 0.9807499999999999}, {'accuracy': 0.9810800000000001}, {'accuracy': 0.9807699999999999}, {'accuracy': 0.9810800000000001}, {'accuracy': 0.9806900000000001}, {'accuracy': 0.98078}, {'accuracy': 0.98071}, {'accuracy': 0.98081}, {'accuracy': 0.98077}, {'accuracy': 0.9812200000000001}, {'accuracy': 0.9811000000000002}, {'accuracy': 0.9814}, {'accuracy': 0.9810399999999999}, {'accuracy': 0.98102}, {'accuracy': 0.98142}, {'accuracy': 0.9821500000000001}, {'accuracy': 0.9814299999999999}, {'accuracy': 0.98127}, {'accuracy': 0.9810000000000001}, {'accuracy': 0.98112}, {'accuracy': 0.9810700000000001}, {'accuracy': 0.9807499999999999}, {'accuracy': 0.9812199999999999}, {'accuracy': 0.98079}, {'accuracy': 0.98103}, {'accuracy': 0.9811799999999999}, {'accuracy': 0.9816}, {'accuracy': 0.9817899999999999}, {'accuracy': 0.9815699999999999}, {'accuracy': 0.9814499999999999}, {'accuracy': 0.9817200000000001}, {'accuracy': 0.9814}, {'accuracy': 0.9814900000000002}, {'accuracy': 0.9812000000000001}, {'accuracy': 0.9809700000000001}, {'accuracy': 0.9812}, {'accuracy': 0.9812800000000002}, {'accuracy': 0.98123}, {'accuracy': 0.98138}, {'accuracy': 0.9811099999999999}, {'accuracy': 0.9811}, {'accuracy': 0.98124}, {'accuracy': 0.9814099999999998}, {'accuracy': 0.9812099999999999}, {'accuracy': 0.98102}, {'accuracy': 0.9815399999999999}, {'accuracy': 0.9813599999999999}, {'accuracy': 0.98155}, {'accuracy': 0.98163}, {'accuracy': 0.9812900000000001}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "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": "badcd6ec-9721-42c9-9dd5-9b5130db3188",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5b6fe361-f901-46d7-9d2c-4115348e2c32",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "524e4643-9d37-4266-b524-d5f5509a2639",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e8189f4-56c4-49ff-a334-ff9ab6bd60e4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b464effc-545d-4fcd-94dc-3db1612e6457",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e81866ef-347a-4b9c-8f5c-0b377341b02a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a2b174fa-a81f-428a-9db5-dfe69b4238c3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "875a2d34-e178-4e13-a739-8e05a9713390",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "22592b6e-3c77-4c7a-922c-34b10cff3321",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bdda39ad-3b5a-4490-bf92-f5603f0e70ac",
   "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
}
