{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "5ea611d7-723b-418d-be29-d045dc4153fe",
   "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 1974]\n",
      " [   1   51]\n",
      " [   2   39]\n",
      " [   3   52]\n",
      " [   4   98]\n",
      " [   5  163]\n",
      " [   6  285]\n",
      " [   7  405]\n",
      " [   8  745]\n",
      " [   9 1197]]\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 1204]\n",
      " [   1 2017]\n",
      " [   2   63]\n",
      " [   3   34]\n",
      " [   4   60]\n",
      " [   5  115]\n",
      " [   6  160]\n",
      " [   7  295]\n",
      " [   8  445]\n",
      " [   9  675]]\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  746]\n",
      " [   1 1197]\n",
      " [   2 2028]\n",
      " [   3   57]\n",
      " [   4   37]\n",
      " [   5   61]\n",
      " [   6   78]\n",
      " [   7  144]\n",
      " [   8  267]\n",
      " [   9  461]]\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  427]\n",
      " [   1  727]\n",
      " [   2 1166]\n",
      " [   3 2005]\n",
      " [   4   59]\n",
      " [   5   38]\n",
      " [   6   46]\n",
      " [   7   84]\n",
      " [   8  143]\n",
      " [   9  269]]\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  264]\n",
      " [   1  446]\n",
      " [   2  677]\n",
      " [   3 1185]\n",
      " [   4 1963]\n",
      " [   5   44]\n",
      " [   6   39]\n",
      " [   7   69]\n",
      " [   8   95]\n",
      " [   9  165]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list4[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "22dd2dd8-3dc7-4537-9df4-68cc2fe9d6cf",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0  135]\n",
      " [   1  248]\n",
      " [   2  448]\n",
      " [   3  698]\n",
      " [   4 1204]\n",
      " [   5 2015]\n",
      " [   6   47]\n",
      " [   7   32]\n",
      " [   8   53]\n",
      " [   9   91]]\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  111]\n",
      " [   1  123]\n",
      " [   2  273]\n",
      " [   3  443]\n",
      " [   4  690]\n",
      " [   5 1169]\n",
      " [   6 1977]\n",
      " [   7   45]\n",
      " [   8   27]\n",
      " [   9   57]]\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   49]\n",
      " [   1  102]\n",
      " [   2  137]\n",
      " [   3  291]\n",
      " [   4  449]\n",
      " [   5  661]\n",
      " [   6 1202]\n",
      " [   7 1986]\n",
      " [   8   43]\n",
      " [   9   43]]\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   27]\n",
      " [   1   53]\n",
      " [   2  107]\n",
      " [   3  140]\n",
      " [   4  260]\n",
      " [   5  461]\n",
      " [   6  748]\n",
      " [   7 1172]\n",
      " [   8 1947]\n",
      " [   9   52]]\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   63]\n",
      " [   1   36]\n",
      " [   2   62]\n",
      " [   3   95]\n",
      " [   4  180]\n",
      " [   5  273]\n",
      " [   6  418]\n",
      " [   7  768]\n",
      " [   8 1235]\n",
      " [   9 1990]]\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": [
      "1995\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 1974]\n",
      " [   1   46]\n",
      " [   2   39]\n",
      " [   3   41]\n",
      " [   4   98]\n",
      " [   5  142]\n",
      " [   6  285]\n",
      " [   7  405]\n",
      " [   8  745]\n",
      " [   9 1026]]\n",
      "[[   0 1974]\n",
      " [   1   54]\n",
      " [   2   39]\n",
      " [   3   45]\n",
      " [   4   98]\n",
      " [   5  158]\n",
      " [   6  285]\n",
      " [   7  405]\n",
      " [   8  745]\n",
      " [   9 1139]]\n",
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([0, 0, 0,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set = tran1, tag1\n",
    "\n",
    "#\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "dataset1=[]\n",
    "target1=[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "for z in range(0,50000,1):\n",
    "    dataset1.append(train_set[0][z])\n",
    "    target1.append(train_set[1][z])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "len(target1)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "\n",
    "noiseyset=[],[]\n",
    "healthset=[],[],[]\n",
    "import random\n",
    "for z in range(0,50000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<1:\n",
    "        if target1[z]==1:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(9))\n",
    "        \n",
    "        elif target1[z]==9:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(1))      \n",
    "        \n",
    "        elif target1[z]==3:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(5))\n",
    "        \n",
    "        \n",
    "        elif target1[z]==5:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(3))     \n",
    "        \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[1][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[1][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "926da84b-6be8-4f83-8dfb-3f862b400691",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "99d1c502-1890-4fb6-a829-2879d75e7de9",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (transform(tran1), tag1)\n",
    "Xte, yte = (transform(test_set[0]), test_set[1])\n",
    "\n",
    "data_handler = ClassificationDataHandler(Xtr, ytr,\n",
    "                                         Xte, yte)\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CIFAR10Net(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.001,\n",
    "            \"momentum\": 0.9,\n",
    "            \"weight_decay\": 5e-4\n",
    "        },\n",
    "        \n",
    "        criterion = F.cross_entropy,\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 32,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=42)\n",
    "simulator.start(n_rounds=350)\n",
    "\n",
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "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.10117000000000001}, {'accuracy': 0.10117000000000001}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10342}, {'accuracy': 0.1}, {'accuracy': 0.10200000000000001}, {'accuracy': 0.1}, {'accuracy': 0.10454000000000001}, {'accuracy': 0.10381}, {'accuracy': 0.10224}, {'accuracy': 0.10611999999999999}, {'accuracy': 0.11183000000000001}, {'accuracy': 0.10532000000000001}, {'accuracy': 0.11113999999999999}, {'accuracy': 0.11032000000000002}, {'accuracy': 0.11265}, {'accuracy': 0.11398}, {'accuracy': 0.10722000000000001}, {'accuracy': 0.10986}, {'accuracy': 0.1127}, {'accuracy': 0.11259999999999999}, {'accuracy': 0.11734}, {'accuracy': 0.11367000000000001}, {'accuracy': 0.12177999999999997}, {'accuracy': 0.12988}, {'accuracy': 0.10868000000000003}, {'accuracy': 0.13238999999999998}, {'accuracy': 0.14823999999999998}, {'accuracy': 0.13540000000000002}, {'accuracy': 0.13413999999999998}, {'accuracy': 0.12333000000000001}, {'accuracy': 0.14186}, {'accuracy': 0.14293000000000003}, {'accuracy': 0.126}, {'accuracy': 0.11700000000000002}, {'accuracy': 0.13833}, {'accuracy': 0.15655000000000002}, {'accuracy': 0.15175}, {'accuracy': 0.18749}, {'accuracy': 0.15465}, {'accuracy': 0.17578000000000002}, {'accuracy': 0.1516}, {'accuracy': 0.16048}, {'accuracy': 0.17907}, {'accuracy': 0.17651999999999995}, {'accuracy': 0.17623}, {'accuracy': 0.18512}, {'accuracy': 0.18268}, {'accuracy': 0.18929}, {'accuracy': 0.18932000000000002}, {'accuracy': 0.19448}, {'accuracy': 0.20991999999999997}, {'accuracy': 0.20964999999999998}, {'accuracy': 0.20384000000000002}, {'accuracy': 0.19955}, {'accuracy': 0.23333999999999996}, {'accuracy': 0.21494}, {'accuracy': 0.21368}, {'accuracy': 0.20922999999999997}, {'accuracy': 0.21135}, {'accuracy': 0.2258}, {'accuracy': 0.21331000000000003}, {'accuracy': 0.21169000000000002}, {'accuracy': 0.24494}, {'accuracy': 0.24335999999999997}, {'accuracy': 0.21738}, {'accuracy': 0.23058}, {'accuracy': 0.23213}, {'accuracy': 0.22426999999999997}, {'accuracy': 0.24184}, {'accuracy': 0.24878}, {'accuracy': 0.23540999999999998}, {'accuracy': 0.26504}, {'accuracy': 0.22386}, {'accuracy': 0.23805}, {'accuracy': 0.26008}, {'accuracy': 0.25566999999999995}, {'accuracy': 0.26962}, {'accuracy': 0.25188}, {'accuracy': 0.23988}, {'accuracy': 0.25785}, {'accuracy': 0.25524}, {'accuracy': 0.25466}, {'accuracy': 0.25643000000000005}, {'accuracy': 0.28273000000000004}, {'accuracy': 0.27275}, {'accuracy': 0.2709}, {'accuracy': 0.27358999999999994}, {'accuracy': 0.27637}, {'accuracy': 0.30138}, {'accuracy': 0.29995000000000005}, {'accuracy': 0.28759999999999997}, {'accuracy': 0.28391}, {'accuracy': 0.31541}, {'accuracy': 0.29268}, {'accuracy': 0.30535999999999996}, {'accuracy': 0.30301000000000006}, {'accuracy': 0.29444000000000004}, {'accuracy': 0.30751000000000006}, {'accuracy': 0.32828999999999997}, {'accuracy': 0.33502}, {'accuracy': 0.33403}, {'accuracy': 0.32754000000000005}, {'accuracy': 0.32905999999999996}, {'accuracy': 0.33363}, {'accuracy': 0.31582000000000005}, {'accuracy': 0.34041000000000005}, {'accuracy': 0.34448}, {'accuracy': 0.33463}, {'accuracy': 0.34928}, {'accuracy': 0.34637999999999997}, {'accuracy': 0.35106}, {'accuracy': 0.3283999999999999}, {'accuracy': 0.35749000000000003}, {'accuracy': 0.35218000000000005}, {'accuracy': 0.34235000000000004}, {'accuracy': 0.3663}, {'accuracy': 0.36762}, {'accuracy': 0.36332}, {'accuracy': 0.35808999999999996}, {'accuracy': 0.36123000000000005}, {'accuracy': 0.36706000000000005}, {'accuracy': 0.36922999999999995}, {'accuracy': 0.3765}, {'accuracy': 0.36552}, {'accuracy': 0.38734}, {'accuracy': 0.37331}, {'accuracy': 0.38306000000000007}, {'accuracy': 0.39719000000000004}, {'accuracy': 0.38888}, {'accuracy': 0.39587999999999995}, {'accuracy': 0.39655}, {'accuracy': 0.39779}, {'accuracy': 0.39141}, {'accuracy': 0.38652000000000003}, {'accuracy': 0.40054999999999996}, {'accuracy': 0.3932}, {'accuracy': 0.39435000000000003}, {'accuracy': 0.39035}, {'accuracy': 0.40922000000000003}, {'accuracy': 0.41513999999999995}, {'accuracy': 0.40499}, {'accuracy': 0.40637999999999996}, {'accuracy': 0.41536999999999996}, {'accuracy': 0.41494}, {'accuracy': 0.4181100000000001}, {'accuracy': 0.41701999999999995}, {'accuracy': 0.42946}, {'accuracy': 0.44166}, {'accuracy': 0.43817000000000006}, {'accuracy': 0.438}, {'accuracy': 0.41945999999999994}, {'accuracy': 0.43099}, {'accuracy': 0.42366000000000004}, {'accuracy': 0.4391299999999999}, {'accuracy': 0.42328}, {'accuracy': 0.43604000000000004}, {'accuracy': 0.43772}, {'accuracy': 0.44017}, {'accuracy': 0.45683999999999997}, {'accuracy': 0.4405900000000001}, {'accuracy': 0.42772000000000004}, {'accuracy': 0.44645}, {'accuracy': 0.44044}, {'accuracy': 0.45380000000000004}, {'accuracy': 0.45152000000000003}, {'accuracy': 0.42890999999999996}, {'accuracy': 0.45615000000000006}, {'accuracy': 0.43796}, {'accuracy': 0.45388}, {'accuracy': 0.47359999999999997}, {'accuracy': 0.45331}, {'accuracy': 0.46218999999999993}, {'accuracy': 0.47714}, {'accuracy': 0.46293000000000006}, {'accuracy': 0.46102}, {'accuracy': 0.4614999999999999}, {'accuracy': 0.46545000000000003}, {'accuracy': 0.47262999999999994}, {'accuracy': 0.47433}, {'accuracy': 0.46479}, {'accuracy': 0.46099999999999997}, {'accuracy': 0.4603999999999999}, {'accuracy': 0.44765}, {'accuracy': 0.46579000000000004}, {'accuracy': 0.47257999999999994}, {'accuracy': 0.48466000000000004}, {'accuracy': 0.39048}, {'accuracy': 0.4641100000000001}, {'accuracy': 0.49835}, {'accuracy': 0.50554}, {'accuracy': 0.51063}, {'accuracy': 0.5144500000000001}, {'accuracy': 0.51481}, {'accuracy': 0.5194599999999999}, {'accuracy': 0.52268}, {'accuracy': 0.5211499999999999}, {'accuracy': 0.5203}, {'accuracy': 0.5370299999999999}, {'accuracy': 0.53665}, {'accuracy': 0.51339}, {'accuracy': 0.53144}, {'accuracy': 0.5424100000000001}, {'accuracy': 0.53999}, {'accuracy': 0.52447}, {'accuracy': 0.53}, {'accuracy': 0.51927}, {'accuracy': 0.5366000000000001}, {'accuracy': 0.49805}, {'accuracy': 0.53005}, {'accuracy': 0.5146799999999999}, {'accuracy': 0.5307299999999999}, {'accuracy': 0.52412}, {'accuracy': 0.5278799999999999}, {'accuracy': 0.52255}, {'accuracy': 0.5393600000000001}, {'accuracy': 0.5473999999999999}, {'accuracy': 0.53469}, {'accuracy': 0.5156799999999999}, {'accuracy': 0.53944}, {'accuracy': 0.5507499999999999}, {'accuracy': 0.5478}, {'accuracy': 0.55036}, {'accuracy': 0.5374}, {'accuracy': 0.5418500000000002}, {'accuracy': 0.5465000000000001}, {'accuracy': 0.5490299999999999}, {'accuracy': 0.54906}, {'accuracy': 0.5373300000000001}, {'accuracy': 0.52715}, {'accuracy': 0.5198400000000001}, {'accuracy': 0.53995}, {'accuracy': 0.54695}, {'accuracy': 0.54021}, {'accuracy': 0.5217499999999999}, {'accuracy': 0.5395300000000001}, {'accuracy': 0.5360199999999999}, {'accuracy': 0.53233}, {'accuracy': 0.53161}, {'accuracy': 0.5397299999999999}, {'accuracy': 0.53815}, {'accuracy': 0.54577}, {'accuracy': 0.54394}, {'accuracy': 0.54967}, {'accuracy': 0.54765}, {'accuracy': 0.5477700000000001}, {'accuracy': 0.55382}, {'accuracy': 0.5557000000000001}, {'accuracy': 0.55058}, {'accuracy': 0.5449399999999999}, {'accuracy': 0.55124}, {'accuracy': 0.5378999999999999}, {'accuracy': 0.52101}, {'accuracy': 0.53508}, {'accuracy': 0.55109}, {'accuracy': 0.54162}, {'accuracy': 0.5461}, {'accuracy': 0.5406099999999999}, {'accuracy': 0.5516}, {'accuracy': 0.5488000000000002}, {'accuracy': 0.54776}, {'accuracy': 0.54277}, {'accuracy': 0.54043}, {'accuracy': 0.5294}, {'accuracy': 0.5338200000000002}, {'accuracy': 0.54565}, {'accuracy': 0.54274}, {'accuracy': 0.5453499999999999}, {'accuracy': 0.5462400000000001}, {'accuracy': 0.55121}, {'accuracy': 0.53886}, {'accuracy': 0.54947}, {'accuracy': 0.55019}, {'accuracy': 0.54922}, {'accuracy': 0.54877}, {'accuracy': 0.5461600000000001}, {'accuracy': 0.55267}, {'accuracy': 0.54542}, {'accuracy': 0.5491300000000001}, {'accuracy': 0.55122}, {'accuracy': 0.5544500000000001}, {'accuracy': 0.54757}, {'accuracy': 0.5514100000000001}, {'accuracy': 0.5465099999999998}, {'accuracy': 0.54647}, {'accuracy': 0.53645}, {'accuracy': 0.5513199999999999}, {'accuracy': 0.54885}, {'accuracy': 0.55317}, {'accuracy': 0.5516399999999999}, {'accuracy': 0.54288}, {'accuracy': 0.54311}, {'accuracy': 0.54518}, {'accuracy': 0.55336}, {'accuracy': 0.53885}, {'accuracy': 0.545}, {'accuracy': 0.55077}, {'accuracy': 0.5479999999999999}, {'accuracy': 0.54788}, {'accuracy': 0.54688}, {'accuracy': 0.54642}, {'accuracy': 0.5445499999999999}, {'accuracy': 0.54904}, {'accuracy': 0.5510499999999998}, {'accuracy': 0.5521900000000001}, {'accuracy': 0.5523399999999999}, {'accuracy': 0.52909}, {'accuracy': 0.5422999999999999}, {'accuracy': 0.50886}, {'accuracy': 0.5301799999999999}, {'accuracy': 0.5175}, {'accuracy': 0.54355}, {'accuracy': 0.5402699999999999}, {'accuracy': 0.5468300000000001}, {'accuracy': 0.54618}, {'accuracy': 0.5431100000000001}, {'accuracy': 0.54445}, {'accuracy': 0.5499400000000001}, {'accuracy': 0.5444199999999999}, {'accuracy': 0.546}, {'accuracy': 0.54478}, {'accuracy': 0.5475199999999999}, {'accuracy': 0.54504}, {'accuracy': 0.54815}, {'accuracy': 0.5477799999999999}, {'accuracy': 0.5505099999999998}, {'accuracy': 0.54191}, {'accuracy': 0.5469100000000001}, {'accuracy': 0.54561}, {'accuracy': 0.5467099999999999}, {'accuracy': 0.54742}, {'accuracy': 0.5401900000000001}, {'accuracy': 0.5490400000000001}, {'accuracy': 0.54935}, {'accuracy': 0.54585}, {'accuracy': 0.5458}, {'accuracy': 0.5348300000000001}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "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": "5ef4dba1-5984-472b-b805-aed3b188e400",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d2e459a3-98d2-4ee0-bbb7-7fcff0cb8e99",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a825395a-2b03-481a-8920-ab9eb086fae7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "abb9195f-8552-43b0-b87c-4274fa338770",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a2e012d6-992d-49e2-800c-5cd13689b314",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a97222e1-28e9-425a-8dff-f513f818c898",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c203a2b5-2dbb-4d67-9b02-03d6143cd8de",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "955de4e5-0478-4d7a-8bdf-e0201de83b36",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3d558492-3f17-4f8d-9ca5-ad1bd71e3db8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "21c7bda8-afba-4e59-a135-3871e0072ad9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5435c319-a6db-48fb-b70e-b658cf0af674",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f1e3310a-fb80-4f0d-b620-103933bd2c18",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "00c07366-1ec2-415e-a6e1-a091bcfbd835",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9d014b5b-9ed9-4a7c-95f0-2b1a385e90a7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4dea7ce6-0b61-4973-818d-005714b611f3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1d58d65c-4ae2-4654-a08a-29702ee01545",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "211e490c-c48f-43af-be9b-5428f8eb7229",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fc15aacd-07d3-4a5f-9072-eb85eca2855c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d9c552ef-ddf2-4ae7-ab90-7927c4464821",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "995059e3-5cf8-487d-b539-6de0f4c1da42",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "908d185e-41e1-46a8-b0f8-62520af30c5e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e9afa3ef-daa3-406a-87de-0bf1cce4c0e0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7e15862f-df0b-4a26-99b8-5b3d8f3b1643",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a4ce481-de30-46f9-869b-6d8aef45c55e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "953b2de8-a255-4b31-9761-1040be915941",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8c672ac4-c5cd-479f-a715-8bdebd3ee451",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b465e739-ab1c-432d-8b42-98372e02bb6a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "06dc1b5e-e48b-42e3-973a-75329449f913",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1ae1f042-1d58-460a-aab2-04d7b15a340f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c4ce7b3b-7afb-41ad-aceb-5c5004c99911",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "289b7762-09fe-47e5-8e7f-c4c1a16c9f25",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7eb6156e-538a-4001-8591-473dbb8e4419",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "06262c68-82d1-41f4-81f1-b11547aa6f7f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d3af14bb-13a4-4286-b8c0-8d7a93150fbb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7f6f1967-e661-4558-ac0d-be29b152692e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5934f9d7-a2c0-4be8-a525-691572393395",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
