{
 "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",
    "    \n",
    "class CNNmnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(1, 10, kernel_size=5)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(10, 20, kernel_size=5)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(320, 50)\n",
    "        self.fc2 = nn.Linear(50, 10)        \n",
    "        # self.out = nn.Linear(64 * 7 * 7, 10)\n",
    "\n",
    "        \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        def _init_weights(m: nn.Module):\n",
    "            if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "                nn.init.xavier_uniform_(m.weight)\n",
    "                nn.init.zeros_(m.bias)\n",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(-1, 320)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2386]\n",
      " [   1   65]\n",
      " [   2   40]\n",
      " [   3   74]\n",
      " [   4  118]\n",
      " [   5  172]\n",
      " [   6  325]\n",
      " [   7  530]\n",
      " [   8  867]\n",
      " [   9 1474]]\n",
      "[[   0 1427]\n",
      " [   1 2715]\n",
      " [   2   44]\n",
      " [   3   44]\n",
      " [   4   61]\n",
      " [   5   99]\n",
      " [   6  191]\n",
      " [   7  292]\n",
      " [   8  491]\n",
      " [   9  874]]\n",
      "[[   0  771]\n",
      " [   1 1579]\n",
      " [   2 2435]\n",
      " [   3   46]\n",
      " [   4   37]\n",
      " [   5   62]\n",
      " [   6  107]\n",
      " [   7  175]\n",
      " [   8  288]\n",
      " [   9  473]]\n",
      "[[   0  530]\n",
      " [   1  981]\n",
      " [   2 1407]\n",
      " [   3 2411]\n",
      " [   4   57]\n",
      " [   5   39]\n",
      " [   6   76]\n",
      " [   7  120]\n",
      " [   8  184]\n",
      " [   9  330]]\n",
      "[[   0  292]\n",
      " [   1  597]\n",
      " [   2  868]\n",
      " [   3 1494]\n",
      " [   4 2352]\n",
      " [   5   69]\n",
      " [   6   51]\n",
      " [   7   63]\n",
      " [   8  100]\n",
      " [   9  175]]\n",
      "[[   0  198]\n",
      " [   1  349]\n",
      " [   2  495]\n",
      " [   3  914]\n",
      " [   4 1407]\n",
      " [   5 2165]\n",
      " [   6   57]\n",
      " [   7   27]\n",
      " [   8   54]\n",
      " [   9  111]]\n",
      "[[   0  136]\n",
      " [   1  190]\n",
      " [   2  295]\n",
      " [   3  528]\n",
      " [   4  823]\n",
      " [   5 1297]\n",
      " [   6 2362]\n",
      " [   7   65]\n",
      " [   8   41]\n",
      " [   9   64]]\n",
      "[[   0   73]\n",
      " [   1  129]\n",
      " [   2  185]\n",
      " [   3  323]\n",
      " [   4  491]\n",
      " [   5  751]\n",
      " [   6 1391]\n",
      " [   7 2554]\n",
      " [   8   50]\n",
      " [   9   45]]\n",
      "[[   0   45]\n",
      " [   1   85]\n",
      " [   2  116]\n",
      " [   3  193]\n",
      " [   4  297]\n",
      " [   5  468]\n",
      " [   6  838]\n",
      " [   7 1545]\n",
      " [   8 2359]\n",
      " [   9   55]]\n",
      "[[   0   65]\n",
      " [   1   52]\n",
      " [   2   73]\n",
      " [   3  104]\n",
      " [   4  199]\n",
      " [   5  299]\n",
      " [   6  520]\n",
      " [   7  894]\n",
      " [   8 1417]\n",
      " [   9 2348]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([5, 0, 4,  ..., 5, 6, 8])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_MNIST()\n",
    "\n",
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,60000,1):\n",
    "    if train_set[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif train_set[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif train_set[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif train_set[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif train_set[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif train_set[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif train_set[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif train_set[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif train_set[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif train_set[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "train_set[1][label[1]]\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(train_set[0][label[0][z]])\n",
    "        list0[1].append(train_set[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(train_set[0][label[0][z]])\n",
    "        list1[1].append(train_set[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(train_set[0][label[0][z]])\n",
    "        list2[1].append(train_set[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(train_set[0][label[0][z]])\n",
    "        list3[1].append(train_set[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(train_set[0][label[0][z]])\n",
    "        list4[1].append(train_set[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(train_set[0][label[0][z]])\n",
    "        list5[1].append(train_set[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(train_set[0][label[0][z]])\n",
    "        list6[1].append(train_set[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(train_set[0][label[0][z]])\n",
    "        list7[1].append(train_set[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(train_set[0][label[0][z]])\n",
    "        list8[1].append(train_set[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(train_set[0][label[0][z]])\n",
    "        list9[1].append(train_set[1][label[0][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(train_set[0][label[1][z]])\n",
    "        list1[1].append(train_set[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(train_set[0][label[1][z]])\n",
    "        list2[1].append(train_set[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(train_set[0][label[1][z]])\n",
    "        list3[1].append(train_set[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(train_set[0][label[1][z]])\n",
    "        list4[1].append(train_set[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(train_set[0][label[1][z]])\n",
    "        list5[1].append(train_set[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(train_set[0][label[1][z]])\n",
    "        list6[1].append(train_set[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(train_set[0][label[1][z]])\n",
    "        list7[1].append(train_set[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(train_set[0][label[1][z]])\n",
    "        list8[1].append(train_set[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(train_set[0][label[1][z]])\n",
    "        list9[1].append(train_set[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(train_set[0][label[1][z]])\n",
    "        list0[1].append(train_set[1][label[1][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(train_set[0][label[2][z]])\n",
    "        list2[1].append(train_set[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(train_set[0][label[2][z]])\n",
    "        list3[1].append(train_set[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(train_set[0][label[2][z]])\n",
    "        list4[1].append(train_set[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(train_set[0][label[2][z]])\n",
    "        list5[1].append(train_set[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(train_set[0][label[2][z]])\n",
    "        list6[1].append(train_set[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(train_set[0][label[2][z]])\n",
    "        list7[1].append(train_set[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(train_set[0][label[2][z]])\n",
    "        list8[1].append(train_set[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(train_set[0][label[2][z]])\n",
    "        list9[1].append(train_set[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(train_set[0][label[2][z]])\n",
    "        list0[1].append(train_set[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(train_set[0][label[2][z]])\n",
    "        list1[1].append(train_set[1][label[2][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(train_set[0][label[3][z]])\n",
    "        list3[1].append(train_set[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(train_set[0][label[3][z]])\n",
    "        list4[1].append(train_set[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(train_set[0][label[3][z]])\n",
    "        list5[1].append(train_set[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(train_set[0][label[3][z]])\n",
    "        list6[1].append(train_set[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(train_set[0][label[3][z]])\n",
    "        list7[1].append(train_set[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(train_set[0][label[3][z]])\n",
    "        list8[1].append(train_set[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(train_set[0][label[3][z]])\n",
    "        list9[1].append(train_set[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(train_set[0][label[3][z]])\n",
    "        list0[1].append(train_set[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(train_set[0][label[3][z]])\n",
    "        list1[1].append(train_set[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(train_set[0][label[3][z]])\n",
    "        list2[1].append(train_set[1][label[3][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(train_set[0][label[4][z]])\n",
    "        list4[1].append(train_set[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(train_set[0][label[4][z]])\n",
    "        list5[1].append(train_set[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(train_set[0][label[4][z]])\n",
    "        list6[1].append(train_set[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(train_set[0][label[4][z]])\n",
    "        list7[1].append(train_set[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(train_set[0][label[4][z]])\n",
    "        list8[1].append(train_set[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(train_set[0][label[4][z]])\n",
    "        list9[1].append(train_set[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(train_set[0][label[4][z]])\n",
    "        list0[1].append(train_set[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(train_set[0][label[4][z]])\n",
    "        list1[1].append(train_set[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(train_set[0][label[4][z]])\n",
    "        list2[1].append(train_set[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(train_set[0][label[4][z]])\n",
    "        list3[1].append(train_set[1][label[4][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(train_set[0][label[5][z]])\n",
    "        list5[1].append(train_set[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(train_set[0][label[5][z]])\n",
    "        list6[1].append(train_set[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(train_set[0][label[5][z]])\n",
    "        list7[1].append(train_set[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(train_set[0][label[5][z]])\n",
    "        list8[1].append(train_set[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(train_set[0][label[5][z]])\n",
    "        list9[1].append(train_set[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(train_set[0][label[5][z]])\n",
    "        list0[1].append(train_set[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(train_set[0][label[5][z]])\n",
    "        list1[1].append(train_set[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(train_set[0][label[5][z]])\n",
    "        list2[1].append(train_set[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(train_set[0][label[5][z]])\n",
    "        list3[1].append(train_set[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(train_set[0][label[5][z]])\n",
    "        list4[1].append(train_set[1][label[5][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(train_set[0][label[6][z]])\n",
    "        list6[1].append(train_set[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(train_set[0][label[6][z]])\n",
    "        list7[1].append(train_set[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(train_set[0][label[6][z]])\n",
    "        list8[1].append(train_set[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(train_set[0][label[6][z]])\n",
    "        list9[1].append(train_set[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(train_set[0][label[6][z]])\n",
    "        list0[1].append(train_set[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(train_set[0][label[6][z]])\n",
    "        list1[1].append(train_set[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(train_set[0][label[6][z]])\n",
    "        list2[1].append(train_set[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(train_set[0][label[6][z]])\n",
    "        list3[1].append(train_set[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(train_set[0][label[6][z]])\n",
    "        list4[1].append(train_set[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(train_set[0][label[6][z]])\n",
    "        list5[1].append(train_set[1][label[6][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(train_set[0][label[7][z]])\n",
    "        list7[1].append(train_set[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(train_set[0][label[7][z]])\n",
    "        list8[1].append(train_set[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(train_set[0][label[7][z]])\n",
    "        list9[1].append(train_set[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(train_set[0][label[7][z]])\n",
    "        list0[1].append(train_set[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(train_set[0][label[7][z]])\n",
    "        list1[1].append(train_set[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(train_set[0][label[7][z]])\n",
    "        list2[1].append(train_set[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(train_set[0][label[7][z]])\n",
    "        list3[1].append(train_set[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(train_set[0][label[7][z]])\n",
    "        list4[1].append(train_set[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(train_set[0][label[7][z]])\n",
    "        list5[1].append(train_set[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(train_set[0][label[7][z]])\n",
    "        list6[1].append(train_set[1][label[7][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(train_set[0][label[8][z]])\n",
    "        list8[1].append(train_set[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(train_set[0][label[8][z]])\n",
    "        list9[1].append(train_set[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(train_set[0][label[8][z]])\n",
    "        list0[1].append(train_set[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(train_set[0][label[8][z]])\n",
    "        list1[1].append(train_set[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(train_set[0][label[8][z]])\n",
    "        list2[1].append(train_set[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(train_set[0][label[8][z]])\n",
    "        list3[1].append(train_set[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(train_set[0][label[8][z]])\n",
    "        list4[1].append(train_set[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(train_set[0][label[8][z]])\n",
    "        list5[1].append(train_set[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(train_set[0][label[8][z]])\n",
    "        list6[1].append(train_set[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(train_set[0][label[8][z]])\n",
    "        list7[1].append(train_set[1][label[8][z]])  \n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(train_set[0][label[9][z]])\n",
    "        list9[1].append(train_set[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(train_set[0][label[9][z]])\n",
    "        list0[1].append(train_set[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(train_set[0][label[9][z]])\n",
    "        list1[1].append(train_set[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(train_set[0][label[9][z]])\n",
    "        list2[1].append(train_set[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(train_set[0][label[9][z]])\n",
    "        list3[1].append(train_set[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(train_set[0][label[9][z]])\n",
    "        list4[1].append(train_set[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(train_set[0][label[9][z]])\n",
    "        list5[1].append(train_set[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(train_set[0][label[9][z]])\n",
    "        list6[1].append(train_set[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(train_set[0][label[9][z]])\n",
    "        list7[1].append(train_set[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(train_set[0][label[9][z]])\n",
    "        list8[1].append(train_set[1][label[9][z]])  \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list1[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list3[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list4[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list5[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "\n",
    "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<5:\n",
    "        if tag1[z]==6:\n",
    "            tag1[z]=0\n",
    "        elif tag1[z]==0:\n",
    "            tag1[z]=6        \n",
    "        elif tag1[z]==1:\n",
    "            tag1[z]=7     \n",
    "        elif tag1[z]==7:\n",
    "            tag1[z]=1   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([6, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CNNmnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\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.85</span>                                                                <a href=\"file:///home/gzh0040/fsdownload/gossip_GPU/MNIST50c%/../gossipy_original/utils.py\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py</span></a><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">:</span><a href=\"file:///home/gzh0040/fsdownload/gossip_GPU/MNIST50c%/../gossipy_original/utils.py#181\" target=\"_blank\"><span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">181</span></a>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.85\u001b[0m                                                                \u001b]8;id=314240;file:///home/gzh0040/fsdownload/gossip_GPU/MNIST50c%/../gossipy_original/utils.py\u001b\\\u001b[2mutils.py\u001b[0m\u001b]8;;\u001b\\\u001b[2m:\u001b[0m\u001b]8;id=559225;file:///home/gzh0040/fsdownload/gossip_GPU/MNIST50c%/../gossipy_original/utils.py#181\u001b\\\u001b[2m181\u001b[0m\u001b]8;;\u001b\\\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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b775Ju6++26p7661qGAxMRFRqyOTyeChdHPJV2O6XQoKCnD8+HE8//zzGDVqFHr06IGioiLp8T59+mD//v0oLCx0eHyfPn3qLdANDg5GVlaW9PPJkycbtLjotm3bcMstt+Bf//oX+vbti86dO+PEiRPS4127doVGo6n3uRMSEpCUlISlS5fi888/x/3333/J520qlwU3er0ee/bsQWpqak1j5HKkpqZix44dTnsenU6H0tJSm6/mIBYTe7JLioiIGsnf3x+BgYH46KOPcOrUKfz+++9IS0uTHh8/fjzCwsJw6623Ytu2bThz5gz+97//SffLefPm4YsvvsC8efNw9OhRHDx4EK+//rp0/MiRI/H+++9j37592L17Nx566CG4u7tfsl1du3bFhg0bsH37dhw9ehTTpk1DTk6O9LharcasWbPwzDPP4OOPP8bp06fx119/YdmyZTbnmTJlCl577TUIgmAziqu5uCy4yc/Ph9FoRGhoqM320NBQZGdnO+155s+fD19fX+krOjraaee2Vm00wVOp4IrgRETUaHK5HKtXr8aePXvQu3dvPPHEE3jzzTelx5VKJX799VeEhITg+uuvR0JCAl577TVpcckRI0bgq6++wvfff49+/fph5MiRNjWsb7/9NqKjozF06FDcc889eOqppxq0uOjzzz+PAQMGYMyYMRgxYoQUYFmbM2cOnnzyScydOxc9evTAuHHjkJuba7PP+PHj4ebmhvHjx0OtVjfhlWoYmVC7E66FZGZmIjIyEtu3b8fAgQOl7c888wz++OMPm7H7jsTFxWHmzJmYOXNmvfvpdDrodDrp59LSUkRHR6OkpAQ+Pj5NugZHBEFo1gpwIiJyrKqqCmfPnkWnTp1a5AZKDZeeno74+Hjs2rULAwYMqHO/+t7D0tJS+Pr6Nuj+7bI0Q1BQEBQKhU16CwBycnIQFhbmtOdRqVQtWp/DwIaIiMisuroaBQUFeP7553HVVVfVG9g4k8u6pZRKJRITE22KkEwmEzZu3GiTySEiIqK2adu2bQgPD8euXbuwZMmSFntelxaIpKWlYeLEiUhKSkJycjIWLlwIrVaLyZMnAwAmTJiAyMhIzJ8/H4C5CPnIkSPS9xcvXsT+/fvh5eVlM5kRERERud6IESPshqC3BJcGN+PGjUNeXh7mzp2L7Oxs9OvXD+vWrZOKjDMyMiCX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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results without noise\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.10037}, {'accuracy': 0.21191}, {'accuracy': 0.20281000000000002}, {'accuracy': 0.15937}, {'accuracy': 0.26850999999999997}, {'accuracy': 0.27832}, {'accuracy': 0.23489}, {'accuracy': 0.3245699999999999}, {'accuracy': 0.37599}, {'accuracy': 0.33581000000000005}, {'accuracy': 0.38159}, {'accuracy': 0.56068}, {'accuracy': 0.41452999999999995}, {'accuracy': 0.43646}, {'accuracy': 0.55619}, {'accuracy': 0.5102300000000001}, {'accuracy': 0.37275}, {'accuracy': 0.47671}, {'accuracy': 0.47241999999999995}, {'accuracy': 0.49377000000000004}, {'accuracy': 0.51503}, {'accuracy': 0.5460900000000001}, {'accuracy': 0.57127}, {'accuracy': 0.6313599999999999}, {'accuracy': 0.6212799999999999}, {'accuracy': 0.6319400000000001}, {'accuracy': 0.5882499999999999}, {'accuracy': 0.63023}, {'accuracy': 0.65202}, {'accuracy': 0.60849}, {'accuracy': 0.62505}, {'accuracy': 0.62061}, {'accuracy': 0.64921}, {'accuracy': 0.6436299999999999}, {'accuracy': 0.61981}, {'accuracy': 0.67284}, {'accuracy': 0.6816599999999999}, {'accuracy': 0.6765800000000001}, {'accuracy': 0.65471}, {'accuracy': 0.65595}, {'accuracy': 0.59791}, {'accuracy': 0.67699}, {'accuracy': 0.6624799999999998}, {'accuracy': 0.66089}, {'accuracy': 0.68518}, {'accuracy': 0.69062}, {'accuracy': 0.6695900000000001}, {'accuracy': 0.68176}, {'accuracy': 0.77916}, {'accuracy': 0.72359}, {'accuracy': 0.7212599999999999}, {'accuracy': 0.66473}, {'accuracy': 0.70117}, {'accuracy': 0.6889699999999999}, {'accuracy': 0.72123}, {'accuracy': 0.67633}, {'accuracy': 0.69557}, {'accuracy': 0.7174799999999999}, {'accuracy': 0.7459}, {'accuracy': 0.77091}, {'accuracy': 0.70289}, {'accuracy': 0.7568800000000001}, {'accuracy': 0.72625}, {'accuracy': 0.7140700000000001}, {'accuracy': 0.7281599999999999}, {'accuracy': 0.726}, {'accuracy': 0.7101200000000001}, {'accuracy': 0.74223}, {'accuracy': 0.70084}, {'accuracy': 0.7230200000000001}, {'accuracy': 0.76113}, {'accuracy': 0.72212}, {'accuracy': 0.70529}, {'accuracy': 0.73708}, {'accuracy': 0.7008000000000001}, {'accuracy': 0.72211}, {'accuracy': 0.7548400000000001}, {'accuracy': 0.7276}, {'accuracy': 0.6911499999999999}, {'accuracy': 0.7309}, {'accuracy': 0.7152999999999999}, {'accuracy': 0.72266}, {'accuracy': 0.7205}, {'accuracy': 0.77085}, {'accuracy': 0.71534}, {'accuracy': 0.74387}, {'accuracy': 0.72098}, {'accuracy': 0.72652}, {'accuracy': 0.7419000000000001}, {'accuracy': 0.68965}, {'accuracy': 0.73619}, {'accuracy': 0.70338}, {'accuracy': 0.74602}, {'accuracy': 0.74232}, {'accuracy': 0.72492}, {'accuracy': 0.7516200000000001}, {'accuracy': 0.72362}, {'accuracy': 0.72206}, {'accuracy': 0.73539}, {'accuracy': 0.7359199999999999}, {'accuracy': 0.7500600000000001}, {'accuracy': 0.73458}, {'accuracy': 0.7241299999999999}, {'accuracy': 0.75735}, {'accuracy': 0.73513}, {'accuracy': 0.7772}, {'accuracy': 0.7364999999999999}, {'accuracy': 0.7570699999999999}, {'accuracy': 0.75927}, {'accuracy': 0.71099}, {'accuracy': 0.7552699999999999}, {'accuracy': 0.7547499999999999}, {'accuracy': 0.6965899999999999}, {'accuracy': 0.7552300000000001}, {'accuracy': 0.76798}, {'accuracy': 0.73892}, {'accuracy': 0.7563700000000001}, {'accuracy': 0.75464}, {'accuracy': 0.7326500000000001}, {'accuracy': 0.75213}, {'accuracy': 0.74797}, {'accuracy': 0.75356}, {'accuracy': 0.7597999999999999}, {'accuracy': 0.72861}, {'accuracy': 0.73251}, {'accuracy': 0.7794800000000001}, {'accuracy': 0.7333}, {'accuracy': 0.74298}, {'accuracy': 0.74332}, {'accuracy': 0.7473400000000001}, {'accuracy': 0.8505}, {'accuracy': 0.85389}, {'accuracy': 0.85291}, {'accuracy': 0.85113}, {'accuracy': 0.8502000000000001}, {'accuracy': 0.8501899999999999}, {'accuracy': 0.84792}, {'accuracy': 0.84993}, {'accuracy': 0.8497199999999999}, {'accuracy': 0.84968}, {'accuracy': 0.8489000000000001}, {'accuracy': 0.84921}, {'accuracy': 0.8516600000000001}, {'accuracy': 0.8491}, {'accuracy': 0.84971}, {'accuracy': 0.85091}, {'accuracy': 0.8442000000000001}, {'accuracy': 0.8490499999999999}, {'accuracy': 0.85462}, {'accuracy': 0.85206}, {'accuracy': 0.8480800000000001}, {'accuracy': 0.8505900000000001}, {'accuracy': 0.8511000000000001}, {'accuracy': 0.84985}, {'accuracy': 0.84737}, {'accuracy': 0.84834}, {'accuracy': 0.8501100000000001}, {'accuracy': 0.85078}, {'accuracy': 0.84817}, {'accuracy': 0.84551}, {'accuracy': 0.8495699999999999}, {'accuracy': 0.84841}, {'accuracy': 0.84952}, {'accuracy': 0.84772}, {'accuracy': 0.8492900000000001}, {'accuracy': 0.85298}, {'accuracy': 0.84741}, {'accuracy': 0.8471300000000002}, {'accuracy': 0.8511099999999999}, {'accuracy': 0.8500399999999999}, {'accuracy': 0.8523400000000001}, {'accuracy': 0.8484}, {'accuracy': 0.84855}, {'accuracy': 0.84511}, {'accuracy': 0.8481}, {'accuracy': 0.8473200000000001}, {'accuracy': 0.85337}, {'accuracy': 0.85343}, {'accuracy': 0.84588}, {'accuracy': 0.85017}, {'accuracy': 0.85117}, {'accuracy': 0.84792}, {'accuracy': 0.8514999999999999}, {'accuracy': 0.8477600000000001}, {'accuracy': 0.84755}, {'accuracy': 0.8489099999999998}, {'accuracy': 0.8511}, {'accuracy': 0.85052}, {'accuracy': 0.84806}, {'accuracy': 0.85236}, {'accuracy': 0.8515599999999999}, {'accuracy': 0.84881}, {'accuracy': 0.85002}, {'accuracy': 0.8503399999999999}, {'accuracy': 0.84845}, {'accuracy': 0.84968}, {'accuracy': 0.84963}, {'accuracy': 0.85052}, {'accuracy': 0.85272}, {'accuracy': 0.84846}]\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": []
  }
 ],
 "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
}
