{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "tensor([6, 9, 9,  ..., 9, 1, 1])\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_CIFAR100\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "\n",
    "class CIFAR10Net(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(3, 64,kernel_size=3, stride=2, padding=1)\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(64, 192, 3, padding=1)\n",
    "        self.conv3 = nn.Conv2d(192, 384, 3, padding=1)\n",
    "        self.conv4 = nn.Conv2d(384, 256, 3, padding=1)\n",
    "        self.conv5 = nn.Conv2d(256, 256, 3, padding=1)\n",
    "        self.fc1 = nn.Linear(256 * 2 * 2, 4096)\n",
    "        self.fc2 = nn.Linear(4096, 4096)\n",
    "        self.fc3 = nn.Linear(4096, 10)\n",
    "    \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        # def _init_weights(m: nn.Module):\n",
    "        #     if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "        #         nn.init.xavier_uniform_(m.weight)\n",
    "        #         nn.init.zeros_(m.bias)\n",
    "        #self.apply(_init_weights)\n",
    "        pass\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.pool(F.relu(self.conv1(x)))\n",
    "        x = self.pool(F.relu(self.conv2(x)))\n",
    "        x = F.relu(self.conv3(x))\n",
    "        x = F.relu(self.conv4(x))\n",
    "        x = self.pool(F.relu(self.conv5(x)))\n",
    "        # print(x.shape)\n",
    "        x = x.view(-1, 256 * 2 * 2)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.relu(self.fc2(x))\n",
    "        x = self.fc3(x)\n",
    "        return x\n",
    "    \n",
    "    def __repr__(self) -> str:\n",
    "        return \"CIFAR10Net(size=%d)\" %self.get_size()\n",
    "    \n",
    "    \n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n",
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_CIFAR10()\n",
    "\n",
    "\n",
    "print(train_set[1])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([50000])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([1, 1, 1,  ..., 1, 1, 1])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tran1=torch.zeros([50000,3,32,32], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([50000], dtype=torch.int64)\n",
    "\n",
    "print(tag1.shape)\n",
    "\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,50000,1):\n",
    "    if train_set[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif train_set[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif train_set[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif train_set[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif train_set[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif train_set[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif train_set[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif train_set[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif train_set[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif train_set[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "train_set[1][label[1]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "dbc3456b-d386-41c9-9465-55f89e6b2d2b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(train_set[0][label[0][z]])\n",
    "        list0[1].append(train_set[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(train_set[0][label[0][z]])\n",
    "        list1[1].append(train_set[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(train_set[0][label[0][z]])\n",
    "        list2[1].append(train_set[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(train_set[0][label[0][z]])\n",
    "        list3[1].append(train_set[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(train_set[0][label[0][z]])\n",
    "        list4[1].append(train_set[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(train_set[0][label[0][z]])\n",
    "        list5[1].append(train_set[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(train_set[0][label[0][z]])\n",
    "        list6[1].append(train_set[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(train_set[0][label[0][z]])\n",
    "        list7[1].append(train_set[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(train_set[0][label[0][z]])\n",
    "        list8[1].append(train_set[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(train_set[0][label[0][z]])\n",
    "        list9[1].append(train_set[1][label[0][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "473ea3ac-f6a7-424a-aca0-e50a6df03355",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "eb808629-58e7-4eb6-8c15-479cc02d237a",
   "metadata": {},
   "outputs": [],
   "source": [
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(train_set[0][label[1][z]])\n",
    "        list1[1].append(train_set[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(train_set[0][label[1][z]])\n",
    "        list2[1].append(train_set[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(train_set[0][label[1][z]])\n",
    "        list3[1].append(train_set[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(train_set[0][label[1][z]])\n",
    "        list4[1].append(train_set[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(train_set[0][label[1][z]])\n",
    "        list5[1].append(train_set[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(train_set[0][label[1][z]])\n",
    "        list6[1].append(train_set[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(train_set[0][label[1][z]])\n",
    "        list7[1].append(train_set[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(train_set[0][label[1][z]])\n",
    "        list8[1].append(train_set[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(train_set[0][label[1][z]])\n",
    "        list9[1].append(train_set[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(train_set[0][label[1][z]])\n",
    "        list0[1].append(train_set[1][label[1][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a3aa2fcc-c4f4-408d-9423-86ea099f696b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "0b70f77d-f544-49f6-93a3-e3e974ce9287",
   "metadata": {},
   "outputs": [],
   "source": [
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(train_set[0][label[2][z]])\n",
    "        list2[1].append(train_set[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(train_set[0][label[2][z]])\n",
    "        list3[1].append(train_set[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(train_set[0][label[2][z]])\n",
    "        list4[1].append(train_set[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(train_set[0][label[2][z]])\n",
    "        list5[1].append(train_set[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(train_set[0][label[2][z]])\n",
    "        list6[1].append(train_set[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(train_set[0][label[2][z]])\n",
    "        list7[1].append(train_set[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(train_set[0][label[2][z]])\n",
    "        list8[1].append(train_set[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(train_set[0][label[2][z]])\n",
    "        list9[1].append(train_set[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(train_set[0][label[2][z]])\n",
    "        list0[1].append(train_set[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(train_set[0][label[2][z]])\n",
    "        list1[1].append(train_set[1][label[2][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bf1e1d02-0668-4c7b-8079-b7b3fadca6f8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "c83b07a5-13f4-46b9-8e6d-ec57a8794c57",
   "metadata": {},
   "outputs": [],
   "source": [
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(train_set[0][label[3][z]])\n",
    "        list3[1].append(train_set[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(train_set[0][label[3][z]])\n",
    "        list4[1].append(train_set[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(train_set[0][label[3][z]])\n",
    "        list5[1].append(train_set[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(train_set[0][label[3][z]])\n",
    "        list6[1].append(train_set[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(train_set[0][label[3][z]])\n",
    "        list7[1].append(train_set[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(train_set[0][label[3][z]])\n",
    "        list8[1].append(train_set[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(train_set[0][label[3][z]])\n",
    "        list9[1].append(train_set[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(train_set[0][label[3][z]])\n",
    "        list0[1].append(train_set[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(train_set[0][label[3][z]])\n",
    "        list1[1].append(train_set[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(train_set[0][label[3][z]])\n",
    "        list2[1].append(train_set[1][label[3][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0ad1327c-00bb-4f50-ac57-be4195b91337",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "b60e76e6-ccff-4323-8a51-ec20b80e923f",
   "metadata": {},
   "outputs": [],
   "source": [
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(train_set[0][label[4][z]])\n",
    "        list4[1].append(train_set[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(train_set[0][label[4][z]])\n",
    "        list5[1].append(train_set[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(train_set[0][label[4][z]])\n",
    "        list6[1].append(train_set[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(train_set[0][label[4][z]])\n",
    "        list7[1].append(train_set[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(train_set[0][label[4][z]])\n",
    "        list8[1].append(train_set[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(train_set[0][label[4][z]])\n",
    "        list9[1].append(train_set[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(train_set[0][label[4][z]])\n",
    "        list0[1].append(train_set[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(train_set[0][label[4][z]])\n",
    "        list1[1].append(train_set[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(train_set[0][label[4][z]])\n",
    "        list2[1].append(train_set[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(train_set[0][label[4][z]])\n",
    "        list3[1].append(train_set[1][label[4][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6dec69bb-536c-4fdc-81bf-c215a286f04a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "925dbdcc-21e0-4f8f-8b75-94963a36f38a",
   "metadata": {},
   "outputs": [],
   "source": [
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(train_set[0][label[5][z]])\n",
    "        list5[1].append(train_set[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(train_set[0][label[5][z]])\n",
    "        list6[1].append(train_set[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(train_set[0][label[5][z]])\n",
    "        list7[1].append(train_set[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(train_set[0][label[5][z]])\n",
    "        list8[1].append(train_set[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(train_set[0][label[5][z]])\n",
    "        list9[1].append(train_set[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(train_set[0][label[5][z]])\n",
    "        list0[1].append(train_set[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(train_set[0][label[5][z]])\n",
    "        list1[1].append(train_set[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(train_set[0][label[5][z]])\n",
    "        list2[1].append(train_set[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(train_set[0][label[5][z]])\n",
    "        list3[1].append(train_set[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(train_set[0][label[5][z]])\n",
    "        list4[1].append(train_set[1][label[5][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3024807a-0e1b-4cda-98fe-a49be1cde0f2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "bbe2a38a-0099-407d-a188-e06ff7ab899d",
   "metadata": {},
   "outputs": [],
   "source": [
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(train_set[0][label[6][z]])\n",
    "        list6[1].append(train_set[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(train_set[0][label[6][z]])\n",
    "        list7[1].append(train_set[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(train_set[0][label[6][z]])\n",
    "        list8[1].append(train_set[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(train_set[0][label[6][z]])\n",
    "        list9[1].append(train_set[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(train_set[0][label[6][z]])\n",
    "        list0[1].append(train_set[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(train_set[0][label[6][z]])\n",
    "        list1[1].append(train_set[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(train_set[0][label[6][z]])\n",
    "        list2[1].append(train_set[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(train_set[0][label[6][z]])\n",
    "        list3[1].append(train_set[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(train_set[0][label[6][z]])\n",
    "        list4[1].append(train_set[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(train_set[0][label[6][z]])\n",
    "        list5[1].append(train_set[1][label[6][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4bc595ee-f8eb-41bf-9dc4-2d32a615b873",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "53de6bac-141a-45b9-8910-3eace920f86b",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(train_set[0][label[7][z]])\n",
    "        list7[1].append(train_set[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(train_set[0][label[7][z]])\n",
    "        list8[1].append(train_set[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(train_set[0][label[7][z]])\n",
    "        list9[1].append(train_set[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(train_set[0][label[7][z]])\n",
    "        list0[1].append(train_set[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(train_set[0][label[7][z]])\n",
    "        list1[1].append(train_set[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(train_set[0][label[7][z]])\n",
    "        list2[1].append(train_set[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(train_set[0][label[7][z]])\n",
    "        list3[1].append(train_set[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(train_set[0][label[7][z]])\n",
    "        list4[1].append(train_set[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(train_set[0][label[7][z]])\n",
    "        list5[1].append(train_set[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(train_set[0][label[7][z]])\n",
    "        list6[1].append(train_set[1][label[7][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0c65c26a-fa65-4399-ae11-78144d521edb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "a0044dab-8c89-4e12-b010-a632ef8426eb",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(train_set[0][label[8][z]])\n",
    "        list8[1].append(train_set[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(train_set[0][label[8][z]])\n",
    "        list9[1].append(train_set[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(train_set[0][label[8][z]])\n",
    "        list0[1].append(train_set[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(train_set[0][label[8][z]])\n",
    "        list1[1].append(train_set[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(train_set[0][label[8][z]])\n",
    "        list2[1].append(train_set[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(train_set[0][label[8][z]])\n",
    "        list3[1].append(train_set[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(train_set[0][label[8][z]])\n",
    "        list4[1].append(train_set[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(train_set[0][label[8][z]])\n",
    "        list5[1].append(train_set[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(train_set[0][label[8][z]])\n",
    "        list6[1].append(train_set[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(train_set[0][label[8][z]])\n",
    "        list7[1].append(train_set[1][label[8][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "acb72266-deb0-41bf-9f24-0e1e15285391",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "cd18c2ac-1778-46ab-9f17-af3b80856111",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(train_set[0][label[9][z]])\n",
    "        list9[1].append(train_set[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(train_set[0][label[9][z]])\n",
    "        list0[1].append(train_set[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(train_set[0][label[9][z]])\n",
    "        list1[1].append(train_set[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(train_set[0][label[9][z]])\n",
    "        list2[1].append(train_set[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(train_set[0][label[9][z]])\n",
    "        list3[1].append(train_set[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(train_set[0][label[9][z]])\n",
    "        list4[1].append(train_set[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(train_set[0][label[9][z]])\n",
    "        list5[1].append(train_set[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(train_set[0][label[9][z]])\n",
    "        list6[1].append(train_set[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(train_set[0][label[9][z]])\n",
    "        list7[1].append(train_set[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(train_set[0][label[9][z]])\n",
    "        list8[1].append(train_set[1][label[9][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cc5132f4-f827-473a-9d1f-6aac269955ee",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "1aad24c5-184d-4721-915c-3825cb7dbc47",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 2004]\n",
      " [   1   49]\n",
      " [   2   33]\n",
      " [   3   54]\n",
      " [   4   98]\n",
      " [   5  173]\n",
      " [   6  245]\n",
      " [   7  427]\n",
      " [   8  723]\n",
      " [   9 1205]]\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 1195]\n",
      " [   1 1992]\n",
      " [   2   42]\n",
      " [   3   22]\n",
      " [   4   67]\n",
      " [   5   91]\n",
      " [   6  155]\n",
      " [   7  246]\n",
      " [   8  452]\n",
      " [   9  735]]\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  710]\n",
      " [   1 1205]\n",
      " [   2 2029]\n",
      " [   3   44]\n",
      " [   4   34]\n",
      " [   5   57]\n",
      " [   6   95]\n",
      " [   7  148]\n",
      " [   8  284]\n",
      " [   9  421]]\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  443]\n",
      " [   1  718]\n",
      " [   2 1192]\n",
      " [   3 2005]\n",
      " [   4   58]\n",
      " [   5   35]\n",
      " [   6   53]\n",
      " [   7  110]\n",
      " [   8  154]\n",
      " [   9  252]]\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  237]\n",
      " [   1  399]\n",
      " [   2  742]\n",
      " [   3 1230]\n",
      " [   4 1951]\n",
      " [   5   55]\n",
      " [   6   33]\n",
      " [   7   50]\n",
      " [   8   79]\n",
      " [   9  174]]\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  158]\n",
      " [   1  266]\n",
      " [   2  426]\n",
      " [   3  730]\n",
      " [   4 1194]\n",
      " [   5 1999]\n",
      " [   6   45]\n",
      " [   7   37]\n",
      " [   8   57]\n",
      " [   9   72]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list5[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "5c6c8374-d56f-49c2-ac81-a94873d19c1c",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   95]\n",
      " [   1  174]\n",
      " [   2  247]\n",
      " [   3  436]\n",
      " [   4  707]\n",
      " [   5 1247]\n",
      " [   6 1985]\n",
      " [   7   60]\n",
      " [   8   29]\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   47]\n",
      " [   1  108]\n",
      " [   2  152]\n",
      " [   3  251]\n",
      " [   4  428]\n",
      " [   5  681]\n",
      " [   6 1192]\n",
      " [   7 1973]\n",
      " [   8   47]\n",
      " [   9   36]]\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   41]\n",
      " [   1   50]\n",
      " [   2   84]\n",
      " [   3  142]\n",
      " [   4  284]\n",
      " [   5  422]\n",
      " [   6  755]\n",
      " [   7 1206]\n",
      " [   8 1978]\n",
      " [   9   39]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "ef796dae-f8f7-4f29-b9f2-80960e55027b",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   70]\n",
      " [   1   39]\n",
      " [   2   53]\n",
      " [   3   86]\n",
      " [   4  179]\n",
      " [   5  240]\n",
      " [   6  442]\n",
      " [   7  743]\n",
      " [   8 1197]\n",
      " [   9 2016]]\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": [
      "6035\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 2004]\n",
      " [   1   34]\n",
      " [   2   33]\n",
      " [   3   37]\n",
      " [   4   98]\n",
      " [   5  109]\n",
      " [   6  245]\n",
      " [   7  427]\n",
      " [   8  723]\n",
      " [   9  687]]\n",
      "[[   0 2004]\n",
      " [   1   51]\n",
      " [   2   33]\n",
      " [   3   50]\n",
      " [   4   98]\n",
      " [   5  154]\n",
      " [   6  245]\n",
      " [   7  427]\n",
      " [   8  723]\n",
      " [   9 1063]]\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<3:\n",
    "        if target1[z]==1:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(9))\n",
    "        \n",
    "        elif target1[z]==9:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(1))      \n",
    "        \n",
    "        elif target1[z]==3:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(5))\n",
    "        \n",
    "        \n",
    "        elif target1[z]==5:\n",
    "            noiseyset[0].append(dataset1[z])\n",
    "            healthset[0].append(dataset1[z])\n",
    "            healthset[1].append(target1[z])\n",
    "            healthset[2].append(z)\n",
    "            noiseyset[1].append(torch.tensor(3))     \n",
    "        \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[1][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[1][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "73a7592b-69b3-4bfe-83b2-1a15b4092afd",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (transform(tran1), tag1)\n",
    "Xte, yte = (transform(test_set[0]), test_set[1])\n",
    "\n",
    "data_handler = ClassificationDataHandler(Xtr, ytr,\n",
    "                                         Xte, yte)\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CIFAR10Net(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.001,\n",
    "            \"momentum\": 0.9,\n",
    "            \"weight_decay\": 5e-4\n",
    "        },\n",
    "        \n",
    "        criterion = F.cross_entropy,\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 32,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1.0\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=42)\n",
    "simulator.start(n_rounds=350)\n",
    "\n",
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10093999999999999}, {'accuracy': 0.10055}, {'accuracy': 0.09999}, {'accuracy': 0.10052000000000001}, {'accuracy': 0.10056000000000001}, {'accuracy': 0.09991}, {'accuracy': 0.10712000000000002}, {'accuracy': 0.10141}, {'accuracy': 0.10633000000000001}, {'accuracy': 0.10579000000000001}, {'accuracy': 0.10719000000000001}, {'accuracy': 0.10865}, {'accuracy': 0.11008000000000003}, {'accuracy': 0.12203000000000001}, {'accuracy': 0.11435}, {'accuracy': 0.11611}, {'accuracy': 0.10783000000000001}, {'accuracy': 0.11666000000000001}, {'accuracy': 0.12550999999999998}, {'accuracy': 0.10684}, {'accuracy': 0.13546999999999998}, {'accuracy': 0.14587999999999998}, {'accuracy': 0.14028}, {'accuracy': 0.13168}, {'accuracy': 0.16149000000000002}, {'accuracy': 0.16188000000000002}, {'accuracy': 0.17389}, {'accuracy': 0.15621000000000002}, {'accuracy': 0.17435}, {'accuracy': 0.15939}, {'accuracy': 0.17319}, {'accuracy': 0.15105}, {'accuracy': 0.17549}, {'accuracy': 0.17668}, {'accuracy': 0.17843000000000003}, {'accuracy': 0.18718}, {'accuracy': 0.18419999999999997}, {'accuracy': 0.19557}, {'accuracy': 0.20421999999999998}, {'accuracy': 0.18692999999999999}, {'accuracy': 0.21303999999999998}, {'accuracy': 0.19996}, {'accuracy': 0.19577}, {'accuracy': 0.19881}, {'accuracy': 0.21257}, {'accuracy': 0.21308000000000002}, {'accuracy': 0.21311}, {'accuracy': 0.20676}, {'accuracy': 0.20421}, {'accuracy': 0.22585000000000002}, {'accuracy': 0.22039}, {'accuracy': 0.21308}, {'accuracy': 0.23671000000000003}, {'accuracy': 0.24293000000000003}, {'accuracy': 0.24605000000000002}, {'accuracy': 0.24123999999999998}, {'accuracy': 0.23426}, {'accuracy': 0.22121}, {'accuracy': 0.23406000000000002}, {'accuracy': 0.25969000000000003}, {'accuracy': 0.24999000000000002}, {'accuracy': 0.24861}, {'accuracy': 0.25969}, {'accuracy': 0.24323}, {'accuracy': 0.24124000000000004}, {'accuracy': 0.24785}, {'accuracy': 0.25795}, {'accuracy': 0.24894}, {'accuracy': 0.27187}, {'accuracy': 0.27058}, {'accuracy': 0.25929}, {'accuracy': 0.26819000000000004}, {'accuracy': 0.25005}, {'accuracy': 0.27257}, {'accuracy': 0.27393999999999996}, {'accuracy': 0.26514999999999994}, {'accuracy': 0.27015}, {'accuracy': 0.28124000000000005}, {'accuracy': 0.28701999999999994}, {'accuracy': 0.29673999999999995}, {'accuracy': 0.28619}, {'accuracy': 0.26986000000000004}, {'accuracy': 0.29246000000000005}, {'accuracy': 0.28895}, {'accuracy': 0.30301}, {'accuracy': 0.30796999999999997}, {'accuracy': 0.30123}, {'accuracy': 0.30043000000000003}, {'accuracy': 0.2917}, {'accuracy': 0.31331999999999993}, {'accuracy': 0.30534000000000006}, {'accuracy': 0.31068999999999997}, {'accuracy': 0.30329}, {'accuracy': 0.31827}, {'accuracy': 0.31327}, {'accuracy': 0.31429}, {'accuracy': 0.30912000000000006}, {'accuracy': 0.3116}, {'accuracy': 0.32972999999999997}, {'accuracy': 0.31061}, {'accuracy': 0.32393}, {'accuracy': 0.33018000000000003}, {'accuracy': 0.33045}, {'accuracy': 0.3345000000000001}, {'accuracy': 0.33353}, {'accuracy': 0.34907000000000005}, {'accuracy': 0.34774}, {'accuracy': 0.35262000000000004}, {'accuracy': 0.3390699999999999}, {'accuracy': 0.33541}, {'accuracy': 0.34515999999999997}, {'accuracy': 0.34125}, {'accuracy': 0.34412000000000004}, {'accuracy': 0.34585}, {'accuracy': 0.35914999999999997}, {'accuracy': 0.34913}, {'accuracy': 0.35650000000000004}, {'accuracy': 0.36343000000000003}, {'accuracy': 0.36041999999999996}, {'accuracy': 0.34911}, {'accuracy': 0.36327999999999994}, {'accuracy': 0.3705}, {'accuracy': 0.37361999999999995}, {'accuracy': 0.36177000000000004}, {'accuracy': 0.36510999999999993}, {'accuracy': 0.38444}, {'accuracy': 0.38312}, {'accuracy': 0.37228000000000006}, {'accuracy': 0.36436999999999997}, {'accuracy': 0.36469999999999997}, {'accuracy': 0.3644}, {'accuracy': 0.37377999999999995}, {'accuracy': 0.3962}, {'accuracy': 0.38098}, {'accuracy': 0.38132}, {'accuracy': 0.37072000000000005}, {'accuracy': 0.38824000000000003}, {'accuracy': 0.39719000000000004}, {'accuracy': 0.37739}, {'accuracy': 0.37555000000000005}, {'accuracy': 0.40202}, {'accuracy': 0.37448}, {'accuracy': 0.37422}, {'accuracy': 0.38419000000000003}, {'accuracy': 0.37306999999999996}, {'accuracy': 0.38924}, {'accuracy': 0.3885200000000001}, {'accuracy': 0.40195}, {'accuracy': 0.36221}, {'accuracy': 0.38793}, {'accuracy': 0.39944}, {'accuracy': 0.39988999999999997}, {'accuracy': 0.39439}, {'accuracy': 0.40014000000000005}, {'accuracy': 0.37594}, {'accuracy': 0.39168}, {'accuracy': 0.38911999999999997}, {'accuracy': 0.38573}, {'accuracy': 0.40114}, {'accuracy': 0.38236}, {'accuracy': 0.39682999999999996}, {'accuracy': 0.40462}, {'accuracy': 0.40698}, {'accuracy': 0.39659999999999995}, {'accuracy': 0.39183999999999997}, {'accuracy': 0.38331}, {'accuracy': 0.40629}, {'accuracy': 0.40424}, {'accuracy': 0.39753999999999995}, {'accuracy': 0.41228}, {'accuracy': 0.42051}, {'accuracy': 0.39413}, {'accuracy': 0.40896}, {'accuracy': 0.40591999999999995}, {'accuracy': 0.40005000000000007}, {'accuracy': 0.39834}, {'accuracy': 0.4061}, {'accuracy': 0.40915999999999997}, {'accuracy': 0.4136}, {'accuracy': 0.4192699999999999}, {'accuracy': 0.40503}, {'accuracy': 0.41162}, {'accuracy': 0.40347}, {'accuracy': 0.43629999999999997}, {'accuracy': 0.46394}, {'accuracy': 0.47587999999999997}, {'accuracy': 0.46748}, {'accuracy': 0.46904}, {'accuracy': 0.47890999999999995}, {'accuracy': 0.4687799999999999}, {'accuracy': 0.4736000000000001}, {'accuracy': 0.48480999999999996}, {'accuracy': 0.48418}, {'accuracy': 0.48457}, {'accuracy': 0.45016999999999996}, {'accuracy': 0.47436999999999996}, {'accuracy': 0.46780999999999995}, {'accuracy': 0.46035000000000004}, {'accuracy': 0.47957}, {'accuracy': 0.49126000000000003}, {'accuracy': 0.48685}, {'accuracy': 0.48821000000000003}, {'accuracy': 0.46672}, {'accuracy': 0.47772}, {'accuracy': 0.47205}, {'accuracy': 0.48224999999999996}, {'accuracy': 0.48922999999999994}, {'accuracy': 0.4943099999999999}, {'accuracy': 0.48363000000000006}, {'accuracy': 0.49466}, {'accuracy': 0.49314}, {'accuracy': 0.4883699999999999}, {'accuracy': 0.46993}, {'accuracy': 0.48695000000000005}, {'accuracy': 0.4906}, {'accuracy': 0.49552000000000007}, {'accuracy': 0.49427000000000004}, {'accuracy': 0.47733}, {'accuracy': 0.49328000000000005}, {'accuracy': 0.4857}, {'accuracy': 0.48930999999999997}, {'accuracy': 0.48577000000000004}, {'accuracy': 0.48331}, {'accuracy': 0.49673999999999996}, {'accuracy': 0.49349}, {'accuracy': 0.49124999999999996}, {'accuracy': 0.47730000000000006}, {'accuracy': 0.48238999999999993}, {'accuracy': 0.49283}, {'accuracy': 0.4950899999999999}, {'accuracy': 0.4706999999999999}, {'accuracy': 0.50332}, {'accuracy': 0.48358}, {'accuracy': 0.48816}, {'accuracy': 0.49573}, {'accuracy': 0.48895}, {'accuracy': 0.5042899999999999}, {'accuracy': 0.48965}, {'accuracy': 0.48859}, {'accuracy': 0.48647}, {'accuracy': 0.4992599999999999}, {'accuracy': 0.49381}, {'accuracy': 0.50222}, {'accuracy': 0.49605}, {'accuracy': 0.5043}, {'accuracy': 0.50181}, {'accuracy': 0.49228999999999995}, {'accuracy': 0.4928100000000001}, {'accuracy': 0.4978300000000001}, {'accuracy': 0.50441}, {'accuracy': 0.47928}, {'accuracy': 0.49077000000000004}, {'accuracy': 0.49285999999999996}, {'accuracy': 0.49748000000000003}, {'accuracy': 0.50354}, {'accuracy': 0.5037999999999998}, {'accuracy': 0.49246999999999996}, {'accuracy': 0.49385}, {'accuracy': 0.5012799999999998}, {'accuracy': 0.50496}, {'accuracy': 0.50416}, {'accuracy': 0.48432}, {'accuracy': 0.4780500000000001}, {'accuracy': 0.49503}, {'accuracy': 0.49214}, {'accuracy': 0.49198000000000003}, {'accuracy': 0.49553}, {'accuracy': 0.5030300000000001}, {'accuracy': 0.4983000000000001}, {'accuracy': 0.5024299999999999}, {'accuracy': 0.48961000000000005}, {'accuracy': 0.49879999999999997}, {'accuracy': 0.4923400000000001}, {'accuracy': 0.4991499999999999}, {'accuracy': 0.4981700000000001}, {'accuracy': 0.50544}, {'accuracy': 0.49729}, {'accuracy': 0.50104}, {'accuracy': 0.49711999999999995}, {'accuracy': 0.49959}, {'accuracy': 0.5071899999999999}, {'accuracy': 0.46840000000000004}, {'accuracy': 0.47246999999999995}, {'accuracy': 0.4743200000000001}, {'accuracy': 0.49774}, {'accuracy': 0.4892200000000001}, {'accuracy': 0.49350000000000005}, {'accuracy': 0.49606000000000006}, {'accuracy': 0.4994199999999999}, {'accuracy': 0.49371}, {'accuracy': 0.49595}, {'accuracy': 0.49139}, {'accuracy': 0.50007}, {'accuracy': 0.49176000000000003}, {'accuracy': 0.5026499999999999}, {'accuracy': 0.50073}, {'accuracy': 0.5011099999999999}, {'accuracy': 0.5044000000000001}, {'accuracy': 0.5037300000000001}, {'accuracy': 0.4997599999999999}, {'accuracy': 0.5064700000000001}, {'accuracy': 0.49826999999999994}, {'accuracy': 0.4965400000000001}, {'accuracy': 0.48812}, {'accuracy': 0.49778}, {'accuracy': 0.49898999999999993}, {'accuracy': 0.49627}, {'accuracy': 0.49972000000000005}, {'accuracy': 0.50283}, {'accuracy': 0.5054299999999999}, {'accuracy': 0.49091000000000007}, {'accuracy': 0.49588}, {'accuracy': 0.49772999999999995}, {'accuracy': 0.49236}, {'accuracy': 0.49289000000000005}, {'accuracy': 0.49781999999999993}, {'accuracy': 0.49354}, {'accuracy': 0.50528}, {'accuracy': 0.5058699999999999}, {'accuracy': 0.5052099999999999}, {'accuracy': 0.49718999999999997}, {'accuracy': 0.47988}, {'accuracy': 0.48335}, {'accuracy': 0.48312999999999995}, {'accuracy': 0.47135}, {'accuracy': 0.47998}, {'accuracy': 0.4887200000000001}, {'accuracy': 0.49524}, {'accuracy': 0.4938600000000001}, {'accuracy': 0.48577999999999993}, {'accuracy': 0.48807999999999996}, {'accuracy': 0.4980399999999999}, {'accuracy': 0.5020100000000001}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "242193f5-6fc9-461f-95f5-e2901e278590",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "240ba157-77dd-47ba-8e79-4a6f5172c73f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c0c887e4-ddae-413a-865a-cf067f8fd7b3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5f5f27e4-5bc6-4b9c-aae1-f9733aa11589",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dade01f3-e4c9-46eb-bcca-3cd0e055cc20",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5bd95d88-5e25-4347-a4e4-e158d1f45599",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a3587fd-7bfa-44f2-8954-f8ff94233c05",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f1c9de94-0207-4d38-be21-be5f2f1556c8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dbf24558-92fb-4091-beff-8f21868b3b8e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1b563a18-b833-4fcb-8dc0-629fd6a21087",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bd3bd2f2-9e33-4a97-8b2f-27e68496be4a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8f8a0be9-7afd-4692-b4cc-873bba93e8a9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be3447c6-7910-49bf-b187-3f7907d1cddb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fde2ad41-7102-4f44-aa1c-4b6dabd3dfb2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a051f4e3-e14c-4092-8300-fe89fc4ba49c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "18695822-3fd4-49fb-b75d-33b9ac65e4cb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d2aa3d5-95a4-4585-9076-79d0d03fe113",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed3c9f73-5701-46b0-bd84-026cd60f6d2c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "efee0526-319c-4cd9-b7a5-bbf3ea389f2f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b1ce10e8-fb04-4bb7-b7a9-8e5dad763013",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eaa452c6-4433-4b7a-bd77-e6dba9dab519",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "681ca48f-e1d1-4645-bf83-20025a9d102f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5ef4dba1-5984-472b-b805-aed3b188e400",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d2e459a3-98d2-4ee0-bbb7-7fcff0cb8e99",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a825395a-2b03-481a-8920-ab9eb086fae7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "abb9195f-8552-43b0-b87c-4274fa338770",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a2e012d6-992d-49e2-800c-5cd13689b314",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "105d55c8-cd7d-4d80-b36c-73309605dc53",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bba72b77-c8e9-4ef6-a44b-37c07d435ac8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "266c4da6-2e6d-40cf-baad-aeb06ff234ea",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f008598a-8084-4c6d-854b-42feca2b5ce8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4a09d07f-be76-4246-891c-a807e1e89881",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0d3cd859-0991-4910-8914-2c445b91c3be",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "90dba923-f841-4975-a6c7-325dea4eb578",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "db16e0ad-eb2b-4dd5-ab8a-f47f042ee3aa",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "39214de0-6e26-4e0b-9ff8-5a6eb3362172",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
