{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "tensor([6, 9, 9,  ..., 9, 1, 1])\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\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_CIFAR100\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "\n",
    "class CIFAR10Net(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(3, 64,kernel_size=3, stride=2, padding=1)\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(64, 192, 3, padding=1)\n",
    "        self.conv3 = nn.Conv2d(192, 384, 3, padding=1)\n",
    "        self.conv4 = nn.Conv2d(384, 256, 3, padding=1)\n",
    "        self.conv5 = nn.Conv2d(256, 256, 3, padding=1)\n",
    "        self.fc1 = nn.Linear(256 * 2 * 2, 4096)\n",
    "        self.fc2 = nn.Linear(4096, 4096)\n",
    "        self.fc3 = nn.Linear(4096, 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",
    "        #self.apply(_init_weights)\n",
    "        pass\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.pool(F.relu(self.conv1(x)))\n",
    "        x = self.pool(F.relu(self.conv2(x)))\n",
    "        x = F.relu(self.conv3(x))\n",
    "        x = F.relu(self.conv4(x))\n",
    "        x = self.pool(F.relu(self.conv5(x)))\n",
    "        # print(x.shape)\n",
    "        x = x.view(-1, 256 * 2 * 2)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.relu(self.fc2(x))\n",
    "        x = self.fc3(x)\n",
    "        return x\n",
    "    \n",
    "    def __repr__(self) -> str:\n",
    "        return \"CIFAR10Net(size=%d)\" %self.get_size()\n",
    "    \n",
    "    \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_CIFAR10()\n",
    "\n",
    "\n",
    "print(train_set[1])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([50000])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([1, 1, 1,  ..., 1, 1, 1])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tran1=torch.zeros([50000,3,32,32], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([50000], dtype=torch.int64)\n",
    "\n",
    "print(tag1.shape)\n",
    "\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,50000,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]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "dbc3456b-d386-41c9-9465-55f89e6b2d2b",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "473ea3ac-f6a7-424a-aca0-e50a6df03355",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "eb808629-58e7-4eb6-8c15-479cc02d237a",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a3aa2fcc-c4f4-408d-9423-86ea099f696b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "0b70f77d-f544-49f6-93a3-e3e974ce9287",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bf1e1d02-0668-4c7b-8079-b7b3fadca6f8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "c83b07a5-13f4-46b9-8e6d-ec57a8794c57",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0ad1327c-00bb-4f50-ac57-be4195b91337",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "b60e76e6-ccff-4323-8a51-ec20b80e923f",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6dec69bb-536c-4fdc-81bf-c215a286f04a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "925dbdcc-21e0-4f8f-8b75-94963a36f38a",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3024807a-0e1b-4cda-98fe-a49be1cde0f2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "bbe2a38a-0099-407d-a188-e06ff7ab899d",
   "metadata": {},
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4bc595ee-f8eb-41bf-9dc4-2d32a615b873",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "53de6bac-141a-45b9-8910-3eace920f86b",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0c65c26a-fa65-4399-ae11-78144d521edb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "a0044dab-8c89-4e12-b010-a632ef8426eb",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "acb72266-deb0-41bf-9f24-0e1e15285391",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "cd18c2ac-1778-46ab-9f17-af3b80856111",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "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]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cc5132f4-f827-473a-9d1f-6aac269955ee",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "1aad24c5-184d-4721-915c-3825cb7dbc47",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 1959]\n",
      " [   1   59]\n",
      " [   2   42]\n",
      " [   3   55]\n",
      " [   4   78]\n",
      " [   5  130]\n",
      " [   6  271]\n",
      " [   7  435]\n",
      " [   8  742]\n",
      " [   9 1193]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "6aa23b81-43cd-40f2-8ae4-3c9ca5b8e5e1",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 1248]\n",
      " [   1 1987]\n",
      " [   2   59]\n",
      " [   3   27]\n",
      " [   4   43]\n",
      " [   5   98]\n",
      " [   6  155]\n",
      " [   7  251]\n",
      " [   8  439]\n",
      " [   9  724]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list1[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "66be2793-b403-43b1-9269-30f94e832cf4",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0  725]\n",
      " [   1 1227]\n",
      " [   2 1972]\n",
      " [   3   56]\n",
      " [   4   24]\n",
      " [   5   54]\n",
      " [   6   82]\n",
      " [   7  170]\n",
      " [   8  264]\n",
      " [   9  453]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "d092746c-0931-48c5-ab0e-66e4cde5adef",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0  424]\n",
      " [   1  715]\n",
      " [   2 1238]\n",
      " [   3 1968]\n",
      " [   4   45]\n",
      " [   5   34]\n",
      " [   6   56]\n",
      " [   7   86]\n",
      " [   8  141]\n",
      " [   9  245]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list3[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "d70cf5da-acd4-44cd-9674-4122225f00ca",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0  235]\n",
      " [   1  443]\n",
      " [   2  679]\n",
      " [   3 1173]\n",
      " [   4 2002]\n",
      " [   5   54]\n",
      " [   6   33]\n",
      " [   7   45]\n",
      " [   8   98]\n",
      " [   9  171]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list4[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "22dd2dd8-3dc7-4537-9df4-68cc2fe9d6cf",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0  156]\n",
      " [   1  246]\n",
      " [   2  446]\n",
      " [   3  789]\n",
      " [   4 1220]\n",
      " [   5 2032]\n",
      " [   6   49]\n",
      " [   7   34]\n",
      " [   8   51]\n",
      " [   9   98]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list5[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "5c6c8374-d56f-49c2-ac81-a94873d19c1c",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0  101]\n",
      " [   1  161]\n",
      " [   2  241]\n",
      " [   3  421]\n",
      " [   4  683]\n",
      " [   5 1209]\n",
      " [   6 2013]\n",
      " [   7   55]\n",
      " [   8   35]\n",
      " [   9   61]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "671aae60-3b3e-468b-9636-99cdcb53c819",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   67]\n",
      " [   1   78]\n",
      " [   2  154]\n",
      " [   3  266]\n",
      " [   4  450]\n",
      " [   5  700]\n",
      " [   6 1150]\n",
      " [   7 1923]\n",
      " [   8   39]\n",
      " [   9   38]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "abad36f3-ca9c-4b61-b13c-84d76f89518d",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   30]\n",
      " [   1   48]\n",
      " [   2   99]\n",
      " [   3  150]\n",
      " [   4  291]\n",
      " [   5  420]\n",
      " [   6  748]\n",
      " [   7 1266]\n",
      " [   8 2023]\n",
      " [   9   55]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "ef796dae-f8f7-4f29-b9f2-80960e55027b",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   55]\n",
      " [   1   36]\n",
      " [   2   70]\n",
      " [   3   95]\n",
      " [   4  164]\n",
      " [   5  269]\n",
      " [   6  443]\n",
      " [   7  735]\n",
      " [   8 1168]\n",
      " [   9 1962]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "86e54019-8768-4ec2-94ec-4f34e0b3fc83",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "742bbd20-cef3-4735-992b-48ca2a6cd065",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "9ad9b17d-eba0-4778-b237-8536501db766",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([6, 9, 9,  ..., 9, 1, 1])"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "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]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "ab138f51-e874-443d-9400-d2a87d63cf54",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "10078\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 1959]\n",
      " [   1   27]\n",
      " [   2   42]\n",
      " [   3   33]\n",
      " [   4   78]\n",
      " [   5   63]\n",
      " [   6  271]\n",
      " [   7  435]\n",
      " [   8  742]\n",
      " [   9  343]]\n",
      "[[   0 1959]\n",
      " [   1   51]\n",
      " [   2   42]\n",
      " [   3   60]\n",
      " [   4   78]\n",
      " [   5  131]\n",
      " [   6  271]\n",
      " [   7  435]\n",
      " [   8  742]\n",
      " [   9  928]]\n",
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set = tran1, tag1\n",
    "\n",
    "#\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "dataset1=[]\n",
    "target1=[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,50000,1):\n",
    "    dataset1.append(train_set[0][z])\n",
    "    target1.append(train_set[1][z])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "len(target1)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "\n",
    "noiseyset=[],[]\n",
    "healthset=[],[],[]\n",
    "import random\n",
    "for z in range(0,50000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<5:\n",
    "        if target1[z]==1:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(9))\n",
    "        \n",
    "        elif target1[z]==9:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(1))      \n",
    "        \n",
    "        elif target1[z]==3:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(5))\n",
    "        \n",
    "        \n",
    "        elif target1[z]==5:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(3))     \n",
    "        \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[1][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[1][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\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",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\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(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \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(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \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(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \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(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[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(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[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(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \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(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[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(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[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(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \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(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[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",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\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": null,
   "id": "bcb77c3b-d583-458b-a7aa-7e042615286a",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (transform(tran1), tag1)\n",
    "Xte, yte = (transform(test_set[0]), test_set[1])\n",
    "\n",
    "data_handler = ClassificationDataHandler(Xtr, ytr,\n",
    "                                         Xte, yte)\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CIFAR10Net(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.001,\n",
    "            \"momentum\": 0.9,\n",
    "            \"weight_decay\": 5e-4\n",
    "        },\n",
    "        \n",
    "        criterion = F.cross_entropy,\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 32,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1.0\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=42)\n",
    "simulator.start(n_rounds=400)\n",
    "\n",
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10024}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10062}, {'accuracy': 0.10059}, {'accuracy': 0.10070000000000001}, {'accuracy': 0.10025999999999999}, {'accuracy': 0.10128000000000001}, {'accuracy': 0.10101}, {'accuracy': 0.10154}, {'accuracy': 0.10110000000000001}, {'accuracy': 0.10013999999999998}, {'accuracy': 0.10003}, {'accuracy': 0.10415999999999999}, {'accuracy': 0.10238}, {'accuracy': 0.11123000000000001}, {'accuracy': 0.11392000000000002}, {'accuracy': 0.0998}, {'accuracy': 0.11509}, {'accuracy': 0.11679999999999999}, {'accuracy': 0.11793000000000001}, {'accuracy': 0.11273}, {'accuracy': 0.11108}, {'accuracy': 0.12040999999999998}, {'accuracy': 0.12022}, {'accuracy': 0.13122}, {'accuracy': 0.11137000000000001}, {'accuracy': 0.13598}, {'accuracy': 0.13351}, {'accuracy': 0.11767000000000001}, {'accuracy': 0.12513000000000002}, {'accuracy': 0.13438000000000003}, {'accuracy': 0.14521}, {'accuracy': 0.14648}, {'accuracy': 0.13671000000000003}, {'accuracy': 0.15017}, {'accuracy': 0.13657}, {'accuracy': 0.14059}, {'accuracy': 0.15782000000000002}, {'accuracy': 0.15820000000000004}, {'accuracy': 0.17898}, {'accuracy': 0.14565}, {'accuracy': 0.15486000000000003}, {'accuracy': 0.14171000000000003}, {'accuracy': 0.1698}, {'accuracy': 0.16197999999999999}, {'accuracy': 0.17969000000000002}, {'accuracy': 0.19641}, {'accuracy': 0.16322}, {'accuracy': 0.17565}, {'accuracy': 0.19065000000000001}, {'accuracy': 0.16176}, {'accuracy': 0.17137000000000002}, {'accuracy': 0.17953}, {'accuracy': 0.18224}, {'accuracy': 0.16804999999999998}, {'accuracy': 0.19073}, {'accuracy': 0.16326}, {'accuracy': 0.19041000000000002}, {'accuracy': 0.15836}, {'accuracy': 0.18851}, {'accuracy': 0.20831}, {'accuracy': 0.19807}, {'accuracy': 0.21511}, {'accuracy': 0.20415}, {'accuracy': 0.23668}, {'accuracy': 0.18033000000000002}, {'accuracy': 0.21099}, {'accuracy': 0.21433}, {'accuracy': 0.21670000000000003}, {'accuracy': 0.17550000000000002}, {'accuracy': 0.20046}, {'accuracy': 0.20439000000000002}, {'accuracy': 0.21966999999999998}, {'accuracy': 0.19472}, {'accuracy': 0.20938000000000004}, {'accuracy': 0.21711}, {'accuracy': 0.22955}, {'accuracy': 0.23034}, {'accuracy': 0.21248999999999998}, {'accuracy': 0.19366}, {'accuracy': 0.21641}, {'accuracy': 0.23395000000000002}, {'accuracy': 0.22318000000000002}, {'accuracy': 0.2211}, {'accuracy': 0.22555999999999998}, {'accuracy': 0.22255000000000003}, {'accuracy': 0.24844}, {'accuracy': 0.24060000000000006}, {'accuracy': 0.21127}, {'accuracy': 0.21936999999999998}, {'accuracy': 0.25132}, {'accuracy': 0.25507}, {'accuracy': 0.26845}, {'accuracy': 0.26857}, {'accuracy': 0.26866999999999996}, {'accuracy': 0.24091999999999997}, {'accuracy': 0.26524000000000003}, {'accuracy': 0.24749000000000004}, {'accuracy': 0.26255}, {'accuracy': 0.24153000000000002}, {'accuracy': 0.25643}, {'accuracy': 0.24951000000000004}, {'accuracy': 0.26631}, {'accuracy': 0.25385}, {'accuracy': 0.28071999999999997}, {'accuracy': 0.27419000000000004}, {'accuracy': 0.27166999999999997}, {'accuracy': 0.28764}, {'accuracy': 0.30412}, {'accuracy': 0.28111}, {'accuracy': 0.32599}, {'accuracy': 0.27717}, {'accuracy': 0.30479}, {'accuracy': 0.28984}, {'accuracy': 0.2778}, {'accuracy': 0.26305}, {'accuracy': 0.31494}, {'accuracy': 0.29652}, {'accuracy': 0.28561000000000003}, {'accuracy': 0.31126}, {'accuracy': 0.29705}, {'accuracy': 0.2852}, {'accuracy': 0.30277000000000004}, {'accuracy': 0.30413999999999997}, {'accuracy': 0.31353}, {'accuracy': 0.28778000000000004}, {'accuracy': 0.30773}, {'accuracy': 0.31845}, {'accuracy': 0.29413}, {'accuracy': 0.30877}, {'accuracy': 0.33297}, {'accuracy': 0.32214}, {'accuracy': 0.32556999999999997}, {'accuracy': 0.3126}, {'accuracy': 0.35262000000000004}, {'accuracy': 0.31822}, {'accuracy': 0.3161}, {'accuracy': 0.33106}, {'accuracy': 0.35086000000000006}, {'accuracy': 0.33716}, {'accuracy': 0.34512000000000004}, {'accuracy': 0.34954999999999997}, {'accuracy': 0.34707}, {'accuracy': 0.34707999999999994}, {'accuracy': 0.32397}, {'accuracy': 0.3369599999999999}, {'accuracy': 0.33254}, {'accuracy': 0.35941000000000006}, {'accuracy': 0.34707}, {'accuracy': 0.34274}, {'accuracy': 0.36321}, {'accuracy': 0.34382999999999997}, {'accuracy': 0.35157999999999995}, {'accuracy': 0.36323}, {'accuracy': 0.35162000000000004}, {'accuracy': 0.36556}, {'accuracy': 0.36827}, {'accuracy': 0.36861}, {'accuracy': 0.36256}, {'accuracy': 0.35877000000000003}, {'accuracy': 0.37664}, {'accuracy': 0.36283}, {'accuracy': 0.37652}, {'accuracy': 0.37388000000000005}, {'accuracy': 0.3614}, {'accuracy': 0.36928}, {'accuracy': 0.36788999999999994}, {'accuracy': 0.38189}, {'accuracy': 0.36707}, {'accuracy': 0.37267}, {'accuracy': 0.37999}, {'accuracy': 0.39024000000000003}, {'accuracy': 0.35476}, {'accuracy': 0.38006}, {'accuracy': 0.39561}, {'accuracy': 0.39118}, {'accuracy': 0.37733000000000005}, {'accuracy': 0.3725299999999999}, {'accuracy': 0.38}, {'accuracy': 0.38706999999999997}, {'accuracy': 0.36806}, {'accuracy': 0.39438999999999996}, {'accuracy': 0.39011}, {'accuracy': 0.37424}, {'accuracy': 0.39726000000000006}, {'accuracy': 0.39778}, {'accuracy': 0.36587000000000003}, {'accuracy': 0.38580000000000003}, {'accuracy': 0.38388}, {'accuracy': 0.38251999999999997}, {'accuracy': 0.37492000000000003}, {'accuracy': 0.39668000000000003}, {'accuracy': 0.39985}, {'accuracy': 0.37288}, {'accuracy': 0.42458999999999997}, {'accuracy': 0.43598}, {'accuracy': 0.45675}, {'accuracy': 0.4652299999999999}, {'accuracy': 0.46757}, {'accuracy': 0.4676600000000001}, {'accuracy': 0.4673900000000001}, {'accuracy': 0.46165}, {'accuracy': 0.46297000000000005}, {'accuracy': 0.46613}, {'accuracy': 0.47126}, {'accuracy': 0.47113999999999995}, {'accuracy': 0.4715000000000001}, {'accuracy': 0.46746}, {'accuracy': 0.46702000000000005}, {'accuracy': 0.47128}, {'accuracy': 0.47724}, {'accuracy': 0.47346000000000005}, {'accuracy': 0.47246}, {'accuracy': 0.46646}, {'accuracy': 0.46803}, {'accuracy': 0.47291}, {'accuracy': 0.46958}, {'accuracy': 0.47723000000000004}, {'accuracy': 0.46819000000000005}, {'accuracy': 0.47685000000000005}, {'accuracy': 0.48432}, {'accuracy': 0.47933000000000003}, {'accuracy': 0.48188999999999993}, {'accuracy': 0.48208}, {'accuracy': 0.47490000000000004}, {'accuracy': 0.48162000000000005}, {'accuracy': 0.47526999999999997}, {'accuracy': 0.47385}, {'accuracy': 0.47709}, {'accuracy': 0.47341}, {'accuracy': 0.47783}, {'accuracy': 0.4789}, {'accuracy': 0.4764099999999999}, {'accuracy': 0.47979000000000005}, {'accuracy': 0.47590999999999994}, {'accuracy': 0.4805}, {'accuracy': 0.48021}, {'accuracy': 0.48305999999999993}, {'accuracy': 0.48631000000000013}, {'accuracy': 0.4823099999999999}, {'accuracy': 0.48312999999999995}, {'accuracy': 0.48749000000000003}, {'accuracy': 0.48051999999999995}, {'accuracy': 0.48037}, {'accuracy': 0.47706}, {'accuracy': 0.47781}, {'accuracy': 0.4805499999999999}, {'accuracy': 0.47325999999999996}, {'accuracy': 0.47774}, {'accuracy': 0.46548}, {'accuracy': 0.4695499999999999}, {'accuracy': 0.48174}, {'accuracy': 0.46570999999999996}, {'accuracy': 0.47926000000000013}, {'accuracy': 0.48143}, {'accuracy': 0.48258}, {'accuracy': 0.48129}, {'accuracy': 0.48084000000000005}, {'accuracy': 0.4840400000000001}, {'accuracy': 0.48342}, {'accuracy': 0.48356000000000005}, {'accuracy': 0.47963000000000006}, {'accuracy': 0.4825799999999999}, {'accuracy': 0.48855999999999994}, {'accuracy': 0.47526}, {'accuracy': 0.47448999999999997}, {'accuracy': 0.46895999999999993}, {'accuracy': 0.4799399999999999}, {'accuracy': 0.48256}, {'accuracy': 0.47955000000000003}, {'accuracy': 0.48097}, {'accuracy': 0.48433000000000004}, {'accuracy': 0.48624999999999996}, {'accuracy': 0.48647}, {'accuracy': 0.48661000000000004}, {'accuracy': 0.4857100000000001}, {'accuracy': 0.48575999999999997}, {'accuracy': 0.48264000000000007}, {'accuracy': 0.4819}, {'accuracy': 0.48396999999999996}, {'accuracy': 0.48095}, {'accuracy': 0.48177000000000003}, {'accuracy': 0.48517}, {'accuracy': 0.4833}, {'accuracy': 0.47977}, {'accuracy': 0.48676}, {'accuracy': 0.48260999999999993}, {'accuracy': 0.48505999999999994}, {'accuracy': 0.47501000000000004}, {'accuracy': 0.48874000000000006}, {'accuracy': 0.48334}, {'accuracy': 0.48966000000000004}, {'accuracy': 0.48602999999999996}, {'accuracy': 0.48177000000000003}, {'accuracy': 0.47844}, {'accuracy': 0.48166000000000003}, {'accuracy': 0.48548}, {'accuracy': 0.48511999999999994}, {'accuracy': 0.48057000000000005}, {'accuracy': 0.48283999999999994}, {'accuracy': 0.47745999999999994}, {'accuracy': 0.47844999999999993}, {'accuracy': 0.4794899999999999}, {'accuracy': 0.47246}, {'accuracy': 0.48477999999999993}, {'accuracy': 0.48418}, {'accuracy': 0.48346}, {'accuracy': 0.4814900000000001}, {'accuracy': 0.48965}, {'accuracy': 0.48373}, {'accuracy': 0.48159}, {'accuracy': 0.48712999999999995}, {'accuracy': 0.48538}, {'accuracy': 0.48410000000000003}, {'accuracy': 0.48477}, {'accuracy': 0.48262}, {'accuracy': 0.48888}, {'accuracy': 0.48741}, {'accuracy': 0.48555000000000004}, {'accuracy': 0.48562000000000005}, {'accuracy': 0.48545}, {'accuracy': 0.48514}, {'accuracy': 0.4835}, {'accuracy': 0.48543000000000003}, {'accuracy': 0.48302000000000006}, {'accuracy': 0.47822999999999993}, {'accuracy': 0.48127}, {'accuracy': 0.48567}, {'accuracy': 0.48263000000000006}, {'accuracy': 0.48125999999999997}, {'accuracy': 0.4835900000000001}, {'accuracy': 0.48434999999999995}, {'accuracy': 0.48574}, {'accuracy': 0.48278999999999994}, {'accuracy': 0.4846500000000001}, {'accuracy': 0.47886999999999996}, {'accuracy': 0.4728199999999999}, {'accuracy': 0.4808}, {'accuracy': 0.48125}, {'accuracy': 0.48360000000000003}, {'accuracy': 0.48406000000000005}, {'accuracy': 0.48575}, {'accuracy': 0.48638000000000003}, {'accuracy': 0.48432}, {'accuracy': 0.48578}, {'accuracy': 0.4868}, {'accuracy': 0.47935999999999995}, {'accuracy': 0.48214000000000007}, {'accuracy': 0.48487}, {'accuracy': 0.48281999999999997}, {'accuracy': 0.48495}, {'accuracy': 0.48056}, {'accuracy': 0.48462000000000005}, {'accuracy': 0.4770899999999999}, {'accuracy': 0.48362}, {'accuracy': 0.4768}, {'accuracy': 0.4840400000000001}, {'accuracy': 0.48334}, {'accuracy': 0.48364}, {'accuracy': 0.48172000000000004}, {'accuracy': 0.48274}, {'accuracy': 0.48251999999999995}, {'accuracy': 0.4827699999999999}, {'accuracy': 0.48427}, {'accuracy': 0.48410000000000003}, {'accuracy': 0.48416}, {'accuracy': 0.48856}, {'accuracy': 0.48841999999999997}, {'accuracy': 0.48511000000000004}, {'accuracy': 0.48534000000000005}, {'accuracy': 0.48714}, {'accuracy': 0.48619}, {'accuracy': 0.48109}, {'accuracy': 0.46135000000000004}, {'accuracy': 0.47241}, {'accuracy': 0.47679}, {'accuracy': 0.48029}, {'accuracy': 0.47743}, {'accuracy': 0.47336}, {'accuracy': 0.48292}, {'accuracy': 0.47841000000000006}, {'accuracy': 0.48213999999999996}, {'accuracy': 0.4808199999999999}, {'accuracy': 0.48273}, {'accuracy': 0.48365}, {'accuracy': 0.48407}, {'accuracy': 0.48329000000000005}, {'accuracy': 0.4853300000000001}, {'accuracy': 0.48714}, {'accuracy': 0.48457999999999996}, {'accuracy': 0.47485}, {'accuracy': 0.47988}, {'accuracy': 0.48339999999999994}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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Hh7YuHGjeMzGjRsRExODXr16AQDOnDkDQRAwf/58+Pn5SW4LFy4EAOTl5UleJzw83OK1q6qqsGDBArEGx9fXF35+figpKUFpaWkrr7x50tLSsHnzZov2x8XFSdo/e/Zs9OrVCzfddBO6deuGBx98EJs3b77i13dwcBBroczbVFpaCn9/f4t2VVRUiG0aPXo07rzzTixatAi+vr6YNGkS1q5dC61We8XtupylS5fi6NGjCA0NxdChQ/Hyyy/j7Nmz7f66RFcba4CIOikPDw8EBQXh8OHDTR53+PBhhISEwN3dHQCgUqkwefJkfPvtt/jggw+Qm5uLnTt34j//+Y/4HFOR8NNPP434+Hir542KipI8Ns/2mPzzn//E2rVrMXfuXAwfPhweHh6QyWS49957LQqR25rBYMD48ePx7LPPWt1vCvb8/f2RmpqKLVu24Ndff8Wvv/6KtWvXYsaMGVi/fn2rX1+lUkEul37HNBgM8Pf3x+eff271OaZCdplMhk2bNmH37t348ccfsWXLFjz44IN4++23sXv3bri6ujY6saFer291mwHgnnvuwciRI/Htt9/it99+w5tvvok33ngD33zzDW666aYrOjdRR8IAiKgTu/XWW7F69Wrs2LEDI0aMsNj/119/ISMjA48++qhk+9SpU7F+/XokJSXhxIkTEARB7P4CIA6Zd3R0FDMmrbFp0ybMnDkTb7/9trituroaJSUlrT5nQ40FApGRkaioqGhW+5VKJW677TbcdtttMBgMmD17Nj788EPMnz8fUVFRbTaLcmRkJH7//XfccMMNVgPGhq677jpcd911eP311/HFF19g+vTp2LBhAx5++GF4eXkBgMX/5fnz55vVlqauKSgoCLNnz8bs2bORl5eHwYMH4/XXX2cARF0Ku8CIOrFnnnkGTk5OePTRR1FYWCjZV1RUhMceewzOzs545plnJPvi4uLg7e2NjRs3YuPGjRg6dKikC8vf3x9jxozBhx9+iOzsbIvXzc/Pb1b7FAoFBEGQbHvvvfeuOEthzsXFxWpAdc899yAlJQVbtmyx2FdSUoLa2loAsPh/k8vliI6OBgCxy8k0f8+VBm733HMP9Ho9Xn31VYt9tbW14vmLi4st/t9iYmIkberRowcUCoVYy2TywQcfNKst1v7f9Hq9Rdekv78/goODr0r3G9HVxAwQUSfWs2dP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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\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10024}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10062}, {'accuracy': 0.10059}, {'accuracy': 0.10070000000000001}, {'accuracy': 0.10025999999999999}, {'accuracy': 0.10128000000000001}, {'accuracy': 0.10101}, {'accuracy': 0.10154}, {'accuracy': 0.10110000000000001}, {'accuracy': 0.10013999999999998}, {'accuracy': 0.10003}, {'accuracy': 0.10415999999999999}, {'accuracy': 0.10238}, {'accuracy': 0.11123000000000001}, {'accuracy': 0.11392000000000002}, {'accuracy': 0.0998}, {'accuracy': 0.11509}, {'accuracy': 0.11679999999999999}, {'accuracy': 0.11793000000000001}, {'accuracy': 0.11273}, {'accuracy': 0.11108}, {'accuracy': 0.12040999999999998}, {'accuracy': 0.12022}, {'accuracy': 0.13122}, {'accuracy': 0.11137000000000001}, {'accuracy': 0.13598}, {'accuracy': 0.13351}, {'accuracy': 0.11767000000000001}, {'accuracy': 0.12513000000000002}, {'accuracy': 0.13438000000000003}, {'accuracy': 0.14521}, {'accuracy': 0.14648}, {'accuracy': 0.13671000000000003}, {'accuracy': 0.15017}, {'accuracy': 0.13657}, {'accuracy': 0.14059}, {'accuracy': 0.15782000000000002}, {'accuracy': 0.15820000000000004}, {'accuracy': 0.17898}, {'accuracy': 0.14565}, {'accuracy': 0.15486000000000003}, {'accuracy': 0.14171000000000003}, {'accuracy': 0.1698}, {'accuracy': 0.16197999999999999}, {'accuracy': 0.17969000000000002}, {'accuracy': 0.19641}, {'accuracy': 0.16322}, {'accuracy': 0.17565}, {'accuracy': 0.19065000000000001}, {'accuracy': 0.16176}, {'accuracy': 0.17137000000000002}, {'accuracy': 0.17953}, {'accuracy': 0.18224}, {'accuracy': 0.16804999999999998}, {'accuracy': 0.19073}, {'accuracy': 0.16326}, {'accuracy': 0.19041000000000002}, {'accuracy': 0.15836}, {'accuracy': 0.18851}, {'accuracy': 0.20831}, {'accuracy': 0.19807}, {'accuracy': 0.21511}, {'accuracy': 0.20415}, {'accuracy': 0.23668}, {'accuracy': 0.18033000000000002}, {'accuracy': 0.21099}, {'accuracy': 0.21433}, {'accuracy': 0.21670000000000003}, {'accuracy': 0.17550000000000002}, {'accuracy': 0.20046}, {'accuracy': 0.20439000000000002}, {'accuracy': 0.21966999999999998}, {'accuracy': 0.19472}, {'accuracy': 0.20938000000000004}, {'accuracy': 0.21711}, {'accuracy': 0.22955}, {'accuracy': 0.23034}, {'accuracy': 0.21248999999999998}, {'accuracy': 0.19366}, {'accuracy': 0.21641}, {'accuracy': 0.23395000000000002}, {'accuracy': 0.22318000000000002}, {'accuracy': 0.2211}, {'accuracy': 0.22555999999999998}, {'accuracy': 0.22255000000000003}, {'accuracy': 0.24844}, {'accuracy': 0.24060000000000006}, {'accuracy': 0.21127}, {'accuracy': 0.21936999999999998}, {'accuracy': 0.25132}, {'accuracy': 0.25507}, {'accuracy': 0.26845}, {'accuracy': 0.26857}, {'accuracy': 0.26866999999999996}, {'accuracy': 0.24091999999999997}, {'accuracy': 0.26524000000000003}, {'accuracy': 0.24749000000000004}, {'accuracy': 0.26255}, {'accuracy': 0.24153000000000002}, {'accuracy': 0.25643}, {'accuracy': 0.24951000000000004}, {'accuracy': 0.26631}, {'accuracy': 0.25385}, {'accuracy': 0.28071999999999997}, {'accuracy': 0.27419000000000004}, {'accuracy': 0.27166999999999997}, {'accuracy': 0.28764}, {'accuracy': 0.30412}, {'accuracy': 0.28111}, {'accuracy': 0.32599}, {'accuracy': 0.27717}, {'accuracy': 0.30479}, {'accuracy': 0.28984}, {'accuracy': 0.2778}, {'accuracy': 0.26305}, {'accuracy': 0.31494}, {'accuracy': 0.29652}, {'accuracy': 0.28561000000000003}, {'accuracy': 0.31126}, {'accuracy': 0.29705}, {'accuracy': 0.2852}, {'accuracy': 0.30277000000000004}, {'accuracy': 0.30413999999999997}, {'accuracy': 0.31353}, {'accuracy': 0.28778000000000004}, {'accuracy': 0.30773}, {'accuracy': 0.31845}, {'accuracy': 0.29413}, {'accuracy': 0.30877}, {'accuracy': 0.33297}, {'accuracy': 0.32214}, {'accuracy': 0.32556999999999997}, {'accuracy': 0.3126}, {'accuracy': 0.35262000000000004}, {'accuracy': 0.31822}, {'accuracy': 0.3161}, {'accuracy': 0.33106}, {'accuracy': 0.35086000000000006}, {'accuracy': 0.33716}, {'accuracy': 0.34512000000000004}, {'accuracy': 0.34954999999999997}, {'accuracy': 0.34707}, {'accuracy': 0.34707999999999994}, {'accuracy': 0.32397}, {'accuracy': 0.3369599999999999}, {'accuracy': 0.33254}, {'accuracy': 0.35941000000000006}, {'accuracy': 0.34707}, {'accuracy': 0.34274}, {'accuracy': 0.36321}, {'accuracy': 0.34382999999999997}, {'accuracy': 0.35157999999999995}, {'accuracy': 0.36323}, {'accuracy': 0.35162000000000004}, {'accuracy': 0.36556}, {'accuracy': 0.36827}, {'accuracy': 0.36861}, {'accuracy': 0.36256}, {'accuracy': 0.35877000000000003}, {'accuracy': 0.37664}, {'accuracy': 0.36283}, {'accuracy': 0.37652}, {'accuracy': 0.37388000000000005}, {'accuracy': 0.3614}, {'accuracy': 0.36928}, {'accuracy': 0.36788999999999994}, {'accuracy': 0.38189}, {'accuracy': 0.36707}, {'accuracy': 0.37267}, {'accuracy': 0.37999}, {'accuracy': 0.39024000000000003}, {'accuracy': 0.35476}, {'accuracy': 0.38006}, {'accuracy': 0.39561}, {'accuracy': 0.39118}, {'accuracy': 0.37733000000000005}, {'accuracy': 0.3725299999999999}, {'accuracy': 0.38}, {'accuracy': 0.38706999999999997}, {'accuracy': 0.36806}, {'accuracy': 0.39438999999999996}, {'accuracy': 0.39011}, {'accuracy': 0.37424}, {'accuracy': 0.39726000000000006}, {'accuracy': 0.39778}, {'accuracy': 0.36587000000000003}, {'accuracy': 0.38580000000000003}, {'accuracy': 0.38388}, {'accuracy': 0.38251999999999997}, {'accuracy': 0.37492000000000003}, {'accuracy': 0.39668000000000003}, {'accuracy': 0.39985}, {'accuracy': 0.37288}, {'accuracy': 0.42458999999999997}, {'accuracy': 0.43598}, {'accuracy': 0.45675}, {'accuracy': 0.4652299999999999}, {'accuracy': 0.46757}, {'accuracy': 0.4676600000000001}, {'accuracy': 0.4673900000000001}, {'accuracy': 0.46165}, {'accuracy': 0.46297000000000005}, {'accuracy': 0.46613}, {'accuracy': 0.47126}, {'accuracy': 0.47113999999999995}, {'accuracy': 0.4715000000000001}, {'accuracy': 0.46746}, {'accuracy': 0.46702000000000005}, {'accuracy': 0.47128}, {'accuracy': 0.47724}, {'accuracy': 0.47346000000000005}, {'accuracy': 0.47246}, {'accuracy': 0.46646}, {'accuracy': 0.46803}, {'accuracy': 0.47291}, {'accuracy': 0.46958}, {'accuracy': 0.47723000000000004}, {'accuracy': 0.46819000000000005}, {'accuracy': 0.47685000000000005}, {'accuracy': 0.48432}, {'accuracy': 0.47933000000000003}, {'accuracy': 0.48188999999999993}, {'accuracy': 0.48208}, {'accuracy': 0.47490000000000004}, {'accuracy': 0.48162000000000005}, {'accuracy': 0.47526999999999997}, {'accuracy': 0.47385}, {'accuracy': 0.47709}, {'accuracy': 0.47341}, {'accuracy': 0.47783}, {'accuracy': 0.4789}, {'accuracy': 0.4764099999999999}, {'accuracy': 0.47979000000000005}, {'accuracy': 0.47590999999999994}, {'accuracy': 0.4805}, {'accuracy': 0.48021}, {'accuracy': 0.48305999999999993}, {'accuracy': 0.48631000000000013}, {'accuracy': 0.4823099999999999}, {'accuracy': 0.48312999999999995}, {'accuracy': 0.48749000000000003}, {'accuracy': 0.48051999999999995}, {'accuracy': 0.48037}, {'accuracy': 0.47706}, {'accuracy': 0.47781}, {'accuracy': 0.4805499999999999}, {'accuracy': 0.47325999999999996}, {'accuracy': 0.47774}, {'accuracy': 0.46548}, {'accuracy': 0.4695499999999999}, {'accuracy': 0.48174}, {'accuracy': 0.46570999999999996}, {'accuracy': 0.47926000000000013}, {'accuracy': 0.48143}, {'accuracy': 0.48258}, {'accuracy': 0.48129}, {'accuracy': 0.48084000000000005}, {'accuracy': 0.4840400000000001}, {'accuracy': 0.48342}, {'accuracy': 0.48356000000000005}, {'accuracy': 0.47963000000000006}, {'accuracy': 0.4825799999999999}, {'accuracy': 0.48855999999999994}, {'accuracy': 0.47526}, {'accuracy': 0.47448999999999997}, {'accuracy': 0.46895999999999993}, {'accuracy': 0.4799399999999999}, {'accuracy': 0.48256}, {'accuracy': 0.47955000000000003}, {'accuracy': 0.48097}, {'accuracy': 0.48433000000000004}, {'accuracy': 0.48624999999999996}, {'accuracy': 0.48647}, {'accuracy': 0.48661000000000004}, {'accuracy': 0.4857100000000001}, {'accuracy': 0.48575999999999997}, {'accuracy': 0.48264000000000007}, {'accuracy': 0.4819}, {'accuracy': 0.48396999999999996}, {'accuracy': 0.48095}, {'accuracy': 0.48177000000000003}, {'accuracy': 0.48517}, {'accuracy': 0.4833}, {'accuracy': 0.47977}, {'accuracy': 0.48676}, {'accuracy': 0.48260999999999993}, {'accuracy': 0.48505999999999994}, {'accuracy': 0.47501000000000004}, {'accuracy': 0.48874000000000006}, {'accuracy': 0.48334}, {'accuracy': 0.48966000000000004}, {'accuracy': 0.48602999999999996}, {'accuracy': 0.48177000000000003}, {'accuracy': 0.47844}, {'accuracy': 0.48166000000000003}, {'accuracy': 0.48548}, {'accuracy': 0.48511999999999994}, {'accuracy': 0.48057000000000005}, {'accuracy': 0.48283999999999994}, {'accuracy': 0.47745999999999994}, {'accuracy': 0.47844999999999993}, {'accuracy': 0.4794899999999999}, {'accuracy': 0.47246}, {'accuracy': 0.48477999999999993}, {'accuracy': 0.48418}, {'accuracy': 0.48346}, {'accuracy': 0.4814900000000001}, {'accuracy': 0.48965}, {'accuracy': 0.48373}, {'accuracy': 0.48159}, {'accuracy': 0.48712999999999995}, {'accuracy': 0.48538}, {'accuracy': 0.48410000000000003}, {'accuracy': 0.48477}, {'accuracy': 0.48262}, {'accuracy': 0.48888}, {'accuracy': 0.48741}, {'accuracy': 0.48555000000000004}, {'accuracy': 0.48562000000000005}, {'accuracy': 0.48545}, {'accuracy': 0.48514}, {'accuracy': 0.4835}, {'accuracy': 0.48543000000000003}, {'accuracy': 0.48302000000000006}, {'accuracy': 0.47822999999999993}, {'accuracy': 0.48127}, {'accuracy': 0.48567}, {'accuracy': 0.48263000000000006}, {'accuracy': 0.48125999999999997}, {'accuracy': 0.4835900000000001}, {'accuracy': 0.48434999999999995}, {'accuracy': 0.48574}, {'accuracy': 0.48278999999999994}, {'accuracy': 0.4846500000000001}, {'accuracy': 0.47886999999999996}, {'accuracy': 0.4728199999999999}, {'accuracy': 0.4808}, {'accuracy': 0.48125}, {'accuracy': 0.48360000000000003}, {'accuracy': 0.48406000000000005}, {'accuracy': 0.48575}, {'accuracy': 0.48638000000000003}, {'accuracy': 0.48432}, {'accuracy': 0.48578}, {'accuracy': 0.4868}, {'accuracy': 0.47935999999999995}, {'accuracy': 0.48214000000000007}, {'accuracy': 0.48487}, {'accuracy': 0.48281999999999997}, {'accuracy': 0.48495}, {'accuracy': 0.48056}, {'accuracy': 0.48462000000000005}, {'accuracy': 0.4770899999999999}, {'accuracy': 0.48362}, {'accuracy': 0.4768}, {'accuracy': 0.4840400000000001}, {'accuracy': 0.48334}, {'accuracy': 0.48364}, {'accuracy': 0.48172000000000004}, {'accuracy': 0.48274}, {'accuracy': 0.48251999999999995}, {'accuracy': 0.4827699999999999}, {'accuracy': 0.48427}, {'accuracy': 0.48410000000000003}, {'accuracy': 0.48416}, {'accuracy': 0.48856}, {'accuracy': 0.48841999999999997}, {'accuracy': 0.48511000000000004}, {'accuracy': 0.48534000000000005}, {'accuracy': 0.48714}, {'accuracy': 0.48619}, {'accuracy': 0.48109}, {'accuracy': 0.46135000000000004}, {'accuracy': 0.47241}, {'accuracy': 0.47679}, {'accuracy': 0.48029}, {'accuracy': 0.47743}, {'accuracy': 0.47336}, {'accuracy': 0.48292}, {'accuracy': 0.47841000000000006}, {'accuracy': 0.48213999999999996}, {'accuracy': 0.4808199999999999}, {'accuracy': 0.48273}, {'accuracy': 0.48365}, {'accuracy': 0.48407}, {'accuracy': 0.48329000000000005}, {'accuracy': 0.4853300000000001}, {'accuracy': 0.48714}, {'accuracy': 0.48457999999999996}, {'accuracy': 0.47485}, {'accuracy': 0.47988}, {'accuracy': 0.48339999999999994}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "242193f5-6fc9-461f-95f5-e2901e278590",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "240ba157-77dd-47ba-8e79-4a6f5172c73f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c0c887e4-ddae-413a-865a-cf067f8fd7b3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5f5f27e4-5bc6-4b9c-aae1-f9733aa11589",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dade01f3-e4c9-46eb-bcca-3cd0e055cc20",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5bd95d88-5e25-4347-a4e4-e158d1f45599",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a3587fd-7bfa-44f2-8954-f8ff94233c05",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f1c9de94-0207-4d38-be21-be5f2f1556c8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dbf24558-92fb-4091-beff-8f21868b3b8e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1b563a18-b833-4fcb-8dc0-629fd6a21087",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bd3bd2f2-9e33-4a97-8b2f-27e68496be4a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8f8a0be9-7afd-4692-b4cc-873bba93e8a9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be3447c6-7910-49bf-b187-3f7907d1cddb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fde2ad41-7102-4f44-aa1c-4b6dabd3dfb2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a051f4e3-e14c-4092-8300-fe89fc4ba49c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "18695822-3fd4-49fb-b75d-33b9ac65e4cb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d2aa3d5-95a4-4585-9076-79d0d03fe113",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed3c9f73-5701-46b0-bd84-026cd60f6d2c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "efee0526-319c-4cd9-b7a5-bbf3ea389f2f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b1ce10e8-fb04-4bb7-b7a9-8e5dad763013",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eaa452c6-4433-4b7a-bd77-e6dba9dab519",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "681ca48f-e1d1-4645-bf83-20025a9d102f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5ef4dba1-5984-472b-b805-aed3b188e400",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d2e459a3-98d2-4ee0-bbb7-7fcff0cb8e99",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a825395a-2b03-481a-8920-ab9eb086fae7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "abb9195f-8552-43b0-b87c-4274fa338770",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a2e012d6-992d-49e2-800c-5cd13689b314",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "950c4100-6492-4d27-b39d-0c4f6fed387c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "65561be3-ce35-4a4f-86ae-4a5f7088bdd2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "285d65e6-e81f-4ac8-82ad-aa3da92afc1e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "901476f2-7836-44a3-aef7-63586cc82ddf",
   "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
}
