{
 "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(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 2320]\n",
      " [   1   65]\n",
      " [   2   44]\n",
      " [   3   79]\n",
      " [   4  122]\n",
      " [   5  170]\n",
      " [   6  310]\n",
      " [   7  552]\n",
      " [   8  863]\n",
      " [   9 1399]]\n",
      "[[   0 1405]\n",
      " [   1 2650]\n",
      " [   2   56]\n",
      " [   3   35]\n",
      " [   4   60]\n",
      " [   5   90]\n",
      " [   6  184]\n",
      " [   7  340]\n",
      " [   8  467]\n",
      " [   9  851]]\n",
      "[[   0  887]\n",
      " [   1 1645]\n",
      " [   2 2380]\n",
      " [   3   58]\n",
      " [   4   39]\n",
      " [   5   56]\n",
      " [   6  127]\n",
      " [   7  215]\n",
      " [   8  299]\n",
      " [   9  515]]\n",
      "[[   0  521]\n",
      " [   1  981]\n",
      " [   2 1471]\n",
      " [   3 2503]\n",
      " [   4   51]\n",
      " [   5   46]\n",
      " [   6   68]\n",
      " [   7  115]\n",
      " [   8  197]\n",
      " [   9  279]]\n",
      "[[   0  323]\n",
      " [   1  573]\n",
      " [   2  831]\n",
      " [   3 1447]\n",
      " [   4 2354]\n",
      " [   5   59]\n",
      " [   6   30]\n",
      " [   7   75]\n",
      " [   8  120]\n",
      " [   9  181]]\n",
      "[[   0  185]\n",
      " [   1  365]\n",
      " [   2  511]\n",
      " [   3  887]\n",
      " [   4 1412]\n",
      " [   5 2150]\n",
      " [   6   57]\n",
      " [   7   48]\n",
      " [   8   58]\n",
      " [   9  104]]\n",
      "[[   0  109]\n",
      " [   1  209]\n",
      " [   2  306]\n",
      " [   3  541]\n",
      " [   4  804]\n",
      " [   5 1289]\n",
      " [   6 2356]\n",
      " [   7   64]\n",
      " [   8   46]\n",
      " [   9   75]]\n",
      "[[   0   64]\n",
      " [   1  128]\n",
      " [   2  186]\n",
      " [   3  294]\n",
      " [   4  498]\n",
      " [   5  786]\n",
      " [   6 1391]\n",
      " [   7 2467]\n",
      " [   8   70]\n",
      " [   9   46]]\n",
      "[[   0   48]\n",
      " [   1   81]\n",
      " [   2  107]\n",
      " [   3  174]\n",
      " [   4  320]\n",
      " [   5  482]\n",
      " [   6  860]\n",
      " [   7 1508]\n",
      " [   8 2338]\n",
      " [   9   62]]\n",
      "[[   0   61]\n",
      " [   1   45]\n",
      " [   2   66]\n",
      " [   3  113]\n",
      " [   4  182]\n",
      " [   5  293]\n",
      " [   6  535]\n",
      " [   7  881]\n",
      " [   8 1393]\n",
      " [   9 2437]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([5, 0, 4,  ..., 5, 6, 8])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\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<1:\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, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": [
    "\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= 30,\n",
    "        local_epochs= 5),\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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "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.16976}, {'accuracy': 0.26861}, {'accuracy': 0.38685}, {'accuracy': 0.40465999999999996}, {'accuracy': 0.4133}, {'accuracy': 0.41944}, {'accuracy': 0.49172000000000005}, {'accuracy': 0.5063700000000001}, {'accuracy': 0.54007}, {'accuracy': 0.61322}, {'accuracy': 0.58062}, {'accuracy': 0.62644}, {'accuracy': 0.6698799999999999}, {'accuracy': 0.6857900000000001}, {'accuracy': 0.7382199999999999}, {'accuracy': 0.76927}, {'accuracy': 0.7463599999999999}, {'accuracy': 0.76794}, {'accuracy': 0.7864500000000001}, {'accuracy': 0.8071800000000001}, {'accuracy': 0.7960500000000001}, {'accuracy': 0.81411}, {'accuracy': 0.79268}, {'accuracy': 0.82211}, {'accuracy': 0.8389}, {'accuracy': 0.7979800000000001}, {'accuracy': 0.82208}, {'accuracy': 0.8701000000000001}, {'accuracy': 0.8892300000000001}, {'accuracy': 0.86}, {'accuracy': 0.8833200000000001}, {'accuracy': 0.8557799999999999}, {'accuracy': 0.8587299999999999}, {'accuracy': 0.92114}, {'accuracy': 0.8815099999999999}, {'accuracy': 0.88978}, {'accuracy': 0.90635}, {'accuracy': 0.91084}, {'accuracy': 0.88852}, {'accuracy': 0.9265799999999998}, {'accuracy': 0.9073100000000001}, {'accuracy': 0.9323500000000001}, {'accuracy': 0.9179699999999998}, {'accuracy': 0.9132200000000001}, {'accuracy': 0.9316600000000002}, {'accuracy': 0.9112499999999999}, {'accuracy': 0.92136}, {'accuracy': 0.9075300000000001}, {'accuracy': 0.9319000000000001}, {'accuracy': 0.9395899999999999}, {'accuracy': 0.9241999999999999}, {'accuracy': 0.9237900000000001}, {'accuracy': 0.9313}, {'accuracy': 0.9436899999999999}, {'accuracy': 0.94429}, {'accuracy': 0.9407399999999999}, {'accuracy': 0.94969}, {'accuracy': 0.9384899999999998}, {'accuracy': 0.9407499999999999}, {'accuracy': 0.95145}, {'accuracy': 0.94505}, {'accuracy': 0.94173}, {'accuracy': 0.9366800000000002}, {'accuracy': 0.93819}, {'accuracy': 0.94679}, {'accuracy': 0.94126}, {'accuracy': 0.9521200000000001}, {'accuracy': 0.9626999999999999}, {'accuracy': 0.9469999999999998}, {'accuracy': 0.9363900000000001}, {'accuracy': 0.9439500000000003}, {'accuracy': 0.9404800000000002}, {'accuracy': 0.9537000000000001}, {'accuracy': 0.9426399999999999}, {'accuracy': 0.9497199999999999}, {'accuracy': 0.96167}, {'accuracy': 0.95672}, {'accuracy': 0.94893}, {'accuracy': 0.95023}, {'accuracy': 0.9423600000000001}, {'accuracy': 0.9490700000000001}, {'accuracy': 0.9522099999999998}, {'accuracy': 0.9578599999999999}, {'accuracy': 0.9504800000000001}, {'accuracy': 0.95228}, {'accuracy': 0.95063}, {'accuracy': 0.9492900000000001}, {'accuracy': 0.9511099999999999}, {'accuracy': 0.9492999999999998}, {'accuracy': 0.95281}, {'accuracy': 0.94798}, {'accuracy': 0.9573}, {'accuracy': 0.9469899999999999}, {'accuracy': 0.94744}, {'accuracy': 0.9386300000000001}, {'accuracy': 0.96143}, {'accuracy': 0.94628}, {'accuracy': 0.9472299999999999}, {'accuracy': 0.94902}, {'accuracy': 0.94862}, {'accuracy': 0.9541999999999999}, {'accuracy': 0.9598599999999999}, {'accuracy': 0.9416799999999999}, {'accuracy': 0.95382}, {'accuracy': 0.9445399999999999}, {'accuracy': 0.95407}, {'accuracy': 0.95136}, {'accuracy': 0.9610900000000001}, {'accuracy': 0.9520299999999999}, {'accuracy': 0.9585899999999998}, {'accuracy': 0.9514000000000001}, {'accuracy': 0.95633}, {'accuracy': 0.9468399999999999}, {'accuracy': 0.9591800000000001}, {'accuracy': 0.9479400000000002}, {'accuracy': 0.94194}, {'accuracy': 0.9533400000000001}, {'accuracy': 0.9629200000000001}, {'accuracy': 0.9563900000000001}, {'accuracy': 0.9576800000000001}, {'accuracy': 0.95717}, {'accuracy': 0.9493999999999998}, {'accuracy': 0.9583999999999999}, {'accuracy': 0.9578200000000001}, {'accuracy': 0.9497}, {'accuracy': 0.95351}, {'accuracy': 0.9566399999999999}, {'accuracy': 0.9397800000000001}, {'accuracy': 0.9516500000000001}, {'accuracy': 0.9402899999999998}, {'accuracy': 0.9460999999999998}, {'accuracy': 0.95082}, {'accuracy': 0.95246}, {'accuracy': 0.9468}, {'accuracy': 0.9466700000000001}, {'accuracy': 0.9536499999999999}, {'accuracy': 0.9422599999999999}, {'accuracy': 0.9505100000000001}, {'accuracy': 0.9519400000000001}, {'accuracy': 0.9490000000000001}, {'accuracy': 0.95867}, {'accuracy': 0.9465}, {'accuracy': 0.95731}, {'accuracy': 0.94696}, {'accuracy': 0.9481299999999999}, {'accuracy': 0.9402799999999999}, {'accuracy': 0.94787}, {'accuracy': 0.9538}, {'accuracy': 0.94844}, {'accuracy': 0.95357}, {'accuracy': 0.9490700000000001}, {'accuracy': 0.96022}, {'accuracy': 0.9443800000000001}, {'accuracy': 0.9502099999999999}, {'accuracy': 0.94026}, {'accuracy': 0.9522499999999999}, {'accuracy': 0.9478399999999999}, {'accuracy': 0.95383}, {'accuracy': 0.9388500000000001}, {'accuracy': 0.95346}, {'accuracy': 0.9520500000000001}, {'accuracy': 0.9492199999999998}, {'accuracy': 0.94851}, {'accuracy': 0.9519799999999998}, {'accuracy': 0.9602499999999999}, {'accuracy': 0.9514799999999999}, {'accuracy': 0.9582}, {'accuracy': 0.9550700000000001}, {'accuracy': 0.9528700000000001}, {'accuracy': 0.95285}, {'accuracy': 0.94962}, {'accuracy': 0.9490999999999999}, {'accuracy': 0.9486000000000001}, {'accuracy': 0.94963}, {'accuracy': 0.9520099999999999}, {'accuracy': 0.9459799999999999}, {'accuracy': 0.9552200000000001}, {'accuracy': 0.94339}, {'accuracy': 0.94253}, {'accuracy': 0.9370499999999998}, {'accuracy': 0.94496}, {'accuracy': 0.9565300000000001}, {'accuracy': 0.95827}, {'accuracy': 0.96051}, {'accuracy': 0.94832}, {'accuracy': 0.94634}, {'accuracy': 0.94947}, {'accuracy': 0.9556800000000001}, {'accuracy': 0.9510499999999998}, {'accuracy': 0.9518899999999999}, {'accuracy': 0.95375}, {'accuracy': 0.9569599999999999}, {'accuracy': 0.9542900000000001}, {'accuracy': 0.9554599999999999}, {'accuracy': 0.9578200000000001}, {'accuracy': 0.9576800000000001}, {'accuracy': 0.9389800000000001}, {'accuracy': 0.95052}, {'accuracy': 0.94444}, {'accuracy': 0.9540900000000001}, {'accuracy': 0.97769}, {'accuracy': 0.9777799999999999}, {'accuracy': 0.97937}, {'accuracy': 0.9796199999999999}, {'accuracy': 0.9805599999999999}, {'accuracy': 0.9805299999999999}, {'accuracy': 0.9799299999999999}, {'accuracy': 0.9818299999999999}, {'accuracy': 0.98103}, {'accuracy': 0.98225}, {'accuracy': 0.9821099999999999}, {'accuracy': 0.9825999999999999}, {'accuracy': 0.9807}, {'accuracy': 0.98138}, {'accuracy': 0.9820799999999998}, {'accuracy': 0.98177}, {'accuracy': 0.9819700000000001}, {'accuracy': 0.98261}, {'accuracy': 0.9820500000000001}, {'accuracy': 0.9819800000000001}, {'accuracy': 0.9826499999999999}, {'accuracy': 0.9834000000000002}, {'accuracy': 0.9823299999999999}, {'accuracy': 0.98339}, {'accuracy': 0.9832600000000001}, {'accuracy': 0.9817199999999999}, {'accuracy': 0.98256}, {'accuracy': 0.98185}, {'accuracy': 0.98261}, {'accuracy': 0.98309}, {'accuracy': 0.9819100000000001}, {'accuracy': 0.9839200000000001}, {'accuracy': 0.9830799999999998}, {'accuracy': 0.98324}, {'accuracy': 0.98224}, {'accuracy': 0.9818200000000001}, {'accuracy': 0.9833400000000001}, {'accuracy': 0.9820200000000001}, {'accuracy': 0.9816499999999999}, {'accuracy': 0.9816900000000001}, {'accuracy': 0.9823999999999999}, {'accuracy': 0.9824299999999999}, {'accuracy': 0.98127}, {'accuracy': 0.98228}, {'accuracy': 0.98382}, {'accuracy': 0.9820099999999998}, {'accuracy': 0.98081}, {'accuracy': 0.9822900000000001}, {'accuracy': 0.9807799999999999}, {'accuracy': 0.9818899999999999}, {'accuracy': 0.9816800000000001}, {'accuracy': 0.9819399999999998}, {'accuracy': 0.98201}, {'accuracy': 0.98102}, {'accuracy': 0.9811100000000001}, {'accuracy': 0.98106}, {'accuracy': 0.9816800000000001}, {'accuracy': 0.9817}, {'accuracy': 0.98194}, {'accuracy': 0.98282}, {'accuracy': 0.9807600000000001}, {'accuracy': 0.98092}, {'accuracy': 0.98224}, {'accuracy': 0.97952}, {'accuracy': 0.98123}, {'accuracy': 0.9810500000000001}, {'accuracy': 0.9812700000000001}, {'accuracy': 0.9813500000000002}, {'accuracy': 0.9799700000000001}, {'accuracy': 0.9805499999999998}, {'accuracy': 0.9805100000000001}, {'accuracy': 0.9820399999999999}, {'accuracy': 0.9798500000000001}, {'accuracy': 0.9805999999999999}, {'accuracy': 0.9800600000000002}, {'accuracy': 0.9797800000000001}, {'accuracy': 0.97833}, {'accuracy': 0.98081}, {'accuracy': 0.98055}, {'accuracy': 0.9810099999999998}, {'accuracy': 0.9803799999999999}, {'accuracy': 0.9813599999999999}, {'accuracy': 0.98005}, {'accuracy': 0.9807900000000002}, {'accuracy': 0.98055}, {'accuracy': 0.98012}, {'accuracy': 0.9780000000000001}, {'accuracy': 0.98062}, {'accuracy': 0.9779}, {'accuracy': 0.97896}, {'accuracy': 0.9799899999999999}, {'accuracy': 0.9793900000000001}, {'accuracy': 0.97879}, {'accuracy': 0.9784200000000001}, {'accuracy': 0.9778100000000001}, {'accuracy': 0.9781600000000001}, {'accuracy': 0.97733}, {'accuracy': 0.9800799999999998}, {'accuracy': 0.9789899999999999}, {'accuracy': 0.9798199999999999}]\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": "6b3f37cb-3c2b-433e-aa3a-29594d54dcaa",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f5b62486-78e1-4518-be55-4e07960c812e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f061f9b9-06ac-4036-958b-4bfe427e62c4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9165b886-afe7-400f-ac42-541a4e91057e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "54774938-6784-450e-8fcf-7c6ae8fc1262",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c6b29e04-eec4-4e5f-a4df-89c3fe12645d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eb270e31-b9ab-4f49-aced-c547350a726f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed8b362e-3ee9-4884-b0a6-83b9c910b526",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ead464c1-9272-43a0-833f-c2d2738927ac",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "431af7e9-3887-43f3-bb82-8e0912ef41f3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f45dc738-8981-4d07-ba9d-5c750b4f0925",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5ca83c22-3b31-486b-8d4a-a9ac2f6f3ce5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bc026e89-796d-4887-b56a-7da151701d6e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7570d5a5-7da7-47ac-8f4b-783ca99b2dc8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "95856c11-648a-4448-8893-1c2a774286d3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "820611f7-008b-4f0f-a0a0-9bd4352d3272",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "16ca2861-3c77-4a45-9e2c-b7d8b4adaa4c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a319e2c1-3c88-4561-a349-79ef74aaa0bc",
   "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
}
