{
 "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, 100)\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 1989]\n",
      " [   1   44]\n",
      " [   2   39]\n",
      " [   3   54]\n",
      " [   4   85]\n",
      " [   5  159]\n",
      " [   6  275]\n",
      " [   7  436]\n",
      " [   8  726]\n",
      " [   9 1198]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "6aa23b81-43cd-40f2-8ae4-3c9ca5b8e5e1",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 1228]\n",
      " [   1 2001]\n",
      " [   2   44]\n",
      " [   3   40]\n",
      " [   4   60]\n",
      " [   5   95]\n",
      " [   6  159]\n",
      " [   7  276]\n",
      " [   8  417]\n",
      " [   9  722]]\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  742]\n",
      " [   1 1224]\n",
      " [   2 1973]\n",
      " [   3   43]\n",
      " [   4   34]\n",
      " [   5   51]\n",
      " [   6   78]\n",
      " [   7  167]\n",
      " [   8  273]\n",
      " [   9  420]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "d092746c-0931-48c5-ab0e-66e4cde5adef",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0  427]\n",
      " [   1  728]\n",
      " [   2 1173]\n",
      " [   3 2027]\n",
      " [   4   53]\n",
      " [   5   33]\n",
      " [   6   68]\n",
      " [   7  101]\n",
      " [   8  167]\n",
      " [   9  271]]\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  231]\n",
      " [   1  385]\n",
      " [   2  733]\n",
      " [   3 1160]\n",
      " [   4 2042]\n",
      " [   5   43]\n",
      " [   6   36]\n",
      " [   7   60]\n",
      " [   8   84]\n",
      " [   9  139]]\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  153]\n",
      " [   1  265]\n",
      " [   2  467]\n",
      " [   3  727]\n",
      " [   4 1183]\n",
      " [   5 2061]\n",
      " [   6   65]\n",
      " [   7   40]\n",
      " [   8   44]\n",
      " [   9   90]]\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  161]\n",
      " [   2  250]\n",
      " [   3  410]\n",
      " [   4  694]\n",
      " [   5 1200]\n",
      " [   6 1911]\n",
      " [   7   53]\n",
      " [   8   29]\n",
      " [   9   56]]\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   51]\n",
      " [   1   91]\n",
      " [   2  154]\n",
      " [   3  280]\n",
      " [   4  443]\n",
      " [   5  683]\n",
      " [   6 1184]\n",
      " [   7 1979]\n",
      " [   8   42]\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   32]\n",
      " [   1   63]\n",
      " [   2  104]\n",
      " [   3  172]\n",
      " [   4  259]\n",
      " [   5  412]\n",
      " [   6  741]\n",
      " [   7 1174]\n",
      " [   8 1986]\n",
      " [   9   50]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list8[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "ef796dae-f8f7-4f29-b9f2-80960e55027b",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   52]\n",
      " [   1   38]\n",
      " [   2   63]\n",
      " [   3   87]\n",
      " [   4  147]\n",
      " [   5  263]\n",
      " [   6  483]\n",
      " [   7  714]\n",
      " [   8 1232]\n",
      " [   9 2018]]\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": [
      "15038\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 1390]\n",
      " [   1   35]\n",
      " [   2   26]\n",
      " [   3   41]\n",
      " [   4   56]\n",
      " [   5  122]\n",
      " [   6  195]\n",
      " [   7  307]\n",
      " [   8  516]\n",
      " [   9  809]]\n",
      "[[   0 2004]\n",
      " [   1   55]\n",
      " [   2   36]\n",
      " [   3   55]\n",
      " [   4   80]\n",
      " [   5  167]\n",
      " [   6  270]\n",
      " [   7  424]\n",
      " [   8  718]\n",
      " [   9 1170]]\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",
    "        noiseyset[0].append(dataset1[z])\n",
    "        healthset[0].append(dataset1[z])\n",
    "        healthset[1].append(target1[z])\n",
    "        healthset[2].append(z)\n",
    "        noiseyset[1].append(((target1[z] - 1) % 10))\n",
    "    \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "121424c8-abe9-478d-8afb-75f18c86f0e4",
   "metadata": {},
   "outputs": [],
   "source": [
    "Xtr, ytr = (transform(tran1), tag1)\n",
    "Xte, yte = (transform(test_set[0]), test_set[1])\n",
    "\n",
    "data_handler = ClassificationDataHandler(Xtr, ytr,\n",
    "                                         Xte, yte)\n",
    "\n",
    "\n",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CIFAR10Net(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.001,\n",
    "            \"momentum\": 0.9,\n",
    "            \"weight_decay\": 5e-4\n",
    "        },\n",
    "        \n",
    "        criterion = F.cross_entropy,\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 32,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1.0\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=42)\n",
    "simulator.start(n_rounds=400)\n",
    "\n",
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.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.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10137}, {'accuracy': 0.10137}, {'accuracy': 0.1}, {'accuracy': 0.1}, {'accuracy': 0.10312000000000002}, {'accuracy': 0.10338}, {'accuracy': 0.10338}, {'accuracy': 0.1}, {'accuracy': 0.10390000000000002}, {'accuracy': 0.10987}, {'accuracy': 0.10662}, {'accuracy': 0.10943}, {'accuracy': 0.11376000000000001}, {'accuracy': 0.11348}, {'accuracy': 0.11396999999999999}, {'accuracy': 0.1}, {'accuracy': 0.10810000000000002}, {'accuracy': 0.10831000000000002}, {'accuracy': 0.11508}, {'accuracy': 0.10912999999999999}, {'accuracy': 0.10828}, {'accuracy': 0.10632}, {'accuracy': 0.11191000000000002}, {'accuracy': 0.10806}, {'accuracy': 0.11476000000000001}, {'accuracy': 0.10743}, {'accuracy': 0.10869}, {'accuracy': 0.1136}, {'accuracy': 0.11803000000000001}, {'accuracy': 0.12005000000000002}, {'accuracy': 0.12448000000000001}, {'accuracy': 0.12961999999999999}, {'accuracy': 0.12537}, {'accuracy': 0.12168000000000001}, {'accuracy': 0.13103}, {'accuracy': 0.13894}, {'accuracy': 0.1463}, {'accuracy': 0.15692}, {'accuracy': 0.14725000000000002}, {'accuracy': 0.1461}, {'accuracy': 0.13516}, {'accuracy': 0.13708}, {'accuracy': 0.15273}, {'accuracy': 0.15454}, {'accuracy': 0.14345000000000002}, {'accuracy': 0.13937999999999998}, {'accuracy': 0.14160999999999999}, {'accuracy': 0.16043000000000002}, {'accuracy': 0.15567999999999999}, {'accuracy': 0.14425}, {'accuracy': 0.15297000000000002}, {'accuracy': 0.15209999999999999}, {'accuracy': 0.16732}, {'accuracy': 0.16117999999999996}, {'accuracy': 0.13756000000000002}, {'accuracy': 0.14018000000000003}, {'accuracy': 0.14048000000000002}, {'accuracy': 0.14109}, {'accuracy': 0.14944}, {'accuracy': 0.14692000000000002}, {'accuracy': 0.16512999999999997}, {'accuracy': 0.16670000000000001}, {'accuracy': 0.16999000000000003}, {'accuracy': 0.16284}, {'accuracy': 0.15266}, {'accuracy': 0.15277}, {'accuracy': 0.15138000000000001}, {'accuracy': 0.15875}, {'accuracy': 0.15610000000000002}, {'accuracy': 0.15569000000000002}, {'accuracy': 0.17077000000000003}, {'accuracy': 0.14672999999999997}, {'accuracy': 0.17404999999999998}, {'accuracy': 0.17775000000000002}, {'accuracy': 0.19064}, {'accuracy': 0.17781}, {'accuracy': 0.17558}, {'accuracy': 0.18062}, {'accuracy': 0.18767}, {'accuracy': 0.18622}, {'accuracy': 0.18934}, {'accuracy': 0.16811000000000004}, {'accuracy': 0.16871}, {'accuracy': 0.19085}, {'accuracy': 0.19473999999999997}, {'accuracy': 0.19604}, {'accuracy': 0.19366}, {'accuracy': 0.19122}, {'accuracy': 0.17561000000000002}, {'accuracy': 0.18675999999999998}, {'accuracy': 0.1724}, {'accuracy': 0.19754}, {'accuracy': 0.19590999999999997}, {'accuracy': 0.19054999999999997}, {'accuracy': 0.19864999999999997}, {'accuracy': 0.19929999999999998}, {'accuracy': 0.20609000000000002}, {'accuracy': 0.19704}, {'accuracy': 0.21100000000000002}, {'accuracy': 0.20318}, {'accuracy': 0.18585999999999997}, {'accuracy': 0.20553999999999997}, {'accuracy': 0.21422000000000002}, {'accuracy': 0.2043}, {'accuracy': 0.20825999999999997}, {'accuracy': 0.22017000000000003}, {'accuracy': 0.20692}, {'accuracy': 0.19661}, {'accuracy': 0.20929999999999999}, {'accuracy': 0.20048999999999997}, {'accuracy': 0.21613}, {'accuracy': 0.19895000000000002}, {'accuracy': 0.2142}, {'accuracy': 0.20741}, {'accuracy': 0.20234000000000002}, {'accuracy': 0.19488999999999998}, {'accuracy': 0.20471000000000003}, {'accuracy': 0.20867}, {'accuracy': 0.20043000000000002}, {'accuracy': 0.20423}, {'accuracy': 0.1984}, {'accuracy': 0.19797000000000003}, {'accuracy': 0.20137}, {'accuracy': 0.2085}, {'accuracy': 0.20635999999999996}, {'accuracy': 0.21348000000000003}, {'accuracy': 0.21659}, {'accuracy': 0.21452}, {'accuracy': 0.20667999999999997}, {'accuracy': 0.21604}, {'accuracy': 0.21515999999999996}, {'accuracy': 0.21549000000000001}, {'accuracy': 0.21254}, {'accuracy': 0.21614}, {'accuracy': 0.20023}, {'accuracy': 0.20604}, {'accuracy': 0.20741}, {'accuracy': 0.21425}, {'accuracy': 0.21431}, {'accuracy': 0.20781}, {'accuracy': 0.21369}, {'accuracy': 0.22613}, {'accuracy': 0.21993000000000001}, {'accuracy': 0.21657}, {'accuracy': 0.21610999999999997}, {'accuracy': 0.22346999999999997}, {'accuracy': 0.22763000000000005}, {'accuracy': 0.21564999999999998}, {'accuracy': 0.19463000000000003}, {'accuracy': 0.20648999999999998}, {'accuracy': 0.20512000000000002}, {'accuracy': 0.21977000000000002}, {'accuracy': 0.21575000000000003}, {'accuracy': 0.20971}, {'accuracy': 0.21084999999999998}, {'accuracy': 0.22224}, {'accuracy': 0.21875}, {'accuracy': 0.21466}, {'accuracy': 0.22235999999999997}, {'accuracy': 0.22626999999999997}, {'accuracy': 0.21227999999999997}, {'accuracy': 0.23052}, {'accuracy': 0.21756999999999999}, {'accuracy': 0.22535}, {'accuracy': 0.22658999999999999}, {'accuracy': 0.24045999999999998}, {'accuracy': 0.21823}, {'accuracy': 0.34688}, {'accuracy': 0.35292}, {'accuracy': 0.36217}, {'accuracy': 0.36574}, {'accuracy': 0.36434}, {'accuracy': 0.36473}, {'accuracy': 0.35517}, {'accuracy': 0.35019}, {'accuracy': 0.35347999999999996}, {'accuracy': 0.34595000000000004}, {'accuracy': 0.3444}, {'accuracy': 0.34304000000000007}, {'accuracy': 0.34761}, {'accuracy': 0.34781}, {'accuracy': 0.34950000000000003}, {'accuracy': 0.35018000000000005}, {'accuracy': 0.34741}, {'accuracy': 0.3504}, {'accuracy': 0.35057}, {'accuracy': 0.34821}, {'accuracy': 0.34678}, {'accuracy': 0.34679}, {'accuracy': 0.34995000000000004}, {'accuracy': 0.35141999999999995}, {'accuracy': 0.34308}, {'accuracy': 0.34706000000000004}, {'accuracy': 0.34243999999999997}, {'accuracy': 0.34624999999999995}, {'accuracy': 0.34689000000000003}, {'accuracy': 0.34109}, {'accuracy': 0.3456}, {'accuracy': 0.34895000000000004}, {'accuracy': 0.34661999999999993}, {'accuracy': 0.34869}, {'accuracy': 0.34958999999999996}, {'accuracy': 0.34850000000000003}, {'accuracy': 0.34512}, {'accuracy': 0.34645000000000004}, {'accuracy': 0.33865}, {'accuracy': 0.34794}, {'accuracy': 0.34725}, {'accuracy': 0.35048}, {'accuracy': 0.34564}, {'accuracy': 0.35642000000000007}, {'accuracy': 0.35359999999999997}, {'accuracy': 0.34236999999999995}, {'accuracy': 0.35014}, {'accuracy': 0.34597}, {'accuracy': 0.34924000000000005}, {'accuracy': 0.35574000000000006}, {'accuracy': 0.35089000000000004}, {'accuracy': 0.3504}, {'accuracy': 0.34745000000000004}, {'accuracy': 0.34853999999999996}, {'accuracy': 0.34671}, {'accuracy': 0.34809}, {'accuracy': 0.35004}, {'accuracy': 0.3497100000000001}, {'accuracy': 0.35196000000000005}, {'accuracy': 0.3538899999999999}, {'accuracy': 0.35329}, {'accuracy': 0.36166}, {'accuracy': 0.34738}, {'accuracy': 0.35214}, {'accuracy': 0.3557}, {'accuracy': 0.35106000000000004}, {'accuracy': 0.34877}, {'accuracy': 0.34894000000000003}, {'accuracy': 0.34964000000000006}, {'accuracy': 0.35805}, {'accuracy': 0.35433}, {'accuracy': 0.3515}, {'accuracy': 0.35561000000000004}, {'accuracy': 0.35494}, {'accuracy': 0.35381}, {'accuracy': 0.35034}, {'accuracy': 0.35335}, {'accuracy': 0.35538}, {'accuracy': 0.35017}, {'accuracy': 0.35507}, {'accuracy': 0.35754}, {'accuracy': 0.35408}, {'accuracy': 0.35303000000000007}, {'accuracy': 0.35164}, {'accuracy': 0.3442}, {'accuracy': 0.34825}, {'accuracy': 0.35602}, {'accuracy': 0.35174000000000005}, {'accuracy': 0.35347999999999996}, {'accuracy': 0.35664999999999997}, {'accuracy': 0.35053999999999996}, {'accuracy': 0.35492}, {'accuracy': 0.35692999999999997}, {'accuracy': 0.35569999999999996}, {'accuracy': 0.35781999999999997}, {'accuracy': 0.35414999999999996}, {'accuracy': 0.35667000000000004}, {'accuracy': 0.35903999999999997}, {'accuracy': 0.35792}, {'accuracy': 0.35319999999999996}, {'accuracy': 0.35416000000000003}, {'accuracy': 0.35645000000000004}, {'accuracy': 0.35273000000000004}, {'accuracy': 0.35916}, {'accuracy': 0.35486}, {'accuracy': 0.3472799999999999}, {'accuracy': 0.34967999999999994}, {'accuracy': 0.35966}, {'accuracy': 0.36072000000000004}, {'accuracy': 0.35740000000000005}, {'accuracy': 0.35082}, {'accuracy': 0.35520000000000007}, {'accuracy': 0.35699}, {'accuracy': 0.35768999999999995}, {'accuracy': 0.3538200000000001}, {'accuracy': 0.35941}, {'accuracy': 0.35895}, {'accuracy': 0.35902}, {'accuracy': 0.35411000000000004}, {'accuracy': 0.35541000000000006}, {'accuracy': 0.36169}, {'accuracy': 0.35475}, {'accuracy': 0.35736}, {'accuracy': 0.35888}, {'accuracy': 0.358}, {'accuracy': 0.35404}, {'accuracy': 0.35411}, {'accuracy': 0.35912}, {'accuracy': 0.35516999999999993}, {'accuracy': 0.35736}, {'accuracy': 0.35855}, {'accuracy': 0.35767000000000004}, {'accuracy': 0.35245999999999994}, {'accuracy': 0.3554}, {'accuracy': 0.3565}, {'accuracy': 0.3569699999999999}, {'accuracy': 0.35736}, {'accuracy': 0.36123999999999995}, {'accuracy': 0.35816000000000003}, {'accuracy': 0.35553}, {'accuracy': 0.36231}, {'accuracy': 0.35905}, {'accuracy': 0.35950000000000004}, {'accuracy': 0.35829}, {'accuracy': 0.36261}, {'accuracy': 0.35744999999999993}, {'accuracy': 0.36086}, {'accuracy': 0.3543}, {'accuracy': 0.35312}, {'accuracy': 0.35665}, {'accuracy': 0.35794}, {'accuracy': 0.35489}, {'accuracy': 0.35753}, {'accuracy': 0.36438000000000004}, {'accuracy': 0.36044}, {'accuracy': 0.35655000000000003}, {'accuracy': 0.34907}, {'accuracy': 0.36075}, {'accuracy': 0.35769}, {'accuracy': 0.35892999999999997}, {'accuracy': 0.36031}, {'accuracy': 0.35942}, {'accuracy': 0.35757999999999995}, {'accuracy': 0.35573999999999995}, {'accuracy': 0.35573999999999995}, {'accuracy': 0.35879000000000005}, {'accuracy': 0.35864}, {'accuracy': 0.35930000000000006}, {'accuracy': 0.36753}, {'accuracy': 0.36183999999999994}, {'accuracy': 0.35797}, {'accuracy': 0.36134}, {'accuracy': 0.3563799999999999}, {'accuracy': 0.3599}, {'accuracy': 0.35522000000000004}, {'accuracy': 0.35748}, {'accuracy': 0.35952}, {'accuracy': 0.35464999999999997}, {'accuracy': 0.3535}, {'accuracy': 0.35456000000000004}, {'accuracy': 0.35412999999999994}, {'accuracy': 0.36074999999999996}, {'accuracy': 0.36008999999999997}, {'accuracy': 0.36433}, {'accuracy': 0.35904}, {'accuracy': 0.36305}, {'accuracy': 0.36082000000000003}, {'accuracy': 0.36092}, {'accuracy': 0.36113}, {'accuracy': 0.35520999999999997}, {'accuracy': 0.35602}, {'accuracy': 0.3604200000000001}, {'accuracy': 0.36026}, {'accuracy': 0.35928}, {'accuracy': 0.36042}, {'accuracy': 0.36308}, {'accuracy': 0.35839999999999994}, {'accuracy': 0.36395}, {'accuracy': 0.36559}, {'accuracy': 0.3569}]\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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8dBDDyE0NBQpKSn4v//7P+Tm5uK7774Tpzjr2Nvb484778SGDRtQVlaGd955x+Tan3zyCYYPH47IyEg88sgjCAsLQ1ZWFhITE3H16lUcO3as0fbdcsst+Oqrr+Dm5oZevXohMTERf//9Nzp16mSxv4MBAwZg5cqVeP311xEREQEfHx+MHj0azz33HH777TfccsstmDlzJgYMGICysjKcOHECmzZtQkpKCry8vPDwww8jPz8fo0ePRufOnXH58mV89NFHiI6OFqe6R0dHQyaT4a233kJRUREUCgVGjx4NHx+fZrV15MiReOyxx7B06VIcPXoU48aNg729PZKSkvDDDz/ggw8+wN13343169fj008/xR133IHw8HCUlJRg9erVcHV1xc033wxAMwQ6efJkfPTRR5BIJAgPD8f//vc/k9qshv7e/v77b7z33nsICAhAaGgounfvjs6dO+Puu+9G37594ezsjL///hsHDhww6MUj6hCsOwmNiCzh+PHjwtSpUwV/f3/B3t5e8PPzE6ZOnSqcOHGi3tds27ZNACBIJBLhypUrZs+5ePGiMH36dMHPz0+wt7cXAgMDhVtuuUXYtGmTeI5uGry5KdsFBQXCrFmzBC8vL8HZ2VmIi4sTzp49K3Tp0sVgCva1TIPPzMwUJk6cKLi4uAgADKbEl5SUCAsWLBAiIiIEuVwueHl5CUOHDhXeeecdobq6WhAEQdi0aZMwbtw4wcfHR5DL5UJwcLDw2GOPCRkZGQbvs3r1aiEsLEyQyWSNTomfMWOG4OTkVO/xzz//XBgwYIDg4OAguLi4CJGRkcLzzz8vpKenC4IgCIcPHxamTp0qBAcHCwqFQvDx8RFuueUW4eDBgwbXycnJEe666y7B0dFR8PDwEB577DHh5MmTTZoGf/bsWeHGG28UHBwcBADCjBkzhKqqKuG5554T+vbtK7i4uAhOTk5C3759hU8//bShj4CoXZIIglE/KxEREVEHxxogIiIisjkMQERERGRzGICIiIjI5jAAERERkc1hACIiIiKbwwBERERENocLIZqhVquRnp4OFxcXiy2BT0RERK1LEASUlJQgICDAZC8+YwxAZqSnpyMoKMjazSAiIqIWuHLlCjp37tzgOQxAZri4uADQ/AXqdtAmIiKitq24uBhBQUHiz/GGMACZoRv2cnV1ZQAiIiJqZ5pSvsIi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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": "1caa8c4f-09bb-4bc0-bd53-95772cfc3230",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5add4c6d-2eeb-4555-94be-24c74b9c412a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "335bb580-7bce-4099-8a4b-ab6a292d1a52",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "30fa3014-445f-41a8-bd13-e8fbf50ef621",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "039cb0a7-a8c4-4b79-b75d-3eb30a807e90",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "745188d5-2db5-42af-8fb1-a7b1ddd28412",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c5e232a2-bfda-4834-9d08-1912e4086d4f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d7dd900c-1b41-4efb-97d2-15865278b9c0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ee7e1e4d-bbf1-49d2-b0cd-1c141f9a331f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "61c7eb09-3d0c-4afd-b017-bd1f9e3e9ff4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e93527d5-be83-4103-9ab9-add5a27264b1",
   "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
}
