{
 "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 2492]\n",
      " [   1   59]\n",
      " [   2   45]\n",
      " [   3   70]\n",
      " [   4  108]\n",
      " [   5  192]\n",
      " [   6  317]\n",
      " [   7  507]\n",
      " [   8  889]\n",
      " [   9 1452]]\n",
      "[[   0 1397]\n",
      " [   1 2406]\n",
      " [   2   57]\n",
      " [   3   32]\n",
      " [   4   69]\n",
      " [   5  106]\n",
      " [   6  175]\n",
      " [   7  296]\n",
      " [   8  526]\n",
      " [   9  867]]\n",
      "[[   0  801]\n",
      " [   1 1451]\n",
      " [   2 2358]\n",
      " [   3   56]\n",
      " [   4   38]\n",
      " [   5   54]\n",
      " [   6  115]\n",
      " [   7  192]\n",
      " [   8  312]\n",
      " [   9  489]]\n",
      "[[   0  519]\n",
      " [   1  851]\n",
      " [   2 1504]\n",
      " [   3 2399]\n",
      " [   4   69]\n",
      " [   5   41]\n",
      " [   6   82]\n",
      " [   7  108]\n",
      " [   8  171]\n",
      " [   9  313]]\n",
      "[[   0  336]\n",
      " [   1  569]\n",
      " [   2  842]\n",
      " [   3 1508]\n",
      " [   4 2389]\n",
      " [   5   61]\n",
      " [   6   38]\n",
      " [   7   67]\n",
      " [   8  107]\n",
      " [   9  209]]\n",
      "[[   0  176]\n",
      " [   1  292]\n",
      " [   2  513]\n",
      " [   3  850]\n",
      " [   4 1512]\n",
      " [   5 2379]\n",
      " [   6   66]\n",
      " [   7   42]\n",
      " [   8   73]\n",
      " [   9  118]]\n",
      "[[   0  108]\n",
      " [   1  158]\n",
      " [   2  312]\n",
      " [   3  488]\n",
      " [   4  827]\n",
      " [   5 1410]\n",
      " [   6 2332]\n",
      " [   7   68]\n",
      " [   8   49]\n",
      " [   9   65]]\n",
      "[[   0   65]\n",
      " [   1   87]\n",
      " [   2  193]\n",
      " [   3  306]\n",
      " [   4  498]\n",
      " [   5  923]\n",
      " [   6 1480]\n",
      " [   7 2459]\n",
      " [   8   43]\n",
      " [   9   44]]\n",
      "[[   0   42]\n",
      " [   1   75]\n",
      " [   2  109]\n",
      " [   3  182]\n",
      " [   4  294]\n",
      " [   5  513]\n",
      " [   6  901]\n",
      " [   7 1381]\n",
      " [   8 2385]\n",
      " [   9   48]]\n",
      "[[   0   64]\n",
      " [   1   52]\n",
      " [   2   67]\n",
      " [   3  109]\n",
      " [   4  196]\n",
      " [   5  321]\n",
      " [   6  494]\n",
      " [   7  880]\n",
      " [   8 1445]\n",
      " [   9 2395]]\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<1:\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\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.74</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:181</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.74\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m181\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAACR3klEQVR4nO3dd3xT9foH8E+SZnXvlpbSsodsEAQZChWc1y3iAFFw4sLJTwXHVZyI14XXK6LXhXLdA0QElL1E9qbM7t202ef3R3JOzknTNoG06fi8X6++bJOT5JvT4Hn6PM/3+1UJgiCAiIiIqJVQh3oARERERMHE4IaIiIhaFQY3RERE1KowuCEiIqJWhcENERERtSoMboiIiKhVYXBDRERErQqDGyIiImpVGNwQERFRq8Lghoga1cqVK6FSqbBy5UrptltuuQVZWVkhG1Nr8vTTT0OlUoV6GETNCoMbomZu165duOmmm5Ceng69Xo+0tDTceOON2LVrV6iH1ujeeecdLFy4sFFfY/fu3Xj66aeRk5PTqK/TlF544QV8++23oR4GUcgwuCFqxr7++msMHDgQy5cvx5QpU/DOO+/gtttuw4oVKzBw4EB88803oR5io2qq4OaZZ55hcEPUioSFegBE5NuhQ4dw8803o1OnTvjjjz+QlJQk3Xf//fdj5MiRuPnmm7F9+3Z06tSpycZlMpkQERHRZK/XEvCcEDUvzNwQNVOvvPIKqqur8e9//1sR2ABAYmIi3nvvPZhMJrz88ssAgMWLF0OlUmHVqlW1nuu9996DSqXCzp07pdv27t2La665BvHx8TAYDBg8eDC+//57xeMWLlwoPefdd9+N5ORktG/fHgBw9OhR3H333ejevTuMRiMSEhJw7bXXBi0DkpWVhV27dmHVqlVQqVRQqVQ477zzpPvLysrwwAMPICMjA3q9Hl26dMFLL70Ep9OpeJ4vvvgCgwYNQlRUFKKjo9GnTx+88cYb0vu79tprAQDnn3++9Dry/iBvt9xyCyIjI3Ho0CFcfPHFiIqKwo033ggAcDqdmDdvHs466ywYDAakpKTgjjvuQGlpqeI5Nm/ejPHjxyMxMRFGoxEdO3bErbfeKt3vq08JAHJycqBSqerNZqlUKphMJnz00UfS+7nlllsAAJWVlXjggQeQlZUFvV6P5ORkXHDBBdi6dWudz0fUEjFzQ9RM/fDDD8jKysLIkSN93j9q1ChkZWXhp59+AgBccskliIyMxJdffonRo0crjl20aBHOOuss9O7dG4Crj+fcc89Feno6Hn/8cURERODLL7/EFVdcgf/973+48sorFY+/++67kZSUhFmzZsFkMgEANm3ahLVr1+L6669H+/btkZOTg3fffRfnnXcedu/ejfDw8DN6//PmzcO9996LyMhIPPHEEwCAlJQUAEB1dTVGjx6NkydP4o477kCHDh2wdu1azJw5E7m5uZg3bx4AYNmyZZg4cSLGjh2Ll156CQCwZ88erFmzBvfffz9GjRqF++67D//617/wf//3f+jZsycASP+ti91ux/jx4zFixAi8+uqr0nu94447sHDhQkyZMgX33Xcfjhw5grfeegt//fUX1qxZA61Wi4KCAowbNw5JSUl4/PHHERsbi5ycHHz99ddndL5E//3vfzF16lQMGTIEt99+OwCgc+fOAIA777wTixcvxvTp09GrVy8UFxdj9erV2LNnDwYOHBiU1ydqFgQianbKysoEAMLll19e73H/+Mc/BABCRUWFIAiCMHHiRCE5OVmw2+3SMbm5uYJarRaeffZZ6baxY8cKffr0Ecxms3Sb0+kUhg8fLnTt2lW67cMPPxQACCNGjFA8pyAIQnV1da3xrFu3TgAgfPzxx9JtK1asEAAIK1askG6bPHmykJmZWe97EwRBOOuss4TRo0fXuv25554TIiIihP379ytuf/zxxwWNRiMcO3ZMEARBuP/++4Xo6OhaY5f76quvao2vPpMnTxYACI8//rji9j///FMAIHz66aeK25csWaK4/ZtvvhEACJs2barzNXydM0EQhCNHjggAhA8//FC6bfbs2YL3/8ojIiKEyZMn13remJgY4Z577vHjXRK1bCxLETVDlZWVAICoqKh6jxPvr6ioAABMmDABBQUFinLG4sWL4XQ6MWHCBABASUkJfv/9d1x33XWorKxEUVERioqKUFxcjPHjx+PAgQM4efKk4nWmTZsGjUajuM1oNErf22w2FBcXo0uXLoiNjW30MsdXX32FkSNHIi4uThp/UVERsrOz4XA48McffwAAYmNjYTKZsGzZsqCP4a677qo1ppiYGFxwwQWKMQ0aNAiRkZFYsWKFNCYA+PHHH2Gz2YI+rvrExsZiw4YNOHXqVJO+LlFTY3BD1AyJQYsY5NTF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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.11049000000000002}, {'accuracy': 0.13811}, {'accuracy': 0.16636}, {'accuracy': 0.25458}, {'accuracy': 0.21825}, {'accuracy': 0.27094999999999997}, {'accuracy': 0.26278999999999997}, {'accuracy': 0.30996}, {'accuracy': 0.32177}, {'accuracy': 0.33458}, {'accuracy': 0.31207}, {'accuracy': 0.29378000000000004}, {'accuracy': 0.39611}, {'accuracy': 0.29432}, {'accuracy': 0.37181000000000003}, {'accuracy': 0.40635000000000004}, {'accuracy': 0.38813000000000003}, {'accuracy': 0.39557}, {'accuracy': 0.39980000000000004}, {'accuracy': 0.37866999999999995}, {'accuracy': 0.43276000000000003}, {'accuracy': 0.38561999999999996}, {'accuracy': 0.40919}, {'accuracy': 0.41791999999999996}, {'accuracy': 0.44239999999999996}, {'accuracy': 0.41296}, {'accuracy': 0.45898000000000005}, {'accuracy': 0.4003}, {'accuracy': 0.44258999999999993}, {'accuracy': 0.44898}, {'accuracy': 0.41436}, {'accuracy': 0.42183000000000004}, {'accuracy': 0.47355}, {'accuracy': 0.47061000000000003}, {'accuracy': 0.51332}, {'accuracy': 0.48854999999999993}, {'accuracy': 0.5048999999999999}, {'accuracy': 0.45599000000000006}, {'accuracy': 0.4738900000000001}, {'accuracy': 0.5062499999999999}, {'accuracy': 0.5038900000000001}, {'accuracy': 0.50915}, {'accuracy': 0.54863}, {'accuracy': 0.49282000000000015}, {'accuracy': 0.49750999999999995}, {'accuracy': 0.47528}, {'accuracy': 0.5110699999999999}, {'accuracy': 0.5048600000000001}, {'accuracy': 0.50205}, {'accuracy': 0.52789}, {'accuracy': 0.54459}, {'accuracy': 0.55979}, {'accuracy': 0.5189199999999999}, {'accuracy': 0.5719}, {'accuracy': 0.5392300000000001}, {'accuracy': 0.48844999999999994}, {'accuracy': 0.5300900000000002}, {'accuracy': 0.5491900000000001}, {'accuracy': 0.51444}, {'accuracy': 0.5256000000000001}, {'accuracy': 0.58727}, {'accuracy': 0.60215}, {'accuracy': 0.6006900000000001}, {'accuracy': 0.58742}, {'accuracy': 0.59339}, {'accuracy': 0.61277}, {'accuracy': 0.5635100000000001}, {'accuracy': 0.58901}, {'accuracy': 0.54305}, {'accuracy': 0.5799}, {'accuracy': 0.60735}, {'accuracy': 0.57012}, {'accuracy': 0.55734}, {'accuracy': 0.64002}, {'accuracy': 0.55517}, {'accuracy': 0.5596300000000001}, {'accuracy': 0.5610099999999999}, {'accuracy': 0.6131}, {'accuracy': 0.62721}, {'accuracy': 0.62979}, {'accuracy': 0.6098100000000001}, {'accuracy': 0.6464300000000001}, {'accuracy': 0.59838}, {'accuracy': 0.56787}, {'accuracy': 0.63734}, {'accuracy': 0.6271899999999999}, {'accuracy': 0.6584800000000001}, {'accuracy': 0.68567}, {'accuracy': 0.6725099999999999}, {'accuracy': 0.59259}, {'accuracy': 0.6250500000000001}, {'accuracy': 0.66485}, {'accuracy': 0.67208}, {'accuracy': 0.6651100000000001}, {'accuracy': 0.6716799999999999}, {'accuracy': 0.69562}, {'accuracy': 0.68301}, {'accuracy': 0.6824399999999999}, {'accuracy': 0.6464300000000001}, {'accuracy': 0.6802400000000001}, {'accuracy': 0.68394}, {'accuracy': 0.61233}, {'accuracy': 0.69662}, {'accuracy': 0.7082599999999999}, {'accuracy': 0.64901}, {'accuracy': 0.69571}, {'accuracy': 0.65035}, {'accuracy': 0.6494899999999999}, {'accuracy': 0.68155}, {'accuracy': 0.63986}, {'accuracy': 0.6866099999999999}, {'accuracy': 0.63815}, {'accuracy': 0.6609900000000001}, {'accuracy': 0.67228}, {'accuracy': 0.6843600000000001}, {'accuracy': 0.67328}, {'accuracy': 0.66801}, {'accuracy': 0.70888}, {'accuracy': 0.66394}, {'accuracy': 0.6560499999999999}, {'accuracy': 0.66914}, {'accuracy': 0.65943}, {'accuracy': 0.67683}, {'accuracy': 0.68351}, {'accuracy': 0.7028699999999999}, {'accuracy': 0.68185}, {'accuracy': 0.67513}, {'accuracy': 0.64964}, {'accuracy': 0.70029}, {'accuracy': 0.68863}, {'accuracy': 0.6897399999999999}, {'accuracy': 0.71006}, {'accuracy': 0.6756199999999999}, {'accuracy': 0.72555}, {'accuracy': 0.6912799999999999}, {'accuracy': 0.70713}, {'accuracy': 0.6883799999999999}, {'accuracy': 0.69876}, {'accuracy': 0.68337}, {'accuracy': 0.6622600000000001}, {'accuracy': 0.7082399999999999}, {'accuracy': 0.7218899999999999}, {'accuracy': 0.6777700000000001}, {'accuracy': 0.6979000000000001}, {'accuracy': 0.70344}, {'accuracy': 0.7018800000000001}, {'accuracy': 0.71928}, {'accuracy': 0.6853}, {'accuracy': 0.6996}, {'accuracy': 0.73596}, {'accuracy': 0.6965800000000001}, {'accuracy': 0.7067}, {'accuracy': 0.71219}, {'accuracy': 0.7234}, {'accuracy': 0.6816}, {'accuracy': 0.71272}, {'accuracy': 0.7005}, {'accuracy': 0.69828}, {'accuracy': 0.7400599999999999}, {'accuracy': 0.72504}, {'accuracy': 0.70447}, {'accuracy': 0.73466}, {'accuracy': 0.68253}, {'accuracy': 0.7196}, {'accuracy': 0.71529}, {'accuracy': 0.72295}, {'accuracy': 0.7132699999999998}, {'accuracy': 0.73437}, {'accuracy': 0.70885}, {'accuracy': 0.73892}, {'accuracy': 0.69252}, {'accuracy': 0.7235100000000001}, {'accuracy': 0.7085899999999999}, {'accuracy': 0.7466}, {'accuracy': 0.7201700000000001}, {'accuracy': 0.7124199999999999}, {'accuracy': 0.7109699999999999}, {'accuracy': 0.73528}, {'accuracy': 0.6918300000000002}, {'accuracy': 0.73077}, {'accuracy': 0.70686}, {'accuracy': 0.71738}, {'accuracy': 0.7017100000000001}, {'accuracy': 0.68224}, {'accuracy': 0.6776}, {'accuracy': 0.69736}, {'accuracy': 0.6521199999999999}, {'accuracy': 0.71766}, {'accuracy': 0.7204799999999999}, {'accuracy': 0.69377}, {'accuracy': 0.70241}, {'accuracy': 0.6972400000000001}, {'accuracy': 0.7462799999999999}, {'accuracy': 0.7191099999999999}, {'accuracy': 0.70966}, {'accuracy': 0.70436}, {'accuracy': 0.7211200000000001}, {'accuracy': 0.75559}, {'accuracy': 0.77384}, {'accuracy': 0.7008300000000001}, {'accuracy': 0.64962}, {'accuracy': 0.65032}, {'accuracy': 0.52548}, {'accuracy': 0.69092}, {'accuracy': 0.6739700000000001}, {'accuracy': 0.6902300000000001}, {'accuracy': 0.6755099999999999}, {'accuracy': 0.6994999999999999}, {'accuracy': 0.73738}, {'accuracy': 0.7379200000000001}, {'accuracy': 0.71177}, {'accuracy': 0.73441}, {'accuracy': 0.7396900000000001}, {'accuracy': 0.73271}, {'accuracy': 0.71522}, {'accuracy': 0.7318999999999999}, {'accuracy': 0.74026}, {'accuracy': 0.73422}, {'accuracy': 0.72603}, {'accuracy': 0.7433700000000001}, {'accuracy': 0.7393}, {'accuracy': 0.71813}, {'accuracy': 0.73692}, {'accuracy': 0.7414799999999999}, {'accuracy': 0.72585}, {'accuracy': 0.69975}, {'accuracy': 0.7320099999999999}, {'accuracy': 0.7012400000000001}, {'accuracy': 0.73569}, {'accuracy': 0.74106}, {'accuracy': 0.70753}, {'accuracy': 0.73652}, {'accuracy': 0.7008500000000001}, {'accuracy': 0.7036899999999999}, {'accuracy': 0.70162}, {'accuracy': 0.73632}, {'accuracy': 0.71623}, {'accuracy': 0.71933}, {'accuracy': 0.6991799999999999}, {'accuracy': 0.74029}, {'accuracy': 0.7361800000000001}, {'accuracy': 0.7182000000000001}, {'accuracy': 0.73743}, {'accuracy': 0.7034}, {'accuracy': 0.745}, {'accuracy': 0.7186999999999999}, {'accuracy': 0.7388600000000001}, {'accuracy': 0.71984}, {'accuracy': 0.7210300000000001}, {'accuracy': 0.7362300000000002}, {'accuracy': 0.70043}, {'accuracy': 0.72311}, {'accuracy': 0.6787000000000001}, {'accuracy': 0.66727}, {'accuracy': 0.7421300000000001}, {'accuracy': 0.7219500000000001}, {'accuracy': 0.7166}, {'accuracy': 0.7168}, {'accuracy': 0.70275}, {'accuracy': 0.70118}, {'accuracy': 0.6983400000000001}, {'accuracy': 0.70689}, {'accuracy': 0.7372799999999999}, {'accuracy': 0.7498600000000001}, {'accuracy': 0.73474}, {'accuracy': 0.7238}, {'accuracy': 0.721}, {'accuracy': 0.72067}, {'accuracy': 0.73991}, {'accuracy': 0.70564}, {'accuracy': 0.7364200000000001}, {'accuracy': 0.7247000000000001}, {'accuracy': 0.7185600000000001}, {'accuracy': 0.72462}, {'accuracy': 0.72369}, {'accuracy': 0.7209000000000001}, {'accuracy': 0.7153600000000001}, {'accuracy': 0.72278}, {'accuracy': 0.70172}, {'accuracy': 0.6973599999999999}, {'accuracy': 0.7358}, {'accuracy': 0.73636}, {'accuracy': 0.7297}, {'accuracy': 0.74225}, {'accuracy': 0.72014}, {'accuracy': 0.70368}, {'accuracy': 0.70059}, {'accuracy': 0.71973}, {'accuracy': 0.7258100000000001}, {'accuracy': 0.69784}, {'accuracy': 0.7205900000000001}, {'accuracy': 0.70288}, {'accuracy': 0.7208500000000001}, {'accuracy': 0.73827}, {'accuracy': 0.7216100000000001}, {'accuracy': 0.74238}, {'accuracy': 0.72185}, {'accuracy': 0.7405}, {'accuracy': 0.7447999999999999}, {'accuracy': 0.73936}]\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": "d4cc1d9b-8c5c-438c-8267-ab526c9289cd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7cb7ab9c-0f3d-43a3-bac4-d2b1b4788985",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "87923e3d-d209-4898-8545-dfc47fb37741",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "21b45472-f626-411d-a713-50c95c5c2975",
   "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
}
