{
 "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",
      "5935\n",
      "[[  0 606]\n",
      " [  1 674]\n",
      " [  2 605]\n",
      " [  3 593]\n",
      " [  4 580]\n",
      " [  5 490]\n",
      " [  6 644]\n",
      " [  7 629]\n",
      " [  8 570]\n",
      " [  9 614]]\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([1, 9, 0,  ..., 5, 6, 8])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "d212199d-c71b-46e8-8602-14f2e1d5f0ab",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2439\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 566]\n",
      " [  1 637]\n",
      " [  2 572]\n",
      " [  3 600]\n",
      " [  4 583]\n",
      " [  5 558]\n",
      " [  6 529]\n",
      " [  7 580]\n",
      " [  8 566]\n",
      " [  9 566]]\n",
      "[[  0 781]\n",
      " [  1 641]\n",
      " [  2 572]\n",
      " [  3 600]\n",
      " [  4 583]\n",
      " [  5 558]\n",
      " [  6 563]\n",
      " [  7 647]\n",
      " [  8 566]\n",
      " [  9 566]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([1, 9, 0,  ..., 7, 7, 7])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set = tran1, tag1\n",
    "\n",
    "#\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "dataset1=[]\n",
    "target1=[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,60000,1):\n",
    "    dataset1.append(train_set[0][z])\n",
    "    target1.append(train_set[1][z])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "len(target1)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "\n",
    "noiseyset=[],[]\n",
    "healthset=[],[],[]\n",
    "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",
    "        if target1[z]==6:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(0))\n",
    "        \n",
    "        elif target1[z]==0:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(6))      \n",
    "        \n",
    "        elif target1[z]==1:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(7))\n",
    "        \n",
    "        \n",
    "        elif target1[z]==7:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(1))    \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\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",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\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",
    "\n"
   ]
  },
  {
   "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",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "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\">151023-23:26:15 </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-23:26:15\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": "f516d3ec8c924760a4e502ff513c29a3",
       "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\">161023-00:02:23 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3362</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m161023-00:02:23\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3362\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\">73426080</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;36m73426080\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": [
      "[{'accuracy': 0.11065}, {'accuracy': 0.29002}, {'accuracy': 0.48385}, {'accuracy': 0.72157}, {'accuracy': 0.62064}, {'accuracy': 0.72102}, {'accuracy': 0.79658}, {'accuracy': 0.6569499999999999}, {'accuracy': 0.69997}, {'accuracy': 0.76443}, {'accuracy': 0.7329600000000001}, {'accuracy': 0.7701699999999999}, {'accuracy': 0.75864}, {'accuracy': 0.8277100000000001}, {'accuracy': 0.83492}, {'accuracy': 0.84583}, {'accuracy': 0.88581}, {'accuracy': 0.7936500000000001}, {'accuracy': 0.85443}, {'accuracy': 0.62428}, {'accuracy': 0.86492}, {'accuracy': 0.83858}, {'accuracy': 0.82743}, {'accuracy': 0.8255399999999999}, {'accuracy': 0.77708}, {'accuracy': 0.84459}, {'accuracy': 0.82602}, {'accuracy': 0.82011}, {'accuracy': 0.8811200000000001}, {'accuracy': 0.68849}, {'accuracy': 0.74545}, {'accuracy': 0.6541499999999999}, {'accuracy': 0.84604}, {'accuracy': 0.8360200000000001}, {'accuracy': 0.8695600000000001}, {'accuracy': 0.86091}, {'accuracy': 0.81717}, {'accuracy': 0.9383699999999999}, {'accuracy': 0.9162699999999999}, {'accuracy': 0.9212000000000001}, {'accuracy': 0.84177}, {'accuracy': 0.77145}, {'accuracy': 0.77019}, {'accuracy': 0.8326600000000001}, {'accuracy': 0.80791}, {'accuracy': 0.6797000000000001}, {'accuracy': 0.83747}, {'accuracy': 0.8773399999999999}, {'accuracy': 0.7090399999999999}, {'accuracy': 0.72639}, {'accuracy': 0.7988500000000001}, {'accuracy': 0.6889299999999999}, {'accuracy': 0.8105800000000001}, {'accuracy': 0.86342}, {'accuracy': 0.8343}, {'accuracy': 0.6886300000000001}, {'accuracy': 0.78727}, {'accuracy': 0.78816}, {'accuracy': 0.85906}, {'accuracy': 0.7762199999999999}, {'accuracy': 0.8349}, {'accuracy': 0.7189300000000001}, {'accuracy': 0.75539}, {'accuracy': 0.68187}, {'accuracy': 0.88544}, {'accuracy': 0.68956}, {'accuracy': 0.76751}, {'accuracy': 0.85846}, {'accuracy': 0.79517}, {'accuracy': 0.68593}, {'accuracy': 0.6511}, {'accuracy': 0.8297399999999999}, {'accuracy': 0.80123}, {'accuracy': 0.8168799999999999}, {'accuracy': 0.7342799999999999}, {'accuracy': 0.8273400000000001}, {'accuracy': 0.89161}, {'accuracy': 0.9062199999999999}, {'accuracy': 0.7230000000000001}, {'accuracy': 0.8615299999999999}, {'accuracy': 0.8101800000000001}, {'accuracy': 0.9320300000000001}, {'accuracy': 0.77026}, {'accuracy': 0.9279700000000002}, {'accuracy': 0.8538000000000002}, {'accuracy': 0.7541300000000001}, {'accuracy': 0.88269}, {'accuracy': 0.9275}, {'accuracy': 0.7501800000000001}, {'accuracy': 0.7352}, {'accuracy': 0.9078700000000002}, {'accuracy': 0.6339600000000001}, {'accuracy': 0.84045}, {'accuracy': 0.63947}, {'accuracy': 0.9237299999999999}, {'accuracy': 0.8002500000000001}, {'accuracy': 0.8072900000000001}, {'accuracy': 0.90999}, {'accuracy': 0.88859}, {'accuracy': 0.81777}, {'accuracy': 0.7313400000000001}, {'accuracy': 0.90564}, {'accuracy': 0.79413}, {'accuracy': 0.85885}, {'accuracy': 0.63322}, {'accuracy': 0.9024599999999999}, {'accuracy': 0.8515600000000001}, {'accuracy': 0.78567}, {'accuracy': 0.78047}, {'accuracy': 0.6352599999999999}, {'accuracy': 0.74139}, {'accuracy': 0.9427100000000002}, {'accuracy': 0.7127199999999999}, {'accuracy': 0.7887600000000001}, {'accuracy': 0.7318}, {'accuracy': 0.73059}, {'accuracy': 0.85789}, {'accuracy': 0.8129899999999999}, {'accuracy': 0.7813100000000001}, {'accuracy': 0.7333999999999999}, {'accuracy': 0.9484999999999999}, {'accuracy': 0.6683}, {'accuracy': 0.6996100000000001}, {'accuracy': 0.6975499999999999}, {'accuracy': 0.8133099999999999}, {'accuracy': 0.68621}, {'accuracy': 0.8693199999999999}, {'accuracy': 0.7879}, {'accuracy': 0.8603799999999999}, {'accuracy': 0.73336}, {'accuracy': 0.7817700000000001}, {'accuracy': 0.8550099999999998}, {'accuracy': 0.85211}, {'accuracy': 0.8422599999999999}, {'accuracy': 0.81182}, {'accuracy': 0.79974}, {'accuracy': 0.80733}, {'accuracy': 0.8757300000000001}, {'accuracy': 0.8700199999999999}, {'accuracy': 0.8681800000000001}, {'accuracy': 0.91905}, {'accuracy': 0.8205}, {'accuracy': 0.82211}, {'accuracy': 0.7429899999999999}, {'accuracy': 0.9549900000000001}, {'accuracy': 0.83981}, {'accuracy': 0.8053700000000001}, {'accuracy': 0.7540899999999999}, {'accuracy': 0.7891699999999999}, {'accuracy': 0.75945}, {'accuracy': 0.71744}, {'accuracy': 0.80724}, {'accuracy': 0.9737499999999999}, {'accuracy': 0.97364}, {'accuracy': 0.9731200000000001}, {'accuracy': 0.97668}, {'accuracy': 0.9768099999999998}, {'accuracy': 0.97279}, {'accuracy': 0.9752199999999999}, {'accuracy': 0.9725299999999999}, {'accuracy': 0.9755900000000001}, {'accuracy': 0.9727}, {'accuracy': 0.9741900000000001}, {'accuracy': 0.9735700000000002}, {'accuracy': 0.9737500000000001}, {'accuracy': 0.9755799999999999}, {'accuracy': 0.97492}, {'accuracy': 0.97211}, {'accuracy': 0.9738}, {'accuracy': 0.9730399999999999}, {'accuracy': 0.97586}, {'accuracy': 0.97503}, {'accuracy': 0.9745899999999998}, {'accuracy': 0.9757399999999998}, {'accuracy': 0.9764099999999999}, {'accuracy': 0.9737599999999998}, {'accuracy': 0.9734}, {'accuracy': 0.97561}, {'accuracy': 0.97657}, {'accuracy': 0.97721}, {'accuracy': 0.9754900000000001}, {'accuracy': 0.97366}, {'accuracy': 0.9747000000000001}, {'accuracy': 0.97683}, {'accuracy': 0.97575}, {'accuracy': 0.97632}, {'accuracy': 0.97591}, {'accuracy': 0.9771999999999998}, {'accuracy': 0.9743699999999998}, {'accuracy': 0.9760199999999999}, {'accuracy': 0.9770999999999999}, {'accuracy': 0.97624}, {'accuracy': 0.9730700000000001}, {'accuracy': 0.9763}, {'accuracy': 0.9755}, {'accuracy': 0.9774199999999998}, {'accuracy': 0.9750500000000001}, {'accuracy': 0.97576}, {'accuracy': 0.9740399999999999}, {'accuracy': 0.97538}, {'accuracy': 0.9746699999999999}, {'accuracy': 0.97683}, {'accuracy': 0.9761799999999999}, {'accuracy': 0.97516}, {'accuracy': 0.97669}, {'accuracy': 0.9767999999999999}, {'accuracy': 0.9769}, {'accuracy': 0.9766}, {'accuracy': 0.97586}, {'accuracy': 0.9777000000000001}, {'accuracy': 0.9767300000000001}, {'accuracy': 0.9755899999999998}, {'accuracy': 0.97529}, {'accuracy': 0.97759}, {'accuracy': 0.97647}, {'accuracy': 0.97637}, {'accuracy': 0.97654}, {'accuracy': 0.9760899999999999}, {'accuracy': 0.97455}, {'accuracy': 0.97766}, {'accuracy': 0.9751999999999998}, {'accuracy': 0.9770899999999999}, {'accuracy': 0.97549}, {'accuracy': 0.9768899999999998}, {'accuracy': 0.97815}, {'accuracy': 0.9773099999999999}, {'accuracy': 0.97652}, {'accuracy': 0.9776000000000001}, {'accuracy': 0.9773299999999999}, {'accuracy': 0.9773799999999999}, {'accuracy': 0.97711}, {'accuracy': 0.9777899999999999}, {'accuracy': 0.9753799999999998}, {'accuracy': 0.97447}, {'accuracy': 0.97506}, {'accuracy': 0.9773799999999999}, {'accuracy': 0.97691}, {'accuracy': 0.9749399999999999}, {'accuracy': 0.97712}, {'accuracy': 0.97704}, {'accuracy': 0.9758099999999998}, {'accuracy': 0.97812}, {'accuracy': 0.9773400000000001}, {'accuracy': 0.9762500000000001}, {'accuracy': 0.9751900000000001}, {'accuracy': 0.97753}, {'accuracy': 0.9782699999999999}, {'accuracy': 0.9764299999999999}, {'accuracy': 0.9764299999999999}, {'accuracy': 0.97682}, {'accuracy': 0.97722}, {'accuracy': 0.97657}, {'accuracy': 0.97774}, {'accuracy': 0.9753699999999998}, {'accuracy': 0.9761900000000001}, {'accuracy': 0.97769}, {'accuracy': 0.9781600000000001}, {'accuracy': 0.9767899999999999}, {'accuracy': 0.9772599999999999}, {'accuracy': 0.97746}, {'accuracy': 0.9751799999999999}, {'accuracy': 0.97553}, {'accuracy': 0.9779}, {'accuracy': 0.97774}, {'accuracy': 0.9768699999999999}, {'accuracy': 0.9755800000000001}, {'accuracy': 0.9778099999999998}, {'accuracy': 0.9776}, {'accuracy': 0.97668}, {'accuracy': 0.9769399999999999}, {'accuracy': 0.9770300000000001}, {'accuracy': 0.9778600000000001}, {'accuracy': 0.97759}, {'accuracy': 0.9784199999999998}, {'accuracy': 0.9756599999999999}, {'accuracy': 0.9758600000000002}, {'accuracy': 0.9782399999999999}, {'accuracy': 0.9763}, {'accuracy': 0.97493}, {'accuracy': 0.97883}, {'accuracy': 0.97754}, {'accuracy': 0.97606}, {'accuracy': 0.9767699999999999}, {'accuracy': 0.97645}, {'accuracy': 0.97599}, {'accuracy': 0.9770300000000001}, {'accuracy': 0.9762599999999999}, {'accuracy': 0.9749399999999999}, {'accuracy': 0.97836}, {'accuracy': 0.97728}, {'accuracy': 0.97685}, {'accuracy': 0.9774799999999999}, {'accuracy': 0.97782}, {'accuracy': 0.97814}, {'accuracy': 0.9766600000000001}, {'accuracy': 0.9771699999999999}, {'accuracy': 0.97836}, {'accuracy': 0.9781699999999999}, {'accuracy': 0.97571}, {'accuracy': 0.9760200000000001}]\n"
     ]
    }
   ],
   "source": [
    "\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(False)])\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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DR06VHNMPXv2hMViUXuHhOeeey6qYzE6bz6fL6RcmJubi65du7ZISYyoJTFzQ9RK9evXD6+++iquueYaDBo0CDfccAN69eqFPXv24J///CeKi4vxxhtvqNN8BZvNhssuuwxvvvkmqqur8ec//znksZ999lmcccYZGDRoEG688Ub07t0bRUVFWLNmDQ4cOIDvv/++weO78MIL8f/+3/9DRkYGBgwYgDVr1uCzzz5D586d43YORowYgeeffx7/93//h759+yI3Nxfjx4/Hvffeiw8++AAXXnghrrvuOowYMQLV1dX44YcfsHjxYuzZswfZ2dmYOXMmSkpKMH78eHTv3h179+7F3/72NwwdOlSd7j106FBYLBY8/vjjKC8vh8PhwPjx45GbmxvTsY4bNw4333wz5s+fj40bN2LSpEmw2WzYvn073n77bTz99NO44oor8Oqrr+K5557DpZdeij59+qCyshIvvvgi0tPTcf755wMIlCWvvPJK/O1vf4PJZEKfPn3w3//+N6QXKtJ5++yzz/DUU0+ha9eu6NWrF/r374/u3bvjiiuuwJAhQ5CamorPPvsM3333nSb7RtQuJHayFhE1ZNOmTcrUqVOVLl26KDabTcnPz1emTp2q/PDDD2Hvs3TpUgWAYjKZlP379xveZufOncq0adOU/Px8xWazKd26dVMuvPBCZfHixeptxFRwo2nLpaWlyowZM5Ts7GwlNTVVmTx5svLTTz8pPXv21ExDbspU8CNHjigXXHCBkpaWpgDQTAuvrKxU5syZo/Tt21ex2+1Kdna2ctpppyl//vOfFbfbrSiKoixevFiZNGmSkpubq9jtdqVHjx7KzTffrBw+fFjzPC+++KLSu3dvxWKxNDgtfPr06UpKSkrY6//+978rI0aMUJKSkpS0tDRl0KBByn333accOnRIURRFWb9+vTJ16lSlR48eisPhUHJzc5ULL7xQWbt2reZxjh07plx++eVKcnKykpWVpdx8883K5s2bo5oK/tNPPylnnnmmkpSUpABQpk+frrhcLuXee+9VhgwZoqSlpSkpKSnKkCFDlOeeey7SW0DUJpkURZcfJSIiImrD2HNDRERE7QqDGyIiImpXGNwQERFRu8LghoiIiNoVBjdERETUrjC4ISIionalwy3i5/f7cejQIaSlpcVt2XUiIiJqXoqioLKyEl27dg3Z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GDx4MPr06YPly5djwoQJCTyyxLr99tuxefNmTa8bGQt3ruS+rEGDBqFLly6YMGECdu7ciT59+rT0YSZc//79sXHjRpSXl2Px4sWYPn06VqxYkejDMsSyVBNkZ2fDYrGEdIQXFRUhPz8/QUfVOmVmZuKEE07Ajh07kJ+fD7fbjbKyMs1teN6gvv5In6n8/PyQhnWv14uSkpIOf/4AoHfv3sjOzsaOHTsAdMzzNWvWLPz3v//FF198ge7du6uXR/Pdy8/PN/z8ievam3Dnysjo0aMBQPPZ6kjnym63o2/fvhgxYgTmz5+PIUOG4Omnn26VnysGN01gt9sxYsQILFu2TL3M7/dj2bJlGDNmTAKPrPWpqqrCzp070aVLF4wYMQI2m01z3n7++Wfs27evw5+3Xr16IT8/X3NuKioq8M0336jnZsyYMSgrK8O6devU23z++efw+/3q/3w7sgMHDuD48ePo0qULgI51vhRFwaxZs/Duu+/i888/R69evTTXR/PdGzNmDH744QdNQLh06VKkp6djwIABLfNCWkBD58rIxo0bAUDz2eoI5yocv98Pl8vVOj9XcW9R7mDefPNNxeFwKK+88oqyZcsW5aabblIyMzM1HeEd0d13360sX75c2b17t7Jq1Spl4sSJSnZ2tnL06FFFURTllltuUXr06KF8/vnnytq1a5UxY8YoY8aMSfBRt4zKykplw4YNyoYNGxQAylNPPaVs2LBB2bt3r6IoivLYY48pmZmZyvvvv69s2rRJufjii5VevXoptbW16mOce+65yrBhw5RvvvlGWblypdKvXz9l6tSpiXpJzSrS+aqsrFTuueceZc2aNcru3buVzz77TBk+fLjSr18/pa6uTn2MjnK+br31ViUjI0NZvny5cvjwYfVfTU2NepuGvnter1cZOHCgMmnSJGXjxo3KkiVLlJycHGXOnDmJeEnNpqFztWPHDuUPf/iDsnbtWmX37t3K+++/r/Tu3Vs588wz1cfoKOdKURTlgQceUFasWKHs3r1b2bRpk/LAAw8oJpNJ+d///qcoSuv7XDG4iYO//e1vSo8ePRS73a6MGjVK+frrrxN9SAk3ZcoUpUuXLordble6deumTJkyRdmxY4d6fW1trXLbbbcpWVlZSnJysnLppZcqhw8fTuARt5wvvvhCARDyb/r06YqiBKaDP/TQQ0peXp7icDiUCRMmKD///LPmMY4fP65MnTpVSU1NVdLT05UZM2YolZWVCXg1zS/S+aqpqVEmTZqk5OTkKDabTenZs6dy4403hvxx0VHOl9F5AqC8/PLL6m2i+e7t2bNHOe+885SkpCQlOztbufvuuxWPx9PCr6Z5NXSu9u3bp5x55plKp06dFIfDofTt21e59957lfLycs3jdIRzpSiKcv311ys9e/ZU7Ha7kpOTo0yYMEENbBSl9X2uTIqiKPHPBxERERElBntuiIiIqF1hcENERETtCoMbIiIialcY3BAREVG7wuCGiIiI2hUGN0RERNSuMLghIiKidoXBDRF1CMuXL4fJZArZ/4aI2h8GN0RERNSuMLghIiKidoXBDRG1Kn6/H0888QT69u0Lh8OBHj164NFHH8X48eMxa9YszW2PHTsGu92u7kbscrlw//33o6CgAA6HA3379sU///nPsM+1cuVKjB07FklJSSgoKMAdd9yB6urqZn19RNT8GNwQUasyZ84cPPbYY3jooYewZcsWvP7668jLy8PMmTPx+uuvw+Vyqbf917/+hW7dumH8+PEAgGnTpuGNN97AX//6V2zduhUvvPACUlNTDZ9n586dOPfcc3H55Zdj06ZNWLRoEVauXBkSQBFR28ONM4mo1aisrEROTg6eeeYZzJw5U3NdXV0dunbtioULF+Kqq64CAAwZMgSXXXYZ5s2bh23btqF///5YunQpJk6cGPLYy5cvx9lnn43S0lJkZmZi5syZsFgseOGFF9TbrFy5EuPGjUN1dTWcTmfzvlgiajbM3BBRq7F161a4XC5MmDAh5Dqn04lrr70WL730EgBg/fr12Lx5M6677joAwMaNG2GxWDBu3Lionuv777/HK6+8gtTUVPXf5MmT4ff7sXv37ri9JiJqedZEHwARkZCUlBTx+pkzZ2Lo0KE4cOAAXn75ZYwfPx49e/aM6r56VVVVuPnmm3HHHXeEXNejR4+YHouIWhdmboio1ejXrx+SkpLUBmG9QYMGYeTIkXjxxRfx+uuv4/rrr9dc5/f7sWLFiqiea/jw4diyZQv69u0b8s9ut8fl9RBRYjC4IaJWw+l04v7778d9992H1157DTt37sTXX3+tmfE0c+ZMPPbYY1AUBZdeeql6eWFhIaZPn47rr78e7733Hnbv3o3ly5fjrbfeMnyu+++/H6tXr8asWbOwceNGbN++He+//z4bionaAQY3RNSqPPTQQ7j77rsxd+5cnHTSSZgyZQqOHj2qXj916lRYrVZMnTo1pOn3+eefxxVXXIHbbrsNJ554Im688cawU7sHDx6MFStWYNu2bRg7diyGDRuGuXPnomvXrs36+oio+XG2FBG1KXv27EGfPn3w3XffYfjw4Yk+HCJqhRjcEFGb4PF4cPz4cdxzzz3YvXs3Vq1alehDIqJWimUpImoTVq1ahS5duuC7777DwoULE304RNSKMXNDRERE7QozN0RERNSuMLghIiKidoXBDREREbUrDG6IiIioXWFwQ0RERO0KgxsiIiJqVxjcEBERUbvC4IaIiIjaFQY3RERE1K78f24Ndb1jXB/+AAAAAElFTkSuQmCC\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.11065}, {'accuracy': 0.29002}, {'accuracy': 0.48385}, {'accuracy': 0.72157}, {'accuracy': 0.62064}, {'accuracy': 0.72102}, {'accuracy': 0.79658}, {'accuracy': 0.6569499999999999}, {'accuracy': 0.69997}, {'accuracy': 0.76443}, {'accuracy': 0.7329600000000001}, {'accuracy': 0.7701699999999999}, {'accuracy': 0.75864}, {'accuracy': 0.8277100000000001}, {'accuracy': 0.83492}, {'accuracy': 0.84583}, {'accuracy': 0.88581}, {'accuracy': 0.7936500000000001}, {'accuracy': 0.85443}, {'accuracy': 0.62428}, {'accuracy': 0.86492}, {'accuracy': 0.83858}, {'accuracy': 0.82743}, {'accuracy': 0.8255399999999999}, {'accuracy': 0.77708}, {'accuracy': 0.84459}, {'accuracy': 0.82602}, {'accuracy': 0.82011}, {'accuracy': 0.8811200000000001}, {'accuracy': 0.68849}, {'accuracy': 0.74545}, {'accuracy': 0.6541499999999999}, {'accuracy': 0.84604}, {'accuracy': 0.8360200000000001}, {'accuracy': 0.8695600000000001}, {'accuracy': 0.86091}, {'accuracy': 0.81717}, {'accuracy': 0.9383699999999999}, {'accuracy': 0.9162699999999999}, {'accuracy': 0.9212000000000001}, {'accuracy': 0.84177}, {'accuracy': 0.77145}, {'accuracy': 0.77019}, {'accuracy': 0.8326600000000001}, {'accuracy': 0.80791}, {'accuracy': 0.6797000000000001}, {'accuracy': 0.83747}, {'accuracy': 0.8773399999999999}, {'accuracy': 0.7090399999999999}, {'accuracy': 0.72639}, {'accuracy': 0.7988500000000001}, {'accuracy': 0.6889299999999999}, {'accuracy': 0.8105800000000001}, {'accuracy': 0.86342}, {'accuracy': 0.8343}, {'accuracy': 0.6886300000000001}, {'accuracy': 0.78727}, {'accuracy': 0.78816}, {'accuracy': 0.85906}, {'accuracy': 0.7762199999999999}, {'accuracy': 0.8349}, {'accuracy': 0.7189300000000001}, {'accuracy': 0.75539}, {'accuracy': 0.68187}, {'accuracy': 0.88544}, {'accuracy': 0.68956}, {'accuracy': 0.76751}, {'accuracy': 0.85846}, {'accuracy': 0.79517}, {'accuracy': 0.68593}, {'accuracy': 0.6511}, {'accuracy': 0.8297399999999999}, {'accuracy': 0.80123}, {'accuracy': 0.8168799999999999}, {'accuracy': 0.7342799999999999}, {'accuracy': 0.8273400000000001}, {'accuracy': 0.89161}, {'accuracy': 0.9062199999999999}, {'accuracy': 0.7230000000000001}, {'accuracy': 0.8615299999999999}, {'accuracy': 0.8101800000000001}, {'accuracy': 0.9320300000000001}, {'accuracy': 0.77026}, {'accuracy': 0.9279700000000002}, {'accuracy': 0.8538000000000002}, {'accuracy': 0.7541300000000001}, {'accuracy': 0.88269}, {'accuracy': 0.9275}, {'accuracy': 0.7501800000000001}, {'accuracy': 0.7352}, {'accuracy': 0.9078700000000002}, {'accuracy': 0.6339600000000001}, {'accuracy': 0.84045}, {'accuracy': 0.63947}, {'accuracy': 0.9237299999999999}, {'accuracy': 0.8002500000000001}, {'accuracy': 0.8072900000000001}, {'accuracy': 0.90999}, {'accuracy': 0.88859}, {'accuracy': 0.81777}, {'accuracy': 0.7313400000000001}, {'accuracy': 0.90564}, {'accuracy': 0.79413}, {'accuracy': 0.85885}, {'accuracy': 0.63322}, {'accuracy': 0.9024599999999999}, {'accuracy': 0.8515600000000001}, {'accuracy': 0.78567}, {'accuracy': 0.78047}, {'accuracy': 0.6352599999999999}, {'accuracy': 0.74139}, {'accuracy': 0.9427100000000002}, {'accuracy': 0.7127199999999999}, {'accuracy': 0.7887600000000001}, {'accuracy': 0.7318}, {'accuracy': 0.73059}, {'accuracy': 0.85789}, {'accuracy': 0.8129899999999999}, {'accuracy': 0.7813100000000001}, {'accuracy': 0.7333999999999999}, {'accuracy': 0.9484999999999999}, {'accuracy': 0.6683}, {'accuracy': 0.6996100000000001}, {'accuracy': 0.6975499999999999}, {'accuracy': 0.8133099999999999}, {'accuracy': 0.68621}, {'accuracy': 0.8693199999999999}, {'accuracy': 0.7879}, {'accuracy': 0.8603799999999999}, {'accuracy': 0.73336}, {'accuracy': 0.7817700000000001}, {'accuracy': 0.8550099999999998}, {'accuracy': 0.85211}, {'accuracy': 0.8422599999999999}, {'accuracy': 0.81182}, {'accuracy': 0.79974}, {'accuracy': 0.80733}, {'accuracy': 0.8757300000000001}, {'accuracy': 0.8700199999999999}, {'accuracy': 0.8681800000000001}, {'accuracy': 0.91905}, {'accuracy': 0.8205}, {'accuracy': 0.82211}, {'accuracy': 0.7429899999999999}, {'accuracy': 0.9549900000000001}, {'accuracy': 0.83981}, {'accuracy': 0.8053700000000001}, {'accuracy': 0.7540899999999999}, {'accuracy': 0.7891699999999999}, {'accuracy': 0.75945}, {'accuracy': 0.71744}, {'accuracy': 0.80724}, {'accuracy': 0.9737499999999999}, {'accuracy': 0.97364}, {'accuracy': 0.9731200000000001}, {'accuracy': 0.97668}, {'accuracy': 0.9768099999999998}, {'accuracy': 0.97279}, {'accuracy': 0.9752199999999999}, {'accuracy': 0.9725299999999999}, {'accuracy': 0.9755900000000001}, {'accuracy': 0.9727}, {'accuracy': 0.9741900000000001}, {'accuracy': 0.9735700000000002}, {'accuracy': 0.9737500000000001}, {'accuracy': 0.9755799999999999}, {'accuracy': 0.97492}, {'accuracy': 0.97211}, {'accuracy': 0.9738}, {'accuracy': 0.9730399999999999}, {'accuracy': 0.97586}, {'accuracy': 0.97503}, {'accuracy': 0.9745899999999998}, {'accuracy': 0.9757399999999998}, {'accuracy': 0.9764099999999999}, {'accuracy': 0.9737599999999998}, {'accuracy': 0.9734}, {'accuracy': 0.97561}, {'accuracy': 0.97657}, {'accuracy': 0.97721}, {'accuracy': 0.9754900000000001}, {'accuracy': 0.97366}, {'accuracy': 0.9747000000000001}, {'accuracy': 0.97683}, {'accuracy': 0.97575}, {'accuracy': 0.97632}, {'accuracy': 0.97591}, {'accuracy': 0.9771999999999998}, {'accuracy': 0.9743699999999998}, {'accuracy': 0.9760199999999999}, {'accuracy': 0.9770999999999999}, {'accuracy': 0.97624}, {'accuracy': 0.9730700000000001}, {'accuracy': 0.9763}, {'accuracy': 0.9755}, {'accuracy': 0.9774199999999998}, {'accuracy': 0.9750500000000001}, {'accuracy': 0.97576}, {'accuracy': 0.9740399999999999}, {'accuracy': 0.97538}, {'accuracy': 0.9746699999999999}, {'accuracy': 0.97683}, {'accuracy': 0.9761799999999999}, {'accuracy': 0.97516}, {'accuracy': 0.97669}, {'accuracy': 0.9767999999999999}, {'accuracy': 0.9769}, {'accuracy': 0.9766}, {'accuracy': 0.97586}, {'accuracy': 0.9777000000000001}, {'accuracy': 0.9767300000000001}, {'accuracy': 0.9755899999999998}, {'accuracy': 0.97529}, {'accuracy': 0.97759}, {'accuracy': 0.97647}, {'accuracy': 0.97637}, {'accuracy': 0.97654}, {'accuracy': 0.9760899999999999}, {'accuracy': 0.97455}, {'accuracy': 0.97766}, {'accuracy': 0.9751999999999998}, {'accuracy': 0.9770899999999999}, {'accuracy': 0.97549}, {'accuracy': 0.9768899999999998}, {'accuracy': 0.97815}, {'accuracy': 0.9773099999999999}, {'accuracy': 0.97652}, {'accuracy': 0.9776000000000001}, {'accuracy': 0.9773299999999999}, {'accuracy': 0.9773799999999999}, {'accuracy': 0.97711}, {'accuracy': 0.9777899999999999}, {'accuracy': 0.9753799999999998}, {'accuracy': 0.97447}, {'accuracy': 0.97506}, {'accuracy': 0.9773799999999999}, {'accuracy': 0.97691}, {'accuracy': 0.9749399999999999}, {'accuracy': 0.97712}, {'accuracy': 0.97704}, {'accuracy': 0.9758099999999998}, {'accuracy': 0.97812}, {'accuracy': 0.9773400000000001}, {'accuracy': 0.9762500000000001}, {'accuracy': 0.9751900000000001}, {'accuracy': 0.97753}, {'accuracy': 0.9782699999999999}, {'accuracy': 0.9764299999999999}, {'accuracy': 0.9764299999999999}, {'accuracy': 0.97682}, {'accuracy': 0.97722}, {'accuracy': 0.97657}, {'accuracy': 0.97774}, {'accuracy': 0.9753699999999998}, {'accuracy': 0.9761900000000001}, {'accuracy': 0.97769}, {'accuracy': 0.9781600000000001}, {'accuracy': 0.9767899999999999}, {'accuracy': 0.9772599999999999}, {'accuracy': 0.97746}, {'accuracy': 0.9751799999999999}, {'accuracy': 0.97553}, {'accuracy': 0.9779}, {'accuracy': 0.97774}, {'accuracy': 0.9768699999999999}, {'accuracy': 0.9755800000000001}, {'accuracy': 0.9778099999999998}, {'accuracy': 0.9776}, {'accuracy': 0.97668}, {'accuracy': 0.9769399999999999}, {'accuracy': 0.9770300000000001}, {'accuracy': 0.9778600000000001}, {'accuracy': 0.97759}, {'accuracy': 0.9784199999999998}, {'accuracy': 0.9756599999999999}, {'accuracy': 0.9758600000000002}, {'accuracy': 0.9782399999999999}, {'accuracy': 0.9763}, {'accuracy': 0.97493}, {'accuracy': 0.97883}, {'accuracy': 0.97754}, {'accuracy': 0.97606}, {'accuracy': 0.9767699999999999}, {'accuracy': 0.97645}, {'accuracy': 0.97599}, {'accuracy': 0.9770300000000001}, {'accuracy': 0.9762599999999999}, {'accuracy': 0.9749399999999999}, {'accuracy': 0.97836}, {'accuracy': 0.97728}, {'accuracy': 0.97685}, {'accuracy': 0.9774799999999999}, {'accuracy': 0.97782}, {'accuracy': 0.97814}, {'accuracy': 0.9766600000000001}, {'accuracy': 0.9771699999999999}, {'accuracy': 0.97836}, {'accuracy': 0.9781699999999999}, {'accuracy': 0.97571}, {'accuracy': 0.9760200000000001}]\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": "dbef4f25-a311-4e52-87d2-b1f79873b9d7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e7be6a70-182b-4c43-9ff0-b48cd4c8bf35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ddcf7d61-9551-4a03-9c7b-c2be954db4c1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9068f0cb-bc30-43dc-a302-970f682a516f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d8e731bb-025f-46ac-81db-e4720e5e67c4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "52e3b328-00ab-4e5e-bc1b-5a0d36ab13b5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3aabf123-b142-421a-976c-4de16804f487",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "753a3bdb-c46b-47c5-85c8-c5e86dfd454e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a6e0edfe-d78d-42a4-b6ec-4385210a7491",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1f24e2bd-45e5-4d39-8212-9861aebd91ab",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "040c3bf4-7e9a-4ddf-a751-24a8a557be37",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e9e127e1-c2ae-4d53-92c2-e9a11859bfd5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "10f26e03-805d-41c0-a606-4936b37d8d85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "19165891-3b48-45da-8ca9-13bf992b9f40",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "327e5ec4-dd60-4096-9c07-c835ecf2323f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9d1b3214-b6e8-422c-9718-8665ef57158c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0457df9f-499f-4b6a-a797-6e102654cba8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6a25fc48-9807-4b3b-a6c6-d2f3181b1ce7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1a3a31de-ddb5-4143-8b33-90b88d15137c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dbb03c9d-1287-449a-a377-6e3dea58642d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a13d64c6-983c-44df-b6b7-0af300366a38",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aa86ae9a-f78a-466e-9e52-9b6594f288cf",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "22a57dfa-4ce0-4628-a49e-1a84a61e5218",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5176ba4a-30b4-4e8b-9b41-63e86016d88a",
   "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
}
