{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n",
      "tensor([6, 9, 9,  ..., 9, 1, 1])\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torchvision.transforms import Compose, Normalize, RandomVerticalFlip\n",
    "from gossipy_original.core import AntiEntropyProtocol, CreateModelMode, StaticP2PNetwork\n",
    "from gossipy_original.data import DataDispatcher\n",
    "\n",
    "from gossipy_original.model import TorchModel\n",
    "from gossipy_original.data.handler import ClassificationDataHandler\n",
    "from gossipy_original.model.handler import TorchModelHandler\n",
    "from gossipy_original.node import PENSNode\n",
    "from gossipy_original.simul import GossipSimulator, SimulationReport\n",
    "from gossipy_original.data import get_CIFAR10, get_CIFAR100\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "\n",
    "class CIFAR10Net(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(3, 64,kernel_size=3, stride=2, padding=1)\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(64, 192, 3, padding=1)\n",
    "        self.conv3 = nn.Conv2d(192, 384, 3, padding=1)\n",
    "        self.conv4 = nn.Conv2d(384, 256, 3, padding=1)\n",
    "        self.conv5 = nn.Conv2d(256, 256, 3, padding=1)\n",
    "        self.fc1 = nn.Linear(256 * 2 * 2, 4096)\n",
    "        self.fc2 = nn.Linear(4096, 4096)\n",
    "        self.fc3 = nn.Linear(4096, 10)\n",
    "    \n",
    "    def init_weights(self, *args, **kwargs) -> None:\n",
    "        # def _init_weights(m: nn.Module):\n",
    "        #     if isinstance(m, nn.Linear) or isinstance(m, nn.Conv2d):\n",
    "        #         nn.init.xavier_uniform_(m.weight)\n",
    "        #         nn.init.zeros_(m.bias)\n",
    "        #self.apply(_init_weights)\n",
    "        pass\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.pool(F.relu(self.conv1(x)))\n",
    "        x = self.pool(F.relu(self.conv2(x)))\n",
    "        x = F.relu(self.conv3(x))\n",
    "        x = F.relu(self.conv4(x))\n",
    "        x = self.pool(F.relu(self.conv5(x)))\n",
    "        # print(x.shape)\n",
    "        x = x.view(-1, 256 * 2 * 2)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.relu(self.fc2(x))\n",
    "        x = self.fc3(x)\n",
    "        return x\n",
    "    \n",
    "    def __repr__(self) -> str:\n",
    "        return \"CIFAR10Net(size=%d)\" %self.get_size()\n",
    "    \n",
    "    \n",
    "    \n",
    "class CustomDataDispatcher(DataDispatcher):\n",
    "    def assign(self, seed: int = 42) -> None:\n",
    "        self.tr_assignments = [[] for _ in range(self.n)]\n",
    "        self.te_assignments = [[] for _ in range(self.n)]\n",
    "\n",
    "        n_ex = self.data_handler.size()\n",
    "        ex_x_user = math.ceil(n_ex / self.n)\n",
    "\n",
    "        for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "            self.tr_assignments[idx] = list(range(i, min(i + ex_x_user, n_ex)))\n",
    "\n",
    "        if self.eval_on_user:\n",
    "            n_eval_ex = self.data_handler.eval_size()\n",
    "            eval_ex_x_user = math.ceil(n_eval_ex / self.n)\n",
    "            for idx, i in enumerate(range(0, n_eval_ex, eval_ex_x_user)):\n",
    "                self.te_assignments[idx] = list(range(i, min(i + eval_ex_x_user, n_eval_ex)))\n",
    "\n",
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_CIFAR10()\n",
    "\n",
    "\n",
    "print(train_set[1])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([50000])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([1, 1, 1,  ..., 1, 1, 1])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tran1=torch.zeros([50000,3,32,32], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([50000], dtype=torch.int64)\n",
    "\n",
    "print(tag1.shape)\n",
    "\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "\n",
    "for z in range(0,50000,1):\n",
    "    if train_set[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif train_set[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif train_set[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif train_set[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif train_set[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif train_set[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif train_set[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif train_set[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif train_set[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif train_set[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "train_set[1][label[1]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "dbc3456b-d386-41c9-9465-55f89e6b2d2b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(train_set[0][label[0][z]])\n",
    "        list0[1].append(train_set[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(train_set[0][label[0][z]])\n",
    "        list1[1].append(train_set[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(train_set[0][label[0][z]])\n",
    "        list2[1].append(train_set[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(train_set[0][label[0][z]])\n",
    "        list3[1].append(train_set[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(train_set[0][label[0][z]])\n",
    "        list4[1].append(train_set[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(train_set[0][label[0][z]])\n",
    "        list5[1].append(train_set[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(train_set[0][label[0][z]])\n",
    "        list6[1].append(train_set[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(train_set[0][label[0][z]])\n",
    "        list7[1].append(train_set[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(train_set[0][label[0][z]])\n",
    "        list8[1].append(train_set[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(train_set[0][label[0][z]])\n",
    "        list9[1].append(train_set[1][label[0][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "473ea3ac-f6a7-424a-aca0-e50a6df03355",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "eb808629-58e7-4eb6-8c15-479cc02d237a",
   "metadata": {},
   "outputs": [],
   "source": [
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(train_set[0][label[1][z]])\n",
    "        list1[1].append(train_set[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(train_set[0][label[1][z]])\n",
    "        list2[1].append(train_set[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(train_set[0][label[1][z]])\n",
    "        list3[1].append(train_set[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(train_set[0][label[1][z]])\n",
    "        list4[1].append(train_set[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(train_set[0][label[1][z]])\n",
    "        list5[1].append(train_set[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(train_set[0][label[1][z]])\n",
    "        list6[1].append(train_set[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(train_set[0][label[1][z]])\n",
    "        list7[1].append(train_set[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(train_set[0][label[1][z]])\n",
    "        list8[1].append(train_set[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(train_set[0][label[1][z]])\n",
    "        list9[1].append(train_set[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(train_set[0][label[1][z]])\n",
    "        list0[1].append(train_set[1][label[1][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a3aa2fcc-c4f4-408d-9423-86ea099f696b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "0b70f77d-f544-49f6-93a3-e3e974ce9287",
   "metadata": {},
   "outputs": [],
   "source": [
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(train_set[0][label[2][z]])\n",
    "        list2[1].append(train_set[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(train_set[0][label[2][z]])\n",
    "        list3[1].append(train_set[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(train_set[0][label[2][z]])\n",
    "        list4[1].append(train_set[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(train_set[0][label[2][z]])\n",
    "        list5[1].append(train_set[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(train_set[0][label[2][z]])\n",
    "        list6[1].append(train_set[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(train_set[0][label[2][z]])\n",
    "        list7[1].append(train_set[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(train_set[0][label[2][z]])\n",
    "        list8[1].append(train_set[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(train_set[0][label[2][z]])\n",
    "        list9[1].append(train_set[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(train_set[0][label[2][z]])\n",
    "        list0[1].append(train_set[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(train_set[0][label[2][z]])\n",
    "        list1[1].append(train_set[1][label[2][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bf1e1d02-0668-4c7b-8079-b7b3fadca6f8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "c83b07a5-13f4-46b9-8e6d-ec57a8794c57",
   "metadata": {},
   "outputs": [],
   "source": [
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(train_set[0][label[3][z]])\n",
    "        list3[1].append(train_set[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(train_set[0][label[3][z]])\n",
    "        list4[1].append(train_set[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(train_set[0][label[3][z]])\n",
    "        list5[1].append(train_set[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(train_set[0][label[3][z]])\n",
    "        list6[1].append(train_set[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(train_set[0][label[3][z]])\n",
    "        list7[1].append(train_set[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(train_set[0][label[3][z]])\n",
    "        list8[1].append(train_set[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(train_set[0][label[3][z]])\n",
    "        list9[1].append(train_set[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(train_set[0][label[3][z]])\n",
    "        list0[1].append(train_set[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(train_set[0][label[3][z]])\n",
    "        list1[1].append(train_set[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(train_set[0][label[3][z]])\n",
    "        list2[1].append(train_set[1][label[3][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0ad1327c-00bb-4f50-ac57-be4195b91337",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "b60e76e6-ccff-4323-8a51-ec20b80e923f",
   "metadata": {},
   "outputs": [],
   "source": [
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(train_set[0][label[4][z]])\n",
    "        list4[1].append(train_set[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(train_set[0][label[4][z]])\n",
    "        list5[1].append(train_set[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(train_set[0][label[4][z]])\n",
    "        list6[1].append(train_set[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(train_set[0][label[4][z]])\n",
    "        list7[1].append(train_set[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(train_set[0][label[4][z]])\n",
    "        list8[1].append(train_set[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(train_set[0][label[4][z]])\n",
    "        list9[1].append(train_set[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(train_set[0][label[4][z]])\n",
    "        list0[1].append(train_set[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(train_set[0][label[4][z]])\n",
    "        list1[1].append(train_set[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(train_set[0][label[4][z]])\n",
    "        list2[1].append(train_set[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(train_set[0][label[4][z]])\n",
    "        list3[1].append(train_set[1][label[4][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6dec69bb-536c-4fdc-81bf-c215a286f04a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "925dbdcc-21e0-4f8f-8b75-94963a36f38a",
   "metadata": {},
   "outputs": [],
   "source": [
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(train_set[0][label[5][z]])\n",
    "        list5[1].append(train_set[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(train_set[0][label[5][z]])\n",
    "        list6[1].append(train_set[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(train_set[0][label[5][z]])\n",
    "        list7[1].append(train_set[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(train_set[0][label[5][z]])\n",
    "        list8[1].append(train_set[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(train_set[0][label[5][z]])\n",
    "        list9[1].append(train_set[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(train_set[0][label[5][z]])\n",
    "        list0[1].append(train_set[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(train_set[0][label[5][z]])\n",
    "        list1[1].append(train_set[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(train_set[0][label[5][z]])\n",
    "        list2[1].append(train_set[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(train_set[0][label[5][z]])\n",
    "        list3[1].append(train_set[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(train_set[0][label[5][z]])\n",
    "        list4[1].append(train_set[1][label[5][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3024807a-0e1b-4cda-98fe-a49be1cde0f2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "bbe2a38a-0099-407d-a188-e06ff7ab899d",
   "metadata": {},
   "outputs": [],
   "source": [
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(train_set[0][label[6][z]])\n",
    "        list6[1].append(train_set[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(train_set[0][label[6][z]])\n",
    "        list7[1].append(train_set[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(train_set[0][label[6][z]])\n",
    "        list8[1].append(train_set[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(train_set[0][label[6][z]])\n",
    "        list9[1].append(train_set[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(train_set[0][label[6][z]])\n",
    "        list0[1].append(train_set[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(train_set[0][label[6][z]])\n",
    "        list1[1].append(train_set[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(train_set[0][label[6][z]])\n",
    "        list2[1].append(train_set[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(train_set[0][label[6][z]])\n",
    "        list3[1].append(train_set[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(train_set[0][label[6][z]])\n",
    "        list4[1].append(train_set[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(train_set[0][label[6][z]])\n",
    "        list5[1].append(train_set[1][label[6][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4bc595ee-f8eb-41bf-9dc4-2d32a615b873",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "53de6bac-141a-45b9-8910-3eace920f86b",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(train_set[0][label[7][z]])\n",
    "        list7[1].append(train_set[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(train_set[0][label[7][z]])\n",
    "        list8[1].append(train_set[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(train_set[0][label[7][z]])\n",
    "        list9[1].append(train_set[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(train_set[0][label[7][z]])\n",
    "        list0[1].append(train_set[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(train_set[0][label[7][z]])\n",
    "        list1[1].append(train_set[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(train_set[0][label[7][z]])\n",
    "        list2[1].append(train_set[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(train_set[0][label[7][z]])\n",
    "        list3[1].append(train_set[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(train_set[0][label[7][z]])\n",
    "        list4[1].append(train_set[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(train_set[0][label[7][z]])\n",
    "        list5[1].append(train_set[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(train_set[0][label[7][z]])\n",
    "        list6[1].append(train_set[1][label[7][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0c65c26a-fa65-4399-ae11-78144d521edb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "a0044dab-8c89-4e12-b010-a632ef8426eb",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(train_set[0][label[8][z]])\n",
    "        list8[1].append(train_set[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(train_set[0][label[8][z]])\n",
    "        list9[1].append(train_set[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(train_set[0][label[8][z]])\n",
    "        list0[1].append(train_set[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(train_set[0][label[8][z]])\n",
    "        list1[1].append(train_set[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(train_set[0][label[8][z]])\n",
    "        list2[1].append(train_set[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(train_set[0][label[8][z]])\n",
    "        list3[1].append(train_set[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(train_set[0][label[8][z]])\n",
    "        list4[1].append(train_set[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(train_set[0][label[8][z]])\n",
    "        list5[1].append(train_set[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(train_set[0][label[8][z]])\n",
    "        list6[1].append(train_set[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(train_set[0][label[8][z]])\n",
    "        list7[1].append(train_set[1][label[8][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "acb72266-deb0-41bf-9f24-0e1e15285391",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "cd18c2ac-1778-46ab-9f17-af3b80856111",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(train_set[0][label[9][z]])\n",
    "        list9[1].append(train_set[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(train_set[0][label[9][z]])\n",
    "        list0[1].append(train_set[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(train_set[0][label[9][z]])\n",
    "        list1[1].append(train_set[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(train_set[0][label[9][z]])\n",
    "        list2[1].append(train_set[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(train_set[0][label[9][z]])\n",
    "        list3[1].append(train_set[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(train_set[0][label[9][z]])\n",
    "        list4[1].append(train_set[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(train_set[0][label[9][z]])\n",
    "        list5[1].append(train_set[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(train_set[0][label[9][z]])\n",
    "        list6[1].append(train_set[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(train_set[0][label[9][z]])\n",
    "        list7[1].append(train_set[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(train_set[0][label[9][z]])\n",
    "        list8[1].append(train_set[1][label[9][z]])  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cc5132f4-f827-473a-9d1f-6aac269955ee",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "1aad24c5-184d-4721-915c-3825cb7dbc47",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0 1999]\n",
      " [   1   58]\n",
      " [   2   28]\n",
      " [   3   62]\n",
      " [   4   79]\n",
      " [   5  130]\n",
      " [   6  261]\n",
      " [   7  453]\n",
      " [   8  767]\n",
      " [   9 1180]]\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 1203]\n",
      " [   1 2043]\n",
      " [   2   36]\n",
      " [   3   29]\n",
      " [   4   50]\n",
      " [   5   88]\n",
      " [   6  172]\n",
      " [   7  248]\n",
      " [   8  417]\n",
      " [   9  732]]\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  687]\n",
      " [   1 1179]\n",
      " [   2 2081]\n",
      " [   3   45]\n",
      " [   4   29]\n",
      " [   5   50]\n",
      " [   6  112]\n",
      " [   7  179]\n",
      " [   8  249]\n",
      " [   9  422]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list2[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "d092746c-0931-48c5-ab0e-66e4cde5adef",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0  428]\n",
      " [   1  717]\n",
      " [   2 1193]\n",
      " [   3 2014]\n",
      " [   4   42]\n",
      " [   5   28]\n",
      " [   6   48]\n",
      " [   7   95]\n",
      " [   8  168]\n",
      " [   9  277]]\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  294]\n",
      " [   1  481]\n",
      " [   2  702]\n",
      " [   3 1203]\n",
      " [   4 2024]\n",
      " [   5   50]\n",
      " [   6   30]\n",
      " [   7   54]\n",
      " [   8   89]\n",
      " [   9  143]]\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  161]\n",
      " [   1  234]\n",
      " [   2  428]\n",
      " [   3  704]\n",
      " [   4 1175]\n",
      " [   5 2015]\n",
      " [   6   48]\n",
      " [   7   36]\n",
      " [   8   67]\n",
      " [   9   96]]\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   89]\n",
      " [   1  126]\n",
      " [   2  243]\n",
      " [   3  429]\n",
      " [   4  723]\n",
      " [   5 1240]\n",
      " [   6 1920]\n",
      " [   7   37]\n",
      " [   8   36]\n",
      " [   9   60]]\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   57]\n",
      " [   1   86]\n",
      " [   2  156]\n",
      " [   3  262]\n",
      " [   4  451]\n",
      " [   5  693]\n",
      " [   6 1238]\n",
      " [   7 1938]\n",
      " [   8   58]\n",
      " [   9   27]]\n"
     ]
    }
   ],
   "source": [
    "unique, counts = np.unique(list7[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "abad36f3-ca9c-4b61-b13c-84d76f89518d",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[   0   27]\n",
      " [   1   49]\n",
      " [   2   79]\n",
      " [   3  149]\n",
      " [   4  256]\n",
      " [   5  431]\n",
      " [   6  745]\n",
      " [   7 1202]\n",
      " [   8 1947]\n",
      " [   9   48]]\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   55]\n",
      " [   1   27]\n",
      " [   2   54]\n",
      " [   3  103]\n",
      " [   4  171]\n",
      " [   5  275]\n",
      " [   6  426]\n",
      " [   7  758]\n",
      " [   8 1202]\n",
      " [   9 2015]]\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": [
      "24676\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[   0 1007]\n",
      " [   1   30]\n",
      " [   2   15]\n",
      " [   3   34]\n",
      " [   4   49]\n",
      " [   5   77]\n",
      " [   6  129]\n",
      " [   7  230]\n",
      " [   8  391]\n",
      " [   9  571]]\n",
      "[[   0 2008]\n",
      " [   1   53]\n",
      " [   2   29]\n",
      " [   3   68]\n",
      " [   4   97]\n",
      " [   5  150]\n",
      " [   6  269]\n",
      " [   7  467]\n",
      " [   8  731]\n",
      " [   9 1177]]\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<5:\n",
    "        noiseyset[0].append(dataset1[z])\n",
    "        healthset[0].append(dataset1[z])\n",
    "        healthset[1].append(target1[z])\n",
    "        healthset[2].append(z)\n",
    "        noiseyset[1].append(((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": "9a8fc374-bf04-4b46-a2ab-105a8ae80815",
   "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.10064999999999999}, {'accuracy': 0.10003999999999999}, {'accuracy': 0.10102}, {'accuracy': 0.10084}, {'accuracy': 0.1036}, {'accuracy': 0.10722000000000001}, {'accuracy': 0.10215}, {'accuracy': 0.10834000000000002}, {'accuracy': 0.10298}, {'accuracy': 0.11292000000000002}, {'accuracy': 0.10529}, {'accuracy': 0.11069000000000002}, {'accuracy': 0.11480000000000001}, {'accuracy': 0.12226000000000004}, {'accuracy': 0.11648}, {'accuracy': 0.11829}, {'accuracy': 0.11833}, {'accuracy': 0.12013000000000003}, {'accuracy': 0.12795}, {'accuracy': 0.10671000000000001}, {'accuracy': 0.12626999999999997}, {'accuracy': 0.11968000000000001}, {'accuracy': 0.12919}, {'accuracy': 0.1312}, {'accuracy': 0.11222000000000001}, {'accuracy': 0.14761}, {'accuracy': 0.13129}, {'accuracy': 0.14726}, {'accuracy': 0.13062}, {'accuracy': 0.12584}, {'accuracy': 0.13794}, {'accuracy': 0.15259999999999999}, {'accuracy': 0.13139}, {'accuracy': 0.12456}, {'accuracy': 0.13637000000000002}, {'accuracy': 0.15399999999999997}, {'accuracy': 0.14833}, {'accuracy': 0.14178}, {'accuracy': 0.13330999999999998}, {'accuracy': 0.1448}, {'accuracy': 0.14881}, {'accuracy': 0.15050999999999998}, {'accuracy': 0.14989}, {'accuracy': 0.13745000000000002}, {'accuracy': 0.13837000000000002}, {'accuracy': 0.14426}, {'accuracy': 0.14243999999999998}, {'accuracy': 0.16603000000000004}, {'accuracy': 0.16458}, {'accuracy': 0.15184}, {'accuracy': 0.15600999999999998}, {'accuracy': 0.14176000000000002}, {'accuracy': 0.13868999999999998}, {'accuracy': 0.15850999999999998}, {'accuracy': 0.15513}, {'accuracy': 0.15475}, {'accuracy': 0.15189000000000002}, {'accuracy': 0.15996000000000002}, {'accuracy': 0.1701}, {'accuracy': 0.15080999999999997}, {'accuracy': 0.15868000000000002}, {'accuracy': 0.15811}, {'accuracy': 0.17203000000000002}, {'accuracy': 0.16427999999999998}, {'accuracy': 0.16959}, {'accuracy': 0.14528000000000002}, {'accuracy': 0.15748}, {'accuracy': 0.16599000000000003}, {'accuracy': 0.17619}, {'accuracy': 0.14555}, {'accuracy': 0.1749}, {'accuracy': 0.15050000000000002}, {'accuracy': 0.15031}, {'accuracy': 0.16909}, {'accuracy': 0.15987}, {'accuracy': 0.15311}, {'accuracy': 0.17241999999999996}, {'accuracy': 0.14778000000000002}, {'accuracy': 0.17443999999999998}, {'accuracy': 0.16462}, {'accuracy': 0.16436}, {'accuracy': 0.16475999999999996}, {'accuracy': 0.16303}, {'accuracy': 0.16333}, {'accuracy': 0.18144}, {'accuracy': 0.17027}, {'accuracy': 0.16731}, {'accuracy': 0.16125000000000003}, {'accuracy': 0.1533}, {'accuracy': 0.16263}, {'accuracy': 0.17096}, {'accuracy': 0.15555999999999998}, {'accuracy': 0.16260999999999998}, {'accuracy': 0.16519}, {'accuracy': 0.16533}, {'accuracy': 0.17298}, {'accuracy': 0.17018999999999998}, {'accuracy': 0.18227}, {'accuracy': 0.16648}, {'accuracy': 0.17806}, {'accuracy': 0.18838}, {'accuracy': 0.18057}, {'accuracy': 0.15802999999999998}, {'accuracy': 0.18761}, {'accuracy': 0.18208}, {'accuracy': 0.17295000000000002}, {'accuracy': 0.17600000000000002}, {'accuracy': 0.18092000000000003}, {'accuracy': 0.19286999999999999}, {'accuracy': 0.17271}, {'accuracy': 0.16898}, {'accuracy': 0.19405999999999998}, {'accuracy': 0.1871}, {'accuracy': 0.19039999999999999}, {'accuracy': 0.20526}, {'accuracy': 0.18723}, {'accuracy': 0.18904}, {'accuracy': 0.19136000000000003}, {'accuracy': 0.19841}, {'accuracy': 0.20258000000000004}, {'accuracy': 0.19724}, {'accuracy': 0.16371999999999998}, {'accuracy': 0.19251000000000001}, {'accuracy': 0.19148}, {'accuracy': 0.19497}, {'accuracy': 0.19507999999999998}, {'accuracy': 0.18382}, {'accuracy': 0.18314000000000002}, {'accuracy': 0.18644}, {'accuracy': 0.20326}, {'accuracy': 0.18739}, {'accuracy': 0.1829}, {'accuracy': 0.19058999999999998}, {'accuracy': 0.19527999999999998}, {'accuracy': 0.19649}, {'accuracy': 0.19602}, {'accuracy': 0.19634000000000001}, {'accuracy': 0.17062}, {'accuracy': 0.19778}, {'accuracy': 0.18921}, {'accuracy': 0.20055}, {'accuracy': 0.19195}, {'accuracy': 0.18754}, {'accuracy': 0.17172}, {'accuracy': 0.18551}, {'accuracy': 0.16997}, {'accuracy': 0.18869999999999998}, {'accuracy': 0.18733}, {'accuracy': 0.19096}, {'accuracy': 0.20271999999999996}, {'accuracy': 0.18450000000000003}, {'accuracy': 0.17892999999999998}, {'accuracy': 0.19727}, {'accuracy': 0.19551}, {'accuracy': 0.18221}, {'accuracy': 0.17532999999999999}, {'accuracy': 0.18973999999999996}, {'accuracy': 0.19022999999999998}, {'accuracy': 0.19203}, {'accuracy': 0.18683}, {'accuracy': 0.20074999999999998}, {'accuracy': 0.19268}, {'accuracy': 0.19224000000000002}, {'accuracy': 0.17381999999999997}, {'accuracy': 0.19322999999999999}, {'accuracy': 0.17902}, {'accuracy': 0.18956}, {'accuracy': 0.20068999999999998}, {'accuracy': 0.1824}, {'accuracy': 0.17921}, {'accuracy': 0.18212}, {'accuracy': 0.19011}, {'accuracy': 0.19140000000000001}, {'accuracy': 0.1795}, {'accuracy': 0.20343999999999998}, {'accuracy': 0.19353}, {'accuracy': 0.18477}, {'accuracy': 0.19072}, {'accuracy': 0.19460999999999998}, {'accuracy': 0.21008}, {'accuracy': 0.1854}, {'accuracy': 0.18437}, {'accuracy': 0.19357999999999997}, {'accuracy': 0.21389999999999998}, {'accuracy': 0.24099999999999996}, {'accuracy': 0.24479}, {'accuracy': 0.21873}, {'accuracy': 0.25173999999999996}, {'accuracy': 0.26254}, {'accuracy': 0.24168000000000003}, {'accuracy': 0.24949}, {'accuracy': 0.2473}, {'accuracy': 0.23843999999999999}, {'accuracy': 0.24896}, {'accuracy': 0.24655999999999997}, {'accuracy': 0.23772000000000001}, {'accuracy': 0.23698999999999998}, {'accuracy': 0.24776000000000004}, {'accuracy': 0.24467999999999995}, {'accuracy': 0.25004000000000004}, {'accuracy': 0.24269000000000002}, {'accuracy': 0.23182}, {'accuracy': 0.24406000000000003}, {'accuracy': 0.23488000000000003}, {'accuracy': 0.23777999999999996}, {'accuracy': 0.24161000000000002}, {'accuracy': 0.24575000000000005}, {'accuracy': 0.24741}, {'accuracy': 0.23412000000000002}, {'accuracy': 0.24523999999999999}, {'accuracy': 0.2451}, {'accuracy': 0.24747999999999998}, {'accuracy': 0.25358}, {'accuracy': 0.25193000000000004}, {'accuracy': 0.24894}, {'accuracy': 0.25778}, {'accuracy': 0.24706999999999998}, {'accuracy': 0.24767}, {'accuracy': 0.24583000000000005}, {'accuracy': 0.25174}, {'accuracy': 0.25821}, {'accuracy': 0.25643}, {'accuracy': 0.21392000000000003}, {'accuracy': 0.24977999999999997}, {'accuracy': 0.24777}, {'accuracy': 0.24564}, {'accuracy': 0.24996000000000002}, {'accuracy': 0.25369}, {'accuracy': 0.24827000000000005}, {'accuracy': 0.25093}, {'accuracy': 0.24714999999999998}, {'accuracy': 0.25571}, {'accuracy': 0.25187}, {'accuracy': 0.25564}, {'accuracy': 0.26015}, {'accuracy': 0.25001999999999996}, {'accuracy': 0.25561}, {'accuracy': 0.255}, {'accuracy': 0.25369}, {'accuracy': 0.24907999999999997}, {'accuracy': 0.25771}, {'accuracy': 0.25664999999999993}, {'accuracy': 0.2598}, {'accuracy': 0.25422}, {'accuracy': 0.26023999999999997}, {'accuracy': 0.25161}, {'accuracy': 0.25458}, {'accuracy': 0.25259}, {'accuracy': 0.25538000000000005}, {'accuracy': 0.25154}, {'accuracy': 0.25456999999999996}, {'accuracy': 0.26067999999999997}, {'accuracy': 0.25487000000000004}, {'accuracy': 0.26124}, {'accuracy': 0.25603}, {'accuracy': 0.25682}, {'accuracy': 0.25952}, {'accuracy': 0.25738999999999995}, {'accuracy': 0.25664000000000003}, {'accuracy': 0.25692000000000004}, {'accuracy': 0.2563}, {'accuracy': 0.26088999999999996}, {'accuracy': 0.26044999999999996}, {'accuracy': 0.25517}, {'accuracy': 0.2512}, {'accuracy': 0.2519}, {'accuracy': 0.25775000000000003}, {'accuracy': 0.2603}, {'accuracy': 0.26415}, {'accuracy': 0.25942}, {'accuracy': 0.26}, {'accuracy': 0.25767999999999996}, {'accuracy': 0.26195}, {'accuracy': 0.26055}, {'accuracy': 0.26085}, {'accuracy': 0.25773999999999997}, {'accuracy': 0.25918}, {'accuracy': 0.2615}, {'accuracy': 0.26508999999999994}, {'accuracy': 0.25240999999999997}, {'accuracy': 0.25465}, {'accuracy': 0.25943}, {'accuracy': 0.25678}, {'accuracy': 0.25592000000000004}, {'accuracy': 0.25146}, {'accuracy': 0.2571}, {'accuracy': 0.2588}, {'accuracy': 0.25229}, {'accuracy': 0.25896}, {'accuracy': 0.25097}, {'accuracy': 0.25795999999999997}, {'accuracy': 0.25385}, {'accuracy': 0.25867}, {'accuracy': 0.25194}, {'accuracy': 0.26171}, {'accuracy': 0.25866}, {'accuracy': 0.26259}, {'accuracy': 0.26149000000000006}, {'accuracy': 0.26494}, {'accuracy': 0.25976}, {'accuracy': 0.256}, {'accuracy': 0.26423}, {'accuracy': 0.25246}, {'accuracy': 0.25095}, {'accuracy': 0.25555}, {'accuracy': 0.25884}, {'accuracy': 0.25687}, {'accuracy': 0.26348000000000005}, {'accuracy': 0.25637000000000004}, {'accuracy': 0.26305}, {'accuracy': 0.26199000000000006}, {'accuracy': 0.26268}, {'accuracy': 0.25422999999999996}, {'accuracy': 0.25233000000000005}, {'accuracy': 0.26327}, {'accuracy': 0.25271}, {'accuracy': 0.246}, {'accuracy': 0.2592}, {'accuracy': 0.26017}, {'accuracy': 0.25449}, {'accuracy': 0.26414}, {'accuracy': 0.26134}, {'accuracy': 0.26288999999999996}, {'accuracy': 0.26697000000000004}, {'accuracy': 0.26612}, {'accuracy': 0.26663}, {'accuracy': 0.26664000000000004}, {'accuracy': 0.26183000000000006}, {'accuracy': 0.25833000000000006}, {'accuracy': 0.25726999999999994}, {'accuracy': 0.25643000000000005}, {'accuracy': 0.26076}, {'accuracy': 0.25663}, {'accuracy': 0.2602399999999999}, {'accuracy': 0.26186999999999994}, {'accuracy': 0.25333}, {'accuracy': 0.24884}, {'accuracy': 0.25895}, {'accuracy': 0.2636}, {'accuracy': 0.26546000000000003}, {'accuracy': 0.25984999999999997}, {'accuracy': 0.25785}, {'accuracy': 0.26309000000000005}, {'accuracy': 0.25887000000000004}, {'accuracy': 0.26274000000000003}, {'accuracy': 0.26042000000000004}, {'accuracy': 0.24911000000000003}, {'accuracy': 0.257}, {'accuracy': 0.26180000000000003}, {'accuracy': 0.25542999999999993}, {'accuracy': 0.25583999999999996}, {'accuracy': 0.2564}, {'accuracy': 0.25585}, {'accuracy': 0.26141000000000003}, {'accuracy': 0.25835}, {'accuracy': 0.26061000000000006}, {'accuracy': 0.26477999999999996}, {'accuracy': 0.26403}, {'accuracy': 0.26563}, {'accuracy': 0.26174000000000003}, {'accuracy': 0.26094}, {'accuracy': 0.26782}, {'accuracy': 0.26396}, {'accuracy': 0.26269}, {'accuracy': 0.26126}, {'accuracy': 0.26065}, {'accuracy': 0.26751}, {'accuracy': 0.25898999999999994}, {'accuracy': 0.2547}, {'accuracy': 0.26349999999999996}, {'accuracy': 0.25736}, {'accuracy': 0.25745}, {'accuracy': 0.26122999999999996}, {'accuracy': 0.25734}, {'accuracy': 0.25132}, {'accuracy': 0.25944}, {'accuracy': 0.26193}, {'accuracy': 0.25043000000000004}, {'accuracy': 0.24206000000000003}, {'accuracy': 0.25368}, {'accuracy': 0.25514}, {'accuracy': 0.25436000000000003}, {'accuracy': 0.25595999999999997}, {'accuracy': 0.25728}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "242193f5-6fc9-461f-95f5-e2901e278590",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "240ba157-77dd-47ba-8e79-4a6f5172c73f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c0c887e4-ddae-413a-865a-cf067f8fd7b3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5f5f27e4-5bc6-4b9c-aae1-f9733aa11589",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dade01f3-e4c9-46eb-bcca-3cd0e055cc20",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5bd95d88-5e25-4347-a4e4-e158d1f45599",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a3587fd-7bfa-44f2-8954-f8ff94233c05",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f1c9de94-0207-4d38-be21-be5f2f1556c8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dbf24558-92fb-4091-beff-8f21868b3b8e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1b563a18-b833-4fcb-8dc0-629fd6a21087",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bd3bd2f2-9e33-4a97-8b2f-27e68496be4a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8f8a0be9-7afd-4692-b4cc-873bba93e8a9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "be3447c6-7910-49bf-b187-3f7907d1cddb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fde2ad41-7102-4f44-aa1c-4b6dabd3dfb2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a051f4e3-e14c-4092-8300-fe89fc4ba49c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "18695822-3fd4-49fb-b75d-33b9ac65e4cb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d2aa3d5-95a4-4585-9076-79d0d03fe113",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed3c9f73-5701-46b0-bd84-026cd60f6d2c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "efee0526-319c-4cd9-b7a5-bbf3ea389f2f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b1ce10e8-fb04-4bb7-b7a9-8e5dad763013",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eaa452c6-4433-4b7a-bd77-e6dba9dab519",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "681ca48f-e1d1-4645-bf83-20025a9d102f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "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": "a986a02c-955c-4c3a-b3f2-20cfe709af08",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "26428b96-837e-496a-9f65-6b5411c9168a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4f6a1501-844b-431e-a05e-11b322d12a26",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c881b465-b767-431b-83f3-a9fe0472e72b",
   "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
}
