{
 "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",
    "    \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 2340]\n",
      " [   1   59]\n",
      " [   2   34]\n",
      " [   3   63]\n",
      " [   4  118]\n",
      " [   5  170]\n",
      " [   6  320]\n",
      " [   7  564]\n",
      " [   8  873]\n",
      " [   9 1472]]\n",
      "[[   0 1459]\n",
      " [   1 2699]\n",
      " [   2   63]\n",
      " [   3   43]\n",
      " [   4   55]\n",
      " [   5  125]\n",
      " [   6  186]\n",
      " [   7  313]\n",
      " [   8  484]\n",
      " [   9  774]]\n",
      "[[   0  869]\n",
      " [   1 1622]\n",
      " [   2 2363]\n",
      " [   3   58]\n",
      " [   4   46]\n",
      " [   5   66]\n",
      " [   6   97]\n",
      " [   7  196]\n",
      " [   8  317]\n",
      " [   9  516]]\n",
      "[[   0  501]\n",
      " [   1  988]\n",
      " [   2 1433]\n",
      " [   3 2474]\n",
      " [   4   58]\n",
      " [   5   31]\n",
      " [   6   58]\n",
      " [   7  103]\n",
      " [   8  187]\n",
      " [   9  305]]\n",
      "[[   0  280]\n",
      " [   1  579]\n",
      " [   2  857]\n",
      " [   3 1511]\n",
      " [   4 2264]\n",
      " [   5   64]\n",
      " [   6   37]\n",
      " [   7   77]\n",
      " [   8  132]\n",
      " [   9  175]]\n",
      "[[   0  200]\n",
      " [   1  359]\n",
      " [   2  533]\n",
      " [   3  818]\n",
      " [   4 1453]\n",
      " [   5 2134]\n",
      " [   6   45]\n",
      " [   7   47]\n",
      " [   8   76]\n",
      " [   9  124]]\n",
      "[[   0  117]\n",
      " [   1  217]\n",
      " [   2  332]\n",
      " [   3  533]\n",
      " [   4  868]\n",
      " [   5 1284]\n",
      " [   6 2359]\n",
      " [   7   60]\n",
      " [   8   42]\n",
      " [   9   69]]\n",
      "[[   0   61]\n",
      " [   1  115]\n",
      " [   2  157]\n",
      " [   3  326]\n",
      " [   4  513]\n",
      " [   5  791]\n",
      " [   6 1436]\n",
      " [   7 2565]\n",
      " [   8   56]\n",
      " [   9   44]]\n",
      "[[   0   41]\n",
      " [   1   58]\n",
      " [   2  123]\n",
      " [   3  192]\n",
      " [   4  288]\n",
      " [   5  459]\n",
      " [   6  857]\n",
      " [   7 1486]\n",
      " [   8 2271]\n",
      " [   9   51]]\n",
      "[[   0   55]\n",
      " [   1   46]\n",
      " [   2   63]\n",
      " [   3  113]\n",
      " [   4  179]\n",
      " [   5  297]\n",
      " [   6  523]\n",
      " [   7  854]\n",
      " [   8 1413]\n",
      " [   9 2419]]\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",
    "\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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "fb85c984-e99f-433e-9cca-7bc7c93c10dd",
   "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<5:\n",
    "        tag1[z]=(tag1[z] - 1) % 10"
   ]
  },
  {
   "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:04:22 </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:04:22\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": "9a1ed95bf0a346f8a86a070a2de0f46a",
       "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-20:12:20 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3299</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-20:12:20\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3299\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\">72050160</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;36m72050160\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.10467}, {'accuracy': 0.13843}, {'accuracy': 0.15492999999999996}, {'accuracy': 0.1565}, {'accuracy': 0.16462000000000002}, {'accuracy': 0.19965}, {'accuracy': 0.17960000000000004}, {'accuracy': 0.19046000000000002}, {'accuracy': 0.1574}, {'accuracy': 0.20965000000000003}, {'accuracy': 0.15752000000000002}, {'accuracy': 0.18551}, {'accuracy': 0.15933000000000003}, {'accuracy': 0.25185}, {'accuracy': 0.21847}, {'accuracy': 0.25912}, {'accuracy': 0.2182}, {'accuracy': 0.27016}, {'accuracy': 0.27644}, {'accuracy': 0.3414}, {'accuracy': 0.3892}, {'accuracy': 0.4131}, {'accuracy': 0.39111}, {'accuracy': 0.38741}, {'accuracy': 0.43316999999999994}, {'accuracy': 0.42123}, {'accuracy': 0.41041}, {'accuracy': 0.5159100000000001}, {'accuracy': 0.47085}, {'accuracy': 0.42706}, {'accuracy': 0.44741}, {'accuracy': 0.45210999999999996}, {'accuracy': 0.42727999999999994}, {'accuracy': 0.59039}, {'accuracy': 0.43765}, {'accuracy': 0.47786999999999996}, {'accuracy': 0.48334}, {'accuracy': 0.39897}, {'accuracy': 0.4432999999999999}, {'accuracy': 0.57253}, {'accuracy': 0.4636100000000001}, {'accuracy': 0.46373999999999993}, {'accuracy': 0.51823}, {'accuracy': 0.42241}, {'accuracy': 0.53067}, {'accuracy': 0.49901}, {'accuracy': 0.49571999999999994}, {'accuracy': 0.5048199999999999}, {'accuracy': 0.568}, {'accuracy': 0.5624499999999999}, {'accuracy': 0.52841}, {'accuracy': 0.563}, {'accuracy': 0.5024299999999999}, {'accuracy': 0.5990800000000001}, {'accuracy': 0.4912399999999999}, {'accuracy': 0.54701}, {'accuracy': 0.54213}, {'accuracy': 0.59975}, {'accuracy': 0.5148900000000001}, {'accuracy': 0.54722}, {'accuracy': 0.49347}, {'accuracy': 0.50437}, {'accuracy': 0.62948}, {'accuracy': 0.5562799999999999}, {'accuracy': 0.52284}, {'accuracy': 0.53466}, {'accuracy': 0.5481199999999999}, {'accuracy': 0.61525}, {'accuracy': 0.57575}, {'accuracy': 0.5300199999999999}, {'accuracy': 0.54391}, {'accuracy': 0.5729799999999999}, {'accuracy': 0.5277000000000001}, {'accuracy': 0.58276}, {'accuracy': 0.58411}, {'accuracy': 0.55811}, {'accuracy': 0.53151}, {'accuracy': 0.64862}, {'accuracy': 0.52467}, {'accuracy': 0.53643}, {'accuracy': 0.5415800000000001}, {'accuracy': 0.60381}, {'accuracy': 0.5380800000000001}, {'accuracy': 0.55983}, {'accuracy': 0.5799000000000001}, {'accuracy': 0.5125}, {'accuracy': 0.5363399999999999}, {'accuracy': 0.5221600000000002}, {'accuracy': 0.5334599999999999}, {'accuracy': 0.54539}, {'accuracy': 0.5348200000000001}, {'accuracy': 0.57795}, {'accuracy': 0.5753100000000001}, {'accuracy': 0.5571900000000001}, {'accuracy': 0.54112}, {'accuracy': 0.60236}, {'accuracy': 0.53735}, {'accuracy': 0.5829300000000001}, {'accuracy': 0.5197299999999999}, {'accuracy': 0.5988800000000001}, {'accuracy': 0.5729900000000001}, {'accuracy': 0.57693}, {'accuracy': 0.6015199999999999}, {'accuracy': 0.5816100000000001}, {'accuracy': 0.60878}, {'accuracy': 0.5950900000000001}, {'accuracy': 0.58439}, {'accuracy': 0.61129}, {'accuracy': 0.6195}, {'accuracy': 0.45376000000000005}, {'accuracy': 0.62081}, {'accuracy': 0.55592}, {'accuracy': 0.60865}, {'accuracy': 0.61256}, {'accuracy': 0.55067}, {'accuracy': 0.5791000000000001}, {'accuracy': 0.5851599999999999}, {'accuracy': 0.58521}, {'accuracy': 0.5764499999999999}, {'accuracy': 0.6154400000000001}, {'accuracy': 0.60836}, {'accuracy': 0.65966}, {'accuracy': 0.58109}, {'accuracy': 0.5838300000000001}, {'accuracy': 0.62951}, {'accuracy': 0.55097}, {'accuracy': 0.5566000000000001}, {'accuracy': 0.5806}, {'accuracy': 0.54678}, {'accuracy': 0.62199}, {'accuracy': 0.49288}, {'accuracy': 0.5152300000000001}, {'accuracy': 0.63048}, {'accuracy': 0.58286}, {'accuracy': 0.52915}, {'accuracy': 0.54298}, {'accuracy': 0.5516}, {'accuracy': 0.5342}, {'accuracy': 0.63791}, {'accuracy': 0.5432600000000001}, {'accuracy': 0.58283}, {'accuracy': 0.64839}, {'accuracy': 0.49802}, {'accuracy': 0.59843}, {'accuracy': 0.5848099999999999}, {'accuracy': 0.59722}, {'accuracy': 0.59095}, {'accuracy': 0.61921}, {'accuracy': 0.62251}, {'accuracy': 0.5357799999999999}, {'accuracy': 0.68943}, {'accuracy': 0.67556}, {'accuracy': 0.78182}, {'accuracy': 0.76549}, {'accuracy': 0.7566299999999999}, {'accuracy': 0.7832800000000001}, {'accuracy': 0.76192}, {'accuracy': 0.69434}, {'accuracy': 0.75162}, {'accuracy': 0.76208}, {'accuracy': 0.7225699999999999}, {'accuracy': 0.7496099999999999}, {'accuracy': 0.7497499999999999}, {'accuracy': 0.71615}, {'accuracy': 0.75382}, {'accuracy': 0.76841}, {'accuracy': 0.7455999999999999}, {'accuracy': 0.6715500000000001}, {'accuracy': 0.66}, {'accuracy': 0.72644}, {'accuracy': 0.7620699999999999}, {'accuracy': 0.7263599999999999}, {'accuracy': 0.75961}, {'accuracy': 0.70248}, {'accuracy': 0.74132}, {'accuracy': 0.71943}, {'accuracy': 0.7534400000000001}, {'accuracy': 0.79313}, {'accuracy': 0.7894500000000001}, {'accuracy': 0.7511300000000001}, {'accuracy': 0.7157000000000001}, {'accuracy': 0.7499399999999999}, {'accuracy': 0.74562}, {'accuracy': 0.69874}, {'accuracy': 0.7097300000000001}, {'accuracy': 0.72192}, {'accuracy': 0.7185900000000001}, {'accuracy': 0.7426200000000001}, {'accuracy': 0.72344}, {'accuracy': 0.7375}, {'accuracy': 0.69534}, {'accuracy': 0.70236}, {'accuracy': 0.66249}, {'accuracy': 0.79057}, {'accuracy': 0.7077899999999999}, {'accuracy': 0.74498}, {'accuracy': 0.7586700000000001}, {'accuracy': 0.77364}, {'accuracy': 0.72594}, {'accuracy': 0.73303}, {'accuracy': 0.74035}, {'accuracy': 0.77194}, {'accuracy': 0.751}, {'accuracy': 0.75045}, {'accuracy': 0.73605}, {'accuracy': 0.76685}, {'accuracy': 0.76558}, {'accuracy': 0.7267800000000001}, {'accuracy': 0.70896}, {'accuracy': 0.7444800000000001}, {'accuracy': 0.75685}, {'accuracy': 0.7057100000000001}, {'accuracy': 0.70261}, {'accuracy': 0.70274}, {'accuracy': 0.72975}, {'accuracy': 0.75449}, {'accuracy': 0.73035}, {'accuracy': 0.72782}, {'accuracy': 0.7282399999999999}, {'accuracy': 0.6997799999999998}, {'accuracy': 0.76051}, {'accuracy': 0.7734499999999999}, {'accuracy': 0.6891700000000001}, {'accuracy': 0.7564200000000001}, {'accuracy': 0.75572}, {'accuracy': 0.7140899999999999}, {'accuracy': 0.7678200000000001}, {'accuracy': 0.7801}, {'accuracy': 0.72714}, {'accuracy': 0.74054}, {'accuracy': 0.74467}, {'accuracy': 0.75217}, {'accuracy': 0.7144199999999999}, {'accuracy': 0.70116}, {'accuracy': 0.74588}, {'accuracy': 0.73702}, {'accuracy': 0.70823}, {'accuracy': 0.7296000000000001}, {'accuracy': 0.7321}, {'accuracy': 0.7767700000000001}, {'accuracy': 0.7491300000000001}, {'accuracy': 0.73827}, {'accuracy': 0.70201}, {'accuracy': 0.7365599999999999}, {'accuracy': 0.7399699999999999}, {'accuracy': 0.7589899999999998}, {'accuracy': 0.73715}, {'accuracy': 0.7724499999999999}, {'accuracy': 0.71697}, {'accuracy': 0.67513}, {'accuracy': 0.7411199999999999}, {'accuracy': 0.7620899999999999}, {'accuracy': 0.73178}, {'accuracy': 0.71754}, {'accuracy': 0.8041699999999998}, {'accuracy': 0.72362}, {'accuracy': 0.79837}, {'accuracy': 0.7533100000000001}, {'accuracy': 0.72558}, {'accuracy': 0.7470000000000001}, {'accuracy': 0.7093900000000001}, {'accuracy': 0.77722}, {'accuracy': 0.73482}, {'accuracy': 0.71342}, {'accuracy': 0.77038}, {'accuracy': 0.75687}, {'accuracy': 0.7125299999999999}, {'accuracy': 0.67217}, {'accuracy': 0.74527}, {'accuracy': 0.73372}, {'accuracy': 0.74316}, {'accuracy': 0.7581}, {'accuracy': 0.71791}, {'accuracy': 0.715}, {'accuracy': 0.7667200000000001}, {'accuracy': 0.72542}, {'accuracy': 0.72746}, {'accuracy': 0.7706100000000001}, {'accuracy': 0.70735}, {'accuracy': 0.7130200000000001}, {'accuracy': 0.6876599999999999}, {'accuracy': 0.69689}, {'accuracy': 0.6599600000000001}, {'accuracy': 0.70412}, {'accuracy': 0.7575299999999999}, {'accuracy': 0.7629699999999999}, {'accuracy': 0.7592}, {'accuracy': 0.77493}, {'accuracy': 0.73932}, {'accuracy': 0.7889099999999999}, {'accuracy': 0.69332}, {'accuracy': 0.6766399999999999}, {'accuracy': 0.73017}, {'accuracy': 0.76446}, {'accuracy': 0.73045}, {'accuracy': 0.7560499999999999}, {'accuracy': 0.7218899999999999}, {'accuracy': 0.7017300000000001}, {'accuracy': 0.71797}, {'accuracy': 0.7266599999999999}]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CNNmnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.73</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.73\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m172\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAACgQ0lEQVR4nO3dd3hUVfoH8O/0yaSHVEIgNFGkCQiiIggorr0juoKorI1Vl9VVVgVdV7Evrg3Xn9jWgrK23XVBRUFBlCYivRNaep8kU+/vj5lz5947M0kmTDIp38/z5CGZuTNz5ibkvnnf95yjkyRJAhEREVEnoY/1AIiIiIiiicENERERdSoMboiIiKhTYXBDREREnQqDGyIiIupUGNwQERFRp8LghoiIiDoVBjdERETUqTC4ISIiok6FwQ0RtaoVK1ZAp9NhxYoV8m033HAD8vPzYzamzuThhx+GTqeL9TCI2hUGN0Tt3NatW/Hb3/4Wubm5sFgs6N69O6677jps3bo11kNrdS+//DLefPPNVn2Nbdu24eGHH8aBAwda9XXa0uOPP45PP/001sMgihkGN0Tt2Mcff4zhw4dj+fLlmDFjBl5++WXcdNNN+PbbbzF8+HB88sknsR5iq2qr4OaRRx5hcEPUiRhjPQAiCm3v3r24/vrr0adPH3z33XfIyMiQ77vrrrswduxYXH/99di8eTP69OnTZuOy2+2Ij49vs9frCHhOiNoXZm6I2qmnn34adXV1+Mc//qEKbAAgPT0dr776Kux2O5566ikAwJIlS6DT6bBy5cqg53r11Veh0+mwZcsW+bYdO3bgyiuvRFpaGqxWK0aOHInPP/9c9bg333xTfs7bb78dmZmZ6NGjBwDg4MGDuP322zFgwADExcWhW7duuOqqq6KWAcnPz8fWrVuxcuVK6HQ66HQ6jB8/Xr6/srISd999N/Ly8mCxWNCvXz88+eST8Hq9quf54IMPMGLECCQmJiIpKQmDBw/G888/L7+/q666CgBw9tlny6+j7A/SuuGGG5CQkIC9e/fi/PPPR2JiIq677joAgNfrxYIFC3DyySfDarUiKysLt9xyCyoqKlTPsX79ekyePBnp6emIi4tD7969ceONN8r3h+pTAoADBw5Ap9M1ms3S6XSw2+1466235Pdzww03AABqampw9913Iz8/HxaLBZmZmTjnnHOwcePGsM9H1BExc0PUTv373/9Gfn4+xo4dG/L+s846C/n5+fjvf/8LALjggguQkJCADz/8EOPGjVMdu3jxYpx88skYNGgQAF8fzxlnnIHc3Fzcf//9iI+Px4cffohLL70U//rXv3DZZZepHn/77bcjIyMDc+fOhd1uBwCsW7cOP/zwA6655hr06NEDBw4cwCuvvILx48dj27ZtsNlsx/X+FyxYgN///vdISEjAAw88AADIysoCANTV1WHcuHE4cuQIbrnlFvTs2RM//PAD5syZg2PHjmHBggUAgK+++gpTp07FxIkT8eSTTwIAtm/fjtWrV+Ouu+7CWWedhTvvvBN///vf8ec//xknnXQSAMj/huN2uzF58mSceeaZeOaZZ+T3esstt+DNN9/EjBkzcOedd2L//v148cUX8fPPP2P16tUwmUwoLi7Gueeei4yMDNx///1ISUnBgQMH8PHHHx/X+RLeeecd3HzzzRg1ahR+97vfAQD69u0LALj11luxZMkSzJo1CwMHDkRZWRlWrVqF7du3Y/jw4VF5faJ2QSKidqeyslICIF1yySWNHnfxxRdLAKTq6mpJkiRp6tSpUmZmpuR2u+Vjjh07Jun1eukvf/mLfNvEiROlwYMHSw0NDfJtXq9XOv3006X+/fvLt73xxhsSAOnMM89UPackSVJdXV3QeNasWSMBkN5++235tm+//VYCIH377bfybdOnT5d69erV6HuTJEk6+eSTpXHjxgXd/uijj0rx8fHSrl27VLfff//9ksFgkAoKCiRJkqS77rpLSkpKChq70kcffRQ0vsZMnz5dAiDdf//9qtu///57CYD07rvvqm5funSp6vZPPvlEAiCtW7cu7GuEOmeSJEn79++XAEhvvPGGfNu8efMk7a/y+Ph4afr06UHPm5ycLN1xxx3NeJdEHRvLUkTtUE1NDQAgMTGx0ePE/dXV1QCAKVOmoLi4WFXOWLJkCbxeL6ZMmQIAKC8vxzfffIOrr74aNTU1KC0tRWlpKcrKyjB58mTs3r0bR44cUb3OzJkzYTAYVLfFxcXJn7tcLpSVlaFfv35ISUlp9TLHRx99hLFjxyI1NVUef2lpKSZNmgSPx4PvvvsOAJCSkgK73Y6vvvoq6mO47bbbgsaUnJyMc845RzWmESNGICEhAd9++608JgD4z3/+A5fLFfVxNSYlJQU//fQTjh492qavS9TWGNwQtUMiaBFBTjjaIOi8885DcnIyFi9eLB+zePFiDBs2DCeccAIAYM+ePZAkCQ899BAyMjJUH/PmzQMAFBcXq16nd+/eQa9dX1+PuXPnyj0v6enpyMjIQGVlJaqqqlr4zptn9+7dWLp0adD4J02apBr/7bffjhNOOAG/+c1v0KNHD9x4441YunTpcb++0WiUe4+UY6qqqkJmZmbQuGpra+UxjRs3DldccQUeeeQRpKen45JLLsEbb7wBh8Nx3ONqylNPPYUtW7YgLy8Po0aNwsMPP4x9+/a1+usStTX23BC1Q8nJycjJycHmzZsbPW7z5s3Izc1FUlISAMBiseDSSy/FJ598gpdffhlFRUVYvXo1Hn/8cfkxouH2nnvuweTJk0M+b79+/VRfK7M0wu9//3u88cYbuPvuuzFmzBgkJydDp9PhmmuuCWrqjTav14tzzjkHf/rTn0LeLwK5zMxMbNq0CcuWLcP//vc//O9//8Mbb7yBadOm4a233mrx61ssFuj16r8NvV4vMjMz8e6774Z8jGgK1+l0WLJkCX788Uf8+9//xrJly3DjjTfi2WefxY8//oiEhISwi/J5PJ4WjxkArr76aowdOxaffPIJvvzySzz99NN48skn8fHHH+M3v/nNcT03UXvC4Iaonbrwwgvx2muvYdWqVTjzzDOD7v/+++9x4MAB3HLLLarbp0yZgrfeegvLly/H9u3bIUmSXJICIE8bN5lMcqajJZYsWYLp06fj2WeflW9raGhAZWVli59TK9xFvm/fvqitrW3W+M1mMy666CJcdNFF8Hq9uP322/Hqq6/ioYceQr9+/aK2um/fvn3x9ddf44wzzggZDGqddtppOO200/DYY4/hvffew3XXXYcPPvgAN998M1JTUwEg6FwePHiwWWNp7D3l5OTg9ttvx+23347i4mIMHz4cjz32GIMb6lRYliJqp+69917ExcXhlltuQVlZmeq+8vJy3HrrrbDZbLj33ntV902aNAlpaWlYvHgxFi9ejFGjRqnKSpmZmRg/fjxeffVVHDt2LOh1S0pKmjU+g8EASZJUt73wwgvHnV1Qio+PDxksXX311VizZg2WLVsWdF9lZSXcbjcABJ03vV6PIUOGAIBcBhLr0xxvUHb11VfD4/Hg0UcfDbrP7XbLz19RURF03oYNG6YaU69evWAwGOTe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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.10467}, {'accuracy': 0.13843}, {'accuracy': 0.15492999999999996}, {'accuracy': 0.1565}, {'accuracy': 0.16462000000000002}, {'accuracy': 0.19965}, {'accuracy': 0.17960000000000004}, {'accuracy': 0.19046000000000002}, {'accuracy': 0.1574}, {'accuracy': 0.20965000000000003}, {'accuracy': 0.15752000000000002}, {'accuracy': 0.18551}, {'accuracy': 0.15933000000000003}, {'accuracy': 0.25185}, {'accuracy': 0.21847}, {'accuracy': 0.25912}, {'accuracy': 0.2182}, {'accuracy': 0.27016}, {'accuracy': 0.27644}, {'accuracy': 0.3414}, {'accuracy': 0.3892}, {'accuracy': 0.4131}, {'accuracy': 0.39111}, {'accuracy': 0.38741}, {'accuracy': 0.43316999999999994}, {'accuracy': 0.42123}, {'accuracy': 0.41041}, {'accuracy': 0.5159100000000001}, {'accuracy': 0.47085}, {'accuracy': 0.42706}, {'accuracy': 0.44741}, {'accuracy': 0.45210999999999996}, {'accuracy': 0.42727999999999994}, {'accuracy': 0.59039}, {'accuracy': 0.43765}, {'accuracy': 0.47786999999999996}, {'accuracy': 0.48334}, {'accuracy': 0.39897}, {'accuracy': 0.4432999999999999}, {'accuracy': 0.57253}, {'accuracy': 0.4636100000000001}, {'accuracy': 0.46373999999999993}, {'accuracy': 0.51823}, {'accuracy': 0.42241}, {'accuracy': 0.53067}, {'accuracy': 0.49901}, {'accuracy': 0.49571999999999994}, {'accuracy': 0.5048199999999999}, {'accuracy': 0.568}, {'accuracy': 0.5624499999999999}, {'accuracy': 0.52841}, {'accuracy': 0.563}, {'accuracy': 0.5024299999999999}, {'accuracy': 0.5990800000000001}, {'accuracy': 0.4912399999999999}, {'accuracy': 0.54701}, {'accuracy': 0.54213}, {'accuracy': 0.59975}, {'accuracy': 0.5148900000000001}, {'accuracy': 0.54722}, {'accuracy': 0.49347}, {'accuracy': 0.50437}, {'accuracy': 0.62948}, {'accuracy': 0.5562799999999999}, {'accuracy': 0.52284}, {'accuracy': 0.53466}, {'accuracy': 0.5481199999999999}, {'accuracy': 0.61525}, {'accuracy': 0.57575}, {'accuracy': 0.5300199999999999}, {'accuracy': 0.54391}, {'accuracy': 0.5729799999999999}, {'accuracy': 0.5277000000000001}, {'accuracy': 0.58276}, {'accuracy': 0.58411}, {'accuracy': 0.55811}, {'accuracy': 0.53151}, {'accuracy': 0.64862}, {'accuracy': 0.52467}, {'accuracy': 0.53643}, {'accuracy': 0.5415800000000001}, {'accuracy': 0.60381}, {'accuracy': 0.5380800000000001}, {'accuracy': 0.55983}, {'accuracy': 0.5799000000000001}, {'accuracy': 0.5125}, {'accuracy': 0.5363399999999999}, {'accuracy': 0.5221600000000002}, {'accuracy': 0.5334599999999999}, {'accuracy': 0.54539}, {'accuracy': 0.5348200000000001}, {'accuracy': 0.57795}, {'accuracy': 0.5753100000000001}, {'accuracy': 0.5571900000000001}, {'accuracy': 0.54112}, {'accuracy': 0.60236}, {'accuracy': 0.53735}, {'accuracy': 0.5829300000000001}, {'accuracy': 0.5197299999999999}, {'accuracy': 0.5988800000000001}, {'accuracy': 0.5729900000000001}, {'accuracy': 0.57693}, {'accuracy': 0.6015199999999999}, {'accuracy': 0.5816100000000001}, {'accuracy': 0.60878}, {'accuracy': 0.5950900000000001}, {'accuracy': 0.58439}, {'accuracy': 0.61129}, {'accuracy': 0.6195}, {'accuracy': 0.45376000000000005}, {'accuracy': 0.62081}, {'accuracy': 0.55592}, {'accuracy': 0.60865}, {'accuracy': 0.61256}, {'accuracy': 0.55067}, {'accuracy': 0.5791000000000001}, {'accuracy': 0.5851599999999999}, {'accuracy': 0.58521}, {'accuracy': 0.5764499999999999}, {'accuracy': 0.6154400000000001}, {'accuracy': 0.60836}, {'accuracy': 0.65966}, {'accuracy': 0.58109}, {'accuracy': 0.5838300000000001}, {'accuracy': 0.62951}, {'accuracy': 0.55097}, {'accuracy': 0.5566000000000001}, {'accuracy': 0.5806}, {'accuracy': 0.54678}, {'accuracy': 0.62199}, {'accuracy': 0.49288}, {'accuracy': 0.5152300000000001}, {'accuracy': 0.63048}, {'accuracy': 0.58286}, {'accuracy': 0.52915}, {'accuracy': 0.54298}, {'accuracy': 0.5516}, {'accuracy': 0.5342}, {'accuracy': 0.63791}, {'accuracy': 0.5432600000000001}, {'accuracy': 0.58283}, {'accuracy': 0.64839}, {'accuracy': 0.49802}, {'accuracy': 0.59843}, {'accuracy': 0.5848099999999999}, {'accuracy': 0.59722}, {'accuracy': 0.59095}, {'accuracy': 0.61921}, {'accuracy': 0.62251}, {'accuracy': 0.5357799999999999}, {'accuracy': 0.68943}, {'accuracy': 0.67556}, {'accuracy': 0.78182}, {'accuracy': 0.76549}, {'accuracy': 0.7566299999999999}, {'accuracy': 0.7832800000000001}, {'accuracy': 0.76192}, {'accuracy': 0.69434}, {'accuracy': 0.75162}, {'accuracy': 0.76208}, {'accuracy': 0.7225699999999999}, {'accuracy': 0.7496099999999999}, {'accuracy': 0.7497499999999999}, {'accuracy': 0.71615}, {'accuracy': 0.75382}, {'accuracy': 0.76841}, {'accuracy': 0.7455999999999999}, {'accuracy': 0.6715500000000001}, {'accuracy': 0.66}, {'accuracy': 0.72644}, {'accuracy': 0.7620699999999999}, {'accuracy': 0.7263599999999999}, {'accuracy': 0.75961}, {'accuracy': 0.70248}, {'accuracy': 0.74132}, {'accuracy': 0.71943}, {'accuracy': 0.7534400000000001}, {'accuracy': 0.79313}, {'accuracy': 0.7894500000000001}, {'accuracy': 0.7511300000000001}, {'accuracy': 0.7157000000000001}, {'accuracy': 0.7499399999999999}, {'accuracy': 0.74562}, {'accuracy': 0.69874}, {'accuracy': 0.7097300000000001}, {'accuracy': 0.72192}, {'accuracy': 0.7185900000000001}, {'accuracy': 0.7426200000000001}, {'accuracy': 0.72344}, {'accuracy': 0.7375}, {'accuracy': 0.69534}, {'accuracy': 0.70236}, {'accuracy': 0.66249}, {'accuracy': 0.79057}, {'accuracy': 0.7077899999999999}, {'accuracy': 0.74498}, {'accuracy': 0.7586700000000001}, {'accuracy': 0.77364}, {'accuracy': 0.72594}, {'accuracy': 0.73303}, {'accuracy': 0.74035}, {'accuracy': 0.77194}, {'accuracy': 0.751}, {'accuracy': 0.75045}, {'accuracy': 0.73605}, {'accuracy': 0.76685}, {'accuracy': 0.76558}, {'accuracy': 0.7267800000000001}, {'accuracy': 0.70896}, {'accuracy': 0.7444800000000001}, {'accuracy': 0.75685}, {'accuracy': 0.7057100000000001}, {'accuracy': 0.70261}, {'accuracy': 0.70274}, {'accuracy': 0.72975}, {'accuracy': 0.75449}, {'accuracy': 0.73035}, {'accuracy': 0.72782}, {'accuracy': 0.7282399999999999}, {'accuracy': 0.6997799999999998}, {'accuracy': 0.76051}, {'accuracy': 0.7734499999999999}, {'accuracy': 0.6891700000000001}, {'accuracy': 0.7564200000000001}, {'accuracy': 0.75572}, {'accuracy': 0.7140899999999999}, {'accuracy': 0.7678200000000001}, {'accuracy': 0.7801}, {'accuracy': 0.72714}, {'accuracy': 0.74054}, {'accuracy': 0.74467}, {'accuracy': 0.75217}, {'accuracy': 0.7144199999999999}, {'accuracy': 0.70116}, {'accuracy': 0.74588}, {'accuracy': 0.73702}, {'accuracy': 0.70823}, {'accuracy': 0.7296000000000001}, {'accuracy': 0.7321}, {'accuracy': 0.7767700000000001}, {'accuracy': 0.7491300000000001}, {'accuracy': 0.73827}, {'accuracy': 0.70201}, {'accuracy': 0.7365599999999999}, {'accuracy': 0.7399699999999999}, {'accuracy': 0.7589899999999998}, {'accuracy': 0.73715}, {'accuracy': 0.7724499999999999}, {'accuracy': 0.71697}, {'accuracy': 0.67513}, {'accuracy': 0.7411199999999999}, {'accuracy': 0.7620899999999999}, {'accuracy': 0.73178}, {'accuracy': 0.71754}, {'accuracy': 0.8041699999999998}, {'accuracy': 0.72362}, {'accuracy': 0.79837}, {'accuracy': 0.7533100000000001}, {'accuracy': 0.72558}, {'accuracy': 0.7470000000000001}, {'accuracy': 0.7093900000000001}, {'accuracy': 0.77722}, {'accuracy': 0.73482}, {'accuracy': 0.71342}, {'accuracy': 0.77038}, {'accuracy': 0.75687}, {'accuracy': 0.7125299999999999}, {'accuracy': 0.67217}, {'accuracy': 0.74527}, {'accuracy': 0.73372}, {'accuracy': 0.74316}, {'accuracy': 0.7581}, {'accuracy': 0.71791}, {'accuracy': 0.715}, {'accuracy': 0.7667200000000001}, {'accuracy': 0.72542}, {'accuracy': 0.72746}, {'accuracy': 0.7706100000000001}, {'accuracy': 0.70735}, {'accuracy': 0.7130200000000001}, {'accuracy': 0.6876599999999999}, {'accuracy': 0.69689}, {'accuracy': 0.6599600000000001}, {'accuracy': 0.70412}, {'accuracy': 0.7575299999999999}, {'accuracy': 0.7629699999999999}, {'accuracy': 0.7592}, {'accuracy': 0.77493}, {'accuracy': 0.73932}, {'accuracy': 0.7889099999999999}, {'accuracy': 0.69332}, {'accuracy': 0.6766399999999999}, {'accuracy': 0.73017}, {'accuracy': 0.76446}, {'accuracy': 0.73045}, {'accuracy': 0.7560499999999999}, {'accuracy': 0.7218899999999999}, {'accuracy': 0.7017300000000001}, {'accuracy': 0.71797}, {'accuracy': 0.7266599999999999}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "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": "ed07a60a-bb9a-4bfa-83ff-95d0ed2db218",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6523abf2-6e4e-4ba8-8073-e21670acab4f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ffc2dae3-918d-4662-a78a-e9221b770973",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b4dc2bdc-eb1f-44c5-a509-fa5052cec6fe",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a5496eb2-f1a4-4f8d-aa76-3333bf99c35f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9089bc69-32d9-46fa-b95c-57c0954054e2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7e93af2c-371d-4ffc-8dcd-50458a4df650",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bffddba6-ab54-4925-9414-078195facf76",
   "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
}
