{
 "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": [
      "[[   0 2367]\n",
      " [   1   62]\n",
      " [   2   34]\n",
      " [   3   84]\n",
      " [   4  113]\n",
      " [   5  176]\n",
      " [   6  326]\n",
      " [   7  551]\n",
      " [   8  791]\n",
      " [   9 1428]]\n",
      "[[   0 1413]\n",
      " [   1 2726]\n",
      " [   2   52]\n",
      " [   3   48]\n",
      " [   4   57]\n",
      " [   5   93]\n",
      " [   6  169]\n",
      " [   7  330]\n",
      " [   8  523]\n",
      " [   9  811]]\n",
      "[[   0  851]\n",
      " [   1 1567]\n",
      " [   2 2431]\n",
      " [   3   78]\n",
      " [   4   48]\n",
      " [   5   70]\n",
      " [   6  119]\n",
      " [   7  203]\n",
      " [   8  263]\n",
      " [   9  486]]\n",
      "[[   0  511]\n",
      " [   1  960]\n",
      " [   2 1445]\n",
      " [   3 2453]\n",
      " [   4   65]\n",
      " [   5   25]\n",
      " [   6   69]\n",
      " [   7  116]\n",
      " [   8  181]\n",
      " [   9  324]]\n",
      "[[   0  299]\n",
      " [   1  626]\n",
      " [   2  845]\n",
      " [   3 1486]\n",
      " [   4 2385]\n",
      " [   5   34]\n",
      " [   6   37]\n",
      " [   7   77]\n",
      " [   8  122]\n",
      " [   9  201]]\n",
      "[[   0  212]\n",
      " [   1  339]\n",
      " [   2  510]\n",
      " [   3  838]\n",
      " [   4 1391]\n",
      " [   5 2083]\n",
      " [   6   65]\n",
      " [   7   34]\n",
      " [   8   52]\n",
      " [   9  104]]\n",
      "[[   0   94]\n",
      " [   1  210]\n",
      " [   2  314]\n",
      " [   3  529]\n",
      " [   4  835]\n",
      " [   5 1356]\n",
      " [   6 2369]\n",
      " [   7   56]\n",
      " [   8   40]\n",
      " [   9   66]]\n",
      "[[   0   64]\n",
      " [   1  137]\n",
      " [   2  156]\n",
      " [   3  322]\n",
      " [   4  508]\n",
      " [   5  868]\n",
      " [   6 1423]\n",
      " [   7 2435]\n",
      " [   8   71]\n",
      " [   9   38]]\n",
      "[[   0   47]\n",
      " [   1   75]\n",
      " [   2  111]\n",
      " [   3  190]\n",
      " [   4  294]\n",
      " [   5  451]\n",
      " [   6  842]\n",
      " [   7 1567]\n",
      " [   8 2340]\n",
      " [   9   55]]\n",
      "[[   0   65]\n",
      " [   1   40]\n",
      " [   2   60]\n",
      " [   3  103]\n",
      " [   4  146]\n",
      " [   5  265]\n",
      " [   6  499]\n",
      " [   7  896]\n",
      " [   8 1468]\n",
      " [   9 2436]]\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",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,60000,1):\n",
    "    if train_set[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif train_set[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif train_set[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif train_set[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif train_set[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif train_set[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif train_set[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif train_set[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif train_set[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif train_set[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "train_set[1][label[1]]\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",
    "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(train_set[0][label[0][z]])\n",
    "        list0[1].append(train_set[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(train_set[0][label[0][z]])\n",
    "        list1[1].append(train_set[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(train_set[0][label[0][z]])\n",
    "        list2[1].append(train_set[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(train_set[0][label[0][z]])\n",
    "        list3[1].append(train_set[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(train_set[0][label[0][z]])\n",
    "        list4[1].append(train_set[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(train_set[0][label[0][z]])\n",
    "        list5[1].append(train_set[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(train_set[0][label[0][z]])\n",
    "        list6[1].append(train_set[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(train_set[0][label[0][z]])\n",
    "        list7[1].append(train_set[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(train_set[0][label[0][z]])\n",
    "        list8[1].append(train_set[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(train_set[0][label[0][z]])\n",
    "        list9[1].append(train_set[1][label[0][z]])  \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(train_set[0][label[1][z]])\n",
    "        list1[1].append(train_set[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(train_set[0][label[1][z]])\n",
    "        list2[1].append(train_set[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(train_set[0][label[1][z]])\n",
    "        list3[1].append(train_set[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(train_set[0][label[1][z]])\n",
    "        list4[1].append(train_set[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(train_set[0][label[1][z]])\n",
    "        list5[1].append(train_set[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(train_set[0][label[1][z]])\n",
    "        list6[1].append(train_set[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(train_set[0][label[1][z]])\n",
    "        list7[1].append(train_set[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(train_set[0][label[1][z]])\n",
    "        list8[1].append(train_set[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(train_set[0][label[1][z]])\n",
    "        list9[1].append(train_set[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(train_set[0][label[1][z]])\n",
    "        list0[1].append(train_set[1][label[1][z]])  \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(train_set[0][label[2][z]])\n",
    "        list2[1].append(train_set[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(train_set[0][label[2][z]])\n",
    "        list3[1].append(train_set[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(train_set[0][label[2][z]])\n",
    "        list4[1].append(train_set[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(train_set[0][label[2][z]])\n",
    "        list5[1].append(train_set[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(train_set[0][label[2][z]])\n",
    "        list6[1].append(train_set[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(train_set[0][label[2][z]])\n",
    "        list7[1].append(train_set[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(train_set[0][label[2][z]])\n",
    "        list8[1].append(train_set[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(train_set[0][label[2][z]])\n",
    "        list9[1].append(train_set[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(train_set[0][label[2][z]])\n",
    "        list0[1].append(train_set[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(train_set[0][label[2][z]])\n",
    "        list1[1].append(train_set[1][label[2][z]])  \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(train_set[0][label[3][z]])\n",
    "        list3[1].append(train_set[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(train_set[0][label[3][z]])\n",
    "        list4[1].append(train_set[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(train_set[0][label[3][z]])\n",
    "        list5[1].append(train_set[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(train_set[0][label[3][z]])\n",
    "        list6[1].append(train_set[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(train_set[0][label[3][z]])\n",
    "        list7[1].append(train_set[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(train_set[0][label[3][z]])\n",
    "        list8[1].append(train_set[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(train_set[0][label[3][z]])\n",
    "        list9[1].append(train_set[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(train_set[0][label[3][z]])\n",
    "        list0[1].append(train_set[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(train_set[0][label[3][z]])\n",
    "        list1[1].append(train_set[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(train_set[0][label[3][z]])\n",
    "        list2[1].append(train_set[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(train_set[0][label[4][z]])\n",
    "        list4[1].append(train_set[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(train_set[0][label[4][z]])\n",
    "        list5[1].append(train_set[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(train_set[0][label[4][z]])\n",
    "        list6[1].append(train_set[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(train_set[0][label[4][z]])\n",
    "        list7[1].append(train_set[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(train_set[0][label[4][z]])\n",
    "        list8[1].append(train_set[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(train_set[0][label[4][z]])\n",
    "        list9[1].append(train_set[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(train_set[0][label[4][z]])\n",
    "        list0[1].append(train_set[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(train_set[0][label[4][z]])\n",
    "        list1[1].append(train_set[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(train_set[0][label[4][z]])\n",
    "        list2[1].append(train_set[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(train_set[0][label[4][z]])\n",
    "        list3[1].append(train_set[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(train_set[0][label[5][z]])\n",
    "        list5[1].append(train_set[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(train_set[0][label[5][z]])\n",
    "        list6[1].append(train_set[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(train_set[0][label[5][z]])\n",
    "        list7[1].append(train_set[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(train_set[0][label[5][z]])\n",
    "        list8[1].append(train_set[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(train_set[0][label[5][z]])\n",
    "        list9[1].append(train_set[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(train_set[0][label[5][z]])\n",
    "        list0[1].append(train_set[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(train_set[0][label[5][z]])\n",
    "        list1[1].append(train_set[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(train_set[0][label[5][z]])\n",
    "        list2[1].append(train_set[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(train_set[0][label[5][z]])\n",
    "        list3[1].append(train_set[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(train_set[0][label[5][z]])\n",
    "        list4[1].append(train_set[1][label[5][z]])  \n",
    "\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(train_set[0][label[6][z]])\n",
    "        list6[1].append(train_set[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(train_set[0][label[6][z]])\n",
    "        list7[1].append(train_set[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(train_set[0][label[6][z]])\n",
    "        list8[1].append(train_set[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(train_set[0][label[6][z]])\n",
    "        list9[1].append(train_set[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(train_set[0][label[6][z]])\n",
    "        list0[1].append(train_set[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(train_set[0][label[6][z]])\n",
    "        list1[1].append(train_set[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(train_set[0][label[6][z]])\n",
    "        list2[1].append(train_set[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(train_set[0][label[6][z]])\n",
    "        list3[1].append(train_set[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(train_set[0][label[6][z]])\n",
    "        list4[1].append(train_set[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(train_set[0][label[6][z]])\n",
    "        list5[1].append(train_set[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(train_set[0][label[7][z]])\n",
    "        list7[1].append(train_set[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(train_set[0][label[7][z]])\n",
    "        list8[1].append(train_set[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(train_set[0][label[7][z]])\n",
    "        list9[1].append(train_set[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(train_set[0][label[7][z]])\n",
    "        list0[1].append(train_set[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(train_set[0][label[7][z]])\n",
    "        list1[1].append(train_set[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(train_set[0][label[7][z]])\n",
    "        list2[1].append(train_set[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(train_set[0][label[7][z]])\n",
    "        list3[1].append(train_set[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(train_set[0][label[7][z]])\n",
    "        list4[1].append(train_set[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(train_set[0][label[7][z]])\n",
    "        list5[1].append(train_set[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(train_set[0][label[7][z]])\n",
    "        list6[1].append(train_set[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(train_set[0][label[8][z]])\n",
    "        list8[1].append(train_set[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(train_set[0][label[8][z]])\n",
    "        list9[1].append(train_set[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(train_set[0][label[8][z]])\n",
    "        list0[1].append(train_set[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(train_set[0][label[8][z]])\n",
    "        list1[1].append(train_set[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(train_set[0][label[8][z]])\n",
    "        list2[1].append(train_set[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(train_set[0][label[8][z]])\n",
    "        list3[1].append(train_set[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(train_set[0][label[8][z]])\n",
    "        list4[1].append(train_set[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(train_set[0][label[8][z]])\n",
    "        list5[1].append(train_set[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(train_set[0][label[8][z]])\n",
    "        list6[1].append(train_set[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(train_set[0][label[8][z]])\n",
    "        list7[1].append(train_set[1][label[8][z]])  \n",
    "\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(train_set[0][label[9][z]])\n",
    "        list9[1].append(train_set[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(train_set[0][label[9][z]])\n",
    "        list0[1].append(train_set[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(train_set[0][label[9][z]])\n",
    "        list1[1].append(train_set[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(train_set[0][label[9][z]])\n",
    "        list2[1].append(train_set[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(train_set[0][label[9][z]])\n",
    "        list3[1].append(train_set[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(train_set[0][label[9][z]])\n",
    "        list4[1].append(train_set[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(train_set[0][label[9][z]])\n",
    "        list5[1].append(train_set[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(train_set[0][label[9][z]])\n",
    "        list6[1].append(train_set[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(train_set[0][label[9][z]])\n",
    "        list7[1].append(train_set[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(train_set[0][label[9][z]])\n",
    "        list8[1].append(train_set[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",
    "unique, counts = np.unique(list1[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list3[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list4[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list5[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "d212199d-c71b-46e8-8602-14f2e1d5f0ab",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<3:\n",
    "        if tag1[z]==6:\n",
    "            tag1[z]=0\n",
    "        elif tag1[z]==0:\n",
    "            tag1[z]=6        \n",
    "        elif tag1[z]==1:\n",
    "            tag1[z]=7     \n",
    "        elif tag1[z]==7:\n",
    "            tag1[z]=1   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 6,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1c1faaf3-0a08-4288-b494-d3059924b666",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is my idx\n",
      "0\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "1\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "2\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "3\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "4\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "5\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "6\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "7\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "8\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "9\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-20:51:32 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Simulation started.                                                           <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:372</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-20:51:32\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Simulation started.                                                           \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m372\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b4a9134631d34674bfc00f6dd2bfa771",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output()"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"></pre>\n"
      ],
      "text/plain": []
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-23:29:24 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3276</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-23:29:24\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3276\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\">71547840</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;36m71547840\u001b[0m                                                          \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m241\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[]\n"
     ]
    }
   ],
   "source": [
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CNNmnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(True)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.95</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.95\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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WrUKvXr1QseOHQEAp06dgiAIeOGFFxAZGen0NW/ePABAXl6e0+u0bdu2xmtXVlZi7ty50piXiIgIREZGoqSkBKWlpZf5zusnPT0da9asqdH+kSNHOrV/xowZ6NixI2644QYkJCTgvvvuw5o1a6749X18fKSxR45tKi0tRVRUVI12lZeXS20aOnQo7rzzTrz00kuIiIjArbfeimXLlsFgMFxxuy5l4cKFOHz4MBITE9G/f3+8+OKLOH36dKO/LlFT45gbomYoODgYsbGxOHjwYJ33O3jwIOLj4xEUFAQAUKvVuO222/Ddd99h8eLFyM3NxdatW/Hqq69KjxEH3D711FMYPXq0y+dNSUlxuu1YpRH985//xLJly/D4448jLS0NwcHBkMlk+Mc//lFjUK+7Wa1WXHfddXjmmWdcnheDXFRUFA4cOIC1a9fit99+w2+//YZly5Zh0qRJ+PTTTy/79dVqNeRy578NrVYroqKi8MUXX7h8jDgoXCaTYfXq1dixYwd++uknrF27Fvfddx/efPNN7NixAwEBAbUuymexWC67zQBw9913Y/Dgwfjuu+/w+++/4/XXX8drr72Gb7/9FjfccMMVPTdRc8JwQ9RM3XzzzVi6dCm2bNmCQYMG1Tj/119/ITMzE9OnT3c6Pm7cOHz66adYv349jh07BkEQpC4pANK0caVSKVU6Lsfq1asxefJkvPnmm9IxvV6PkpKSy37O6mr7kG/fvj3Ky8vr1X6VSoUxY8ZgzJgxsFqtmDFjBj788EO88MILSElJcdvqvu3bt8cff/yBgQMHugyD1V199dW4+uqr8corr+DLL7/EhAkTsHLlSkybNg2hoaEAUONanj17tl5tqes9xcbGYsaMGZgxYwby8vLQp08fvPLKKww31KqwW4qomXr66aeh0Wgwffp0FBYWOp0rKirCQw89BD8/Pzz99NNO50aOHImwsDCsWrUKq1atQv/+/Z26laKiojBs2DB8+OGHyM7OrvG6+fn59WqfQqGAIAhOx959990rri448vf3dxmW7r77bmzfvh1r166tca6kpARmsxkAalw3uVyOHj16AIDUDSSuT3Oloezuu++GxWLByy+/XOOc2WyWnr+4uLjGdevVq5dTm9q0aQOFQiGNHRItXry4Xm1xdd0sFkuN7sKoqCjExcU1SZcYUVNi5YaomerQoQM+/fRT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12tz0a1bt+LWW2/Fvffei549e6Jdu3Y4efKkdL5Dhw7QaDR1vnZqair69euHpUuX4ssvv8R99913yde9Ugw3blLKwcRERHSZQkNDER4ejo8++ginTp3Chg0bMGvWLOn8+PHjERMTg9tuuw1bt27F6dOn8c0332D79u0AgHnz5mHFihWYN28ejh07hkOHDuG1116THj98+HC899572L9/P/bs2YOHHnoISuWlP686dOiAdevWYdu2bTh27BimT5+O3Nxc6byvry+effZZPPPMM/jss8+QkZGBHTt24OOPP3Z6nmnTpmHBggUQBMFpFldjYbhxk0qTBYFqH463ISKiBpPL5Vi5ciX27t2L7t2744knnsDrr78unVepVPj9998RFRWFG2+8EampqViwYIG0ueSwYcPw9ddf48cff0SvXr0wfPhw7Nq1S3r8m2++icTERAwePBj33HMPnnrqqXptLvr888+jT58+GD16NIYNGyYFLEcvvPACnnzyScydOxddunTBuHHjkJeX53Sf8ePHw8fHB+PHj4evr+8VXKn6kQnVO+FaOa1Wi+DgYJSWliIoKMjtz2+xClDIG28EOBERuabX63HmzBm0bdu2ST5Aqf4yMzPRvn177N69G3369Kn1fnX9P2zI5zcHFLsZgw0REZGNyWRCYWEhnn/+eVx99dV1Bht3YrcUERERNYqtW7ciNjYWu3fvxpIlS5rsdVm5ISIiokYxbNiwGlPQmwIrN0RERNSqMNwQERFRq8JwQ0RErYqXTQJuVdz1/47hhoiIWgVxUbr6rLxLzZO4rYO4fs/l4oBiIiJqFRQKBUJCQqQF5Pz8/Bp152lyL6vVivz8fPj5+cHH58riCcMNERG1GjExMQBQY4VcahnkcjmSkpKuOJQy3BARUashk8kQGxuLqKgol7teU/OmUqkgl1/5iBmGGyIianUUCsUVj9uglosDiomIiKhVYbghIiKiVoXhhoiIiFoVrxtzIy4QpNVqPdwSIiIiqi/xc7s+C/15XbgpKysDACQmJnq4JURERNRQZWVlCA4OrvM+MsHL1qm2Wq24ePEiAgMD3ba4k1arRWJiIs6dO4egoCC3PGdrxutVf7xWDcPrVX+8VvXHa9UwjXW9BEFAWVkZ4uLiLjld3OsqN3K5HAkJCY3y3EFBQfzBbwBer/rjtWoYXq/647WqP16rhmmM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vfcepk2b5nROr9cjLi4OS5Yswd133w0A6NmzJ+644w7MmzcPJ0+eRKdOnbBu3TqMHDmyxnNv2rQJ1157LYqLixESEoJp06ZBoVDgww8/lO6zZcsWDB06FDqdDr6+vo37Zomo0bByQ0TNxrFjx2AwGDBixIga53x9fTFx4kR88sknAIB9+/bh8OHDmDJlCgDgwIEDUCgUGDp0aL1e6++//8by5csREBAgfY0ePRpWqxVnzpxx23sioqbn4+kGEBGJNBpNneenTZuGXr164fz581i2bBmGDx+ONm3a1Oux1ZWXl2P69Ol49NFHa5xLSkpq0HMRUfPCyg0RNRsdOnSARqORBghXl5qain79+mHp0qX48ssvcd999zmds1qt2Lx5c71eq0+fPjh69ChSUlJqfKlUKre8HyLyDIYbImo2fH198eyzz+KZZ57BZ599hoyMDOzYscNpxtO0adOwYMECCIKA22+/XTqenJyMyZMn47777sP333+PM2fOYNOmTfjqq69cvtazzz6Lbdu2YebMmThw4ADS09Pxww8/cEAxUSvAcENEzcoLL7yAJ598EnPnzkWXLl0wbtw45OXlSefHjx8PHx8fjB8/vsag3w8++AB33XUXZsyYgc6dO+OBBx6odWp3jx49sHnzZpw8eRKDBw9G7969MXfuXMTFxTXq+yOixsfZUkTUomRmZqJ9+/bYvXs3+vTp4+nmEFEzxHBDRC2CyWRCYWEhnnrqKZw5cwZbt271dJOIqJlitxQRtQhbt25FbGwsdu/ejSVLlni6OUTUjLFyQ0RERK0KKzdERETUqjDcEBERUavCcENEREStCsMNERERtSoMN0RERNSqMNwQERFRq8JwQ0RERK0Kww0RERG1Kgw3RERE1Kr8P4cGQzeys1nNAAAAAElFTkSuQmCC",
      "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.11852}, {'accuracy': 0.17159}, {'accuracy': 0.18852999999999998}, {'accuracy': 0.23179}, {'accuracy': 0.24846}, {'accuracy': 0.29114999999999996}, {'accuracy': 0.31951999999999997}, {'accuracy': 0.37734}, {'accuracy': 0.37266}, {'accuracy': 0.41947999999999996}, {'accuracy': 0.5051599999999999}, {'accuracy': 0.42389}, {'accuracy': 0.47634}, {'accuracy': 0.46541}, {'accuracy': 0.51235}, {'accuracy': 0.52941}, {'accuracy': 0.62015}, {'accuracy': 0.51118}, {'accuracy': 0.67651}, {'accuracy': 0.6858000000000001}, {'accuracy': 0.62492}, {'accuracy': 0.6345900000000001}, {'accuracy': 0.62159}, {'accuracy': 0.68395}, {'accuracy': 0.71239}, {'accuracy': 0.7036}, {'accuracy': 0.72462}, {'accuracy': 0.63863}, {'accuracy': 0.7145}, {'accuracy': 0.73133}, {'accuracy': 0.69576}, {'accuracy': 0.72432}, {'accuracy': 0.71355}, {'accuracy': 0.7380800000000001}, {'accuracy': 0.6986100000000001}, {'accuracy': 0.7464599999999999}, {'accuracy': 0.79345}, {'accuracy': 0.7214799999999999}, {'accuracy': 0.7308600000000001}, {'accuracy': 0.8123799999999999}, {'accuracy': 0.7524200000000001}, {'accuracy': 0.7591899999999999}, {'accuracy': 0.8027099999999999}, {'accuracy': 0.82347}, {'accuracy': 0.73017}, {'accuracy': 0.7944399999999999}, {'accuracy': 0.76047}, {'accuracy': 0.80037}, {'accuracy': 0.77905}, {'accuracy': 0.78591}, {'accuracy': 0.80235}, {'accuracy': 0.74008}, {'accuracy': 0.7454700000000001}, {'accuracy': 0.79473}, {'accuracy': 0.80802}, {'accuracy': 0.79086}, {'accuracy': 0.8522700000000001}, {'accuracy': 0.81924}, {'accuracy': 0.79585}, {'accuracy': 0.85172}, {'accuracy': 0.8222400000000001}, {'accuracy': 0.81842}, {'accuracy': 0.7884900000000001}, {'accuracy': 0.78013}, {'accuracy': 0.8453999999999999}, {'accuracy': 0.80127}, {'accuracy': 0.80908}, {'accuracy': 0.8354699999999999}, {'accuracy': 0.81569}, {'accuracy': 0.8046200000000001}, {'accuracy': 0.8324400000000001}, {'accuracy': 0.8494300000000001}, {'accuracy': 0.80643}, {'accuracy': 0.8432499999999999}, {'accuracy': 0.82847}, {'accuracy': 0.8302299999999999}, {'accuracy': 0.84974}, {'accuracy': 0.84526}, {'accuracy': 0.8065599999999999}, {'accuracy': 0.8547399999999999}, {'accuracy': 0.8123299999999999}, {'accuracy': 0.86473}, {'accuracy': 0.84375}, {'accuracy': 0.82853}, {'accuracy': 0.76999}, {'accuracy': 0.8055299999999999}, {'accuracy': 0.8514900000000001}, {'accuracy': 0.8222799999999999}, {'accuracy': 0.8056000000000001}, {'accuracy': 0.85158}, {'accuracy': 0.83726}, {'accuracy': 0.85717}, {'accuracy': 0.8146100000000001}, {'accuracy': 0.85131}, {'accuracy': 0.8467399999999999}, {'accuracy': 0.8189499999999998}, {'accuracy': 0.8312100000000001}, {'accuracy': 0.8681899999999999}, {'accuracy': 0.8584000000000002}, {'accuracy': 0.88669}, {'accuracy': 0.85007}, {'accuracy': 0.8728}, {'accuracy': 0.8551399999999999}, {'accuracy': 0.84659}, {'accuracy': 0.82088}, {'accuracy': 0.87382}, {'accuracy': 0.87569}, {'accuracy': 0.81418}, {'accuracy': 0.82864}, {'accuracy': 0.88063}, {'accuracy': 0.85409}, {'accuracy': 0.8676599999999999}, {'accuracy': 0.87148}, {'accuracy': 0.87267}, {'accuracy': 0.8771599999999999}, {'accuracy': 0.8667400000000001}, {'accuracy': 0.8632499999999999}, {'accuracy': 0.87195}, {'accuracy': 0.89054}, {'accuracy': 0.9049200000000001}, {'accuracy': 0.9069300000000002}, {'accuracy': 0.87138}, {'accuracy': 0.88727}, {'accuracy': 0.88873}, {'accuracy': 0.88329}, {'accuracy': 0.85409}, {'accuracy': 0.88432}, {'accuracy': 0.8406800000000001}, {'accuracy': 0.8610200000000001}, {'accuracy': 0.83398}, {'accuracy': 0.8744900000000001}, {'accuracy': 0.8601300000000001}, {'accuracy': 0.86595}, {'accuracy': 0.8831199999999999}, {'accuracy': 0.88538}, {'accuracy': 0.8816900000000001}, {'accuracy': 0.89977}, {'accuracy': 0.8943099999999999}, {'accuracy': 0.8700699999999999}, {'accuracy': 0.9177299999999999}, {'accuracy': 0.8949300000000001}, {'accuracy': 0.8771700000000001}, {'accuracy': 0.8539900000000001}, {'accuracy': 0.8824099999999999}, {'accuracy': 0.88146}, {'accuracy': 0.88759}, {'accuracy': 0.8958600000000001}, {'accuracy': 0.88375}, {'accuracy': 0.8939600000000001}, {'accuracy': 0.8856499999999998}, {'accuracy': 0.73683}, {'accuracy': 0.9195400000000001}, {'accuracy': 0.94268}, {'accuracy': 0.93036}, {'accuracy': 0.9226000000000001}, {'accuracy': 0.9392699999999999}, {'accuracy': 0.93611}, {'accuracy': 0.94321}, {'accuracy': 0.9441399999999998}, {'accuracy': 0.94571}, {'accuracy': 0.94148}, {'accuracy': 0.94016}, {'accuracy': 0.9425100000000001}, {'accuracy': 0.9455499999999999}, {'accuracy': 0.9417300000000001}, {'accuracy': 0.94388}, {'accuracy': 0.9491800000000001}, {'accuracy': 0.94788}, {'accuracy': 0.9437999999999999}, {'accuracy': 0.9399999999999998}, {'accuracy': 0.9403900000000001}, {'accuracy': 0.9411000000000002}, {'accuracy': 0.9425100000000001}, {'accuracy': 0.94255}, {'accuracy': 0.93873}, {'accuracy': 0.9384500000000001}, {'accuracy': 0.93801}, {'accuracy': 0.9459}, {'accuracy': 0.94153}, {'accuracy': 0.93822}, {'accuracy': 0.9439900000000001}, {'accuracy': 0.9401600000000002}, {'accuracy': 0.9449400000000001}, {'accuracy': 0.94249}, {'accuracy': 0.93714}, {'accuracy': 0.94098}, {'accuracy': 0.94266}, {'accuracy': 0.94194}, {'accuracy': 0.9456}, {'accuracy': 0.9468300000000001}, {'accuracy': 0.94248}, {'accuracy': 0.94275}, {'accuracy': 0.94099}, {'accuracy': 0.9449099999999999}, {'accuracy': 0.9449200000000001}, {'accuracy': 0.94664}, {'accuracy': 0.9396699999999999}, {'accuracy': 0.9456599999999998}, {'accuracy': 0.9457000000000001}, {'accuracy': 0.94092}, {'accuracy': 0.94336}, {'accuracy': 0.9380499999999999}, {'accuracy': 0.94275}, {'accuracy': 0.9411299999999999}, {'accuracy': 0.9484899999999999}, {'accuracy': 0.9476100000000001}, {'accuracy': 0.94496}, {'accuracy': 0.94442}, {'accuracy': 0.94009}, {'accuracy': 0.9440099999999999}, {'accuracy': 0.94762}, {'accuracy': 0.9440500000000001}, {'accuracy': 0.94669}, {'accuracy': 0.94367}, {'accuracy': 0.9373699999999999}, {'accuracy': 0.94955}, {'accuracy': 0.9449500000000001}, {'accuracy': 0.94527}, {'accuracy': 0.94242}, {'accuracy': 0.9423400000000001}, {'accuracy': 0.9459400000000002}, {'accuracy': 0.9433999999999999}, {'accuracy': 0.94392}, {'accuracy': 0.9433999999999999}, {'accuracy': 0.94058}, {'accuracy': 0.94047}, {'accuracy': 0.94396}, {'accuracy': 0.94199}, {'accuracy': 0.9423299999999999}, {'accuracy': 0.9474899999999999}, {'accuracy': 0.9441}, {'accuracy': 0.94754}, {'accuracy': 0.9391299999999999}, {'accuracy': 0.9447699999999998}, {'accuracy': 0.9416500000000001}, {'accuracy': 0.94633}, {'accuracy': 0.93983}, {'accuracy': 0.94238}, {'accuracy': 0.9476000000000001}, {'accuracy': 0.94668}, {'accuracy': 0.94375}, {'accuracy': 0.9434100000000001}, {'accuracy': 0.9422899999999998}, {'accuracy': 0.9421399999999999}, {'accuracy': 0.94566}, {'accuracy': 0.94443}, {'accuracy': 0.9457599999999999}, {'accuracy': 0.94367}, {'accuracy': 0.9473100000000001}, {'accuracy': 0.9432499999999999}, {'accuracy': 0.94152}, {'accuracy': 0.9449400000000001}, {'accuracy': 0.9454600000000001}, {'accuracy': 0.94471}, {'accuracy': 0.9471}, {'accuracy': 0.9435800000000001}, {'accuracy': 0.9446899999999999}, {'accuracy': 0.94712}, {'accuracy': 0.94618}, {'accuracy': 0.94546}, {'accuracy': 0.94295}, {'accuracy': 0.9465199999999999}, {'accuracy': 0.94844}, {'accuracy': 0.9445499999999999}, {'accuracy': 0.9435699999999999}, {'accuracy': 0.9440900000000001}, {'accuracy': 0.9447699999999999}, {'accuracy': 0.9440100000000001}, {'accuracy': 0.9459000000000002}, {'accuracy': 0.94489}, {'accuracy': 0.9459}, {'accuracy': 0.94281}, {'accuracy': 0.9448599999999999}, {'accuracy': 0.93995}, {'accuracy': 0.9412799999999999}, {'accuracy': 0.9465299999999999}, {'accuracy': 0.94529}, {'accuracy': 0.9455600000000001}, {'accuracy': 0.94703}, {'accuracy': 0.9434799999999999}, {'accuracy': 0.94614}, {'accuracy': 0.9453999999999999}, {'accuracy': 0.9441200000000001}, {'accuracy': 0.9461899999999999}, {'accuracy': 0.9452299999999999}, {'accuracy': 0.94497}, {'accuracy': 0.94335}, {'accuracy': 0.9477599999999999}, {'accuracy': 0.94575}, {'accuracy': 0.94188}, {'accuracy': 0.94716}, {'accuracy': 0.9431400000000002}, {'accuracy': 0.94786}, {'accuracy': 0.9452399999999999}, {'accuracy': 0.94431}, {'accuracy': 0.9478500000000001}, {'accuracy': 0.9434400000000001}, {'accuracy': 0.94686}, {'accuracy': 0.94632}, {'accuracy': 0.9486199999999998}]\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": "81819e42-77ef-4c29-bd00-95dbf29e49be",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1426e9d7-eeeb-43ff-ab51-4dc75182b661",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "52a1e2c2-767f-4aa4-8854-4d2b018f5ee5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e11a40e6-7185-480d-a3b6-33ebb0b1c9d8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fed658e9-2a1d-4907-81d5-4b2385f87cde",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fbddefb1-354b-46dd-b280-664581af6d3d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "191119ed-0b5e-4b57-b048-62dd78c77167",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5e95c8e7-7336-4524-ae17-118b9ecf3fb5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e65bf920-f642-4cfb-a866-d1bebbcc0212",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a054f43d-8887-41d4-b751-51032542824e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "822d6a9c-d7f9-4567-b7f2-df2604591225",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0b8d6c2c-8210-4365-b001-ebd1cea87079",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5ee98064-42ca-4998-9b5d-1e4fa7cba018",
   "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
}
