{
 "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 2419]\n",
      " [   1   59]\n",
      " [   2   37]\n",
      " [   3   65]\n",
      " [   4  103]\n",
      " [   5  185]\n",
      " [   6  309]\n",
      " [   7  518]\n",
      " [   8  894]\n",
      " [   9 1388]]\n",
      "[[   0 1456]\n",
      " [   1 2414]\n",
      " [   2   66]\n",
      " [   3   48]\n",
      " [   4   73]\n",
      " [   5  116]\n",
      " [   6  176]\n",
      " [   7  339]\n",
      " [   8  514]\n",
      " [   9  880]]\n",
      "[[   0  819]\n",
      " [   1 1475]\n",
      " [   2 2343]\n",
      " [   3   45]\n",
      " [   4   42]\n",
      " [   5   64]\n",
      " [   6  116]\n",
      " [   7  181]\n",
      " [   8  273]\n",
      " [   9  502]]\n",
      "[[   0  536]\n",
      " [   1  846]\n",
      " [   2 1474]\n",
      " [   3 2379]\n",
      " [   4   57]\n",
      " [   5   41]\n",
      " [   6   74]\n",
      " [   7  111]\n",
      " [   8  176]\n",
      " [   9  334]]\n",
      "[[   0  309]\n",
      " [   1  502]\n",
      " [   2  906]\n",
      " [   3 1416]\n",
      " [   4 2443]\n",
      " [   5   61]\n",
      " [   6   34]\n",
      " [   7   75]\n",
      " [   8  115]\n",
      " [   9  211]]\n",
      "[[   0  169]\n",
      " [   1  315]\n",
      " [   2  510]\n",
      " [   3  923]\n",
      " [   4 1342]\n",
      " [   5 2358]\n",
      " [   6   64]\n",
      " [   7   52]\n",
      " [   8   68]\n",
      " [   9  110]]\n",
      "[[   0  127]\n",
      " [   1  182]\n",
      " [   2  318]\n",
      " [   3  500]\n",
      " [   4  882]\n",
      " [   5 1438]\n",
      " [   6 2364]\n",
      " [   7   75]\n",
      " [   8   40]\n",
      " [   9   67]]\n",
      "[[   0   58]\n",
      " [   1  115]\n",
      " [   2  192]\n",
      " [   3  323]\n",
      " [   4  518]\n",
      " [   5  896]\n",
      " [   6 1465]\n",
      " [   7 2349]\n",
      " [   8   56]\n",
      " [   9   45]]\n",
      "[[   0   47]\n",
      " [   1   55]\n",
      " [   2   98]\n",
      " [   3  192]\n",
      " [   4  332]\n",
      " [   5  526]\n",
      " [   6  889]\n",
      " [   7 1423]\n",
      " [   8 2396]\n",
      " [   9   55]]\n",
      "[[   0   60]\n",
      " [   1   37]\n",
      " [   2   56]\n",
      " [   3  109]\n",
      " [   4  208]\n",
      " [   5  315]\n",
      " [   6  509]\n",
      " [   7  877]\n",
      " [   8 1468]\n",
      " [   9 2408]]\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<1:\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([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=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.76</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.76\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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\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.12955000000000003}, {'accuracy': 0.22614}, {'accuracy': 0.21513}, {'accuracy': 0.24012000000000003}, {'accuracy': 0.33103000000000005}, {'accuracy': 0.26781000000000005}, {'accuracy': 0.29982999999999993}, {'accuracy': 0.36612}, {'accuracy': 0.38299000000000005}, {'accuracy': 0.41864999999999997}, {'accuracy': 0.38574}, {'accuracy': 0.40352000000000005}, {'accuracy': 0.43539000000000005}, {'accuracy': 0.42806999999999995}, {'accuracy': 0.42532000000000003}, {'accuracy': 0.4487900000000001}, {'accuracy': 0.44145}, {'accuracy': 0.46723}, {'accuracy': 0.44258999999999993}, {'accuracy': 0.44979}, {'accuracy': 0.47507}, {'accuracy': 0.4659299999999999}, {'accuracy': 0.46697}, {'accuracy': 0.48003999999999997}, {'accuracy': 0.4965}, {'accuracy': 0.53701}, {'accuracy': 0.534}, {'accuracy': 0.5459400000000001}, {'accuracy': 0.56091}, {'accuracy': 0.56561}, {'accuracy': 0.57211}, {'accuracy': 0.5869700000000001}, {'accuracy': 0.59636}, {'accuracy': 0.59568}, {'accuracy': 0.57795}, {'accuracy': 0.6031599999999999}, {'accuracy': 0.6018299999999999}, {'accuracy': 0.61972}, {'accuracy': 0.5994600000000001}, {'accuracy': 0.5926400000000001}, {'accuracy': 0.62988}, {'accuracy': 0.62313}, {'accuracy': 0.63927}, {'accuracy': 0.61764}, {'accuracy': 0.6442699999999999}, {'accuracy': 0.6571399999999998}, {'accuracy': 0.6236499999999999}, {'accuracy': 0.63876}, {'accuracy': 0.6377900000000001}, {'accuracy': 0.6134999999999999}, {'accuracy': 0.6555500000000001}, {'accuracy': 0.65162}, {'accuracy': 0.6400399999999999}, {'accuracy': 0.6535599999999999}, {'accuracy': 0.64392}, {'accuracy': 0.66307}, {'accuracy': 0.65585}, {'accuracy': 0.66288}, {'accuracy': 0.64041}, {'accuracy': 0.6495599999999999}, {'accuracy': 0.64297}, {'accuracy': 0.67397}, {'accuracy': 0.66363}, {'accuracy': 0.67492}, {'accuracy': 0.67469}, {'accuracy': 0.67059}, {'accuracy': 0.64639}, {'accuracy': 0.6549400000000001}, {'accuracy': 0.6780999999999999}, {'accuracy': 0.6709699999999998}, {'accuracy': 0.6584200000000001}, {'accuracy': 0.6595099999999999}, {'accuracy': 0.69007}, {'accuracy': 0.68475}, {'accuracy': 0.6774199999999999}, {'accuracy': 0.6784999999999999}, {'accuracy': 0.66176}, {'accuracy': 0.6419799999999999}, {'accuracy': 0.6755599999999999}, {'accuracy': 0.6805500000000001}, {'accuracy': 0.6984199999999999}, {'accuracy': 0.67396}, {'accuracy': 0.6712699999999999}, {'accuracy': 0.70963}, {'accuracy': 0.70367}, {'accuracy': 0.69759}, {'accuracy': 0.6967}, {'accuracy': 0.69022}, {'accuracy': 0.6975100000000001}, {'accuracy': 0.69737}, {'accuracy': 0.68986}, {'accuracy': 0.68589}, {'accuracy': 0.6931300000000001}, {'accuracy': 0.6803}, {'accuracy': 0.7022300000000001}, {'accuracy': 0.69672}, {'accuracy': 0.70175}, {'accuracy': 0.70259}, {'accuracy': 0.7178000000000001}, {'accuracy': 0.70617}, {'accuracy': 0.7193499999999999}, {'accuracy': 0.70097}, {'accuracy': 0.7144400000000001}, {'accuracy': 0.6990999999999999}, {'accuracy': 0.7093900000000001}, {'accuracy': 0.69173}, {'accuracy': 0.7126699999999999}, {'accuracy': 0.69423}, {'accuracy': 0.72502}, {'accuracy': 0.7284400000000002}, {'accuracy': 0.69638}, {'accuracy': 0.7001700000000001}, {'accuracy': 0.7125499999999999}, {'accuracy': 0.71238}, {'accuracy': 0.7119800000000001}, {'accuracy': 0.6909400000000001}, {'accuracy': 0.70964}, {'accuracy': 0.71864}, {'accuracy': 0.70595}, {'accuracy': 0.7120299999999999}, {'accuracy': 0.7283799999999999}, {'accuracy': 0.6952699999999999}, {'accuracy': 0.6861499999999999}, {'accuracy': 0.7191899999999999}, {'accuracy': 0.6828799999999999}, {'accuracy': 0.7095}, {'accuracy': 0.72963}, {'accuracy': 0.7010700000000001}, {'accuracy': 0.71463}, {'accuracy': 0.72859}, {'accuracy': 0.71421}, {'accuracy': 0.7088300000000001}, {'accuracy': 0.7228100000000001}, {'accuracy': 0.7463}, {'accuracy': 0.7333000000000001}, {'accuracy': 0.71633}, {'accuracy': 0.7131399999999999}, {'accuracy': 0.7328499999999999}, {'accuracy': 0.73791}, {'accuracy': 0.7188599999999999}, {'accuracy': 0.71831}, {'accuracy': 0.7320500000000001}, {'accuracy': 0.7305300000000001}, {'accuracy': 0.7317199999999999}, {'accuracy': 0.71284}, {'accuracy': 0.7126}, {'accuracy': 0.72217}, {'accuracy': 0.70937}, {'accuracy': 0.7472799999999999}, {'accuracy': 0.73957}, {'accuracy': 0.7139300000000001}, {'accuracy': 0.7237699999999999}, {'accuracy': 0.72772}, {'accuracy': 0.725}, {'accuracy': 0.7525}, {'accuracy': 0.7040500000000002}, {'accuracy': 0.73916}, {'accuracy': 0.73953}, {'accuracy': 0.73776}, {'accuracy': 0.75914}, {'accuracy': 0.7177899999999999}, {'accuracy': 0.7117700000000001}, {'accuracy': 0.73511}, {'accuracy': 0.73754}, {'accuracy': 0.70519}, {'accuracy': 0.72741}, {'accuracy': 0.7128599999999999}, {'accuracy': 0.73614}, {'accuracy': 0.71645}, {'accuracy': 0.73425}, {'accuracy': 0.73952}, {'accuracy': 0.70561}, {'accuracy': 0.73634}, {'accuracy': 0.73098}, {'accuracy': 0.75318}, {'accuracy': 0.7133800000000001}, {'accuracy': 0.7295699999999999}, {'accuracy': 0.7101}, {'accuracy': 0.7672800000000001}, {'accuracy': 0.7365700000000001}, {'accuracy': 0.70181}, {'accuracy': 0.73248}, {'accuracy': 0.7403599999999999}, {'accuracy': 0.7033800000000001}, {'accuracy': 0.72733}, {'accuracy': 0.7393799999999999}, {'accuracy': 0.7133200000000002}, {'accuracy': 0.74066}, {'accuracy': 0.7432399999999999}, {'accuracy': 0.7470600000000001}, {'accuracy': 0.7326499999999999}, {'accuracy': 0.75294}, {'accuracy': 0.73372}, {'accuracy': 0.7444599999999999}, {'accuracy': 0.7323500000000001}, {'accuracy': 0.71655}, {'accuracy': 0.7375299999999999}, {'accuracy': 0.73695}, {'accuracy': 0.71907}, {'accuracy': 0.7415499999999999}, {'accuracy': 0.71102}, {'accuracy': 0.74434}, {'accuracy': 0.72671}, {'accuracy': 0.7491199999999999}, {'accuracy': 0.77331}, {'accuracy': 0.7662899999999999}, {'accuracy': 0.7627}, {'accuracy': 0.7657999999999999}, {'accuracy': 0.76941}, {'accuracy': 0.76386}, {'accuracy': 0.77493}, {'accuracy': 0.7656799999999999}, {'accuracy': 0.7673099999999999}, {'accuracy': 0.76027}, {'accuracy': 0.7613000000000001}, {'accuracy': 0.7653999999999999}, {'accuracy': 0.7681500000000001}, {'accuracy': 0.7625599999999999}, {'accuracy': 0.76499}, {'accuracy': 0.76423}, {'accuracy': 0.7669299999999999}, {'accuracy': 0.76346}, {'accuracy': 0.76658}, {'accuracy': 0.76583}, {'accuracy': 0.76834}, {'accuracy': 0.7715}, {'accuracy': 0.75166}, {'accuracy': 0.76957}, {'accuracy': 0.76032}, {'accuracy': 0.76485}, {'accuracy': 0.7678499999999999}, {'accuracy': 0.7716700000000001}, {'accuracy': 0.77533}, {'accuracy': 0.77146}, {'accuracy': 0.7686399999999999}, {'accuracy': 0.77565}, {'accuracy': 0.7708900000000001}, {'accuracy': 0.78108}, {'accuracy': 0.7591600000000001}, {'accuracy': 0.77943}, {'accuracy': 0.7702}, {'accuracy': 0.7708299999999999}, {'accuracy': 0.76973}, {'accuracy': 0.77846}, {'accuracy': 0.7827899999999999}, {'accuracy': 0.78524}, {'accuracy': 0.76703}, {'accuracy': 0.76501}, {'accuracy': 0.76799}, {'accuracy': 0.77113}, {'accuracy': 0.76311}, {'accuracy': 0.7689000000000001}, {'accuracy': 0.76979}, {'accuracy': 0.77885}, {'accuracy': 0.7670600000000001}, {'accuracy': 0.77901}, {'accuracy': 0.77154}, {'accuracy': 0.7835500000000001}, {'accuracy': 0.77258}, {'accuracy': 0.7638599999999999}, {'accuracy': 0.77381}, {'accuracy': 0.77324}, {'accuracy': 0.76748}, {'accuracy': 0.77154}, {'accuracy': 0.7697}, {'accuracy': 0.76427}, {'accuracy': 0.78301}, {'accuracy': 0.7725900000000001}, {'accuracy': 0.7682100000000001}, {'accuracy': 0.77288}, {'accuracy': 0.76875}, {'accuracy': 0.77037}, {'accuracy': 0.7695299999999999}, {'accuracy': 0.7709900000000001}, {'accuracy': 0.76521}, {'accuracy': 0.76536}, {'accuracy': 0.77636}, {'accuracy': 0.77373}, {'accuracy': 0.76658}, {'accuracy': 0.7620799999999999}, {'accuracy': 0.76589}, {'accuracy': 0.7639699999999999}, {'accuracy': 0.7660599999999999}, {'accuracy': 0.7798299999999999}, {'accuracy': 0.76698}, {'accuracy': 0.76502}, {'accuracy': 0.7706500000000001}, {'accuracy': 0.7651000000000001}, {'accuracy': 0.7657999999999999}, {'accuracy': 0.76897}, {'accuracy': 0.76723}, {'accuracy': 0.76989}, {'accuracy': 0.77032}, {'accuracy': 0.77997}, {'accuracy': 0.76774}, {'accuracy': 0.77979}, {'accuracy': 0.78671}, {'accuracy': 0.77233}, {'accuracy': 0.7732999999999999}, {'accuracy': 0.7552300000000001}]\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": "a1a0f7d3-cba9-4ddf-85ee-a243bcda0ea9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6c6eef1d-a45d-481f-823e-46ce3030f2e1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "870bfaba-d0cc-409e-8af3-c72b0a5ebe81",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "82504726-dbaf-4e3c-a64d-65e8e4da1df3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9d71bdec-0bf5-4b64-bae8-79d2e95a7fbd",
   "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
}
