{
 "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 Famnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(in_channels=1, out_channels=32, kernel_size=3, padding=1)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(32, 64, kernel_size=3)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(64*6*6, 600)\n",
    "        self.fc2 = nn.Linear(in_features=600, out_features=120)\n",
    "        self.fc3 = nn.Linear(in_features=120, out_features=10)\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(x.size(0), -1)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        x=self.fc3(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n",
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_FashionMNIST()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2454]\n",
      " [   1   52]\n",
      " [   2   46]\n",
      " [   3   63]\n",
      " [   4  114]\n",
      " [   5  185]\n",
      " [   6  297]\n",
      " [   7  503]\n",
      " [   8  841]\n",
      " [   9 1391]]\n",
      "[[   0 1421]\n",
      " [   1 2452]\n",
      " [   2   67]\n",
      " [   3   31]\n",
      " [   4   56]\n",
      " [   5  117]\n",
      " [   6  193]\n",
      " [   7  304]\n",
      " [   8  500]\n",
      " [   9  876]]\n",
      "[[   0  841]\n",
      " [   1 1437]\n",
      " [   2 2363]\n",
      " [   3   65]\n",
      " [   4   41]\n",
      " [   5   74]\n",
      " [   6  116]\n",
      " [   7  234]\n",
      " [   8  308]\n",
      " [   9  498]]\n",
      "[[   0  488]\n",
      " [   1  840]\n",
      " [   2 1425]\n",
      " [   3 2370]\n",
      " [   4   67]\n",
      " [   5   38]\n",
      " [   6   83]\n",
      " [   7  115]\n",
      " [   8  212]\n",
      " [   9  303]]\n",
      "[[   0  323]\n",
      " [   1  492]\n",
      " [   2  865]\n",
      " [   3 1417]\n",
      " [   4 2367]\n",
      " [   5   59]\n",
      " [   6   46]\n",
      " [   7   82]\n",
      " [   8  101]\n",
      " [   9  201]]\n",
      "[[   0  175]\n",
      " [   1  286]\n",
      " [   2  516]\n",
      " [   3  909]\n",
      " [   4 1420]\n",
      " [   5 2442]\n",
      " [   6   57]\n",
      " [   7   30]\n",
      " [   8   61]\n",
      " [   9   92]]\n",
      "[[   0  124]\n",
      " [   1  190]\n",
      " [   2  296]\n",
      " [   3  520]\n",
      " [   4  872]\n",
      " [   5 1429]\n",
      " [   6 2403]\n",
      " [   7   59]\n",
      " [   8   47]\n",
      " [   9   86]]\n",
      "[[   0   73]\n",
      " [   1  133]\n",
      " [   2  213]\n",
      " [   3  340]\n",
      " [   4  537]\n",
      " [   5  863]\n",
      " [   6 1419]\n",
      " [   7 2416]\n",
      " [   8   76]\n",
      " [   9   44]]\n",
      "[[   0   44]\n",
      " [   1   71]\n",
      " [   2  147]\n",
      " [   3  172]\n",
      " [   4  337]\n",
      " [   5  488]\n",
      " [   6  895]\n",
      " [   7 1437]\n",
      " [   8 2445]\n",
      " [   9   69]]\n",
      "[[   0   57]\n",
      " [   1   47]\n",
      " [   2   62]\n",
      " [   3  113]\n",
      " [   4  189]\n",
      " [   5  305]\n",
      " [   6  491]\n",
      " [   7  820]\n",
      " [   8 1409]\n",
      " [   9 2440]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 0, 0,  ..., 3, 0, 5])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,60000,1):\n",
    "    if train_set[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif train_set[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif train_set[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif train_set[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif train_set[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif train_set[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif train_set[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif train_set[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif train_set[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif train_set[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "train_set[1][label[1]]\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(train_set[0][label[0][z]])\n",
    "        list0[1].append(train_set[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(train_set[0][label[0][z]])\n",
    "        list1[1].append(train_set[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(train_set[0][label[0][z]])\n",
    "        list2[1].append(train_set[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(train_set[0][label[0][z]])\n",
    "        list3[1].append(train_set[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(train_set[0][label[0][z]])\n",
    "        list4[1].append(train_set[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(train_set[0][label[0][z]])\n",
    "        list5[1].append(train_set[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(train_set[0][label[0][z]])\n",
    "        list6[1].append(train_set[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(train_set[0][label[0][z]])\n",
    "        list7[1].append(train_set[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(train_set[0][label[0][z]])\n",
    "        list8[1].append(train_set[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(train_set[0][label[0][z]])\n",
    "        list9[1].append(train_set[1][label[0][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(train_set[0][label[1][z]])\n",
    "        list1[1].append(train_set[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(train_set[0][label[1][z]])\n",
    "        list2[1].append(train_set[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(train_set[0][label[1][z]])\n",
    "        list3[1].append(train_set[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(train_set[0][label[1][z]])\n",
    "        list4[1].append(train_set[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(train_set[0][label[1][z]])\n",
    "        list5[1].append(train_set[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(train_set[0][label[1][z]])\n",
    "        list6[1].append(train_set[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(train_set[0][label[1][z]])\n",
    "        list7[1].append(train_set[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(train_set[0][label[1][z]])\n",
    "        list8[1].append(train_set[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(train_set[0][label[1][z]])\n",
    "        list9[1].append(train_set[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(train_set[0][label[1][z]])\n",
    "        list0[1].append(train_set[1][label[1][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(train_set[0][label[2][z]])\n",
    "        list2[1].append(train_set[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(train_set[0][label[2][z]])\n",
    "        list3[1].append(train_set[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(train_set[0][label[2][z]])\n",
    "        list4[1].append(train_set[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(train_set[0][label[2][z]])\n",
    "        list5[1].append(train_set[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(train_set[0][label[2][z]])\n",
    "        list6[1].append(train_set[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(train_set[0][label[2][z]])\n",
    "        list7[1].append(train_set[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(train_set[0][label[2][z]])\n",
    "        list8[1].append(train_set[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(train_set[0][label[2][z]])\n",
    "        list9[1].append(train_set[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(train_set[0][label[2][z]])\n",
    "        list0[1].append(train_set[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(train_set[0][label[2][z]])\n",
    "        list1[1].append(train_set[1][label[2][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(train_set[0][label[3][z]])\n",
    "        list3[1].append(train_set[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(train_set[0][label[3][z]])\n",
    "        list4[1].append(train_set[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(train_set[0][label[3][z]])\n",
    "        list5[1].append(train_set[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(train_set[0][label[3][z]])\n",
    "        list6[1].append(train_set[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(train_set[0][label[3][z]])\n",
    "        list7[1].append(train_set[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(train_set[0][label[3][z]])\n",
    "        list8[1].append(train_set[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(train_set[0][label[3][z]])\n",
    "        list9[1].append(train_set[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(train_set[0][label[3][z]])\n",
    "        list0[1].append(train_set[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(train_set[0][label[3][z]])\n",
    "        list1[1].append(train_set[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(train_set[0][label[3][z]])\n",
    "        list2[1].append(train_set[1][label[3][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(train_set[0][label[4][z]])\n",
    "        list4[1].append(train_set[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(train_set[0][label[4][z]])\n",
    "        list5[1].append(train_set[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(train_set[0][label[4][z]])\n",
    "        list6[1].append(train_set[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(train_set[0][label[4][z]])\n",
    "        list7[1].append(train_set[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(train_set[0][label[4][z]])\n",
    "        list8[1].append(train_set[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(train_set[0][label[4][z]])\n",
    "        list9[1].append(train_set[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(train_set[0][label[4][z]])\n",
    "        list0[1].append(train_set[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(train_set[0][label[4][z]])\n",
    "        list1[1].append(train_set[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(train_set[0][label[4][z]])\n",
    "        list2[1].append(train_set[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(train_set[0][label[4][z]])\n",
    "        list3[1].append(train_set[1][label[4][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(train_set[0][label[5][z]])\n",
    "        list5[1].append(train_set[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(train_set[0][label[5][z]])\n",
    "        list6[1].append(train_set[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(train_set[0][label[5][z]])\n",
    "        list7[1].append(train_set[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(train_set[0][label[5][z]])\n",
    "        list8[1].append(train_set[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(train_set[0][label[5][z]])\n",
    "        list9[1].append(train_set[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(train_set[0][label[5][z]])\n",
    "        list0[1].append(train_set[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(train_set[0][label[5][z]])\n",
    "        list1[1].append(train_set[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(train_set[0][label[5][z]])\n",
    "        list2[1].append(train_set[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(train_set[0][label[5][z]])\n",
    "        list3[1].append(train_set[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(train_set[0][label[5][z]])\n",
    "        list4[1].append(train_set[1][label[5][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(train_set[0][label[6][z]])\n",
    "        list6[1].append(train_set[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(train_set[0][label[6][z]])\n",
    "        list7[1].append(train_set[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(train_set[0][label[6][z]])\n",
    "        list8[1].append(train_set[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(train_set[0][label[6][z]])\n",
    "        list9[1].append(train_set[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(train_set[0][label[6][z]])\n",
    "        list0[1].append(train_set[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(train_set[0][label[6][z]])\n",
    "        list1[1].append(train_set[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(train_set[0][label[6][z]])\n",
    "        list2[1].append(train_set[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(train_set[0][label[6][z]])\n",
    "        list3[1].append(train_set[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(train_set[0][label[6][z]])\n",
    "        list4[1].append(train_set[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(train_set[0][label[6][z]])\n",
    "        list5[1].append(train_set[1][label[6][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(train_set[0][label[7][z]])\n",
    "        list7[1].append(train_set[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(train_set[0][label[7][z]])\n",
    "        list8[1].append(train_set[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(train_set[0][label[7][z]])\n",
    "        list9[1].append(train_set[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(train_set[0][label[7][z]])\n",
    "        list0[1].append(train_set[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(train_set[0][label[7][z]])\n",
    "        list1[1].append(train_set[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(train_set[0][label[7][z]])\n",
    "        list2[1].append(train_set[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(train_set[0][label[7][z]])\n",
    "        list3[1].append(train_set[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(train_set[0][label[7][z]])\n",
    "        list4[1].append(train_set[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(train_set[0][label[7][z]])\n",
    "        list5[1].append(train_set[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(train_set[0][label[7][z]])\n",
    "        list6[1].append(train_set[1][label[7][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(train_set[0][label[8][z]])\n",
    "        list8[1].append(train_set[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(train_set[0][label[8][z]])\n",
    "        list9[1].append(train_set[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(train_set[0][label[8][z]])\n",
    "        list0[1].append(train_set[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(train_set[0][label[8][z]])\n",
    "        list1[1].append(train_set[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(train_set[0][label[8][z]])\n",
    "        list2[1].append(train_set[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(train_set[0][label[8][z]])\n",
    "        list3[1].append(train_set[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(train_set[0][label[8][z]])\n",
    "        list4[1].append(train_set[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(train_set[0][label[8][z]])\n",
    "        list5[1].append(train_set[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(train_set[0][label[8][z]])\n",
    "        list6[1].append(train_set[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(train_set[0][label[8][z]])\n",
    "        list7[1].append(train_set[1][label[8][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(train_set[0][label[9][z]])\n",
    "        list9[1].append(train_set[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(train_set[0][label[9][z]])\n",
    "        list0[1].append(train_set[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(train_set[0][label[9][z]])\n",
    "        list1[1].append(train_set[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(train_set[0][label[9][z]])\n",
    "        list2[1].append(train_set[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(train_set[0][label[9][z]])\n",
    "        list3[1].append(train_set[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(train_set[0][label[9][z]])\n",
    "        list4[1].append(train_set[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(train_set[0][label[9][z]])\n",
    "        list5[1].append(train_set[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(train_set[0][label[9][z]])\n",
    "        list6[1].append(train_set[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(train_set[0][label[9][z]])\n",
    "        list7[1].append(train_set[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(train_set[0][label[9][z]])\n",
    "        list8[1].append(train_set[1][label[9][z]])  \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list1[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list3[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list4[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list5[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "d212199d-c71b-46e8-8602-14f2e1d5f0ab",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<3:\n",
    "        if tag1[z]==6:\n",
    "            tag1[z]=0\n",
    "        elif tag1[z]==0:\n",
    "            tag1[z]=6        \n",
    "        elif tag1[z]==2:\n",
    "            tag1[z]=4     \n",
    "        elif tag1[z]==4:\n",
    "            tag1[z]=2   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([6, 0, 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=Famnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.74</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:181</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.74\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m181\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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ywsbNmyQjtmwYQNiY2PRo0cPAEBqaioEQcBLL72EgIAA2Wvx4sUAgLy8PNl1unbt2uDaVVVVWLRokVTz4u/vj4CAAJSUlKC0tPQyP3nznDlzBps2bWrQ/vj4eFn7586dix49euCmm25CeHg4HnroIWzatOmKr+/k5CTVHlm3qbS0FIGBgQ3aVVFRIbVp1KhRuOuuu/DKK6/A398fkyZNwtq1a6HX66+4XZeydOlSHD9+HBERERg6dChefvllnD17ttWvS9TWWHND1A55eXkhJCQER48ebfK4o0ePIiwsDJ6engAAjUaDO+64A9999x3ef/995ObmYteuXXj99del94gFt8888wwmTpxo87wxMTGy762zNKJ//OMfWLt2LZ588kkMHz4cXl5eUCgUuPfeexsU9dqbyWTC+PHj8dxzz9ncLwZygYGBOHLkCDZv3ozffvsNv/32G9auXYvp06fjk08+uezrazQaKJXyvw1NJhMCAwPx+eef23yPWBSuUCiwceNG7NmzBz/99BM2b96Mhx56CO+88w727NkDd3f3RiflMxqNl91mALjnnnswcuRIfPfdd/j999/x1ltv4c0338S3336Lm2666YrOTdSeMLghaqduvfVWrF69Gjt37sSIESMa7P/zzz+Rnp6OOXPmyLZPnToVn3zyCRISEpCcnAxBEKQuKQDSsHFnZ2cp03E5Nm7ciBkzZuCdd96RtlVXV6OkpOSyz1lfYw/56OhoVFRUNKv9arUat912G2677TaYTCbMnTsXH374IV566SXExMTYbXbf6OhobN26Fddff73NYLC+a6+9Ftdeey1ee+01fPHFF7jvvvuwfv16zJo1Cz4+PgDQ4F6eP3++WW1p6jOFhIRg7ty5mDt3LvLy8jB48GC89tprDG6oQ2G3FFE79eyzz8LFxQVz5sxBYWGhbF9RUREeeeQRuLq64tlnn5Xti4+Ph6+vLzZs2IANGzZg6NChsm6lwMBAjB49Gh9++CGys7MbXDc/P79Z7VOpVBAEQbbt3XffveLsgjU3NzebwdI999yDpKQkbN68ucG+kpIS1NbWAkCD+6ZUKjFgwAAAkLqBxPlprjQou+eee2A0GvHqq6822FdbWyudv7i4uMF9i42NlbWpS5cuUKlUUu2Q6P33329WW2zdN6PR2KC7MDAwEKGhoW3SJUbUlpi5IWqnunfv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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.10001}, {'accuracy': 0.13959000000000005}, {'accuracy': 0.19814}, {'accuracy': 0.21545}, {'accuracy': 0.27882}, {'accuracy': 0.31543}, {'accuracy': 0.2547}, {'accuracy': 0.29469}, {'accuracy': 0.30771999999999994}, {'accuracy': 0.31653}, {'accuracy': 0.34113000000000004}, {'accuracy': 0.35929}, {'accuracy': 0.33924}, {'accuracy': 0.37588}, {'accuracy': 0.40164999999999995}, {'accuracy': 0.43014}, {'accuracy': 0.39362}, {'accuracy': 0.39041000000000003}, {'accuracy': 0.43993000000000004}, {'accuracy': 0.38534}, {'accuracy': 0.4426}, {'accuracy': 0.50546}, {'accuracy': 0.50518}, {'accuracy': 0.50078}, {'accuracy': 0.48932000000000003}, {'accuracy': 0.44431999999999994}, {'accuracy': 0.46432}, {'accuracy': 0.49484000000000006}, {'accuracy': 0.5432199999999999}, {'accuracy': 0.53106}, {'accuracy': 0.57113}, {'accuracy': 0.531}, {'accuracy': 0.5418100000000001}, {'accuracy': 0.52177}, {'accuracy': 0.56332}, {'accuracy': 0.58201}, {'accuracy': 0.5399100000000001}, {'accuracy': 0.58957}, {'accuracy': 0.5552499999999999}, {'accuracy': 0.56499}, {'accuracy': 0.6085900000000001}, {'accuracy': 0.5699700000000001}, {'accuracy': 0.59301}, {'accuracy': 0.57507}, {'accuracy': 0.5765300000000001}, {'accuracy': 0.56038}, {'accuracy': 0.58912}, {'accuracy': 0.5723699999999999}, {'accuracy': 0.58493}, {'accuracy': 0.5784100000000001}, {'accuracy': 0.5868800000000001}, {'accuracy': 0.5996}, {'accuracy': 0.58754}, {'accuracy': 0.6135700000000001}, {'accuracy': 0.6185499999999999}, {'accuracy': 0.5896399999999999}, {'accuracy': 0.5921299999999999}, {'accuracy': 0.6288600000000001}, {'accuracy': 0.61019}, {'accuracy': 0.61321}, {'accuracy': 0.63175}, {'accuracy': 0.62887}, {'accuracy': 0.6252899999999999}, {'accuracy': 0.60686}, {'accuracy': 0.6287}, {'accuracy': 0.62405}, {'accuracy': 0.6165499999999999}, {'accuracy': 0.64283}, {'accuracy': 0.63091}, {'accuracy': 0.6547}, {'accuracy': 0.64137}, {'accuracy': 0.6533899999999999}, {'accuracy': 0.6607099999999999}, {'accuracy': 0.6524}, {'accuracy': 0.6437899999999999}, {'accuracy': 0.64702}, {'accuracy': 0.61969}, {'accuracy': 0.6527700000000001}, {'accuracy': 0.6600299999999999}, {'accuracy': 0.64369}, {'accuracy': 0.62765}, {'accuracy': 0.65012}, {'accuracy': 0.63821}, {'accuracy': 0.67484}, {'accuracy': 0.64856}, {'accuracy': 0.63922}, {'accuracy': 0.6501}, {'accuracy': 0.6681}, {'accuracy': 0.6548}, {'accuracy': 0.65147}, {'accuracy': 0.6429}, {'accuracy': 0.6449}, {'accuracy': 0.6464899999999999}, {'accuracy': 0.66369}, {'accuracy': 0.6581499999999999}, {'accuracy': 0.65176}, {'accuracy': 0.6677899999999999}, {'accuracy': 0.6856500000000001}, {'accuracy': 0.69243}, {'accuracy': 0.63867}, {'accuracy': 0.65699}, {'accuracy': 0.66458}, {'accuracy': 0.67256}, {'accuracy': 0.67843}, {'accuracy': 0.66488}, {'accuracy': 0.6787}, {'accuracy': 0.66939}, {'accuracy': 0.6566799999999999}, {'accuracy': 0.69246}, {'accuracy': 0.6574}, {'accuracy': 0.6672499999999999}, {'accuracy': 0.67246}, {'accuracy': 0.66246}, {'accuracy': 0.6690799999999999}, {'accuracy': 0.6643299999999999}, {'accuracy': 0.6907699999999999}, {'accuracy': 0.6867099999999999}, {'accuracy': 0.69621}, {'accuracy': 0.6824200000000001}, {'accuracy': 0.70225}, {'accuracy': 0.69251}, {'accuracy': 0.6958799999999999}, {'accuracy': 0.6576599999999999}, {'accuracy': 0.6919}, {'accuracy': 0.66587}, {'accuracy': 0.6484399999999999}, {'accuracy': 0.65829}, {'accuracy': 0.6806500000000001}, {'accuracy': 0.68262}, {'accuracy': 0.66769}, {'accuracy': 0.64966}, {'accuracy': 0.6551199999999999}, {'accuracy': 0.6932699999999999}, {'accuracy': 0.6994100000000001}, {'accuracy': 0.70709}, {'accuracy': 0.6811}, {'accuracy': 0.65226}, {'accuracy': 0.68188}, {'accuracy': 0.66891}, {'accuracy': 0.68323}, {'accuracy': 0.7031400000000001}, {'accuracy': 0.68174}, {'accuracy': 0.67927}, {'accuracy': 0.6588799999999999}, {'accuracy': 0.6750900000000001}, {'accuracy': 0.68475}, {'accuracy': 0.68136}, {'accuracy': 0.66365}, {'accuracy': 0.66335}, {'accuracy': 0.6959299999999999}, {'accuracy': 0.69612}, {'accuracy': 0.7060199999999999}, {'accuracy': 0.64706}, {'accuracy': 0.69074}, {'accuracy': 0.68687}, {'accuracy': 0.66741}, {'accuracy': 0.66001}, {'accuracy': 0.6841400000000001}, {'accuracy': 0.6880200000000001}, {'accuracy': 0.66257}, {'accuracy': 0.72723}, {'accuracy': 0.6820300000000001}, {'accuracy': 0.6908299999999999}, {'accuracy': 0.68916}, {'accuracy': 0.65648}, {'accuracy': 0.67908}, {'accuracy': 0.6703699999999999}, {'accuracy': 0.67795}, {'accuracy': 0.69592}, {'accuracy': 0.6644300000000001}, {'accuracy': 0.68013}, {'accuracy': 0.69188}, {'accuracy': 0.7179500000000001}, {'accuracy': 0.69668}, {'accuracy': 0.70292}, {'accuracy': 0.67157}, {'accuracy': 0.7122499999999999}, {'accuracy': 0.6867000000000001}, {'accuracy': 0.6582899999999998}, {'accuracy': 0.67444}, {'accuracy': 0.72651}, {'accuracy': 0.72072}, {'accuracy': 0.7148199999999999}, {'accuracy': 0.6834100000000001}, {'accuracy': 0.7036800000000001}, {'accuracy': 0.68496}, {'accuracy': 0.70398}, {'accuracy': 0.68211}, {'accuracy': 0.69916}, {'accuracy': 0.71401}, {'accuracy': 0.70384}, {'accuracy': 0.6752400000000001}, {'accuracy': 0.69632}, {'accuracy': 0.6608099999999999}, {'accuracy': 0.6827099999999999}, {'accuracy': 0.70332}, {'accuracy': 0.7120599999999999}, {'accuracy': 0.72383}, {'accuracy': 0.6935300000000001}, {'accuracy': 0.6783499999999999}, {'accuracy': 0.6803}, {'accuracy': 0.6816099999999999}, {'accuracy': 0.72501}, {'accuracy': 0.72517}, {'accuracy': 0.7381500000000001}, {'accuracy': 0.7426600000000001}, {'accuracy': 0.73609}, {'accuracy': 0.7373800000000001}, {'accuracy': 0.7227499999999999}, {'accuracy': 0.73323}, {'accuracy': 0.7263}, {'accuracy': 0.7144400000000001}, {'accuracy': 0.7313500000000001}, {'accuracy': 0.7448499999999999}, {'accuracy': 0.74142}, {'accuracy': 0.73433}, {'accuracy': 0.73125}, {'accuracy': 0.74267}, {'accuracy': 0.72743}, {'accuracy': 0.72587}, {'accuracy': 0.72546}, {'accuracy': 0.73326}, {'accuracy': 0.7294}, {'accuracy': 0.7310299999999998}, {'accuracy': 0.74562}, {'accuracy': 0.73002}, {'accuracy': 0.7355999999999999}, {'accuracy': 0.73485}, {'accuracy': 0.73845}, {'accuracy': 0.7362799999999999}, {'accuracy': 0.74781}, {'accuracy': 0.73708}, {'accuracy': 0.73335}, {'accuracy': 0.7311300000000001}, {'accuracy': 0.73762}, {'accuracy': 0.7419499999999999}, {'accuracy': 0.74061}, {'accuracy': 0.73598}, {'accuracy': 0.72107}, {'accuracy': 0.7273099999999999}, {'accuracy': 0.7359600000000001}, {'accuracy': 0.74933}, {'accuracy': 0.73727}, {'accuracy': 0.73232}, {'accuracy': 0.73197}, {'accuracy': 0.73492}, {'accuracy': 0.74206}, {'accuracy': 0.73429}, {'accuracy': 0.7484300000000002}, {'accuracy': 0.7437199999999999}, {'accuracy': 0.7380699999999999}, {'accuracy': 0.7249099999999999}, {'accuracy': 0.74182}, {'accuracy': 0.7394200000000001}, {'accuracy': 0.7395499999999999}, {'accuracy': 0.73092}, {'accuracy': 0.72459}, {'accuracy': 0.7238100000000001}, {'accuracy': 0.7372000000000001}, {'accuracy': 0.7361200000000001}, {'accuracy': 0.73618}, {'accuracy': 0.7404}, {'accuracy': 0.73549}, {'accuracy': 0.7440300000000001}, {'accuracy': 0.74095}, {'accuracy': 0.73557}, {'accuracy': 0.74401}, {'accuracy': 0.73344}, {'accuracy': 0.7332599999999999}, {'accuracy': 0.73605}, {'accuracy': 0.74352}, {'accuracy': 0.7484299999999999}, {'accuracy': 0.73211}, {'accuracy': 0.74004}, {'accuracy': 0.7368499999999999}, {'accuracy': 0.74943}, {'accuracy': 0.74402}, {'accuracy': 0.7372}, {'accuracy': 0.74543}, {'accuracy': 0.73729}, {'accuracy': 0.7506299999999999}, {'accuracy': 0.74631}, {'accuracy': 0.7467400000000002}, {'accuracy': 0.7408500000000001}, {'accuracy': 0.73322}, {'accuracy': 0.7402799999999999}, {'accuracy': 0.73651}, {'accuracy': 0.75173}, {'accuracy': 0.7322899999999999}, {'accuracy': 0.74653}, {'accuracy': 0.73837}, {'accuracy': 0.7409399999999999}, {'accuracy': 0.7455900000000001}, {'accuracy': 0.73822}, {'accuracy': 0.7403299999999999}, {'accuracy': 0.73685}, {'accuracy': 0.74105}, {'accuracy': 0.74283}, {'accuracy': 0.75313}, {'accuracy': 0.7411199999999999}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dbef4f25-a311-4e52-87d2-b1f79873b9d7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "81819e42-77ef-4c29-bd00-95dbf29e49be",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2f2edf35-501e-4e5f-8625-18550720b217",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "315fe4ce-abe7-45a2-a308-ca8a1c93e5a4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "08bce72d-9f8a-48ea-8d1e-aa05df93828f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d4a98c76-5314-45fa-b138-b590b4c43448",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d132cfef-f45a-413b-aa96-13223ad46f7f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c0567fdb-df88-44f4-beb1-d312ecc61cda",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c936f45a-963f-4dd9-ae64-673682d54ee1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a6fc8e28-8453-4732-98e0-050bd9387716",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d47049ab-17c9-4cc2-8afd-84f69ab73c0d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fca4afcc-8885-4456-8cf8-676e02fe5d8d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5cf5efda-ffdd-4abe-8070-9aacff1a9235",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f642baa3-876b-4e92-81a2-9f884aced573",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5af09a63-ef18-4ba1-b153-f7da056f1364",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3ffa2b2b-58a1-43e9-bcf0-bb5adb7510d6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "16ffa705-1c0a-4fdd-8712-a17b9dd41771",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "489da6a5-7526-4c6a-9d18-ce182ba66d32",
   "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
}
