{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_FEMNIST,get_FashionMNIST, get_MNIST\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "    \n",
    "class CNNmnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(1, 10, kernel_size=5)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(10, 20, kernel_size=5)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(320, 50)\n",
    "        self.fc2 = nn.Linear(50, 10)        \n",
    "        # self.out = nn.Linear(64 * 7 * 7, 10)\n",
    "\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(-1, 320)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2323]\n",
      " [   1   73]\n",
      " [   2   37]\n",
      " [   3   71]\n",
      " [   4  114]\n",
      " [   5  167]\n",
      " [   6  313]\n",
      " [   7  524]\n",
      " [   8  826]\n",
      " [   9 1472]]\n",
      "[[   0 1443]\n",
      " [   1 2695]\n",
      " [   2   57]\n",
      " [   3   56]\n",
      " [   4   57]\n",
      " [   5  106]\n",
      " [   6  180]\n",
      " [   7  342]\n",
      " [   8  539]\n",
      " [   9  831]]\n",
      "[[   0  890]\n",
      " [   1 1592]\n",
      " [   2 2343]\n",
      " [   3   62]\n",
      " [   4   35]\n",
      " [   5   62]\n",
      " [   6   94]\n",
      " [   7  198]\n",
      " [   8  316]\n",
      " [   9  489]]\n",
      "[[   0  502]\n",
      " [   1 1001]\n",
      " [   2 1471]\n",
      " [   3 2459]\n",
      " [   4   59]\n",
      " [   5   29]\n",
      " [   6   82]\n",
      " [   7  106]\n",
      " [   8  182]\n",
      " [   9  324]]\n",
      "[[   0  299]\n",
      " [   1  591]\n",
      " [   2  865]\n",
      " [   3 1458]\n",
      " [   4 2303]\n",
      " [   5   62]\n",
      " [   6   41]\n",
      " [   7   70]\n",
      " [   8  118]\n",
      " [   9  189]]\n",
      "[[   0  188]\n",
      " [   1  343]\n",
      " [   2  483]\n",
      " [   3  872]\n",
      " [   4 1470]\n",
      " [   5 2166]\n",
      " [   6   69]\n",
      " [   7   56]\n",
      " [   8   60]\n",
      " [   9  115]]\n",
      "[[   0  110]\n",
      " [   1  214]\n",
      " [   2  303]\n",
      " [   3  551]\n",
      " [   4  812]\n",
      " [   5 1277]\n",
      " [   6 2330]\n",
      " [   7   70]\n",
      " [   8   43]\n",
      " [   9   71]]\n",
      "[[   0   60]\n",
      " [   1  120]\n",
      " [   2  201]\n",
      " [   3  295]\n",
      " [   4  499]\n",
      " [   5  762]\n",
      " [   6 1414]\n",
      " [   7 2444]\n",
      " [   8   52]\n",
      " [   9   39]]\n",
      "[[   0   48]\n",
      " [   1   61]\n",
      " [   2  132]\n",
      " [   3  180]\n",
      " [   4  288]\n",
      " [   5  491]\n",
      " [   6  898]\n",
      " [   7 1524]\n",
      " [   8 2341]\n",
      " [   9   50]]\n",
      "[[   0   60]\n",
      " [   1   52]\n",
      " [   2   66]\n",
      " [   3  127]\n",
      " [   4  205]\n",
      " [   5  299]\n",
      " [   6  497]\n",
      " [   7  931]\n",
      " [   8 1374]\n",
      " [   9 2369]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([5, 0, 4,  ..., 5, 6, 8])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_MNIST()\n",
    "\n",
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,60000,1):\n",
    "    if train_set[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif train_set[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif train_set[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif train_set[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif train_set[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif train_set[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif train_set[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif train_set[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif train_set[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif train_set[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "train_set[1][label[1]]\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(train_set[0][label[0][z]])\n",
    "        list0[1].append(train_set[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(train_set[0][label[0][z]])\n",
    "        list1[1].append(train_set[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(train_set[0][label[0][z]])\n",
    "        list2[1].append(train_set[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(train_set[0][label[0][z]])\n",
    "        list3[1].append(train_set[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(train_set[0][label[0][z]])\n",
    "        list4[1].append(train_set[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(train_set[0][label[0][z]])\n",
    "        list5[1].append(train_set[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(train_set[0][label[0][z]])\n",
    "        list6[1].append(train_set[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(train_set[0][label[0][z]])\n",
    "        list7[1].append(train_set[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(train_set[0][label[0][z]])\n",
    "        list8[1].append(train_set[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(train_set[0][label[0][z]])\n",
    "        list9[1].append(train_set[1][label[0][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(train_set[0][label[1][z]])\n",
    "        list1[1].append(train_set[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(train_set[0][label[1][z]])\n",
    "        list2[1].append(train_set[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(train_set[0][label[1][z]])\n",
    "        list3[1].append(train_set[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(train_set[0][label[1][z]])\n",
    "        list4[1].append(train_set[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(train_set[0][label[1][z]])\n",
    "        list5[1].append(train_set[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(train_set[0][label[1][z]])\n",
    "        list6[1].append(train_set[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(train_set[0][label[1][z]])\n",
    "        list7[1].append(train_set[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(train_set[0][label[1][z]])\n",
    "        list8[1].append(train_set[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(train_set[0][label[1][z]])\n",
    "        list9[1].append(train_set[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(train_set[0][label[1][z]])\n",
    "        list0[1].append(train_set[1][label[1][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(train_set[0][label[2][z]])\n",
    "        list2[1].append(train_set[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(train_set[0][label[2][z]])\n",
    "        list3[1].append(train_set[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(train_set[0][label[2][z]])\n",
    "        list4[1].append(train_set[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(train_set[0][label[2][z]])\n",
    "        list5[1].append(train_set[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(train_set[0][label[2][z]])\n",
    "        list6[1].append(train_set[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(train_set[0][label[2][z]])\n",
    "        list7[1].append(train_set[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(train_set[0][label[2][z]])\n",
    "        list8[1].append(train_set[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(train_set[0][label[2][z]])\n",
    "        list9[1].append(train_set[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(train_set[0][label[2][z]])\n",
    "        list0[1].append(train_set[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(train_set[0][label[2][z]])\n",
    "        list1[1].append(train_set[1][label[2][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(train_set[0][label[3][z]])\n",
    "        list3[1].append(train_set[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(train_set[0][label[3][z]])\n",
    "        list4[1].append(train_set[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(train_set[0][label[3][z]])\n",
    "        list5[1].append(train_set[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(train_set[0][label[3][z]])\n",
    "        list6[1].append(train_set[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(train_set[0][label[3][z]])\n",
    "        list7[1].append(train_set[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(train_set[0][label[3][z]])\n",
    "        list8[1].append(train_set[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(train_set[0][label[3][z]])\n",
    "        list9[1].append(train_set[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(train_set[0][label[3][z]])\n",
    "        list0[1].append(train_set[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(train_set[0][label[3][z]])\n",
    "        list1[1].append(train_set[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(train_set[0][label[3][z]])\n",
    "        list2[1].append(train_set[1][label[3][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(train_set[0][label[4][z]])\n",
    "        list4[1].append(train_set[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(train_set[0][label[4][z]])\n",
    "        list5[1].append(train_set[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(train_set[0][label[4][z]])\n",
    "        list6[1].append(train_set[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(train_set[0][label[4][z]])\n",
    "        list7[1].append(train_set[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(train_set[0][label[4][z]])\n",
    "        list8[1].append(train_set[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(train_set[0][label[4][z]])\n",
    "        list9[1].append(train_set[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(train_set[0][label[4][z]])\n",
    "        list0[1].append(train_set[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(train_set[0][label[4][z]])\n",
    "        list1[1].append(train_set[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(train_set[0][label[4][z]])\n",
    "        list2[1].append(train_set[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(train_set[0][label[4][z]])\n",
    "        list3[1].append(train_set[1][label[4][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(train_set[0][label[5][z]])\n",
    "        list5[1].append(train_set[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(train_set[0][label[5][z]])\n",
    "        list6[1].append(train_set[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(train_set[0][label[5][z]])\n",
    "        list7[1].append(train_set[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(train_set[0][label[5][z]])\n",
    "        list8[1].append(train_set[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(train_set[0][label[5][z]])\n",
    "        list9[1].append(train_set[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(train_set[0][label[5][z]])\n",
    "        list0[1].append(train_set[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(train_set[0][label[5][z]])\n",
    "        list1[1].append(train_set[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(train_set[0][label[5][z]])\n",
    "        list2[1].append(train_set[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(train_set[0][label[5][z]])\n",
    "        list3[1].append(train_set[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(train_set[0][label[5][z]])\n",
    "        list4[1].append(train_set[1][label[5][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(train_set[0][label[6][z]])\n",
    "        list6[1].append(train_set[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(train_set[0][label[6][z]])\n",
    "        list7[1].append(train_set[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(train_set[0][label[6][z]])\n",
    "        list8[1].append(train_set[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(train_set[0][label[6][z]])\n",
    "        list9[1].append(train_set[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(train_set[0][label[6][z]])\n",
    "        list0[1].append(train_set[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(train_set[0][label[6][z]])\n",
    "        list1[1].append(train_set[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(train_set[0][label[6][z]])\n",
    "        list2[1].append(train_set[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(train_set[0][label[6][z]])\n",
    "        list3[1].append(train_set[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(train_set[0][label[6][z]])\n",
    "        list4[1].append(train_set[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(train_set[0][label[6][z]])\n",
    "        list5[1].append(train_set[1][label[6][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(train_set[0][label[7][z]])\n",
    "        list7[1].append(train_set[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(train_set[0][label[7][z]])\n",
    "        list8[1].append(train_set[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(train_set[0][label[7][z]])\n",
    "        list9[1].append(train_set[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(train_set[0][label[7][z]])\n",
    "        list0[1].append(train_set[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(train_set[0][label[7][z]])\n",
    "        list1[1].append(train_set[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(train_set[0][label[7][z]])\n",
    "        list2[1].append(train_set[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(train_set[0][label[7][z]])\n",
    "        list3[1].append(train_set[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(train_set[0][label[7][z]])\n",
    "        list4[1].append(train_set[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(train_set[0][label[7][z]])\n",
    "        list5[1].append(train_set[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(train_set[0][label[7][z]])\n",
    "        list6[1].append(train_set[1][label[7][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(train_set[0][label[8][z]])\n",
    "        list8[1].append(train_set[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(train_set[0][label[8][z]])\n",
    "        list9[1].append(train_set[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(train_set[0][label[8][z]])\n",
    "        list0[1].append(train_set[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(train_set[0][label[8][z]])\n",
    "        list1[1].append(train_set[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(train_set[0][label[8][z]])\n",
    "        list2[1].append(train_set[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(train_set[0][label[8][z]])\n",
    "        list3[1].append(train_set[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(train_set[0][label[8][z]])\n",
    "        list4[1].append(train_set[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(train_set[0][label[8][z]])\n",
    "        list5[1].append(train_set[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(train_set[0][label[8][z]])\n",
    "        list6[1].append(train_set[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(train_set[0][label[8][z]])\n",
    "        list7[1].append(train_set[1][label[8][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(train_set[0][label[9][z]])\n",
    "        list9[1].append(train_set[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(train_set[0][label[9][z]])\n",
    "        list0[1].append(train_set[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(train_set[0][label[9][z]])\n",
    "        list1[1].append(train_set[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(train_set[0][label[9][z]])\n",
    "        list2[1].append(train_set[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(train_set[0][label[9][z]])\n",
    "        list3[1].append(train_set[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(train_set[0][label[9][z]])\n",
    "        list4[1].append(train_set[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(train_set[0][label[9][z]])\n",
    "        list5[1].append(train_set[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(train_set[0][label[9][z]])\n",
    "        list6[1].append(train_set[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(train_set[0][label[9][z]])\n",
    "        list7[1].append(train_set[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(train_set[0][label[9][z]])\n",
    "        list8[1].append(train_set[1][label[9][z]])  \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list1[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list3[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list4[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list5[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0c21f936-247b-47ad-974c-af7e1368a4e1",
   "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",
    "        pa=random.randint(0,9)\n",
    "        while pa == tag1[z]:\n",
    "            pa=random.randint(0,9)\n",
    "        tag1[z]=pa"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 6, 0,  ..., 9, 0, 5])"
      ]
     },
     "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": [
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CNNmnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1.0\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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8fDDD6Nt27ZITk7GF198gZycHHz//ffSNF8TR0dH3HnnnVi/fj3UajXee++9ao/9ySefYNCgQYiOjsYjjzyCdu3aITMzE/v27cPly5dx7Nixa7bvlltuwTfffANPT0907doV+/btw9atW+Hr62u170GfPn3w2Wef4X//+x/at2+PgIAAjBgxAs8//zx+//133HLLLZg+fTr69OkDtVqNEydOYOPGjUhOToafnx9mzpyJvLw8jBgxAmFhYUhJScFHH32Enj17StO9e/bsCblcjrfffhuFhYVQKpUYMWIEAgICLGrr0KFDMWvWLCxZsgTx8fEYM2YMHB0dcf78efz444/44IMPcPfdd+Orr77Cp59+ijvuuANRUVFQqVRYvXo1PDw8MGHCBACGYcl77rkHH330EQRBQFRUFP78889qtVB1fd+2bt2K5cuXIyQkBG3btkWnTp0QFhaGu+++GzExMXBzc8PWrVtx6NAhs943Irtg28laRHQtx48fFydPniwGBweLjo6OYlBQkDh58mTxxIkTtd5ny5YtIgBREATx0qVLNZ6TmJgoTp06VQwKChIdHR3F0NBQ8ZZbbhE3btwonWOaCl7TtOX8/HxxxowZop+fn+jm5iaOHTtWTEhIENu0aWM2DbkxU8EzMjLEm2++WXR3dxcBmE0LV6lU4oIFC8T27duLCoVC9PPzE2+66SbxvffeE7VarSiKorhx40ZxzJgxYkBAgKhQKMSIiAhx1qxZYnp6utnzrF69WmzXrp0ol8uvOS182rRpoqura623f/7552KfPn1EZ2dn0d3dXYyOjhZfeOEF8cqVK6IoimJcXJw4efJkMSIiQlQqlWJAQIB4yy23iIcPHzZ7nOzsbPGuu+4SXVxcRG9vb3HWrFniyZMn6zUVPCEhQRwyZIjo7OwsAhCnTZsmajQa8fnnnxdjYmJEd3d30dXVVYyJiRE//fTTul4ColZJEMWr+keJiIiIWjHW3BAREZFdYbghIiIiu8JwQ0RERHaF4YaIiIjsCsMNERER2RWGGyIiIrIr190ifnq9HleuXIG7u7vVll0nIiKipiWKIlQqFUJCQqrt7Xa16y7cXLlyBeHh4bZuBhERETXApUuXEBYWVuc51124cXd3B2D45ph2UiYiIqKWraioCOHh4dL7eF2uu3BjGory8PBguCEiImpl6lNSwoJiIiIi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WttrqFarERMTg08++aTG29955x18+OGHWLlyJQ4cOABXV1eMHTsWZWVl0jlTpkzBqVOnsGXLFvz555/YtWsXHn300ea6hDrVdX0lJSWIi4vDwoULERcXh59//hlnz57FbbfdVu3c119/3ex1ffLJJ5uj+fVyrdcQAMaNG2fW/u+//97s9tb6GgIwu6709HR8+eWXEAQBd911l9l5Lfk1rM97xLV+h+p0Otx8883QarXYu3cvvvrqK6xduxaLFi2yfoNFarB+/fqJTzzxhPS1TqcTQ0JCxCVLltiwVdaRlZUlAhB37twpHRs6dKg4d+5c2zWqkRYvXizGxMTUeFtBQYHo6Ogo/vjjj9KxM2fOiADEffv2NVMLrW/u3LliVFSUqNfrRVFs/a8hAPGXX36Rvtbr9WJQUJD47rvvSscKCgpEpVIpfv/996IoiuLp06dFAOKhQ4ekc/755x9REAQxLS2t2dpeH1dfX00OHjwoAhBTUlKkY23atBHff//9pm2cldR0jdOmTRMnTpxY633s7TWcOHGiOGLECLNjrek1FMXq7xH1+R36999/izKZTMzIyJDO+eyzz0QPDw9Ro9FYtX3suWkgrVaLI0eOYNSoUdIxmUyGUaNGYd++fTZsmXUUFhYCAHx8fMyOf/fdd/Dz80P37t2xYMEClJSU2KJ5DXb+/HmEhISgXbt2mDJlClJTUwEAR44cQXl5udnr2blzZ0RERLTa11Or1eLbb7/FQw89ZLZJbGt/DatKSkpCRkaG2evm6emJ/v37S6/bvn374OXlhb59+0rnjBo1CjKZDAcOHGj2NjdWYWEhBEGAl5eX2fGlS5fC19cXvXr1wrvvvtskXf1NKTY2FgEBAejUqRMef/xx5ObmSrfZ02uYmZmJv/76Cw8//HC121rTa3j1e0R9fofu27cP0dHRCAwMlM4ZO3YsioqKcOrUKau277rbONNacnJyoNPpzF4kAAgMDERCQoKNWmUder0eTz/9NAYOHIju3btLx++//360adMGISEhOH78OObPn4+zZ8/i559/tmFr669///5Yu3YtOnXqhPT0dLz22msYPHgwTp48iYyMDCgUimpvGIGBgcjIyLBNgxvp119/RUFBAaZPny4da+2v4dVMr01N/w9Nt2VkZCAgIMDsdgcHB/j4+LS617asrAzz58/H5MmTzTYkfOqpp9C7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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.10334000000000002}, {'accuracy': 0.10995999999999999}, {'accuracy': 0.15248}, {'accuracy': 0.16948999999999997}, {'accuracy': 0.25941}, {'accuracy': 0.22168000000000002}, {'accuracy': 0.28145}, {'accuracy': 0.29274999999999995}, {'accuracy': 0.41442000000000007}, {'accuracy': 0.39725}, {'accuracy': 0.40705}, {'accuracy': 0.48195}, {'accuracy': 0.52256}, {'accuracy': 0.47276000000000007}, {'accuracy': 0.5634300000000001}, {'accuracy': 0.5379}, {'accuracy': 0.54412}, {'accuracy': 0.61004}, {'accuracy': 0.6040800000000001}, {'accuracy': 0.54696}, {'accuracy': 0.6112200000000001}, {'accuracy': 0.5978299999999999}, {'accuracy': 0.6071199999999999}, {'accuracy': 0.60548}, {'accuracy': 0.6425099999999999}, {'accuracy': 0.63997}, {'accuracy': 0.68503}, {'accuracy': 0.66689}, {'accuracy': 0.6734699999999999}, {'accuracy': 0.70734}, {'accuracy': 0.6693899999999999}, {'accuracy': 0.7462700000000001}, {'accuracy': 0.70353}, {'accuracy': 0.6799499999999999}, {'accuracy': 0.7192000000000001}, {'accuracy': 0.735}, {'accuracy': 0.75369}, {'accuracy': 0.7292799999999999}, {'accuracy': 0.74984}, {'accuracy': 0.73663}, {'accuracy': 0.7469300000000001}, {'accuracy': 0.7509699999999999}, {'accuracy': 0.75818}, {'accuracy': 0.77778}, {'accuracy': 0.8010400000000001}, {'accuracy': 0.73979}, {'accuracy': 0.79528}, {'accuracy': 0.76326}, {'accuracy': 0.7642900000000001}, {'accuracy': 0.8360700000000001}, {'accuracy': 0.79986}, {'accuracy': 0.80488}, {'accuracy': 0.79744}, {'accuracy': 0.8122199999999999}, {'accuracy': 0.7939}, {'accuracy': 0.8075800000000001}, {'accuracy': 0.8474600000000001}, {'accuracy': 0.83111}, {'accuracy': 0.8063100000000001}, {'accuracy': 0.78713}, {'accuracy': 0.81281}, {'accuracy': 0.8263}, {'accuracy': 0.83904}, {'accuracy': 0.8294899999999998}, {'accuracy': 0.8488999999999999}, {'accuracy': 0.85272}, {'accuracy': 0.8543200000000001}, {'accuracy': 0.8439099999999999}, {'accuracy': 0.8430600000000001}, {'accuracy': 0.8747}, {'accuracy': 0.8578000000000001}, {'accuracy': 0.85268}, {'accuracy': 0.86898}, {'accuracy': 0.8779600000000001}, {'accuracy': 0.86603}, {'accuracy': 0.86281}, {'accuracy': 0.8721599999999998}, {'accuracy': 0.8751}, {'accuracy': 0.87842}, {'accuracy': 0.8579999999999999}, {'accuracy': 0.87665}, {'accuracy': 0.8814}, {'accuracy': 0.8705299999999999}, {'accuracy': 0.87065}, {'accuracy': 0.8968}, {'accuracy': 0.86464}, {'accuracy': 0.88501}, {'accuracy': 0.8800400000000002}, {'accuracy': 0.87178}, {'accuracy': 0.8912699999999999}, {'accuracy': 0.8848199999999998}, {'accuracy': 0.8812300000000001}, {'accuracy': 0.8887099999999999}, {'accuracy': 0.8921000000000001}, {'accuracy': 0.8824}, {'accuracy': 0.8912800000000001}, {'accuracy': 0.8704699999999999}, {'accuracy': 0.8915000000000001}, {'accuracy': 0.89275}, {'accuracy': 0.8971200000000001}, {'accuracy': 0.9089900000000002}, {'accuracy': 0.89247}, {'accuracy': 0.89369}, {'accuracy': 0.90151}, {'accuracy': 0.8896099999999999}, {'accuracy': 0.88964}, {'accuracy': 0.8953599999999999}, {'accuracy': 0.8844999999999998}, {'accuracy': 0.89376}, {'accuracy': 0.89674}, {'accuracy': 0.89111}, {'accuracy': 0.9179499999999999}, {'accuracy': 0.8965}, {'accuracy': 0.90593}, {'accuracy': 0.90474}, {'accuracy': 0.9105399999999999}, {'accuracy': 0.9080200000000002}, {'accuracy': 0.90086}, {'accuracy': 0.90563}, {'accuracy': 0.9028700000000001}, {'accuracy': 0.90588}, {'accuracy': 0.9209299999999999}, {'accuracy': 0.8932399999999999}, {'accuracy': 0.9153499999999999}, {'accuracy': 0.91217}, {'accuracy': 0.91019}, {'accuracy': 0.9090200000000002}, {'accuracy': 0.9031499999999999}, {'accuracy': 0.8857099999999999}, {'accuracy': 0.9168}, {'accuracy': 0.90404}, {'accuracy': 0.9052}, {'accuracy': 0.9073100000000001}, {'accuracy': 0.9091999999999999}, {'accuracy': 0.93154}, {'accuracy': 0.89865}, {'accuracy': 0.9158600000000001}, {'accuracy': 0.90351}, {'accuracy': 0.91217}, {'accuracy': 0.91828}, {'accuracy': 0.92154}, {'accuracy': 0.9038999999999999}, {'accuracy': 0.9094299999999998}, {'accuracy': 0.9004399999999999}, {'accuracy': 0.9112}, {'accuracy': 0.9136200000000001}, {'accuracy': 0.91684}, {'accuracy': 0.9296200000000001}, {'accuracy': 0.92872}, {'accuracy': 0.91021}, {'accuracy': 0.7287399999999999}, {'accuracy': 0.88317}, {'accuracy': 0.88889}, {'accuracy': 0.90618}, {'accuracy': 0.8853099999999999}, {'accuracy': 0.9170800000000001}, {'accuracy': 0.91873}, {'accuracy': 0.91698}, {'accuracy': 0.91272}, {'accuracy': 0.91952}, {'accuracy': 0.92874}, {'accuracy': 0.92128}, {'accuracy': 0.9319}, {'accuracy': 0.93165}, {'accuracy': 0.92445}, {'accuracy': 0.9210499999999999}, {'accuracy': 0.9365500000000001}, {'accuracy': 0.9131499999999999}, {'accuracy': 0.9121500000000001}, {'accuracy': 0.93581}, {'accuracy': 0.93897}, {'accuracy': 0.9221299999999999}, {'accuracy': 0.9158499999999998}, {'accuracy': 0.92612}, {'accuracy': 0.94174}, {'accuracy': 0.94338}, {'accuracy': 0.9445200000000001}, {'accuracy': 0.93597}, {'accuracy': 0.9305999999999999}, {'accuracy': 0.93567}, {'accuracy': 0.94629}, {'accuracy': 0.9406800000000001}, {'accuracy': 0.91516}, {'accuracy': 0.9325100000000001}, {'accuracy': 0.9518099999999998}, {'accuracy': 0.9214800000000001}, {'accuracy': 0.9400300000000001}, {'accuracy': 0.9401399999999999}, {'accuracy': 0.9103999999999999}, {'accuracy': 0.9383699999999999}, {'accuracy': 0.9486399999999999}, {'accuracy': 0.9498700000000001}, {'accuracy': 0.9342600000000001}, {'accuracy': 0.94503}, {'accuracy': 0.9468799999999999}, {'accuracy': 0.93628}, {'accuracy': 0.93567}, {'accuracy': 0.9164100000000002}, {'accuracy': 0.92849}, {'accuracy': 0.94641}]\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": "badcd6ec-9721-42c9-9dd5-9b5130db3188",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5b6fe361-f901-46d7-9d2c-4115348e2c32",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7841fd69-ca01-4606-a24f-d738656aec1a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "151842d7-05ec-44b1-82bb-92dbed36c21e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dd4be85c-5795-46fb-8434-b59ad99bbc2f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f3febeee-f8ca-40d2-b2fa-9257dca9b1a5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9435d333-9fd0-43fe-8203-4a062429ab27",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aac1a87e-107e-4842-a7a3-f99e82fa9ca0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be44aec2-6d98-4d43-a452-057523dad8ba",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "93a8809a-c501-4fcc-a7a1-769fe98a8447",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4f83642b-f51a-42fa-b37b-73a7b6bd3f37",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1c62a3ea-e703-4b1d-a1ba-d21b9fe55c14",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2b172bf4-fce6-44aa-87f5-37ba90fb00e1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "084269bd-7f55-4358-a040-2be8111a6ab5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e14e8c3e-d66b-4572-94a9-e4acde017711",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "05c5e711-9e1b-497e-adf3-e53c7b37020b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f160c4f5-fa92-41d0-b844-2e3198a3055e",
   "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
}
