{
 "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 Famnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(in_channels=1, out_channels=32, kernel_size=3, padding=1)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(32, 64, kernel_size=3)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(64*6*6, 600)\n",
    "        self.fc2 = nn.Linear(in_features=600, out_features=120)\n",
    "        self.fc3 = nn.Linear(in_features=120, out_features=10)\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(x.size(0), -1)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        x=self.fc3(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",
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_FashionMNIST()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([60000])\n",
      "6201\n",
      "[[  0 600]\n",
      " [  1 630]\n",
      " [  2 549]\n",
      " [  3 602]\n",
      " [  4 563]\n",
      " [  5 557]\n",
      " [  6 581]\n",
      " [  7 629]\n",
      " [  8 592]\n",
      " [  9 602]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 0, 0,  ..., 3, 0, 5])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "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([0, 5, 3,  ..., 3, 6, 4])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "fb85c984-e99f-433e-9cca-7bc7c93c10dd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "30163\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 274]\n",
      " [  1 280]\n",
      " [  2 309]\n",
      " [  3 284]\n",
      " [  4 275]\n",
      " [  5 301]\n",
      " [  6 351]\n",
      " [  7 325]\n",
      " [  8 277]\n",
      " [  9 308]]\n",
      "[[   0 1448]\n",
      " [   1  304]\n",
      " [   2  327]\n",
      " [   3  321]\n",
      " [   4  345]\n",
      " [   5  393]\n",
      " [   6  497]\n",
      " [   7  602]\n",
      " [   8  717]\n",
      " [   9 1001]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 6,  ..., 9, 9, 9])"
      ]
     },
     "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<5:\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(((target1[z] - 1) % 10))\n",
    "    \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": 6,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is my idx\n",
      "0\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "1\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "2\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "3\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "4\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "5\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "6\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "7\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "8\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "9\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-18:07:43 </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-18:07:43\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": "42e237099d0e40ba89a4e2f774dd7b8b",
       "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-21:16:55 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3293</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-21:16:55\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3293\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\">4857655778</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;36m4857655778\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.10771}, {'accuracy': 0.15144000000000002}, {'accuracy': 0.19842000000000004}, {'accuracy': 0.14511000000000002}, {'accuracy': 0.262}, {'accuracy': 0.16362000000000002}, {'accuracy': 0.19962}, {'accuracy': 0.17933}, {'accuracy': 0.31997}, {'accuracy': 0.28513}, {'accuracy': 0.20233000000000004}, {'accuracy': 0.23115999999999998}, {'accuracy': 0.26052}, {'accuracy': 0.25404}, {'accuracy': 0.3169800000000001}, {'accuracy': 0.23251999999999998}, {'accuracy': 0.25904999999999995}, {'accuracy': 0.31613}, {'accuracy': 0.28970999999999997}, {'accuracy': 0.24171}, {'accuracy': 0.25818}, {'accuracy': 0.29898}, {'accuracy': 0.26280000000000003}, {'accuracy': 0.25553}, {'accuracy': 0.23186}, {'accuracy': 0.34377}, {'accuracy': 0.38738}, {'accuracy': 0.27482999999999996}, {'accuracy': 0.24101}, {'accuracy': 0.2924}, {'accuracy': 0.31976}, {'accuracy': 0.38044}, {'accuracy': 0.26098}, {'accuracy': 0.24713}, {'accuracy': 0.28025}, {'accuracy': 0.19518000000000002}, {'accuracy': 0.27945000000000003}, {'accuracy': 0.22744999999999999}, {'accuracy': 0.30234999999999995}, {'accuracy': 0.35564999999999997}, {'accuracy': 0.22565}, {'accuracy': 0.20985}, {'accuracy': 0.38187000000000004}, {'accuracy': 0.26744}, {'accuracy': 0.37334}, {'accuracy': 0.17694}, {'accuracy': 0.26386000000000004}, {'accuracy': 0.31362}, {'accuracy': 0.43355}, {'accuracy': 0.2763}, {'accuracy': 0.27284}, {'accuracy': 0.26377}, {'accuracy': 0.2985}, {'accuracy': 0.28267}, {'accuracy': 0.3118}, {'accuracy': 0.21883000000000002}, {'accuracy': 0.36360000000000003}, {'accuracy': 0.28589000000000003}, {'accuracy': 0.30862}, {'accuracy': 0.34728}, {'accuracy': 0.29146}, {'accuracy': 0.34623}, {'accuracy': 0.32438}, {'accuracy': 0.31072}, {'accuracy': 0.27224}, {'accuracy': 0.31124000000000007}, {'accuracy': 0.29025}, {'accuracy': 0.30898}, {'accuracy': 0.28281}, {'accuracy': 0.24999}, {'accuracy': 0.44261999999999996}, {'accuracy': 0.33355999999999997}, {'accuracy': 0.37116}, {'accuracy': 0.31355999999999995}, {'accuracy': 0.35056}, {'accuracy': 0.19752999999999998}, {'accuracy': 0.31865}, {'accuracy': 0.24379000000000003}, {'accuracy': 0.23108}, {'accuracy': 0.29586999999999997}, {'accuracy': 0.29481}, {'accuracy': 0.32981}, {'accuracy': 0.24481999999999998}, {'accuracy': 0.21051999999999998}, {'accuracy': 0.29490000000000005}, {'accuracy': 0.31585}, {'accuracy': 0.30181}, {'accuracy': 0.25212}, {'accuracy': 0.25466}, {'accuracy': 0.24378000000000002}, {'accuracy': 0.23841}, {'accuracy': 0.27273000000000003}, {'accuracy': 0.42288}, {'accuracy': 0.38737999999999995}, {'accuracy': 0.28005}, {'accuracy': 0.31403}, {'accuracy': 0.18257}, {'accuracy': 0.28265}, {'accuracy': 0.37935}, {'accuracy': 0.26942999999999995}, {'accuracy': 0.39174999999999993}, {'accuracy': 0.29552999999999996}, {'accuracy': 0.35208999999999996}, {'accuracy': 0.22595}, {'accuracy': 0.39205999999999996}, {'accuracy': 0.37267}, {'accuracy': 0.26426}, {'accuracy': 0.31222999999999995}, {'accuracy': 0.3217}, {'accuracy': 0.30662}, {'accuracy': 0.36418}, {'accuracy': 0.25866}, {'accuracy': 0.33924000000000004}, {'accuracy': 0.29673}, {'accuracy': 0.3212}, {'accuracy': 0.31335}, {'accuracy': 0.36147}, {'accuracy': 0.24236999999999997}, {'accuracy': 0.30656}, {'accuracy': 0.38506}, {'accuracy': 0.28012999999999993}, {'accuracy': 0.36344000000000004}, {'accuracy': 0.28842}, {'accuracy': 0.31283000000000005}, {'accuracy': 0.29016}, {'accuracy': 0.26659}, {'accuracy': 0.30118999999999996}, {'accuracy': 0.23731}, {'accuracy': 0.24279}, {'accuracy': 0.39482}, {'accuracy': 0.3895}, {'accuracy': 0.20864}, {'accuracy': 0.35242000000000007}, {'accuracy': 0.32543}, {'accuracy': 0.28407000000000004}, {'accuracy': 0.36195}, {'accuracy': 0.29635}, {'accuracy': 0.44343000000000005}, {'accuracy': 0.248}, {'accuracy': 0.28792000000000006}, {'accuracy': 0.39023}, {'accuracy': 0.24259999999999998}, {'accuracy': 0.23121}, {'accuracy': 0.21671}, {'accuracy': 0.31037}, {'accuracy': 0.29009999999999997}, {'accuracy': 0.38008}, {'accuracy': 0.23400000000000004}, {'accuracy': 0.35052000000000005}, {'accuracy': 0.24208}, {'accuracy': 0.3166300000000001}, {'accuracy': 0.3889}, {'accuracy': 0.21295999999999998}, {'accuracy': 0.3434499999999999}, {'accuracy': 0.36646}, {'accuracy': 0.33361}, {'accuracy': 0.26425}, {'accuracy': 0.31899000000000005}, {'accuracy': 0.30379}, {'accuracy': 0.3529}, {'accuracy': 0.25942}, {'accuracy': 0.26827000000000006}, {'accuracy': 0.24023}, {'accuracy': 0.32686000000000004}, {'accuracy': 0.30351}, {'accuracy': 0.30593}, {'accuracy': 0.34124000000000004}, {'accuracy': 0.28408}, {'accuracy': 0.25278}, {'accuracy': 0.2779}, {'accuracy': 0.28513}, {'accuracy': 0.30179}, {'accuracy': 0.34065}, {'accuracy': 0.23418}, {'accuracy': 0.32018}, {'accuracy': 0.32586}, {'accuracy': 0.34826}, {'accuracy': 0.18838}, {'accuracy': 0.30239}, {'accuracy': 0.3788099999999999}, {'accuracy': 0.34506}, {'accuracy': 0.30019}, {'accuracy': 0.41511}, {'accuracy': 0.34131999999999996}, {'accuracy': 0.23925000000000002}, {'accuracy': 0.19928}, {'accuracy': 0.30033000000000004}, {'accuracy': 0.26907}, {'accuracy': 0.32644}, {'accuracy': 0.26656}, {'accuracy': 0.24743999999999997}, {'accuracy': 0.31218999999999997}, {'accuracy': 0.4314}, {'accuracy': 0.36183}, {'accuracy': 0.36689}, {'accuracy': 0.34120000000000006}, {'accuracy': 0.36286}, {'accuracy': 0.3008}, {'accuracy': 0.42116}, {'accuracy': 0.37944}, {'accuracy': 0.5236600000000001}, {'accuracy': 0.49217000000000005}, {'accuracy': 0.4069299999999999}, {'accuracy': 0.37395999999999996}, {'accuracy': 0.57518}, {'accuracy': 0.55597}, {'accuracy': 0.5447600000000001}, {'accuracy': 0.5475399999999999}, {'accuracy': 0.57324}, {'accuracy': 0.56716}, {'accuracy': 0.54216}, {'accuracy': 0.55334}, {'accuracy': 0.5590099999999999}, {'accuracy': 0.57667}, {'accuracy': 0.56868}, {'accuracy': 0.56162}, {'accuracy': 0.54752}, {'accuracy': 0.55944}, {'accuracy': 0.56372}, {'accuracy': 0.54524}, {'accuracy': 0.57318}, {'accuracy': 0.5568700000000001}, {'accuracy': 0.54984}, {'accuracy': 0.5506399999999999}, {'accuracy': 0.5631900000000001}, {'accuracy': 0.5612100000000001}, {'accuracy': 0.55413}, {'accuracy': 0.56215}, {'accuracy': 0.5552199999999999}, {'accuracy': 0.54279}, {'accuracy': 0.53735}, {'accuracy': 0.5559200000000001}, {'accuracy': 0.5643900000000001}, {'accuracy': 0.54803}, {'accuracy': 0.56284}, {'accuracy': 0.56304}, {'accuracy': 0.56518}, {'accuracy': 0.5289900000000001}, {'accuracy': 0.5510400000000001}, {'accuracy': 0.5619099999999999}, {'accuracy': 0.5463500000000001}, {'accuracy': 0.5521499999999999}, {'accuracy': 0.5667800000000001}, {'accuracy': 0.54044}, {'accuracy': 0.5414899999999999}, {'accuracy': 0.5533000000000001}, {'accuracy': 0.5581200000000001}, {'accuracy': 0.54775}, {'accuracy': 0.55738}, {'accuracy': 0.5327}, {'accuracy': 0.5567}, {'accuracy': 0.5599999999999999}, {'accuracy': 0.5647300000000001}, {'accuracy': 0.5449599999999999}, {'accuracy': 0.5702999999999999}, {'accuracy': 0.55562}, {'accuracy': 0.5486099999999999}, {'accuracy': 0.5493899999999999}, {'accuracy': 0.56277}, {'accuracy': 0.5468400000000001}, {'accuracy': 0.5570299999999999}, {'accuracy': 0.56641}, {'accuracy': 0.53989}, {'accuracy': 0.5572499999999999}, {'accuracy': 0.5488299999999999}, {'accuracy': 0.5566500000000001}, {'accuracy': 0.55362}, {'accuracy': 0.5398}, {'accuracy': 0.54196}, {'accuracy': 0.56148}, {'accuracy': 0.5654199999999999}, {'accuracy': 0.5351499999999999}, {'accuracy': 0.55678}, {'accuracy': 0.57414}, {'accuracy': 0.5539}, {'accuracy': 0.5446000000000002}, {'accuracy': 0.56823}, {'accuracy': 0.5593000000000001}, {'accuracy': 0.54091}, {'accuracy': 0.57241}, {'accuracy': 0.55144}, {'accuracy': 0.51936}, {'accuracy': 0.54371}, {'accuracy': 0.56029}, {'accuracy': 0.5500299999999999}, {'accuracy': 0.55616}, {'accuracy': 0.5606699999999999}, {'accuracy': 0.54988}, {'accuracy': 0.56268}, {'accuracy': 0.53291}, {'accuracy': 0.5461199999999999}, {'accuracy': 0.56601}, {'accuracy': 0.55826}, {'accuracy': 0.5375500000000001}, {'accuracy': 0.5570999999999999}, {'accuracy': 0.54929}, {'accuracy': 0.53736}, {'accuracy': 0.55579}, {'accuracy': 0.5510100000000001}, {'accuracy': 0.53491}]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=Famnist(),\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": "095dd5c3-1f9e-4049-83b4-fa575593435d",
   "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.53</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:171</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.53\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m171\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAADBiklEQVR4nOydd3gc1fm2n9mu3iU3uZticAEb05sxmAAJHYcQbJxACCWBOA1/ITaEJKYHQodfaCnghEBCQjDFYKppNmBwAWPjbsuS1VfSlpn5/tg9M+ecmdkirbQr6b2viwtr25wdrfY887xN0XVdB0EQBEEQxADBle0FEARBEARBZBISNwRBEARBDChI3BAEQRAEMaAgcUMQBEEQxICCxA1BEARBEAMKEjcEQRAEQQwoSNwQBEEQBDGgIHFDEARBEMSAgsQNQRAEQRADChI3BEH0KitWrICiKFixYoVx2yWXXILRo0dnbU0DiRtuuAGKomR7GQSRU5C4IYgcZ+3atfjud7+L4cOHw+/3Y9iwYbjooouwdu3abC+t17n//vvx+OOP9+ox1q1bhxtuuAFbtmzp1eP0Jb///e/xr3/9K9vLIIisQeKGIHKYZ599FoceeiiWL1+O+fPn4/7778f3v/99vP766zj00EPx3HPPZXuJvUpfiZsbb7yRxA1BDCA82V4AQRD2bNq0CRdffDHGjh2LN998E1VVVcZ911xzDY499lhcfPHFWLNmDcaOHdtn6woGgygoKOiz4/UH6JwQRG5Bzg1B5Ci33XYbOjo68PDDDwvCBgAqKyvx0EMPIRgM4tZbbwUAPPPMM1AUBW+88YbltR566CEoioLPP//cuG3Dhg0477zzUF5ejkAggOnTp+P5558Xnvf4448br3nllVeiuroaI0aMAABs3boVV155Jfbff3/k5eWhoqIC559/fsYckNGjR2Pt2rV44403oCgKFEXBCSecYNzf3NyMa6+9FrW1tfD7/Rg/fjxuueUWaJomvM7TTz+NadOmoaioCMXFxZg0aRLuvvtu4/2df/75AIATTzzROA6fHyRzySWXoLCwEJs2bcJpp52GoqIiXHTRRQAATdNw11134aCDDkIgEEBNTQ0uv/xyNDU1Ca/x0UcfYfbs2aisrEReXh7GjBmD733ve8b9dnlKALBlyxYoipLQzVIUBcFgEE888YTxfi655BIAQFtbG6699lqMHj0afr8f1dXVOPnkk7F69WrH1yOI/gg5NwSRo/znP//B6NGjceyxx9ref9xxx2H06NF44YUXAACnn346CgsL8fe//x3HH3+88NilS5fioIMOwsEHHwwglsdz9NFHY/jw4bjuuutQUFCAv//97zjrrLPwz3/+E2effbbw/CuvvBJVVVVYtGgRgsEgAODDDz/Eu+++i29/+9sYMWIEtmzZggceeAAnnHAC1q1bh/z8/B69/7vuugs/+tGPUFhYiF/96lcAgJqaGgBAR0cHjj/+eOzcuROXX345Ro4ciXfffRcLFy7E7t27cddddwEAXnnlFVx44YU46aSTcMsttwAA1q9fj3feeQfXXHMNjjvuOPz4xz/GH//4R/y///f/cOCBBwKA8X8notEoZs+ejWOOOQa333678V4vv/xyPP7445g/fz5+/OMf4+uvv8a9996Ljz/+GO+88w68Xi/27t2LU045BVVVVbjuuutQWlqKLVu24Nlnn+3R+WL8+c9/xqWXXooZM2bgBz/4AQBg3LhxAIAf/vCHeOaZZ3D11Vdj4sSJ2LdvH95++22sX78ehx56aEaOTxA5gU4QRM7R3NysA9DPPPPMhI/71re+pQPQW1tbdV3X9QsvvFCvrq7Wo9Go8Zjdu3frLpdL/81vfmPcdtJJJ+mTJk3Su7q6jNs0TdOPOuoofcKECcZtjz32mA5AP+aYY4TX1HVd7+josKxn5cqVOgD9ySefNG57/fXXdQD666+/btw2b948fdSoUQnfm67r+kEHHaQff/zxlttvuukmvaCgQP/yyy+F26+77jrd7Xbr27Zt03Vd16+55hq9uLjYsnaef/zjH5b1JWLevHk6AP26664Tbn/rrbd0APpf//pX4fZly5YJtz/33HM6AP3DDz90PIbdOdN1Xf/66691APpjjz1m3LZ48WJd/iovKCjQ582bZ3ndkpIS/aqrrkrhXRJE/4bCUgSRg7S1tQEAioqKEj6O3d/a2goAmDNnDvbu3SuEM5555hlomoY5c+YAABobG/Haa6/hggsuQFtbGxoaGtDQ0IB9+/Zh9uzZ2LhxI3bu3Ckc57LLLoPb7RZuy8vLM/4diUSwb98+jB8/HqWlpb0e5vjHP/6BY489FmVlZcb6GxoaMGvWLKiqijfffBMAUFpaimAwiFdeeSXja7jiiissayopKcHJJ58srGnatGkoLCzE66+/bqwJAP773/8iEolkfF2JKC0txfvvv49du3b16XEJoq8hcUMQOQgTLUzkOCGLoFNPPRUlJSVYunSp8ZilS5di6tSp2G+//QAAX331FXRdx69//WtUVVUJ/y1evBgAsHfvXuE4Y8aMsRy7s7MTixYtMnJeKisrUVVVhebmZrS0tHTznafGxo0bsWzZMsv6Z82aJaz/yiuvxH777YdvfOMbGDFiBL73ve9h2bJlPT6+x+Mxco/4NbW0tKC6utqyrvb2dmNNxx9/PM4991zceOONqKysxJlnnonHHnsMoVCox+tKxq233orPP/8ctbW1mDFjBm644QZs3ry5149LEH0N5dwQRA5SUlKCoUOHYs2aNQkft2bNGgwfPhzFxcUAAL/fj7POOgvPPfcc7r//ftTV1eGdd97B73//e+M5LOH2Zz/7GWbPnm37uuPHjxd+5l0axo9+9CM89thjuPbaa3HkkUeipKQEiqLg29/+tiWpN9NomoaTTz4Zv/jFL2zvZ0Kuuroan3zyCV566SW8+OKLePHFF/HYY49h7ty5eOKJJ7p9fL/fD5dLvDbUNA3V1dX461//avsclhSuKAqeeeYZvPfee/jPf/6Dl156Cd/73vdwxx134L333kNhYaFjUz5VVbu9ZgC44IILcOyxx+K5557Dyy+/jNtuuw233HILnn32WXzjG9/o0WsTRC5B4oYgcpQzzjgDjzzyCN5++20cc8wxlvvfeustbNmyBZdffrlw+5w5c/DEE09g+fLlWL9+PXRdN0JSAIyyca/Xazgd3eGZZ57BvHnzcMcddxi3dXV1obm5uduvKeO0yY8bNw7t7e0prd/n8+Gb3/wmvvnNb0LTNFx55ZV46KGH8Otf/xrjx4/PWHffcePG4dVXX8XRRx9tKwZljjjiCBxxxBH43e9+h7/97W+46KKL8PTTT+PSSy9FWVkZAFjO5datW1NaS6L3NHToUFx55ZW48sorsXfvXhx66KH43e9+R+KGGFBQWIogcpSf//znyMvLw+WXX459+/YJ9zU2NuKHP/wh8vPz8fOf/1y4b9asWSgvL8fSpUuxdOlSzJgxQwgrVVdX44QTTsBDDz2E3bt3W45bX1+f0vrcbjd0XRduu+eee3rsLvAUFBTYiqULLrgAK1euxEsvvWS5r7m5GdFoFAAs583lcmHy5MkAYISBWH+anoqyCy64AKqq4qabbrLcF41GjddvamqynLepU6cKaxo1ahTcbreRO8S4//77U1qL3XlTVdUSLqyursawYcP6JCRGEH0JOTcEkaNMmDABTzzxBC666CJMmjQJ3//+9zFmzBhs2bIFf/rTn9DQ0ICnnnrKKPNleL1enHPOOXj66acRDAZx++23W177vvvuwzHHHINJkybhsssuw9ixY1FXV4eVK1dix44d+PTTT5Ou74wzzsCf//xnlJSUYOLEiVi5ciVeffVVVFRUZOwcTJs2DQ888AB++9vfYvz48aiursbMmTPx85//HM8//zzOOOMMXHLJJZg2bRqCwSA+++wzPPPMM9iyZQsqKytx6aWXorGxETNnzsSIESOwdetW3HPPPZg6dapR7j116lS43W7ccsstaGlpgd/vx8yZM1FdXZ3WWo8//nhcfvnlWLJkCT755BOccsop8Hq92LhxI/7xj3/g7rvvxnnnnYcnnngC999/P84++2yMGzcObW1teOSRR1BcXIzTTjsNQCwsef755+Oee+6BoigYN24c/vvf/1pyoRKdt1dffRV33nknhg0bhjFjxmD//ffHiBEjcN5552HKlCkoLCzEq6++ig8//FBw3whiQJDdYi2CIJKxZs0a/cILL9SHDh2qe71efciQIfqFF16of/bZZ47PeeWVV3QAuqIo+vbt220fs2nTJn3u3Ln6kCFDdK/Xqw8fPlw/44wz9GeeecZ4DCsFtytbbmpq0ufPn69XVlbqhYWF+uzZs/UNGzboo0aNEsqQe1IKvmfPHv3000/Xi4qKdABCWXhbW5u+cOFCffz48brP59MrKyv1o446Sr/99tv1cDis67quP/PMM/opp5yiV1dX6z6fTx85cqR++eWX67t37xaO88gjj+hjx47V3W530rLwefPm6QUFBY73P/zww/q0adP0vLw8vaioSJ80aZL+i1/8Qt+1a5eu67q+evVq/cILL9RHjhyp+/1+vbq6Wj/jjDP0jz76SHid+vp6/dxzz9Xz8/P1srIy/fLLL9c///zzlErBN2zYoB933HF6Xl6eDkCfN2+eHgqF9J///Of6lClT9KKiIr2goECfMmWKfv/99yf6FRBEv0TRdckfJQiCIAiC6MdQzg1BEARBEAMKEjcEQRAEQQwoSNwQBEEQBDGgyLq4ue+++zB6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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\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.10771}, {'accuracy': 0.15144000000000002}, {'accuracy': 0.19842000000000004}, {'accuracy': 0.14511000000000002}, {'accuracy': 0.262}, {'accuracy': 0.16362000000000002}, {'accuracy': 0.19962}, {'accuracy': 0.17933}, {'accuracy': 0.31997}, {'accuracy': 0.28513}, {'accuracy': 0.20233000000000004}, {'accuracy': 0.23115999999999998}, {'accuracy': 0.26052}, {'accuracy': 0.25404}, {'accuracy': 0.3169800000000001}, {'accuracy': 0.23251999999999998}, {'accuracy': 0.25904999999999995}, {'accuracy': 0.31613}, {'accuracy': 0.28970999999999997}, {'accuracy': 0.24171}, {'accuracy': 0.25818}, {'accuracy': 0.29898}, {'accuracy': 0.26280000000000003}, {'accuracy': 0.25553}, {'accuracy': 0.23186}, {'accuracy': 0.34377}, {'accuracy': 0.38738}, {'accuracy': 0.27482999999999996}, {'accuracy': 0.24101}, {'accuracy': 0.2924}, {'accuracy': 0.31976}, {'accuracy': 0.38044}, {'accuracy': 0.26098}, {'accuracy': 0.24713}, {'accuracy': 0.28025}, {'accuracy': 0.19518000000000002}, {'accuracy': 0.27945000000000003}, {'accuracy': 0.22744999999999999}, {'accuracy': 0.30234999999999995}, {'accuracy': 0.35564999999999997}, {'accuracy': 0.22565}, {'accuracy': 0.20985}, {'accuracy': 0.38187000000000004}, {'accuracy': 0.26744}, {'accuracy': 0.37334}, {'accuracy': 0.17694}, {'accuracy': 0.26386000000000004}, {'accuracy': 0.31362}, {'accuracy': 0.43355}, {'accuracy': 0.2763}, {'accuracy': 0.27284}, {'accuracy': 0.26377}, {'accuracy': 0.2985}, {'accuracy': 0.28267}, {'accuracy': 0.3118}, {'accuracy': 0.21883000000000002}, {'accuracy': 0.36360000000000003}, {'accuracy': 0.28589000000000003}, {'accuracy': 0.30862}, {'accuracy': 0.34728}, {'accuracy': 0.29146}, {'accuracy': 0.34623}, {'accuracy': 0.32438}, {'accuracy': 0.31072}, {'accuracy': 0.27224}, {'accuracy': 0.31124000000000007}, {'accuracy': 0.29025}, {'accuracy': 0.30898}, {'accuracy': 0.28281}, {'accuracy': 0.24999}, {'accuracy': 0.44261999999999996}, {'accuracy': 0.33355999999999997}, {'accuracy': 0.37116}, {'accuracy': 0.31355999999999995}, {'accuracy': 0.35056}, {'accuracy': 0.19752999999999998}, {'accuracy': 0.31865}, {'accuracy': 0.24379000000000003}, {'accuracy': 0.23108}, {'accuracy': 0.29586999999999997}, {'accuracy': 0.29481}, {'accuracy': 0.32981}, {'accuracy': 0.24481999999999998}, {'accuracy': 0.21051999999999998}, {'accuracy': 0.29490000000000005}, {'accuracy': 0.31585}, {'accuracy': 0.30181}, {'accuracy': 0.25212}, {'accuracy': 0.25466}, {'accuracy': 0.24378000000000002}, {'accuracy': 0.23841}, {'accuracy': 0.27273000000000003}, {'accuracy': 0.42288}, {'accuracy': 0.38737999999999995}, {'accuracy': 0.28005}, {'accuracy': 0.31403}, {'accuracy': 0.18257}, {'accuracy': 0.28265}, {'accuracy': 0.37935}, {'accuracy': 0.26942999999999995}, {'accuracy': 0.39174999999999993}, {'accuracy': 0.29552999999999996}, {'accuracy': 0.35208999999999996}, {'accuracy': 0.22595}, {'accuracy': 0.39205999999999996}, {'accuracy': 0.37267}, {'accuracy': 0.26426}, {'accuracy': 0.31222999999999995}, {'accuracy': 0.3217}, {'accuracy': 0.30662}, {'accuracy': 0.36418}, {'accuracy': 0.25866}, {'accuracy': 0.33924000000000004}, {'accuracy': 0.29673}, {'accuracy': 0.3212}, {'accuracy': 0.31335}, {'accuracy': 0.36147}, {'accuracy': 0.24236999999999997}, {'accuracy': 0.30656}, {'accuracy': 0.38506}, {'accuracy': 0.28012999999999993}, {'accuracy': 0.36344000000000004}, {'accuracy': 0.28842}, {'accuracy': 0.31283000000000005}, {'accuracy': 0.29016}, {'accuracy': 0.26659}, {'accuracy': 0.30118999999999996}, {'accuracy': 0.23731}, {'accuracy': 0.24279}, {'accuracy': 0.39482}, {'accuracy': 0.3895}, {'accuracy': 0.20864}, {'accuracy': 0.35242000000000007}, {'accuracy': 0.32543}, {'accuracy': 0.28407000000000004}, {'accuracy': 0.36195}, {'accuracy': 0.29635}, {'accuracy': 0.44343000000000005}, {'accuracy': 0.248}, {'accuracy': 0.28792000000000006}, {'accuracy': 0.39023}, {'accuracy': 0.24259999999999998}, {'accuracy': 0.23121}, {'accuracy': 0.21671}, {'accuracy': 0.31037}, {'accuracy': 0.29009999999999997}, {'accuracy': 0.38008}, {'accuracy': 0.23400000000000004}, {'accuracy': 0.35052000000000005}, {'accuracy': 0.24208}, {'accuracy': 0.3166300000000001}, {'accuracy': 0.3889}, {'accuracy': 0.21295999999999998}, {'accuracy': 0.3434499999999999}, {'accuracy': 0.36646}, {'accuracy': 0.33361}, {'accuracy': 0.26425}, {'accuracy': 0.31899000000000005}, {'accuracy': 0.30379}, {'accuracy': 0.3529}, {'accuracy': 0.25942}, {'accuracy': 0.26827000000000006}, {'accuracy': 0.24023}, {'accuracy': 0.32686000000000004}, {'accuracy': 0.30351}, {'accuracy': 0.30593}, {'accuracy': 0.34124000000000004}, {'accuracy': 0.28408}, {'accuracy': 0.25278}, {'accuracy': 0.2779}, {'accuracy': 0.28513}, {'accuracy': 0.30179}, {'accuracy': 0.34065}, {'accuracy': 0.23418}, {'accuracy': 0.32018}, {'accuracy': 0.32586}, {'accuracy': 0.34826}, {'accuracy': 0.18838}, {'accuracy': 0.30239}, {'accuracy': 0.3788099999999999}, {'accuracy': 0.34506}, {'accuracy': 0.30019}, {'accuracy': 0.41511}, {'accuracy': 0.34131999999999996}, {'accuracy': 0.23925000000000002}, {'accuracy': 0.19928}, {'accuracy': 0.30033000000000004}, {'accuracy': 0.26907}, {'accuracy': 0.32644}, {'accuracy': 0.26656}, {'accuracy': 0.24743999999999997}, {'accuracy': 0.31218999999999997}, {'accuracy': 0.4314}, {'accuracy': 0.36183}, {'accuracy': 0.36689}, {'accuracy': 0.34120000000000006}, {'accuracy': 0.36286}, {'accuracy': 0.3008}, {'accuracy': 0.42116}, {'accuracy': 0.37944}, {'accuracy': 0.5236600000000001}, {'accuracy': 0.49217000000000005}, {'accuracy': 0.4069299999999999}, {'accuracy': 0.37395999999999996}, {'accuracy': 0.57518}, {'accuracy': 0.55597}, {'accuracy': 0.5447600000000001}, {'accuracy': 0.5475399999999999}, {'accuracy': 0.57324}, {'accuracy': 0.56716}, {'accuracy': 0.54216}, {'accuracy': 0.55334}, {'accuracy': 0.5590099999999999}, {'accuracy': 0.57667}, {'accuracy': 0.56868}, {'accuracy': 0.56162}, {'accuracy': 0.54752}, {'accuracy': 0.55944}, {'accuracy': 0.56372}, {'accuracy': 0.54524}, {'accuracy': 0.57318}, {'accuracy': 0.5568700000000001}, {'accuracy': 0.54984}, {'accuracy': 0.5506399999999999}, {'accuracy': 0.5631900000000001}, {'accuracy': 0.5612100000000001}, {'accuracy': 0.55413}, {'accuracy': 0.56215}, {'accuracy': 0.5552199999999999}, {'accuracy': 0.54279}, {'accuracy': 0.53735}, {'accuracy': 0.5559200000000001}, {'accuracy': 0.5643900000000001}, {'accuracy': 0.54803}, {'accuracy': 0.56284}, {'accuracy': 0.56304}, {'accuracy': 0.56518}, {'accuracy': 0.5289900000000001}, {'accuracy': 0.5510400000000001}, {'accuracy': 0.5619099999999999}, {'accuracy': 0.5463500000000001}, {'accuracy': 0.5521499999999999}, {'accuracy': 0.5667800000000001}, {'accuracy': 0.54044}, {'accuracy': 0.5414899999999999}, {'accuracy': 0.5533000000000001}, {'accuracy': 0.5581200000000001}, {'accuracy': 0.54775}, {'accuracy': 0.55738}, {'accuracy': 0.5327}, {'accuracy': 0.5567}, {'accuracy': 0.5599999999999999}, {'accuracy': 0.5647300000000001}, {'accuracy': 0.5449599999999999}, {'accuracy': 0.5702999999999999}, {'accuracy': 0.55562}, {'accuracy': 0.5486099999999999}, {'accuracy': 0.5493899999999999}, {'accuracy': 0.56277}, {'accuracy': 0.5468400000000001}, {'accuracy': 0.5570299999999999}, {'accuracy': 0.56641}, {'accuracy': 0.53989}, {'accuracy': 0.5572499999999999}, {'accuracy': 0.5488299999999999}, {'accuracy': 0.5566500000000001}, {'accuracy': 0.55362}, {'accuracy': 0.5398}, {'accuracy': 0.54196}, {'accuracy': 0.56148}, {'accuracy': 0.5654199999999999}, {'accuracy': 0.5351499999999999}, {'accuracy': 0.55678}, {'accuracy': 0.57414}, {'accuracy': 0.5539}, {'accuracy': 0.5446000000000002}, {'accuracy': 0.56823}, {'accuracy': 0.5593000000000001}, {'accuracy': 0.54091}, {'accuracy': 0.57241}, {'accuracy': 0.55144}, {'accuracy': 0.51936}, {'accuracy': 0.54371}, {'accuracy': 0.56029}, {'accuracy': 0.5500299999999999}, {'accuracy': 0.55616}, {'accuracy': 0.5606699999999999}, {'accuracy': 0.54988}, {'accuracy': 0.56268}, {'accuracy': 0.53291}, {'accuracy': 0.5461199999999999}, {'accuracy': 0.56601}, {'accuracy': 0.55826}, {'accuracy': 0.5375500000000001}, {'accuracy': 0.5570999999999999}, {'accuracy': 0.54929}, {'accuracy': 0.53736}, {'accuracy': 0.55579}, {'accuracy': 0.5510100000000001}, {'accuracy': 0.53491}]\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": "918b3aa8-d15e-4315-8b2d-bbdc0a8f2ac1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cb9a1753-eba6-4fff-8f0c-b848db8c8440",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "25158f47-204c-497d-bf9a-b15aa83cf750",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a3aa999e-5218-459b-aa18-c368d2b89a07",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5d38c6bc-0648-4efd-bd10-c21686f81fb2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "65522bb9-83a9-4924-9ac4-ba3aeca46882",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bd33447b-b31e-4cba-8293-c1aa029a6dfa",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d2f26062-db15-4120-ba56-68df79685aca",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a3fe85b8-ea75-4769-ac7f-2082bd43c7b8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d4a172bb-0afb-4ee7-b710-3384a8d99aee",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7a669ffc-148d-4ed0-99d2-6b9a8aadad65",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "19c1504a-a979-45ba-a3b4-705e6e22eb3e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e737917a-c48d-492e-8adb-fbfabc1e4f08",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1a50aed2-d28e-41b1-981f-cc3d915efc64",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c012f3d5-7464-47ab-81c3-a3a406c769d2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d6136f62-ec3f-4b89-b99d-68c6287ed670",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "143d4c85-ad6d-4c07-affb-85304515c58a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3b0aec3a-b949-4a9f-a6e0-90cdcc1ea66a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7ede9ac5-3686-43b1-a937-f42e92f0c4b8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "159ede36-64aa-4532-b5f5-502e1dcca14a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e0e3400d-3e4e-427e-8b19-47e96f586296",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "19fa6dde-4795-4e79-9ded-5b40b3ca22c2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dec5013d-415a-4386-8f30-8f77bccb4349",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3b1c440a-8203-44b8-af3e-a53f369d1abb",
   "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
}
