{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "069b5b1d-3de1-4863-a7ac-12e39dcfab9d",
   "metadata": {},
   "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": null,
   "id": "e0fc255e-e0ac-4394-b469-8db8650215bd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "1e954128-4fd2-47cc-8c67-ab75f6023977",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([50000])\n",
      "5045\n",
      "[[  0 496]\n",
      " [  1 546]\n",
      " [  2 493]\n",
      " [  3 507]\n",
      " [  4 453]\n",
      " [  5 493]\n",
      " [  6 514]\n",
      " [  7 492]\n",
      " [  8 487]\n",
      " [  9 512]]\n",
      "50000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([6, 9, 9,  ..., 9, 1, 1])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "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",
    "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,50000,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": null,
   "id": "12481c9e-2a34-4bc9-b4ee-913ea0159a0a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4890dfaf-46a2-4ab9-8679-4f4575eb1c09",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "4d947770-e271-4f09-8736-8aeb5724a05d",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ba047732-8e7b-4d04-944a-eca0b4a6c9a0",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "4903"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(dataset1[1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "ba00fc84-39d3-4725-ae00-248de51460fe",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "50000\n"
     ]
    }
   ],
   "source": [
    "\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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1d2ee4f0-b3f9-45e2-aabe-2c2742163945",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([6, 9, 9,  ..., 9, 1, 1])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_set[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "e001b59c-29c3-4efb-b723-8b265bf0749b",
   "metadata": {},
   "outputs": [],
   "source": [
    "# After IID ditribution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "47eee55e-0f73-432a-8861-fc8ceedd0b05",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([6, 1, 1,  ..., 5, 3, 5])"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "e72861b8-4ec1-4510-90b5-7fd0b980ab65",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "for z in range(0,50000,1):\n",
    "    t=math.floor(np.random.uniform(low = 0.0, high = 10.0, size = None))\n",
    "    if t<1:\n",
    "        tag1[z]=(tag1[z] - 1) % 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bbd75d3f-e732-48dc-b88e-972fd6901a7c",
   "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": 11,
   "id": "82019675-4b8a-4f29-9b01-7e680b162a7b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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jtTUVHz66afIzc3FN998I03zNVAqlbjnnnuwevVqlJWV4e2336733EuXLsXAgQMRFRWFqVOnomPHjsjKysKuXbuQnp6OQ4cOXbN8t99+O7744gu4ubmhW7du2LVrFzZv3owOHTqY7HsQExODjz76CP/9738RGRkJHx8fDB8+HM8++yx++ukn3H777Xj00UcRExODsrIyHDlyBGvXrkVqaiq8vLwwZcoU5OfnY/jw4QgKCsL58+fxwQcfIDo6WpruHR0dDYVCgTfffBNFRUVQq9UYPnw4fHx8mlXWIUOGYNq0aViwYAGSkpIwcuRIKJVKnD59Gt999x3ee+893Hffffjss8/w4Ycf4u6770ZERARKSkrwySefwNXVFaNHjwag75a8//778cEHH0AmkyEiIgK//PJLvbFQV/u+bd68Ge+++y4CAgIQHh6Ozp07IygoCPfddx969uwJZ2dnbN68GXv37jVqfSOyCdadrEVE13L48GExbtw44e/vL5RKpfDz8xPjxo0TR44cafQxmzZtEgCETCYTFy5caPCas2fPigkTJgg/Pz+hVCpFYGCguP3228XatWulawxTwRuatlxQUCAmTZokvLy8hLOzsxg1apQ4efKkCA0NNZqG3JKp4JmZmeK2224TLi4uAoDRtPCSkhIxd+5cERkZKVQqlfDy8hL9+/cXb7/9ttBoNEIIIdauXStGjhwpfHx8hEqlEiEhIWLatGni0qVLRq/zySefiI4dOwqFQnHNaeETJ04UTk5OjZ7/+OOPRUxMjHBwcBAuLi4iKipKPPfcc+LixYtCCCEOHDggxo0bJ0JCQoRarRY+Pj7i9ttvF/v27TN6npycHHHvvfcKR0dH4eHhIaZNmyaOHj3apKngJ0+eFIMHDxYODg4CgJg4caKoqqoSzz77rOjZs6dwcXERTk5OomfPnuLDDz+82ltA1CbJhLiifZSIiIioDeOYGyIiIrIpDDdERERkUxhuiIiIyKYw3BAREZFNYbghIiIim8JwQ0RERDal3S3ip9PpcPHiRbi4uJhs2XUiIiIyLyEESkpKEBAQUG9vtyu1u3Bz8eJFBAcHW7sYREREdB0uXLiAoKCgq17T7sKNi4sLAP03x7CTMhEREbVuxcXFCA4Olj7Hr6bdhRtDV5SrqyvDDRERURvTlCElHFBMRERENoXhhoiIiGwKww0RERHZ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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": 13,
   "id": "b20ac57d-a33d-40fc-b4d9-3a500ed1f8ae",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[{'accuracy': 0.1}, {'accuracy': 0.10346}, {'accuracy': 0.10776000000000001}, {'accuracy': 0.11054000000000001}, {'accuracy': 0.11054}, {'accuracy': 0.12885}, {'accuracy': 0.14755000000000001}, {'accuracy': 0.19146000000000002}, {'accuracy': 0.21386}, {'accuracy': 0.25615}, {'accuracy': 0.29355999999999993}, {'accuracy': 0.32597}, {'accuracy': 0.3397}, {'accuracy': 0.36321000000000003}, {'accuracy': 0.38875}, {'accuracy': 0.41095}, {'accuracy': 0.41764999999999997}, {'accuracy': 0.43063}, {'accuracy': 0.44232000000000005}, {'accuracy': 0.45393999999999995}, {'accuracy': 0.47606000000000004}, {'accuracy': 0.48041}, {'accuracy': 0.49437}, {'accuracy': 0.5055}, {'accuracy': 0.50105}, {'accuracy': 0.52004}, {'accuracy': 0.52431}, {'accuracy': 0.5241799999999999}, {'accuracy': 0.5163}, {'accuracy': 0.51075}, {'accuracy': 0.49768999999999997}, {'accuracy': 0.47890999999999995}, {'accuracy': 0.493}, {'accuracy': 0.49539}, {'accuracy': 0.49329}, {'accuracy': 0.4848}, {'accuracy': 0.49009}, {'accuracy': 0.47004}, {'accuracy': 0.4866}, {'accuracy': 0.48457}, {'accuracy': 0.50414}, {'accuracy': 0.49876}, {'accuracy': 0.49493}, {'accuracy': 0.49749999999999994}, {'accuracy': 0.5017}, {'accuracy': 0.49198000000000003}, {'accuracy': 0.48650000000000004}, {'accuracy': 0.495}, {'accuracy': 0.49928}, {'accuracy': 0.5003}, {'accuracy': 0.50186}, {'accuracy': 0.4999999999999999}, {'accuracy': 0.51271}, {'accuracy': 0.5118799999999999}, {'accuracy': 0.51385}, {'accuracy': 0.51872}, {'accuracy': 0.52033}, {'accuracy': 0.5172399999999999}, {'accuracy': 0.5284}, {'accuracy': 0.52024}, {'accuracy': 0.5288700000000001}, {'accuracy': 0.5337000000000001}, {'accuracy': 0.53334}, {'accuracy': 0.53712}, {'accuracy': 0.53759}, {'accuracy': 0.5236099999999999}, {'accuracy': 0.53277}, {'accuracy': 0.5362199999999999}, {'accuracy': 0.5242}, {'accuracy': 0.54322}, {'accuracy': 0.5400699999999998}, {'accuracy': 0.5383699999999999}, {'accuracy': 0.5403100000000001}, {'accuracy': 0.55365}, {'accuracy': 0.54713}, {'accuracy': 0.5533699999999999}, {'accuracy': 0.5580900000000001}, {'accuracy': 0.5553}, {'accuracy': 0.55384}, {'accuracy': 0.5529100000000001}, {'accuracy': 0.5594300000000001}, {'accuracy': 0.56316}, {'accuracy': 0.5534900000000001}, {'accuracy': 0.56}, {'accuracy': 0.5570499999999999}, {'accuracy': 0.5689200000000001}, {'accuracy': 0.56885}, {'accuracy': 0.5734200000000002}, {'accuracy': 0.5622699999999999}, {'accuracy': 0.57697}, {'accuracy': 0.56884}, {'accuracy': 0.5653600000000001}, {'accuracy': 0.56985}, {'accuracy': 0.56974}, {'accuracy': 0.57481}, {'accuracy': 0.5740299999999999}, {'accuracy': 0.57661}, {'accuracy': 0.5645800000000001}, {'accuracy': 0.5626599999999999}, {'accuracy': 0.5703900000000001}, {'accuracy': 0.57481}, {'accuracy': 0.58288}, {'accuracy': 0.59124}, {'accuracy': 0.5866}, {'accuracy': 0.5879300000000001}, {'accuracy': 0.58429}, {'accuracy': 0.57815}, {'accuracy': 0.5663400000000001}, {'accuracy': 0.5749299999999999}, {'accuracy': 0.5692800000000001}, {'accuracy': 0.5956100000000001}, {'accuracy': 0.58941}, {'accuracy': 0.57885}, {'accuracy': 0.57988}, {'accuracy': 0.5776100000000002}, {'accuracy': 0.59006}, {'accuracy': 0.59706}, {'accuracy': 0.59985}, {'accuracy': 0.5995}, {'accuracy': 0.6053999999999998}, {'accuracy': 0.5665899999999999}, {'accuracy': 0.6028499999999999}, {'accuracy': 0.6077799999999999}, {'accuracy': 0.6101400000000001}, {'accuracy': 0.61098}, {'accuracy': 0.6092099999999999}, {'accuracy': 0.60262}, {'accuracy': 0.6076900000000001}, {'accuracy': 0.6081100000000002}, {'accuracy': 0.59583}, {'accuracy': 0.6108399999999998}, {'accuracy': 0.6071}, {'accuracy': 0.6008100000000001}, {'accuracy': 0.5960400000000001}, {'accuracy': 0.60364}, {'accuracy': 0.5977699999999999}, {'accuracy': 0.6074200000000001}, {'accuracy': 0.6089800000000001}, {'accuracy': 0.61441}, {'accuracy': 0.61284}, {'accuracy': 0.6108}, {'accuracy': 0.6103400000000001}, {'accuracy': 0.60768}, {'accuracy': 0.6111899999999999}, {'accuracy': 0.6095400000000001}, {'accuracy': 0.6133599999999999}, {'accuracy': 0.6124}, {'accuracy': 0.61075}, {'accuracy': 0.6110700000000001}, {'accuracy': 0.6097299999999999}, {'accuracy': 0.61143}, {'accuracy': 0.6112499999999998}, {'accuracy': 0.6104200000000001}, {'accuracy': 0.60893}, {'accuracy': 0.6103000000000001}, {'accuracy': 0.61072}, {'accuracy': 0.60937}, {'accuracy': 0.60982}, {'accuracy': 0.61042}, {'accuracy': 0.6103000000000001}, {'accuracy': 0.6102000000000001}, {'accuracy': 0.60954}, {'accuracy': 0.6117699999999999}, {'accuracy': 0.6107}, {'accuracy': 0.61034}, {'accuracy': 0.61155}, {'accuracy': 0.61135}, {'accuracy': 0.60971}, {'accuracy': 0.60993}, {'accuracy': 0.60942}, {'accuracy': 0.6106199999999999}, {'accuracy': 0.60783}, {'accuracy': 0.6106}, {'accuracy': 0.6080300000000001}, {'accuracy': 0.6103799999999999}, {'accuracy': 0.6089800000000001}, {'accuracy': 0.6089399999999999}, {'accuracy': 0.6079600000000001}, {'accuracy': 0.60814}, {'accuracy': 0.6081200000000001}, {'accuracy': 0.6072200000000001}, {'accuracy': 0.6086900000000001}, {'accuracy': 0.60818}, {'accuracy': 0.60704}, {'accuracy': 0.6094200000000001}, {'accuracy': 0.6073100000000001}, {'accuracy': 0.6090800000000002}, {'accuracy': 0.6069399999999999}, {'accuracy': 0.6089800000000001}, {'accuracy': 0.6096}, {'accuracy': 0.6083500000000001}, {'accuracy': 0.60693}, {'accuracy': 0.60788}, {'accuracy': 0.6062099999999999}, {'accuracy': 0.60702}, {'accuracy': 0.60609}, {'accuracy': 0.6055299999999999}, {'accuracy': 0.60619}, {'accuracy': 0.60678}, {'accuracy': 0.6062000000000001}, {'accuracy': 0.60082}, {'accuracy': 0.6046400000000001}, {'accuracy': 0.5997300000000001}, {'accuracy': 0.61406}, {'accuracy': 0.6119399999999999}, {'accuracy': 0.6048200000000001}, {'accuracy': 0.61667}, {'accuracy': 0.5916399999999999}, {'accuracy': 0.6122500000000001}, {'accuracy': 0.6144700000000001}, {'accuracy': 0.6130599999999999}, {'accuracy': 0.61808}, {'accuracy': 0.61717}, {'accuracy': 0.6109199999999999}, {'accuracy': 0.6073000000000001}, {'accuracy': 0.61809}, {'accuracy': 0.60103}, {'accuracy': 0.6149899999999999}, {'accuracy': 0.61229}, {'accuracy': 0.61925}, {'accuracy': 0.61387}, {'accuracy': 0.61765}, {'accuracy': 0.61721}, {'accuracy': 0.61802}, {'accuracy': 0.6196600000000001}, {'accuracy': 0.61715}, {'accuracy': 0.61854}, {'accuracy': 0.6167199999999998}, {'accuracy': 0.61703}, {'accuracy': 0.61656}, {'accuracy': 0.6157}, {'accuracy': 0.6157100000000001}, {'accuracy': 0.6146100000000001}, {'accuracy': 0.61668}, {'accuracy': 0.61601}, {'accuracy': 0.61662}, {'accuracy': 0.61576}, {'accuracy': 0.61588}, {'accuracy': 0.6145400000000001}, {'accuracy': 0.61514}, {'accuracy': 0.61462}, {'accuracy': 0.61581}, {'accuracy': 0.61511}, {'accuracy': 0.6141300000000001}, {'accuracy': 0.61478}, {'accuracy': 0.6144499999999999}, {'accuracy': 0.6142399999999999}, {'accuracy': 0.61368}, {'accuracy': 0.61367}, {'accuracy': 0.61386}, {'accuracy': 0.61226}, {'accuracy': 0.6129899999999999}, {'accuracy': 0.61324}, {'accuracy': 0.6128799999999999}, {'accuracy': 0.6124099999999999}, {'accuracy': 0.61239}, {'accuracy': 0.6119399999999999}, {'accuracy': 0.61053}, {'accuracy': 0.6112900000000001}, {'accuracy': 0.6112}, {'accuracy': 0.61298}, {'accuracy': 0.61111}, {'accuracy': 0.6102}, {'accuracy': 0.61276}, {'accuracy': 0.61113}, {'accuracy': 0.61152}, {'accuracy': 0.61066}, {'accuracy': 0.6092000000000001}, {'accuracy': 0.60978}, {'accuracy': 0.61119}, {'accuracy': 0.6108100000000001}, {'accuracy': 0.6101700000000001}, {'accuracy': 0.6106900000000001}, {'accuracy': 0.61028}, {'accuracy': 0.60881}, {'accuracy': 0.60992}, {'accuracy': 0.6095400000000001}, {'accuracy': 0.6097699999999999}, {'accuracy': 0.60906}, {'accuracy': 0.61078}, {'accuracy': 0.6104300000000001}, {'accuracy': 0.60972}, {'accuracy': 0.6104800000000001}, {'accuracy': 0.6092899999999999}, {'accuracy': 0.6086499999999999}, {'accuracy': 0.60849}, {'accuracy': 0.60784}, {'accuracy': 0.6091599999999999}, {'accuracy': 0.60813}, {'accuracy': 0.6078399999999999}, {'accuracy': 0.60867}, {'accuracy': 0.60822}, {'accuracy': 0.6082799999999999}, {'accuracy': 0.6071}, {'accuracy': 0.60802}, {'accuracy': 0.60779}, {'accuracy': 0.6066}, {'accuracy': 0.60807}, {'accuracy': 0.6057999999999999}, {'accuracy': 0.6068999999999999}, {'accuracy': 0.60839}, {'accuracy': 0.6061099999999999}, {'accuracy': 0.6056600000000001}, {'accuracy': 0.6059699999999999}, {'accuracy': 0.6065400000000001}, {'accuracy': 0.6063}, {'accuracy': 0.6052200000000001}, {'accuracy': 0.60725}, {'accuracy': 0.60795}, {'accuracy': 0.60694}, {'accuracy': 0.6065900000000001}, {'accuracy': 0.6046699999999999}, {'accuracy': 0.60582}, {'accuracy': 0.6072099999999999}, {'accuracy': 0.60537}, {'accuracy': 0.6059100000000001}, {'accuracy': 0.6058899999999999}, {'accuracy': 0.60518}, {'accuracy': 0.6049399999999999}, {'accuracy': 0.6035600000000001}, {'accuracy': 0.60448}, {'accuracy': 0.6043900000000001}, {'accuracy': 0.60474}, {'accuracy': 0.6043999999999999}, {'accuracy': 0.60554}, {'accuracy': 0.6017}, {'accuracy': 0.6036400000000001}, {'accuracy': 0.5977699999999999}, {'accuracy': 0.6020300000000001}, {'accuracy': 0.60521}, {'accuracy': 0.6085799999999999}, {'accuracy': 0.59416}, {'accuracy': 0.6022000000000001}, {'accuracy': 0.60876}, {'accuracy': 0.60156}, {'accuracy': 0.60921}, {'accuracy': 0.6139699999999999}, {'accuracy': 0.6175900000000001}, {'accuracy': 0.60459}, {'accuracy': 0.6199399999999999}, {'accuracy': 0.60838}, {'accuracy': 0.5993800000000001}, {'accuracy': 0.6122500000000001}, {'accuracy': 0.60975}, {'accuracy': 0.6075100000000001}, {'accuracy': 0.60013}, {'accuracy': 0.6064499999999999}, {'accuracy': 0.61447}, {'accuracy': 0.6022200000000001}, {'accuracy': 0.5661700000000001}, {'accuracy': 0.5971299999999999}, {'accuracy': 0.61022}, {'accuracy': 0.61671}, {'accuracy': 0.6126400000000001}, {'accuracy': 0.6093}, {'accuracy': 0.6222799999999999}, {'accuracy': 0.62286}, {'accuracy': 0.6239700000000001}, {'accuracy': 0.60063}, {'accuracy': 0.6201399999999999}, {'accuracy': 0.6252600000000001}, {'accuracy': 0.6242500000000001}, {'accuracy': 0.6230100000000001}, {'accuracy': 0.6223099999999999}, {'accuracy': 0.62247}, {'accuracy': 0.61477}, {'accuracy': 0.6244999999999999}, {'accuracy': 0.6219499999999999}, {'accuracy': 0.62225}, {'accuracy': 0.62143}, {'accuracy': 0.62113}, {'accuracy': 0.61893}, {'accuracy': 0.62061}, {'accuracy': 0.6181500000000001}, {'accuracy': 0.61706}, {'accuracy': 0.61564}, {'accuracy': 0.61961}, {'accuracy': 0.6190399999999999}, {'accuracy': 0.61799}, {'accuracy': 0.61747}, {'accuracy': 0.6189500000000001}, {'accuracy': 0.6180700000000001}, {'accuracy': 0.61773}, {'accuracy': 0.6181}, {'accuracy': 0.6182399999999999}, {'accuracy': 0.6176099999999999}, {'accuracy': 0.616}, {'accuracy': 0.61742}, {'accuracy': 0.6172300000000001}, {'accuracy': 0.6173500000000001}, {'accuracy': 0.6152599999999999}, {'accuracy': 0.6154899999999999}, {'accuracy': 0.6144000000000001}, {'accuracy': 0.6148400000000002}, {'accuracy': 0.61598}, {'accuracy': 0.61557}, {'accuracy': 0.61487}, {'accuracy': 0.6153}, {'accuracy': 0.6157299999999999}, {'accuracy': 0.6138600000000001}]\n"
     ]
    }
   ],
   "source": [
    "print([ev for _, ev in report.get_evaluation(False)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2cc30cf6-f4a7-4826-8de7-f30389319120",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "08e70310-351c-449e-8074-541fe8b84a42",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2d316984-07e1-4e44-b34c-df55266be41c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "440cc158-3139-4010-8090-c7424e96aced",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f36c0121-a71f-498f-b58a-ab83519ea44a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e1af4c26-3f96-40e1-ac6a-fed61c40104a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a5d193a2-9eb0-47a6-ba64-3a4d52f5a6a8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "176ae7a4-ae23-40f2-b680-e58d19ea8576",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b50c3e18-f38a-4874-99c1-9289a68e8447",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "20030df0-691c-4396-9533-a62e35483350",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "de5b0d97-8d20-4f20-8738-b3df41b4abcb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "15990a03-0a25-4bde-bee3-f4773c104bba",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e833faca-c68b-45bd-8f6b-a45548543e28",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b9a532b-c04d-418f-a32e-774ee6fd11e9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aaed9e31-5959-41a3-bcfa-2c6f9e07aaca",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "75ef8c36-d752-4d98-a25b-a748d0fb9d00",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8e3a453d-3363-4c9e-98d1-75473a873e35",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e3df1e6b-50c7-40ed-9f33-96ddd900534a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "60a0c23d-eb7a-43c5-a931-d39fa2485487",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "22fc3c82-5a7d-4707-8baf-6cacd0600627",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b72aa215-421b-4019-913b-5430f9c3b2ee",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "aa9759b7-b05a-4d61-8293-704c8db093d4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9cad8570-dd27-43d3-bca2-53bab0c9b05a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cc73a625-7ebe-4eff-ab3b-d68068e4a36e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "974f40e4-0ecd-4bfa-bfbf-faad7a48beb6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d871dd00-4992-4be7-9389-715f8c203b15",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1a4ee343-4649-4e95-a15e-93bafb069564",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
