{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "8a02ed89-1c7b-4c1d-af17-c6b69f89c380",
   "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 1983]\n",
      " [   1   55]\n",
      " [   2   28]\n",
      " [   3   69]\n",
      " [   4   86]\n",
      " [   5  150]\n",
      " [   6  256]\n",
      " [   7  418]\n",
      " [   8  702]\n",
      " [   9 1206]]\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 1215]\n",
      " [   1 1957]\n",
      " [   2   37]\n",
      " [   3   44]\n",
      " [   4   48]\n",
      " [   5   98]\n",
      " [   6  154]\n",
      " [   7  251]\n",
      " [   8  420]\n",
      " [   9  720]]\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  733]\n",
      " [   1 1233]\n",
      " [   2 2012]\n",
      " [   3   54]\n",
      " [   4   29]\n",
      " [   5   59]\n",
      " [   6   81]\n",
      " [   7  167]\n",
      " [   8  253]\n",
      " [   9  448]]\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  431]\n",
      " [   1  726]\n",
      " [   2 1166]\n",
      " [   3 2000]\n",
      " [   4   52]\n",
      " [   5   37]\n",
      " [   6   54]\n",
      " [   7   93]\n",
      " [   8  145]\n",
      " [   9  280]]\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  247]\n",
      " [   1  454]\n",
      " [   2  726]\n",
      " [   3 1177]\n",
      " [   4 1972]\n",
      " [   5   42]\n",
      " [   6   27]\n",
      " [   7   64]\n",
      " [   8  106]\n",
      " [   9  136]]\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  152]\n",
      " [   1  262]\n",
      " [   2  459]\n",
      " [   3  725]\n",
      " [   4 1233]\n",
      " [   5 1965]\n",
      " [   6   45]\n",
      " [   7   34]\n",
      " [   8   54]\n",
      " [   9  112]]\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  100]\n",
      " [   1  143]\n",
      " [   2  263]\n",
      " [   3  435]\n",
      " [   4  730]\n",
      " [   5 1258]\n",
      " [   6 1999]\n",
      " [   7   42]\n",
      " [   8   42]\n",
      " [   9   50]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list6[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "671aae60-3b3e-468b-9636-99cdcb53c819",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   59]\n",
      " [   1   91]\n",
      " [   2  155]\n",
      " [   3  263]\n",
      " [   4  429]\n",
      " [   5  704]\n",
      " [   6 1216]\n",
      " [   7 2030]\n",
      " [   8   56]\n",
      " [   9   30]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "abad36f3-ca9c-4b61-b13c-84d76f89518d",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   33]\n",
      " [   1   57]\n",
      " [   2  102]\n",
      " [   3  138]\n",
      " [   4  255]\n",
      " [   5  424]\n",
      " [   6  723]\n",
      " [   7 1141]\n",
      " [   8 1971]\n",
      " [   9   51]]\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   47]\n",
      " [   1   22]\n",
      " [   2   52]\n",
      " [   3   95]\n",
      " [   4  166]\n",
      " [   5  263]\n",
      " [   6  445]\n",
      " [   7  760]\n",
      " [   8 1251]\n",
      " [   9 1967]]\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": [
      "5005\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 1834]\n",
      " [   1   50]\n",
      " [   2   26]\n",
      " [   3   67]\n",
      " [   4   77]\n",
      " [   5  129]\n",
      " [   6  222]\n",
      " [   7  372]\n",
      " [   8  638]\n",
      " [   9 1085]]\n",
      "[[   0 2071]\n",
      " [   1   56]\n",
      " [   2   29]\n",
      " [   3   72]\n",
      " [   4   86]\n",
      " [   5  144]\n",
      " [   6  249]\n",
      " [   7  417]\n",
      " [   8  697]\n",
      " [   9 1188]]\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",
    "        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(((target1[z] - 1) % 10))\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[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c59a3e9a-564f-4641-8e76-a4971e910ef1",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (transform(tran1), tag1)\n",
    "Xte, yte = (transform(test_set[0]), test_set[1])\n",
    "\n",
    "data_handler = ClassificationDataHandler(Xtr, ytr,\n",
    "                                         Xte, yte)\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CIFAR10Net(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.001,\n",
    "            \"momentum\": 0.9,\n",
    "            \"weight_decay\": 5e-4\n",
    "        },\n",
    "        \n",
    "        criterion = F.cross_entropy,\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 32,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1.0\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=42)\n",
    "simulator.start(n_rounds=400)\n",
    "\n",
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "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.10199}, {'accuracy': 0.10146}, {'accuracy': 0.10153000000000001}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10400000000000001}, {'accuracy': 0.10400000000000001}, {'accuracy': 0.10400000000000001}, {'accuracy': 0.1}, {'accuracy': 0.10506}, {'accuracy': 0.10253000000000001}, {'accuracy': 0.10636000000000001}, {'accuracy': 0.10483}, {'accuracy': 0.10586}, {'accuracy': 0.1}, {'accuracy': 0.10604}, {'accuracy': 0.1}, {'accuracy': 0.1093}, {'accuracy': 0.10375999999999999}, {'accuracy': 0.1}, {'accuracy': 0.1126}, {'accuracy': 0.10823}, {'accuracy': 0.10286}, {'accuracy': 0.10421}, {'accuracy': 0.10443}, {'accuracy': 0.11524000000000001}, {'accuracy': 0.11606999999999998}, {'accuracy': 0.11123000000000001}, {'accuracy': 0.10861000000000001}, {'accuracy': 0.12655}, {'accuracy': 0.11372}, {'accuracy': 0.1116}, {'accuracy': 0.12604}, {'accuracy': 0.12178000000000003}, {'accuracy': 0.10823}, {'accuracy': 0.11820000000000001}, {'accuracy': 0.11388000000000001}, {'accuracy': 0.12817}, {'accuracy': 0.12075}, {'accuracy': 0.12702}, {'accuracy': 0.11052999999999999}, {'accuracy': 0.11637}, {'accuracy': 0.10976}, {'accuracy': 0.13352999999999998}, {'accuracy': 0.11271}, {'accuracy': 0.12455000000000001}, {'accuracy': 0.13555999999999999}, {'accuracy': 0.12741}, {'accuracy': 0.13939}, {'accuracy': 0.12856}, {'accuracy': 0.13556}, {'accuracy': 0.10803}, {'accuracy': 0.13023}, {'accuracy': 0.13427}, {'accuracy': 0.14033}, {'accuracy': 0.13139}, {'accuracy': 0.12678}, {'accuracy': 0.16854}, {'accuracy': 0.1379}, {'accuracy': 0.15939}, {'accuracy': 0.15002}, {'accuracy': 0.15705}, {'accuracy': 0.16346}, {'accuracy': 0.16802}, {'accuracy': 0.14606000000000002}, {'accuracy': 0.16083}, {'accuracy': 0.18081000000000003}, {'accuracy': 0.14905000000000002}, {'accuracy': 0.16516999999999998}, {'accuracy': 0.16441}, {'accuracy': 0.179}, {'accuracy': 0.15245999999999998}, {'accuracy': 0.18526}, {'accuracy': 0.17173999999999998}, {'accuracy': 0.16682999999999998}, {'accuracy': 0.19285}, {'accuracy': 0.16458}, {'accuracy': 0.17655}, {'accuracy': 0.17517}, {'accuracy': 0.21836000000000003}, {'accuracy': 0.19091}, {'accuracy': 0.20163999999999999}, {'accuracy': 0.17554999999999998}, {'accuracy': 0.17592}, {'accuracy': 0.18092}, {'accuracy': 0.1946}, {'accuracy': 0.18131000000000003}, {'accuracy': 0.21193}, {'accuracy': 0.17265999999999998}, {'accuracy': 0.18379}, {'accuracy': 0.20076}, {'accuracy': 0.18585}, {'accuracy': 0.18077000000000001}, {'accuracy': 0.2028}, {'accuracy': 0.18426}, {'accuracy': 0.2051}, {'accuracy': 0.22164999999999999}, {'accuracy': 0.18758000000000002}, {'accuracy': 0.20901}, {'accuracy': 0.18895}, {'accuracy': 0.20598999999999998}, {'accuracy': 0.19632999999999998}, {'accuracy': 0.20499}, {'accuracy': 0.21684}, {'accuracy': 0.21046}, {'accuracy': 0.19834999999999997}, {'accuracy': 0.21280000000000002}, {'accuracy': 0.19593}, {'accuracy': 0.21810000000000002}, {'accuracy': 0.22196}, {'accuracy': 0.21002}, {'accuracy': 0.21057}, {'accuracy': 0.17758000000000002}, {'accuracy': 0.21952}, {'accuracy': 0.22261000000000003}, {'accuracy': 0.21036000000000002}, {'accuracy': 0.21415}, {'accuracy': 0.20761000000000002}, {'accuracy': 0.21946}, {'accuracy': 0.21311}, {'accuracy': 0.18685}, {'accuracy': 0.22084}, {'accuracy': 0.23418999999999998}, {'accuracy': 0.20955}, {'accuracy': 0.19846000000000003}, {'accuracy': 0.22749999999999998}, {'accuracy': 0.19471000000000002}, {'accuracy': 0.21848}, {'accuracy': 0.24150999999999997}, {'accuracy': 0.22885}, {'accuracy': 0.25109000000000004}, {'accuracy': 0.23739999999999997}, {'accuracy': 0.22655000000000003}, {'accuracy': 0.22885}, {'accuracy': 0.26918}, {'accuracy': 0.23534000000000002}, {'accuracy': 0.23592000000000005}, {'accuracy': 0.25582}, {'accuracy': 0.23376000000000002}, {'accuracy': 0.24843}, {'accuracy': 0.24346}, {'accuracy': 0.24422000000000005}, {'accuracy': 0.23544}, {'accuracy': 0.26572}, {'accuracy': 0.23319}, {'accuracy': 0.25297000000000003}, {'accuracy': 0.27201}, {'accuracy': 0.25239999999999996}, {'accuracy': 0.27293}, {'accuracy': 0.26372999999999996}, {'accuracy': 0.25242}, {'accuracy': 0.28078}, {'accuracy': 0.26471}, {'accuracy': 0.25953}, {'accuracy': 0.26751}, {'accuracy': 0.28189000000000003}, {'accuracy': 0.26749}, {'accuracy': 0.30213999999999996}, {'accuracy': 0.25237}, {'accuracy': 0.29904000000000003}, {'accuracy': 0.28632}, {'accuracy': 0.28506}, {'accuracy': 0.27686}, {'accuracy': 0.27849}, {'accuracy': 0.31577}, {'accuracy': 0.29525999999999997}, {'accuracy': 0.27647}, {'accuracy': 0.27281}, {'accuracy': 0.27712000000000003}, {'accuracy': 0.32188999999999995}, {'accuracy': 0.27897}, {'accuracy': 0.31216}, {'accuracy': 0.28276999999999997}, {'accuracy': 0.28654}, {'accuracy': 0.31288999999999995}, {'accuracy': 0.30235}, {'accuracy': 0.30276000000000003}, {'accuracy': 0.29826}, {'accuracy': 0.29708999999999997}, {'accuracy': 0.32767}, {'accuracy': 0.28535000000000005}, {'accuracy': 0.32406}, {'accuracy': 0.29225}, {'accuracy': 0.27566}, {'accuracy': 0.29802999999999996}, {'accuracy': 0.28535999999999995}, {'accuracy': 0.30649000000000004}, {'accuracy': 0.30358999999999997}, {'accuracy': 0.32946}, {'accuracy': 0.30989}, {'accuracy': 0.27467}, {'accuracy': 0.40004}, {'accuracy': 0.41852999999999996}, {'accuracy': 0.39225000000000004}, {'accuracy': 0.38897}, {'accuracy': 0.40397999999999995}, {'accuracy': 0.4262499999999999}, {'accuracy': 0.42675}, {'accuracy': 0.41856}, {'accuracy': 0.42661}, {'accuracy': 0.4245}, {'accuracy': 0.41703999999999997}, {'accuracy': 0.42425999999999997}, {'accuracy': 0.40991}, {'accuracy': 0.42885999999999996}, {'accuracy': 0.42911}, {'accuracy': 0.42457}, {'accuracy': 0.42995}, {'accuracy': 0.42661999999999994}, {'accuracy': 0.42766000000000004}, {'accuracy': 0.4275399999999999}, {'accuracy': 0.42751}, {'accuracy': 0.4131}, {'accuracy': 0.42266000000000004}, {'accuracy': 0.42486999999999997}, {'accuracy': 0.42412}, {'accuracy': 0.42943}, {'accuracy': 0.42574000000000006}, {'accuracy': 0.43344999999999995}, {'accuracy': 0.42615}, {'accuracy': 0.43515999999999994}, {'accuracy': 0.42955999999999994}, {'accuracy': 0.42422999999999994}, {'accuracy': 0.42862999999999996}, {'accuracy': 0.42264}, {'accuracy': 0.43048000000000003}, {'accuracy': 0.43341}, {'accuracy': 0.42584999999999995}, {'accuracy': 0.42971000000000004}, {'accuracy': 0.43140999999999996}, {'accuracy': 0.41509999999999997}, {'accuracy': 0.42817000000000005}, {'accuracy': 0.42824999999999996}, {'accuracy': 0.43415}, {'accuracy': 0.43027}, {'accuracy': 0.4248}, {'accuracy': 0.42514}, {'accuracy': 0.42341000000000006}, {'accuracy': 0.41992}, {'accuracy': 0.43339}, {'accuracy': 0.42892}, {'accuracy': 0.44579}, {'accuracy': 0.42994000000000004}, {'accuracy': 0.43584000000000006}, {'accuracy': 0.4307}, {'accuracy': 0.43061999999999995}, {'accuracy': 0.42854000000000003}, {'accuracy': 0.43249000000000004}, {'accuracy': 0.44054000000000004}, {'accuracy': 0.43055999999999994}, {'accuracy': 0.43547}, {'accuracy': 0.43055000000000004}, {'accuracy': 0.43183}, {'accuracy': 0.42979}, {'accuracy': 0.42973999999999996}, {'accuracy': 0.43685999999999997}, {'accuracy': 0.43671}, {'accuracy': 0.43133}, {'accuracy': 0.44017}, {'accuracy': 0.43508}, {'accuracy': 0.43329000000000006}, {'accuracy': 0.42819}, {'accuracy': 0.43421000000000004}, {'accuracy': 0.43269}, {'accuracy': 0.43161000000000005}, {'accuracy': 0.43321000000000004}, {'accuracy': 0.42877}, {'accuracy': 0.43798000000000004}, {'accuracy': 0.434}, {'accuracy': 0.43622000000000005}, {'accuracy': 0.4314299999999999}, {'accuracy': 0.44099000000000005}, {'accuracy': 0.43251}, {'accuracy': 0.43475}, {'accuracy': 0.42954}, {'accuracy': 0.4361}, {'accuracy': 0.43159000000000003}, {'accuracy': 0.43712}, {'accuracy': 0.43867}, {'accuracy': 0.43333000000000005}, {'accuracy': 0.42806999999999995}, {'accuracy': 0.43413}, {'accuracy': 0.43551}, {'accuracy': 0.43310000000000004}, {'accuracy': 0.43571}, {'accuracy': 0.43579999999999997}, {'accuracy': 0.43451000000000006}, {'accuracy': 0.43548}, {'accuracy': 0.44292999999999993}, {'accuracy': 0.43984999999999996}, {'accuracy': 0.4344}, {'accuracy': 0.43079999999999996}, {'accuracy': 0.43796}, {'accuracy': 0.4339500000000001}, {'accuracy': 0.43933}, {'accuracy': 0.43903}, {'accuracy': 0.4348000000000001}, {'accuracy': 0.43649000000000004}, {'accuracy': 0.44562}, {'accuracy': 0.43891}, {'accuracy': 0.43592}, {'accuracy': 0.43842}, {'accuracy': 0.44111}, {'accuracy': 0.44292}, {'accuracy': 0.43929}, {'accuracy': 0.44978999999999997}, {'accuracy': 0.44536}, {'accuracy': 0.44505999999999996}, {'accuracy': 0.44724}, {'accuracy': 0.44017}, {'accuracy': 0.445}, {'accuracy': 0.44324}, {'accuracy': 0.44139}, {'accuracy': 0.44226}, {'accuracy': 0.4404399999999999}, {'accuracy': 0.4366499999999999}, {'accuracy': 0.442}, {'accuracy': 0.43854}, {'accuracy': 0.43848000000000004}, {'accuracy': 0.43689}, {'accuracy': 0.43665000000000004}, {'accuracy': 0.43945}, {'accuracy': 0.44017999999999996}, {'accuracy': 0.44544999999999996}, {'accuracy': 0.43952}, {'accuracy': 0.44530999999999993}, {'accuracy': 0.441}, {'accuracy': 0.44252}, {'accuracy': 0.44197}, {'accuracy': 0.4417}, {'accuracy': 0.43857999999999997}, {'accuracy': 0.44356999999999996}, {'accuracy': 0.44447000000000003}, {'accuracy': 0.44534}, {'accuracy': 0.43769999999999987}, {'accuracy': 0.43963}, {'accuracy': 0.44504}, {'accuracy': 0.44777000000000006}, {'accuracy': 0.43894}, {'accuracy': 0.44082}, {'accuracy': 0.44308999999999993}, {'accuracy': 0.44946}, {'accuracy': 0.44824}, {'accuracy': 0.44742999999999994}, {'accuracy': 0.44462999999999997}, {'accuracy': 0.44699}, {'accuracy': 0.44356}, {'accuracy': 0.44604}, {'accuracy': 0.44537999999999994}, {'accuracy': 0.44608}, {'accuracy': 0.44384999999999997}, {'accuracy': 0.44451}, {'accuracy': 0.44772}, {'accuracy': 0.44676}, {'accuracy': 0.44165}, {'accuracy': 0.44759000000000004}, {'accuracy': 0.44512999999999997}, {'accuracy': 0.44684999999999997}, {'accuracy': 0.45179}, {'accuracy': 0.44322999999999996}, {'accuracy': 0.42808}, {'accuracy': 0.43739}, {'accuracy': 0.42538}, {'accuracy': 0.43613}, {'accuracy': 0.43637}, {'accuracy': 0.4414599999999999}, {'accuracy': 0.43221999999999994}, {'accuracy': 0.43957999999999997}, {'accuracy': 0.44265}, {'accuracy': 0.44387999999999994}, {'accuracy': 0.44603000000000004}, {'accuracy': 0.44401999999999997}, {'accuracy': 0.44593999999999995}, {'accuracy': 0.44577999999999995}, {'accuracy': 0.43960999999999995}, {'accuracy': 0.44236000000000003}, {'accuracy': 0.43976}, {'accuracy': 0.44781999999999994}, {'accuracy': 0.43556}, {'accuracy': 0.42352}, {'accuracy': 0.43113999999999997}, {'accuracy': 0.44173}, {'accuracy': 0.44363}, {'accuracy': 0.43738}, {'accuracy': 0.44447000000000003}, {'accuracy': 0.44915000000000005}, {'accuracy': 0.44099000000000005}, {'accuracy': 0.44579}, {'accuracy': 0.44087000000000004}, {'accuracy': 0.44765}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "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": "1caa8c4f-09bb-4bc0-bd53-95772cfc3230",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5add4c6d-2eeb-4555-94be-24c74b9c412a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "335bb580-7bce-4099-8a4b-ab6a292d1a52",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "30fa3014-445f-41a8-bd13-e8fbf50ef621",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "039cb0a7-a8c4-4b79-b75d-3eb30a807e90",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "745188d5-2db5-42af-8fb1-a7b1ddd28412",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "73f53992-0c98-4d02-ab5a-e745eabe572a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "36bad464-6a2f-47b6-8677-3189560dd881",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e5b697e1-c94f-4453-9c97-311ab7b118a3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ca668483-72bd-4a9c-b240-2848d35bbcab",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1334b249-a53a-43a6-80f6-bb3162072ea1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fd3c67f4-599d-4388-81e6-2ec1eec168ce",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6c06c513-2207-4b98-bfb2-016d3c828539",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8a3988ab-d6c3-4ca3-a8f9-b8eca6364f9a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f51209fc-6042-4efb-943b-ecf3ac658f83",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3f708ec9-d492-446b-80c6-ae3a7cc9ad28",
   "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
}
