{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "tensor([6, 9, 9,  ..., 9, 1, 1])\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_CIFAR100\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "\n",
    "class CIFAR10Net(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(3, 64,kernel_size=3, stride=2, padding=1)\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(64, 192, 3, padding=1)\n",
    "        self.conv3 = nn.Conv2d(192, 384, 3, padding=1)\n",
    "        self.conv4 = nn.Conv2d(384, 256, 3, padding=1)\n",
    "        self.conv5 = nn.Conv2d(256, 256, 3, padding=1)\n",
    "        self.fc1 = nn.Linear(256 * 2 * 2, 4096)\n",
    "        self.fc2 = nn.Linear(4096, 4096)\n",
    "        self.fc3 = nn.Linear(4096, 10)\n",
    "    \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        # def _init_weights(m: nn.Module):\n",
    "        #     if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "        #         nn.init.xavier_uniform_(m.weight)\n",
    "        #         nn.init.zeros_(m.bias)\n",
    "        #self.apply(_init_weights)\n",
    "        pass\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.pool(F.relu(self.conv1(x)))\n",
    "        x = self.pool(F.relu(self.conv2(x)))\n",
    "        x = F.relu(self.conv3(x))\n",
    "        x = F.relu(self.conv4(x))\n",
    "        x = self.pool(F.relu(self.conv5(x)))\n",
    "        # print(x.shape)\n",
    "        x = x.view(-1, 256 * 2 * 2)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.relu(self.fc2(x))\n",
    "        x = self.fc3(x)\n",
    "        return x\n",
    "    \n",
    "    def __repr__(self) -> str:\n",
    "        return \"CIFAR10Net(size=%d)\" %self.get_size()\n",
    "    \n",
    "    \n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n",
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_CIFAR10()\n",
    "\n",
    "\n",
    "print(train_set[1])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([50000])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([1, 1, 1,  ..., 1, 1, 1])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tran1=torch.zeros([50000,3,32,32], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([50000], dtype=torch.int64)\n",
    "\n",
    "print(tag1.shape)\n",
    "\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,50000,1):\n",
    "    if train_set[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif train_set[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif train_set[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif train_set[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif train_set[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif train_set[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif train_set[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif train_set[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif train_set[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif train_set[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "train_set[1][label[1]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "dbc3456b-d386-41c9-9465-55f89e6b2d2b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(train_set[0][label[0][z]])\n",
    "        list0[1].append(train_set[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(train_set[0][label[0][z]])\n",
    "        list1[1].append(train_set[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(train_set[0][label[0][z]])\n",
    "        list2[1].append(train_set[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(train_set[0][label[0][z]])\n",
    "        list3[1].append(train_set[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(train_set[0][label[0][z]])\n",
    "        list4[1].append(train_set[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(train_set[0][label[0][z]])\n",
    "        list5[1].append(train_set[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(train_set[0][label[0][z]])\n",
    "        list6[1].append(train_set[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(train_set[0][label[0][z]])\n",
    "        list7[1].append(train_set[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(train_set[0][label[0][z]])\n",
    "        list8[1].append(train_set[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(train_set[0][label[0][z]])\n",
    "        list9[1].append(train_set[1][label[0][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "473ea3ac-f6a7-424a-aca0-e50a6df03355",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "eb808629-58e7-4eb6-8c15-479cc02d237a",
   "metadata": {},
   "outputs": [],
   "source": [
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(train_set[0][label[1][z]])\n",
    "        list1[1].append(train_set[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(train_set[0][label[1][z]])\n",
    "        list2[1].append(train_set[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(train_set[0][label[1][z]])\n",
    "        list3[1].append(train_set[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(train_set[0][label[1][z]])\n",
    "        list4[1].append(train_set[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(train_set[0][label[1][z]])\n",
    "        list5[1].append(train_set[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(train_set[0][label[1][z]])\n",
    "        list6[1].append(train_set[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(train_set[0][label[1][z]])\n",
    "        list7[1].append(train_set[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(train_set[0][label[1][z]])\n",
    "        list8[1].append(train_set[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(train_set[0][label[1][z]])\n",
    "        list9[1].append(train_set[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(train_set[0][label[1][z]])\n",
    "        list0[1].append(train_set[1][label[1][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a3aa2fcc-c4f4-408d-9423-86ea099f696b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "0b70f77d-f544-49f6-93a3-e3e974ce9287",
   "metadata": {},
   "outputs": [],
   "source": [
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(train_set[0][label[2][z]])\n",
    "        list2[1].append(train_set[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(train_set[0][label[2][z]])\n",
    "        list3[1].append(train_set[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(train_set[0][label[2][z]])\n",
    "        list4[1].append(train_set[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(train_set[0][label[2][z]])\n",
    "        list5[1].append(train_set[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(train_set[0][label[2][z]])\n",
    "        list6[1].append(train_set[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(train_set[0][label[2][z]])\n",
    "        list7[1].append(train_set[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(train_set[0][label[2][z]])\n",
    "        list8[1].append(train_set[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(train_set[0][label[2][z]])\n",
    "        list9[1].append(train_set[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(train_set[0][label[2][z]])\n",
    "        list0[1].append(train_set[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(train_set[0][label[2][z]])\n",
    "        list1[1].append(train_set[1][label[2][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bf1e1d02-0668-4c7b-8079-b7b3fadca6f8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "c83b07a5-13f4-46b9-8e6d-ec57a8794c57",
   "metadata": {},
   "outputs": [],
   "source": [
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(train_set[0][label[3][z]])\n",
    "        list3[1].append(train_set[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(train_set[0][label[3][z]])\n",
    "        list4[1].append(train_set[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(train_set[0][label[3][z]])\n",
    "        list5[1].append(train_set[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(train_set[0][label[3][z]])\n",
    "        list6[1].append(train_set[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(train_set[0][label[3][z]])\n",
    "        list7[1].append(train_set[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(train_set[0][label[3][z]])\n",
    "        list8[1].append(train_set[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(train_set[0][label[3][z]])\n",
    "        list9[1].append(train_set[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(train_set[0][label[3][z]])\n",
    "        list0[1].append(train_set[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(train_set[0][label[3][z]])\n",
    "        list1[1].append(train_set[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(train_set[0][label[3][z]])\n",
    "        list2[1].append(train_set[1][label[3][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0ad1327c-00bb-4f50-ac57-be4195b91337",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "b60e76e6-ccff-4323-8a51-ec20b80e923f",
   "metadata": {},
   "outputs": [],
   "source": [
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(train_set[0][label[4][z]])\n",
    "        list4[1].append(train_set[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(train_set[0][label[4][z]])\n",
    "        list5[1].append(train_set[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(train_set[0][label[4][z]])\n",
    "        list6[1].append(train_set[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(train_set[0][label[4][z]])\n",
    "        list7[1].append(train_set[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(train_set[0][label[4][z]])\n",
    "        list8[1].append(train_set[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(train_set[0][label[4][z]])\n",
    "        list9[1].append(train_set[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(train_set[0][label[4][z]])\n",
    "        list0[1].append(train_set[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(train_set[0][label[4][z]])\n",
    "        list1[1].append(train_set[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(train_set[0][label[4][z]])\n",
    "        list2[1].append(train_set[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(train_set[0][label[4][z]])\n",
    "        list3[1].append(train_set[1][label[4][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6dec69bb-536c-4fdc-81bf-c215a286f04a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "925dbdcc-21e0-4f8f-8b75-94963a36f38a",
   "metadata": {},
   "outputs": [],
   "source": [
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(train_set[0][label[5][z]])\n",
    "        list5[1].append(train_set[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(train_set[0][label[5][z]])\n",
    "        list6[1].append(train_set[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(train_set[0][label[5][z]])\n",
    "        list7[1].append(train_set[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(train_set[0][label[5][z]])\n",
    "        list8[1].append(train_set[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(train_set[0][label[5][z]])\n",
    "        list9[1].append(train_set[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(train_set[0][label[5][z]])\n",
    "        list0[1].append(train_set[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(train_set[0][label[5][z]])\n",
    "        list1[1].append(train_set[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(train_set[0][label[5][z]])\n",
    "        list2[1].append(train_set[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(train_set[0][label[5][z]])\n",
    "        list3[1].append(train_set[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(train_set[0][label[5][z]])\n",
    "        list4[1].append(train_set[1][label[5][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3024807a-0e1b-4cda-98fe-a49be1cde0f2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "bbe2a38a-0099-407d-a188-e06ff7ab899d",
   "metadata": {},
   "outputs": [],
   "source": [
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(train_set[0][label[6][z]])\n",
    "        list6[1].append(train_set[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(train_set[0][label[6][z]])\n",
    "        list7[1].append(train_set[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(train_set[0][label[6][z]])\n",
    "        list8[1].append(train_set[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(train_set[0][label[6][z]])\n",
    "        list9[1].append(train_set[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(train_set[0][label[6][z]])\n",
    "        list0[1].append(train_set[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(train_set[0][label[6][z]])\n",
    "        list1[1].append(train_set[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(train_set[0][label[6][z]])\n",
    "        list2[1].append(train_set[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(train_set[0][label[6][z]])\n",
    "        list3[1].append(train_set[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(train_set[0][label[6][z]])\n",
    "        list4[1].append(train_set[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(train_set[0][label[6][z]])\n",
    "        list5[1].append(train_set[1][label[6][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4bc595ee-f8eb-41bf-9dc4-2d32a615b873",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "53de6bac-141a-45b9-8910-3eace920f86b",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(train_set[0][label[7][z]])\n",
    "        list7[1].append(train_set[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(train_set[0][label[7][z]])\n",
    "        list8[1].append(train_set[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(train_set[0][label[7][z]])\n",
    "        list9[1].append(train_set[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(train_set[0][label[7][z]])\n",
    "        list0[1].append(train_set[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(train_set[0][label[7][z]])\n",
    "        list1[1].append(train_set[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(train_set[0][label[7][z]])\n",
    "        list2[1].append(train_set[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(train_set[0][label[7][z]])\n",
    "        list3[1].append(train_set[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(train_set[0][label[7][z]])\n",
    "        list4[1].append(train_set[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(train_set[0][label[7][z]])\n",
    "        list5[1].append(train_set[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(train_set[0][label[7][z]])\n",
    "        list6[1].append(train_set[1][label[7][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0c65c26a-fa65-4399-ae11-78144d521edb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "a0044dab-8c89-4e12-b010-a632ef8426eb",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(train_set[0][label[8][z]])\n",
    "        list8[1].append(train_set[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(train_set[0][label[8][z]])\n",
    "        list9[1].append(train_set[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(train_set[0][label[8][z]])\n",
    "        list0[1].append(train_set[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(train_set[0][label[8][z]])\n",
    "        list1[1].append(train_set[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(train_set[0][label[8][z]])\n",
    "        list2[1].append(train_set[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(train_set[0][label[8][z]])\n",
    "        list3[1].append(train_set[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(train_set[0][label[8][z]])\n",
    "        list4[1].append(train_set[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(train_set[0][label[8][z]])\n",
    "        list5[1].append(train_set[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(train_set[0][label[8][z]])\n",
    "        list6[1].append(train_set[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(train_set[0][label[8][z]])\n",
    "        list7[1].append(train_set[1][label[8][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "acb72266-deb0-41bf-9f24-0e1e15285391",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "cd18c2ac-1778-46ab-9f17-af3b80856111",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(train_set[0][label[9][z]])\n",
    "        list9[1].append(train_set[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(train_set[0][label[9][z]])\n",
    "        list0[1].append(train_set[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(train_set[0][label[9][z]])\n",
    "        list1[1].append(train_set[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(train_set[0][label[9][z]])\n",
    "        list2[1].append(train_set[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(train_set[0][label[9][z]])\n",
    "        list3[1].append(train_set[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(train_set[0][label[9][z]])\n",
    "        list4[1].append(train_set[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(train_set[0][label[9][z]])\n",
    "        list5[1].append(train_set[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(train_set[0][label[9][z]])\n",
    "        list6[1].append(train_set[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(train_set[0][label[9][z]])\n",
    "        list7[1].append(train_set[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(train_set[0][label[9][z]])\n",
    "        list8[1].append(train_set[1][label[9][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cc5132f4-f827-473a-9d1f-6aac269955ee",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "1aad24c5-184d-4721-915c-3825cb7dbc47",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2009]\n",
      " [   1   52]\n",
      " [   2   33]\n",
      " [   3   50]\n",
      " [   4   94]\n",
      " [   5  155]\n",
      " [   6  278]\n",
      " [   7  444]\n",
      " [   8  715]\n",
      " [   9 1198]]\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 1221]\n",
      " [   1 1943]\n",
      " [   2   51]\n",
      " [   3   29]\n",
      " [   4   60]\n",
      " [   5   86]\n",
      " [   6  133]\n",
      " [   7  267]\n",
      " [   8  432]\n",
      " [   9  754]]\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  690]\n",
      " [   1 1245]\n",
      " [   2 2044]\n",
      " [   3   48]\n",
      " [   4   35]\n",
      " [   5   49]\n",
      " [   6   73]\n",
      " [   7  143]\n",
      " [   8  256]\n",
      " [   9  422]]\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  449]\n",
      " [   1  720]\n",
      " [   2 1185]\n",
      " [   3 2012]\n",
      " [   4   58]\n",
      " [   5   30]\n",
      " [   6   65]\n",
      " [   7  103]\n",
      " [   8  152]\n",
      " [   9  294]]\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  248]\n",
      " [   1  446]\n",
      " [   2  721]\n",
      " [   3 1112]\n",
      " [   4 2048]\n",
      " [   5   45]\n",
      " [   6   34]\n",
      " [   7   57]\n",
      " [   8   95]\n",
      " [   9  162]]\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  154]\n",
      " [   1  243]\n",
      " [   2  421]\n",
      " [   3  756]\n",
      " [   4 1167]\n",
      " [   5 2035]\n",
      " [   6   45]\n",
      " [   7   26]\n",
      " [   8   68]\n",
      " [   9   84]]\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   95]\n",
      " [   1  164]\n",
      " [   2  256]\n",
      " [   3  473]\n",
      " [   4  723]\n",
      " [   5 1214]\n",
      " [   6 2012]\n",
      " [   7   55]\n",
      " [   8   22]\n",
      " [   9   49]]\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   53]\n",
      " [   1   99]\n",
      " [   2  156]\n",
      " [   3  248]\n",
      " [   4  424]\n",
      " [   5  685]\n",
      " [   6 1204]\n",
      " [   7 1994]\n",
      " [   8   37]\n",
      " [   9   26]]\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   32]\n",
      " [   1   60]\n",
      " [   2   85]\n",
      " [   3  180]\n",
      " [   4  237]\n",
      " [   5  448]\n",
      " [   6  708]\n",
      " [   7 1203]\n",
      " [   8 2014]\n",
      " [   9   39]]\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   49]\n",
      " [   1   28]\n",
      " [   2   48]\n",
      " [   3   92]\n",
      " [   4  154]\n",
      " [   5  253]\n",
      " [   6  448]\n",
      " [   7  708]\n",
      " [   8 1209]\n",
      " [   9 1972]]\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": [
      "25017\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 994]\n",
      " [  1  31]\n",
      " [  2  14]\n",
      " [  3  26]\n",
      " [  4  45]\n",
      " [  5  74]\n",
      " [  6 134]\n",
      " [  7 211]\n",
      " [  8 357]\n",
      " [  9 613]]\n",
      "[[   0 1964]\n",
      " [   1   51]\n",
      " [   2   26]\n",
      " [   3   43]\n",
      " [   4  102]\n",
      " [   5  153]\n",
      " [   6  264]\n",
      " [   7  414]\n",
      " [   8  679]\n",
      " [   9 1156]]\n",
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 5, 0, 1])"
      ]
     },
     "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<5:\n",
    "        noiseyset[0].append(dataset1[z])\n",
    "        healthset[0].append(dataset1[z])\n",
    "        healthset[1].append(target1[z])\n",
    "        healthset[2].append(z)\n",
    "        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": "d71939e2-38bc-4760-a233-f3288d361b28",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (transform(tran1), tag1)\n",
    "Xte, yte = (transform(test_set[0]), test_set[1])\n",
    "\n",
    "data_handler = ClassificationDataHandler(Xtr, ytr,\n",
    "                                         Xte, yte)\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CIFAR10Net(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.001,\n",
    "            \"momentum\": 0.9,\n",
    "            \"weight_decay\": 5e-4\n",
    "        },\n",
    "        \n",
    "        criterion = F.cross_entropy,\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 32,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1.0\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=42)\n",
    "simulator.start(n_rounds=400)\n",
    "\n",
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10039000000000001}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10159}, {'accuracy': 0.1}, {'accuracy': 0.1065}, {'accuracy': 0.10546}, {'accuracy': 0.10831000000000002}, {'accuracy': 0.10707}, {'accuracy': 0.11192000000000002}, {'accuracy': 0.11027}, {'accuracy': 0.11317000000000002}, {'accuracy': 0.13411}, {'accuracy': 0.11054000000000001}, {'accuracy': 0.13773}, {'accuracy': 0.11586}, {'accuracy': 0.14179999999999998}, {'accuracy': 0.12175000000000002}, {'accuracy': 0.13886}, {'accuracy': 0.1369}, {'accuracy': 0.15068}, {'accuracy': 0.14447}, {'accuracy': 0.16349000000000002}, {'accuracy': 0.16352000000000003}, {'accuracy': 0.15415}, {'accuracy': 0.14250000000000002}, {'accuracy': 0.16522}, {'accuracy': 0.17425}, {'accuracy': 0.15818000000000002}, {'accuracy': 0.17785}, {'accuracy': 0.17673}, {'accuracy': 0.18507}, {'accuracy': 0.18988}, {'accuracy': 0.18042000000000002}, {'accuracy': 0.20235000000000003}, {'accuracy': 0.17803}, {'accuracy': 0.17428000000000002}, {'accuracy': 0.21122000000000002}, {'accuracy': 0.18574000000000002}, {'accuracy': 0.18026}, {'accuracy': 0.20537}, {'accuracy': 0.17028}, {'accuracy': 0.20752}, {'accuracy': 0.2177}, {'accuracy': 0.22532999999999997}, {'accuracy': 0.21625999999999998}, {'accuracy': 0.21902999999999997}, {'accuracy': 0.20971}, {'accuracy': 0.21755999999999998}, {'accuracy': 0.19488999999999998}, {'accuracy': 0.21037}, {'accuracy': 0.20139999999999997}, {'accuracy': 0.25792000000000004}, {'accuracy': 0.20303}, {'accuracy': 0.24165}, {'accuracy': 0.25839}, {'accuracy': 0.23968999999999996}, {'accuracy': 0.23511}, {'accuracy': 0.25759}, {'accuracy': 0.22035}, {'accuracy': 0.17655}, {'accuracy': 0.21928999999999998}, {'accuracy': 0.22787000000000002}, {'accuracy': 0.24677000000000002}, {'accuracy': 0.22957999999999998}, {'accuracy': 0.23491}, {'accuracy': 0.24179}, {'accuracy': 0.23896}, {'accuracy': 0.28553}, {'accuracy': 0.24311}, {'accuracy': 0.24624000000000001}, {'accuracy': 0.22959000000000002}, {'accuracy': 0.28789}, {'accuracy': 0.26172000000000006}, {'accuracy': 0.26481}, {'accuracy': 0.22051999999999997}, {'accuracy': 0.23605}, {'accuracy': 0.24967}, {'accuracy': 0.23072000000000004}, {'accuracy': 0.26234999999999997}, {'accuracy': 0.25410999999999995}, {'accuracy': 0.22355}, {'accuracy': 0.23697000000000004}, {'accuracy': 0.24410000000000004}, {'accuracy': 0.24453999999999998}, {'accuracy': 0.21483}, {'accuracy': 0.21345}, {'accuracy': 0.22368000000000002}, {'accuracy': 0.24093}, {'accuracy': 0.20267}, {'accuracy': 0.25051999999999996}, {'accuracy': 0.2367}, {'accuracy': 0.21416999999999997}, {'accuracy': 0.24944999999999995}, {'accuracy': 0.23683}, {'accuracy': 0.25985}, {'accuracy': 0.23895}, {'accuracy': 0.25481}, {'accuracy': 0.26374}, {'accuracy': 0.25421}, {'accuracy': 0.28996}, {'accuracy': 0.25059}, {'accuracy': 0.24003999999999995}, {'accuracy': 0.25240000000000007}, {'accuracy': 0.23389000000000001}, {'accuracy': 0.25210000000000005}, {'accuracy': 0.25528}, {'accuracy': 0.23539}, {'accuracy': 0.26139999999999997}, {'accuracy': 0.22905000000000003}, {'accuracy': 0.24574999999999997}, {'accuracy': 0.24194}, {'accuracy': 0.28631}, {'accuracy': 0.24413999999999997}, {'accuracy': 0.27691}, {'accuracy': 0.24252}, {'accuracy': 0.24764}, {'accuracy': 0.25474}, {'accuracy': 0.2687}, {'accuracy': 0.24042}, {'accuracy': 0.23592999999999997}, {'accuracy': 0.24415}, {'accuracy': 0.27293}, {'accuracy': 0.26455999999999996}, {'accuracy': 0.24712}, {'accuracy': 0.2292}, {'accuracy': 0.26541}, {'accuracy': 0.24567999999999998}, {'accuracy': 0.22637000000000002}, {'accuracy': 0.2566}, {'accuracy': 0.25928}, {'accuracy': 0.26027999999999996}, {'accuracy': 0.22925}, {'accuracy': 0.2894}, {'accuracy': 0.23102999999999999}, {'accuracy': 0.22809}, {'accuracy': 0.27206}, {'accuracy': 0.25375000000000003}, {'accuracy': 0.24717000000000003}, {'accuracy': 0.26305999999999996}, {'accuracy': 0.25752}, {'accuracy': 0.25190999999999997}, {'accuracy': 0.24916999999999997}, {'accuracy': 0.2792}, {'accuracy': 0.24121}, {'accuracy': 0.29447}, {'accuracy': 0.28059}, {'accuracy': 0.28464}, {'accuracy': 0.25687000000000004}, {'accuracy': 0.24952000000000002}, {'accuracy': 0.27380000000000004}, {'accuracy': 0.26727}, {'accuracy': 0.26719}, {'accuracy': 0.26303}, {'accuracy': 0.29949000000000003}, {'accuracy': 0.27128}, {'accuracy': 0.26865}, {'accuracy': 0.2802}, {'accuracy': 0.27668}, {'accuracy': 0.28328}, {'accuracy': 0.28781999999999996}, {'accuracy': 0.24706}, {'accuracy': 0.28182999999999997}, {'accuracy': 0.27995000000000003}, {'accuracy': 0.28351000000000004}, {'accuracy': 0.29472}, {'accuracy': 0.28978}, {'accuracy': 0.27025}, {'accuracy': 0.27967000000000003}, {'accuracy': 0.2948799999999999}, {'accuracy': 0.28527}, {'accuracy': 0.31148}, {'accuracy': 0.26133000000000006}, {'accuracy': 0.32760999999999996}, {'accuracy': 0.28032}, {'accuracy': 0.30443}, {'accuracy': 0.26743000000000006}, {'accuracy': 0.30294999999999994}, {'accuracy': 0.33043}, {'accuracy': 0.29050000000000004}, {'accuracy': 0.26584}, {'accuracy': 0.2921}, {'accuracy': 0.28321}, {'accuracy': 0.29219}, {'accuracy': 0.29564}, {'accuracy': 0.27452}, {'accuracy': 0.30463}, {'accuracy': 0.30330999999999997}, {'accuracy': 0.30165999999999993}, {'accuracy': 0.32807}, {'accuracy': 0.34326}, {'accuracy': 0.34007}, {'accuracy': 0.35131}, {'accuracy': 0.34869}, {'accuracy': 0.34937000000000007}, {'accuracy': 0.35321}, {'accuracy': 0.35998}, {'accuracy': 0.34894}, {'accuracy': 0.34907}, {'accuracy': 0.34643000000000007}, {'accuracy': 0.34912}, {'accuracy': 0.35934}, {'accuracy': 0.34631}, {'accuracy': 0.35126999999999997}, {'accuracy': 0.34529}, {'accuracy': 0.34934}, {'accuracy': 0.34846999999999995}, {'accuracy': 0.35322000000000003}, {'accuracy': 0.35399}, {'accuracy': 0.35827}, {'accuracy': 0.34897}, {'accuracy': 0.35768}, {'accuracy': 0.35599}, {'accuracy': 0.34852000000000005}, {'accuracy': 0.36551}, {'accuracy': 0.37167}, {'accuracy': 0.36869999999999997}, {'accuracy': 0.35716000000000003}, {'accuracy': 0.36547999999999997}, {'accuracy': 0.36689}, {'accuracy': 0.36294999999999994}, {'accuracy': 0.35806999999999994}, {'accuracy': 0.34248}, {'accuracy': 0.36171000000000003}, {'accuracy': 0.36337}, {'accuracy': 0.36158999999999997}, {'accuracy': 0.35785000000000006}, {'accuracy': 0.36107}, {'accuracy': 0.35998}, {'accuracy': 0.36485999999999996}, {'accuracy': 0.35877}, {'accuracy': 0.35973}, {'accuracy': 0.36184}, {'accuracy': 0.36526}, {'accuracy': 0.36889999999999995}, {'accuracy': 0.36739}, {'accuracy': 0.35519999999999996}, {'accuracy': 0.35863999999999996}, {'accuracy': 0.36261}, {'accuracy': 0.36033}, {'accuracy': 0.36627}, {'accuracy': 0.36161}, {'accuracy': 0.3529}, {'accuracy': 0.35660000000000003}, {'accuracy': 0.36139}, {'accuracy': 0.35655000000000003}, {'accuracy': 0.36436}, {'accuracy': 0.35900000000000004}, {'accuracy': 0.35943}, {'accuracy': 0.35799}, {'accuracy': 0.36218999999999996}, {'accuracy': 0.36700999999999995}, {'accuracy': 0.35777000000000003}, {'accuracy': 0.35307}, {'accuracy': 0.36655999999999994}, {'accuracy': 0.36345}, {'accuracy': 0.36403}, {'accuracy': 0.36143999999999993}, {'accuracy': 0.35934999999999995}, {'accuracy': 0.36212}, {'accuracy': 0.36036}, {'accuracy': 0.36127000000000004}, {'accuracy': 0.36225}, {'accuracy': 0.36001}, {'accuracy': 0.36396}, {'accuracy': 0.35346}, {'accuracy': 0.35703999999999997}, {'accuracy': 0.35900999999999994}, {'accuracy': 0.36402}, {'accuracy': 0.35897999999999997}, {'accuracy': 0.36366}, {'accuracy': 0.3628}, {'accuracy': 0.3625}, {'accuracy': 0.36248}, {'accuracy': 0.35592}, {'accuracy': 0.36035999999999996}, {'accuracy': 0.35936}, {'accuracy': 0.35619}, {'accuracy': 0.36160000000000003}, {'accuracy': 0.35126999999999997}, {'accuracy': 0.36388999999999994}, {'accuracy': 0.35621}, {'accuracy': 0.35606}, {'accuracy': 0.35412999999999994}, {'accuracy': 0.35575}, {'accuracy': 0.35383000000000003}, {'accuracy': 0.35777000000000003}, {'accuracy': 0.34831}, {'accuracy': 0.34257}, {'accuracy': 0.34476000000000007}, {'accuracy': 0.34728}, {'accuracy': 0.36194000000000004}, {'accuracy': 0.3623200000000001}, {'accuracy': 0.35674}, {'accuracy': 0.36181}, {'accuracy': 0.35913}, {'accuracy': 0.36468}, {'accuracy': 0.36194}, {'accuracy': 0.36174999999999996}, {'accuracy': 0.36412000000000005}, {'accuracy': 0.36103}, {'accuracy': 0.35928000000000004}, {'accuracy': 0.35739}, {'accuracy': 0.3593}, {'accuracy': 0.35777}, {'accuracy': 0.36077000000000004}, {'accuracy': 0.35853999999999997}, {'accuracy': 0.36222000000000004}, {'accuracy': 0.36457}, {'accuracy': 0.35961}, {'accuracy': 0.36181}, {'accuracy': 0.36805}, {'accuracy': 0.35923}, {'accuracy': 0.36037}, {'accuracy': 0.35927}, {'accuracy': 0.36212999999999995}, {'accuracy': 0.36508999999999997}, {'accuracy': 0.35988}, {'accuracy': 0.36008}, {'accuracy': 0.35905}, {'accuracy': 0.36349000000000004}, {'accuracy': 0.36416000000000004}, {'accuracy': 0.35756}, {'accuracy': 0.3507}, {'accuracy': 0.36434}, {'accuracy': 0.35632}, {'accuracy': 0.35412000000000005}, {'accuracy': 0.35668999999999995}, {'accuracy': 0.35754}, {'accuracy': 0.36272000000000004}, {'accuracy': 0.36141999999999996}, {'accuracy': 0.36013}, {'accuracy': 0.35851}, {'accuracy': 0.36139}, {'accuracy': 0.36041}, {'accuracy': 0.36255000000000004}, {'accuracy': 0.36443}, {'accuracy': 0.35753}, {'accuracy': 0.3519}, {'accuracy': 0.34512}, {'accuracy': 0.35032}, {'accuracy': 0.36085}, {'accuracy': 0.35997}, {'accuracy': 0.36185999999999996}, {'accuracy': 0.35376}, {'accuracy': 0.35395}, {'accuracy': 0.35921}, {'accuracy': 0.35654}, {'accuracy': 0.3393400000000001}, {'accuracy': 0.34384000000000003}, {'accuracy': 0.35324}, {'accuracy': 0.3496}, {'accuracy': 0.35863}, {'accuracy': 0.36592}, {'accuracy': 0.35694}, {'accuracy': 0.35812}, {'accuracy': 0.35946}, {'accuracy': 0.3566}, {'accuracy': 0.35556}, {'accuracy': 0.36129}, {'accuracy': 0.35775999999999997}, {'accuracy': 0.35713999999999996}, {'accuracy': 0.36285}, {'accuracy': 0.35083000000000003}, {'accuracy': 0.35184000000000004}, {'accuracy': 0.36545}, {'accuracy': 0.36046}, {'accuracy': 0.35592}, {'accuracy': 0.34699}, {'accuracy': 0.34515}, {'accuracy': 0.35914}, {'accuracy': 0.36134}, {'accuracy': 0.3577}, {'accuracy': 0.35522}, {'accuracy': 0.35581999999999997}, {'accuracy': 0.35304}, {'accuracy': 0.35955}, {'accuracy': 0.3414}, {'accuracy': 0.34186}, {'accuracy': 0.35428}, {'accuracy': 0.35522}, {'accuracy': 0.36168}, {'accuracy': 0.35499}, {'accuracy': 0.3598100000000001}, {'accuracy': 0.36073}, {'accuracy': 0.35595}, {'accuracy': 0.35988999999999993}, {'accuracy': 0.36521}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkAAAAHHCAYAAABXx+fLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACSYklEQVR4nO3dd3gU5doG8Ht7eiMdAgFCkd4EUZoQATtW5KggKrbDsWDlqKDHgmI52FHPZy+g2BsoEVAw0pFeBUJJD+nJ1vn+2MzszO7sZjek7/27Li6zu7Oz72Rj9snzPO/7agRBEEBEREQURLQtPQAiIiKi5sYAiIiIiIIOAyAiIiIKOgyAiIiIKOgwACIiIqKgwwCIiIiIgg4DICIiIgo6DICIiIgo6DAAIiIioqDDAIiIWtzq1auh0WiwevVq6b4bbrgB6enpLTam9uSxxx6DRqNp6WEQtSoMgIjagV27duG6665Dx44dYTKZkJqaimuvvRa7du1q6aE1uddffx3vvfdek77G7t278dhjj+HIkSNN+jrN6emnn8bXX3/d0sMgajEMgIjauC+//BJDhgxBVlYWZs6ciddffx033XQTVq1ahSFDhuCrr75q6SE2qeYKgB5//HEGQETtiL6lB0BEDXfo0CFcf/316NatG3777TckJCRIj911110YPXo0rr/+emzfvh3dunVrtnFVVVUhPDy82V6vLeD3hKh1YQaIqA177rnnUF1djbfeeksR/ABAfHw83nzzTVRVVWHhwoUAgGXLlkGj0WDNmjUe53rzzTeh0Wiwc+dO6b69e/fiyiuvRFxcHEJCQjBs2DB8++23iue999570jnvuOMOJCYmolOnTgCAo0eP4o477kCvXr0QGhqKDh064Kqrrmq0TEp6ejp27dqFNWvWQKPRQKPRYNy4cdLjpaWluPvuu5GWlgaTyYSMjAw8++yzcDgcivMsWbIEQ4cORWRkJKKiotC/f3+89NJL0vVdddVVAIBzzz1Xeh15v5K7G264ARERETh06BAuuOACREZG4tprrwUAOBwOLFq0CH379kVISAiSkpJw66234tSpU4pzbNq0CZMmTUJ8fDxCQ0PRtWtX3HjjjdLjan1TAHDkyBFoNBqfWTGNRoOqqiq8//770vXccMMNAICKigrcfffdSE9Ph8lkQmJiIs477zxs2bLF6/mI2iJmgIjasO+++w7p6ekYPXq06uNjxoxBeno6fvjhBwDAhRdeiIiICHz22WcYO3as4tilS5eib9++6NevHwBnX9E555yDjh074qGHHkJ4eDg+++wzTJkyBV988QUuu+wyxfPvuOMOJCQkYN68eaiqqgIAbNy4EX/88QeuueYadOrUCUeOHMEbb7yBcePGYffu3QgLCzut61+0aBH+9a9/ISIiAg8//DAAICkpCQBQXV2NsWPH4sSJE7j11lvRuXNn/PHHH5g7dy5yc3OxaNEiAMAvv/yCadOmYcKECXj22WcBAHv27MG6detw1113YcyYMbjzzjvx8ssv49///jfOOOMMAJD+643NZsOkSZMwatQoPP/889K13nrrrXjvvfcwc+ZM3HnnnTh8+DBeffVVbN26FevWrYPBYEBBQQEmTpyIhIQEPPTQQ4iJicGRI0fw5Zdfntb3S/Thhx/i5ptvxvDhw3HLLbcAALp37w4AuO2227Bs2TLMnj0bffr0QXFxMdauXYs9e/ZgyJAhjfL6RK2CQERtUmlpqQBAuPTSS30ed8kllwgAhPLyckEQBGHatGlCYmKiYLPZpGNyc3MFrVYr/Oc//5HumzBhgtC/f3+htrZWus/hcAhnn3220KNHD+m+d999VwAgjBo1SnFOQRCE6upqj/FkZ2cLAIQPPvhAum/VqlUCAGHVqlXSfTNmzBC6dOni89oEQRD69u0rjB071uP+J554QggPDxf279+vuP+hhx4SdDqdkJOTIwiCINx1111CVFSUx9jlPv/8c4/x+TJjxgwBgPDQQw8p7v/9998FAMLHH3+suH/58uWK+7/66isBgLBx40avr6H2PRMEQTh8+LAAQHj33Xel++bPny+4/7oPDw8XZsyY4XHe6Oho4Z///KcfV0nUtrEERtRGVVRUAAAiIyN9Hic+Xl5eDgCYOnUqCgoKFKWTZcuWweFwYOrUqQCAkpIS/Prrr7j66qtRUVGBoqIiFBUVobi4GJMmTcKBAwdw4sQJxevMmjULOp1OcV9oaKj0tdVqRXFxMTIyMhATE9PkJZXPP/8co0ePRmxsrDT+oqIiZGZmwm6347fffgMAxMTEoKqqCr/88kujj+H222/3GFN0dDTOO+88xZiGDh2KiIgIrFq1ShoTAHz//fewWq2NPi5fYmJisH79epw8ebJZX5eouTEAImqjxMBGDIS8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GuRT00vlGSCzTZHVqY88e2JRZICcP+5i+cY1S0pQBD3ua+oEwn3RwMgQA2LCjIgLN0of+v/8ZAte/vUgRi9cJZXH5CyyoM1dfrlZWtgwMkQvjdciK7kB8GiCljJAep3qYoVqix1GmPTokRThcT8AqZcqIcIk3VfqNnvMF5bAiKilNagJetOmTfjss8+Qk5MDi0X5C/zLL78M6FwvvvgiZs2ahZkzZwIAFi9ejB9++AHvvPMOHnroIY/jP/74Y8Xt//3vf/jiiy+QlZWl2IfMZDIhOTk5oLFQy5JngORr3ThLYAE0QXtZCVrMUBh02royk1B3jAD56d331fLmSFEVYsONiA51TZl3L4GJQYr4uv7wlQESt9dIjDTBoNOiotbm7AESA6C6Elit1QH5upHi1Haj1wyQZ8AVGaJH/44x+HFHnsdjYgZIXvYurvK/dKgogenYBE1EzS/gP72WLFmCs88+G3v27MFXX30Fq9WKXbt24ddff0V0dHRA57JYLNi8eTMyMzNdA9JqkZmZiezsbL/OUV1dDavViri4OMX9q1evRmJiInr16oXbb78dxcXFXs4AmM1mlJeXK/5R85MHLqfcSmDepoWrnke+ErRNOQsMcK1BY7M7UGOx4/gp5awvf0pgR4urMO751Tjr6SzpPkEQPDNAJnkA5F+px1cPkKhzXJg068o5C8z5uvIVreWZLFcGSKuaARL3FEuMdGV0okIMOL+f+h8RepVrKVbJZnlj5DR4ImphAQdATz/9NP773//iu+++g9FoxEsvvYS9e/fi6quvRufOnQM6V1FREex2O5KSlLs7JyUlIS/P869ONQ8++CBSU1MVQdTkyZPxwQcfICsrC88++yzWrFmD888/H3a7+l/2CxYsQHR0tPQvLS0toOugxmFT9AA1PAOkmAXmEFQzQOJxmS+uwbnPr1Y8358S2MYjzk2BxYDn1V8PYMxznr1y8gUVY8L8227DbLPXu11GWlyY1MxstjmkafyRIQbVgELeA6TWBC1mizISXSWviBA90uPDVV9frd/Hz51KALAERkQtL+DfPIcOHcKFF14IADAajaiqqoJGo8E999yDt956q9EH6MszzzyDJUuW4KuvvkJISIh0/zXXXINLLrkE/fv3x5QpU/D9999j48aNWL16tep55s6di7KyMunfsWPHmukKSM7uowcokM1LbR4r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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 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": "51f3348e-05de-4ec8-9756-0cd120eb6e35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8a1395dd-837c-4fa5-b8d1-8600f3b7b38b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bcc90da2-1f58-4677-a0c7-6ad86f81385a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d39f2e24-9eba-4a37-9bde-da84a1a17b10",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
