{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "21b4997f-439f-4dfa-a9de-72121a2b3aad",
   "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 2031]\n",
      " [   1   49]\n",
      " [   2   37]\n",
      " [   3   62]\n",
      " [   4   96]\n",
      " [   5  166]\n",
      " [   6  259]\n",
      " [   7  421]\n",
      " [   8  760]\n",
      " [   9 1221]]\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 1134]\n",
      " [   1 1976]\n",
      " [   2   51]\n",
      " [   3   28]\n",
      " [   4   54]\n",
      " [   5   82]\n",
      " [   6  157]\n",
      " [   7  264]\n",
      " [   8  399]\n",
      " [   9  712]]\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  768]\n",
      " [   1 1206]\n",
      " [   2 2015]\n",
      " [   3   61]\n",
      " [   4   35]\n",
      " [   5   55]\n",
      " [   6   95]\n",
      " [   7  157]\n",
      " [   8  280]\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  398]\n",
      " [   1  734]\n",
      " [   2 1148]\n",
      " [   3 2026]\n",
      " [   4   37]\n",
      " [   5   35]\n",
      " [   6   53]\n",
      " [   7   92]\n",
      " [   8  155]\n",
      " [   9  275]]\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  284]\n",
      " [   1  430]\n",
      " [   2  758]\n",
      " [   3 1188]\n",
      " [   4 1958]\n",
      " [   5   45]\n",
      " [   6   39]\n",
      " [   7   65]\n",
      " [   8   93]\n",
      " [   9  165]]\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  150]\n",
      " [   1  260]\n",
      " [   2  422]\n",
      " [   3  726]\n",
      " [   4 1244]\n",
      " [   5 1933]\n",
      " [   6   54]\n",
      " [   7   38]\n",
      " [   8   59]\n",
      " [   9   83]]\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   85]\n",
      " [   1  154]\n",
      " [   2  288]\n",
      " [   3  420]\n",
      " [   4  729]\n",
      " [   5 1232]\n",
      " [   6 2067]\n",
      " [   7   61]\n",
      " [   8   31]\n",
      " [   9   50]]\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   68]\n",
      " [   1   93]\n",
      " [   2  147]\n",
      " [   3  242]\n",
      " [   4  417]\n",
      " [   5  773]\n",
      " [   6 1191]\n",
      " [   7 1966]\n",
      " [   8   45]\n",
      " [   9   52]]\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   34]\n",
      " [   1   60]\n",
      " [   2   81]\n",
      " [   3  142]\n",
      " [   4  264]\n",
      " [   5  402]\n",
      " [   6  681]\n",
      " [   7 1234]\n",
      " [   8 1956]\n",
      " [   9   50]]\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   48]\n",
      " [   1   38]\n",
      " [   2   53]\n",
      " [   3  105]\n",
      " [   4  166]\n",
      " [   5  277]\n",
      " [   6  404]\n",
      " [   7  702]\n",
      " [   8 1222]\n",
      " [   9 1939]]\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": [
      "15130\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 1416]\n",
      " [   1   36]\n",
      " [   2   26]\n",
      " [   3   42]\n",
      " [   4   61]\n",
      " [   5  115]\n",
      " [   6  178]\n",
      " [   7  290]\n",
      " [   8  530]\n",
      " [   9  793]]\n",
      "[[   0 2086]\n",
      " [   1   50]\n",
      " [   2   35]\n",
      " [   3   63]\n",
      " [   4   76]\n",
      " [   5  161]\n",
      " [   6  248]\n",
      " [   7  409]\n",
      " [   8  756]\n",
      " [   9 1160]]\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",
    "        \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<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",
    "        pa=random.randint(0,9)\n",
    "        while pa == tag1[z]:\n",
    "            pa=random.randint(0,9)\n",
    "        tag1[z]=pa\n",
    "        noiseyset[1].append(tag1[z])    \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[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][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": "c32381c6-0952-465a-9662-10d448e880f2",
   "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=350)\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.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10008000000000002}, {'accuracy': 0.10008000000000002}, {'accuracy': 0.10191000000000001}, {'accuracy': 0.10802}, {'accuracy': 0.10549}, {'accuracy': 0.10563}, {'accuracy': 0.10222}, {'accuracy': 0.10301}, {'accuracy': 0.1132}, {'accuracy': 0.1109}, {'accuracy': 0.11536000000000002}, {'accuracy': 0.11482}, {'accuracy': 0.12809999999999996}, {'accuracy': 0.10435000000000001}, {'accuracy': 0.11335000000000002}, {'accuracy': 0.11100000000000002}, {'accuracy': 0.12219999999999998}, {'accuracy': 0.12969000000000003}, {'accuracy': 0.13479}, {'accuracy': 0.13489}, {'accuracy': 0.13382999999999998}, {'accuracy': 0.14689000000000002}, {'accuracy': 0.15685}, {'accuracy': 0.16082999999999997}, {'accuracy': 0.16296}, {'accuracy': 0.14855999999999997}, {'accuracy': 0.16378}, {'accuracy': 0.15437}, {'accuracy': 0.15709}, {'accuracy': 0.18959}, {'accuracy': 0.1999}, {'accuracy': 0.17763}, {'accuracy': 0.18572}, {'accuracy': 0.19938}, {'accuracy': 0.18864}, {'accuracy': 0.20396}, {'accuracy': 0.18775999999999998}, {'accuracy': 0.21451000000000003}, {'accuracy': 0.22698000000000002}, {'accuracy': 0.20979}, {'accuracy': 0.21724000000000002}, {'accuracy': 0.22069}, {'accuracy': 0.22533000000000003}, {'accuracy': 0.21275000000000005}, {'accuracy': 0.21106000000000003}, {'accuracy': 0.22399}, {'accuracy': 0.24721}, {'accuracy': 0.24013999999999996}, {'accuracy': 0.20865999999999998}, {'accuracy': 0.24799}, {'accuracy': 0.26507}, {'accuracy': 0.23653}, {'accuracy': 0.21829}, {'accuracy': 0.24769000000000005}, {'accuracy': 0.26614}, {'accuracy': 0.24488999999999997}, {'accuracy': 0.26391}, {'accuracy': 0.25494}, {'accuracy': 0.24861}, {'accuracy': 0.25755999999999996}, {'accuracy': 0.25244}, {'accuracy': 0.27854999999999996}, {'accuracy': 0.24695999999999999}, {'accuracy': 0.25712}, {'accuracy': 0.2372}, {'accuracy': 0.27308000000000004}, {'accuracy': 0.23842}, {'accuracy': 0.23827000000000004}, {'accuracy': 0.26355999999999996}, {'accuracy': 0.26398}, {'accuracy': 0.28202000000000005}, {'accuracy': 0.27598}, {'accuracy': 0.26947}, {'accuracy': 0.27767}, {'accuracy': 0.24718}, {'accuracy': 0.25061000000000005}, {'accuracy': 0.26529}, {'accuracy': 0.25671999999999995}, {'accuracy': 0.25683999999999996}, {'accuracy': 0.24608000000000002}, {'accuracy': 0.25216}, {'accuracy': 0.26589}, {'accuracy': 0.23611}, {'accuracy': 0.29589000000000004}, {'accuracy': 0.26213000000000003}, {'accuracy': 0.2847}, {'accuracy': 0.28378000000000003}, {'accuracy': 0.28087}, {'accuracy': 0.28554}, {'accuracy': 0.25368}, {'accuracy': 0.26119000000000003}, {'accuracy': 0.28064}, {'accuracy': 0.28573000000000004}, {'accuracy': 0.27779999999999994}, {'accuracy': 0.28283}, {'accuracy': 0.29556}, {'accuracy': 0.27566999999999997}, {'accuracy': 0.26882999999999996}, {'accuracy': 0.29764999999999997}, {'accuracy': 0.27076}, {'accuracy': 0.27174}, {'accuracy': 0.25467999999999996}, {'accuracy': 0.28252}, {'accuracy': 0.30437}, {'accuracy': 0.26782000000000006}, {'accuracy': 0.31621999999999995}, {'accuracy': 0.26023}, {'accuracy': 0.2942}, {'accuracy': 0.31202}, {'accuracy': 0.30469}, {'accuracy': 0.2813}, {'accuracy': 0.27577999999999997}, {'accuracy': 0.28417}, {'accuracy': 0.31022000000000005}, {'accuracy': 0.27767}, {'accuracy': 0.29602000000000006}, {'accuracy': 0.30599999999999994}, {'accuracy': 0.31848}, {'accuracy': 0.32314000000000004}, {'accuracy': 0.30865}, {'accuracy': 0.33176}, {'accuracy': 0.29131}, {'accuracy': 0.2853}, {'accuracy': 0.30738}, {'accuracy': 0.32391000000000003}, {'accuracy': 0.33894}, {'accuracy': 0.25669}, {'accuracy': 0.30536}, {'accuracy': 0.31798999999999994}, {'accuracy': 0.28232}, {'accuracy': 0.34211}, {'accuracy': 0.32455}, {'accuracy': 0.34611000000000003}, {'accuracy': 0.31011}, {'accuracy': 0.30993}, {'accuracy': 0.33523}, {'accuracy': 0.34317}, {'accuracy': 0.37551999999999996}, {'accuracy': 0.33957000000000004}, {'accuracy': 0.33059000000000005}, {'accuracy': 0.3526}, {'accuracy': 0.3440599999999999}, {'accuracy': 0.3707000000000001}, {'accuracy': 0.36494}, {'accuracy': 0.35185000000000005}, {'accuracy': 0.36829}, {'accuracy': 0.34445000000000003}, {'accuracy': 0.33172}, {'accuracy': 0.3557}, {'accuracy': 0.34168}, {'accuracy': 0.3375699999999999}, {'accuracy': 0.34198}, {'accuracy': 0.36666}, {'accuracy': 0.3523}, {'accuracy': 0.36593}, {'accuracy': 0.32702}, {'accuracy': 0.34684}, {'accuracy': 0.37803}, {'accuracy': 0.35818}, {'accuracy': 0.36207}, {'accuracy': 0.36561999999999995}, {'accuracy': 0.37520000000000003}, {'accuracy': 0.31723}, {'accuracy': 0.34502}, {'accuracy': 0.35021}, {'accuracy': 0.37675000000000003}, {'accuracy': 0.36965}, {'accuracy': 0.36619999999999997}, {'accuracy': 0.36902}, {'accuracy': 0.34878}, {'accuracy': 0.35667}, {'accuracy': 0.35424}, {'accuracy': 0.40216}, {'accuracy': 0.40216}, {'accuracy': 0.34534000000000004}, {'accuracy': 0.38201000000000007}, {'accuracy': 0.38007}, {'accuracy': 0.34689000000000003}, {'accuracy': 0.37334}, {'accuracy': 0.39001}, {'accuracy': 0.36968999999999996}, {'accuracy': 0.37259000000000003}, {'accuracy': 0.39353}, {'accuracy': 0.36238000000000004}, {'accuracy': 0.39760999999999996}, {'accuracy': 0.39258}, {'accuracy': 0.37856}, {'accuracy': 0.37974}, {'accuracy': 0.37886}, {'accuracy': 0.37245000000000006}, {'accuracy': 0.35785999999999996}, {'accuracy': 0.31649999999999995}, {'accuracy': 0.36973}, {'accuracy': 0.39371999999999996}, {'accuracy': 0.41544}, {'accuracy': 0.43136}, {'accuracy': 0.42306999999999995}, {'accuracy': 0.42650000000000005}, {'accuracy': 0.4348599999999999}, {'accuracy': 0.43776000000000004}, {'accuracy': 0.43052999999999997}, {'accuracy': 0.42973}, {'accuracy': 0.43948}, {'accuracy': 0.42367999999999995}, {'accuracy': 0.43678999999999996}, {'accuracy': 0.44338000000000005}, {'accuracy': 0.44116999999999995}, {'accuracy': 0.41939000000000004}, {'accuracy': 0.44270000000000004}, {'accuracy': 0.4532}, {'accuracy': 0.43343}, {'accuracy': 0.43305}, {'accuracy': 0.43572000000000005}, {'accuracy': 0.43287000000000003}, {'accuracy': 0.42042999999999997}, {'accuracy': 0.43457999999999997}, {'accuracy': 0.43479999999999996}, {'accuracy': 0.44189}, {'accuracy': 0.44478999999999996}, {'accuracy': 0.42522000000000004}, {'accuracy': 0.44569000000000003}, {'accuracy': 0.44438000000000005}, {'accuracy': 0.44369}, {'accuracy': 0.44820000000000004}, {'accuracy': 0.44936999999999994}, {'accuracy': 0.44546}, {'accuracy': 0.44593000000000005}, {'accuracy': 0.45369000000000004}, {'accuracy': 0.44729}, {'accuracy': 0.44249}, {'accuracy': 0.43113999999999997}, {'accuracy': 0.44432}, {'accuracy': 0.44345}, {'accuracy': 0.45260999999999996}, {'accuracy': 0.45888}, {'accuracy': 0.45601}, {'accuracy': 0.45976}, {'accuracy': 0.454}, {'accuracy': 0.45359}, {'accuracy': 0.46421}, {'accuracy': 0.45546}, {'accuracy': 0.4476400000000001}, {'accuracy': 0.45220000000000005}, {'accuracy': 0.4492900000000001}, {'accuracy': 0.45189}, {'accuracy': 0.45377}, {'accuracy': 0.44766000000000006}, {'accuracy': 0.45597999999999994}, {'accuracy': 0.46064}, {'accuracy': 0.45002999999999993}, {'accuracy': 0.45639}, {'accuracy': 0.46205000000000007}, {'accuracy': 0.45458}, {'accuracy': 0.4579}, {'accuracy': 0.45932000000000006}, {'accuracy': 0.4574}, {'accuracy': 0.45847}, {'accuracy': 0.45236}, {'accuracy': 0.45611999999999997}, {'accuracy': 0.45366}, {'accuracy': 0.45436999999999994}, {'accuracy': 0.46158}, {'accuracy': 0.44589}, {'accuracy': 0.44616}, {'accuracy': 0.44497}, {'accuracy': 0.44501}, {'accuracy': 0.44645999999999997}, {'accuracy': 0.45795}, {'accuracy': 0.45355999999999996}, {'accuracy': 0.45561999999999997}, {'accuracy': 0.45734}, {'accuracy': 0.45355000000000006}, {'accuracy': 0.45606}, {'accuracy': 0.45499}, {'accuracy': 0.45260999999999996}, {'accuracy': 0.45472999999999997}, {'accuracy': 0.44718}, {'accuracy': 0.45204999999999995}, {'accuracy': 0.45178}, {'accuracy': 0.46259000000000006}, {'accuracy': 0.45779000000000003}, {'accuracy': 0.46170999999999995}, {'accuracy': 0.45685000000000003}, {'accuracy': 0.45948}, {'accuracy': 0.45702}, {'accuracy': 0.45532000000000006}, {'accuracy': 0.45671}, {'accuracy': 0.45441000000000004}, {'accuracy': 0.45954000000000006}, {'accuracy': 0.46335}, {'accuracy': 0.45848000000000005}, {'accuracy': 0.45768000000000003}, {'accuracy': 0.45718999999999993}, {'accuracy': 0.4633}, {'accuracy': 0.45725}, {'accuracy': 0.46437999999999996}, {'accuracy': 0.45665999999999995}, {'accuracy': 0.45977999999999997}, {'accuracy': 0.45967}, {'accuracy': 0.4565}, {'accuracy': 0.45553}, {'accuracy': 0.45822}, {'accuracy': 0.45942}, {'accuracy': 0.45960999999999996}, {'accuracy': 0.46101000000000003}, {'accuracy': 0.4542999999999999}, {'accuracy': 0.45863000000000004}, {'accuracy': 0.45620000000000005}, {'accuracy': 0.45628}, {'accuracy': 0.45728}, {'accuracy': 0.45599}, {'accuracy': 0.45967}, {'accuracy': 0.4475599999999999}, {'accuracy': 0.42504}, {'accuracy': 0.45341000000000004}, {'accuracy': 0.45699000000000006}, {'accuracy': 0.4606100000000001}, {'accuracy': 0.45816000000000007}, {'accuracy': 0.45663}, {'accuracy': 0.46242}, {'accuracy': 0.46294}, {'accuracy': 0.45426}, {'accuracy': 0.45522999999999997}, {'accuracy': 0.45687}, {'accuracy': 0.45829999999999993}, {'accuracy': 0.45894}, {'accuracy': 0.4569500000000001}, {'accuracy': 0.46141}, {'accuracy': 0.45718999999999993}, {'accuracy': 0.45596}, {'accuracy': 0.46023000000000003}, {'accuracy': 0.45685000000000003}, {'accuracy': 0.45687}, {'accuracy': 0.45877999999999997}, {'accuracy': 0.45846}, {'accuracy': 0.45752999999999994}, {'accuracy': 0.45722000000000007}, {'accuracy': 0.4573499999999999}, {'accuracy': 0.45620000000000005}, {'accuracy': 0.4531199999999999}, {'accuracy': 0.45640000000000003}]\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": "iVBORw0KGgoAAAANSUhEUgAAAkAAAAHHCAYAAABXx+fLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAACSiElEQVR4nO3dd3hUZdoG8Hv6THqvBEJCk94EUSlCJNixIssKYhfZ1cXKqrC2RVH5sOOyCnZRVl3XAkokKIp0pHdCgPSEZJJJMjOZOd8fM+fknCkhgSSTcv+uKxfJmTNn3pOE5MnzPO/7qgRBEEBERETUiagDPQAiIiKi1sYAiIiIiDodBkBERETU6TAAIiIiok6HARARERF1OgyAiIiIqNNhAERERESdDgMgIiIi6nQYABEREVGnwwCIiAIuOzsbKpUK2dnZ0rFbb70VqampARtTR/KPf/wDKpUq0MMgalMYABF1AHv27MGf//xnJCcnw2AwICkpCdOmTcOePXsCPbQW9+abb2L58uUt+hp79+7FP/7xD+Tk5LTo67Smf/7zn/jqq68CPQyigGEARNTOffHFFxg6dCiysrIwc+ZMvPnmm7j99tuxdu1aDB06FF9++WWgh9iiWisAeuqppxgAEXUg2kAPgIjO3pEjR3DLLbcgLS0NP//8M2JjY6XH7r//fowePRq33HILdu7cibS0tFYbl8ViQXBwcKu9XnvAzwlR28IMEFE79uKLL6K6uhr/+te/FMEPAMTExODtt9+GxWLBwoULAQArV66ESqXCunXrvK719ttvQ6VSYffu3dKx/fv344YbbkBUVBSMRiOGDx+Or7/+WvG85cuXS9ecNWsW4uLi0KVLFwDA8ePHMWvWLPTu3RsmkwnR0dG48cYbmy2Tkpqaij179mDdunVQqVRQqVQYN26c9Hh5eTkeeOABpKSkwGAwoEePHnjhhRfgdDoV1/n0008xbNgwhIaGIiwsDAMGDMArr7wi3d+NN94IALjkkkuk15H3K3m69dZbERISgiNHjuDyyy9HaGgopk2bBgBwOp1YvHgx+vXrB6PRiPj4eNx99904ffq04hpbtmxBZmYmYmJiYDKZ0L17d9x2223S4776pgAgJycHKpWqwayYSqWCxWLBe++9J93PrbfeCgCorKzEAw88gNTUVBgMBsTFxeHSSy/Ftm3b/F6PqD1iBoioHfvf//6H1NRUjB492ufjY8aMQWpqKr799lsAwBVXXIGQkBB89tlnGDt2rOLcFStWoF+/fujfvz8AV1/RRRddhOTkZDz22GMIDg7GZ599hsmTJ+M///kPrr32WsXzZ82ahdjYWMybNw8WiwUAsHnzZvz222+4+eab0aVLF+Tk5OCtt97CuHHjsHfvXgQFBZ3T/S9evBh/+ctfEBISgscffxwAEB8fDwCorq7G2LFjcerUKdx9993o2rUrfvvtN8ydOxf5+flYvHgxAODHH3/E1KlTMWHCBLzwwgsAgH379uHXX3/F/fffjzFjxuCvf/0rXn31Vfz973/HeeedBwDSv/7U1dUhMzMTF198MV566SXpXu+++24sX74cM2fOxF//+lccO3YMr7/+OrZv345ff/0VOp0ORUVFmDhxImJjY/HYY48hIiICOTk5+OKLL87p8yX64IMPcMcdd2DEiBG46667AADp6ekAgHvuuQcrV67E7Nmz0bdvX5SWlmL9+vXYt28fhg4d2iyvT9QmCETULpWXlwsAhGuuuabB866++moBgGA2mwVBEISpU6cKcXFxQl1dnXROfn6+oFarhaefflo6NmHCBGHAgAFCbW2tdMzpdAoXXnih0LNnT+nYsmXLBADCxRdfrLimIAhCdXW113g2bNggABDef/996djatWsFAMLatWulYzNmzBC6devW4L0JgiD069dPGDt2rNfxZ555RggODhYOHjyoOP7YY48JGo1GyM3NFQRBEO6//34hLCzMa+xyn3/+udf4GjJjxgwBgPDYY48pjv/yyy8CAOGjjz5SHF+1apXi+JdffikAEDZv3uz3NXx9zgRBEI4dOyYAEJYtWyYdmz9/vuD54z44OFiYMWOG13XDw8OF++67rxF3SdS+sQRG1E5VVlYCAEJDQxs8T3zcbDYDAKZMmYKioiJF6WTlypVwOp2YMmUKAKCsrAw//fQTbrrpJlRWVqKkpAQlJSUoLS1FZmYmDh06hFOnTile584774RGo1EcM5lM0vt2ux2lpaXo0aMHIiIiWryk8vnnn2P06NGIjIyUxl9SUoKMjAw4HA78/PPPAICIiAhYLBb8+OOPzT6Ge++912tM4eHhuPTSSxVjGjZsGEJCQrB27VppTADwzTffwG63N/u4GhIREYGNGzciLy+vVV+XqLUxACJqp8TARgyE/PEM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5JNP8Oqrr2Lfvn14++23ERIS4vN1jhw5gkmTJuH666/Hzp07sWLFCqxfv94ryCKi9oeboRJRu1JZWYnY2Fi8/vrruOOOOxSP1dbWIikpCUuWLMFNN90EABg0aBCuu+46zJ8/HwcPHkTv3r3x448/IiMjw+va2dnZuOSSS3D69GlERETgjjvugEajwdtvvy2ds379eowdOxYWiwVGo7Flb5aIWgwzQETUruzbtw9WqxUTJkzwesxoNOKWW27Bu+++CwDYtm0bdu/ejVtvvRUAsGPHDmg0GowdO7ZRr/XHH39g+fLlCAkJkd4yMzPhdDpx7NixZrsnImp92kAPgIioKUwmU4OP33HHHRg8eDBOnjyJZcuWYfz48ejWrVujnuupqqoKd999N/761796Pda1a9cmXYuI2hZmgIioXenZsydMJpPU1OxpwIABGD58OJYuXYqPP/4Yt912m+Ixp9OJdevWNeq1hg4dir1796JHjx5eb3q9vlnuh4gCgwEQEbUrRqMRjz76KB555BG8//77OHLkCH7//XfFTK477rgDzz//PARBwLXXXisdT01NxYwZM3Dbbbfhq6++wrFjx5CdnY3PPvvM52s9+uij+O233zB79mzs2LEDhw4dwn//+182QRN1AAyAiKjdefLJJ/Hggw9i3rx5OO+88zBlyhQUFRVJj0+dOhVarRZTp071alR+6623cMMNN2DWrFno06cP7rzzTr/T2gcOHIh169bh4MGDGD16NIYMGYJ58+YhKSmpRe+PiFoeZ4ERUYeTk5OD9PR0bN68GUOHDg30cIioDWIAREQdht1uR2lpKR566CEcO3YMv/76a6CHRERtFEtgRNRh/Prrr0hMTMTmzZuxZMmSQA+HiNowZoCIiIio02EGiIiIiDodBkBERETU6TAAIiIiok6HARARERF1OgyAiIiIqNNhAERERESdDgMgIiIi6nQYABEREVGnwwCIiIiIOp3/B7CwtT3Sh+leAAAAAElFTkSuQmCC",
      "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": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "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": "2f6c5879-a537-4312-9fec-14a74d2b1a94",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "17ab1040-3048-4e83-907d-2801f5f2f9c3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "15b6f1a7-34f0-48de-a463-95c72c2f672f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fae9b2b6-0854-4ccc-891e-7d1b3f851aba",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ddcf15ad-4a0a-4ffb-9a6a-c021aba1205a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4bec41d2-4033-46a5-a89c-58015596be16",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2acb1f20-079e-48c8-9df4-8e5da11a1fa1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cd6504be-8fbd-4cd7-b810-756eaca7ee2c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "11634b6f-b721-4d5a-8560-0abdf216809d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b69f35ec-9d8a-4cbf-b706-5e6f9a52d7cf",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c91785e1-28d1-4847-bb31-8a29ec680e1e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e390cb1c-1dca-454a-bf3b-dae01b71a2f9",
   "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
}
