{
 "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",
    "class Famnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(in_channels=1, out_channels=32, kernel_size=3, padding=1)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(32, 64, kernel_size=3)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(64*6*6, 600)\n",
    "        self.fc2 = nn.Linear(in_features=600, out_features=120)\n",
    "        self.fc3 = nn.Linear(in_features=120, out_features=10)\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(x.size(0), -1)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        x=self.fc3(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n",
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_FashionMNIST()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2370]\n",
      " [   1   53]\n",
      " [   2   29]\n",
      " [   3   72]\n",
      " [   4  136]\n",
      " [   5  190]\n",
      " [   6  305]\n",
      " [   7  548]\n",
      " [   8  968]\n",
      " [   9 1473]]\n",
      "[[   0 1447]\n",
      " [   1 2415]\n",
      " [   2   64]\n",
      " [   3   45]\n",
      " [   4   66]\n",
      " [   5  113]\n",
      " [   6  182]\n",
      " [   7  339]\n",
      " [   8  480]\n",
      " [   9  874]]\n",
      "[[   0  885]\n",
      " [   1 1426]\n",
      " [   2 2429]\n",
      " [   3   49]\n",
      " [   4   35]\n",
      " [   5   91]\n",
      " [   6  109]\n",
      " [   7  183]\n",
      " [   8  303]\n",
      " [   9  518]]\n",
      "[[   0  517]\n",
      " [   1  880]\n",
      " [   2 1448]\n",
      " [   3 2349]\n",
      " [   4   64]\n",
      " [   5   36]\n",
      " [   6   68]\n",
      " [   7  101]\n",
      " [   8  175]\n",
      " [   9  326]]\n",
      "[[   0  299]\n",
      " [   1  500]\n",
      " [   2  834]\n",
      " [   3 1453]\n",
      " [   4 2437]\n",
      " [   5   73]\n",
      " [   6   35]\n",
      " [   7   78]\n",
      " [   8  124]\n",
      " [   9  170]]\n",
      "[[   0  172]\n",
      " [   1  315]\n",
      " [   2  520]\n",
      " [   3  852]\n",
      " [   4 1422]\n",
      " [   5 2312]\n",
      " [   6   73]\n",
      " [   7   30]\n",
      " [   8   70]\n",
      " [   9  111]]\n",
      "[[   0  130]\n",
      " [   1  175]\n",
      " [   2  307]\n",
      " [   3  552]\n",
      " [   4  868]\n",
      " [   5 1493]\n",
      " [   6 2444]\n",
      " [   7   76]\n",
      " [   8   35]\n",
      " [   9   65]]\n",
      "[[   0   74]\n",
      " [   1  126]\n",
      " [   2  181]\n",
      " [   3  310]\n",
      " [   4  477]\n",
      " [   5  896]\n",
      " [   6 1448]\n",
      " [   7 2330]\n",
      " [   8   59]\n",
      " [   9   43]]\n",
      "[[   0   46]\n",
      " [   1   62]\n",
      " [   2  126]\n",
      " [   3  192]\n",
      " [   4  292]\n",
      " [   5  500]\n",
      " [   6  840]\n",
      " [   7 1423]\n",
      " [   8 2318]\n",
      " [   9   63]]\n",
      "[[   0   60]\n",
      " [   1   48]\n",
      " [   2   62]\n",
      " [   3  126]\n",
      " [   4  203]\n",
      " [   5  296]\n",
      " [   6  496]\n",
      " [   7  892]\n",
      " [   8 1468]\n",
      " [   9 2357]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 0, 0,  ..., 3, 0, 5])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "\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<5:\n",
    "        if tag1[z]==6:\n",
    "            tag1[z]=0\n",
    "        elif tag1[z]==0:\n",
    "            tag1[z]=6        \n",
    "        elif tag1[z]==2:\n",
    "            tag1[z]=4     \n",
    "        elif tag1[z]==4:\n",
    "            tag1[z]=2   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([6, 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",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1c1faaf3-0a08-4288-b494-d3059924b666",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is my idx\n",
      "0\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "1\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "2\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "3\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "4\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "5\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "6\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "7\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "8\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "9\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-18:07:55 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Simulation started.                                                           <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:372</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-18:07:55\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": "4e1133c982de412190b1c42e89fa099d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output()"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\n",
       "\u001b[?25h"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-21:18:49 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3370</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-21:18:49\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3370\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\">4971242020</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;36m4971242020\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.11787}, {'accuracy': 0.17573000000000003}, {'accuracy': 0.20512999999999998}, {'accuracy': 0.25008}, {'accuracy': 0.24386000000000002}, {'accuracy': 0.27566}, {'accuracy': 0.27491000000000004}, {'accuracy': 0.29521000000000003}, {'accuracy': 0.35625}, {'accuracy': 0.33623000000000003}, {'accuracy': 0.34987}, {'accuracy': 0.33299999999999996}, {'accuracy': 0.31985}, {'accuracy': 0.35114}, {'accuracy': 0.37254999999999994}, {'accuracy': 0.34615}, {'accuracy': 0.32817}, {'accuracy': 0.37434}, {'accuracy': 0.34219000000000005}, {'accuracy': 0.36715}, {'accuracy': 0.36401000000000006}, {'accuracy': 0.34073000000000003}, {'accuracy': 0.37758}, {'accuracy': 0.40968}, {'accuracy': 0.43348000000000003}, {'accuracy': 0.38858000000000004}, {'accuracy': 0.39074000000000003}, {'accuracy': 0.43269}, {'accuracy': 0.46172}, {'accuracy': 0.42279}, {'accuracy': 0.43061}, {'accuracy': 0.48285}, {'accuracy': 0.45105000000000006}, {'accuracy': 0.4696999999999999}, {'accuracy': 0.47544000000000003}, {'accuracy': 0.5059199999999999}, {'accuracy': 0.5182499999999999}, {'accuracy': 0.48650000000000004}, {'accuracy': 0.46759000000000006}, {'accuracy': 0.4985700000000001}, {'accuracy': 0.53781}, {'accuracy': 0.51567}, {'accuracy': 0.51227}, {'accuracy': 0.55204}, {'accuracy': 0.55952}, {'accuracy': 0.5401299999999999}, {'accuracy': 0.55787}, {'accuracy': 0.59969}, {'accuracy': 0.5504}, {'accuracy': 0.60262}, {'accuracy': 0.58247}, {'accuracy': 0.5466900000000001}, {'accuracy': 0.57779}, {'accuracy': 0.58405}, {'accuracy': 0.5859}, {'accuracy': 0.6021799999999999}, {'accuracy': 0.5877}, {'accuracy': 0.56509}, {'accuracy': 0.62377}, {'accuracy': 0.5770000000000001}, {'accuracy': 0.5701}, {'accuracy': 0.557}, {'accuracy': 0.60219}, {'accuracy': 0.588}, {'accuracy': 0.57311}, {'accuracy': 0.61659}, {'accuracy': 0.58677}, {'accuracy': 0.5926899999999999}, {'accuracy': 0.57778}, {'accuracy': 0.55799}, {'accuracy': 0.58393}, {'accuracy': 0.57988}, {'accuracy': 0.5697400000000001}, {'accuracy': 0.6056700000000002}, {'accuracy': 0.6030399999999999}, {'accuracy': 0.5825400000000001}, {'accuracy': 0.58511}, {'accuracy': 0.5869500000000001}, {'accuracy': 0.59727}, {'accuracy': 0.5798099999999999}, {'accuracy': 0.56826}, {'accuracy': 0.5986400000000001}, {'accuracy': 0.60169}, {'accuracy': 0.6292699999999999}, {'accuracy': 0.6219899999999999}, {'accuracy': 0.6087400000000001}, {'accuracy': 0.6049800000000001}, {'accuracy': 0.6040300000000001}, {'accuracy': 0.62172}, {'accuracy': 0.62069}, {'accuracy': 0.62873}, {'accuracy': 0.61209}, {'accuracy': 0.58487}, {'accuracy': 0.62736}, {'accuracy': 0.6154999999999999}, {'accuracy': 0.61954}, {'accuracy': 0.63609}, {'accuracy': 0.63239}, {'accuracy': 0.66785}, {'accuracy': 0.61844}, {'accuracy': 0.6082299999999999}, {'accuracy': 0.62889}, {'accuracy': 0.6056400000000001}, {'accuracy': 0.6311699999999999}, {'accuracy': 0.6327299999999999}, {'accuracy': 0.5862100000000001}, {'accuracy': 0.61728}, {'accuracy': 0.64543}, {'accuracy': 0.6098100000000001}, {'accuracy': 0.5814700000000002}, {'accuracy': 0.65436}, {'accuracy': 0.6202300000000001}, {'accuracy': 0.59839}, {'accuracy': 0.63077}, {'accuracy': 0.63673}, {'accuracy': 0.6065599999999999}, {'accuracy': 0.65466}, {'accuracy': 0.6033799999999998}, {'accuracy': 0.59943}, {'accuracy': 0.64072}, {'accuracy': 0.6313899999999999}, {'accuracy': 0.61219}, {'accuracy': 0.6051399999999999}, {'accuracy': 0.63017}, {'accuracy': 0.6380999999999999}, {'accuracy': 0.62755}, {'accuracy': 0.62184}, {'accuracy': 0.6072500000000001}, {'accuracy': 0.61213}, {'accuracy': 0.6392100000000001}, {'accuracy': 0.6262700000000001}, {'accuracy': 0.63912}, {'accuracy': 0.6401300000000001}, {'accuracy': 0.60361}, {'accuracy': 0.6553100000000001}, {'accuracy': 0.64449}, {'accuracy': 0.6389699999999999}, {'accuracy': 0.64346}, {'accuracy': 0.6418900000000001}, {'accuracy': 0.59499}, {'accuracy': 0.62021}, {'accuracy': 0.65586}, {'accuracy': 0.60008}, {'accuracy': 0.6148100000000001}, {'accuracy': 0.63274}, {'accuracy': 0.65882}, {'accuracy': 0.63625}, {'accuracy': 0.6201}, {'accuracy': 0.6083700000000001}, {'accuracy': 0.63188}, {'accuracy': 0.64451}, {'accuracy': 0.6025400000000001}, {'accuracy': 0.62588}, {'accuracy': 0.64395}, {'accuracy': 0.63428}, {'accuracy': 0.61584}, {'accuracy': 0.6189}, {'accuracy': 0.6111199999999999}, {'accuracy': 0.6619499999999999}, {'accuracy': 0.6673}, {'accuracy': 0.6442399999999999}, {'accuracy': 0.65276}, {'accuracy': 0.6305}, {'accuracy': 0.60046}, {'accuracy': 0.6336999999999999}, {'accuracy': 0.60616}, {'accuracy': 0.64509}, {'accuracy': 0.63342}, {'accuracy': 0.6298299999999999}, {'accuracy': 0.63473}, {'accuracy': 0.6328000000000001}, {'accuracy': 0.6310100000000001}, {'accuracy': 0.66172}, {'accuracy': 0.6404099999999999}, {'accuracy': 0.6328799999999999}, {'accuracy': 0.6452399999999999}, {'accuracy': 0.6233500000000001}, {'accuracy': 0.65049}, {'accuracy': 0.65718}, {'accuracy': 0.5919500000000001}, {'accuracy': 0.64096}, {'accuracy': 0.61889}, {'accuracy': 0.6343300000000001}, {'accuracy': 0.59453}, {'accuracy': 0.65474}, {'accuracy': 0.63574}, {'accuracy': 0.65582}, {'accuracy': 0.62533}, {'accuracy': 0.63647}, {'accuracy': 0.6352599999999999}, {'accuracy': 0.62893}, {'accuracy': 0.6390800000000001}, {'accuracy': 0.64442}, {'accuracy': 0.65675}, {'accuracy': 0.60676}, {'accuracy': 0.64184}, {'accuracy': 0.6147400000000001}, {'accuracy': 0.63834}, {'accuracy': 0.6452699999999999}, {'accuracy': 0.68029}, {'accuracy': 0.6544599999999999}, {'accuracy': 0.61044}, {'accuracy': 0.6608700000000001}, {'accuracy': 0.66731}, {'accuracy': 0.6644699999999999}, {'accuracy': 0.67268}, {'accuracy': 0.6658199999999999}, {'accuracy': 0.6694499999999999}, {'accuracy': 0.66333}, {'accuracy': 0.65816}, {'accuracy': 0.6589200000000001}, {'accuracy': 0.66114}, {'accuracy': 0.67205}, {'accuracy': 0.6660699999999999}, {'accuracy': 0.66603}, {'accuracy': 0.65746}, {'accuracy': 0.66998}, {'accuracy': 0.6561899999999999}, {'accuracy': 0.6576099999999999}, {'accuracy': 0.6672800000000001}, {'accuracy': 0.6613900000000001}, {'accuracy': 0.66024}, {'accuracy': 0.6694100000000001}, {'accuracy': 0.6693299999999999}, {'accuracy': 0.6674399999999999}, {'accuracy': 0.66724}, {'accuracy': 0.66695}, {'accuracy': 0.6646200000000001}, {'accuracy': 0.6667000000000001}, {'accuracy': 0.6597100000000001}, {'accuracy': 0.65952}, {'accuracy': 0.6678}, {'accuracy': 0.6647299999999999}, {'accuracy': 0.6669099999999999}, {'accuracy': 0.6690800000000001}, {'accuracy': 0.6594399999999999}, {'accuracy': 0.67836}, {'accuracy': 0.6656799999999999}, {'accuracy': 0.66741}, {'accuracy': 0.6597899999999999}, {'accuracy': 0.66608}, {'accuracy': 0.6664999999999999}, {'accuracy': 0.65829}, {'accuracy': 0.66641}, {'accuracy': 0.66957}, {'accuracy': 0.66903}, {'accuracy': 0.6714}, {'accuracy': 0.66518}, {'accuracy': 0.66804}, {'accuracy': 0.66751}, {'accuracy': 0.66486}, {'accuracy': 0.67107}, {'accuracy': 0.66379}, {'accuracy': 0.67035}, {'accuracy': 0.6685800000000001}, {'accuracy': 0.6692400000000001}, {'accuracy': 0.66699}, {'accuracy': 0.67297}, {'accuracy': 0.66807}, {'accuracy': 0.67322}, {'accuracy': 0.67222}, {'accuracy': 0.662}, {'accuracy': 0.6671500000000001}, {'accuracy': 0.66537}, {'accuracy': 0.67379}, {'accuracy': 0.6683000000000001}, {'accuracy': 0.6743699999999999}, {'accuracy': 0.65855}, {'accuracy': 0.66547}, {'accuracy': 0.6688500000000001}, {'accuracy': 0.67059}, {'accuracy': 0.6700900000000001}, {'accuracy': 0.6669599999999999}, {'accuracy': 0.6722400000000001}, {'accuracy': 0.67742}, {'accuracy': 0.6620299999999999}, {'accuracy': 0.67054}, {'accuracy': 0.6588700000000001}, {'accuracy': 0.67074}, {'accuracy': 0.6692899999999999}, {'accuracy': 0.66463}, {'accuracy': 0.6700900000000001}, {'accuracy': 0.669}, {'accuracy': 0.6747000000000001}, {'accuracy': 0.6648900000000001}, {'accuracy': 0.6717299999999999}, {'accuracy': 0.6678099999999999}, {'accuracy': 0.66577}, {'accuracy': 0.66455}, {'accuracy': 0.67365}, {'accuracy': 0.6708700000000001}, {'accuracy': 0.6683800000000001}, {'accuracy': 0.66663}, {'accuracy': 0.6728400000000001}, {'accuracy': 0.6707500000000001}, {'accuracy': 0.67161}, {'accuracy': 0.6739}, {'accuracy': 0.66807}, {'accuracy': 0.66846}, {'accuracy': 0.66722}]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=Famnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "add8dd82-4e9d-45dc-b09e-b09b584c206c",
   "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.67</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:171</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.67\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m171\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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yy5DZGQkFi9eLJ2zePFi9OvXD926dQMAHD58GIIg4Omnn0Z8fLzsa9asWQCAoqIi2ft06tSp3nvX1tZi5syZUs9LXFwc4uPjUVFRgcrKyrP85E1z6NAhLF26tN74c3JyZON/4IEH0K1bN1x++eXo0KED7r77bixduvSc3z8kJETqPfIcU2VlJRISEuqNq6amRhrTiBEjcOONN+KZZ55BXFwcrr32WnzwwQewWCznPK4zefnll7F7926kpaVh0KBB+Oc//4mjR48G/H2JWhp7bohaocjISCQnJ2Pnzp2Nnrdz506kpqYiIiICAKDVanHdddfh66+/xttvv43CwkKsXbsWL7zwgvQcseH2sccew7hx43y+bmZmpuxnzyyN6K9//Ss++OADPPLIIxgyZAgiIyOhUChw66231mvq9Ten04lLL70Uf//7330+LgZyCQkJ2L59O5YtW4aff/4ZP//8Mz744ANMnDgRH3744Vm/v1arhVIp/7eh0+lEQkICPv30U5/PEZvCFQoFlixZgj///BPff/89li1bhrvvvhuvvvoq/vzzTxgMhgYX5XM4HGc9ZgC45ZZbMGzYMHz99df45Zdf8Morr+Cll17CV199hcsvv/ycXpuoNWFwQ9RKXXXVVViwYAHWrFmDoUOH1nv8jz/+QG5uLu69917Z8fHjx+PDDz/EihUrsG/fPgiCIJWkAEjTxtVqtZTpOBtLlizBpEmT8Oqrr0rHzGYzKioqzvo1vTV0k+/SpQtqamqaNH6NRoOrr74aV199NZxOJx544AHMnz8fTz/9NDIzM/22um+XLl3w66+/4pJLLvEZDHq76KKLcNFFF+H555/HZ599httvvx2LFi3ClClTEB0dDQD1ruXx48ebNJbGPlNycjIeeOABPPDAAygqKsKAAQPw/PPPM7ihNoVlKaJW6vHHH0doaCjuvfdelJaWyh4rKyvDfffdB71ej8cff1z2WE5ODmJiYrB48WIsXrwYgwYNkpWVEhISMHLkSMyfPx/5+fn13re4uLhJ41OpVBAEQXbsjTfeOOfsgqewsDCfwdItt9yC9evXY9myZfUeq6iogN1uB4B6102pVKJv374AIJWBxPVpzjUou+WWW+BwOPDcc8/Ve8xut0uvX15eXu+69evXTzamjh07QqVSSb1DorfffrtJY/F13RwOR71yYUJCAlJSUlqk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Tz/91OwxP/nkk3j11VfRv39/6HQ6mM1mZGdn44knnkBERAR+/PFH3HnnnejSpQsGDRoEAJgxYwYWLFiA1157DUOHDkV+fj72798PAJgyZQqmTZuGV199FVqtFgDwySefIDU1FaNHj272+JqKd2E/sTqccDgFAIBey8wNEVFrUGtzoOfMZUF5773PjmvWP3ZvvPFG2c/vv/8+4uPjsXfvXqxbtw7FxcXYtGkTYmJiAACZmZnSuc8//zxuvfVWPPPMM9KxrKysZo/5kUcewQ033CA79thjj0nf//Wvf8WyZcvwxRdfYNCgQaiursbrr7+ON998E5MmTQIAdOnSBUOHDgUA3HDDDZg2bRq+/fZb3HLLLQCAhQsX4q677groAossS/mJyVL3LwM9e26IiKiZDh06hAkTJqBz586IiIhARkYGACAvLw/bt29H//79pcDG2/bt2zFmzJhzHsPAgQNlPzscDjz33HPo06cPYmJiYDAYsGzZMuTl5QEA9u3bB4vF0uB763Q63HnnnXj//fcBAFu3bsXu3btx1113nfNYG8PMjZ+IJSmNSokQFWNGIqLWIFStwt5nxwXtvZvj6quvRseOHbFgwQKkpKTA6XSid+/esFqtCA0Nbfy9zvC4QqGAIAiyY74ahsPCwmQ/v/LKK3j99dcxd+5c9OnTB2FhYXjkkUdgtVqb9L6AqzTVr18/nDx5Eh988AFGjx6Njh07nvF554J3YT+plbZeYNaGiKi1UCgU0GtCgvLVnLJLaWkpDhw4gH/84x8YM2YMevTogfLycunxvn37Yvv27SgrK/P5/L59+zbaoBsfH4/8/Hzp50OHDjVpc9G1a9fi2muvxR133IGsrCx07twZBw8elB7v2rUrQkNDG33vPn36YODAgViwYAE+++wz3H333Wd833PF4MZPTJwpRUREZyk6OhqxsbF49913cfjwYfz222+YPn269PiECROQlJSE6667DmvXrsXRo0fxv//9D+vXrwcAzJo1C59//jlmzZqFffv2YdeuXXjppZek548ePRpvvvkmtm3bhs2bN+O+++6DWq0+47i6du2K5cuXY926ddi3bx/uvfdeFBYWSo/rdDo88cQT+Pvf/46PPvoIR44cwZ9//on33ntP9jpTpkzBiy++CEEQZLO4AoXBjZ/YHE6EaVQwaFnpIyKi5lEqlVi0aBG2bNmC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iy++iKeffhp79+7FZ599hsTEREyZMgWfffYZLBaLdO4nn3yC1NRUjB49GgAwceJEfP755/jPf/6Dffv2Yf78+TAYDD7f58iRI7jssstw4403YufOnVi8eDHWrFlTL4AiovMPN84kolajuroa8fHxePPNNzFlyhTZY2azGSkpKZg3bx5uueUWAEBWVhZuuOEGzJo1CwcPHkT37t2xfPly5OTk1HvtVatWYdSoUSgvL0dUVBSmTJkClUqF+fPnS+esWbMGI0aMgNFohE6nC+yHJaKAYeaGiFqNffv2wWKxYMyYMfUe0+l0uPPOO/H+++8DALZu3Yrdu3fjrrvuAgBs374dKpUKI0aMaNJ77dixAwsXLoTBYJC+xo0bB6fTiWPHjvntMxFRywsJ9gCIiEShoaGNPj5lyhT069cPJ0+exAcffIDRo0ejY8eOTXqut5qaGtx777146KGH6j2Wnp7erNciotaFmRsiajW6du2K0NBQqUHYW58+fTBw4EAsWLAAn332Ge6++27ZY06nE6tXr27Sew0YMAB79+5FZmZmvS+NRuOXz0NEwcHghohaDZ1OhyeeeAJ///vf8dFHH+HIkSP4888/ZTOepkyZghdffBGCIOD666+XjmdkZGDSpEm4++678c033+DYsWNYtWoVvvjiC5/v9cQTT2DdunWYNm0atm/fjkOHDuHbb79lQzFRG8Dghohalaeffhp/+9vfMHPmTPTo0QPjx49HUVGR9PiECRMQEhKCCRMm1Gv6feedd3DTTTfhgQcewAUXXICpU6c2OLW7b9++WL16NQ4ePIhhw4ahf//+mDlzJlJSUgL6+Ygo8DhbiojOK7m5uejSpQs2bdqEAQMGBHs4RNQKMbghovOCzWZDaWkpHnvsMRw7dgxr164N9pCIqJViWYqIzgtr165FcnIyNm3ahHnz5gV7OETUijFzQ0RERG0KMzdERETUpjC4ISIiojaFwQ0RERG1KQxuiIiIqE1hcENERERtCoMbIiIialMY3BAREVGbwuCGiIiI2hQGN0RERNSm/D92yPf+WkaufAAAAABJRU5ErkJggg==\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.11787}, {'accuracy': 0.17573000000000003}, {'accuracy': 0.20512999999999998}, {'accuracy': 0.25008}, {'accuracy': 0.24386000000000002}, {'accuracy': 0.27566}, {'accuracy': 0.27491000000000004}, {'accuracy': 0.29521000000000003}, {'accuracy': 0.35625}, {'accuracy': 0.33623000000000003}, {'accuracy': 0.34987}, {'accuracy': 0.33299999999999996}, {'accuracy': 0.31985}, {'accuracy': 0.35114}, {'accuracy': 0.37254999999999994}, {'accuracy': 0.34615}, {'accuracy': 0.32817}, {'accuracy': 0.37434}, {'accuracy': 0.34219000000000005}, {'accuracy': 0.36715}, {'accuracy': 0.36401000000000006}, {'accuracy': 0.34073000000000003}, {'accuracy': 0.37758}, {'accuracy': 0.40968}, {'accuracy': 0.43348000000000003}, {'accuracy': 0.38858000000000004}, {'accuracy': 0.39074000000000003}, {'accuracy': 0.43269}, {'accuracy': 0.46172}, {'accuracy': 0.42279}, {'accuracy': 0.43061}, {'accuracy': 0.48285}, {'accuracy': 0.45105000000000006}, {'accuracy': 0.4696999999999999}, {'accuracy': 0.47544000000000003}, {'accuracy': 0.5059199999999999}, {'accuracy': 0.5182499999999999}, {'accuracy': 0.48650000000000004}, {'accuracy': 0.46759000000000006}, {'accuracy': 0.4985700000000001}, {'accuracy': 0.53781}, {'accuracy': 0.51567}, {'accuracy': 0.51227}, {'accuracy': 0.55204}, {'accuracy': 0.55952}, {'accuracy': 0.5401299999999999}, {'accuracy': 0.55787}, {'accuracy': 0.59969}, {'accuracy': 0.5504}, {'accuracy': 0.60262}, {'accuracy': 0.58247}, {'accuracy': 0.5466900000000001}, {'accuracy': 0.57779}, {'accuracy': 0.58405}, {'accuracy': 0.5859}, {'accuracy': 0.6021799999999999}, {'accuracy': 0.5877}, {'accuracy': 0.56509}, {'accuracy': 0.62377}, {'accuracy': 0.5770000000000001}, {'accuracy': 0.5701}, {'accuracy': 0.557}, {'accuracy': 0.60219}, {'accuracy': 0.588}, {'accuracy': 0.57311}, {'accuracy': 0.61659}, {'accuracy': 0.58677}, {'accuracy': 0.5926899999999999}, {'accuracy': 0.57778}, {'accuracy': 0.55799}, {'accuracy': 0.58393}, {'accuracy': 0.57988}, {'accuracy': 0.5697400000000001}, {'accuracy': 0.6056700000000002}, {'accuracy': 0.6030399999999999}, {'accuracy': 0.5825400000000001}, {'accuracy': 0.58511}, {'accuracy': 0.5869500000000001}, {'accuracy': 0.59727}, {'accuracy': 0.5798099999999999}, {'accuracy': 0.56826}, {'accuracy': 0.5986400000000001}, {'accuracy': 0.60169}, {'accuracy': 0.6292699999999999}, {'accuracy': 0.6219899999999999}, {'accuracy': 0.6087400000000001}, {'accuracy': 0.6049800000000001}, {'accuracy': 0.6040300000000001}, {'accuracy': 0.62172}, {'accuracy': 0.62069}, {'accuracy': 0.62873}, {'accuracy': 0.61209}, {'accuracy': 0.58487}, {'accuracy': 0.62736}, {'accuracy': 0.6154999999999999}, {'accuracy': 0.61954}, {'accuracy': 0.63609}, {'accuracy': 0.63239}, {'accuracy': 0.66785}, {'accuracy': 0.61844}, {'accuracy': 0.6082299999999999}, {'accuracy': 0.62889}, {'accuracy': 0.6056400000000001}, {'accuracy': 0.6311699999999999}, {'accuracy': 0.6327299999999999}, {'accuracy': 0.5862100000000001}, {'accuracy': 0.61728}, {'accuracy': 0.64543}, {'accuracy': 0.6098100000000001}, {'accuracy': 0.5814700000000002}, {'accuracy': 0.65436}, {'accuracy': 0.6202300000000001}, {'accuracy': 0.59839}, {'accuracy': 0.63077}, {'accuracy': 0.63673}, {'accuracy': 0.6065599999999999}, {'accuracy': 0.65466}, {'accuracy': 0.6033799999999998}, {'accuracy': 0.59943}, {'accuracy': 0.64072}, {'accuracy': 0.6313899999999999}, {'accuracy': 0.61219}, {'accuracy': 0.6051399999999999}, {'accuracy': 0.63017}, {'accuracy': 0.6380999999999999}, {'accuracy': 0.62755}, {'accuracy': 0.62184}, {'accuracy': 0.6072500000000001}, {'accuracy': 0.61213}, {'accuracy': 0.6392100000000001}, {'accuracy': 0.6262700000000001}, {'accuracy': 0.63912}, {'accuracy': 0.6401300000000001}, {'accuracy': 0.60361}, {'accuracy': 0.6553100000000001}, {'accuracy': 0.64449}, {'accuracy': 0.6389699999999999}, {'accuracy': 0.64346}, {'accuracy': 0.6418900000000001}, {'accuracy': 0.59499}, {'accuracy': 0.62021}, {'accuracy': 0.65586}, {'accuracy': 0.60008}, {'accuracy': 0.6148100000000001}, {'accuracy': 0.63274}, {'accuracy': 0.65882}, {'accuracy': 0.63625}, {'accuracy': 0.6201}, {'accuracy': 0.6083700000000001}, {'accuracy': 0.63188}, {'accuracy': 0.64451}, {'accuracy': 0.6025400000000001}, {'accuracy': 0.62588}, {'accuracy': 0.64395}, {'accuracy': 0.63428}, {'accuracy': 0.61584}, {'accuracy': 0.6189}, {'accuracy': 0.6111199999999999}, {'accuracy': 0.6619499999999999}, {'accuracy': 0.6673}, {'accuracy': 0.6442399999999999}, {'accuracy': 0.65276}, {'accuracy': 0.6305}, {'accuracy': 0.60046}, {'accuracy': 0.6336999999999999}, {'accuracy': 0.60616}, {'accuracy': 0.64509}, {'accuracy': 0.63342}, {'accuracy': 0.6298299999999999}, {'accuracy': 0.63473}, {'accuracy': 0.6328000000000001}, {'accuracy': 0.6310100000000001}, {'accuracy': 0.66172}, {'accuracy': 0.6404099999999999}, {'accuracy': 0.6328799999999999}, {'accuracy': 0.6452399999999999}, {'accuracy': 0.6233500000000001}, {'accuracy': 0.65049}, {'accuracy': 0.65718}, {'accuracy': 0.5919500000000001}, {'accuracy': 0.64096}, {'accuracy': 0.61889}, {'accuracy': 0.6343300000000001}, {'accuracy': 0.59453}, {'accuracy': 0.65474}, {'accuracy': 0.63574}, {'accuracy': 0.65582}, {'accuracy': 0.62533}, {'accuracy': 0.63647}, {'accuracy': 0.6352599999999999}, {'accuracy': 0.62893}, {'accuracy': 0.6390800000000001}, {'accuracy': 0.64442}, {'accuracy': 0.65675}, {'accuracy': 0.60676}, {'accuracy': 0.64184}, {'accuracy': 0.6147400000000001}, {'accuracy': 0.63834}, {'accuracy': 0.6452699999999999}, {'accuracy': 0.68029}, {'accuracy': 0.6544599999999999}, {'accuracy': 0.61044}, {'accuracy': 0.6608700000000001}, {'accuracy': 0.66731}, {'accuracy': 0.6644699999999999}, {'accuracy': 0.67268}, {'accuracy': 0.6658199999999999}, {'accuracy': 0.6694499999999999}, {'accuracy': 0.66333}, {'accuracy': 0.65816}, {'accuracy': 0.6589200000000001}, {'accuracy': 0.66114}, {'accuracy': 0.67205}, {'accuracy': 0.6660699999999999}, {'accuracy': 0.66603}, {'accuracy': 0.65746}, {'accuracy': 0.66998}, {'accuracy': 0.6561899999999999}, {'accuracy': 0.6576099999999999}, {'accuracy': 0.6672800000000001}, {'accuracy': 0.6613900000000001}, {'accuracy': 0.66024}, {'accuracy': 0.6694100000000001}, {'accuracy': 0.6693299999999999}, {'accuracy': 0.6674399999999999}, {'accuracy': 0.66724}, {'accuracy': 0.66695}, {'accuracy': 0.6646200000000001}, {'accuracy': 0.6667000000000001}, {'accuracy': 0.6597100000000001}, {'accuracy': 0.65952}, {'accuracy': 0.6678}, {'accuracy': 0.6647299999999999}, {'accuracy': 0.6669099999999999}, {'accuracy': 0.6690800000000001}, {'accuracy': 0.6594399999999999}, {'accuracy': 0.67836}, {'accuracy': 0.6656799999999999}, {'accuracy': 0.66741}, {'accuracy': 0.6597899999999999}, {'accuracy': 0.66608}, {'accuracy': 0.6664999999999999}, {'accuracy': 0.65829}, {'accuracy': 0.66641}, {'accuracy': 0.66957}, {'accuracy': 0.66903}, {'accuracy': 0.6714}, {'accuracy': 0.66518}, {'accuracy': 0.66804}, {'accuracy': 0.66751}, {'accuracy': 0.66486}, {'accuracy': 0.67107}, {'accuracy': 0.66379}, {'accuracy': 0.67035}, {'accuracy': 0.6685800000000001}, {'accuracy': 0.6692400000000001}, {'accuracy': 0.66699}, {'accuracy': 0.67297}, {'accuracy': 0.66807}, {'accuracy': 0.67322}, {'accuracy': 0.67222}, {'accuracy': 0.662}, {'accuracy': 0.6671500000000001}, {'accuracy': 0.66537}, {'accuracy': 0.67379}, {'accuracy': 0.6683000000000001}, {'accuracy': 0.6743699999999999}, {'accuracy': 0.65855}, {'accuracy': 0.66547}, {'accuracy': 0.6688500000000001}, {'accuracy': 0.67059}, {'accuracy': 0.6700900000000001}, {'accuracy': 0.6669599999999999}, {'accuracy': 0.6722400000000001}, {'accuracy': 0.67742}, {'accuracy': 0.6620299999999999}, {'accuracy': 0.67054}, {'accuracy': 0.6588700000000001}, {'accuracy': 0.67074}, {'accuracy': 0.6692899999999999}, {'accuracy': 0.66463}, {'accuracy': 0.6700900000000001}, {'accuracy': 0.669}, {'accuracy': 0.6747000000000001}, {'accuracy': 0.6648900000000001}, {'accuracy': 0.6717299999999999}, {'accuracy': 0.6678099999999999}, {'accuracy': 0.66577}, {'accuracy': 0.66455}, {'accuracy': 0.67365}, {'accuracy': 0.6708700000000001}, {'accuracy': 0.6683800000000001}, {'accuracy': 0.66663}, {'accuracy': 0.6728400000000001}, {'accuracy': 0.6707500000000001}, {'accuracy': 0.67161}, {'accuracy': 0.6739}, {'accuracy': 0.66807}, {'accuracy': 0.66846}, {'accuracy': 0.66722}]\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": "2f2edf35-501e-4e5f-8625-18550720b217",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "315fe4ce-abe7-45a2-a308-ca8a1c93e5a4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "08bce72d-9f8a-48ea-8d1e-aa05df93828f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d4a98c76-5314-45fa-b138-b590b4c43448",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d132cfef-f45a-413b-aa96-13223ad46f7f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c0567fdb-df88-44f4-beb1-d312ecc61cda",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c936f45a-963f-4dd9-ae64-673682d54ee1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a6fc8e28-8453-4732-98e0-050bd9387716",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d47049ab-17c9-4cc2-8afd-84f69ab73c0d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fca4afcc-8885-4456-8cf8-676e02fe5d8d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cadbc4df-5eba-4f08-be66-cab624fe8ee1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "09e94e95-0d48-4dff-8cea-559874447fb3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5b310df7-781d-4a38-ba1f-538cae7f5221",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a31d3e36-bbee-4a3c-b7f8-a4a1cda89097",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be1fac52-22c9-45d4-a57f-bd0d20fcf531",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b6e7b46c-4c8a-4a6b-aa3a-262e399a1315",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4be94add-1eb5-4bf5-a645-9a27a3fc2925",
   "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
}
