{
 "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 2406]\n",
      " [   1   72]\n",
      " [   2   40]\n",
      " [   3   61]\n",
      " [   4  114]\n",
      " [   5  171]\n",
      " [   6  328]\n",
      " [   7  566]\n",
      " [   8  880]\n",
      " [   9 1457]]\n",
      "[[   0 1481]\n",
      " [   1 2412]\n",
      " [   2   63]\n",
      " [   3   42]\n",
      " [   4   69]\n",
      " [   5  117]\n",
      " [   6  179]\n",
      " [   7  336]\n",
      " [   8  532]\n",
      " [   9  886]]\n",
      "[[   0  833]\n",
      " [   1 1398]\n",
      " [   2 2388]\n",
      " [   3   46]\n",
      " [   4   34]\n",
      " [   5   64]\n",
      " [   6  114]\n",
      " [   7  220]\n",
      " [   8  306]\n",
      " [   9  516]]\n",
      "[[   0  517]\n",
      " [   1  857]\n",
      " [   2 1491]\n",
      " [   3 2402]\n",
      " [   4   58]\n",
      " [   5   33]\n",
      " [   6   60]\n",
      " [   7  123]\n",
      " [   8  186]\n",
      " [   9  313]]\n",
      "[[   0  325]\n",
      " [   1  542]\n",
      " [   2  841]\n",
      " [   3 1530]\n",
      " [   4 2371]\n",
      " [   5   58]\n",
      " [   6   47]\n",
      " [   7   68]\n",
      " [   8  108]\n",
      " [   9  178]]\n",
      "[[   0  185]\n",
      " [   1  317]\n",
      " [   2  511]\n",
      " [   3  848]\n",
      " [   4 1467]\n",
      " [   5 2345]\n",
      " [   6   58]\n",
      " [   7   34]\n",
      " [   8   68]\n",
      " [   9  127]]\n",
      "[[   0   91]\n",
      " [   1  179]\n",
      " [   2  288]\n",
      " [   3  510]\n",
      " [   4  906]\n",
      " [   5 1482]\n",
      " [   6 2365]\n",
      " [   7   60]\n",
      " [   8   42]\n",
      " [   9   70]]\n",
      "[[   0   58]\n",
      " [   1  124]\n",
      " [   2  190]\n",
      " [   3  263]\n",
      " [   4  503]\n",
      " [   5  897]\n",
      " [   6 1424]\n",
      " [   7 2360]\n",
      " [   8   66]\n",
      " [   9   50]]\n",
      "[[   0   44]\n",
      " [   1   56]\n",
      " [   2  124]\n",
      " [   3  193]\n",
      " [   4  300]\n",
      " [   5  500]\n",
      " [   6  875]\n",
      " [   7 1427]\n",
      " [   8 2409]\n",
      " [   9   53]]\n",
      "[[   0   60]\n",
      " [   1   43]\n",
      " [   2   64]\n",
      " [   3  105]\n",
      " [   4  178]\n",
      " [   5  333]\n",
      " [   6  550]\n",
      " [   7  806]\n",
      " [   8 1403]\n",
      " [   9 2350]]\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",
    "\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-20:33:32 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Simulation started.                                                           <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:372</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-20:33:32\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Simulation started.                                                           \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m372\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "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": "204a1ed0a7484fdaa6d0bdff2717b215",
       "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-22:45:33 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3302</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-22:45:33\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3302\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\">4870932092</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;36m4870932092\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.15362}, {'accuracy': 0.12902}, {'accuracy': 0.19319000000000003}, {'accuracy': 0.16394}, {'accuracy': 0.18245}, {'accuracy': 0.18237}, {'accuracy': 0.15202}, {'accuracy': 0.13820000000000002}, {'accuracy': 0.1952}, {'accuracy': 0.15471}, {'accuracy': 0.17687999999999998}, {'accuracy': 0.14272}, {'accuracy': 0.17407}, {'accuracy': 0.15336}, {'accuracy': 0.14506999999999998}, {'accuracy': 0.16731000000000001}, {'accuracy': 0.18916000000000002}, {'accuracy': 0.17105}, {'accuracy': 0.14516}, {'accuracy': 0.14459}, {'accuracy': 0.15655000000000002}, {'accuracy': 0.13976}, {'accuracy': 0.15276000000000003}, {'accuracy': 0.16039}, {'accuracy': 0.15363}, {'accuracy': 0.11804999999999999}, {'accuracy': 0.15947}, {'accuracy': 0.15444999999999998}, {'accuracy': 0.14592}, {'accuracy': 0.19333999999999998}, {'accuracy': 0.17211}, {'accuracy': 0.15867000000000003}, {'accuracy': 0.16060000000000002}, {'accuracy': 0.1317}, {'accuracy': 0.14696}, {'accuracy': 0.14789000000000002}, {'accuracy': 0.19438000000000002}, {'accuracy': 0.14302}, {'accuracy': 0.18011000000000005}, {'accuracy': 0.16815}, {'accuracy': 0.17536000000000002}, {'accuracy': 0.18863999999999997}, {'accuracy': 0.15056999999999998}, {'accuracy': 0.15522}, {'accuracy': 0.11205000000000001}, {'accuracy': 0.15286000000000002}, {'accuracy': 0.17075}, {'accuracy': 0.18048}, {'accuracy': 0.17931999999999998}, {'accuracy': 0.19149}, {'accuracy': 0.17992000000000002}, {'accuracy': 0.18918000000000001}, {'accuracy': 0.22082000000000002}, {'accuracy': 0.18064}, {'accuracy': 0.17572000000000002}, {'accuracy': 0.19478}, {'accuracy': 0.18174000000000004}, {'accuracy': 0.17727}, {'accuracy': 0.18358999999999998}, {'accuracy': 0.21605999999999997}, {'accuracy': 0.22213000000000002}, {'accuracy': 0.21703999999999998}, {'accuracy': 0.18893}, {'accuracy': 0.19887000000000002}, {'accuracy': 0.20722999999999997}, {'accuracy': 0.18056}, {'accuracy': 0.20421999999999998}, {'accuracy': 0.18948}, {'accuracy': 0.20561000000000001}, {'accuracy': 0.22389}, {'accuracy': 0.27714000000000005}, {'accuracy': 0.19286999999999999}, {'accuracy': 0.23564000000000002}, {'accuracy': 0.25538}, {'accuracy': 0.18792999999999999}, {'accuracy': 0.19687}, {'accuracy': 0.23077999999999999}, {'accuracy': 0.23142999999999997}, {'accuracy': 0.20886999999999997}, {'accuracy': 0.24427}, {'accuracy': 0.19954}, {'accuracy': 0.21386}, {'accuracy': 0.24306}, {'accuracy': 0.22805}, {'accuracy': 0.22312000000000004}, {'accuracy': 0.23919}, {'accuracy': 0.24478}, {'accuracy': 0.18772000000000003}, {'accuracy': 0.20104000000000002}, {'accuracy': 0.23334000000000002}, {'accuracy': 0.2197}, {'accuracy': 0.21259999999999998}, {'accuracy': 0.23427999999999996}, {'accuracy': 0.20054000000000002}, {'accuracy': 0.24010999999999996}, {'accuracy': 0.27376999999999996}, {'accuracy': 0.23438999999999996}, {'accuracy': 0.29062}, {'accuracy': 0.21380999999999997}, {'accuracy': 0.24440000000000003}, {'accuracy': 0.24172000000000002}, {'accuracy': 0.22705999999999998}, {'accuracy': 0.24828999999999998}, {'accuracy': 0.22118}, {'accuracy': 0.21986999999999995}, {'accuracy': 0.23653999999999997}, {'accuracy': 0.25111}, {'accuracy': 0.23831000000000002}, {'accuracy': 0.26128999999999997}, {'accuracy': 0.23199}, {'accuracy': 0.28853}, {'accuracy': 0.23923999999999998}, {'accuracy': 0.30128000000000005}, {'accuracy': 0.23092000000000001}, {'accuracy': 0.21947}, {'accuracy': 0.27222}, {'accuracy': 0.24032000000000003}, {'accuracy': 0.27114}, {'accuracy': 0.3102600000000001}, {'accuracy': 0.27739}, {'accuracy': 0.22908}, {'accuracy': 0.23135999999999995}, {'accuracy': 0.22376999999999997}, {'accuracy': 0.23801}, {'accuracy': 0.2661300000000001}, {'accuracy': 0.22744999999999999}, {'accuracy': 0.28347}, {'accuracy': 0.24091999999999997}, {'accuracy': 0.23331999999999997}, {'accuracy': 0.24891000000000002}, {'accuracy': 0.23372}, {'accuracy': 0.25109}, {'accuracy': 0.27847}, {'accuracy': 0.26236}, {'accuracy': 0.23142999999999997}, {'accuracy': 0.26948}, {'accuracy': 0.29185}, {'accuracy': 0.30723}, {'accuracy': 0.26599999999999996}, {'accuracy': 0.23243}, {'accuracy': 0.29457999999999995}, {'accuracy': 0.27141000000000004}, {'accuracy': 0.28958999999999996}, {'accuracy': 0.33469}, {'accuracy': 0.31629}, {'accuracy': 0.3236}, {'accuracy': 0.32487999999999995}, {'accuracy': 0.31153}, {'accuracy': 0.31315}, {'accuracy': 0.30948000000000003}, {'accuracy': 0.34167000000000003}, {'accuracy': 0.3567}, {'accuracy': 0.33738999999999997}, {'accuracy': 0.36518}, {'accuracy': 0.38449999999999995}, {'accuracy': 0.2815500000000001}, {'accuracy': 0.35543}, {'accuracy': 0.35143}, {'accuracy': 0.31995999999999997}, {'accuracy': 0.30938000000000004}, {'accuracy': 0.35341999999999996}, {'accuracy': 0.31656999999999996}, {'accuracy': 0.35108}, {'accuracy': 0.40147000000000005}, {'accuracy': 0.39792}, {'accuracy': 0.3536}, {'accuracy': 0.36768}, {'accuracy': 0.36366}, {'accuracy': 0.37759}, {'accuracy': 0.40031999999999995}, {'accuracy': 0.36639}, {'accuracy': 0.34516}, {'accuracy': 0.32014000000000004}, {'accuracy': 0.34557000000000004}, {'accuracy': 0.34006}, {'accuracy': 0.36143000000000003}, {'accuracy': 0.3382299999999999}, {'accuracy': 0.41676}, {'accuracy': 0.35751}, {'accuracy': 0.34973}, {'accuracy': 0.3744}, {'accuracy': 0.36907}, {'accuracy': 0.39076}, {'accuracy': 0.4168}, {'accuracy': 0.37035999999999997}, {'accuracy': 0.36956}, {'accuracy': 0.39080000000000004}, {'accuracy': 0.44088000000000005}, {'accuracy': 0.38206999999999997}, {'accuracy': 0.42314000000000007}, {'accuracy': 0.42359}, {'accuracy': 0.409}, {'accuracy': 0.3975099999999999}, {'accuracy': 0.38253000000000004}, {'accuracy': 0.43036}, {'accuracy': 0.42999}, {'accuracy': 0.40145}, {'accuracy': 0.37515}, {'accuracy': 0.44432}, {'accuracy': 0.44882999999999995}, {'accuracy': 0.33658}, {'accuracy': 0.48163}, {'accuracy': 0.5458500000000001}, {'accuracy': 0.54993}, {'accuracy': 0.5449999999999999}, {'accuracy': 0.54009}, {'accuracy': 0.5538400000000001}, {'accuracy': 0.54302}, {'accuracy': 0.53696}, {'accuracy': 0.53291}, {'accuracy': 0.5433800000000001}, {'accuracy': 0.55326}, {'accuracy': 0.54082}, {'accuracy': 0.55508}, {'accuracy': 0.54844}, {'accuracy': 0.5431600000000001}, {'accuracy': 0.54041}, {'accuracy': 0.54898}, {'accuracy': 0.54076}, {'accuracy': 0.53906}, {'accuracy': 0.55158}, {'accuracy': 0.5467299999999999}, {'accuracy': 0.54081}, {'accuracy': 0.53816}, {'accuracy': 0.5453699999999999}, {'accuracy': 0.53835}, {'accuracy': 0.53773}, {'accuracy': 0.5478500000000001}, {'accuracy': 0.5516099999999999}, {'accuracy': 0.5392}, {'accuracy': 0.53779}, {'accuracy': 0.55556}, {'accuracy': 0.55587}, {'accuracy': 0.54905}, {'accuracy': 0.55202}, {'accuracy': 0.54672}, {'accuracy': 0.55534}, {'accuracy': 0.5540700000000001}, {'accuracy': 0.5479}, {'accuracy': 0.55465}, {'accuracy': 0.54367}, {'accuracy': 0.53637}, {'accuracy': 0.5433600000000001}, {'accuracy': 0.54337}, {'accuracy': 0.5402699999999999}, {'accuracy': 0.54174}, {'accuracy': 0.5452999999999999}, {'accuracy': 0.5408999999999999}, {'accuracy': 0.5494399999999999}, {'accuracy': 0.55165}, {'accuracy': 0.5442099999999999}, {'accuracy': 0.54857}, {'accuracy': 0.54654}, {'accuracy': 0.55392}, {'accuracy': 0.5503600000000001}, {'accuracy': 0.5481800000000001}, {'accuracy': 0.55038}, {'accuracy': 0.54759}, {'accuracy': 0.5427}, {'accuracy': 0.54173}, {'accuracy': 0.55137}, {'accuracy': 0.55452}, {'accuracy': 0.54733}, {'accuracy': 0.53852}, {'accuracy': 0.54894}, {'accuracy': 0.54848}, {'accuracy': 0.5498199999999999}, {'accuracy': 0.5491}, {'accuracy': 0.55263}, {'accuracy': 0.55096}, {'accuracy': 0.5471}, {'accuracy': 0.53816}, {'accuracy': 0.5529999999999999}, {'accuracy': 0.5515899999999998}, {'accuracy': 0.5475899999999999}, {'accuracy': 0.55087}, {'accuracy': 0.54193}, {'accuracy': 0.54402}, {'accuracy': 0.54879}, {'accuracy': 0.5522199999999999}, {'accuracy': 0.5537099999999999}, {'accuracy': 0.5379400000000001}, {'accuracy': 0.54805}, {'accuracy': 0.54691}, {'accuracy': 0.5573400000000001}, {'accuracy': 0.5446700000000001}, {'accuracy': 0.5403799999999999}, {'accuracy': 0.55412}, {'accuracy': 0.54714}, {'accuracy': 0.55623}, {'accuracy': 0.5511999999999999}, {'accuracy': 0.55167}, {'accuracy': 0.5418400000000001}, {'accuracy': 0.5478599999999999}, {'accuracy': 0.53854}, {'accuracy': 0.55728}, {'accuracy': 0.5461199999999999}, {'accuracy': 0.54834}, {'accuracy': 0.54823}, {'accuracy': 0.53975}]\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": "8802a6f7-69d2-4c65-92ce-127958f1a437",
   "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.54</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.54\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m171\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAACTkUlEQVR4nO3dd3hUZdoG8Ht6yaSSHhJCR3oTRKUIKNa1i6wriIptWXVRV/lcQdd1sa+uXXcVy6qoa9siFgSUolJEeieEkt4zSaae748z58w5U5JMmBQm9++6uExmzpw5M6bced7nfV+NIAgCiIiIiGKEtrMvgIiIiCiaGG6IiIgopjDcEBERUUxhuCEiIqKYwnBDREREMYXhhoiIiGIKww0RERHFFIYbIiIiiikMN0RERBRTGG6IqF2tWrUKGo0Gq1atkm+77rrrkJ+f32nXFEsefPBBaDSazr4Moi6F4Yaoi9uxYwd+85vfICcnByaTCdnZ2bjmmmuwY8eOzr60dvfiiy9i6dKl7focO3fuxIMPPoiCgoJ2fZ6O9Je//AWffvppZ18GUadhuCHqwj7++GOMHj0aK1aswNy5c/Hiiy/ihhtuwMqVKzF69Gh88sknnX2J7aqjws1DDz3EcEMUQ/SdfQFEFNqBAwdw7bXXok+fPvjuu++QlpYm33fHHXdg4sSJuPbaa7F161b06dOnw67LbrcjLi6uw57vZMD3hKhrYeWGqIt64okn0NDQgFdffVUVbAAgNTUVr7zyCux2Ox5//HEAwEcffQSNRoPVq1cHneuVV16BRqPB9u3b5dt2796NK664AikpKTCbzRg7diw+//xz1eOWLl0qn/O2225Deno6evbsCQA4fPgwbrvtNgwcOBAWiwU9evTAlVdeGbUKSH5+Pnbs2IHVq1dDo9FAo9FgypQp8v3V1dW48847kZubC5PJhH79+uGxxx6D1+tVnef999/HmDFjEB8fj4SEBAwbNgzPPvus/PquvPJKAMBZZ50lP4+yPyjQddddB5vNhgMHDuD8889HfHw8rrnmGgCA1+vFM888gyFDhsBsNiMjIwM333wzqqqqVOfYuHEjZsyYgdTUVFgsFvTu3RvXX3+9fH+oPiUAKCgogEajabaapdFoYLfb8eabb8qv57rrrgMA1NXV4c4770R+fj5MJhPS09Nx9tlnY/PmzWHPR3QyYuWGqIv697//jfz8fEycODHk/ZMmTUJ+fj7++9//AgAuuOAC2Gw2fPDBB5g8ebLq2GXLlmHIkCEYOnQoALGP54wzzkBOTg7uu+8+xMXF4YMPPsAll1yCf/3rX7j00ktVj7/tttuQlpaGRYsWwW63AwA2bNiAdevW4eqrr0bPnj1RUFCAl156CVOmTMHOnTthtVpP6PU/88wz+N3vfgebzYb7778fAJCRkQEAaGhowOTJk3Hs2DHcfPPNyMvLw7p167Bw4UIUFRXhmWeeAQB8/fXXmDVrFqZNm4bHHnsMALBr1y6sXbsWd9xxByZNmoTbb78df/vb3/B///d/OOWUUwBA/m84brcbM2bMwJlnnoknn3xSfq0333wzli5dirlz5+L222/HoUOH8Pzzz+Pnn3/G2rVrYTAYUFpainPOOQdpaWm47777kJSUhIKCAnz88ccn9H5J3n77bdx4440YN24cbrrpJgBA3759AQC33HILPvroI8yfPx+DBw9GRUUF1qxZg127dmH06NFReX6iLkEgoi6nurpaACBcfPHFzR73q1/9SgAg1NbWCoIgCLNmzRLS09MFt9stH1NUVCRotVrhT3/6k3zbtGnThGHDhglNTU3ybV6vVzj99NOF/v37y7e98cYbAgDhzDPPVJ1TEAShoaEh6HrWr18vABDeeust+baVK1cKAISVK1fKt82ZM0fo1atXs69NEARhyJAhwuTJk4Nuf/jhh4W4uDhh7969qtvvu+8+QafTCYWFhYIgCMIdd9whJCQkBF270ocffhh0fc2ZM2eOAEC47777VLd///33AgDhn//8p+r25cuXq27/5JNPBADChg0bwj5HqPdMEATh0KFDAgDhjTfekG9bvHixEPijPC4uTpgzZ07QeRMTE4Xf/va3rXiVRCc3DksRdUF1dXUAgPj4+GaPk+6vra0FAMycOROlpaWq4YyPPvoIXq8XM2fOBABUVlbi22+/xVVXXYW6ujqUl5ejvLwcFRUVmDFjBvbt24djx46pnmfevHnQ6XSq2ywWi/yxy+VCRUUF+vXrh6SkpHYf5vjwww8xceJEJCcny9dfXl6O6dOnw+Px4LvvvgMAJCUlwW634+uvv476Ndx6661B15SYmIizzz5bdU1jxoyBzWbDypUr5WsCgP/85z9wuVxRv67mJCUl4ccff8Tx48c79HmJOhrDDVEXJIUWKeSEExiCzj33XCQmJmLZsmXyMcuWLcPIkSMxYMAAAMD+/fshCAIeeOABpKWlqf4tXrwYAFBaWqp6nt69ewc9d2NjIxYtWiT3vKSmpiItLQ3V1dWoqalp4ytvnX379mH58uVB1z99+nTV9d92220YMGAAzjvvPPTs2RPXX389li9ffsLPr9fr5d4j5TXV1NQgPT096Lrq6+vla5o8eTIuv/xyPPTQQ0hNTcXFF1+MN954Aw6H44SvqyWPP/44tm/fjtzcXIwbNw4PPvggDh482O7PS9TR2HND1AUlJiYiKysLW7dubfa4rVu3IicnBwkJCQAAk8mESy65BJ988glefPFFlJSUYO3atfjLX/4iP0ZquL377rsxY8aMkOft16+f6nNllUbyu9/9Dm+88QbuvPNOTJgwAYmJidBoNLj66quDmnqjzev14uyzz8Yf/vCHkPdLQS49PR1btmzBl19+iS+++AJffPEF3njjDcyePRtvvvlmm5/fZDJBq1X/bej1epGeno5//vOfIR8jNYVrNBp89NFH+OGHH/Dvf/8bX375Ja6//no89dRT+OGHH2Cz2cIuyufxeNp8zQBw1VVXYeLEifjkk0/w1Vdf4YknnsBjjz2Gjz/+GOedd94JnZuoK2G4IeqiLrzwQrz22mtYs2YNzjzzzKD7v//+exQUFODmm29W3T5z5ky8+eabWLFiBXbt2gVBEOQhKQDytHGDwSBXOtrio48+wpw5c/DUU0/JtzU1NaG6urrN5wwU7pd83759UV9f36rrNxqNuOiii3DRRRfB6/XitttuwyuvvIIHHngA/fr1i9rqvn379sU333yDM844I2QYDHTaaafhtNNOwyOPPIJ3330X11xzDd5//33ceOONSE5OBoCg9/Lw4cOtupbmXlNWVhZuu+023HbbbSgtLcXo0aPxyCOPMNxQTOGwFFEXdc8998BiseDmm29GRUWF6r7KykrccsstsFqtuOeee1T3TZ8+HSkpKVi2bBmWLVuGcePGqYaV0tPTMWXKFLzyyisoKioKet6ysrJWXZ9Op4MgCKrbnnvuuROuLijFxcWFDEtXXXUV1q9fjy+//DLovurqarjdbgAIet+0Wi2GDx8OAPIwkLQ+zYmGsquuugoejwcPP/xw0H1ut1s+f1VVVdD7NnLkSNU19erVCzqdTu4dkrz44outupZQ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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.15362}, {'accuracy': 0.12902}, {'accuracy': 0.19319000000000003}, {'accuracy': 0.16394}, {'accuracy': 0.18245}, {'accuracy': 0.18237}, {'accuracy': 0.15202}, {'accuracy': 0.13820000000000002}, {'accuracy': 0.1952}, {'accuracy': 0.15471}, {'accuracy': 0.17687999999999998}, {'accuracy': 0.14272}, {'accuracy': 0.17407}, {'accuracy': 0.15336}, {'accuracy': 0.14506999999999998}, {'accuracy': 0.16731000000000001}, {'accuracy': 0.18916000000000002}, {'accuracy': 0.17105}, {'accuracy': 0.14516}, {'accuracy': 0.14459}, {'accuracy': 0.15655000000000002}, {'accuracy': 0.13976}, {'accuracy': 0.15276000000000003}, {'accuracy': 0.16039}, {'accuracy': 0.15363}, {'accuracy': 0.11804999999999999}, {'accuracy': 0.15947}, {'accuracy': 0.15444999999999998}, {'accuracy': 0.14592}, {'accuracy': 0.19333999999999998}, {'accuracy': 0.17211}, {'accuracy': 0.15867000000000003}, {'accuracy': 0.16060000000000002}, {'accuracy': 0.1317}, {'accuracy': 0.14696}, {'accuracy': 0.14789000000000002}, {'accuracy': 0.19438000000000002}, {'accuracy': 0.14302}, {'accuracy': 0.18011000000000005}, {'accuracy': 0.16815}, {'accuracy': 0.17536000000000002}, {'accuracy': 0.18863999999999997}, {'accuracy': 0.15056999999999998}, {'accuracy': 0.15522}, {'accuracy': 0.11205000000000001}, {'accuracy': 0.15286000000000002}, {'accuracy': 0.17075}, {'accuracy': 0.18048}, {'accuracy': 0.17931999999999998}, {'accuracy': 0.19149}, {'accuracy': 0.17992000000000002}, {'accuracy': 0.18918000000000001}, {'accuracy': 0.22082000000000002}, {'accuracy': 0.18064}, {'accuracy': 0.17572000000000002}, {'accuracy': 0.19478}, {'accuracy': 0.18174000000000004}, {'accuracy': 0.17727}, {'accuracy': 0.18358999999999998}, {'accuracy': 0.21605999999999997}, {'accuracy': 0.22213000000000002}, {'accuracy': 0.21703999999999998}, {'accuracy': 0.18893}, {'accuracy': 0.19887000000000002}, {'accuracy': 0.20722999999999997}, {'accuracy': 0.18056}, {'accuracy': 0.20421999999999998}, {'accuracy': 0.18948}, {'accuracy': 0.20561000000000001}, {'accuracy': 0.22389}, {'accuracy': 0.27714000000000005}, {'accuracy': 0.19286999999999999}, {'accuracy': 0.23564000000000002}, {'accuracy': 0.25538}, {'accuracy': 0.18792999999999999}, {'accuracy': 0.19687}, {'accuracy': 0.23077999999999999}, {'accuracy': 0.23142999999999997}, {'accuracy': 0.20886999999999997}, {'accuracy': 0.24427}, {'accuracy': 0.19954}, {'accuracy': 0.21386}, {'accuracy': 0.24306}, {'accuracy': 0.22805}, {'accuracy': 0.22312000000000004}, {'accuracy': 0.23919}, {'accuracy': 0.24478}, {'accuracy': 0.18772000000000003}, {'accuracy': 0.20104000000000002}, {'accuracy': 0.23334000000000002}, {'accuracy': 0.2197}, {'accuracy': 0.21259999999999998}, {'accuracy': 0.23427999999999996}, {'accuracy': 0.20054000000000002}, {'accuracy': 0.24010999999999996}, {'accuracy': 0.27376999999999996}, {'accuracy': 0.23438999999999996}, {'accuracy': 0.29062}, {'accuracy': 0.21380999999999997}, {'accuracy': 0.24440000000000003}, {'accuracy': 0.24172000000000002}, {'accuracy': 0.22705999999999998}, {'accuracy': 0.24828999999999998}, {'accuracy': 0.22118}, {'accuracy': 0.21986999999999995}, {'accuracy': 0.23653999999999997}, {'accuracy': 0.25111}, {'accuracy': 0.23831000000000002}, {'accuracy': 0.26128999999999997}, {'accuracy': 0.23199}, {'accuracy': 0.28853}, {'accuracy': 0.23923999999999998}, {'accuracy': 0.30128000000000005}, {'accuracy': 0.23092000000000001}, {'accuracy': 0.21947}, {'accuracy': 0.27222}, {'accuracy': 0.24032000000000003}, {'accuracy': 0.27114}, {'accuracy': 0.3102600000000001}, {'accuracy': 0.27739}, {'accuracy': 0.22908}, {'accuracy': 0.23135999999999995}, {'accuracy': 0.22376999999999997}, {'accuracy': 0.23801}, {'accuracy': 0.2661300000000001}, {'accuracy': 0.22744999999999999}, {'accuracy': 0.28347}, {'accuracy': 0.24091999999999997}, {'accuracy': 0.23331999999999997}, {'accuracy': 0.24891000000000002}, {'accuracy': 0.23372}, {'accuracy': 0.25109}, {'accuracy': 0.27847}, {'accuracy': 0.26236}, {'accuracy': 0.23142999999999997}, {'accuracy': 0.26948}, {'accuracy': 0.29185}, {'accuracy': 0.30723}, {'accuracy': 0.26599999999999996}, {'accuracy': 0.23243}, {'accuracy': 0.29457999999999995}, {'accuracy': 0.27141000000000004}, {'accuracy': 0.28958999999999996}, {'accuracy': 0.33469}, {'accuracy': 0.31629}, {'accuracy': 0.3236}, {'accuracy': 0.32487999999999995}, {'accuracy': 0.31153}, {'accuracy': 0.31315}, {'accuracy': 0.30948000000000003}, {'accuracy': 0.34167000000000003}, {'accuracy': 0.3567}, {'accuracy': 0.33738999999999997}, {'accuracy': 0.36518}, {'accuracy': 0.38449999999999995}, {'accuracy': 0.2815500000000001}, {'accuracy': 0.35543}, {'accuracy': 0.35143}, {'accuracy': 0.31995999999999997}, {'accuracy': 0.30938000000000004}, {'accuracy': 0.35341999999999996}, {'accuracy': 0.31656999999999996}, {'accuracy': 0.35108}, {'accuracy': 0.40147000000000005}, {'accuracy': 0.39792}, {'accuracy': 0.3536}, {'accuracy': 0.36768}, {'accuracy': 0.36366}, {'accuracy': 0.37759}, {'accuracy': 0.40031999999999995}, {'accuracy': 0.36639}, {'accuracy': 0.34516}, {'accuracy': 0.32014000000000004}, {'accuracy': 0.34557000000000004}, {'accuracy': 0.34006}, {'accuracy': 0.36143000000000003}, {'accuracy': 0.3382299999999999}, {'accuracy': 0.41676}, {'accuracy': 0.35751}, {'accuracy': 0.34973}, {'accuracy': 0.3744}, {'accuracy': 0.36907}, {'accuracy': 0.39076}, {'accuracy': 0.4168}, {'accuracy': 0.37035999999999997}, {'accuracy': 0.36956}, {'accuracy': 0.39080000000000004}, {'accuracy': 0.44088000000000005}, {'accuracy': 0.38206999999999997}, {'accuracy': 0.42314000000000007}, {'accuracy': 0.42359}, {'accuracy': 0.409}, {'accuracy': 0.3975099999999999}, {'accuracy': 0.38253000000000004}, {'accuracy': 0.43036}, {'accuracy': 0.42999}, {'accuracy': 0.40145}, {'accuracy': 0.37515}, {'accuracy': 0.44432}, {'accuracy': 0.44882999999999995}, {'accuracy': 0.33658}, {'accuracy': 0.48163}, {'accuracy': 0.5458500000000001}, {'accuracy': 0.54993}, {'accuracy': 0.5449999999999999}, {'accuracy': 0.54009}, {'accuracy': 0.5538400000000001}, {'accuracy': 0.54302}, {'accuracy': 0.53696}, {'accuracy': 0.53291}, {'accuracy': 0.5433800000000001}, {'accuracy': 0.55326}, {'accuracy': 0.54082}, {'accuracy': 0.55508}, {'accuracy': 0.54844}, {'accuracy': 0.5431600000000001}, {'accuracy': 0.54041}, {'accuracy': 0.54898}, {'accuracy': 0.54076}, {'accuracy': 0.53906}, {'accuracy': 0.55158}, {'accuracy': 0.5467299999999999}, {'accuracy': 0.54081}, {'accuracy': 0.53816}, {'accuracy': 0.5453699999999999}, {'accuracy': 0.53835}, {'accuracy': 0.53773}, {'accuracy': 0.5478500000000001}, {'accuracy': 0.5516099999999999}, {'accuracy': 0.5392}, {'accuracy': 0.53779}, {'accuracy': 0.55556}, {'accuracy': 0.55587}, {'accuracy': 0.54905}, {'accuracy': 0.55202}, {'accuracy': 0.54672}, {'accuracy': 0.55534}, {'accuracy': 0.5540700000000001}, {'accuracy': 0.5479}, {'accuracy': 0.55465}, {'accuracy': 0.54367}, {'accuracy': 0.53637}, {'accuracy': 0.5433600000000001}, {'accuracy': 0.54337}, {'accuracy': 0.5402699999999999}, {'accuracy': 0.54174}, {'accuracy': 0.5452999999999999}, {'accuracy': 0.5408999999999999}, {'accuracy': 0.5494399999999999}, {'accuracy': 0.55165}, {'accuracy': 0.5442099999999999}, {'accuracy': 0.54857}, {'accuracy': 0.54654}, {'accuracy': 0.55392}, {'accuracy': 0.5503600000000001}, {'accuracy': 0.5481800000000001}, {'accuracy': 0.55038}, {'accuracy': 0.54759}, {'accuracy': 0.5427}, {'accuracy': 0.54173}, {'accuracy': 0.55137}, {'accuracy': 0.55452}, {'accuracy': 0.54733}, {'accuracy': 0.53852}, {'accuracy': 0.54894}, {'accuracy': 0.54848}, {'accuracy': 0.5498199999999999}, {'accuracy': 0.5491}, {'accuracy': 0.55263}, {'accuracy': 0.55096}, {'accuracy': 0.5471}, {'accuracy': 0.53816}, {'accuracy': 0.5529999999999999}, {'accuracy': 0.5515899999999998}, {'accuracy': 0.5475899999999999}, {'accuracy': 0.55087}, {'accuracy': 0.54193}, {'accuracy': 0.54402}, {'accuracy': 0.54879}, {'accuracy': 0.5522199999999999}, {'accuracy': 0.5537099999999999}, {'accuracy': 0.5379400000000001}, {'accuracy': 0.54805}, {'accuracy': 0.54691}, {'accuracy': 0.5573400000000001}, {'accuracy': 0.5446700000000001}, {'accuracy': 0.5403799999999999}, {'accuracy': 0.55412}, {'accuracy': 0.54714}, {'accuracy': 0.55623}, {'accuracy': 0.5511999999999999}, {'accuracy': 0.55167}, {'accuracy': 0.5418400000000001}, {'accuracy': 0.5478599999999999}, {'accuracy': 0.53854}, {'accuracy': 0.55728}, {'accuracy': 0.5461199999999999}, {'accuracy': 0.54834}, {'accuracy': 0.54823}, {'accuracy': 0.53975}]\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": "537807cb-6879-40fc-afeb-3868f45b51a7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0ec61b23-bd0f-4f5d-ad8c-9cbd070b2a51",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7adf0d30-f0ba-43b8-b4db-0377fdd7ad8e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c6b7c989-3d1f-4130-be3f-3957c1b1c723",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "986eabb5-1a48-4417-97ee-31a1f8458a4e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bf10f37e-c46f-45f4-8a33-8ce164d76c23",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "12c4f7a4-897b-4b06-876a-af8ace52a837",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "93aa5768-b0bc-4deb-9d3a-6cf0c8b62ea9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9edf1c60-a398-4228-be90-0ee841f4923d",
   "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
}
