{
 "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 2368]\n",
      " [   1   65]\n",
      " [   2   31]\n",
      " [   3   62]\n",
      " [   4  124]\n",
      " [   5  192]\n",
      " [   6  328]\n",
      " [   7  487]\n",
      " [   8  887]\n",
      " [   9 1418]]\n",
      "[[   0 1476]\n",
      " [   1 2437]\n",
      " [   2   57]\n",
      " [   3   24]\n",
      " [   4   69]\n",
      " [   5  114]\n",
      " [   6  184]\n",
      " [   7  321]\n",
      " [   8  528]\n",
      " [   9  873]]\n",
      "[[   0  897]\n",
      " [   1 1461]\n",
      " [   2 2413]\n",
      " [   3   78]\n",
      " [   4   47]\n",
      " [   5   59]\n",
      " [   6  105]\n",
      " [   7  179]\n",
      " [   8  310]\n",
      " [   9  530]]\n",
      "[[   0  509]\n",
      " [   1  833]\n",
      " [   2 1391]\n",
      " [   3 2336]\n",
      " [   4   72]\n",
      " [   5   45]\n",
      " [   6   67]\n",
      " [   7  104]\n",
      " [   8  178]\n",
      " [   9  288]]\n",
      "[[   0  293]\n",
      " [   1  524]\n",
      " [   2  846]\n",
      " [   3 1433]\n",
      " [   4 2367]\n",
      " [   5   52]\n",
      " [   6   46]\n",
      " [   7   69]\n",
      " [   8  129]\n",
      " [   9  173]]\n",
      "[[   0  162]\n",
      " [   1  298]\n",
      " [   2  541]\n",
      " [   3  905]\n",
      " [   4 1392]\n",
      " [   5 2397]\n",
      " [   6   58]\n",
      " [   7   49]\n",
      " [   8   46]\n",
      " [   9  110]]\n",
      "[[   0  107]\n",
      " [   1  164]\n",
      " [   2  315]\n",
      " [   3  518]\n",
      " [   4  890]\n",
      " [   5 1414]\n",
      " [   6 2357]\n",
      " [   7   51]\n",
      " [   8   47]\n",
      " [   9   80]]\n",
      "[[   0   71]\n",
      " [   1  116]\n",
      " [   2  215]\n",
      " [   3  343]\n",
      " [   4  502]\n",
      " [   5  878]\n",
      " [   6 1450]\n",
      " [   7 2391]\n",
      " [   8   55]\n",
      " [   9   32]]\n",
      "[[   0   43]\n",
      " [   1   65]\n",
      " [   2  125]\n",
      " [   3  188]\n",
      " [   4  316]\n",
      " [   5  516]\n",
      " [   6  866]\n",
      " [   7 1471]\n",
      " [   8 2393]\n",
      " [   9   52]]\n",
      "[[   0   74]\n",
      " [   1   37]\n",
      " [   2   66]\n",
      " [   3  113]\n",
      " [   4  221]\n",
      " [   5  333]\n",
      " [   6  539]\n",
      " [   7  878]\n",
      " [   8 1427]\n",
      " [   9 2444]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 0, 0,  ..., 3, 0, 5])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,60000,1):\n",
    "    if train_set[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif train_set[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif train_set[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif train_set[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif train_set[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif train_set[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif train_set[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif train_set[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif train_set[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif train_set[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "train_set[1][label[1]]\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(train_set[0][label[0][z]])\n",
    "        list0[1].append(train_set[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(train_set[0][label[0][z]])\n",
    "        list1[1].append(train_set[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(train_set[0][label[0][z]])\n",
    "        list2[1].append(train_set[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(train_set[0][label[0][z]])\n",
    "        list3[1].append(train_set[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(train_set[0][label[0][z]])\n",
    "        list4[1].append(train_set[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(train_set[0][label[0][z]])\n",
    "        list5[1].append(train_set[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(train_set[0][label[0][z]])\n",
    "        list6[1].append(train_set[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(train_set[0][label[0][z]])\n",
    "        list7[1].append(train_set[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(train_set[0][label[0][z]])\n",
    "        list8[1].append(train_set[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(train_set[0][label[0][z]])\n",
    "        list9[1].append(train_set[1][label[0][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(train_set[0][label[1][z]])\n",
    "        list1[1].append(train_set[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(train_set[0][label[1][z]])\n",
    "        list2[1].append(train_set[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(train_set[0][label[1][z]])\n",
    "        list3[1].append(train_set[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(train_set[0][label[1][z]])\n",
    "        list4[1].append(train_set[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(train_set[0][label[1][z]])\n",
    "        list5[1].append(train_set[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(train_set[0][label[1][z]])\n",
    "        list6[1].append(train_set[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(train_set[0][label[1][z]])\n",
    "        list7[1].append(train_set[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(train_set[0][label[1][z]])\n",
    "        list8[1].append(train_set[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(train_set[0][label[1][z]])\n",
    "        list9[1].append(train_set[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(train_set[0][label[1][z]])\n",
    "        list0[1].append(train_set[1][label[1][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(train_set[0][label[2][z]])\n",
    "        list2[1].append(train_set[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(train_set[0][label[2][z]])\n",
    "        list3[1].append(train_set[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(train_set[0][label[2][z]])\n",
    "        list4[1].append(train_set[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(train_set[0][label[2][z]])\n",
    "        list5[1].append(train_set[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(train_set[0][label[2][z]])\n",
    "        list6[1].append(train_set[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(train_set[0][label[2][z]])\n",
    "        list7[1].append(train_set[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(train_set[0][label[2][z]])\n",
    "        list8[1].append(train_set[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(train_set[0][label[2][z]])\n",
    "        list9[1].append(train_set[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(train_set[0][label[2][z]])\n",
    "        list0[1].append(train_set[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(train_set[0][label[2][z]])\n",
    "        list1[1].append(train_set[1][label[2][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(train_set[0][label[3][z]])\n",
    "        list3[1].append(train_set[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(train_set[0][label[3][z]])\n",
    "        list4[1].append(train_set[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(train_set[0][label[3][z]])\n",
    "        list5[1].append(train_set[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(train_set[0][label[3][z]])\n",
    "        list6[1].append(train_set[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(train_set[0][label[3][z]])\n",
    "        list7[1].append(train_set[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(train_set[0][label[3][z]])\n",
    "        list8[1].append(train_set[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(train_set[0][label[3][z]])\n",
    "        list9[1].append(train_set[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(train_set[0][label[3][z]])\n",
    "        list0[1].append(train_set[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(train_set[0][label[3][z]])\n",
    "        list1[1].append(train_set[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(train_set[0][label[3][z]])\n",
    "        list2[1].append(train_set[1][label[3][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(train_set[0][label[4][z]])\n",
    "        list4[1].append(train_set[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(train_set[0][label[4][z]])\n",
    "        list5[1].append(train_set[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(train_set[0][label[4][z]])\n",
    "        list6[1].append(train_set[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(train_set[0][label[4][z]])\n",
    "        list7[1].append(train_set[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(train_set[0][label[4][z]])\n",
    "        list8[1].append(train_set[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(train_set[0][label[4][z]])\n",
    "        list9[1].append(train_set[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(train_set[0][label[4][z]])\n",
    "        list0[1].append(train_set[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(train_set[0][label[4][z]])\n",
    "        list1[1].append(train_set[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(train_set[0][label[4][z]])\n",
    "        list2[1].append(train_set[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(train_set[0][label[4][z]])\n",
    "        list3[1].append(train_set[1][label[4][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(train_set[0][label[5][z]])\n",
    "        list5[1].append(train_set[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(train_set[0][label[5][z]])\n",
    "        list6[1].append(train_set[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(train_set[0][label[5][z]])\n",
    "        list7[1].append(train_set[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(train_set[0][label[5][z]])\n",
    "        list8[1].append(train_set[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(train_set[0][label[5][z]])\n",
    "        list9[1].append(train_set[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(train_set[0][label[5][z]])\n",
    "        list0[1].append(train_set[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(train_set[0][label[5][z]])\n",
    "        list1[1].append(train_set[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(train_set[0][label[5][z]])\n",
    "        list2[1].append(train_set[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(train_set[0][label[5][z]])\n",
    "        list3[1].append(train_set[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(train_set[0][label[5][z]])\n",
    "        list4[1].append(train_set[1][label[5][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(train_set[0][label[6][z]])\n",
    "        list6[1].append(train_set[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(train_set[0][label[6][z]])\n",
    "        list7[1].append(train_set[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(train_set[0][label[6][z]])\n",
    "        list8[1].append(train_set[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(train_set[0][label[6][z]])\n",
    "        list9[1].append(train_set[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(train_set[0][label[6][z]])\n",
    "        list0[1].append(train_set[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(train_set[0][label[6][z]])\n",
    "        list1[1].append(train_set[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(train_set[0][label[6][z]])\n",
    "        list2[1].append(train_set[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(train_set[0][label[6][z]])\n",
    "        list3[1].append(train_set[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(train_set[0][label[6][z]])\n",
    "        list4[1].append(train_set[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(train_set[0][label[6][z]])\n",
    "        list5[1].append(train_set[1][label[6][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(train_set[0][label[7][z]])\n",
    "        list7[1].append(train_set[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(train_set[0][label[7][z]])\n",
    "        list8[1].append(train_set[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(train_set[0][label[7][z]])\n",
    "        list9[1].append(train_set[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(train_set[0][label[7][z]])\n",
    "        list0[1].append(train_set[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(train_set[0][label[7][z]])\n",
    "        list1[1].append(train_set[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(train_set[0][label[7][z]])\n",
    "        list2[1].append(train_set[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(train_set[0][label[7][z]])\n",
    "        list3[1].append(train_set[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(train_set[0][label[7][z]])\n",
    "        list4[1].append(train_set[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(train_set[0][label[7][z]])\n",
    "        list5[1].append(train_set[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(train_set[0][label[7][z]])\n",
    "        list6[1].append(train_set[1][label[7][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(train_set[0][label[8][z]])\n",
    "        list8[1].append(train_set[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(train_set[0][label[8][z]])\n",
    "        list9[1].append(train_set[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(train_set[0][label[8][z]])\n",
    "        list0[1].append(train_set[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(train_set[0][label[8][z]])\n",
    "        list1[1].append(train_set[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(train_set[0][label[8][z]])\n",
    "        list2[1].append(train_set[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(train_set[0][label[8][z]])\n",
    "        list3[1].append(train_set[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(train_set[0][label[8][z]])\n",
    "        list4[1].append(train_set[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(train_set[0][label[8][z]])\n",
    "        list5[1].append(train_set[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(train_set[0][label[8][z]])\n",
    "        list6[1].append(train_set[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(train_set[0][label[8][z]])\n",
    "        list7[1].append(train_set[1][label[8][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(train_set[0][label[9][z]])\n",
    "        list9[1].append(train_set[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(train_set[0][label[9][z]])\n",
    "        list0[1].append(train_set[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(train_set[0][label[9][z]])\n",
    "        list1[1].append(train_set[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(train_set[0][label[9][z]])\n",
    "        list2[1].append(train_set[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(train_set[0][label[9][z]])\n",
    "        list3[1].append(train_set[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(train_set[0][label[9][z]])\n",
    "        list4[1].append(train_set[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(train_set[0][label[9][z]])\n",
    "        list5[1].append(train_set[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(train_set[0][label[9][z]])\n",
    "        list6[1].append(train_set[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(train_set[0][label[9][z]])\n",
    "        list7[1].append(train_set[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(train_set[0][label[9][z]])\n",
    "        list8[1].append(train_set[1][label[9][z]])  \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list1[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list3[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list4[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list5[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "fb85c984-e99f-433e-9cca-7bc7c93c10dd",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<3:\n",
    "        tag1[z]=(tag1[z] - 1) % 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 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.0\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "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.79</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.79\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.15621000000000002}, {'accuracy': 0.14518}, {'accuracy': 0.15786}, {'accuracy': 0.18014000000000002}, {'accuracy': 0.21038}, {'accuracy': 0.21164999999999998}, {'accuracy': 0.27366999999999997}, {'accuracy': 0.27052}, {'accuracy': 0.29279}, {'accuracy': 0.29230999999999996}, {'accuracy': 0.33581000000000005}, {'accuracy': 0.28925}, {'accuracy': 0.31299}, {'accuracy': 0.36455000000000004}, {'accuracy': 0.32525}, {'accuracy': 0.33680999999999994}, {'accuracy': 0.30813999999999997}, {'accuracy': 0.33998999999999996}, {'accuracy': 0.37765}, {'accuracy': 0.37929}, {'accuracy': 0.37408}, {'accuracy': 0.39252000000000004}, {'accuracy': 0.36387}, {'accuracy': 0.36753}, {'accuracy': 0.36680000000000007}, {'accuracy': 0.37143}, {'accuracy': 0.37879}, {'accuracy': 0.33985999999999994}, {'accuracy': 0.40293999999999996}, {'accuracy': 0.37448000000000004}, {'accuracy': 0.40563000000000005}, {'accuracy': 0.40718000000000004}, {'accuracy': 0.36547999999999997}, {'accuracy': 0.41117}, {'accuracy': 0.3953399999999999}, {'accuracy': 0.46283}, {'accuracy': 0.42756999999999995}, {'accuracy': 0.42994000000000004}, {'accuracy': 0.37724}, {'accuracy': 0.41821}, {'accuracy': 0.44048999999999994}, {'accuracy': 0.4196099999999999}, {'accuracy': 0.41861}, {'accuracy': 0.41879999999999995}, {'accuracy': 0.44560000000000005}, {'accuracy': 0.42774}, {'accuracy': 0.45905000000000007}, {'accuracy': 0.41088}, {'accuracy': 0.43283999999999995}, {'accuracy': 0.44506999999999997}, {'accuracy': 0.46334}, {'accuracy': 0.41422}, {'accuracy': 0.49678999999999995}, {'accuracy': 0.43346999999999997}, {'accuracy': 0.44618}, {'accuracy': 0.45386000000000004}, {'accuracy': 0.44984}, {'accuracy': 0.46789}, {'accuracy': 0.4629899999999999}, {'accuracy': 0.44203000000000003}, {'accuracy': 0.49751}, {'accuracy': 0.5115500000000001}, {'accuracy': 0.48197999999999996}, {'accuracy': 0.48403999999999997}, {'accuracy': 0.4938700000000001}, {'accuracy': 0.49696999999999997}, {'accuracy': 0.51062}, {'accuracy': 0.4990900000000001}, {'accuracy': 0.51658}, {'accuracy': 0.46646}, {'accuracy': 0.49991}, {'accuracy': 0.49897999999999987}, {'accuracy': 0.51092}, {'accuracy': 0.5608600000000001}, {'accuracy': 0.53418}, {'accuracy': 0.5287200000000001}, {'accuracy': 0.5257400000000001}, {'accuracy': 0.5069899999999999}, {'accuracy': 0.49781}, {'accuracy': 0.55635}, {'accuracy': 0.5507700000000001}, {'accuracy': 0.5414199999999999}, {'accuracy': 0.5480600000000001}, {'accuracy': 0.59263}, {'accuracy': 0.5896500000000001}, {'accuracy': 0.5309699999999999}, {'accuracy': 0.53416}, {'accuracy': 0.59092}, {'accuracy': 0.6073100000000001}, {'accuracy': 0.57359}, {'accuracy': 0.5719000000000001}, {'accuracy': 0.59669}, {'accuracy': 0.5923299999999999}, {'accuracy': 0.57038}, {'accuracy': 0.6260600000000001}, {'accuracy': 0.5903799999999999}, {'accuracy': 0.6339500000000001}, {'accuracy': 0.6157600000000001}, {'accuracy': 0.58726}, {'accuracy': 0.59525}, {'accuracy': 0.63499}, {'accuracy': 0.60497}, {'accuracy': 0.64264}, {'accuracy': 0.63563}, {'accuracy': 0.6408699999999999}, {'accuracy': 0.6377200000000001}, {'accuracy': 0.62134}, {'accuracy': 0.61495}, {'accuracy': 0.61679}, {'accuracy': 0.6465}, {'accuracy': 0.65998}, {'accuracy': 0.63111}, {'accuracy': 0.6581499999999999}, {'accuracy': 0.67348}, {'accuracy': 0.62924}, {'accuracy': 0.66991}, {'accuracy': 0.6515000000000001}, {'accuracy': 0.65077}, {'accuracy': 0.6605300000000001}, {'accuracy': 0.6814}, {'accuracy': 0.6521999999999999}, {'accuracy': 0.69172}, {'accuracy': 0.6781}, {'accuracy': 0.67628}, {'accuracy': 0.6908899999999999}, {'accuracy': 0.7076800000000001}, {'accuracy': 0.68125}, {'accuracy': 0.6742199999999999}, {'accuracy': 0.6639299999999999}, {'accuracy': 0.6790700000000001}, {'accuracy': 0.67774}, {'accuracy': 0.6812400000000001}, {'accuracy': 0.7151099999999999}, {'accuracy': 0.68021}, {'accuracy': 0.68838}, {'accuracy': 0.71504}, {'accuracy': 0.6792900000000001}, {'accuracy': 0.67246}, {'accuracy': 0.6694100000000001}, {'accuracy': 0.6684300000000001}, {'accuracy': 0.6945300000000001}, {'accuracy': 0.68869}, {'accuracy': 0.7181299999999999}, {'accuracy': 0.69906}, {'accuracy': 0.6812199999999999}, {'accuracy': 0.72338}, {'accuracy': 0.7240599999999999}, {'accuracy': 0.7415099999999999}, {'accuracy': 0.6893200000000002}, {'accuracy': 0.6923299999999999}, {'accuracy': 0.7097399999999999}, {'accuracy': 0.6973499999999999}, {'accuracy': 0.6866300000000001}, {'accuracy': 0.7219899999999999}, {'accuracy': 0.68532}, {'accuracy': 0.7150500000000001}, {'accuracy': 0.7308}, {'accuracy': 0.6935500000000001}, {'accuracy': 0.72862}, {'accuracy': 0.72349}, {'accuracy': 0.71722}, {'accuracy': 0.6884300000000001}, {'accuracy': 0.7268100000000002}, {'accuracy': 0.72699}, {'accuracy': 0.7202999999999999}, {'accuracy': 0.74124}, {'accuracy': 0.72403}, {'accuracy': 0.71568}, {'accuracy': 0.7161599999999999}, {'accuracy': 0.72753}, {'accuracy': 0.7396}, {'accuracy': 0.73922}, {'accuracy': 0.71146}, {'accuracy': 0.7435599999999999}, {'accuracy': 0.7276100000000001}, {'accuracy': 0.7285299999999999}, {'accuracy': 0.7417000000000001}, {'accuracy': 0.7311799999999999}, {'accuracy': 0.7352000000000001}, {'accuracy': 0.7558300000000001}, {'accuracy': 0.73803}, {'accuracy': 0.71719}, {'accuracy': 0.73949}, {'accuracy': 0.74143}, {'accuracy': 0.74968}, {'accuracy': 0.73039}, {'accuracy': 0.7208699999999999}, {'accuracy': 0.74847}, {'accuracy': 0.7271699999999999}, {'accuracy': 0.73866}, {'accuracy': 0.73445}, {'accuracy': 0.7317899999999999}, {'accuracy': 0.7235799999999999}, {'accuracy': 0.76206}, {'accuracy': 0.72888}, {'accuracy': 0.7410599999999999}, {'accuracy': 0.72822}, {'accuracy': 0.74791}, {'accuracy': 0.73457}, {'accuracy': 0.75807}, {'accuracy': 0.7171199999999999}, {'accuracy': 0.75971}, {'accuracy': 0.76626}, {'accuracy': 0.78481}, {'accuracy': 0.78657}, {'accuracy': 0.78465}, {'accuracy': 0.7901400000000001}, {'accuracy': 0.78296}, {'accuracy': 0.78349}, {'accuracy': 0.7921199999999999}, {'accuracy': 0.7961699999999999}, {'accuracy': 0.7903999999999999}, {'accuracy': 0.7899100000000001}, {'accuracy': 0.79671}, {'accuracy': 0.79091}, {'accuracy': 0.7878000000000001}, {'accuracy': 0.78858}, {'accuracy': 0.78905}, {'accuracy': 0.79473}, {'accuracy': 0.79214}, {'accuracy': 0.79555}, {'accuracy': 0.7909599999999999}, {'accuracy': 0.7876900000000001}, {'accuracy': 0.7997599999999999}, {'accuracy': 0.79578}, {'accuracy': 0.78252}, {'accuracy': 0.79201}, {'accuracy': 0.79416}, {'accuracy': 0.7913300000000001}, {'accuracy': 0.7905099999999999}, {'accuracy': 0.7987499999999998}, {'accuracy': 0.79486}, {'accuracy': 0.7917500000000001}, {'accuracy': 0.79459}, {'accuracy': 0.7897200000000001}, {'accuracy': 0.80175}, {'accuracy': 0.7907399999999999}, {'accuracy': 0.79628}, {'accuracy': 0.79132}, {'accuracy': 0.7924599999999999}, {'accuracy': 0.79034}, {'accuracy': 0.7974699999999999}, {'accuracy': 0.7942499999999999}, {'accuracy': 0.79633}, {'accuracy': 0.7944599999999999}, {'accuracy': 0.7860400000000001}, {'accuracy': 0.7963899999999999}, {'accuracy': 0.79499}, {'accuracy': 0.7884599999999999}, {'accuracy': 0.7773200000000001}, {'accuracy': 0.7920200000000001}, {'accuracy': 0.79875}, {'accuracy': 0.7955500000000001}, {'accuracy': 0.79536}, {'accuracy': 0.7925000000000001}, {'accuracy': 0.7987700000000001}, {'accuracy': 0.7883300000000001}, {'accuracy': 0.7877500000000001}, {'accuracy': 0.7992100000000001}, {'accuracy': 0.7937399999999999}, {'accuracy': 0.79556}, {'accuracy': 0.79605}, {'accuracy': 0.79776}, {'accuracy': 0.79719}, {'accuracy': 0.7932699999999999}, {'accuracy': 0.79148}, {'accuracy': 0.78747}, {'accuracy': 0.79244}, {'accuracy': 0.78741}, {'accuracy': 0.7929299999999999}, {'accuracy': 0.79423}, {'accuracy': 0.781}, {'accuracy': 0.7874399999999999}, {'accuracy': 0.79018}, {'accuracy': 0.79591}, {'accuracy': 0.7874}, {'accuracy': 0.78126}, {'accuracy': 0.78145}, {'accuracy': 0.78083}, {'accuracy': 0.79042}, {'accuracy': 0.7960100000000001}, {'accuracy': 0.7937000000000001}, {'accuracy': 0.79427}, {'accuracy': 0.78804}, {'accuracy': 0.7955800000000001}, {'accuracy': 0.78806}, {'accuracy': 0.79704}, {'accuracy': 0.78325}, {'accuracy': 0.7905}, {'accuracy': 0.78426}, {'accuracy': 0.79009}, {'accuracy': 0.79681}, {'accuracy': 0.79682}, {'accuracy': 0.7888200000000001}, {'accuracy': 0.78771}, {'accuracy': 0.7997799999999999}, {'accuracy': 0.8000299999999999}, {'accuracy': 0.7961}, {'accuracy': 0.78227}, {'accuracy': 0.7912699999999999}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "918b3aa8-d15e-4315-8b2d-bbdc0a8f2ac1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed07a60a-bb9a-4bfa-83ff-95d0ed2db218",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6523abf2-6e4e-4ba8-8073-e21670acab4f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ffc2dae3-918d-4662-a78a-e9221b770973",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b4dc2bdc-eb1f-44c5-a509-fa5052cec6fe",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a5496eb2-f1a4-4f8d-aa76-3333bf99c35f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9089bc69-32d9-46fa-b95c-57c0954054e2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7e93af2c-371d-4ffc-8dcd-50458a4df650",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "537807cb-6879-40fc-afeb-3868f45b51a7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0ec61b23-bd0f-4f5d-ad8c-9cbd070b2a51",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bdbd1464-ec6c-48af-b40d-118bdaf6b927",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "86d4a893-f1ee-4515-83b8-18a5f814c5d8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5679476a-ba3d-435c-af91-5299e245aaab",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5a2d976c-6714-48df-8416-10edf5ad8090",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d97a7b2e-d0dc-42cf-a0d5-33ba3a35380a",
   "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
}
