{
 "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",
      "6024\n",
      "[[  0 571]\n",
      " [  1 648]\n",
      " [  2 614]\n",
      " [  3 600]\n",
      " [  4 590]\n",
      " [  5 564]\n",
      " [  6 614]\n",
      " [  7 601]\n",
      " [  8 618]\n",
      " [  9 537]]\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<1:\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([6, 5, 0,  ..., 2, 5, 3])"
      ]
     },
     "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",
    "\n",
    "\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:09:02 </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:09:02\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": "2c0fce9580ab4e849df36e4da7153b87",
       "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:08:30 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3451</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-00:08:30\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3451\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\">75369840</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;36m75369840\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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fDweeeQRtG3bFidPnsTixYuRn5+PTz75xHWbr5NGo8Fdd92F5cuXw2w245///GeN9543bx569+6N+Ph4jBs3Du3atUNOTg7S09Nx5swZ/P7775et7/bbb8d//vMfmEwmdOrUCenp6fjxxx/RsmVLj52DxMREvP/++/jHP/6BuLg4hIWFoV+/fnjuuefw1Vdf4fbbb8fo0aORmJgIs9mMPXv2YOXKlTh58iRCQkIwduxYFBYWol+/fmjVqhVOnTqFd999F127dnXd7t21a1eoVCq8/fbbKCkpgU6nQ79+/RAWFlavWvv27Yvx48djxowZyMjIwIABA6DRaHDkyBF89tlnmDt3Lu655x58+OGHmD9/PoYOHYr27dujrKwMixYtgtFoxKBBgwBUd0vee++9ePfdd6FQKNC+fXt88803NcZCXeq8/fjjj5g9ezaioqLQtm1bdOzYEa1atcI999yDhIQEBAQE4Mcff8S2bdvcWt+ImgR5b9YiosvZvXu3GD58uIiMjBQajUZERESI4cOHiz179lx0n3Xr1gkAQqFQiNOnT9e6zbFjx8TIkSNFRESE0Gg0Ijo6Wtx+++1i5cqVrm2ct4LXdttyUVGRGDNmjAgJCREBAQEiJSVFHDx4ULRp08btNuQruRU8Oztb3HbbbSIwMFAAcLstvKysTEyZMkXExcUJrVYrQkJCxPXXXy/++c9/CqvVKoQQYuXKlWLAgAEiLCxMaLVa0bp1azF+/HiRlZXldpxFixaJdu3aCZVKddnbwkeNGiX8/f0vuv6DDz4QiYmJwmAwiMDAQBEfHy+ef/55ce7cOSGEEDt37hTDhw8XrVu3FjqdToSFhYnbb79dbN++3e198vLyxN133y38/PxEixYtxPjx48XevXvrdCv4wYMHxY033igMBoMAIEaNGiUsFot47rnnREJCgggMDBT+/v4iISFBzJ8//1J/BESNkkKIP7WPEhERETViHHNDRERETQrDDRERETUpDDdERETUpDDcEBERUZPCcENERERNCsMNERERNSnN7iF+kiTh3LlzCAwM9Nhj14mIiMi7hBAoKytDVFRUjbnd/qzZhZtz584hJiZG7jKIiIjoLzh9+jRatWp1yW2aXbgJDAwEUH1ynDMpExERUcNWWlqKmJgY13X8UppduHF2RRmNRoYbIiKiRqYuQ0o4oJiIiIiaFFnD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8RDnQ/w45oaIiJoCm80mdwl/GcONhzgHFHPSTCIi+ivWrFmD3r17IygoCC1btsTtt9+OY8eOudafOXMGw4cPR3BwMPz9/dGjRw/89ttvrvVff/01/va3v0Gv1yMkJARDhw51rVMoFPjiiy/cjhcUFIRly5YBAE6ePAmFQoEVK1agb9++0Ov1+N///oeCggIMHz4c0dHR8PPzQ3x8PD755BO395EkCTNnzkRcXBx0Oh1at26NN954AwDQr18/TJw40W37vLw8aLVapKWleeK01Yq3gnvIH91SMhdCREQuQghU2uR5UrFBo6rX3T9msxmpqano0qULysvLMW3aNAwdOhQZGRmoqKhA3759ER0dja+++goRERHYuXMnpPOPx//2228xdOhQvPTSS/joo49gtVrx3Xff1bvmyZMnY9asWejWrRv0ej2qqqqQmJiIF154AUajEd9++y0eeughtG/fHj179gQATJkyBYsWLcK//vUv9O7dG1lZWTh48CAAYOzYsZg4cSJmzZoFnU4HAPjvf/+L6Oho9OvXr9711RXDjYe4uqWYboiIGoxKmwOdpq2V5dj7X0uBn7bul9m7777b7eclS5YgNDQU+/fvx5YtW5CXl4dt27YhODgYABAXF+fa9o033sD999+PV1991bUsISGh3jU/9dRTuOuuu9yWPfvss67///vf/461a9fi008/Rc+ePVFWVoa5c+fivffew6hRowAA7du3R+/evQEAd911FyZOnIgvv/wS9913HwBg2bJlGD16tFefCdcguqXmzZuH2NhY6PV69OrVC1u3bq3TfsuXL4dCocCdd97p3QLrwNlywwf4ERHRX3HkyBEMHz4c7dq1g9FoRGxsLAAgMzMTGRkZ6NatmyvY/FlGRgb69+9/xTX06NHD7WeHw4HXX38d8fHxCA4ORkBAANauXYvMzEwAwIEDB2CxWC56bL1ej4ceeghLliwBAOzcuRN79+7F6NGjr7jWS5G95WbFihVITU3FggUL0KtXL8yZMwcpKSk4dOgQwsLCLrrfyZMn8eyzz6JPnz4+rPbinBNnckAxEVHDYdCosP+1FNmOXR+DBw9GmzZtsGjRIkRFRUGSJHTu3BlWqxUGg+HSx7rMeoVCAXHBNEFA7QOG/f393X5+5513MHfuXMyZMwfx8fHw9/fHU089BavVWqfjAtVdU127dsWZ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\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.4}, {'accuracy': 0.65629}, {'accuracy': 0.72458}, {'accuracy': 0.8654399999999999}, {'accuracy': 0.90532}, {'accuracy': 0.9191900000000001}, {'accuracy': 0.9215700000000002}, {'accuracy': 0.92831}, {'accuracy': 0.93575}, {'accuracy': 0.94065}, {'accuracy': 0.94309}, {'accuracy': 0.9460700000000001}, {'accuracy': 0.94519}, {'accuracy': 0.9498099999999999}, {'accuracy': 0.9513800000000001}, {'accuracy': 0.95373}, {'accuracy': 0.9566000000000001}, {'accuracy': 0.9576800000000001}, {'accuracy': 0.95936}, {'accuracy': 0.9577199999999999}, {'accuracy': 0.9609500000000001}, {'accuracy': 0.96081}, {'accuracy': 0.96237}, {'accuracy': 0.96302}, {'accuracy': 0.96434}, {'accuracy': 0.9651799999999999}, {'accuracy': 0.9659199999999999}, {'accuracy': 0.9667200000000001}, {'accuracy': 0.9674099999999999}, {'accuracy': 0.9682099999999998}, {'accuracy': 0.9689100000000002}, {'accuracy': 0.9682499999999999}, {'accuracy': 0.9693100000000001}, {'accuracy': 0.96967}, {'accuracy': 0.97028}, {'accuracy': 0.9701700000000001}, {'accuracy': 0.9714200000000002}, {'accuracy': 0.9716400000000002}, {'accuracy': 0.9722499999999998}, {'accuracy': 0.97292}, {'accuracy': 0.97346}, {'accuracy': 0.9732799999999999}, {'accuracy': 0.9741299999999999}, {'accuracy': 0.9738900000000001}, {'accuracy': 0.97468}, {'accuracy': 0.9749099999999998}, {'accuracy': 0.9747599999999998}, {'accuracy': 0.97488}, {'accuracy': 0.9752699999999999}, {'accuracy': 0.9759900000000001}, {'accuracy': 0.9761000000000001}, {'accuracy': 0.9756099999999999}, {'accuracy': 0.9762300000000002}, {'accuracy': 0.97675}, {'accuracy': 0.97712}, {'accuracy': 0.9767999999999999}, {'accuracy': 0.9773000000000002}, {'accuracy': 0.97669}, {'accuracy': 0.9773700000000002}, {'accuracy': 0.97766}, {'accuracy': 0.97744}, {'accuracy': 0.9785300000000001}, {'accuracy': 0.97821}, {'accuracy': 0.9782}, {'accuracy': 0.97834}, {'accuracy': 0.9784499999999999}, {'accuracy': 0.97869}, {'accuracy': 0.97894}, {'accuracy': 0.9790800000000001}, {'accuracy': 0.97911}, {'accuracy': 0.9794400000000001}, {'accuracy': 0.9794099999999999}, {'accuracy': 0.9798499999999999}, {'accuracy': 0.97972}, {'accuracy': 0.97981}, {'accuracy': 0.9791700000000001}, {'accuracy': 0.9793600000000001}, {'accuracy': 0.9801200000000001}, {'accuracy': 0.98017}, {'accuracy': 0.9802200000000001}, {'accuracy': 0.9806499999999998}, {'accuracy': 0.9805999999999999}, {'accuracy': 0.9797}, {'accuracy': 0.9802100000000001}, {'accuracy': 0.98062}, {'accuracy': 0.9809100000000001}, {'accuracy': 0.9806099999999999}, {'accuracy': 0.98072}, {'accuracy': 0.98074}, {'accuracy': 0.98091}, {'accuracy': 0.98088}, {'accuracy': 0.9810800000000001}, {'accuracy': 0.9811099999999999}, {'accuracy': 0.9812000000000001}, {'accuracy': 0.9810199999999998}, {'accuracy': 0.9815000000000002}, {'accuracy': 0.9810700000000001}, {'accuracy': 0.9814800000000001}, {'accuracy': 0.9815500000000001}, {'accuracy': 0.9812800000000002}, {'accuracy': 0.98185}, {'accuracy': 0.9821000000000002}, {'accuracy': 0.9814999999999999}, {'accuracy': 0.9822199999999999}, {'accuracy': 0.98194}, {'accuracy': 0.98225}, {'accuracy': 0.98228}, {'accuracy': 0.9823599999999999}, {'accuracy': 0.98201}, {'accuracy': 0.9824999999999999}, {'accuracy': 0.9822000000000001}, {'accuracy': 0.98201}, {'accuracy': 0.9827199999999999}, {'accuracy': 0.98249}, {'accuracy': 0.9826600000000001}, {'accuracy': 0.9827299999999999}, {'accuracy': 0.9825200000000001}, {'accuracy': 0.9827299999999999}, {'accuracy': 0.9825099999999999}, {'accuracy': 0.9830500000000001}, {'accuracy': 0.98308}, {'accuracy': 0.98316}, {'accuracy': 0.98285}, {'accuracy': 0.9828699999999999}, {'accuracy': 0.98284}, {'accuracy': 0.98314}, {'accuracy': 0.98345}, {'accuracy': 0.98314}, {'accuracy': 0.98306}, {'accuracy': 0.98321}, {'accuracy': 0.9833700000000001}, {'accuracy': 0.9835100000000001}, {'accuracy': 0.98346}, {'accuracy': 0.98363}, {'accuracy': 0.9835800000000001}, {'accuracy': 0.98363}, {'accuracy': 0.98368}, {'accuracy': 0.9835699999999999}, {'accuracy': 0.98382}, {'accuracy': 0.98386}, {'accuracy': 0.9839399999999999}, {'accuracy': 0.9839}, {'accuracy': 0.9835899999999999}, {'accuracy': 0.98339}, {'accuracy': 0.98332}, {'accuracy': 0.98356}, {'accuracy': 0.98383}, {'accuracy': 0.98384}, {'accuracy': 0.98383}, {'accuracy': 0.9841900000000001}, {'accuracy': 0.9819800000000001}, {'accuracy': 0.98038}, {'accuracy': 0.98174}, {'accuracy': 0.98052}, {'accuracy': 0.9805400000000001}, {'accuracy': 0.98037}, {'accuracy': 0.9804999999999999}, {'accuracy': 0.98127}, {'accuracy': 0.9805499999999998}, {'accuracy': 0.9812600000000001}, {'accuracy': 0.9807}, {'accuracy': 0.9808899999999999}, {'accuracy': 0.98155}, {'accuracy': 0.98125}, {'accuracy': 0.9816600000000001}, {'accuracy': 0.9817899999999999}, {'accuracy': 0.9818}, {'accuracy': 0.9821000000000002}, {'accuracy': 0.9819100000000001}, {'accuracy': 0.9817599999999999}, {'accuracy': 0.98199}, {'accuracy': 0.9817199999999999}, {'accuracy': 0.9822299999999998}, {'accuracy': 0.9821899999999999}, {'accuracy': 0.98234}, {'accuracy': 0.9820399999999999}, {'accuracy': 0.9824900000000001}, {'accuracy': 0.9826900000000001}, {'accuracy': 0.9820799999999998}, {'accuracy': 0.9819599999999999}, {'accuracy': 0.9822199999999999}, {'accuracy': 0.98267}, {'accuracy': 0.9832099999999999}, {'accuracy': 0.9827600000000001}, {'accuracy': 0.9830499999999999}, {'accuracy': 0.9830099999999999}, {'accuracy': 0.9828000000000001}, {'accuracy': 0.9831799999999999}, {'accuracy': 0.9830400000000001}, {'accuracy': 0.9827}, {'accuracy': 0.98254}, {'accuracy': 0.9825099999999999}, {'accuracy': 0.98281}, {'accuracy': 0.98284}, {'accuracy': 0.9829700000000001}, {'accuracy': 0.9824599999999999}, {'accuracy': 0.9826600000000001}, {'accuracy': 0.98293}, {'accuracy': 0.98302}, {'accuracy': 0.98293}, {'accuracy': 0.9828699999999999}, {'accuracy': 0.9830200000000001}, {'accuracy': 0.98285}, {'accuracy': 0.9824999999999999}, {'accuracy': 0.9827400000000001}, {'accuracy': 0.98282}, {'accuracy': 0.98307}, {'accuracy': 0.98285}, {'accuracy': 0.9827699999999998}, {'accuracy': 0.9826900000000001}, {'accuracy': 0.9831999999999999}, {'accuracy': 0.9835}, {'accuracy': 0.9830200000000001}, {'accuracy': 0.98328}, {'accuracy': 0.9827499999999999}, {'accuracy': 0.98278}, {'accuracy': 0.98299}, {'accuracy': 0.98299}, {'accuracy': 0.98293}, {'accuracy': 0.98315}, {'accuracy': 0.98375}, {'accuracy': 0.9829500000000001}, {'accuracy': 0.98316}, {'accuracy': 0.9831900000000001}, {'accuracy': 0.98307}, {'accuracy': 0.9831}, {'accuracy': 0.9835199999999998}, {'accuracy': 0.9831799999999999}, {'accuracy': 0.9833500000000001}, {'accuracy': 0.98346}, {'accuracy': 0.98325}, {'accuracy': 0.9829000000000001}, {'accuracy': 0.9832599999999999}, {'accuracy': 0.9831800000000002}, {'accuracy': 0.9834399999999999}, {'accuracy': 0.98328}, {'accuracy': 0.9833000000000001}, {'accuracy': 0.9835}, {'accuracy': 0.9831199999999999}, {'accuracy': 0.9832599999999999}, {'accuracy': 0.9835200000000001}, {'accuracy': 0.98343}, {'accuracy': 0.9831200000000001}, {'accuracy': 0.9833299999999999}, {'accuracy': 0.98324}, {'accuracy': 0.9833500000000001}, {'accuracy': 0.98338}, {'accuracy': 0.98356}, {'accuracy': 0.98309}, {'accuracy': 0.98389}, {'accuracy': 0.9837400000000001}, {'accuracy': 0.9840100000000002}, {'accuracy': 0.98342}, {'accuracy': 0.98369}, {'accuracy': 0.9835}, {'accuracy': 0.9839}, {'accuracy': 0.9836599999999999}, {'accuracy': 0.9835800000000001}, {'accuracy': 0.9833700000000001}, {'accuracy': 0.9836199999999999}, {'accuracy': 0.98377}, {'accuracy': 0.9836600000000001}, {'accuracy': 0.98411}, {'accuracy': 0.9834600000000002}, {'accuracy': 0.98356}, {'accuracy': 0.9833700000000001}, {'accuracy': 0.9835899999999999}, {'accuracy': 0.98378}, {'accuracy': 0.9834099999999999}, {'accuracy': 0.98345}, {'accuracy': 0.9833300000000001}, {'accuracy': 0.9837400000000003}, {'accuracy': 0.9837700000000001}, {'accuracy': 0.9838700000000001}, {'accuracy': 0.98385}, {'accuracy': 0.9842899999999999}, {'accuracy': 0.98342}, {'accuracy': 0.9832599999999999}, {'accuracy': 0.98378}, {'accuracy': 0.9837}, {'accuracy': 0.9837499999999999}, {'accuracy': 0.98303}, {'accuracy': 0.9835800000000001}, {'accuracy': 0.9834099999999999}, {'accuracy': 0.98383}, {'accuracy': 0.98382}, {'accuracy': 0.9834100000000001}, {'accuracy': 0.9838600000000002}, {'accuracy': 0.9840200000000001}, {'accuracy': 0.9835799999999999}, {'accuracy': 0.9838099999999999}, {'accuracy': 0.9837000000000001}, {'accuracy': 0.9843000000000002}, {'accuracy': 0.9842299999999999}, {'accuracy': 0.9841099999999999}, {'accuracy': 0.98385}, {'accuracy': 0.9835100000000001}, {'accuracy': 0.9839399999999999}, {'accuracy': 0.9845499999999999}, {'accuracy': 0.9839800000000001}]\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": "36bc0529-fb45-49ae-b5e9-f0f774dbd9d7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1ce96900-09aa-42e9-94ca-3b9d5f0390c5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d608b6b2-9d0b-4b12-b10b-f44615bff04c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bc001961-edd2-4489-8b9a-79a33fab39a3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6553deae-4451-4581-9b36-7a3605ec98b2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4f7ab240-209e-4e53-ac90-e4d321a0a2bc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "13ea07fb-f328-4ef5-9686-8b3005ca246f",
   "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
}
