{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "11c73c96-9735-4cd2-9ae9-8b41e4c3ea3a",
   "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 1986]\n",
      " [   1   48]\n",
      " [   2   26]\n",
      " [   3   68]\n",
      " [   4   85]\n",
      " [   5  150]\n",
      " [   6  252]\n",
      " [   7  450]\n",
      " [   8  698]\n",
      " [   9 1191]]\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 1232]\n",
      " [   1 2023]\n",
      " [   2   39]\n",
      " [   3   42]\n",
      " [   4   64]\n",
      " [   5   95]\n",
      " [   6  169]\n",
      " [   7  265]\n",
      " [   8  457]\n",
      " [   9  762]]\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  734]\n",
      " [   1 1173]\n",
      " [   2 1998]\n",
      " [   3   45]\n",
      " [   4   46]\n",
      " [   5   53]\n",
      " [   6  103]\n",
      " [   7  143]\n",
      " [   8  242]\n",
      " [   9  397]]\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  433]\n",
      " [   1  738]\n",
      " [   2 1232]\n",
      " [   3 2009]\n",
      " [   4   47]\n",
      " [   5   30]\n",
      " [   6   56]\n",
      " [   7   95]\n",
      " [   8  162]\n",
      " [   9  274]]\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  242]\n",
      " [   1  439]\n",
      " [   2  721]\n",
      " [   3 1183]\n",
      " [   4 2028]\n",
      " [   5   43]\n",
      " [   6   37]\n",
      " [   7   55]\n",
      " [   8  109]\n",
      " [   9  143]]\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  147]\n",
      " [   1  269]\n",
      " [   2  444]\n",
      " [   3  708]\n",
      " [   4 1167]\n",
      " [   5 1948]\n",
      " [   6   58]\n",
      " [   7   27]\n",
      " [   8   55]\n",
      " [   9   92]]\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   78]\n",
      " [   1  146]\n",
      " [   2  259]\n",
      " [   3  420]\n",
      " [   4  725]\n",
      " [   5 1255]\n",
      " [   6 1997]\n",
      " [   7   44]\n",
      " [   8   40]\n",
      " [   9   39]]\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   63]\n",
      " [   1   85]\n",
      " [   2  145]\n",
      " [   3  255]\n",
      " [   4  426]\n",
      " [   5  739]\n",
      " [   6 1153]\n",
      " [   7 1988]\n",
      " [   8   45]\n",
      " [   9   38]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "abad36f3-ca9c-4b61-b13c-84d76f89518d",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   33]\n",
      " [   1   55]\n",
      " [   2   77]\n",
      " [   3  165]\n",
      " [   4  233]\n",
      " [   5  446]\n",
      " [   6  726]\n",
      " [   7 1207]\n",
      " [   8 2006]\n",
      " [   9   47]]\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   52]\n",
      " [   1   24]\n",
      " [   2   59]\n",
      " [   3  105]\n",
      " [   4  179]\n",
      " [   5  241]\n",
      " [   6  449]\n",
      " [   7  726]\n",
      " [   8 1186]\n",
      " [   9 2017]]\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": [
      "4950\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 1831]\n",
      " [   1   42]\n",
      " [   2   25]\n",
      " [   3   58]\n",
      " [   4   81]\n",
      " [   5  136]\n",
      " [   6  218]\n",
      " [   7  408]\n",
      " [   8  628]\n",
      " [   9 1078]]\n",
      "[[   0 2039]\n",
      " [   1   49]\n",
      " [   2   26]\n",
      " [   3   60]\n",
      " [   4   93]\n",
      " [   5  148]\n",
      " [   6  245]\n",
      " [   7  448]\n",
      " [   8  720]\n",
      " [   9 1197]]\n",
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 8, 8, 8])"
      ]
     },
     "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<1:\n",
    "        noiseyset[0].append(dataset1[z])\n",
    "        healthset[0].append(dataset1[z])\n",
    "        healthset[1].append(target1[z])\n",
    "        healthset[2].append(z)\n",
    "        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": "b9d382c7-5015-4102-a3c8-779bc244b73d",
   "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\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=42)\n",
    "simulator.start(n_rounds=350)\n",
    "\n"
   ]
  },
  {
   "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.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10133}, {'accuracy': 0.10049999999999999}, {'accuracy': 0.11282}, {'accuracy': 0.10429}, {'accuracy': 0.10784}, {'accuracy': 0.11669}, {'accuracy': 0.12206000000000002}, {'accuracy': 0.11483000000000002}, {'accuracy': 0.11372}, {'accuracy': 0.11678999999999999}, {'accuracy': 0.11393}, {'accuracy': 0.12074}, {'accuracy': 0.10801000000000001}, {'accuracy': 0.11400000000000002}, {'accuracy': 0.12017}, {'accuracy': 0.12349999999999998}, {'accuracy': 0.13439}, {'accuracy': 0.11914000000000002}, {'accuracy': 0.13123999999999997}, {'accuracy': 0.1277}, {'accuracy': 0.13759000000000002}, {'accuracy': 0.14943}, {'accuracy': 0.15352000000000002}, {'accuracy': 0.14969}, {'accuracy': 0.14604999999999999}, {'accuracy': 0.15023}, {'accuracy': 0.15975}, {'accuracy': 0.16970000000000002}, {'accuracy': 0.16183}, {'accuracy': 0.16072}, {'accuracy': 0.17502}, {'accuracy': 0.16795}, {'accuracy': 0.17638}, {'accuracy': 0.16068000000000002}, {'accuracy': 0.18382}, {'accuracy': 0.19535}, {'accuracy': 0.18375}, {'accuracy': 0.20111000000000004}, {'accuracy': 0.19805999999999999}, {'accuracy': 0.20566}, {'accuracy': 0.18935}, {'accuracy': 0.20922999999999997}, {'accuracy': 0.22319999999999998}, {'accuracy': 0.19659999999999997}, {'accuracy': 0.21453000000000003}, {'accuracy': 0.23628999999999997}, {'accuracy': 0.24131}, {'accuracy': 0.22929}, {'accuracy': 0.21379}, {'accuracy': 0.23699000000000003}, {'accuracy': 0.23582000000000006}, {'accuracy': 0.22641}, {'accuracy': 0.21905000000000002}, {'accuracy': 0.24305000000000004}, {'accuracy': 0.25254000000000004}, {'accuracy': 0.26328}, {'accuracy': 0.21802000000000002}, {'accuracy': 0.25800999999999996}, {'accuracy': 0.2465}, {'accuracy': 0.25526}, {'accuracy': 0.2511}, {'accuracy': 0.24614999999999995}, {'accuracy': 0.25425999999999993}, {'accuracy': 0.26863000000000004}, {'accuracy': 0.25463}, {'accuracy': 0.28054}, {'accuracy': 0.29259}, {'accuracy': 0.28581}, {'accuracy': 0.26331999999999994}, {'accuracy': 0.26411999999999997}, {'accuracy': 0.28081999999999996}, {'accuracy': 0.2938299999999999}, {'accuracy': 0.28814}, {'accuracy': 0.29814}, {'accuracy': 0.27931}, {'accuracy': 0.29828}, {'accuracy': 0.28162}, {'accuracy': 0.29122}, {'accuracy': 0.29129}, {'accuracy': 0.3037}, {'accuracy': 0.29903}, {'accuracy': 0.30474}, {'accuracy': 0.31542}, {'accuracy': 0.29120999999999997}, {'accuracy': 0.30487}, {'accuracy': 0.30018}, {'accuracy': 0.33621}, {'accuracy': 0.31873999999999997}, {'accuracy': 0.34204}, {'accuracy': 0.31874}, {'accuracy': 0.31921}, {'accuracy': 0.3490399999999999}, {'accuracy': 0.32469999999999993}, {'accuracy': 0.34545}, {'accuracy': 0.35055000000000003}, {'accuracy': 0.34315}, {'accuracy': 0.34802999999999995}, {'accuracy': 0.33607}, {'accuracy': 0.33773}, {'accuracy': 0.34959}, {'accuracy': 0.35928000000000004}, {'accuracy': 0.35066}, {'accuracy': 0.35497999999999996}, {'accuracy': 0.3516}, {'accuracy': 0.35134}, {'accuracy': 0.3403}, {'accuracy': 0.36957}, {'accuracy': 0.3623}, {'accuracy': 0.35446999999999995}, {'accuracy': 0.36583}, {'accuracy': 0.37222}, {'accuracy': 0.35327000000000003}, {'accuracy': 0.35829000000000005}, {'accuracy': 0.36962}, {'accuracy': 0.36214999999999997}, {'accuracy': 0.37439}, {'accuracy': 0.38721}, {'accuracy': 0.37605000000000005}, {'accuracy': 0.37898}, {'accuracy': 0.38786}, {'accuracy': 0.3730299999999999}, {'accuracy': 0.39916999999999997}, {'accuracy': 0.38106999999999996}, {'accuracy': 0.39370000000000005}, {'accuracy': 0.38566}, {'accuracy': 0.38299000000000005}, {'accuracy': 0.39183}, {'accuracy': 0.37654}, {'accuracy': 0.39276}, {'accuracy': 0.40232999999999997}, {'accuracy': 0.40560999999999997}, {'accuracy': 0.39516}, {'accuracy': 0.39303}, {'accuracy': 0.39837}, {'accuracy': 0.40603999999999996}, {'accuracy': 0.41291}, {'accuracy': 0.40449}, {'accuracy': 0.40596000000000004}, {'accuracy': 0.4158799999999999}, {'accuracy': 0.41390000000000005}, {'accuracy': 0.40628000000000003}, {'accuracy': 0.4142}, {'accuracy': 0.40417999999999993}, {'accuracy': 0.40986}, {'accuracy': 0.40176}, {'accuracy': 0.40854999999999997}, {'accuracy': 0.42216000000000004}, {'accuracy': 0.42580999999999997}, {'accuracy': 0.4175000000000001}, {'accuracy': 0.42214}, {'accuracy': 0.42103}, {'accuracy': 0.41117}, {'accuracy': 0.42789}, {'accuracy': 0.42123999999999995}, {'accuracy': 0.41794000000000003}, {'accuracy': 0.4158100000000001}, {'accuracy': 0.43707}, {'accuracy': 0.43051000000000006}, {'accuracy': 0.44575000000000004}, {'accuracy': 0.45791999999999994}, {'accuracy': 0.43907999999999997}, {'accuracy': 0.44695}, {'accuracy': 0.43376000000000003}, {'accuracy': 0.41249}, {'accuracy': 0.42935}, {'accuracy': 0.41652000000000006}, {'accuracy': 0.43661000000000005}, {'accuracy': 0.42957}, {'accuracy': 0.43362}, {'accuracy': 0.43409}, {'accuracy': 0.45825999999999995}, {'accuracy': 0.44415999999999994}, {'accuracy': 0.44953000000000004}, {'accuracy': 0.45710999999999996}, {'accuracy': 0.45267}, {'accuracy': 0.45202}, {'accuracy': 0.42969999999999997}, {'accuracy': 0.44930000000000003}, {'accuracy': 0.45187}, {'accuracy': 0.45614}, {'accuracy': 0.43900000000000006}, {'accuracy': 0.43681000000000003}, {'accuracy': 0.4306}, {'accuracy': 0.44276}, {'accuracy': 0.46695999999999993}, {'accuracy': 0.48327}, {'accuracy': 0.48599000000000003}, {'accuracy': 0.49968}, {'accuracy': 0.50528}, {'accuracy': 0.50794}, {'accuracy': 0.50392}, {'accuracy': 0.5038800000000001}, {'accuracy': 0.51338}, {'accuracy': 0.50143}, {'accuracy': 0.5176799999999999}, {'accuracy': 0.5065900000000001}, {'accuracy': 0.51094}, {'accuracy': 0.50592}, {'accuracy': 0.5119900000000001}, {'accuracy': 0.51871}, {'accuracy': 0.5150300000000001}, {'accuracy': 0.51308}, {'accuracy': 0.51088}, {'accuracy': 0.5235700000000001}, {'accuracy': 0.5198299999999999}, {'accuracy': 0.52325}, {'accuracy': 0.52722}, {'accuracy': 0.52431}, {'accuracy': 0.5233700000000001}, {'accuracy': 0.5256100000000001}, {'accuracy': 0.5189900000000001}, {'accuracy': 0.52218}, {'accuracy': 0.5263300000000001}, {'accuracy': 0.5306}, {'accuracy': 0.5264700000000001}, {'accuracy': 0.53093}, {'accuracy': 0.53339}, {'accuracy': 0.52873}, {'accuracy': 0.53102}, {'accuracy': 0.5294100000000002}, {'accuracy': 0.5277700000000001}, {'accuracy': 0.53146}, {'accuracy': 0.5326099999999999}, {'accuracy': 0.5323899999999999}, {'accuracy': 0.53246}, {'accuracy': 0.5344899999999999}, {'accuracy': 0.53013}, {'accuracy': 0.52221}, {'accuracy': 0.5222}, {'accuracy': 0.5271600000000001}, {'accuracy': 0.5294200000000001}, {'accuracy': 0.5327000000000001}, {'accuracy': 0.5315800000000002}, {'accuracy': 0.53164}, {'accuracy': 0.5314099999999999}, {'accuracy': 0.5304599999999999}, {'accuracy': 0.5298}, {'accuracy': 0.5311999999999999}, {'accuracy': 0.52851}, {'accuracy': 0.5342399999999999}, {'accuracy': 0.5332000000000001}, {'accuracy': 0.5288499999999999}, {'accuracy': 0.53091}, {'accuracy': 0.53114}, {'accuracy': 0.5312700000000001}, {'accuracy': 0.5316099999999999}, {'accuracy': 0.52973}, {'accuracy': 0.5284300000000001}, {'accuracy': 0.53043}, {'accuracy': 0.53083}, {'accuracy': 0.52875}, {'accuracy': 0.52619}, {'accuracy': 0.52382}, {'accuracy': 0.5273000000000001}, {'accuracy': 0.5236500000000001}, {'accuracy': 0.52189}, {'accuracy': 0.5166700000000001}, {'accuracy': 0.5208900000000001}, {'accuracy': 0.51457}, {'accuracy': 0.51588}, {'accuracy': 0.51707}, {'accuracy': 0.5139400000000001}, {'accuracy': 0.52027}, {'accuracy': 0.5176700000000001}, {'accuracy': 0.5175}, {'accuracy': 0.52162}, {'accuracy': 0.5255699999999999}, {'accuracy': 0.52763}, {'accuracy': 0.52824}, {'accuracy': 0.52949}, {'accuracy': 0.52722}, {'accuracy': 0.52894}, {'accuracy': 0.52579}, {'accuracy': 0.5275099999999999}, {'accuracy': 0.5294999999999999}, {'accuracy': 0.5277700000000001}, {'accuracy': 0.52611}, {'accuracy': 0.52797}, {'accuracy': 0.53053}, {'accuracy': 0.53057}, {'accuracy': 0.5273599999999999}, {'accuracy': 0.53016}, {'accuracy': 0.5267299999999999}, {'accuracy': 0.5318099999999999}, {'accuracy': 0.52668}, {'accuracy': 0.52966}, {'accuracy': 0.52954}, {'accuracy': 0.5240099999999999}, {'accuracy': 0.5252}, {'accuracy': 0.5294699999999999}, {'accuracy': 0.5276400000000001}, {'accuracy': 0.5288700000000001}, {'accuracy': 0.5294800000000001}, {'accuracy': 0.5288600000000001}, {'accuracy': 0.5294999999999999}, {'accuracy': 0.52729}, {'accuracy': 0.5289900000000001}, {'accuracy': 0.5283300000000001}, {'accuracy': 0.5267900000000001}, {'accuracy': 0.52694}, {'accuracy': 0.5290600000000001}, {'accuracy': 0.52969}, {'accuracy': 0.53091}, {'accuracy': 0.53003}, {'accuracy': 0.5304800000000001}, {'accuracy': 0.52928}, {'accuracy': 0.5301500000000001}, {'accuracy': 0.5250400000000001}, {'accuracy': 0.5286899999999999}, {'accuracy': 0.52641}, {'accuracy': 0.5315000000000001}, {'accuracy': 0.5262499999999999}, {'accuracy': 0.5309699999999999}, {'accuracy': 0.52614}, {'accuracy': 0.5266000000000001}, {'accuracy': 0.53005}, {'accuracy': 0.5279900000000001}, {'accuracy': 0.52705}, {'accuracy': 0.5300199999999999}, {'accuracy': 0.5282699999999999}, {'accuracy': 0.51442}, {'accuracy': 0.51688}, {'accuracy': 0.5141500000000001}, {'accuracy': 0.48782}, {'accuracy': 0.51746}, {'accuracy': 0.51122}, {'accuracy': 0.5099000000000001}, {'accuracy': 0.5209000000000001}, {'accuracy': 0.52694}, {'accuracy': 0.52482}, {'accuracy': 0.52595}, {'accuracy': 0.5288700000000001}, {'accuracy': 0.52541}, {'accuracy': 0.5276900000000001}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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M3B1dcXvv/+Oe+65B1FRURg6dCgAYMmSJVi9ejXeffddjB49GtnZ2Th79iwAYM6cOViwYAHefvttKJVKAMDXX3+NoKAgTJgwodX1aymGm04gtbDhSpuzRoZf9nEPXxPdBrUhIuo8qmoM6L10s01e+/RLU+CoaPnX7G233WZx//PPP4ePjw9Onz6NPXv2ID8/HwcPHoSnpycAIDq67nf8q6++irvuugsvvviieKx///6trvPChQtx6623Whx78sknxduPPPIINm/ejO+//x5Dhw5FeXk53nvvPaxcuRKzZs0CAERFRWH06NEAgFtvvRULFizAzz//jDvvvBMAsHbtWtx7771tusCizbulPvzwQ4SHh0OlUmHYsGE4cOBAk2VPnTqF2267DeHh4ZBIJFixYkX7VdSG0ossw82Enr7wclbaqDZERNQWzp8/jxkzZiAyMhKurq4IDw8HAKSlpSEhIQEDBgwQg82lEhISMHHixKuuw+DBgy3uGwwGvPzyy4iJiYGnpyecnZ2xefNmpKWlAQDOnDkDrVbb5GurVCrcc889+PzzzwEAR44cwcmTJ3HvvfdedV2bY9OWm/Xr12PRokVYtWoVhg0bhhUrVmDKlClITEyEr69vg/KVlZWIjIzEHXfcgccff9wGNW5/+eVaca+oNbOH4EByER4aH3WZRxEREWDqGjr90hSbvXZr3HjjjQgLC8Pq1asRGBgIo9GIvn37QqfTQa1WN/vYy52XSCTiQrBmjQ0YdnKynKjy5ptv4r333sOKFSsQExMDJycnLFy4EDqdrkWvC5i6pmJjY5GRkYE1a9ZgwoQJCAsLu+zjroZNw80777yDuXPnYvbs2QCAVatW4ffff8fnn3+OxYsXNyg/ZMgQDBkyBAAaPW9LWr0B+eVaqz2f0Qi8vSVRXGEYAMZ288E1PRqGPiIiapxEImlV15CtFBYWIjExEatXr8aYMWMAALt27RLP9+vXD59++imKiooabb3p168f4uPjxe/TS/n4+CA7O1u8f/78+RZtLrp7927cfPPN+Pe//w3ANHj43Llz6N27NwCgW7duUKvViI+Px5w5cxp9jpiYGAwePBirV6/Gt99+i5UrV172da+Wzf7FdTodDh8+jCVLlojHpFIp4uLisHfvXqu9jlarhVZbFzrKysqs9tz1ncoqw60f7WmT5waA7n7OkEm5ARwR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RHaF4YaIuoQdO3ZAIpE02AOIiOwPww0RERHZFYYbIiIisisMN0TUoRiNRrzxxhuIjo6GUqlEaGgoXn31VUyYMAELFiywKJufnw+FQiHuyKzVavHMM88gJCQESqUS0dHR+Oyzz5p8rV27dmHMmDFQq9UICQnBo48+Co1G06bXR0Rtj+GGiDqUJUuW4LXXXsPzzz+P06dP49tvv4Wfnx/mzJmDb7/9FlqtViz79ddfIygoCBMmTAAAzJw5E9999x3ef/99nDlzBp988gmcnZ0bfZ2kpCRMnToVt912G44fP47169dj165dDQIUEXU+3DiTiDqM8vJy+Pj4YOXKlZgzZ47FuerqagQGBmLVqlW48847AQD9+/fHrbfeimXLluHcuXPo0aMHtmzZgri4uAbPvWPHDlxzzTUoLi6Gu7s75syZA5lMhk8++UQss2vXLowbNw4ajQYqlaptL5aI2gxbboiowzhz5gy0Wi0mTpzY4JxKpcI999yDzz//HABw5MgRnDx5Evfeey8AICEhATKZDOPGjWvRax07dgxr166Fs7Oz+DNlyhQYjUYkJydb7ZqIqP052LoCRERmarW62fNz5sxBbGwsMjIysGbNGkyYMAFhYWEteuylKioqMG/ePDz66KMNzoWGhrbquYioY2HLDRF1GN26dYNarRYHCF8qJiYGgwcPxurVq/Htt9/ivvvuszhnNBqxc+fOFr3WwIEDcfr0aURHRzf4USgUVrkeIrINhhsi6jBUKhWeeeYZPP300/jyyy+RlJSEffv2Wcx4mjNnDl577TUIgoBp06aJx8PDwzFr1izcd999+Omnn5CcnIwdO3bg+++/b/S1nnnmGezZswcLFixAQkICzp8/j59//pkDionsAMMNEXUozz//PJ544gksXboUvXr1wvTp05GXlyeenzFjBhwcHDBjxowGg34//vhj3H777Zg/fz569uyJuXPnNjm1u1+/fti5cyfOnTuHMWPGYMCAAVi6dCkCAwPb9PqIqO1xthQRdSopKSmIiorCwYMHMXDgQFtXh4g6IIYbIuoUampqUFhYiCeffBLJycnYvXu3ratERB0Uu6WIqFPYvXs3AgICcPDgQaxatcrW1SGiDowtN0RERGRX2HJDREREdoXhhoiIiOwKww0RERHZFYYbIiIisisMN0RERGRXGG6IiIjIrjDcEBERkV1huCEiIiK7wnBDREREduX/AbD+xalYhLojAAAAAElFTkSuQmCC",
      "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": "e318b44b-7b79-49b7-84bf-11729e803c98",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1f1278f1-9b52-42ed-85e8-fade9dd1da39",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "249f06a9-d2a3-4016-8c0b-d91c5e688ba9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cd6aafc0-83b3-4a97-90f4-779ec9a875cd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "98f5f712-1867-4ffd-9410-8e57d59833c6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0b301df2-4012-4436-809c-1271b710bb34",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f324a6af-84e5-4283-b1ff-17a16cdf9cf8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "63c3a97a-d657-4933-b8c6-f5bb6898e420",
   "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
