{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7ef47ffb-38cd-4095-9561-431be338e1c8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    " \n",
    "# setting path\n",
    "sys.path.append('../')\n",
    "\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_FEMNIST,get_FashionMNIST, get_MNIST\n",
    "from gossipy_original.utils import plot_evaluation\n",
    "\n",
    "\n",
    "class CNNmnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(1, 10, kernel_size=5)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(10, 20, kernel_size=5)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(320, 50)\n",
    "        self.fc2 = nn.Linear(50, 10)        \n",
    "        # self.out = nn.Linear(64 * 7 * 7, 10)\n",
    "\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",
    "        pass\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = x.reshape(-1, 1, 28, 28)\n",
    "        x = F.relu(F.max_pool2d(self.conv1(x), 2))\n",
    "        x = F.relu(F.max_pool2d(self.conv2_drop(self.conv2(x)), 2))\n",
    "        x = x.view(-1, 320)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    def __repr__(self) -> str:\n",
    "        return \"miniNet(size=%d)\" %self.get_size()\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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([60000])\n",
      "6099\n",
      "[[  0 596]\n",
      " [  1 720]\n",
      " [  2 618]\n",
      " [  3 611]\n",
      " [  4 547]\n",
      " [  5 528]\n",
      " [  6 563]\n",
      " [  7 640]\n",
      " [  8 597]\n",
      " [  9 615]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([5, 0, 4,  ..., 5, 6, 8])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_MNIST()\n",
    "\n",
    "train_set[0].shape\n",
    "\n",
    "tran1=torch.zeros([60000, 28,28], dtype=torch.float32)\n",
    "\n",
    "tran1.shape\n",
    "\n",
    "train_set[1].shape\n",
    "\n",
    "tag1=torch.zeros([60000], dtype=torch.int64)\n",
    "\n",
    "print(tag1.shape)\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",
    "for z in range(0,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t ==0:\n",
    "        list0[0].append(train_set[0][z])\n",
    "        list0[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==1:\n",
    "        list1[0].append(train_set[0][z])\n",
    "        list1[1].append(train_set[1][z])\n",
    "\n",
    "    elif t ==2:\n",
    "        list2[0].append(train_set[0][z])\n",
    "        list2[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==3:\n",
    "        list3[0].append(train_set[0][z])\n",
    "        list3[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==4:\n",
    "        list4[0].append(train_set[0][z])\n",
    "        list4[1].append(train_set[1][z])        \n",
    "        \n",
    "        \n",
    "    elif t ==5:\n",
    "        list5[0].append(train_set[0][z])\n",
    "        list5[1].append(train_set[1][z])\n",
    "        \n",
    "    elif t ==6:\n",
    "        list6[0].append(train_set[0][z])\n",
    "        list6[1].append(train_set[1][z])        \n",
    "        \n",
    "    elif t ==7:\n",
    "        list7[0].append(train_set[0][z])\n",
    "        list7[1].append(train_set[1][z])   \n",
    "        \n",
    "        \n",
    "    elif t ==8:\n",
    "        list8[0].append(train_set[0][z])\n",
    "        list8[1].append(train_set[1][z])   \n",
    "        \n",
    "    elif t ==9:\n",
    "        list9[0].append(train_set[0][z])\n",
    "        list9[1].append(train_set[1][z])   \n",
    "\n",
    "\n",
    "print(len(list0[0]))\n",
    "\n",
    "unique, counts = np.unique(list9[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\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": 3,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([3, 0, 6,  ..., 1, 3, 2])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "fb85c984-e99f-433e-9cca-7bc7c93c10dd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5982\n",
      "([], [], [], [], [], [], [], [], [], [])\n",
      "[[  0 526]\n",
      " [  1 576]\n",
      " [  2 551]\n",
      " [  3 564]\n",
      " [  4 521]\n",
      " [  5 475]\n",
      " [  6 529]\n",
      " [  7 570]\n",
      " [  8 540]\n",
      " [  9 550]]\n",
      "[[  0 793]\n",
      " [  1 580]\n",
      " [  2 553]\n",
      " [  3 574]\n",
      " [  4 529]\n",
      " [  5 493]\n",
      " [  6 553]\n",
      " [  7 609]\n",
      " [  8 612]\n",
      " [  9 711]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([3, 0, 6,  ..., 9, 9, 9])"
      ]
     },
     "execution_count": 4,
     "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,60000,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,60000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<1:\n",
    "        noiseyset[0].append(dataset1[z])\n",
    "        healthset[0].append(dataset1[z])\n",
    "        healthset[1].append(target1[z])\n",
    "        healthset[2].append(z)\n",
    "        noiseyset[1].append(((target1[z] - 1) % 10))\n",
    "    \n",
    "\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "noiseyset[1][0:20]\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "healthset[2][0:20]\n",
    "\n",
    "\n",
    "\n",
    "p=0\n",
    "for z in range(0,len(healthset[2]),1):\n",
    "    dataset1.pop(healthset[2][z]-p)\n",
    "    target1.pop(healthset[2][z]-p)\n",
    "    p=p+1\n",
    "\n",
    "print(p)\n",
    "\n",
    "target1[0:20]\n",
    "\n",
    "len(target1)\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "#finish getting noised dataset\n",
    "\n",
    "import random\n",
    "label=[],[],[],[],[],[],[],[],[],[]\n",
    "\n",
    "\n",
    "print(label)\n",
    "\n",
    "for z in range(0,len(noiseyset[1]),1):\n",
    "    if noiseyset[1][z] ==0:\n",
    "        label[0].append(z)\n",
    "    elif noiseyset[1][z] ==1:\n",
    "        label[1].append(z)\n",
    "    elif noiseyset[1][z] ==2:\n",
    "        label[2].append(z)\n",
    "    elif noiseyset[1][z] ==3:\n",
    "        label[3].append(z)\n",
    "    elif noiseyset[1][z] ==4:\n",
    "        label[4].append(z)\n",
    "    elif noiseyset[1][z] ==5:\n",
    "        label[5].append(z)\n",
    "    elif noiseyset[1][z] ==6:\n",
    "        label[6].append(z)\n",
    "    elif noiseyset[1][z] ==7:\n",
    "        label[7].append(z)\n",
    "    elif noiseyset[1][z] ==8:\n",
    "        label[8].append(z)\n",
    "    elif noiseyset[1][z] ==9:\n",
    "        label[9].append(z)\n",
    "\n",
    "label[0][0]\n",
    "\n",
    "len(noiseyset[1])\n",
    "\n",
    "noiseyset[1][label[0][50]]\n",
    "\n",
    "len(label[1])\n",
    "\n",
    "#split the dataset\n",
    "\n",
    "n_ex = len(target1)\n",
    "ex_x_user = math.ceil(n_ex / 10)\n",
    "\n",
    "\n",
    "\n",
    "ex_x_user\n",
    "\n",
    "listpp=[]\n",
    "\n",
    "idx=0\n",
    "for idx, i in enumerate(range(0, n_ex, ex_x_user)):\n",
    "    listpp.append(list(range(i, min(i + ex_x_user, n_ex))))\n",
    "\n",
    "len(listpp[9])\n",
    "\n",
    "\n",
    "\n",
    "import random\n",
    "list0=[],[]\n",
    "list1=[],[]\n",
    "list2=[],[]\n",
    "list3=[],[]\n",
    "list4=[],[]\n",
    "list5=[],[]\n",
    "list6=[],[]\n",
    "list7=[],[]\n",
    "list8=[],[]\n",
    "list9=[],[]\n",
    "\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "for z in range(0,len(listpp[0]),1):\n",
    "    list0[0].append(dataset1[listpp[0][z]])\n",
    "    list0[1].append(target1[listpp[0][z]])\n",
    "\n",
    "for z in range(0,len(listpp[1]),1):\n",
    "    list1[0].append(dataset1[listpp[1][z]])\n",
    "    list1[1].append(target1[listpp[1][z]])\n",
    "\n",
    "for z in range(0,len(listpp[2]),1):\n",
    "    list2[0].append(dataset1[listpp[2][z]])\n",
    "    list2[1].append(target1[listpp[2][z]])\n",
    "\n",
    "for z in range(0,len(listpp[3]),1):\n",
    "    list3[0].append(dataset1[listpp[3][z]])\n",
    "    list3[1].append(target1[listpp[3][z]])\n",
    "\n",
    "for z in range(0,len(listpp[4]),1):\n",
    "    list4[0].append(dataset1[listpp[4][z]])\n",
    "    list4[1].append(target1[listpp[4][z]])\n",
    "\n",
    "for z in range(0,len(listpp[5]),1):\n",
    "    list5[0].append(dataset1[listpp[5][z]])\n",
    "    list5[1].append(target1[listpp[5][z]])\n",
    "\n",
    "    \n",
    "for z in range(0,len(listpp[6]),1):\n",
    "    list6[0].append(dataset1[listpp[6][z]])\n",
    "    list6[1].append(target1[listpp[6][z]])\n",
    "\n",
    "for z in range(0,len(listpp[7]),1):\n",
    "    list7[0].append(dataset1[listpp[7][z]])\n",
    "    list7[1].append(target1[listpp[7][z]])\n",
    "\n",
    "for z in range(0,len(listpp[8]),1):\n",
    "    list8[0].append(dataset1[listpp[8][z]])\n",
    "    list8[1].append(target1[listpp[8][z]])\n",
    "\n",
    "for z in range(0,len(listpp[9]),1):\n",
    "    list9[0].append(dataset1[listpp[9][z]])\n",
    "    list9[1].append(target1[listpp[9][z]])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "len(label[0])\n",
    "\n",
    "import math\n",
    "import numpy as np\n",
    "\n",
    "for z in range(0,len(label[0]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list0[0].append(noiseyset[0][label[0][z]])\n",
    "        list0[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t1<4:\n",
    "        list1[0].append(noiseyset[0][label[0][z]])\n",
    "        list1[1].append(noiseyset[1][label[0][z]])\n",
    "    elif t2<4:\n",
    "        list2[0].append(noiseyset[0][label[0][z]])\n",
    "        list2[1].append(noiseyset[1][label[0][z]])        \n",
    "    elif t3<4:\n",
    "        list3[0].append(noiseyset[0][label[0][z]])\n",
    "        list3[1].append(noiseyset[1][label[0][z]])       \n",
    "    elif t4<4:\n",
    "        list4[0].append(noiseyset[0][label[0][z]])\n",
    "        list4[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t5<4:\n",
    "        list5[0].append(noiseyset[0][label[0][z]])\n",
    "        list5[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t6<4:\n",
    "        list6[0].append(noiseyset[0][label[0][z]])\n",
    "        list6[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t7<4:\n",
    "        list7[0].append(noiseyset[0][label[0][z]])\n",
    "        list7[1].append(noiseyset[1][label[0][z]])  \n",
    "    elif t8<4:\n",
    "        list8[0].append(noiseyset[0][label[0][z]])\n",
    "        list8[1].append(noiseyset[1][label[0][z]])  \n",
    "    else:\n",
    "        list9[0].append(noiseyset[0][label[0][z]])\n",
    "        list9[1].append(noiseyset[1][label[0][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[1]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list1[0].append(noiseyset[0][label[1][z]])\n",
    "        list1[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t1<4:\n",
    "        list2[0].append(noiseyset[0][label[1][z]])\n",
    "        list2[1].append(noiseyset[1][label[1][z]])\n",
    "    elif t2<4:\n",
    "        list3[0].append(noiseyset[0][label[1][z]])\n",
    "        list3[1].append(noiseyset[1][label[1][z]])        \n",
    "    elif t3<4:\n",
    "        list4[0].append(noiseyset[0][label[1][z]])\n",
    "        list4[1].append(noiseyset[1][label[1][z]])       \n",
    "    elif t4<4:\n",
    "        list5[0].append(noiseyset[0][label[1][z]])\n",
    "        list5[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t5<4:\n",
    "        list6[0].append(noiseyset[0][label[1][z]])\n",
    "        list6[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t6<4:\n",
    "        list7[0].append(noiseyset[0][label[1][z]])\n",
    "        list7[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t7<4:\n",
    "        list8[0].append(noiseyset[0][label[1][z]])\n",
    "        list8[1].append(noiseyset[1][label[1][z]])  \n",
    "    elif t8<4:\n",
    "        list9[0].append(noiseyset[0][label[1][z]])\n",
    "        list9[1].append(noiseyset[1][label[1][z]])  \n",
    "    else:\n",
    "        list0[0].append(noiseyset[0][label[1][z]])\n",
    "        list0[1].append(noiseyset[1][label[1][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[2]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list2[0].append(noiseyset[0][label[2][z]])\n",
    "        list2[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t1<4:\n",
    "        list3[0].append(noiseyset[0][label[2][z]])\n",
    "        list3[1].append(noiseyset[1][label[2][z]])\n",
    "    elif t2<4:\n",
    "        list4[0].append(noiseyset[0][label[2][z]])\n",
    "        list4[1].append(noiseyset[1][label[2][z]])        \n",
    "    elif t3<4:\n",
    "        list5[0].append(noiseyset[0][label[2][z]])\n",
    "        list5[1].append(noiseyset[1][label[2][z]])       \n",
    "    elif t4<4:\n",
    "        list6[0].append(noiseyset[0][label[2][z]])\n",
    "        list6[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t5<4:\n",
    "        list7[0].append(noiseyset[0][label[2][z]])\n",
    "        list7[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t6<4:\n",
    "        list8[0].append(noiseyset[0][label[2][z]])\n",
    "        list8[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t7<4:\n",
    "        list9[0].append(noiseyset[0][label[2][z]])\n",
    "        list9[1].append(noiseyset[1][label[2][z]])  \n",
    "    elif t8<4:\n",
    "        list0[0].append(noiseyset[0][label[2][z]])\n",
    "        list0[1].append(noiseyset[1][label[2][z]])  \n",
    "    else:\n",
    "        list1[0].append(noiseyset[0][label[2][z]])\n",
    "        list1[1].append(noiseyset[1][label[2][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[3]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list3[0].append(noiseyset[0][label[3][z]])\n",
    "        list3[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t1<4:\n",
    "        list4[0].append(noiseyset[0][label[3][z]])\n",
    "        list4[1].append(noiseyset[1][label[3][z]])\n",
    "    elif t2<4:\n",
    "        list5[0].append(noiseyset[0][label[3][z]])\n",
    "        list5[1].append(noiseyset[1][label[3][z]])        \n",
    "    elif t3<4:\n",
    "        list6[0].append(noiseyset[0][label[3][z]])\n",
    "        list6[1].append(noiseyset[1][label[3][z]])       \n",
    "    elif t4<4:\n",
    "        list7[0].append(noiseyset[0][label[3][z]])\n",
    "        list7[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t5<4:\n",
    "        list8[0].append(noiseyset[0][label[3][z]])\n",
    "        list8[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t6<4:\n",
    "        list9[0].append(noiseyset[0][label[3][z]])\n",
    "        list9[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t7<4:\n",
    "        list0[0].append(noiseyset[0][label[3][z]])\n",
    "        list0[1].append(noiseyset[1][label[3][z]])  \n",
    "    elif t8<4:\n",
    "        list1[0].append(noiseyset[0][label[3][z]])\n",
    "        list1[1].append(noiseyset[1][label[3][z]])  \n",
    "    else:\n",
    "        list2[0].append(noiseyset[0][label[3][z]])\n",
    "        list2[1].append(noiseyset[1][label[3][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[4]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list4[0].append(noiseyset[0][label[4][z]])\n",
    "        list4[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t1<4:\n",
    "        list5[0].append(noiseyset[0][label[4][z]])\n",
    "        list5[1].append(noiseyset[1][label[4][z]])\n",
    "    elif t2<4:\n",
    "        list6[0].append(noiseyset[0][label[4][z]])\n",
    "        list6[1].append(noiseyset[1][label[4][z]])        \n",
    "    elif t3<4:\n",
    "        list7[0].append(noiseyset[0][label[4][z]])\n",
    "        list7[1].append(noiseyset[1][label[4][z]])       \n",
    "    elif t4<4:\n",
    "        list8[0].append(noiseyset[0][label[4][z]])\n",
    "        list8[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t5<4:\n",
    "        list9[0].append(noiseyset[0][label[4][z]])\n",
    "        list9[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t6<4:\n",
    "        list0[0].append(noiseyset[0][label[4][z]])\n",
    "        list0[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t7<4:\n",
    "        list1[0].append(noiseyset[0][label[4][z]])\n",
    "        list1[1].append(noiseyset[1][label[4][z]])  \n",
    "    elif t8<4:\n",
    "        list2[0].append(noiseyset[0][label[4][z]])\n",
    "        list2[1].append(noiseyset[1][label[4][z]])  \n",
    "    else:\n",
    "        list3[0].append(noiseyset[0][label[4][z]])\n",
    "        list3[1].append(noiseyset[1][label[4][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[5]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list5[0].append(noiseyset[0][label[5][z]])\n",
    "        list5[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t1<4:\n",
    "        list6[0].append(noiseyset[0][label[5][z]])\n",
    "        list6[1].append(noiseyset[1][label[5][z]])\n",
    "    elif t2<4:\n",
    "        list7[0].append(noiseyset[0][label[5][z]])\n",
    "        list7[1].append(noiseyset[1][label[5][z]])        \n",
    "    elif t3<4:\n",
    "        list8[0].append(noiseyset[0][label[5][z]])\n",
    "        list8[1].append(noiseyset[1][label[5][z]])       \n",
    "    elif t4<4:\n",
    "        list9[0].append(noiseyset[0][label[5][z]])\n",
    "        list9[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t5<4:\n",
    "        list0[0].append(noiseyset[0][label[5][z]])\n",
    "        list0[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t6<4:\n",
    "        list1[0].append(noiseyset[0][label[5][z]])\n",
    "        list1[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t7<4:\n",
    "        list2[0].append(noiseyset[0][label[5][z]])\n",
    "        list2[1].append(noiseyset[1][label[5][z]])  \n",
    "    elif t8<4:\n",
    "        list3[0].append(noiseyset[0][label[5][z]])\n",
    "        list3[1].append(noiseyset[1][label[5][z]])  \n",
    "    else:\n",
    "        list4[0].append(noiseyset[0][label[5][z]])\n",
    "        list4[1].append(noiseyset[1][label[5][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[6]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list6[0].append(noiseyset[0][label[6][z]])\n",
    "        list6[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t1<4:\n",
    "        list7[0].append(noiseyset[0][label[6][z]])\n",
    "        list7[1].append(noiseyset[1][label[6][z]])\n",
    "    elif t2<4:\n",
    "        list8[0].append(noiseyset[0][label[6][z]])\n",
    "        list8[1].append(noiseyset[1][label[6][z]])        \n",
    "    elif t3<4:\n",
    "        list9[0].append(noiseyset[0][label[6][z]])\n",
    "        list9[1].append(noiseyset[1][label[6][z]])       \n",
    "    elif t4<4:\n",
    "        list0[0].append(noiseyset[0][label[6][z]])\n",
    "        list0[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t5<4:\n",
    "        list1[0].append(noiseyset[0][label[6][z]])\n",
    "        list1[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t6<4:\n",
    "        list2[0].append(noiseyset[0][label[6][z]])\n",
    "        list2[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t7<4:\n",
    "        list3[0].append(noiseyset[0][label[6][z]])\n",
    "        list3[1].append(noiseyset[1][label[6][z]])  \n",
    "    elif t8<4:\n",
    "        list4[0].append(noiseyset[0][label[6][z]])\n",
    "        list4[1].append(noiseyset[1][label[6][z]])  \n",
    "    else:\n",
    "        list5[0].append(noiseyset[0][label[6][z]])\n",
    "        list5[1].append(noiseyset[1][label[6][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[7]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list7[0].append(noiseyset[0][label[7][z]])\n",
    "        list7[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t1<4:\n",
    "        list8[0].append(noiseyset[0][label[7][z]])\n",
    "        list8[1].append(noiseyset[1][label[7][z]])\n",
    "    elif t2<4:\n",
    "        list9[0].append(noiseyset[0][label[7][z]])\n",
    "        list9[1].append(noiseyset[1][label[7][z]])        \n",
    "    elif t3<4:\n",
    "        list0[0].append(noiseyset[0][label[7][z]])\n",
    "        list0[1].append(noiseyset[1][label[7][z]])       \n",
    "    elif t4<4:\n",
    "        list1[0].append(noiseyset[0][label[7][z]])\n",
    "        list1[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t5<4:\n",
    "        list2[0].append(noiseyset[0][label[7][z]])\n",
    "        list2[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t6<4:\n",
    "        list3[0].append(noiseyset[0][label[7][z]])\n",
    "        list3[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t7<4:\n",
    "        list4[0].append(noiseyset[0][label[7][z]])\n",
    "        list4[1].append(noiseyset[1][label[7][z]])  \n",
    "    elif t8<4:\n",
    "        list5[0].append(noiseyset[0][label[7][z]])\n",
    "        list5[1].append(noiseyset[1][label[7][z]])  \n",
    "    else:\n",
    "        list6[0].append(noiseyset[0][label[7][z]])\n",
    "        list6[1].append(noiseyset[1][label[7][z]])  \n",
    "        \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[8]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list8[0].append(noiseyset[0][label[8][z]])\n",
    "        list8[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t1<4:\n",
    "        list9[0].append(noiseyset[0][label[8][z]])\n",
    "        list9[1].append(noiseyset[1][label[8][z]])\n",
    "    elif t2<4:\n",
    "        list0[0].append(noiseyset[0][label[8][z]])\n",
    "        list0[1].append(noiseyset[1][label[8][z]])        \n",
    "    elif t3<4:\n",
    "        list1[0].append(noiseyset[0][label[8][z]])\n",
    "        list1[1].append(noiseyset[1][label[8][z]])       \n",
    "    elif t4<4:\n",
    "        list2[0].append(noiseyset[0][label[8][z]])\n",
    "        list2[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t5<4:\n",
    "        list3[0].append(noiseyset[0][label[8][z]])\n",
    "        list3[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t6<4:\n",
    "        list4[0].append(noiseyset[0][label[8][z]])\n",
    "        list4[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t7<4:\n",
    "        list5[0].append(noiseyset[0][label[8][z]])\n",
    "        list5[1].append(noiseyset[1][label[8][z]])  \n",
    "    elif t8<4:\n",
    "        list6[0].append(noiseyset[0][label[8][z]])\n",
    "        list6[1].append(noiseyset[1][label[8][z]])  \n",
    "    else:\n",
    "        list7[0].append(noiseyset[0][label[8][z]])\n",
    "        list7[1].append(noiseyset[1][label[8][z]])  \n",
    "        \n",
    "        \n",
    "for z in range(0,len(label[9]),1):\n",
    "    t0=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t1=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t2=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t3=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t4=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t5=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t6=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t7=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t8=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    t9=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t0<4:\n",
    "        list9[0].append(noiseyset[0][label[9][z]])\n",
    "        list9[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t1<4:\n",
    "        list0[0].append(noiseyset[0][label[9][z]])\n",
    "        list0[1].append(noiseyset[1][label[9][z]])\n",
    "    elif t2<4:\n",
    "        list1[0].append(noiseyset[0][label[9][z]])\n",
    "        list1[1].append(noiseyset[1][label[9][z]])        \n",
    "    elif t3<4:\n",
    "        list2[0].append(noiseyset[0][label[9][z]])\n",
    "        list2[1].append(noiseyset[1][label[9][z]])       \n",
    "    elif t4<4:\n",
    "        list3[0].append(noiseyset[0][label[9][z]])\n",
    "        list3[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t5<4:\n",
    "        list4[0].append(noiseyset[0][label[9][z]])\n",
    "        list4[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t6<4:\n",
    "        list5[0].append(noiseyset[0][label[9][z]])\n",
    "        list5[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t7<4:\n",
    "        list6[0].append(noiseyset[0][label[9][z]])\n",
    "        list6[1].append(noiseyset[1][label[9][z]])  \n",
    "    elif t8<4:\n",
    "        list7[0].append(noiseyset[0][label[9][z]])\n",
    "        list7[1].append(noiseyset[1][label[9][z]])  \n",
    "    else:\n",
    "        list8[0].append(noiseyset[0][label[9][z]])\n",
    "        list8[1].append(noiseyset[1][label[9][z]])       \n",
    "\n",
    "\n",
    "\n",
    "unique, counts = np.unique(list0[1], return_counts=True)\n",
    "print(np.asarray((unique, counts)).T)\n",
    "\n",
    "len(list0[1])+len(list1[1])+len(list2[1])+len(list3[1])+len(list4[1])+len(list5[1])+len(list6[1])+len(list7[1])+len(list8[1])+len(list9[1])\n",
    "\n",
    "\n",
    "\n",
    "dataset1=[]\n",
    "\n",
    "dataset1.append(list0[0])\n",
    "dataset1.append(list1[0])\n",
    "dataset1.append(list2[0])\n",
    "dataset1.append(list3[0])\n",
    "dataset1.append(list4[0])\n",
    "dataset1.append(list5[0])\n",
    "dataset1.append(list6[0])\n",
    "dataset1.append(list7[0])\n",
    "dataset1.append(list8[0])\n",
    "dataset1.append(list9[0])\n",
    "\n",
    "target1=[]\n",
    "\n",
    "target1.append(list0[1])\n",
    "target1.append(list1[1])\n",
    "target1.append(list2[1])\n",
    "target1.append(list3[1])\n",
    "target1.append(list4[1])\n",
    "target1.append(list5[1])\n",
    "target1.append(list6[1])\n",
    "target1.append(list7[1])\n",
    "target1.append(list8[1])\n",
    "target1.append(list9[1])\n",
    "\n",
    "len(dataset1[1])\n",
    "\n",
    "global o\n",
    "o=0\n",
    "for i in range (len(target1)):\n",
    "    for j in range (len(dataset1[i])):\n",
    "        tran1[o]= dataset1[i][j]\n",
    "        tag1[o]=target1[i][j]\n",
    "        o=o+1\n",
    "print(o)\n",
    "\n",
    "train_set[1]\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6f48e465-6fd1-42d9-82fe-08c9095db491",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "data_handler = ClassificationDataHandler(tran1, tag1,\n",
    "                                         test_set[0], test_set[1])\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1c1faaf3-0a08-4288-b494-d3059924b666",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is my idx\n",
      "0\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "1\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "2\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "3\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "4\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "5\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "6\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "7\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "8\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my idx\n",
      "9\n",
      "this is my n_sampled\n",
      "9\n",
      "this is my m_top\n",
      "9\n",
      "this is my nighbor counter\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n",
      "this is my nighbor selected\n",
      "{0: 0, 1: 0, 2: 0, 3: 0, 4: 0, 5: 0, 6: 0, 7: 0, 8: 0, 9: 0}\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">151023-23:26:05 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Simulation started.                                                           <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:372</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m151023-23:26:05\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Simulation started.                                                           \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m372\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"></pre>\n"
      ],
      "text/plain": [
       "\u001b[?25l"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "73867294d48f412aa4f18ce139b552e7",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Output()"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\n",
       "\u001b[?25h"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">161023-00:01:16 </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Sent messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3231</span>                                                         <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:239</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m161023-00:01:16\u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Sent messages: \u001b[1;36m3231\u001b[0m                                                         \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m239\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> # Failed messages: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0</span>                                                          <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:240</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m # Failed messages: \u001b[1;36m0\u001b[0m                                                          \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m240\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> Total size: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">70565040</span>                                                          <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">simul.py:241</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m Total size: \u001b[1;36m70565040\u001b[0m                                                          \u001b[2msimul.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m241\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.12779000000000001}, {'accuracy': 0.28007}, {'accuracy': 0.44957}, {'accuracy': 0.54974}, {'accuracy': 0.6949500000000001}, {'accuracy': 0.66503}, {'accuracy': 0.65408}, {'accuracy': 0.68903}, {'accuracy': 0.74741}, {'accuracy': 0.75889}, {'accuracy': 0.7811800000000001}, {'accuracy': 0.8292400000000001}, {'accuracy': 0.86883}, {'accuracy': 0.8280899999999999}, {'accuracy': 0.8266399999999999}, {'accuracy': 0.86144}, {'accuracy': 0.8684}, {'accuracy': 0.82392}, {'accuracy': 0.82013}, {'accuracy': 0.81419}, {'accuracy': 0.84045}, {'accuracy': 0.8450799999999999}, {'accuracy': 0.86058}, {'accuracy': 0.83058}, {'accuracy': 0.8999699999999999}, {'accuracy': 0.8671499999999999}, {'accuracy': 0.88072}, {'accuracy': 0.84955}, {'accuracy': 0.79036}, {'accuracy': 0.8531599999999999}, {'accuracy': 0.87607}, {'accuracy': 0.85068}, {'accuracy': 0.81375}, {'accuracy': 0.8499699999999999}, {'accuracy': 0.8678699999999999}, {'accuracy': 0.86584}, {'accuracy': 0.88506}, {'accuracy': 0.83618}, {'accuracy': 0.87257}, {'accuracy': 0.90334}, {'accuracy': 0.91663}, {'accuracy': 0.8509500000000001}, {'accuracy': 0.8566100000000001}, {'accuracy': 0.83065}, {'accuracy': 0.7355799999999999}, {'accuracy': 0.84867}, {'accuracy': 0.8479999999999999}, {'accuracy': 0.88039}, {'accuracy': 0.92721}, {'accuracy': 0.8607100000000001}, {'accuracy': 0.90703}, {'accuracy': 0.9354699999999999}, {'accuracy': 0.84246}, {'accuracy': 0.88737}, {'accuracy': 0.8602200000000002}, {'accuracy': 0.83694}, {'accuracy': 0.8161900000000001}, {'accuracy': 0.84414}, {'accuracy': 0.8924199999999999}, {'accuracy': 0.8914799999999999}, {'accuracy': 0.8556999999999999}, {'accuracy': 0.9135}, {'accuracy': 0.79365}, {'accuracy': 0.8352299999999999}, {'accuracy': 0.8568300000000001}, {'accuracy': 0.9352300000000001}, {'accuracy': 0.85664}, {'accuracy': 0.8912800000000001}, {'accuracy': 0.8546000000000001}, {'accuracy': 0.8742599999999999}, {'accuracy': 0.8899199999999998}, {'accuracy': 0.8230299999999999}, {'accuracy': 0.8693}, {'accuracy': 0.8937999999999999}, {'accuracy': 0.9343300000000001}, {'accuracy': 0.8387100000000001}, {'accuracy': 0.8922399999999999}, {'accuracy': 0.8904100000000001}, {'accuracy': 0.8048}, {'accuracy': 0.84454}, {'accuracy': 0.82386}, {'accuracy': 0.86072}, {'accuracy': 0.8816}, {'accuracy': 0.88826}, {'accuracy': 0.85674}, {'accuracy': 0.9088200000000001}, {'accuracy': 0.91507}, {'accuracy': 0.8782900000000001}, {'accuracy': 0.8880500000000001}, {'accuracy': 0.8380599999999999}, {'accuracy': 0.8727199999999999}, {'accuracy': 0.84474}, {'accuracy': 0.9205499999999999}, {'accuracy': 0.81349}, {'accuracy': 0.88208}, {'accuracy': 0.89796}, {'accuracy': 0.8353499999999998}, {'accuracy': 0.8949400000000001}, {'accuracy': 0.8456400000000001}, {'accuracy': 0.85808}, {'accuracy': 0.8691699999999999}, {'accuracy': 0.8103899999999999}, {'accuracy': 0.8748099999999999}, {'accuracy': 0.91526}, {'accuracy': 0.75512}, {'accuracy': 0.7971199999999999}, {'accuracy': 0.8710000000000001}, {'accuracy': 0.75326}, {'accuracy': 0.7324499999999999}, {'accuracy': 0.9384099999999999}, {'accuracy': 0.8401400000000001}, {'accuracy': 0.87073}, {'accuracy': 0.8840399999999999}, {'accuracy': 0.8352}, {'accuracy': 0.80715}, {'accuracy': 0.8311499999999998}, {'accuracy': 0.85379}, {'accuracy': 0.8815000000000002}, {'accuracy': 0.8159000000000001}, {'accuracy': 0.77363}, {'accuracy': 0.83809}, {'accuracy': 0.8957200000000001}, {'accuracy': 0.8569300000000002}, {'accuracy': 0.73149}, {'accuracy': 0.87974}, {'accuracy': 0.8491800000000002}, {'accuracy': 0.90845}, {'accuracy': 0.82508}, {'accuracy': 0.8239999999999998}, {'accuracy': 0.86645}, {'accuracy': 0.8548}, {'accuracy': 0.88744}, {'accuracy': 0.8960100000000001}, {'accuracy': 0.8522500000000001}, {'accuracy': 0.87226}, {'accuracy': 0.8373200000000001}, {'accuracy': 0.87767}, {'accuracy': 0.85078}, {'accuracy': 0.88789}, {'accuracy': 0.8248099999999999}, {'accuracy': 0.81662}, {'accuracy': 0.86173}, {'accuracy': 0.8714999999999999}, {'accuracy': 0.8673100000000001}, {'accuracy': 0.8745700000000001}, {'accuracy': 0.8697199999999998}, {'accuracy': 0.88468}, {'accuracy': 0.8459800000000002}, {'accuracy': 0.8801}, {'accuracy': 0.83557}, {'accuracy': 0.72197}, {'accuracy': 0.9807300000000001}, {'accuracy': 0.72173}, {'accuracy': 0.9435800000000001}, {'accuracy': 0.98016}, {'accuracy': 0.98072}, {'accuracy': 0.98052}, {'accuracy': 0.98017}, {'accuracy': 0.9803799999999999}, {'accuracy': 0.98041}, {'accuracy': 0.9802499999999998}, {'accuracy': 0.98059}, {'accuracy': 0.9806100000000001}, {'accuracy': 0.9806099999999999}, {'accuracy': 0.9803900000000001}, {'accuracy': 0.98049}, {'accuracy': 0.98078}, {'accuracy': 0.9809300000000001}, {'accuracy': 0.9810400000000001}, {'accuracy': 0.98055}, {'accuracy': 0.9805900000000001}, {'accuracy': 0.98139}, {'accuracy': 0.9811500000000001}, {'accuracy': 0.98066}, {'accuracy': 0.9806900000000001}, {'accuracy': 0.98064}, {'accuracy': 0.9814100000000001}, {'accuracy': 0.9808199999999999}, {'accuracy': 0.98131}, {'accuracy': 0.98131}, {'accuracy': 0.98132}, {'accuracy': 0.98135}, {'accuracy': 0.98142}, {'accuracy': 0.9808600000000001}, {'accuracy': 0.9812299999999998}, {'accuracy': 0.9810999999999999}, {'accuracy': 0.9811500000000001}, {'accuracy': 0.9813299999999998}, {'accuracy': 0.9812999999999998}, {'accuracy': 0.9816499999999999}, {'accuracy': 0.9814200000000002}, {'accuracy': 0.98171}, {'accuracy': 0.9815299999999999}, {'accuracy': 0.9813699999999999}, {'accuracy': 0.9815999999999999}, {'accuracy': 0.9815999999999999}, {'accuracy': 0.9816400000000002}, {'accuracy': 0.9818}, {'accuracy': 0.98145}, {'accuracy': 0.98171}, {'accuracy': 0.9818200000000001}, {'accuracy': 0.9816100000000001}, {'accuracy': 0.9815800000000001}, {'accuracy': 0.98123}, {'accuracy': 0.98152}, {'accuracy': 0.9815699999999999}, {'accuracy': 0.9815299999999999}, {'accuracy': 0.98148}, {'accuracy': 0.9818999999999999}, {'accuracy': 0.98155}, {'accuracy': 0.98173}, {'accuracy': 0.9812900000000001}, {'accuracy': 0.98146}, {'accuracy': 0.9814299999999999}, {'accuracy': 0.98187}, {'accuracy': 0.9817300000000001}, {'accuracy': 0.9817400000000001}, {'accuracy': 0.9814999999999999}, {'accuracy': 0.98171}, {'accuracy': 0.9819199999999999}, {'accuracy': 0.982}, {'accuracy': 0.98209}, {'accuracy': 0.9819399999999998}, {'accuracy': 0.98193}, {'accuracy': 0.9816800000000001}, {'accuracy': 0.98153}, {'accuracy': 0.98163}, {'accuracy': 0.9818300000000001}, {'accuracy': 0.9819700000000001}, {'accuracy': 0.9819199999999999}, {'accuracy': 0.9818199999999999}, {'accuracy': 0.98162}, {'accuracy': 0.9816999999999998}, {'accuracy': 0.9822200000000001}, {'accuracy': 0.9818399999999998}, {'accuracy': 0.9820500000000001}, {'accuracy': 0.9820399999999999}, {'accuracy': 0.9817600000000001}, {'accuracy': 0.98178}, {'accuracy': 0.9821399999999999}, {'accuracy': 0.9821799999999999}, {'accuracy': 0.98216}, {'accuracy': 0.9826900000000001}, {'accuracy': 0.98178}, {'accuracy': 0.9818}, {'accuracy': 0.98216}, {'accuracy': 0.98245}, {'accuracy': 0.9822900000000001}, {'accuracy': 0.98199}, {'accuracy': 0.98201}, {'accuracy': 0.98164}, {'accuracy': 0.98231}, {'accuracy': 0.98245}, {'accuracy': 0.98245}, {'accuracy': 0.9822399999999998}, {'accuracy': 0.9822000000000001}, {'accuracy': 0.9822599999999999}, {'accuracy': 0.9824299999999999}, {'accuracy': 0.9822000000000001}, {'accuracy': 0.9821300000000001}, {'accuracy': 0.98216}, {'accuracy': 0.98194}, {'accuracy': 0.9821400000000002}, {'accuracy': 0.98192}, {'accuracy': 0.9826400000000002}, {'accuracy': 0.9827199999999999}, {'accuracy': 0.98253}, {'accuracy': 0.98277}, {'accuracy': 0.9823299999999999}, {'accuracy': 0.98242}, {'accuracy': 0.9824300000000001}, {'accuracy': 0.9819599999999999}, {'accuracy': 0.9823000000000001}, {'accuracy': 0.98249}, {'accuracy': 0.98223}, {'accuracy': 0.98247}, {'accuracy': 0.9824999999999999}, {'accuracy': 0.9824400000000001}, {'accuracy': 0.98231}, {'accuracy': 0.9825299999999999}, {'accuracy': 0.9827299999999999}, {'accuracy': 0.9827400000000001}, {'accuracy': 0.9827900000000002}, {'accuracy': 0.9824400000000001}, {'accuracy': 0.9827600000000001}, {'accuracy': 0.98231}, {'accuracy': 0.9831}, {'accuracy': 0.9830900000000001}, {'accuracy': 0.9829800000000001}, {'accuracy': 0.9826}, {'accuracy': 0.98235}, {'accuracy': 0.98293}, {'accuracy': 0.9829399999999999}, {'accuracy': 0.9824400000000001}, {'accuracy': 0.98262}, {'accuracy': 0.9825900000000001}, {'accuracy': 0.9829799999999999}, {'accuracy': 0.9827200000000001}, {'accuracy': 0.9823599999999999}, {'accuracy': 0.98309}]\n"
     ]
    }
   ],
   "source": [
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=CNNmnist(),\n",
    "        optimizer= torch.optim.SGD,\n",
    "        optimizer_params = {\n",
    "            \"lr\": 0.01,\n",
    "            \"weight_decay\": 0.001\n",
    "        },\n",
    "        criterion = F.cross_entropy, \n",
    "        #loss function\n",
    "        create_model_mode= CreateModelMode.MERGE_UPDATE,\n",
    "        batch_size= 50,\n",
    "        local_epochs= 3),\n",
    "    round_len=100,\n",
    "    sync=False,\n",
    "    n_sampled= 9,\n",
    "    m_top= 9,\n",
    "    step1_rounds= 1)\n",
    "\n",
    "simulator = GossipSimulator(\n",
    "    nodes = nodes,\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    delta=100,\n",
    "    protocol=AntiEntropyProtocol.PUSH,\n",
    "    sampling_eval=1\n",
    ")\n",
    "\n",
    "report = SimulationReport()\n",
    "simulator.add_receiver(report)\n",
    "simulator.init_nodes(seed=50)\n",
    "simulator.start(n_rounds=300)\n",
    "\n",
    "print([ev for _, ev in report.get_evaluation(False)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "054e7a28-741d-4173-92dc-00b98386b953",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"color: #7fbfbf; text-decoration-color: #7fbfbf\">                </span><span style=\"color: #000080; text-decoration-color: #000080\">INFO    </span> accuracy: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.98</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:172</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.98\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m172\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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EhgEnXfeeUhPT8eiRYuU+yxatAiDBg3CCSecAADYvXs3hBB47LHHkJ2drfmaNWsWAKCkpETzPD169Ah67oaGBsycOVOpecnKykJ2djaqqqpQXV3dxlfeMrt27cKSJUuC2j927FhN+++44w6ccMIJOP/889GlSxfceOONWLJkyTE/v8FgUGqP1G2qrq5GTk5OULvq6uqUNo0aNQpXXnklHn/8cWRlZeHSSy/Fm2++CbvdfsztOpo5c+Zg69atKCgowLBhw/DnP/8Zv/32W8SflyjaWHND1A6lp6ejU6dO2Lx5c7P327x5Mzp37oy0tDQAgNlsxmWXXYaPPvoIL7/8MoqLi7F69Wo89dRTymPkgtv7778f48ePD3ne3r17a75XZ2lkd911F958803ce++9GD58ONLT0yFJEq699tqgot5w83g8OPfcc/Hggw+GvF0O5HJycrBp0yYsXboUX3zxBb744gu8+eabmDRpEt566602P7/ZbIZOp/3b0OPxICcnB++8807Ix8hF4ZIkYfHixfj+++/x2WefYenSpbjxxhvx3HPP4fvvv0dKSkqTi/K53e42txkArrnmGowcORIfffQRvvzySzz77LN45pln8OGHH+L8888/pnMTtScMbojaqYsuugivv/46vvvuO4wYMSLo9m+//RaFhYW49dZbNccnTJiAt956C8uXL8e2bdsghFCGpAAo08aNRqOS6WiLxYsXY/LkyXjuueeUY42NjaiqqmrzOQM11cn36tULdXV1LWq/yWTCxRdfjIsvvhgejwd33HEHXn31VTz22GPo3bt32Fb37dWrF7766iuceeaZIYPBQKeffjpOP/10PPnkk3j33Xdx3XXXYeHChZg6dSoyMzMBIOha7tu3r0Vtae41derUCXfccQfuuOMOlJSUYPDgwXjyyScZ3FBc4bAUUTv1wAMPwGq14tZbb0V5ebnmtoqKCtx2221ISkrCAw88oLlt7Nix6NChAxYtWoRFixZh2LBhmmGlnJwcnH322Xj11Vdx5MiRoOctLS1tUfv0ej2EEJpjL7zwwjFnF9SSk5NDBkvXXHMN1q5di6VLlwbdVlVVBZfLBQBB102n02HAgAEAoAwDyevTHGtQds0118DtduOJJ54Ius3lcinnr6ysDLpugwYN0rSpW7du0Ov1Su2Q7OWXX25RW0JdN7fbHTRcmJOTg/z8/KgMiRFFEzM3RO1Unz598NZbb+G6665D//79cdNNN6FHjx4oLCzEv/71L5SVleG9995TpvnKjEYjrrjiCixcuBA2mw1/+9vfgs790ksvYcSIEejfvz9uvvlm9OzZE8XFxVi7di0OHjyIn3/++ajtu+iii/Dvf/8b6enpOPnkk7F27Vp89dVX6NixY9iuwZAhQ/DKK6/gr3/9K3r37o2cnByMHj0aDzzwAD799FNcdNFFuOGGGzBkyBDYbDZs2bIFixcvRmFhIbKysjB16lRUVFRg9OjR6NKlC/bt24cXXngBgwYNUqZ7Dxo0CHq9Hs888wyqq6thNpsxevRo5OTktKqto0aNwq233orZs2dj06ZNGDduHIxGI3bt2oUPPvgAzz//PK666iq89dZbePnll3H55ZejV69eqK2txeuvv460tDRccMEFALzDkldffTVeeOEFSJKEXr164b///W9QLVRz1+2rr77C3LlzkZ+fjx49eqBv377o0qULrrrqKgwcOBApKSn46quvsG7dOk32jSguxHayFhEdzebNm8XEiRNFp06dhNFoFHl5eWLixIliy5YtTT5m2bJlAoCQJEkcOHAg5H327NkjJk2aJPLy8oTRaBSdO3cWF110kVi8eLFyH3kqeKhpy5WVlWLKlCkiKytLpKSkiPHjx4vt27eLbt26aaYhH8tU8KKiInHhhReK1NRUAUAzLby2tlbMmDFD9O7dW5hMJpGVlSXOOOMM8be//U04HA4hhBCLFy8W48aNEzk5OcJkMomuXbuKW2+9VRw5ckTzPK+//rro2bOn0Ov1R50WPnnyZJGcnNzk7a+99poYMmSIsFqtIjU1VfTv3188+OCD4vDhw0IIITZu3CgmTpwounbtKsxms8jJyREXXXSRWL9+veY8paWl4sorrxRJSUkiMzNT3HrrrWLr1q0tmgq+fft2cdZZZwmr1SoAiMmTJwu73S4eeOABMXDgQJGamiqSk5PFwIEDxcsvv9zcW0B0XJKECMiPEhERER3HWHNDREREcYXBDREREcUVBjdEREQUVxjcEBERUVxhcENERERxhcENERERxZWEW8TP4/Hg8OHDSE1NDduy60RERBRZQgjU1tYiPz8/aG+3QAkX3Bw+fBgFBQWxbgYRERG1wYEDB9ClS5dm75NwwU1qaioA78WRd1ImIiKi9q2mpgYF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uSgoKMArr7yCSy65BLt27cL3338fiTYet7i3FBERUfS1OnOTm5uLzMxMTJgwAbNnz8bQoUMj0a64wL2liIiIoq/Vwc2nn36KMWPGaNafodAY3BAREUVfq4Obc889NxLtiEvcOJOIiCj62OtGEGdLERERRR973QhysqCYiIgo6tjrRpCdNTdERERRx143glhQTEREFH2t7nXvvvtu/OMf/wg6/uKLL+Lee+8NR5viBhfxIyIiir5W97r/93//hzPPPDPo+BlnnIHFixeHpVHxQi4o5t5SRERE0dPqXre8vBzp6elBx9PS0lBWVhaWRsWLBocbAGA16WPcEiIiosTR6uCmd+/eWLJkSdDxL774Aj179gxLo+JFo9MX3BgZ3BAREUVLqxfxmz59OqZNm4bS0lJlF/Dly5fjueeew7x588LdvuNaA4MbIiKiqGt1cHPjjTfCbrfjySefxBNPPAEA6N69O1555RVMmjQp7A08njU6vTU3Fg5LERERRU2rgxsAuP3223H77bejtLQUVqsVKSkp4W5XXJAzNxYDgxsiIqJoaVNwI8vOzg5XO+JSIwuKiYiIoq5Fwc3gwYOxfPlyZGZm4tRTT4UkSU3ed+PGjWFr3PGONTdERETR16Lg5tJLL4XZbAYAXHbZZZFsT9xwuj1weQQABjdERETR1KLgZtasWQAAt9uNc845BwMGDEBGRkYk23Xck7M2AGAxcRE/IiKiaGlVr6vX6zFu3DhUVlZGqj1xQ17jRpK4KzgREVE0tbrX7devH3777bdItCWuNDq808CtRn2zNUpEREQUXq0Obv7617/i/vvvx3//+18cOXIENTU1mi/yYjExERFRbLR6KvgFF1wAALjkkks0GQkhBCRJgtvtbuqhCUVZ44bBDRERUVS1OrhZsWJFJNoRd7hpJhERUWy0Orjp0aMHCgoKgupIhBA4cOBA2Bp2vGt0cViKiIgoFlpdc9OjRw+UlpYGHa+oqECPHj3C0qh4IK9ObDFyphQREVE0tbrnlWtrAtXV1cFisYSlUfGANTdERESx0eJhqenTpwMAJEnCY489hqSkJOU2t9uNH374AYMGDQp7A49XnC1FREQUGy0Obn766ScA3szNli1bYDKZlNtMJhMGDhyI+++/P/wtPE6xoJiIiCg2WhzcyLOkpkyZgueffx5paWkRa1Q8sLv8i/gRERFR9LS65ubNN99EWloadu/ejaVLl6KhoQGAN6NDfg0O1twQERHFQquDm4qKCowZMwYnnHACLrjgAhw5cgQAcNNNN+GPf/xj2Bt4vGJBMRERUWy0Ori59957YTQasX//fk1R8YQJE7BkyZKwNu54xoJiIiKi2Gj1In5ffvklli5dii5dumiO9+nTB/v27Qtbw453jUpBMde5ISIiiqZW97w2m02TsZFVVFTAbDaHpVHxgCsUExERxUarg5uRI0fi7bffVr6XJAkejwdz5szBOeecE9bGHc/kgmIzgxsiIqKoavWw1Jw5czBmzBisX78eDocDDz74IH755RdUVFRg9erVkWjjcYk1N0RERLHR6sxNv379sHPnTowYMQKXXnopbDYbrrjiCvz000/o1atXJNp4XGpwcp0bIiKiWGh15gYA0tPT8cgjj4S7LXGlkSsUExERxUSbgpvGxkZs3rwZJSUl8Hg8mtsuueSSsDTseMd1boiIiGKj1cHNkiVLMGnSJJSVlQXdJkkS3G53WBp2vGtUghtOBSciIoqmVve8d911F66++mocOXIEHo9H88XAxo8FxURERLHR6uCmuLgY06dPR25ubiTaEzfkzA1rboiIiKKr1cHNVVddhZUrV0agKfHD6fbA6fZuJMrMDRERUXS1uubmxRdfxNVXX41vv/0W/fv3h9Fo1Nx+9913h61xxys5awOwoJiIiCjaWh3cvPfee/jyyy9hsViwcuVKSJKk3CZJEoMbAI2+NW4kCTAbWFBMREQUTa0Obh555BE8/vjjePjhh6HTseMORZkpZdBrgj8iIiKKvFZHJw6HAxMmTGBg04wGFhMTERHFTKsjlMmTJ2PRokWRaEvckDfNtHBIioiIKOpaPSzldrsxZ84cLF26FAMGDAgqKJ47d27YGne8crq9NTcmBjdERERR1+rgZsuWLTj11FMBAFu3btXcxvoSL3kauFHP4IaIiCjaWh3crFixIhLtiCty5obBDRERUfSx940Af3DDTBYREVG0MbiJAGZuiIiIYoe9bwSw5oaIiCh22PtGgJK54WwpIiKiqGPvGwHKVHDW3BAREUUdg5sIcPiGpQxcxZmIiCjq2PtGgNPFYSkiIqJYYe8bAS4Pp4ITERHFCoObCJBnS5k4W4qIiCjq2PtGgMM3LGVg5oaIiCjqGNxEABfxIyIiih32vhHgnwrOy0tERBRt7aL3femll9C9e3dYLBacdtpp+PHHH1v0uIULF0KSJFx22WWRbWArcYViIiKi2Il577to0SJMnz4ds2bNwsaNGzFw4ECMHz8eJSUlzT6usLAQ999/P0aOHBmllrYch6WIiIhiJ+a979y5c3HzzTdjypQpOPnkkzF//nwkJSXhjTfeaPIxbrcb1113HR5//HH07Nkziq1tGTm4YUExERFR9MU0uHE4HNiwYQPGjh2rHNPpdBg7dizWrl3b5OP+8pe/ICcnBzfddNNRn8Nut6OmpkbzFWmcCk5ERBQ7Me19y8rK4Ha7kZubqzmem5uLoqKikI/57rvv8K9//Quvv/56i55j9uzZSE9PV74KCgqOud1H43BzET8iIqJYOa5SC7W1tbj++uvx+uuvIysrq0WPmTFjBqqrq5WvAwcORLiVgIu7ghMREcWMIZZPnpWVBb1ej+LiYs3x4uJi5OXlBd1/z549KCwsxMUXX6wc8/i2OjAYDNixYwd69eqleYzZbIbZbI5A65vG2VJERESxE9Pe12QyYciQIVi+fLlyzOPxYPny5Rg+fHjQ/U888URs2bIFmzZtUr4uueQSnHPOOdi0aVNUhpxawslhKSIiopiJaeYGAKZPn47Jkydj6NChGDZsGObNmwebzYYpU6YAACZNmoTOnTtj9uzZsFgs6Nevn+bxGRkZABB0PJbk7ReYuSEiIoq+mAc3EyZMQGlpKWbOnImioiIMGjQIS5YsUYqM9+/fD53u+AoSuM4NERFR7EhCCBHrRkRTTU0N0tPTUV1djbS0tIg8xyUvfofNB6vx5g2/wzkn5kTkOYiIiBJJa/pvphYigMNSREREscPeNwK4QjEREVHsMLiJAE4FJyIiih32vhEgZ264/QIREVH0sfeNACVzY+CwFBERUbQxuIkATgUnIiKKHfa+EaAEN8fZ+jxERETxgL1vBCjBDYeliIiIoo7BTZgJIThbioiIKIbY+4aZy+Nf8JnBDRERUfSx9w0zeUgK4FRwIiKiWGDvG2ZOlz9zwxWKiYiIoo/BTZg5VJkbg47BDRERUbQxuAkz9erEksTghoiIKNoY3ISZS5kpxcCGiIgoFhjchJlDWeOGl5aIiCgW2AOHmTwsZeDqxERERDHBHjjM/DU3HJYiIiKKBQY3YebksBQREVFMsQcOM269QEREFFvsgcNMydwwuCEiIooJ9sBh5g9uWHNDREQUCwxuwszh4rAUERFRLLEHDjNmboiIiGKLwU2YuTysuSEiIool9sBhJu8KbmJwQ0REFBPsgcNM3n7BwGEpIiKimGBwE2acCk5ERBRb7IHDzL/9Ai8tERFRLLAHDjOuUExERBRb7IHDzL+3FGtuiIiIYoHBTZjJwY1Bx0tLREQUC+yBw0weljJxV3AiIqKYYA8cZlyhmIiIKLYY3IQZp4ITERHFFnvgMHNy40wiIqKYYg8cZhyWIiIiii0GN2Hm4LAUERFRTLEHDjMXF/EjIiKKKfbAYcbtF4iIiGKLPXCYcVdwIiKi2GJwE2YOly9zw0X8iIiIYoI9cJhxWIqIiCi22AOHmTJbipkbIiKimGAPHGbyIn7M3BAREcUGe+AwkzM3rLkhIiKKDfbAYSYXFHOdGyIiothgDxxmDhYUExERxRR74DBTZksZuM4NERFRLDC4CTNlnRu9PsYtISIiSkwMbsJM2RWcmRsiIqKYYHATRh6PgNPNqeBERESxxB44jJwej/J/LuJHREQUG+yBw0jO2gDM3BAREcUKe+AwkouJAa5zQ0REFCvsgcNILibW6yTodSwoJiIiigUGN2HknwbOy0pERBQr7IXDSNkRXM+sDRERUawwuAkjJXNj4AJ+REREscLgJoyUrReYuSEiIooZBjdh5M/c8LISERHFCnvhMPLX3PCyEhERxQp74TCSMzcMboiIiGKHvXAYKftKcViKiIgoZtgLh5G/oJiXlYiIKFbYC4cRC4qJiIhij71wGHERPyIiothrF8HNSy+9hO7du8NiseC0007Djz/+2OR9X3/9dYwcORKZmZnIzMzE2LFjm71/NDFzQ0REFHsx74UXLVqE6dOnY9asWdi4cSMGDhyI8ePHo6SkJOT9V65ciYkTJ2LFihVYu3YtCgoKMG7cOBw6dCjKLQ/m5FRwIiKimIt5Lzx37lzcfPPNmDJlCk4++WTMnz8fSUlJeOONN0Le/5133sEdd9yBQYMG4cQTT8Q///lPeDweLF++PMotD8aNM4mIiGIvpr2ww+HAhg0bMHbsWOWYTqfD2LFjsXbt2hado76+Hk6nEx06dIhUM1tMmS3FYSkiIqKYMcTyycvKyuB2u5Gbm6s5npubi+3bt7foHA899BDy8/M1AZKa3W6H3W5Xvq+pqWl7g4+Ci/gRERHF3nHdCz/99NNYuHAhPvroI1gslpD3mT17NtLT05WvgoKCiLXHwUX8iIiIYi6mvXBWVhb0ej2Ki4s1x4uLi5GXl9fsY//2t7/h6aefxpdffokBAwY0eb8ZM2agurpa+Tpw4EBY2h4KMzdERESxF9Ne2GQyYciQIZpiYLk4ePjw4U0+bs6cOXjiiSewZMkSDB06tNnnMJvNSEtL03xFCmtuiIiIYi+mNTcAMH36dEyePBlDhw7FsGHDMG/ePNhsNkyZMgUAMGnSJHTu3BmzZ88GADzzzDOYOXMm3n33XXTv3h1FRUUAgJSUFKSkpMTsdQDq7Re4iB8REVGsxDy4mTBhAkpLSzFz5kwUFRVh0KBBWLJkiVJkvH//fuh0/kzIK6+8AofDgauuukpznlmzZuHPf/5zNJsehIv4ERERxV7MgxsAmDZtGqZNmxbytpUrV2q+LywsjHyD2sjBRfyIiIhijr1wGLGgmIiIKPbYC4cRC4qJiIhij71wGDnc3H6BiIgo1tgLh5HTxUX8iIiIYo29cBjZWVBMREQUc+yFw8jJqeBEREQx1y6mgscL/1RwLuJHRBQrQgi4XC643e5YN4VayWg0Qq/XH/N5GNyEkTxbyszMDRFRTDgcDhw5cgT19fWxbgq1gSRJ6NKlyzHvOMDgJoy4zg0RUex4PB7s3bsXer0e+fn5MJlMkCRm0o8XQgiUlpbi4MGD6NOnzzFlcBjchJGTBcVERDHjcDjg8XhQUFCApKSkWDeH2iA7OxuFhYVwOp3HFNywFw4j7i1FRBR76v0I6fgSrkwbPwFhxEX8iIiIYo+9cBg53VzEj4iIKNbYC4eJ2yPg9niDG9bcEBERxQ574TCRi4kBZm6IiOj453Q6Y92ENmMvHCZ2lz+44SJ+RETUWkuWLMGIESOQkZGBjh074qKLLsKePXuU2w8ePIiJEyeiQ4cOSE5OxtChQ/HDDz8ot3/22Wf43e9+B4vFgqysLFx++eXKbZIk4eOPP9Y8X0ZGBhYsWAAAKCwshCRJWLRoEUaNGgWLxYJ33nkH5eXlmDhxIjp37oykpCT0798f7733nuY8Ho8Hc+bMQe/evWE2m9G1a1c8+eSTAIDRo0dj2rRpmvuXlpbCZDJh+fLl4bhsIXEqeJioMzdGVuoTEbULQgg0OGOzUrHVqG/V7B+bzYbp06djwIABqKurw8yZM3H55Zdj06ZNqK+vx6hRo9C5c2d8+umnyMvLw8aNG+HxePuezz//HJdffjkeeeQRvP3223A4HPjf//7X6jY//PDDeO6553DqqafCYrGgsbERQ4YMwUMPPYS0tDR8/vnnuP7669GrVy8MGzYMADBjxgy8/vrr+Pvf/44RI0bgyJEj2L59OwBg6tSpmDZtGp577jmYzWYAwH/+8x907twZo0ePbnX7WorBTZj4F/CToNMxc0NE1B40ON04eebSmDz3r38ZjyRTy7vZK6+8UvP9G2+8gezsbPz6669Ys2YNSktLsW7dOnTo0AEA0Lt3b+W+Tz75JK699lo8/vjjyrGBAwe2us333nsvrrjiCs2x+++/X/n/XXfdhaVLl+L999/HsGHDUFtbi+effx4vvvgiJk+eDADo1asXRowYAQC44oorMG3aNHzyySe45pprAAALFizADTfcENEFFpliCBMu4EdERMdi165dmDhxInr27Im0tDR0794dALB//35s2rQJp556qhLYBNq0aRPGjBlzzG0YOnSo5nu3240nnngC/fv3R4cOHZCSkoKlS5di//79AIBt27bBbrc3+dwWiwXXX3893njjDQDAxo0bsXXrVtxwww3H3NbmMHMTJlzAj4io/bEa9fj1L+Nj9tytcfHFF6Nbt254/fXXkZ+fD4/Hg379+sHhcMBqtTb/XEe5XZIkCCE0x0IVDCcnJ2u+f/bZZ/H8889j3rx56N+/P5KTk3HvvffC4XC06HkB79DUoEGDcPDgQbz55psYPXo0unXrdtTHHQv2xGHiYOaGiKjdkSQJSSZDTL5aM+xSXl6OHTt24NFHH8WYMWNw0kknobKyUrl9wIAB2LRpEyoqKkI+fsCAAc0W6GZnZ+PIkSPK97t27WrR5qKrV6/GpZdeij/84Q8YOHAgevbsiZ07dyq39+nTB1artdnn7t+/P4YOHYrXX38d7777Lm688cajPu+xYk8cJsoCfgxuiIiolTIzM9GxY0e89tpr2L17N77++mtMnz5duX3ixInIy8vDZZddhtWrV+O3337D//3f/2Ht2rUAgFmzZuG9997DrFmzsG3bNmzZsgXPPPOM8vjRo0fjxRdfxE8//YT169fjtttug9FoPGq7+vTpg2XLlmHNmjXYtm0bbr31VhQXFyu3WywWPPTQQ3jwwQfx9ttvY8+ePfj+++/xr3/9S3OeqVOn4umnn4YQQjOLK1LYE4eJ2yOQZNIjydT2jb6IiCgx6XQ6LFy4EBs2bEC/fv1w33334dlnn1VuN5lM+PLLL5GTk4MLLrgA/fv3x9NPP61sLnn22Wfjgw8+wKeffopBgwZh9OjR+PHHH5XHP/fccygoKMDIkSPx+9//Hvfff3+LNhd99NFHMXjwYIwfPx5nn322EmCpPfbYY/jjH/+ImTNn4qSTTsKECRNQUlKiuc/EiRNhMBgwceJEWCyWY7hSLSOJwEG4OFdTU4P09HRUV1cjLS0t1s0hIqIwaWxsxN69e9GjR4+odKDUcoWFhejVqxfWrVuHwYMHN3m/5t7D1vTfLCgmIiKiiHA6nSgvL8ejjz6K008/vdnAJpw4LEVEREQRsXr1anTq1Anr1q3D/Pnzo/a8zNwQERFRRJx99tlBU9CjgZkbIiIiiisMboiIiCiuMLghIqK4kmCTgONKuN47BjdERBQX5EXpWrLyLrVP8rYO8vo9bcWCYiIiigt6vR4ZGRnKAnJJSUkR3Xmawsvj8aC0tBRJSUkwGI4tPGFwQ0REcSMvLw8AglbIpeODTqdD165djzkoZXBDRERxQ5IkdOrUCTk5OSF3vab2zWQyQac79ooZBjdERBR39Hr9Mddt0PGLBcVEREQUVxjcEBERUVxhcENERERxJeFqbuQFgmpqamLcEiIiImopud9uyUJ/CRfc1NbWAgAKCgpi3BIiIiJqrdraWqSnpzd7H0kk2DrVHo8Hhw8fRmpqatgWd6qpqUFBQQEOHDiAtLS0sJwznvF6tRyvVevwerUcr1XL8Vq1TqSulxACtbW1yM/PP+p08YTL3Oh0OnTp0iUi505LS+MHvxV4vVqO16p1eL1ajteq5XitWicS1+toGRsZC4qJiIgorjC4ISIiorjC4CYMzGYzZs2aBbPZHOumHBd4vVqO16p1eL1ajteq5XitWqc9XK+EKygmIiKi+MbMDREREcUVBjdEREQUVxjcEBERUVxhcENERERxhcFNGLz00kvo3r07LBYLTjvtNPz444+xblLM/fnPf4YkSZqvE088Ubm9sbERd955Jzp27IiUlBRceeWVKC4ujmGLo+ebb77BxRdfjPz8fEiShI8//lhzuxACM2fORKdOnWC1WjF27Fjs2rVLc5+Kigpcd911SEtLQ0ZGBm666SbU1dVF8VVEz9Gu1w033BD0WTvvvPM090mU6zV79mz87ne/Q2pqKnJycnDZZZdhx44dmvu05Gdv//79uPDCC5GUlIScnBw88MADcLlc0XwpEdeSa3X22WcHfbZuu+02zX0S4VoBwCuvvIIBAwYoC/MNHz4cX3zxhXJ7e/tcMbg5RosWLcL06dMxa9YsbNy4EQMHDsT48eNRUlIS66bF3CmnnIIjR44oX999951y23333YfPPvsMH3zwAVatWoXDhw/jiiuuiGFro8dms2HgwIF46aWXQt4+Z84c/OMf/8D8+fPxww8/IDk5GePHj0djY6Nyn+uuuw6//PILli1bhv/+97/45ptvcMstt0TrJUTV0a4XAJx33nmaz9p7772nuT1RrteqVatw55134vvvv8eyZcvgdDoxbtw42Gw25T5H+9lzu9248MIL4XA4sGbNGrz11ltYsGABZs6cGYuXFDEtuVYAcPPNN2s+W3PmzFFuS5RrBQBdunTB008/jQ0bNmD9+vUYPXo0Lr30Uvzyyy8A2uHnStAxGTZsmLjzzjuV791ut8jPzxezZ8+OYatib9asWWLgwIEhb6uqqhJGo1F88MEHyrFt27YJAGLt2rVRamH7AEB89NFHyvcej0fk5eWJZ599VjlWVVUlzGazeO+994QQQvz6668CgFi3bp1yny+++EJIkiQOHToUtbbHQuD1EkKIyZMni0svvbTJxyTy9SopKREAxKpVq4QQLfvZ+9///id0Op0oKipS7vPKK6+ItLQ0Ybfbo/sCoijwWgkhxKhRo8Q999zT5GMS9VrJMjMzxT//+c92+bli5uYYOBwObNiwAWPHjlWO6XQ6jB07FmvXro1hy9qHXbt2IT8/Hz179sR1112H/fv3AwA2bNgAp9OpuW4nnngiunbtmvDXbe/evSgqKtJcm/T0dJx22mnKtVm7di0yMjIwdOhQ5T5jx46FTqfDDz/8EPU2twcrV65ETk4O+vbti9tvvx3l5eXKbYl8vaqrqwEAHTp0ANCyn721a9eif//+yM3NVe4zfvx41NTUKH+lx6PAayV75513kJWVhX79+mHGjBmor69XbkvUa+V2u7Fw4ULYbDYMHz68XX6uEm7jzHAqKyuD2+3WvFkAkJubi+3bt8eoVe3DaaedhgULFqBv3744cuQIHn/8cYwcORJbt25FUVERTCYTMjIyNI/Jzc1F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gerq6nDrrbfi7rvvDrqta9eurToXEbUvzNwQUbvRp08fWK1WpUA4UP/+/TF06FC8/vrrePfdd3HjjTdqbvN4PFi1alWLnmvw4MH49ddf0bt376Avk8kUltdDRLHB4IaI2g2LxYKHHnoIDz74IN5++23s2bMH33//vWbG09SpU/H0009DCIHLL79cOd69e3dMnjwZN954Iz7++GPs3bsXK1euxPvvvx/yuR566CGsWbMG06ZNw6ZNm7Br1y588sknLCgmigMMboioXXnsscfwxz/+ETNnzsRJJ52ECRMmoKSkRLl94sSJMBgMmDhxYlDR7yuvvIKrrroKd9xxB0488UTcfPPNTU7tHjBgAFatWoWdO3di5MiROPXUUzFz5kzk5+dH9PURUeRxthQRHVcKCwvRq1cvrFu3DoMHD451c4ioHWJwQ0THBafTifLyctx///3Yu3cvVq9eHesmEVE7xWEpIjourF69Gp06dcK6deswf/78WDeHiNoxZm6IiIgorjBzQ0RERHGFwQ0RERHFFQY3REREFFcY3BAREVFcYXBDREREcYXBDREREcUVBjdEREQUVxjcEBERUVxhcENERERx5f8BCed1+TCORhIAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_evaluation([[ev for _, ev in report.get_evaluation(False)]], \"Overall test results\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c137896b-470c-4faf-aebe-496ca123f991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.12779000000000001}, {'accuracy': 0.28007}, {'accuracy': 0.44957}, {'accuracy': 0.54974}, {'accuracy': 0.6949500000000001}, {'accuracy': 0.66503}, {'accuracy': 0.65408}, {'accuracy': 0.68903}, {'accuracy': 0.74741}, {'accuracy': 0.75889}, {'accuracy': 0.7811800000000001}, {'accuracy': 0.8292400000000001}, {'accuracy': 0.86883}, {'accuracy': 0.8280899999999999}, {'accuracy': 0.8266399999999999}, {'accuracy': 0.86144}, {'accuracy': 0.8684}, {'accuracy': 0.82392}, {'accuracy': 0.82013}, {'accuracy': 0.81419}, {'accuracy': 0.84045}, {'accuracy': 0.8450799999999999}, {'accuracy': 0.86058}, {'accuracy': 0.83058}, {'accuracy': 0.8999699999999999}, {'accuracy': 0.8671499999999999}, {'accuracy': 0.88072}, {'accuracy': 0.84955}, {'accuracy': 0.79036}, {'accuracy': 0.8531599999999999}, {'accuracy': 0.87607}, {'accuracy': 0.85068}, {'accuracy': 0.81375}, {'accuracy': 0.8499699999999999}, {'accuracy': 0.8678699999999999}, {'accuracy': 0.86584}, {'accuracy': 0.88506}, {'accuracy': 0.83618}, {'accuracy': 0.87257}, {'accuracy': 0.90334}, {'accuracy': 0.91663}, {'accuracy': 0.8509500000000001}, {'accuracy': 0.8566100000000001}, {'accuracy': 0.83065}, {'accuracy': 0.7355799999999999}, {'accuracy': 0.84867}, {'accuracy': 0.8479999999999999}, {'accuracy': 0.88039}, {'accuracy': 0.92721}, {'accuracy': 0.8607100000000001}, {'accuracy': 0.90703}, {'accuracy': 0.9354699999999999}, {'accuracy': 0.84246}, {'accuracy': 0.88737}, {'accuracy': 0.8602200000000002}, {'accuracy': 0.83694}, {'accuracy': 0.8161900000000001}, {'accuracy': 0.84414}, {'accuracy': 0.8924199999999999}, {'accuracy': 0.8914799999999999}, {'accuracy': 0.8556999999999999}, {'accuracy': 0.9135}, {'accuracy': 0.79365}, {'accuracy': 0.8352299999999999}, {'accuracy': 0.8568300000000001}, {'accuracy': 0.9352300000000001}, {'accuracy': 0.85664}, {'accuracy': 0.8912800000000001}, {'accuracy': 0.8546000000000001}, {'accuracy': 0.8742599999999999}, {'accuracy': 0.8899199999999998}, {'accuracy': 0.8230299999999999}, {'accuracy': 0.8693}, {'accuracy': 0.8937999999999999}, {'accuracy': 0.9343300000000001}, {'accuracy': 0.8387100000000001}, {'accuracy': 0.8922399999999999}, {'accuracy': 0.8904100000000001}, {'accuracy': 0.8048}, {'accuracy': 0.84454}, {'accuracy': 0.82386}, {'accuracy': 0.86072}, {'accuracy': 0.8816}, {'accuracy': 0.88826}, {'accuracy': 0.85674}, {'accuracy': 0.9088200000000001}, {'accuracy': 0.91507}, {'accuracy': 0.8782900000000001}, {'accuracy': 0.8880500000000001}, {'accuracy': 0.8380599999999999}, {'accuracy': 0.8727199999999999}, {'accuracy': 0.84474}, {'accuracy': 0.9205499999999999}, {'accuracy': 0.81349}, {'accuracy': 0.88208}, {'accuracy': 0.89796}, {'accuracy': 0.8353499999999998}, {'accuracy': 0.8949400000000001}, {'accuracy': 0.8456400000000001}, {'accuracy': 0.85808}, {'accuracy': 0.8691699999999999}, {'accuracy': 0.8103899999999999}, {'accuracy': 0.8748099999999999}, {'accuracy': 0.91526}, {'accuracy': 0.75512}, {'accuracy': 0.7971199999999999}, {'accuracy': 0.8710000000000001}, {'accuracy': 0.75326}, {'accuracy': 0.7324499999999999}, {'accuracy': 0.9384099999999999}, {'accuracy': 0.8401400000000001}, {'accuracy': 0.87073}, {'accuracy': 0.8840399999999999}, {'accuracy': 0.8352}, {'accuracy': 0.80715}, {'accuracy': 0.8311499999999998}, {'accuracy': 0.85379}, {'accuracy': 0.8815000000000002}, {'accuracy': 0.8159000000000001}, {'accuracy': 0.77363}, {'accuracy': 0.83809}, {'accuracy': 0.8957200000000001}, {'accuracy': 0.8569300000000002}, {'accuracy': 0.73149}, {'accuracy': 0.87974}, {'accuracy': 0.8491800000000002}, {'accuracy': 0.90845}, {'accuracy': 0.82508}, {'accuracy': 0.8239999999999998}, {'accuracy': 0.86645}, {'accuracy': 0.8548}, {'accuracy': 0.88744}, {'accuracy': 0.8960100000000001}, {'accuracy': 0.8522500000000001}, {'accuracy': 0.87226}, {'accuracy': 0.8373200000000001}, {'accuracy': 0.87767}, {'accuracy': 0.85078}, {'accuracy': 0.88789}, {'accuracy': 0.8248099999999999}, {'accuracy': 0.81662}, {'accuracy': 0.86173}, {'accuracy': 0.8714999999999999}, {'accuracy': 0.8673100000000001}, {'accuracy': 0.8745700000000001}, {'accuracy': 0.8697199999999998}, {'accuracy': 0.88468}, {'accuracy': 0.8459800000000002}, {'accuracy': 0.8801}, {'accuracy': 0.83557}, {'accuracy': 0.72197}, {'accuracy': 0.9807300000000001}, {'accuracy': 0.72173}, {'accuracy': 0.9435800000000001}, {'accuracy': 0.98016}, {'accuracy': 0.98072}, {'accuracy': 0.98052}, {'accuracy': 0.98017}, {'accuracy': 0.9803799999999999}, {'accuracy': 0.98041}, {'accuracy': 0.9802499999999998}, {'accuracy': 0.98059}, {'accuracy': 0.9806100000000001}, {'accuracy': 0.9806099999999999}, {'accuracy': 0.9803900000000001}, {'accuracy': 0.98049}, {'accuracy': 0.98078}, {'accuracy': 0.9809300000000001}, {'accuracy': 0.9810400000000001}, {'accuracy': 0.98055}, {'accuracy': 0.9805900000000001}, {'accuracy': 0.98139}, {'accuracy': 0.9811500000000001}, {'accuracy': 0.98066}, {'accuracy': 0.9806900000000001}, {'accuracy': 0.98064}, {'accuracy': 0.9814100000000001}, {'accuracy': 0.9808199999999999}, {'accuracy': 0.98131}, {'accuracy': 0.98131}, {'accuracy': 0.98132}, {'accuracy': 0.98135}, {'accuracy': 0.98142}, {'accuracy': 0.9808600000000001}, {'accuracy': 0.9812299999999998}, {'accuracy': 0.9810999999999999}, {'accuracy': 0.9811500000000001}, {'accuracy': 0.9813299999999998}, {'accuracy': 0.9812999999999998}, {'accuracy': 0.9816499999999999}, {'accuracy': 0.9814200000000002}, {'accuracy': 0.98171}, {'accuracy': 0.9815299999999999}, {'accuracy': 0.9813699999999999}, {'accuracy': 0.9815999999999999}, {'accuracy': 0.9815999999999999}, {'accuracy': 0.9816400000000002}, {'accuracy': 0.9818}, {'accuracy': 0.98145}, {'accuracy': 0.98171}, {'accuracy': 0.9818200000000001}, {'accuracy': 0.9816100000000001}, {'accuracy': 0.9815800000000001}, {'accuracy': 0.98123}, {'accuracy': 0.98152}, {'accuracy': 0.9815699999999999}, {'accuracy': 0.9815299999999999}, {'accuracy': 0.98148}, {'accuracy': 0.9818999999999999}, {'accuracy': 0.98155}, {'accuracy': 0.98173}, {'accuracy': 0.9812900000000001}, {'accuracy': 0.98146}, {'accuracy': 0.9814299999999999}, {'accuracy': 0.98187}, {'accuracy': 0.9817300000000001}, {'accuracy': 0.9817400000000001}, {'accuracy': 0.9814999999999999}, {'accuracy': 0.98171}, {'accuracy': 0.9819199999999999}, {'accuracy': 0.982}, {'accuracy': 0.98209}, {'accuracy': 0.9819399999999998}, {'accuracy': 0.98193}, {'accuracy': 0.9816800000000001}, {'accuracy': 0.98153}, {'accuracy': 0.98163}, {'accuracy': 0.9818300000000001}, {'accuracy': 0.9819700000000001}, {'accuracy': 0.9819199999999999}, {'accuracy': 0.9818199999999999}, {'accuracy': 0.98162}, {'accuracy': 0.9816999999999998}, {'accuracy': 0.9822200000000001}, {'accuracy': 0.9818399999999998}, {'accuracy': 0.9820500000000001}, {'accuracy': 0.9820399999999999}, {'accuracy': 0.9817600000000001}, {'accuracy': 0.98178}, {'accuracy': 0.9821399999999999}, {'accuracy': 0.9821799999999999}, {'accuracy': 0.98216}, {'accuracy': 0.9826900000000001}, {'accuracy': 0.98178}, {'accuracy': 0.9818}, {'accuracy': 0.98216}, {'accuracy': 0.98245}, {'accuracy': 0.9822900000000001}, {'accuracy': 0.98199}, {'accuracy': 0.98201}, {'accuracy': 0.98164}, {'accuracy': 0.98231}, {'accuracy': 0.98245}, {'accuracy': 0.98245}, {'accuracy': 0.9822399999999998}, {'accuracy': 0.9822000000000001}, {'accuracy': 0.9822599999999999}, {'accuracy': 0.9824299999999999}, {'accuracy': 0.9822000000000001}, {'accuracy': 0.9821300000000001}, {'accuracy': 0.98216}, {'accuracy': 0.98194}, {'accuracy': 0.9821400000000002}, {'accuracy': 0.98192}, {'accuracy': 0.9826400000000002}, {'accuracy': 0.9827199999999999}, {'accuracy': 0.98253}, {'accuracy': 0.98277}, {'accuracy': 0.9823299999999999}, {'accuracy': 0.98242}, {'accuracy': 0.9824300000000001}, {'accuracy': 0.9819599999999999}, {'accuracy': 0.9823000000000001}, {'accuracy': 0.98249}, {'accuracy': 0.98223}, {'accuracy': 0.98247}, {'accuracy': 0.9824999999999999}, {'accuracy': 0.9824400000000001}, {'accuracy': 0.98231}, {'accuracy': 0.9825299999999999}, {'accuracy': 0.9827299999999999}, {'accuracy': 0.9827400000000001}, {'accuracy': 0.9827900000000002}, {'accuracy': 0.9824400000000001}, {'accuracy': 0.9827600000000001}, {'accuracy': 0.98231}, {'accuracy': 0.9831}, {'accuracy': 0.9830900000000001}, {'accuracy': 0.9829800000000001}, {'accuracy': 0.9826}, {'accuracy': 0.98235}, {'accuracy': 0.98293}, {'accuracy': 0.9829399999999999}, {'accuracy': 0.9824400000000001}, {'accuracy': 0.98262}, {'accuracy': 0.9825900000000001}, {'accuracy': 0.9829799999999999}, {'accuracy': 0.9827200000000001}, {'accuracy': 0.9823599999999999}, {'accuracy': 0.98309}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b1d25a1-d183-4e82-bbf4-24d4a64cda66",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49eb0aaf-7df8-497b-86ac-24fb6d6bbc85",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4962adf7-d916-4138-9802-9148ab602638",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9a01a27-105c-4a38-bcd6-27a03e934dbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fac72374-f0a5-4f97-9691-af5e04fc2467",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "918b3aa8-d15e-4315-8b2d-bbdc0a8f2ac1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cb9a1753-eba6-4fff-8f0c-b848db8c8440",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5dca1090-8bd5-4211-986c-372e456e7134",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "191e1a43-4cfc-4041-985c-527e0233730f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fc39e27e-4f42-4ab4-ae71-da9a70af4b18",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "26087f83-c09f-4eed-be82-ac0eba9d32d1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d8aa37f6-e28f-4b57-8dde-229e7f7bc2f0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "42e0032e-09a9-4e49-b318-25d0fd942b66",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fc964922-235e-4bcf-81ee-5a917079a003",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ff910897-2664-4b5c-8f86-2fa6c16c476b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f8be1dc8-f65c-45b6-82e3-926d730d4a43",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "86128b32-d414-47c3-9d47-18eb7fa3f03b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "58bff550-23c7-4b6b-ab2a-354186665e8c",
   "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
}
