{
 "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 Famnist(TorchModel):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.conv1 = nn.Conv2d(in_channels=1, out_channels=32, kernel_size=3, padding=1)\n",
    "        self.act = nn.ReLU()\n",
    "        self.pool = nn.MaxPool2d(2, 2)\n",
    "        self.conv2 = nn.Conv2d(32, 64, kernel_size=3)\n",
    "        self.conv2_drop = nn.Dropout2d()\n",
    "        self.fc1 = nn.Linear(64*6*6, 600)\n",
    "        self.fc2 = nn.Linear(in_features=600, out_features=120)\n",
    "        self.fc3 = nn.Linear(in_features=120, out_features=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",
    "        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(x.size(0), -1)\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.dropout(x, training=self.training)\n",
    "        x = self.fc2(x)\n",
    "        x=self.fc3(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",
    "# Dataset loading\n",
    "transform = Compose([Normalize([0.5, 0.5, 0.5], [0.5, 0.5, 0.5])])\n",
    "train_set, test_set = get_FashionMNIST()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "610d0fa5-0ad8-41e3-8345-59c287c10ef2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([60000])\n",
      "5982\n",
      "[[  0 617]\n",
      " [  1 612]\n",
      " [  2 579]\n",
      " [  3 622]\n",
      " [  4 592]\n",
      " [  5 585]\n",
      " [  6 601]\n",
      " [  7 631]\n",
      " [  8 582]\n",
      " [  9 600]]\n",
      "60000\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor([9, 0, 0,  ..., 3, 0, 5])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "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": "d212199d-c71b-46e8-8602-14f2e1d5f0ab",
   "metadata": {},
   "outputs": [],
   "source": [
    "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<3:\n",
    "        if tag1[z]==6:\n",
    "            tag1[z]=0\n",
    "        elif tag1[z]==0:\n",
    "            tag1[z]=6        \n",
    "        elif tag1[z]==2:\n",
    "            tag1[z]=4     \n",
    "        elif tag1[z]==4:\n",
    "            tag1[z]=2   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f87a367e-f092-46c6-aed1-8c340b50791a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([2, 3, 2,  ..., 9, 3, 5])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tag1"
   ]
  },
  {
   "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",
    "data_dispatcher = CustomDataDispatcher(data_handler, n=10, eval_on_user=False, auto_assign=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e9f9c07-d4f6-4dab-b33e-655da5dbf51a",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "nodes = PENSNode.generate(\n",
    "    data_dispatcher=data_dispatcher,\n",
    "    p2p_net=StaticP2PNetwork(10),\n",
    "    model_proto=TorchModelHandler(\n",
    "        net=Famnist(),\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": null,
   "id": "9927a46d-ee05-4159-9e98-1e827b3570e8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "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.90</span>                                                                <span style=\"color: #7f7f7f; text-decoration-color: #7f7f7f\">utils.py:181</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[2;36m               \u001b[0m\u001b[2;36m \u001b[0m\u001b[34mINFO    \u001b[0m accuracy: \u001b[1;36m0.90\u001b[0m                                                                \u001b[2mutils.py\u001b[0m\u001b[2m:\u001b[0m\u001b[2m181\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkAAAAHHCAYAAABXx+fLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAABvxUlEQVR4nO3deVxUVf8H8M/MwMywL7JvsrgroGIS7imKWmZWZmS5lFYuZdGmubVq2ZOPLZbmz62nck3L0jQjsVTccFdEURRRdmQbhIGZ+/tj4OYEKijMBebzfr3mFXPvuXfOvQ7dL+d8zzkyQRAEEBEREZkRudQVICIiIjI1BkBERERkdhgAERERkdlhAERERERmhwEQERERmR0GQERERGR2GAARERGR2WEARERERGaHARARERGZHQZARCS5uLg4yGQyxMXFidvGjRsHf39/yerUnLzzzjuQyWRSV4OoUWEARNQMnD59Gk8//TS8vb2hUqng5eWF0aNH4/Tp01JXrcF99dVXWLVqVYN+xpkzZ/DOO+/g0qVLDfo5pjRv3jz89NNPUleDSDIMgIiauE2bNqFr166IjY3F+PHj8dVXX+G5557Drl270LVrV2zevFnqKjYoUwVA7777LgMgombEQuoKENHdu3DhAp555hkEBgbir7/+gqurq7hv2rRp6N27N5555hmcOHECgYGBJquXRqOBjY2NyT6vKeA9IWpc2AJE1IR98sknKCkpwTfffGMU/ACAi4sLli5dCo1GgwULFgAANm7cCJlMht27d1c719KlSyGTyXDq1Clx29mzZ/H444/D2dkZarUa3bp1w5YtW4yOW7VqlXjOyZMnw83NDT4+PgCAy5cvY/LkyWjbti2srKzQokULjBw5st5aUvz9/XH69Gns3r0bMpkMMpkM/fr1E/fn5+fjlVdega+vL1QqFVq1aoWPP/4Yer3e6Dxr165FWFgY7OzsYG9vj+DgYHz22Wfi9Y0cORIA8MADD4ifc3O+0r+NGzcOtra2uHDhAoYOHQo7OzuMHj0aAKDX67Fo0SJ07NgRarUa7u7ueOGFF3D9+nWjcxw+fBhRUVFwcXGBlZUVAgIC8Oyzz4r7a8qbAoBLly5BJpPdtlVMJpNBo9Fg9erV4vWMGzcOAFBUVIRXXnkF/v7+UKlUcHNzw8CBA3HkyJFbno+oKWILEFET9ssvv8Df3x+9e/eucX+fPn3g7++PrVu3AgAefPBB2NraYv369ejbt69R2XXr1qFjx47o1KkTAENeUc+ePeHt7Y3p06fDxsYG69evxyOPPIIff/wRI0aMMDp+8uTJcHV1xZw5c6DRaAAAhw4dwr59+/Dkk0/Cx8cHly5dwtdff41+/frhzJkzsLa2vqfrX7RoEV566SXY2tpi5syZAAB3d3cAQElJCfr27YurV6/ihRdegJ+fH/bt24cZM2YgPT0dixYtAgDs3LkT0dHRGDBgAD7++GMAQGJiIvbu3Ytp06ahT58+ePnll/H555/j7bffRvv27QFA/O+tVFRUICoqCr169cJ//vMf8VpfeOEFrFq1CuPHj8fLL7+MlJQUfPnllzh69Cj27t0LS0tLZGVlYdCgQXB1dcX06dPh6OiIS5cuYdOmTfd0v6r873//w4QJE9C9e3c8//zzAICgoCAAwIsvvoiNGzdi6tSp6NChA3Jzc7Fnzx4kJiaia9eu9fL5RI2CQERNUn5+vgBAGD58+G3LPfzwwwIAobCwUBAEQYiOjhbc3NyEiooKsUx6erogl8uF9957T9w2YMAAITg4WCgtLRW36fV6oUePHkLr1q3FbStXrhQACL169TI6pyAIQklJSbX6xMfHCwCEb7/9Vty2a9cuAYCwa9cucdvYsWOFli1b3vbaBEEQOnbsKPTt27fa9vfff1+wsbERzp07Z7R9+vTpgkKhEFJTUwVBEIRp06YJ9vb21ep+sw0bNlSr3+2MHTtWACBMnz7daPvff/8tABC+//57o+3bt2832r5582YBgHDo0KFbfkZN90wQBCElJUUAIKxcuVLcNnfuXOHf/7u3sbERxo4dW+28Dg4OwpQpU2pxlURNG7vAiJqooqIiAICdnd1ty1XtLywsBACMGjUKWVlZRl0nGzduhF6vx6hRowAAeXl5+PPPP/HEE0+gqKgIOTk5yMnJQW5uLqKionD+/HlcvXrV6HMmTpwIhUJhtM3Kykr8uby8HLm5uWjVqhUcHR0bvEtlw4YN6N27N5ycnMT65+TkIDIyEjqdDn/99RcAwNHRERqNBjt37qz3OkyaNKlanRwcHDBw4ECjOoWFhcHW1ha7du0S6wQAv/76K8rLy+u9Xrfj6OiIAwcO4Nq1ayb9XCJTYwBE1ERVBTZVgdCt/DtQGjx4MBwcHLBu3TqxzLp169C5c2e0adMGAJCcnAxBEDB79my4uroavebOnQsAyMrKMvqcgICAap9948YNzJkzR8zBcXFxgaurK/Lz81FQUHCXV14758+fx/bt26vVPzIy0qj+kydPRps2bTBkyBD4+Pjg2Wefxfbt2+/58y0sLMRcqJvrVFBQADc3t2r1Ki4uFuvUt29fPPbYY3j33Xfh4uKC4cOHY+XKlSgrK7vnet3JggULcOrUKfj6+qJ79+545513cPHixQb/XCJTYw4QURPl4OAAT09PnDhx4rblTpw4AW9vb9jb2wMAVCoVHnnkEWzevBlfffUVMjMzsXfvXsybN088pipJ+PXXX0dUVFSN523VqpXR+5tbe6q89NJLWLlyJV555RVERETAwcEBMpkMTz75ZLVE5Pqm1+sxcOBAvPnmmzXurwr23NzccOzYMezYsQO//fYbfvvtN6xcuRJjxozB6tWr7/rzVSoV5HLjvzH1ej3c3Nzw/fff13hMVSK7TCbDxo0bsX//fvzyyy/YsWMHnn32WXz66afYv38/bG1tbzmxoU6nu+s6A8ATTzyB3r17Y/Pmzfj999/xySef4OOPP8amTZswZMiQezo3UWPCAIioCXvooYewbNky7NmzB7169aq2/++//8alS5fwwgsvGG0fNWoUVq9ejdjYWCQmJkIQBLH7C4A4ZN7S0lJsMbkbGzduxNixY/Hpp5+K20pLS5Gfn3/X5/y3WwUCQUFBKC4urlX9lUolhg0bhmHDhkGv12Py5MlYunQpZs+ejVatWtXbLMpBQUH4448/0LNnzxoDxn+7//77cf/99+PDDz/EDz/8gNGjR2Pt2rWYMGECnJycAKDavbx8+XKt6nK7a/L09MTkyZMxefJkZGVloWvXrvjwww8ZAFGzwi4woibsjTfegJWVFV544QXk5uYa7cvLy8OLL74Ia2trvPHGG0b7IiMj4ezsjHXr1mHdunXo3r27UReWm5sb+vXrh6VLlyI9Pb3a52ZnZ9eqfgqFAoIgGG374osv7rmV4mY2NjY1BlRPPPEE4uPjsWPHjmr78vPzUVFRAQDV7ptcLkdISAgAiF1OVfP33Gvg9sQTT0Cn0+H999+vtq+iokI8//Xr16vdt86dOxvVqWXLllAoFGIuU5WvvvqqVnWp6b7pdLpqXZNubm7w8vIySfcbkSmxBYioCWvdujVWr16N0aNHIzg4GM899xwCAgJw6dIlLF++HDk5OVizZo04xLmKpaUlHn30UaxduxYajQb/+c9/qp178eLF6NWrF4KDgzFx4kQEBgYiMzMT8fHxSEtLw/Hjx+9Yv4ceegj/+9//4ODggA4dOiA+Ph5//PEHWrRoUW/3ICwsDF9//TU++OADtGrVCm5ubujfvz/eeOMNbNmyBQ899BDGjRuHsLAwaDQanDx5Ehs3bsSlS5fg4uKCCRMmIC8vD/3794ePjw8uX76ML774Ap07dxaHunfu3BkKhQIff/wxCgoKoFKp0L9/f7i5udWprn379sULL7yA+fPn49ixYxg0aBAsLS1x/vx5bNiwAZ999hkef/xxrF69Gl999RVGjBiBoKAgFBUVYdmyZbC3t8fQoUMBGLpAR44ciS+++AIymQxBQUH49ddfq+Vm3e6+/fHHH1i4cCG8vLwQEBCAtm3bwsfHB48//jhCQ0Nha2uLP/74A4cOHTJqxSNqFqQdhEZE9eHEiRNCdHS04OnpKVhaWgoeHh5CdHS0cPLkyVses3PnTgGAIJPJhCtXrtRY5sKFC8KYMWMEDw8PwdLSUvD29hYeeughYePGjWKZqmHwNQ3Zvn79ujB+/HjBxcVFsLW1FaKiooSzZ88KLVu2NBqCfS/D4DMyMoQHH3xQsLOzEwAYDYkvKioSZsyYIbRq1UpQKpWCi4uL0KNHD+E///mPoNVqBUEQhI0bNwqDBg0S3NzcBKVSKfj5+QkvvPCCkJ6ebvQ5y5YtEwIDAwWFQnHHIfFjx44VbGxsbrn/m2++EcLCwgQrKyvBzs5OCA4OFt58803h2rVrgiAIwpEjR4To6GjBz89PUKlUgpubm/DQQw8Jhw8fNjpPdna28NhjjwnW1taCk5OT8MILLwinTp2q1TD4s2fPCn369BGsrKwEAMLYsWOFsrIy4Y033hBCQ0MFOzs7wcbGRggNDRW++uqr2/0TEDVJMkH4VzsrERERUTPHHCAiIiIyOwyAiIiIyOwwACIiIiKzwwCIiIiIzA4DICIiIjI7DICIiIjI7HAixBro9Xpcu3YNdnZ29TYFPhERETUsQRBQVFQELy+vamvx/RsDoBpcu3YNvr6+UleDiIiI7sKVK1fg4+Nz2zIMgGpgZ2cHwHADq1bQJiIiosatsLAQvr6+4nP8dhgA1aCq28ve3p4BEBERURNTm/QVJkETERGR2WEARERERGaHARARERGZHQZAREREZHYYABEREZHZYQBEREREZocBEBEREZkdyQOgxYsXw9/fH2q1GuHh4Th48OAty5aXl+O9995DUFAQ1Go1QkNDsX379ns6JxEREZkfSQOgdevWISYmBnPnzsWRI0cQGhqKqKgoZGVl1Vh+1qxZWLp0Kb744gucOXMGL774IkaMGIGjR4/e9TmJiIjI/MgEQRCk+vDw8HDcd999+PLLLwEYFiH19fXFSy+9hOnTp1cr7+XlhZkzZ2LKlCnitsceewxWVlb47rvv7uqcNSksLISDgwMKCgo4EzQREVETUZfnt2QtQFqtFgkJCYiMjPynMnI5IiMjER8fX+MxZWVlUKvVRtusrKywZ8+euz5n1XkLCwuNXkRERNR8SRYA5eTkQKfTwd3d3Wi7u7s7MjIyajwmKioKCxcuxPnz56HX67Fz505s2rQJ6enpd31OAJg/fz4cHBzEF1eCJyIiat4kT4Kui88++wytW7dGu3btoFQqMXXqVIwfPx5y+b1dxowZM1BQUCC+rly5Uk81JiIiMg8VOj2qsmpKy3XQVuglrtHtSbYavIuLCxQKBTIzM422Z2ZmwsPDo8ZjXF1d8dNPP6G0tBS5ubnw8vLC9OnTERgYeNfnBACVSgWVSnWPV0REJI3Sch1uaHVwslHWqmyFXoCt6tb/+y8t16HgRjnc7dW3LNNY7buQA22FHh087bHu0BWUlOvQ1c8J/dq6olynx+lrheji6wgLhWn//hcEQVyhvKxCB5WF4pZlyyp0uJJ3A6l5Guj1QHigMxIuX8fFbA28HNU4eiUfhTfK8dbgdnC0/uffXKcXkFNchrJyPbQ6HayVFvBytEKeRotjV65DBhlc7VQIdLWBtdLw719arsPuc9m4odXB2UYJZxslvByt4GBliYzCUljKZbBRWeB8VjF+PnYVZ64VYs6wDujo5WBU511JWXhz4wkoZDL0au2CbSfTYa+2xH9GhqJXaxfo9AIuZBfD3U4NB2vLBrjDdSdZAKRUKhEWFobY2Fg88sgjAAwJy7GxsZg6deptj1Wr1fD29kZ5eTl+/PFHPPHEE/d8TiKi+rQxIQ0f/ZaIDx4JxuBOt/4D7HZ2nc2CQi5Dnzau1fadvlaA1zecQFpeCYrKKgAAke3d8fFjwWhha/iD7sy1QnwVl4yxPfxxn78zSst1eGTxXlzM0eCD4Z3wxH3Vu/sTLufh5TXHcDX/BkJ9HTH7wfbo5u98V/VfsvsC/jybhZlD28PZRonLuSW4L8AJej2Qdr0EPk7WuFGuQ7lOX6tgSxAE/HYqA3uSc/BsT3+0crMz2h9/IRdPLTtQ47EtW1jjhlaHrKIyDGjnhtcGtcX20xnYnZSF4rIKeDpYAQDyb2ihKdNhUEd3BHs74PS1QrSwUcLHyQqeDlbQCwIUchnKdQI2HUlDYWkFugc4I6uwFOU6Ae097SAIgAABzjYqdPd3xh+JmXh780l08XNCCxslfj52FX3buCKqowc2H72KwZ088EBbNyzelYyE1OtIydGgNsOTjqbm4+HOXkjOLEZeiRZHU/NRcKPcqEyoryPOZxahRKsTtykt5Bgb0RIVegGbj15Ffkn5v08NuQzQ36IO41YewjP3t8T+i7nQCwKyispwMVsj7t+YkAYAKNHq8PTyA4ju7oukjCIcSc0HAKgt5ajQCZjcLwgxg9re+UIbiKSjwNatW4exY8di6dKl6N69OxYtWoT169fj7NmzcHd3x5gxY+Dt7Y358+cDAA4cOICrV6+ic+fOuHr1Kt555x2kpKTgyJEjcHR0rNU5a4OjwIjoZpqyCqgtFVDIZbU+5uEv9+BEWgHUlnKsfyECIT6OtT62tFyH9389g+8PpMJSIcPhmQMhQIBeAJwrW3ne2XIaq/Zdqnasm50Kq8Z3R2peCV5bfwwarQ7tPe2x7eVeWLAjCV/HXRDLutgqEerjiPmPBsPNXo0fDqRi9s+noLvpyfdAW1esHN/9tvX940wm/kzKwoReAfBytMKlXA12nMrEf/84BwCwVMig0xvq72KrRIlWZ/RABoCoju54oW8QPOzV2Hz0KvZfzMXl3BI4WlvCUiFHuU6PghvluJxbAsDwEO/W0gm5xVoAQLCPA45cvo6LORpYKgwBSoiPAzp42uOPxEzkVJYzNRdbFa6XaI3uaU3+HXDYKBXwa2EDTVkFUvNK4GBlifv8nZFReAMBLrbYfzEX2UVl1c6jkMugspDDUiFHUWm5eE7/FtawVVvgWn4p8jTG98LLQQ1/FxvkabTI1WjF81rIZdAL/3zvuvs7IyVHg6TMomqfK5MBYyP80dHLHseu5KNvG1fsPpeN7w+kimWq/l2qvNg3CNOHtLvjPayLujy/JWsBAoBRo0YhOzsbc+bMQUZGBjp37ozt27eLgUpqaqpRfk9paSlmzZqFixcvwtbWFkOHDsX//vc/MfipzTmJiOpi/8VcTFh9GEGuNlj7fASslAoIgoDisgrYqWtuys/TaHHyagEAoLRcj6k/HEXc6/0grwygBEHApiNXYaGQ4eFQL7FrRKcXsHhXMlbsTRH/Ki/XCUhIzcPbm06hsLQcS54OQ582rkjKMDyEZg5tjyfu80Xa9RJMW3sMyVnFGPblHqMHbmJ6If7v7xR889dFAMCwUC/8djIdOcVaxJ7NwmNL9qGjpwO2n84Q90cEtsDbm0+iuLJ1qUq5To8lcRfwQDs3dPJ2QLlOjzc2Hsf1knLxL/+bcz/aedjhbGVdHawsxUBEbSlHabmhnEwG7DidiR2njdMXACA1z/i9laUCbT3scOxKPvZdyBW3Vz2UXe1U2PFKH9wo18HLQQ2ZTAZNWQXWHEyF2lIBP2drTPouAaUVevRr44rBnTzg6WCFrKJSKOQy2KosUFqux//2X0LBjQp09nVAUWkF0q7fQEZBKSwUMlToBJRoK9CnjSsCXGxwNDUfXo5qWCrkOJ9ZDEsLGWSQITmrGBmFpQCA4Z294GStRFFpBQZ2cMfXuy8gNVeDqI4e+PFIGsp1AiICW+D5PoHo6G0PV1sVZDIZBEHA1fwbcLFVQW35T7fZxexizNx8Cg5Wlgj2cYCTtRLtPO0Q4u0gdu9lFJTi9zMZ8HW2Rr82ruL54pKy8X97LsJOZYlR3X3Rp7WrUXBfWq5Dfkk5XO1UEAQBJeU62Fd+19MLbuDZVYdhqZBhZDdfOFhZwtHKEu087eBmZ2jFG9nN0LI4qKMHHg71wrxtibBWWmDB4yGwt7JEUWk5LORy2KolDUGkbQFqrNgCRNS8Fdwoh41Sccc8kLMZhRj5dbzYxTQyzAcfjOiEV9cdw7aTGYjq6I4B7dxxMUeD7afS0cXPCf8d1Rm/HL+Gl9YcRaCLDdILSnGjXIdtL/dGBy/D/0++ikvGgu1JAIDBHT2wYGQIVBZyxKw/jq0nDKNavR2tUFhajqLSCvGvacDwV/mq8d3x0pojuF5Sjl9f6oVO3g7idU389jAOpuRBZSHHuB7+yNNosaEyMAGAIZ088PXTYSi4UY7krCLErD8utqoAwLQBrfFKZGvEncvG+JWH0MnbHr++1Fvc/2NCGl7bcBwhPg7YMrUXdp/LxtgVxrPtO1hZwsnaEtHd/TCxdyD+SMyEr7M1glxtsfdCDpyslQj1cUDBjXKoLRW4kleCL/5Mxq6zWSgqq0B3f2c8FOqJtu52KCytgE4viK0a7T3t4GyjxK6kLORpyuFhr0ZZhQ7fxl/GwZQ8fBHdBZEdbv8Hb26xoYWjqquwoWgr9NiYkIbisnI81yvQKMgQBAGCAMjlMiRnFSE1rwQPtHUTg2G6O3V5fjMAqgEDIKKm4Zfj1/Dn2Sw8HOoFd3s19l3IwdaT6RjYwR2T+gaJDxNBEPD3+Ry0cbdDRmEpor/ZD2cbJeYM64Cojv/k55Tr9Phq1wUkpF7Hx48F45W1x3AgJQ/tPOxwLrMIegGwV1ugsLTiVlXC5sk98MOBVGxISMPE3gE4n1WMuKRsvD20HZ7vE4SNCWl4fcNxAIbuCp1eQDsPO1gpFTiamg9LhQwfjgjGY119sHrfJbz36xnx3FXlQ3wccCKtAHIZcOa9wUYtA2UVOsQlZaOLryPc7NVIyihC1KK/AAChPg74bkK4UctVdlEZ/hd/CZYKOe4PaoH7KvN99l/MxZPf7EeQqw1iX+snlp+x6QTWHLwCuQw4PncQ3vvlDDYkpGF0uB+e6OYLG5UCQa62d/UgL9fpUVxaUatk7prcnGhM5qnJdIEREd2sXKfHjcrm9su5GmQUlCI8sAXKdXoUlVaI+S+AoZn+7U0nUVRWgc1Hrxqd52hqPsorBEyLbA0A+Db+MuZuOQ0XWyVcbFW4Ua7D1fwbeOF/CVj6TBgeaOuG306lY9nfF3HqqmEi1Nk/ncKBlDzIZMDycfdh5+kMzNt2FoWlFVBbyvHew51w+HIecoq1cLCyRGZhKfZdyMX/7UlBwqXrAIA+bVzhbq9GXFI2/j6fgyBXW7z14wkAwPN9AjE02BMTvz0sdhHZqy3w1egw9GrtAsCQwHqzJ7r5YM3BKziRZuhe83exMQp+AEBloTAK6tp62OGFPoFIzirGf0aGVuu2c7VT1ZiIalV53qpuqpvvLWDIV9l/MQ87buo2+3d968pSIb/r4AcAgx+qEwZARFRvdHoB//k9CTlFZZgW2Ro+Ttb4+3w23vvlDF6JbIMHQzxve/zT/3cAx9Py8WLfIHzz10WUaHVYNKozlv19EclZxVgx7j74u9ggo6AU2UVlKCqrgJ3aApYKOWQwBARt3G2x5uAV/PePc8jVlOGRLt746LezAICcYi1yirWwU1mgf3s3/HzsGj7efhar9l5C/EVDPklVbsofiYb1A7v7O8Pb0QrjegbgsTAf7E3ORaCrDdq42xmNojp1tQAPfbFH7MKyslTgPn/nyryIRBxIycPBlDzo9AIe7eqN6YPbQS6XYfPkHnh5zVFYKOT4z+Oh8GthLZ6zo5c9LOQyVFTm8zzXKxA7TmeKSaztPIxHQd3KjKHta1XuZlZKQwB0o/yfZOWi0nKjBNj/7EhCYWkF3OxUYssRUVPBAIiI6iy/RGs0/wgA6PUC3t50EusOGyYS/fVEOkZ09cbmI1dxo1yHz2PP48EQTxTcKMfmI2nQCcD4Hv4o1+tRVqFHabkOB1IMGa+L/jgvnveVdcfEnyd/fwRlFTqUluvh7WgYthzd3Q9v/+sBH+hiiw+3JeLb+Mv4Nv4yACCspRMu55Ygp7gMrw5sg5HdfPDXuWxczNbgYrYGtioLTOgdgOjufhj9fweQnFUMABjRxVs8r53a8pZD2jt5O6C7vzMOXsqDrcqQ8Km2VKCNuy3c7FTIqhxZM6CdGz5+LERMiPZxssamyT1rPKfaUoF2nnY4dbUQHvZqBLnaoFcrF2w5fg0A0Na94broq1qAbtw0Wuv4lQKj4dlVwdCT3f3qNEKOqDFgAERk5o6mXseag6mY2DsQrd3tIAgC/qycf+b+wBb44s/zkMtkeHlAa1gq5GIS7OhwP7w/vJP4IF+xNwXrDhtyQzp42ePU1UL8cNMQ2KTMInwbfwkLtieJI4vyS7TYdjIdWUVlmDbA0F1V1QITEdgCmYWluJhjmF/E19kKV/JuiOe7mm/4+eFQr2rXNLFPIPxdbDCzchRTRy97LHqyCyp0ehy7ko9hIV6Qy2WY8kArfLA1EQq5DItHd0Xfyvl2xkS0xJyfT0OpkGNI8O1brW723yc7Y1NCGkZ09YaPk6ElRyaToW8bV2xISEO3lk748qmusKzDJHydfR1x6mohegS1gEwmQ+/WNwVAtWwBuhtVXWs3ynVibs3RVEPXXrC3gzjKzU5tged6BTRYPYgaCgMgIjOWcPk6xiw/AI1WV5mo2x7fH7iMQ5U5LE7WlrheORz7zLVCLB7dFb+eMDx8vz+QihKtDpP6BcHZRonPKltt3nm4I565vyXikrKx/vAVyGUyFJaW4+/zOZjz82kAgIe9GhmFpfjiz2SxLp/+bpgzZnR4S0zoHQB3O8OMt8+tPoSnw1siOtwP87Ym4j5/J8Sdy0ZcUjYCXWzQ0avmVpCBHdwR2b76qJqWLWzEn8dE+KPgRjmCvR3E4AcARob5IuHydXT2dYSDVe1nrfV2tMJLlYHczd4a0g5d/JwwLNRT7Fqqrcn9WqFCJ2DKA60AAL1b/1PP9p4NFwDdXM+yCj3UlgocqQyAHu3qjfSCUuQUl2Fi78A63SOixoKjwGrAUWDUnBWVlkMuk6Fcp0ffT+JQcKPcKM8EMLTC6PWAVqeHk7UlSrQ6lFXoMalfEL6LvywOC6/iaG2J/JJydPK2x5YpvcRWoSpbT6Rjyg9HABgmXfs9pi+mrTmK2MqWppvnrPm/Md3uOIy5oKQcn/95HoM6uCM8sMW93pImZ+nuC9BodYgZ2KbBPqNCp0ermb8BAI7OHoic4jIM/uxv6PQCfpvWGxeyi7E3ORezHmwPm9ssq0FkShwFRmQmikrL8c6WM+jgZY/negUgJceQy+JqZ5jf5HKuBj8mpGFCn0CoLOT4Ou4Cvoq7AE8HNYZ0MuTjtHG3xZKnw/Dc6sMoKi3Hw6HemNgnAKXlevx+OgMPd/bCwZQ8TFt7DCv2pKCsQg87tQW+fKorvtt/GXFJWeKkfXMe6lgt+AGAAe3dxOHjHz4aDFuVBRaO6ozv9l9G79YueGrZARSXVUAuA7oH3jmZ1sHaErMf6lC/N7MJeaFvUIN/hoVCDqVCDm3lyLx52xKh0wsY1MEd7T3t0d7THg+FVO9+JGoqGAARNUE6vYD0ght4Ze0xHL58HT8fkyGspROeWBoPe7Ultk3rBTc7NWb/fBp/nctGYWkFBEHA6sqE4Mu5JViy27AkwqR+QQh0tcWfr/UFYDyUuOpBG9XRA3ZqCxRVzn/T3d8Zfdu4om8bVxSUlGPHmQw4WFmie0DNwYvaUoEfJt6PPI1WXNfKwcpS7NZ5KMQTaw9dQSdvB3HGWZKe2tIQAO27kItdSdmwkMvuakQZUWNk2uVwicyM/g7r/9zsYEoe5m1LRGm5DruSsvDqumPV1uwBgOsaLfos2IVeH+/C4cuGnIwKvYCX1hyBtkKPnOIyvLb+ODIKSrHnvGH24A2Hr2DNQcPorAk3Jax62KvFv+JlMtkt51FRWyowtNM/ycDhN7XSOFhb4oluvkZzz9Skk7dDjYt6AoY8l/sDnTG1MiCixqEqD+hEWj4AoGcrFwS42NzmCKKmgy1ARA1k+o8nsPVkOn6Z2gv+Nz00fj1xDb+dzMD7j3TCukNXsP7wFUzoHYD5286iuKwCLWyU+Db+Mq7m34CtygI+TlZY9ncKnG0MgYalQo6r+TegkMvQ2s0WbdztsOX4NaMRUn+fz8HYFQfFhRA1lUOZu7V0wqyHOqCkXIcfDqRiUr+gWo9IGt7ZSxzifn895934tbDG2ucj6vWcdO+qhsJXLY7paM3WOWo+GAAR3aN1h1KxNzkX8ypzWwCguKwCm45chVanx5pDqZgx5J9ugwXbk5CaVwIBAnaeyUS5TsDMzafE/V/8mSwOE197KFVcRTunuAzzfzsLXyfD/Dczh7bHs70CcCWvRBwW7WyjxGuD2mDm5lPiHC2dvO3F2Y0n9TN0aX0wvBPGRvijjbttra8zPLAFerd2gV4Q0MGTgwPMgfpfAZAtk52pGWEXGNE9+mTHOWw5fg2r910St/19LhtanWEJgS3HroldYTnFZUjNMyw8ue1kBsp1AqwruxmcbZRQW8qNVt8u1xmCnwdDPNGzVQvo9AIu5ZZALgMeCjV0Sfk6W6OLnyMAw6R9o8Nb4vk+gQAAS4UMS54OQzsPO/Ru7YIH2roBMCzA2NbDrk5LByjkMvzvuXB8P+H+Oy4iSs1DVRdYduXioVKv3k1Un/htJqqFPI0Wv5/OgFwuwxPdfHE09TrOZRYhsr07ciofDiv2pOC5XgFQWyoQezZLPDa9oBQHUvIQEdQCRypzdm625OkwaCv0aOthh//+cQ6bjhjWtXojqi0+2ZEEd3sV5j0SjIs5xdibvA+AIRfDsMSCwbsPd8Sag1fEpOK3BrdDCxslfJ2t4eNkje2v9Gmwe0PNV1UXWE5lC5AdW4CoGeG3megOjl/JxxNL41FWYWjRaedhh5j1x5GSo8HLA0rFcrkaLTYkpOGp7n7YVRkAtXKzRXJWMdYdSjUEQJULSXbwtEdSZhHCWjqhd2sXsSXmqe5+2HTkKtq422JyvyBEBLWAp4MaDtaW6OLnhMj27vgjMRNPdPM1qmOIjyNCfBzF9wq5zCRDpal5qwqAqnLI2AVGzQm/zUR3EJuYKQY/gCEgSqlcnqFqqYeq+VJ+TEhDRy975GoMC25++EgnjPpmP346dg3dA1qIM+mO6+GPiKAWcLZRGnVDdfN3xqbJPeDlYAWZTIaufk5Gdfk8ujMS0w2BE1FDU/9r1up/ryRP1JSxI5/Mzr7kHDzwnzhsPpombtOUVeByrgbX8m/gjQ3HMeWHIyitXAX7ROWaR1VxStUq4QDE7q8hwYYh4GeuFeKvc4ah5z1atUB4YAu8GmmYrfftzSdxsHKxz64tHeHrbF3jDLpd/Zzg4aCuth0ArJUWDH7IZKpagKowB4iaE36byaxcytHgxe8SUFhagfnbzuLBYC/c0OowfPEeXMotMSr7cKgXBnVwx8k0QwD0SGdvbD56FfEXcqudd2AHd/x9Pgd5Gq3YKtQ9wDBU/OUBrZBecANrD10Rywe61H70FZFU/h0AMQeImhO2AJHZuJJXgvGrDqGwcjbjrKIy/HzsKl7bcNwo+Kn6n35cUjauFZQiV6OFhVyGBytXBa8a3XWzdh526OLrKJ4XAO7zN7TUyGQyzH80GB89Ggw7lQXGRrSscbkIosbm3wu3sgWImhN+m6lZKavQITYxC71buxjlK1zO1eCxr/chp1gLb0crDOrojpV7L+GtH09ALwBKCzk2vhgBL0crnLxagPErDyEuKQt927gAANq426H9LVYdVyrkaNnCBl38HMXRX9ZKhdFcOTKZDE9298PIbr5QMPihJkL97y4wtgBRM8JvMzVJFTo99l7IxbmMIng7WWFosCcEQUDMuuPYejIdT9/vhweDvTD5+wS883BHnL5WiJxiLdq62+Hb57pDbaHA+kNXoNHqYKeywAcjOomjqCICW0BlIUd6QSk2JhiGpIf4OMDTXg0rSwVuVOYGdfVzxJHUfAS52cJSIUdn339yc7r4OdY4Vw6DH2pKqnWBMQmamhEGQNQkfR13AZ/uPCe+/8/IUOSXaLH1ZDoAYOuJdFzM1uB6STm+jb8MXeVEhC/0DYS7vSHB+IeJ9yMlR4OBHdyNkpHVlgpEBLVAXFI2/kjMBAAE+zhALpchwMUGZ9INsyq/HtUWi3aeR3S4YUh6iK8DZDJAEID7/O+8ojlRY2dlaRzE27ELjJoRfpupUTPMfKxBoIuNOFy8rEKH1fGXAADtPe2RmF6I1zccF4+Ry4DrJeXYV5msfOxKPqraXW4OTEJ9HRFambfzb5Ht3RGXlC2+rxqOHuhqCIAUchm6tXTG+hf/Wb/KXm2JEG8HHE8rQK9WLvd66USSuzkHyEIug8qCaaPUfDAAokbt2/hLePeXM5gxpJ04sd/WE+nIKdbCw16Nn6f0xLS1R/HbqQxYWSrwbC9/5Gm04srnAMTWHw97NXwq19G6k6qJBgtulCPI1QbtK/N5glwNo7f8nK2hrOFh8OVTXZGSo0E3tgBRM3BzDpCt2qJOS6cQNXYMgKhR25tsaMVZsvsCxkT4Q20px6rKNbeeiWgJpYUcn0d3wZ7zOeji5whHayX+Pp8tBkBO1pa4XlIOALgvwLnW/wNXWsjx9P0tq23vXNliFOrjUONxvs7W8HW2rsslEjVaN+cAMQGamht+o6lRKC3X4a9z2SjXCQj2doBfC0MQcSG7GIChS2tjwhV09HbAibQCKC3kePI+QyuNpUKOB9q5iee6P7AF/FtYo7C0Am9GtcX0TScBAN39730CwX5tXbHhxQi09bC753MRNXY3d4ExAZqaGwZAZFJ6vYDMolJ4Ohh3Rf33j3NYuvsiAMOq6PtnDIBeEHA5VyOWWfrXRbTzMHRFPRzqhRa2qho/w1Ihx5aXeqFCJ0Ahl2HmT6eg0wu4L+Deu6VkMhkTnMls3NwCxEkQqbnhN5pM6os/k/HfP85hcr8gvDm4nbg99qblJfI0WhxPy4etygJ6wTDyxFqpQNr1G0i7fgOAYS2t27G/6a/Vjx8LQZ6mTAyeiKh2/p0DRNSc8BtNJvXzMcO8Ol/FXcD1Ei3CWjojPMAZyVnFkMmAnkEu2JOcg33JuQhwtQEAtHW3w9xhHfHE0njcKNehW0sndPKuOQenJo+H+TTItRA1dzd3gTEHiJobfqOpXun0Aj774xxatrDBY/8KPARBQHblMhEAsObgFaw5eAWt3Awjqzp5OWBIsIchALqQA53esOREa3dbBPs4YMkzYVj0xznMGNoORNTwrNgCRM0Yv9FUr349cQ2f/5kMC7kMPVq1MMr1Sbt+A0VlFbBUyLDg8RD8dS4Hm49eRXKWIdG5R1AL9AgyzJ9zNDUf1pV/fbZyMyQc923jir5tXE18RUTmyygHiAEQNTOc1YrqjSAIWFKZyFyhF7Bq7yWj/YmVMyi3crPDiC4+WPhEKLq1/GdkVo9WLvBvYQ1PBzW0Oj12VU5EWNVCRESmZTQKjF1g1MwwAKJ689f5HCSmF6Jqqp0fDqSiqLQcm4+moedHf2LtIcPcPO09DS06MpkMbw0xdGepLOS4z98JMpkMEUEtjM7bmgEQkSRunvmZOUDU3PAbTXVyNf8GnKwtYa20wN7kHKw/fAUXsovxcv/W+Oi3swAMI7R2n8vGxWwNfj52DRsS0nA1/wau5htGcN28Svp9/s5Y8nRX2KsN5wSAl/u3xg2tDnuTc9DRywGeDmrTXygRQSaTiQsA23IeIGpmJG8BWrx4Mfz9/aFWqxEeHo6DBw/etvyiRYvQtm1bWFlZwdfXF6+++ipKS0vF/e+88w5kMpnRq107Js3Whyt5Jej3yS4MXPgXFv6ehNH/dwA/H7uGU1cL8fz/EnAxRwMvBzWmPtAKj3U1JEBvOX4Np64WGJ3n38PRB3fyRI+b1s7yd7HB10+H4fjcQVjz/P2cfp9IQlXdYGwBouZG0gBo3bp1iImJwdy5c3HkyBGEhoYiKioKWVlZNZb/4YcfMH36dMydOxeJiYlYvnw51q1bh7ffftuoXMeOHZGeni6+9uzZY4rLafb+Pp+Dcp2Aq/k38PmfyQCAR7t648FgTwCG5vKlz3RDC1sV+rU1JCsfTMkT1+KqUtUFdicMfIikV5UIbc8kaGpmJP1GL1y4EBMnTsT48eMBAEuWLMHWrVuxYsUKTJ8+vVr5ffv2oWfPnnjqqacAAP7+/oiOjsaBAweMyllYWMDDw6PhL8DMHL6cZ/R+XA9/zB3WAYIADA32RMsW1uL8PB087eFmp0JW5bD3/u3ccCKtAD5OVrecwZmIGp/uAc7YlZTF5V+o2ZEsANJqtUhISMCMGTPEbXK5HJGRkYiPj6/xmB49euC7777DwYMH0b17d1y8eBHbtm3DM888Y1Tu/Pnz8PLyglqtRkREBObPnw8/P78GvR5zkHD5OgDg69Fd4eVohRAfh8puRuDBEE+jsjKZDH3buGJDQhoAYHhnL3wR3aXGFdSJqPFa+EQoynUCf3ep2ZEsAMrJyYFOp4O7u7vRdnd3d5w9e7bGY5566ink5OSgV69eEAQBFRUVePHFF426wMLDw7Fq1Sq0bdsW6enpePfdd9G7d2+cOnUKdnY1/wVTVlaGsrJ/JugrLCyshytsmnYlZeG3k+l45+GOYlIyAGQXleFybglkMsNwdQerOydE9mvrJgZAEYEtYMMcAqImRyaTQWnB7mhqfppUSB8XF4d58+bhq6++wpEjR7Bp0yZs3boV77//vlhmyJAhGDlyJEJCQhAVFYVt27YhPz8f69evv+V558+fDwcHB/Hl6+tristpdDILS/HSD0ex/nAathy7ZrSvqvWnjZtdrYIfAOjb1hVt3e0wpJMH3Ow5kouIiBoPyf4kd3FxgUKhQGZmptH2zMzMW+bvzJ49G8888wwmTJgAAAgODoZGo8Hzzz+PmTNnQi6vHs85OjqiTZs2SE5OvmVdZsyYgZiYGPF9YWGhWQZB87YlorisAgBw4moBnrxpX0Jl/k+Yv1MNR9bMVmWBHa/2qc8qEhER1QvJWoCUSiXCwsIQGxsrbtPr9YiNjUVERESNx5SUlFQLchQKwwgFQRBqOgTFxcW4cOECPD09a9wPACqVCvb29kYvc3LmWiGeWrYfP9/U6nMyrQCbjqRh1NJ4ZBeV4diVfABAV7/aB0BERESNlaRdYDExMVi2bBlWr16NxMRETJo0CRqNRhwVNmbMGKMk6WHDhuHrr7/G2rVrkZKSgp07d2L27NkYNmyYGAi9/vrr2L17Ny5duoR9+/ZhxIgRUCgUiI6OluQam4J3fjmNfRdyYSGX4Zn7WwIAzmYUYv5vZ3EgJQ+bj6bh9DVDXlSoT+1XYSciImqsJM1KHTVqFLKzszFnzhxkZGSgc+fO2L59u5gYnZqaatTiM2vWLMhkMsyaNQtXr16Fq6srhg0bhg8//FAsk5aWhujoaOTm5sLV1RW9evXC/v374erKRTRv5WK2BgDw3YRwhAc445cT15BfUi6u3L756DWUaHVQW8oR6MplKYiIqOmTCbfqOzJjhYWFcHBwQEFBQbPvDruh1aH9nO0AgONzBsHB2hLPLD+Av8/nVCvb1c8Rmyb3NHUViYiIaqUuz+8mNQqM6l/a9RIAgJ3aAg7WhtFdIbfo5qqa5JCIiKipYwBk5q5UBkC+TtbitmBvRwCAjVKBQBcbcXsnLwZARETUPHBmOjN3Jc+wQruvs5W47YF2rng8zAfhAc5IuHwdF3MMOUIdvZt3dyAREZkPBkBmLjWveguQykKB/4wMBQDoBQFrD12BpUKG1m5cC4iIiJoHBkBm7kpVAORsXeP+Pm1cYae2QK9WLlwLiIiImg0GQGYmt7gME749jC6+TnhzcFtcuV69C+xmng5WOPh2JCwVXAuIiIiaDwZAZmb76QwcTc3H0dR8HLqUh8R0wwSHfrdoAQIAK6XCVNUjIiIyCfZpmJmES9fFn09eLRB/9nG6dQBERETU3DAAMjMJqYYAaObQ9kbb1ZZs5SEiIvPBAKgZKy3XQRAECIKA7acycDKtAJdzSyCTAaO6+2LZmG6wVMjwYPCtF4olIiJqjpgD1EydSMvHqKX7Meo+XzzQzg0vfpcgJjK3dbeDvdoSAzu4I37GADhaWUpcWyIiItNiANRMfbXrAm6U67Dl+DWoLA0NfeU6w7JvYS2dxHIutipJ6kdERCQldoE1Q1fySvD7mQwAQJ5Gi1+OXTPa383fqabDiIiIzAZbgJqh/+2/DL3wz/trBaUAgJf7t8LV/FIM6cScHyIiMm8MgJqZCp0eGxPSAADtPe3FeX7sVBZ4JbIN5HJOaEhERMQusGZm34Vc5Gm0cLZRYtqA1uL2zn6ODH6IiIgqMQBqZn45bsj3GRrsge4BzuL2Ln7M+yEiIqrCAKgZKavQYftpQ/LzsBAvONso0c7DsIJ7d3/n2x1KRERkVpgD1IzsOZ+DotIKuNurcF9lwPN5dBecvlaAnq1aSFw7IiKixoMBUDMSl5QNABjYwV3M92njboc27nZSVouIiKjRYRdYM/L3eUMA1Ke1q8Q1ISIiatzYAtTEaSv0WLE3BUGutriUWwILuQwRQezuIiIiuh0GQE3cb6fS8dFvZ8X3Xf2cYKfm2l5ERES3wy6wJi4xvcjofZ82LhLVhIiIqOlgANTEXc7ViD/LZcDADh4S1oaIiKhpYBdYE5eSYwiAPnuyM9p72nPEFxERUS0wAGrC9HpBDIA6+zqiZQsbiWtERETUNLALrAlLLyxFWYUelgoZvB2tpK4OERFRk8EAqAlLyTa0/vg5W8NCwX9KIiKi2uJTswlLySkGAAS62kpcEyIioqaFAVATdqGyBSjQhbk/REREdcEk6CaoqLQcH25NxN/ncwAAAQyAiIiI6oQBUBP0Y0Ia1h66Ir5v5cYuMCIiorpgANQEnUgrAADc5++Efm3dENbSSeIaERERNS0MgJqg42n5AIDJ/VrhgXZu0laGiIioCZI8CXrx4sXw9/eHWq1GeHg4Dh48eNvyixYtQtu2bWFlZQVfX1+8+uqrKC0tvadzNiVFpeW4WDn5YSdvB4lrQ0RE1DRJGgCtW7cOMTExmDt3Lo4cOYLQ0FBERUUhKyurxvI//PADpk+fjrlz5yIxMRHLly/HunXr8Pbbb9/1OZua09cKIQiAl4MarnYqqatDRETUJEkaAC1cuBATJ07E+PHj0aFDByxZsgTW1tZYsWJFjeX37duHnj174qmnnoK/vz8GDRqE6Ohooxaeup6zqTlR2f0V4uMoaT2IiIiaMskCIK1Wi4SEBERGRv5TGbkckZGRiI+Pr/GYHj16ICEhQQx4Ll68iG3btmHo0KF3fU4AKCsrQ2FhodGrsapKgA72YfcXERHR3ZIsCTonJwc6nQ7u7u5G293d3XH27Nkaj3nqqaeQk5ODXr16QRAEVFRU4MUXXxS7wO7mnAAwf/58vPvuu/d4RQ1PW6HHwZQ8AEAIAyAiIqK7JnkSdF3ExcVh3rx5+Oqrr3DkyBFs2rQJW7duxfvvv39P550xYwYKCgrE15UrV+58kAQ2JqQhq6gMbnYq3OfvLHV1iIiImizJWoBcXFygUCiQmZlptD0zMxMeHh41HjN79mw888wzmDBhAgAgODgYGo0Gzz//PGbOnHlX5wQAlUoFlapxJxRrK/RYvCsZADCpXxDUlgqJa0RERNR0SdYCpFQqERYWhtjYWHGbXq9HbGwsIiIiajympKQEcrlxlRUKQyAgCMJdnbOp+P1MBq7m34CbnQrR3f2krg4REVGTJulEiDExMRg7diy6deuG7t27Y9GiRdBoNBg/fjwAYMyYMfD29sb8+fMBAMOGDcPChQvRpUsXhIeHIzk5GbNnz8awYcPEQOhO52yqzqYXAQAiO7iz9YeIiOgeSRoAjRo1CtnZ2ZgzZw4yMjLQuXNnbN++XUxiTk1NNWrxmTVrFmQyGWbNmoWrV6/C1dUVw4YNw4cffljrczZVKbmGyQ8DWnDhUyIionslEwRBkLoSjU1hYSEcHBxQUFAAe3t7qasDAHjw879x+lohlo3phoEdmnYwR0RE1BDq8vxuUqPAzJUgCLhUufxFgIu1xLUhIiJq+hgANQHZxWXQaHWQyQBfZwZARERE94qrwTdigiDgYEoeyir0AAAvByuoLJgATUREdK8YADViO89k4vn/JYjvA1yYAE1ERFQf2AXWiP1+xnhCR3/m/xAREdULBkCNmNLC+J/Hn0PgiYiI6gUDoEYsq7DU6L0fE6CJiIjqBQOgRiyzsEz82VqpQGc/R+kqQ0RE1IwwCboRy6xsAVr7/P1o5WYLF9vGvWArERFRU8EWoEaqQqdHTrGhBSjQ1YbBDxERUT1iANRI5Wq00AuAQi5DCxsGP0RERPWJAVAjVdX95WqrgkIuk7g2REREzQsDoEaqKgHa3Z6tP0RERPWNAVAjVdUC5GavlrgmREREzQ8DoEaqag4gtgARERHVPwZAjZTYBWbHFiAiIqL6xgCokcosqmoBYgBERERU3xgANVJVLUBu7AIjIiKqdwyAGiFBEJBecAMAW4CIiIgaAgOgRii7qAz5JeWQy4AAF64AT0REVN8YADVCiRlFAAzBj9pSIXFtiIiImh8GQI3Q2fRCAEA7T3uJa0JERNQ8MQBqhJIqW4Dae9hJXBMiIqLmiQFQI1TVBdbWgy1AREREDYEBUCNTrtMjOcsQALVjCxAREVGDYADUyFzM1qBcJ8BWZQEfJyupq0NERNQsMQBqZM5mGBKg23rYQSaTSVwbIiKi5okBUCNzMVsDAGjtZitxTYiIiJovBkCNTGpeCQDAr4W1xDUhIiJqvhgANTKXcg0tQC2dOQM0ERFRQ2EA1Mik5hpagFqyBYiIiKjB3FUAVFFRgT/++ANLly5FUZFhyPa1a9dQXFxcr5UzN8VlFcjVaAGwC4yIiKghWdT1gMuXL2Pw4MFITU1FWVkZBg4cCDs7O3z88ccoKyvDkiVLGqKeZuFyZfeXs40S9mpLiWtDRETUfNW5BWjatGno1q0brl+/Diurf+apGTFiBGJjY+u1cuamqvvLz5mtP0RERA2pzgHQ33//jVmzZkGpVBpt9/f3x9WrV++qEosXL4a/vz/UajXCw8Nx8ODBW5bt168fZDJZtdeDDz4olhk3bly1/YMHD76rupnS5Tzm/xAREZlCnbvA9Ho9dDpdte1paWmws6v70g3r1q1DTEwMlixZgvDwcCxatAhRUVFISkqCm5tbtfKbNm2CVqsV3+fm5iI0NBQjR440Kjd48GCsXLlSfK9SqepcN1O7XJUAzRYgIiKiBlXnFqBBgwZh0aJF4nuZTIbi4mLMnTsXQ4cOrXMFFi5ciIkTJ2L8+PHo0KEDlixZAmtra6xYsaLG8s7OzvDw8BBfO3fuhLW1dbUASKVSGZVzcnKqc91MrSoHyK8Fh8ATERE1pDoHQJ9++in27t2LDh06oLS0FE899ZTY/fXxxx/X6VxarRYJCQmIjIz8p0JyOSIjIxEfH1+rcyxfvhxPPvkkbGyMg4a4uDi4ubmhbdu2mDRpEnJzc295jrKyMhQWFhq9pFDVAuTPLjAiIqIGVecuMB8fHxw/fhxr167FiRMnUFxcjOeeew6jR482SoqujZycHOh0Ori7uxttd3d3x9mzZ+94/MGDB3Hq1CksX77caPvgwYPx6KOPIiAgABcuXMDbb7+NIUOGID4+HgqFotp55s+fj3fffbdOda9vhaXluJp/AwAQ5MplMIiIiBpSnQMgALCwsMDTTz9d33Wps+XLlyM4OBjdu3c32v7kk0+KPwcHByMkJARBQUGIi4vDgAEDqp1nxowZiImJEd8XFhbC19e34Speg1NXCwAAPk5WcLJR3qE0ERER3Ys6B0DffvvtbfePGTOm1udycXGBQqFAZmam0fbMzEx4eHjc9liNRoO1a9fivffeu+PnBAYGwsXFBcnJyTUGQCqVSvIk6ZNphgAo2NtB0noQERGZgzoHQNOmTTN6X15ejpKSEiiVSlhbW9cpAFIqlQgLC0NsbCweeeQRAIZRZrGxsZg6deptj92wYQPKyspq1RKVlpaG3NxceHp61rpupnaysgWoEwMgIiKiBlfnJOjr168bvYqLi5GUlIRevXphzZo1da5ATEwMli1bhtWrVyMxMRGTJk2CRqPB+PHjARhalGbMmFHtuOXLl+ORRx5BixYtjLYXFxfjjTfewP79+3Hp0iXExsZi+PDhaNWqFaKioupcP1Op6gIL8WEARERE1NDuKgfo31q3bo2PPvoITz/9dK2Sl282atQoZGdnY86cOcjIyEDnzp2xfft2MTE6NTUVcrlxnJaUlIQ9e/bg999/r3Y+hUKBEydOYPXq1cjPz4eXlxcGDRqE999/X/JurlspuFGOS5UjwDp5MQAiIiJqaDJBEIT6ONGxY8fQp08fyYaQ16fCwkI4ODigoKAA9vb2Df55+5Jz8NT/HYCPkxX2vNW/wT+PiIioOarL87vOLUBbtmwxei8IAtLT0/Hll1+iZ8+edT0dATiTbgga2fpDRERkGnUOgKqSlavIZDK4urqif//++PTTT+urXmYlvaAUAODHCRCJiIhM4q7WAqP6lVEZAHnYqyWuCRERkXmo8ygwqn/XCgwzQHs6MAAiIiIyhVq1AN08S/KdLFy48K4rY66qWoA8Heu2lAgRERHdnVoFQEePHq3VyWQy2T1VxhxV6PTIKioDwBYgIiIiU6lVALRr166GrofZyinWQqcXYCGXwcW2cc5TRERE1NwwB0hiVfk/7vZqKORsQSMiIjKFu5oJ+vDhw1i/fj1SU1Oh1WqN9m3atKleKmYuxBFg7P4iIiIymTq3AK1duxY9evRAYmIiNm/ejPLycpw+fRp//vknHBw4kV9dpTMAIiIiMrk6B0Dz5s3Df//7X/zyyy9QKpX47LPPcPbsWTzxxBPw8/NriDo2axmVXWBeDICIiIhMps4B0IULF/Dggw8CAJRKJTQaDWQyGV599VV888039V7B5u6fFiAOgSciIjKVOgdATk5OKCoqAgB4e3vj1KlTAID8/HyUlJTUb+3MQFUAxCHwREREplPnJOg+ffpg586dCA4OxsiRIzFt2jT8+eef2LlzJwYMGNAQdWzWmARNRERkenUOgL788kuUlhoe2jNnzoSlpSX27duHxx57DLNmzar3CjZner2AzEKuA0ZERGRqdQ6AnJ2dxZ/lcjmmT59erxUyJ3klWlToBchkgKsdJ0EkIiIylTrnAEVGRmLVqlUoLCxsiPqYlarWnxY2KlgqOCclERGRqdT5qduxY0fMmDEDHh4eGDlyJH7++WeUl5c3RN2avao1wNzt2fpDRERkSnUOgD777DNcvXoVP/30E2xsbDBmzBi4u7vj+eefx+7duxuijs1WVmULkBu7v4iIiEzqrvpd5HI5Bg0ahFWrViEzMxNLly7FwYMH0b9///quX7OWWVjVAsQEaCIiIlO6q7XAqmRkZGDt2rX47rvvcOLECXTv3r2+6mUWqnKA3BgAERERmVSdW4AKCwuxcuVKDBw4EL6+vvj666/x8MMP4/z589i/f39D1LHZYg4QERGRNOrcAuTu7g4nJyeMGjUK8+fPR7du3RqiXmbhnxwgtgARERGZUp0DoC1btmDAgAGQyzls+179kwPEFiAiIiJTqnMANHDgwIaoh9nR6QVkFzMJmoiISApsxpFIrqYMOr0AuQxoYaOUujpERERmhQGQRLIqu79cbFWw4CzQREREJsUnr0SyiqqGwDP/h4iIyNQYAElETIDmCDAiIiKTq3MA9PLLL+Pzzz+vtv3LL7/EK6+8Uh91Mgv5JYb10xytmf9DRERkanUOgH788Uf07Nmz2vYePXpg48aN9VIpc6Ct0AMAVJZshCMiIjK1Oj99c3Nz4eDgUG27vb09cnJy6qVS5kCr0wEAVBYMgIiIiEytzk/fVq1aYfv27dW2//bbbwgMDKyXSpmDsnJDC5CSARAREZHJ1XkixJiYGEydOhXZ2dni6u+xsbH49NNPsWjRovquX7Ol1VV2gXEIPBERkcnV+en77LPP4tNPP8Xy5cvxwAMP4IEHHsB3332Hr7/+GhMnTryrSixevBj+/v5Qq9UIDw/HwYMHb1m2X79+kMlk1V4PPvigWEYQBMyZMweenp6wsrJCZGQkzp8/f1d1ayhVOUBsASIiIjK9u3r6Tpo0CWlpacjMzERhYSEuXryIMWPG3FUF1q1bh5iYGMydOxdHjhxBaGgooqKikJWVVWP5TZs2IT09XXydOnUKCoUCI0eOFMssWLAAn3/+OZYsWYIDBw7AxsYGUVFRKC0tvas6NgQxCdpCIXFNiIiIzM89NT+4urrC1tb2niqwcOFCTJw4EePHj0eHDh2wZMkSWFtbY8WKFTWWd3Z2hoeHh/jauXMnrK2txQBIEAQsWrQIs2bNwvDhwxESEoJvv/0W165dw08//XRPda1PZWwBIiIikkytcoC6du2K2NhYODk5oUuXLpDJZLcse+TIkVp/uFarRUJCAmbMmCFuk8vliIyMRHx8fK3OsXz5cjz55JOwsbEBAKSkpCAjIwORkZFiGQcHB4SHhyM+Ph5PPvlkrevXkBgAERERSadWAdDw4cOhUhmWbHjkkUfq7cNzcnKg0+ng7u5utN3d3R1nz5694/EHDx7EqVOnsHz5cnFbRkaGeI5/n7Nq37+VlZWhrKxMfF9YWFjra7hbVUnQSiZBExERmVytAqC5c+cCAHQ6HR544AGEhITA0dGxIetVK8uXL0dwcDC6d+9+T+eZP38+3n333XqqVe2UlVfOA8SJEImIiEyuTk9fhUKBQYMG4fr16/Xy4S4uLlAoFMjMzDTanpmZCQ8Pj9seq9FosHbtWjz33HNG26uOq8s5Z8yYgYKCAvF15cqVul5KnbEFiIiISDp1fvp26tQJFy9erJcPVyqVCAsLQ2xsrLhNr9cjNjYWERERtz12w4YNKCsrw9NPP220PSAgAB4eHkbnLCwsxIEDB255TpVKBXt7e6NXQ+MweCIiIunU+en7wQcf4PXXX8evv/6K9PR0FBYWGr3qKiYmBsuWLcPq1auRmJiISZMmQaPRYPz48QCAMWPGGCVJV1m+fDkeeeQRtGjRwmi7TCbDK6+8gg8++ABbtmzByZMnMWbMGHh5edVr/tK9YgBEREQknTrPBD106FAAwMMPP2w0GkwQBMhkMugq17iqrVGjRiE7Oxtz5sxBRkYGOnfujO3bt4tJzKmpqZDLjYOEpKQk7NmzB7///nuN53zzzTeh0Wjw/PPPIz8/H7169cL27duhVqvrVLeGVMZ5gIiIiCQjEwRBqMsBu3fvvu3+vn373lOFGoPCwkI4ODigoKCgwbrD7p8Xi4zCUvz6Ui908q6+uCwRERHVTV2e33VuAQoICICvr2+1uYAEQTBJ8nBzISZBswuMiIjI5Or89A0ICEB2dna17Xl5eQgICKiXSpkDMQeIo8CIiIhMrs5P36pcn38rLi5uVDk2jV1ZBecBIiIikkqtu8BiYmIAGEZZzZ49G9bW1uI+nU6HAwcOoHPnzvVeweZIrxdQrjOkXrEFiIiIyPRqHQAdPXoUgKEF6OTJk1AqleI+pVKJ0NBQvP766/Vfw2aoKv8HYA4QERGRFGodAO3atQsAMH78eHz22WcmmSywuWIAREREJK06P31XrlwJe3t7JCcnY8eOHbhx4wYAQ8sQ1U5Z+U0BELvAiIiITK7OT9+8vDwMGDAAbdq0wdChQ5Geng4AeO655/Daa6/VewWbo5uHwNeUUE5EREQNq84B0CuvvAJLS0ukpqYaJUKPGjUK27dvr9fKNVdVQ+BVbP0hIiKSRJ0nQvz999+xY8cO+Pj4GG1v3bo1Ll++XG8Va864DhgREZG06vwE1mg0Ri0/VfLy8qBSqeqlUs2dOAcQAyAiIiJJ1PkJ3Lt3b3z77bfie5lMBr1ejwULFuCBBx6o18o1V2wBIiIikladu8AWLFiAAQMG4PDhw9BqtXjzzTdx+vRp5OXlYe/evQ1Rx2aHARAREZG06vwE7tSpE86dO4devXph+PDh0Gg0ePTRR3H06FEEBQU1RB2bnTIuhEpERCSpOrcAAYCDgwNmzpxZ33UxG1XzAKksFBLXhIiIyDzdVQBUWlqKEydOICsrC3q93mjfww8/XC8Va87EeYA4DJ6IiEgSdQ6Atm/fjjFjxiAnJ6faPplMBp1OVy8Va86YA0RERCStOj+BX3rpJYwcORLp6enQ6/VGLwY/tcMAiIiISFp1fgJnZmYiJiYG7u7uDVEfs8B5gIiIiKRV5yfw448/jri4uAaoivlgCxAREZG06pwD9OWXX2LkyJH4+++/ERwcDEtLS6P9L7/8cr1VrrkS1wJjAERERCSJOgdAa9aswe+//w61Wo24uDij1cxlMhkDoFrgKDAiIiJp1TkAmjlzJt59911Mnz4dcjkf4HejrKoFyJLzABEREUmhzhGMVqvFqFGjGPzcAzEHiC1AREREkqjzE3js2LFYt25dQ9TFbJQxCZqIiEhSde4C0+l0WLBgAXbs2IGQkJBqSdALFy6st8o1VxwFRkREJK06B0AnT55Ely5dAACnTp0y2ndzQjTdGucBIiIikladA6Bdu3Y1RD3MCluAiIiIpMUnsAQ4DJ6IiEhafAJLgC1ARERE0uITWALiPEAWnAeIiIhICgyAJMClMIiIiKTFJ7AE2AVGREQkLT6BJVA1DJ4BEBERkTT4BJYAu8CIiIikJfkTePHixfD394darUZ4eDgOHjx42/L5+fmYMmUKPD09oVKp0KZNG2zbtk3c/84770Amkxm92rVr19CXUSfiMHgGQERERJKo80SI9WndunWIiYnBkiVLEB4ejkWLFiEqKgpJSUlwc3OrVl6r1WLgwIFwc3PDxo0b4e3tjcuXL8PR0dGoXMeOHfHHH3+I7y0sJL3Masq4GCoREZGkJI0MFi5ciIkTJ2L8+PEAgCVLlmDr1q1YsWIFpk+fXq38ihUrkJeXh3379olrkPn7+1crZ2FhAQ8Pjwat+72o6gKzZABEREQkCcmewFqtFgkJCYiMjPynMnI5IiMjER8fX+MxW7ZsQUREBKZMmQJ3d3d06tQJ8+bNg06nMyp3/vx5eHl5ITAwEKNHj0Zqaupt61JWVobCwkKjV0PS6QUADICIiIikItkTOCcnBzqdDu7u7kbb3d3dkZGRUeMxFy9exMaNG6HT6bBt2zbMnj0bn376KT744AOxTHh4OFatWoXt27fj66+/RkpKCnr37o2ioqJb1mX+/PlwcHAQX76+vvVzkbegEwwBkJzxDxERkSQaV3LMHej1eri5ueGbb76BQqFAWFgYrl69ik8++QRz584FAAwZMkQsHxISgvDwcLRs2RLr16/Hc889V+N5Z8yYgZiYGPF9YWFhgwVBer2AyvgHFoyAiIiIJCFZAOTi4gKFQoHMzEyj7ZmZmbfM3/H09ISlpSUUin+WkGjfvj0yMjKg1WqhVCqrHePo6Ig2bdogOTn5lnVRqVRQqVR3eSV1U9X6AwAKmcwkn0lERETGJGuCUCqVCAsLQ2xsrLhNr9cjNjYWERERNR7Ts2dPJCcnQ6/Xi9vOnTsHT0/PGoMfACguLsaFCxfg6elZvxdwl6ryfwB2gREREUlF0kdwTEwMli1bhtWrVyMxMRGTJk2CRqMRR4WNGTMGM2bMEMtPmjQJeXl5mDZtGs6dO4etW7di3rx5mDJliljm9ddfx+7du3Hp0iXs27cPI0aMgEKhQHR0tMmvryb6m1qA2AVGREQkDUlzgEaNGoXs7GzMmTMHGRkZ6Ny5M7Zv3y4mRqempkJ+U5Dg6+uLHTt24NVXX0VISAi8vb0xbdo0vPXWW2KZtLQ0REdHIzc3F66urujVqxf2798PV1dXk19fTSrYAkRERCQ5mSDc1CRBAAxJ0A4ODigoKIC9vX29nju/RIvO7+0EAFyYNxQKOfOAiIiI6kNdnt9sgzAxoxYgxj5ERESSYABkYvrKAEguA2QcBUZERCQJBkAmVjUMngnQRERE0uFT2MQqdJwFmoiISGp8DJuYni1AREREkuNT2MQqbsoBIiIiImkwADKxqiRoDn8nIiKSDgMgE6tKglawC4yIiEgyfAqbWFUStIJ3noiISDJ8DJtYVRI0V4InIiKSDgMgE6tKglYoGAARERFJhQGQiYlJ0GwBIiIikgwDIBPTcRQYERGR5BgAmRgDICIiIukxADKxqmHwcnaBERERSYYBkIlVJUFbMAmaiIhIMgyATIxJ0ERERNJjAGRizAEiIiKSHgMgE2MAREREJD0GQCbGJGgiIiLpMQAyMR2ToImIiCTHAMjEqgIgtgARERFJhwGQiYktQMwBIiIikgwDIBNjEjQREZH0GACZGJOgiYiIpMcAyMSYBE1ERCQ9BkAmxiRoIiIi6TEAMjEmQRMREUmPAZCJiS1ADICIiIgkwwDIxKqSoLkYKhERkXQYAJmYTsckaCIiIqkxADIxDoMnIiKSHgMgE9MzCZqIiEhyDIBMrIJJ0ERERJKTPABavHgx/P39oVarER4ejoMHD962fH5+PqZMmQJPT0+oVCq0adMG27Ztu6dzmhKToImIiKQnaQC0bt06xMTEYO7cuThy5AhCQ0MRFRWFrKysGstrtVoMHDgQly5dwsaNG5GUlIRly5bB29v7rs9palVJ0AomQRMREUlG0gBo4cKFmDhxIsaPH48OHTpgyZIlsLa2xooVK2osv2LFCuTl5eGnn35Cz5494e/vj759+yI0NPSuz2lqbAEiIiKSnmQBkFarRUJCAiIjI/+pjFyOyMhIxMfH13jMli1bEBERgSlTpsDd3R2dOnXCvHnzoNPp7vqcAFBWVobCwkKjV0NhEjQREZH0JAuAcnJyoNPp4O7ubrTd3d0dGRkZNR5z8eJFbNy4ETqdDtu2bcPs2bPx6aef4oMPPrjrcwLA/Pnz4eDgIL58fX3v8epujUnQRERE0pM8Cbou9Ho93Nzc8M033yAsLAyjRo3CzJkzsWTJkns674wZM1BQUCC+rly5Uk81rk7PLjAiIiLJWUj1wS4uLlAoFMjMzDTanpmZCQ8PjxqP8fT0hKWlJRQKhbitffv2yMjIgFarvatzAoBKpYJKpbqHq6m9CiZBExERSU6yFiClUomwsDDExsaK2/R6PWJjYxEREVHjMT179kRycjL0er247dy5c/D09IRSqbyrc5oak6CJiIikJ2kXWExMDJYtW4bVq1cjMTERkyZNgkajwfjx4wEAY8aMwYwZM8TykyZNQl5eHqZNm4Zz585h69atmDdvHqZMmVLrc0qtKglawRwgIiIiyUjWBQYAo0aNQnZ2NubMmYOMjAx07twZ27dvF5OYU1NTIZf/E6P5+vpix44dePXVVxESEgJvb29MmzYNb731Vq3PKbUKBkBERESSkwlCZZ8MiQoLC+Hg4ICCggLY29vX67knf5+AbScz8N7wjhgT4V+v5yYiIjJndXl+N6lRYM2BmATNFiAiIiLJMAAyMQ6DJyIikh4DIBPTMQeIiIhIcgyATIxJ0ERERNJjAGRiYhcYAyAiIiLJMAAyMXaBERERSY8BkImJARCToImIiCTDAMjE2AJEREQkPQZAJsYAiIiISHoMgEysajFUOQMgIiIiyTAAMjFd5UL2FgyAiIiIJMMAyMR0ekMExCRoIiIi6TAAMjHmABEREUmPAZCJMQAiIiKSHgMgE2MSNBERkfQYAJmYnknQREREkmMAZGIVlRGQnEnQREREkmEAZGLiMHgFAyAiIiKpMAAyMQ6DJyIikh4DIBOrGgXGJGgiIiLpMAAyscr4h0nQREREEmIAZGJMgiYiIpIeAyAT0zMJmoiISHIMgEysgknQREREkmMAZEKCIIg5QEyCJiIikg4DIBOqCn4AJkETERFJiQGQCVV1fwFsASIiIpISAyATuin+YQ4QERGRhBgAmdDNLUAKtgARERFJhgGQCRm1ADEAIiIikgwDIBPSCf9kQbMLjIiISDoMgEyoqgtMJmMSNBERkZQYAJlQVRcYW3+IiIikxQDIhMRZoNn6Q0REJKlGEQAtXrwY/v7+UKvVCA8Px8GDB29ZdtWqVZDJZEYvtVptVGbcuHHVygwePLihL+OOxBYgBkBERESSspC6AuvWrUNMTAyWLFmC8PBwLFq0CFFRUUhKSoKbm1uNx9jb2yMpKUl8L6uhS2nw4MFYuXKl+F6lUtV/5euoKgmaARAREZG0JG8BWrhwISZOnIjx48ejQ4cOWLJkCaytrbFixYpbHiOTyeDh4SG+3N3dq5VRqVRGZZycnBryMmpFxy4wIiKiRkHSAEir1SIhIQGRkZHiNrlcjsjISMTHx9/yuOLiYrRs2RK+vr4YPnw4Tp8+Xa1MXFwc3Nzc0LZtW0yaNAm5ubkNcg11oWMSNBERUaMgaQCUk5MDnU5XrQXH3d0dGRkZNR7Ttm1brFixAj///DO+++476PV69OjRA2lpaWKZwYMH49tvv0VsbCw+/vhj7N69G0OGDIFOp6vxnGVlZSgsLDR6NQQmQRMRETUOkucA1VVERAQiIiLE9z169ED79u2xdOlSvP/++wCAJ598UtwfHByMkJAQBAUFIS4uDgMGDKh2zvnz5+Pdd99t8LozCZqIiKhxkLQFyMXFBQqFApmZmUbbMzMz4eHhUatzWFpaokuXLkhOTr5lmcDAQLi4uNyyzIwZM1BQUCC+rly5UvuLqAMmQRMRETUOkgZASqUSYWFhiI2NFbfp9XrExsYatfLcjk6nw8mTJ+Hp6XnLMmlpacjNzb1lGZVKBXt7e6NXQ2ASNBERUeMg+SiwmJgYLFu2DKtXr0ZiYiImTZoEjUaD8ePHAwDGjBmDGTNmiOXfe+89/P7777h48SKOHDmCp59+GpcvX8aECRMAGBKk33jjDezfvx+XLl1CbGwshg8fjlatWiEqKkqSa6zCJGgiIqLGQfIcoFGjRiE7Oxtz5sxBRkYGOnfujO3bt4uJ0ampqZDL/4nTrl+/jokTJyIjIwNOTk4ICwvDvn370KFDBwCAQqHAiRMnsHr1auTn58PLywuDBg3C+++/L/lcQEyCJiIiahxkgnDTEuUEACgsLISDgwMKCgrqtTtsz/kcPL38ANp52GH7K33q7bxERFQ3giCgoqLilqODqXFSKBSwsLCocQJkoG7Pb8lbgMwJk6CJiKSn1WqRnp6OkpISqatCd8Ha2hqenp5QKpX3dB4GQCbEJGgiImnp9XqkpKRAoVDAy8sLSqXylq0J1LgIggCtVovs7GykpKSgdevWRikydcUAyISqkqDl/GUjIpKEVquFXq+Hr68vrK2tpa4O1ZGVlRUsLS1x+fJlaLXaaouh14Xko8DMSVULkAVbgIiIJHUvLQckrfr6t+M3wITEFiAGQERERJJiAGRCVUnQbAEiIiKSFgMgE2ISNBERUePAAMiEmARNRETNSXl5udRVuGsMgEyISdBERHQvtm/fjl69esHR0REtWrTAQw89hAsXLoj709LSEB0dDWdnZ9jY2KBbt244cOCAuP+XX37BfffdB7VaDRcXF4wYMULcJ5PJ8NNPPxl9nqOjI1atWgUAuHTpEmQyGdatW4e+fftCrVbj+++/R25uLqKjo+Ht7Q1ra2sEBwdjzZo1RufR6/VYsGABWrVqBZVKBT8/P3z44YcAgP79+2Pq1KlG5bOzs6FUKo3WCq1vHAZvQkyCJiJqfARBwI1yaWaEtrJU1GkeIo1Gg5iYGISEhKC4uBhz5szBiBEjcOzYMZSUlKBv377w9vbGli1b4OHhgSNHjkBf+cf31q1bMWLECMycORPffvsttFottm3bVuc6T58+HZ9++im6dOkCtVqN0tJShIWF4a233oK9vT22bt2KZ555BkFBQejevTsAYMaMGVi2bBn++9//olevXkhPT8fZs2cBABMmTMDUqVPx6aefiktWfffdd/D29kb//v3rXL/aYgBkQkyCJiJqfG6U69Bhzg5JPvvMe1GwVtb+UfzYY48ZvV+xYgVcXV1x5swZ7Nu3D9nZ2Th06BCcnZ0BAK1atRLLfvjhh3jyySfx7rvvittCQ0PrXOdXXnkFjz76qNG2119/Xfz5pZdewo4dO7B+/Xp0794dRUVF+Oyzz/Dll19i7NixAICgoCD06tULAPDoo49i6tSp+Pnnn/HEE08AAFatWoVx48Y16CSV7AIzIV1lExBbgIiI6G6cP38e0dHRCAwMhL29Pfz9/QEYFg4/duwYunTpIgY//3bs2DEMGDDgnuvQrVs3o/c6nQ7vv/8+goOD4ezsDFtbW+zYsQOpqakAgMTERJSVld3ys9VqNZ555hmsWLECAHDkyBGcOnUK48aNu+e63g5bgExIV7nsrIJJ0EREjYaVpQJn3ouS7LPrYtiwYWjZsiWWLVsGLy8v6PV6dOrUCVqtFlZWVrf/rDvsl8lk+Pf66DUlOdvY2Bi9/+STT/DZZ59h0aJFCA4Oho2NDV555RVotdpafS5g6Abr3Lkz0tLSsHLlSvTv3x8tW7a843H3gi1AJqTXswuMiKixkclksFZaSPKqSxdPbm4ukpKSMGvWLAwYMADt27fH9evXxf0hISE4duwY8vLyajw+JCTktknFrq6uSE9PF9+fP3++VgvG7t27F8OHD8fTTz+N0NBQBAYG4ty5c+L+1q1bw8rK6rafHRwcjG7dumHZsmX44Ycf8Oyzz97xc+8VAyATqqgMgNgFRkREdeXk5IQWLVrgm2++QXJyMv7880/ExMSI+6Ojo+Hh4YFHHnkEe/fuxcWLF/Hjjz8iPj4eADB37lysWbMGc+fORWJiIk6ePImPP/5YPL5///748ssvcfToURw+fBgvvvgiLC0t71iv1q1bY+fOndi3bx8SExPxwgsvIDMzU9yvVqvx1ltv4c0338S3336LCxcuYP/+/Vi+fLnReSZMmICPPvoIgiAYjU5rKAyATEghB9SWcqgseNuJiKhu5HI51q5di4SEBHTq1AmvvvoqPvnkE3G/UqnE77//Djc3NwwdOhTBwcH46KOPoFAYutn69euHDRs2YMuWLejcuTP69++PgwcPisd/+umn8PX1Re/evfHUU0/h9ddfr9WCsbNmzULXrl0RFRWFfv36iUHYzWbPno3XXnsNc+bMQfv27TFq1ChkZWUZlYmOjoaFhQWio6PvaZHT2pIJ/+7wIxQWFsLBwQEFBQWwt7eXujpERFRPSktLkZKSgoCAAJM8ZKn2Ll26hKCgIBw6dAhdu3a9Zbnb/RvW5fnNJGgiIiKSTHl5OXJzczFr1izcf//9tw1+6hP7YoiIiEgye/fuhaenJw4dOoQlS5aY7HPZAkRERESS6devX7Xh96bAFiAiIiIyOwyAiIiIyOwwACIiIrPDAdBNV3392zEAIiIis1E1sV9tZjimxqnq3642kzTeDpOgiYjIbCgUCjg6OoqT8FlbWzfoiuNUfwRBQElJCbKysuDo6ChO8Hi3GAAREZFZ8fDwAIBqMxFT0+Do6Cj+G94LBkBERGRWZDIZPD094ebmVuNq59R4WVpa3nPLTxUGQEREZJYUCkW9PUyp6WESNBEREZkdBkBERERkdhgAERERkdlhDlANqiZZKiwslLgmREREVFtVz+3aTJbIAKgGRUVFAABfX1+Ja0JERER1VVRUBAcHh9uWkQmcD7wavV6Pa9euwc7Ort4myCosLISvry+uXLkCe3v7ejlnc8V7VTe8X7XHe1U3vF+1x3tVew15rwRBQFFREby8vCCX3z7Lhy1ANZDL5fDx8WmQc9vb2/OXo5Z4r+qG96v2eK/qhver9nivaq+h7tWdWn6qMAmaiIiIzA4DICIiIjI7DIBMRKVSYe7cuVCpVFJXpdHjvaob3q/a472qG96v2uO9qr3Gcq+YBE1ERERmhy1AREREZHYYABEREZHZYQBEREREZocBEBEREZkdBkAmsnjxYvj7+0OtViM8PBwHDx6UukqSe+eddyCTyYxe7dq1E/eXlpZiypQpaNGiBWxtbfHYY48hMzNTwhqbzl9//YVhw4bBy8sLMpkMP/30k9F+QRAwZ84ceHp6wsrKCpGRkTh//rxRmby8PIwePRr29vZwdHTEc889h+LiYhNehenc6X6NGzeu2ndt8ODBRmXM5X7Nnz8f9913H+zs7ODm5oZHHnkESUlJRmVq87uXmpqKBx98ENbW1nBzc8Mbb7yBiooKU15Kg6vNverXr1+179aLL75oVMYc7tXXX3+NkJAQcXLDiIgI/Pbbb+L+xvidYgBkAuvWrUNMTAzmzp2LI0eOIDQ0FFFRUcjKypK6apLr2LEj0tPTxdeePXvEfa+++ip++eUXbNiwAbt378a1a9fw6KOPSlhb09FoNAgNDcXixYtr3L9gwQJ8/vnnWLJkCQ4cOAAbGxtERUWhtLRULDN69GicPn0aO3fuxK+//oq//voLzz//vKkuwaTudL8AYPDgwUbftTVr1hjtN5f7tXv3bkyZMgX79+/Hzp07UV5ejkGDBkGj0Yhl7vS7p9Pp8OCDD0Kr1WLfvn1YvXo1Vq1ahTlz5khxSQ2mNvcKACZOnGj03VqwYIG4z1zulY+PDz766CMkJCTg8OHD6N+/P4YPH47Tp08DaKTfKYEaXPfu3YUpU6aI73U6neDl5SXMnz9fwlpJb+7cuUJoaGiN+/Lz8wVLS0thw4YN4rbExEQBgBAfH2+iGjYOAITNmzeL7/V6veDh4SF88skn4rb8/HxBpVIJa9asEQRBEM6cOSMAEA4dOiSW+e233wSZTCZcvXrVZHWXwr/vlyAIwtixY4Xhw4ff8hhzvl9ZWVkCAGH37t2CINTud2/btm2CXC4XMjIyxDJff/21YG9vL5SVlZn2Akzo3/dKEAShb9++wrRp0255jLneK0EQBCcnJ+H//u//Gu13ii1ADUyr1SIhIQGRkZHiNrlcjsjISMTHx0tYs8bh/Pnz8PLyQmBgIEaPHo3U1FQAQEJCAsrLy43uW7t27eDn52f29y0lJQUZGRlG98bBwQHh4eHivYmPj4ejoyO6desmlomMjIRcLseBAwdMXufGIC4uDm5ubmjbti0mTZqE3NxccZ8536+CggIAgLOzM4Da/e7Fx8cjODgY7u7uYpmoqCgUFhaKf/E3R/++V1W+//57uLi4oFOnTpgxYwZKSkrEfeZ4r3Q6HdauXQuNRoOIiIhG+53iYqgNLCcnBzqdzugfFQDc3d1x9uxZiWrVOISHh2PVqlVo27Yt0tPT8e6776J37944deoUMjIyoFQq4ejoaHSMu7s7MjIypKlwI1F1/TV9p6r2ZWRkwM3NzWi/hYUFnJ2dzfL+DR48GI8++igCAgJw4cIFvP322xgyZAji4+OhUCjM9n7p9Xq88sor6NmzJzp16gQAtfrdy8jIqPH7V7WvOarpXgHAU089hZYtW8LLywsnTpzAW2+9haSkJGzatAmAed2rkydPIiIiAqWlpbC1tcXmzZvRoUMHHDt2rFF+pxgAkWSGDBki/hwSEoLw8HC0bNkS69evh5WVlYQ1o+bmySefFH8ODg5GSEgIgoKCEBcXhwEDBkhYM2lNmTIFp06dMsq9o5rd6l7dnCcWHBwMT09PDBgwABcuXEBQUJCpqymptm3b4tixYygoKMDGjRsxduxY7N69W+pq3RK7wBqYi4sLFApFtWz3zMxMeHh4SFSrxsnR0RFt2rRBcnIyPDw8oNVqkZ+fb1SG9w3i9d/uO+Xh4VEtyb6iogJ5eXlmf/8AIDAwEC4uLkhOTgZgnvdr6tSp+PXXX7Fr1y74+PiI22vzu+fh4VHj969qX3Nzq3tVk/DwcAAw+m6Zy71SKpVo1aoVwsLCMH/+fISGhuKzzz5rtN8pBkANTKlUIiwsDLGxseI2vV6P2NhYRERESFizxqe4uBgXLlyAp6cnwsLCYGlpaXTfkpKSkJqaavb3LSAgAB4eHkb3prCwEAcOHBDvTUREBPLz85GQkCCW+fPPP6HX68X/QZuztLQ05ObmwtPTE4B53S9BEDB16lRs3rwZf/75JwICAoz21+Z3LyIiAidPnjQKGnfu3Al7e3t06NDBNBdiAne6VzU5duwYABh9t8zhXtVEr9ejrKys8X6nGiS1moysXbtWUKlUwqpVq4QzZ84Izz//vODo6GiU7W6OXnvtNSEuLk5ISUkR9u7dK0RGRgouLi5CVlaWIAiC8OKLLwp+fn7Cn3/+KRw+fFiIiIgQIiIiJK61aRQVFQlHjx4Vjh49KgAQFi5cKBw9elS4fPmyIAiC8NFHHwmOjo7Czz//LJw4cUIYPny4EBAQINy4cUM8x+DBg4UuXboIBw4cEPbs2SO0bt1aiI6OluqSGtTt7ldRUZHw+uuvC/Hx8UJKSorwxx9/CF27dhVat24tlJaWiucwl/s1adIkwcHBQYiLixPS09PFV0lJiVjmTr97FRUVQqdOnYRBgwYJx44dE7Zv3y64uroKM2bMkOKSGsyd7lVycrLw3nvvCYcPHxZSUlKEn3/+WQgMDBT69OkjnsNc7tX06dOF3bt3CykpKcKJEyeE6dOnCzKZTPj9998FQWic3ykGQCbyxRdfCH5+foJSqRS6d+8u7N+/X+oqSW7UqFGCp6enoFQqBW9vb2HUqFFCcnKyuP/GjRvC5MmTBScnJ8Ha2loYMWKEkJ6eLmGNTWfXrl0CgGqvsWPHCoJgGAo/e/Zswd3dXVCpVMKAAQOEpKQko3Pk5uYK0dHRgq2trWBvby+MHz9eKCoqkuBqGt7t7ldJSYkwaNAgwdXVVbC0tBRatmwpTJw4sdofIOZyv2q6TwCElStXimVq87t36dIlYciQIYKVlZXg4uIivPbaa0J5ebmJr6Zh3elepaamCn369BGcnZ0FlUoltGrVSnjjjTeEgoICo/OYw7169tlnhZYtWwpKpVJwdXUVBgwYIAY/gtA4v1MyQRCEhmlbIiIiImqcmANEREREZocBEBEREZkdBkBERERkdhgAERERkdlhAERERERmhwEQERERmR0GQERERGR2GAAREVWKi4uDTCartmYRETU/DICIiIjI7DAAIiIiIrPDAIiImhy9Xo8FCxagVatWUKlU8PPzw4cffoj+/ftj6tSpRmWzs7OhVCrFlajLysrw1ltvwdfXFyqVCq1atcLy5ctv+Vl79uxB7969YWVlBV9fX7z88svQaDQNen1E1PAYABFRkzNjxgx89NFHmD17Ns6cOYMffvgB7u7umDBhAn744QeUlZWJZb/77jt4e3ujf//+AIAxY8ZgzZo1+Pzzz5GYmIilS5fC1ta2xs+5cOECBg8ejMceewwnTpzAunXrsGfPnmpBFhE1PVwMlYialKKiIri6uuLLL7/EhAkTjPaVlpbCy8sLS5YswRNPPAEACA0NxaOPPoq5c+fi3LlzaNu2LXbu3InIyMhq546Li8MDDzyA69evw9HRERMmTIBCocDSpUvFMnv27EHfvn2h0WigVqsb9mKJqMGwBYiImpTExESUlZVhwIAB1fap1Wo888wzWLFiBQDgyJEjOHXqFMaNGwcAOHbsGBQKBfr27Vurzzp+/DhWrVoFW1tb8RUVFQW9Xo+UlJR6uyYiMj0LqStARFQXVlZWt90/YcIEdO7cGWlpaVi5ciX69++Pli1b1urYfysuLsYLL7yAl19+udo+Pz+/Op2LiBoXtgARUZPSunVrWFlZiUnN/xYcHIxu3bph2bJl+OGHH/Dss88a7dPr9di9e3etPqtr1644c+YMWrVqVe2lVCrr5XqISBoMgIioSVGr1Xjrrbfw5ptv4ttvv8WFCxewf/9+o5FcEyZMwEcffQRBEDBixAhxu7+/P8aOHYtnn30WP/30E1JSUhAXF4f169fX+FlvvfUW9u3bh6lTp+LYsWM4f/48fv75ZyZBEzUDDICIqMmZPXs2XnvtNcyZMwft27fHqFGjkJWVJe6Pjo6GhYUFoqOjqyUqf/3113j88ccxefJktGvXDhMnTrzlsPaQkBDs3r0b586dQ+/evdGlSxfMmTMHXl5eDXp9RNTwOAqMiJqdS5cuISgoCIcOHULXrl2lrg4RNUIMgIio2SgvL0dubi5ef/11pKSkYO/evVJXiYgaKXaBEVGzsXfvXnh6euLQoUNYsmSJ1NUhokaMLUBERERkdtgCRERERGaHARARERGZHQZAREREZHYYABEREZHZYQBEREREZocBEBEREZkdBkBERERkdhgAERERkdlhAERERERm5/8BMhP/ajfA16cAAAAASUVORK5CYII=\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.52664}, {'accuracy': 0.65172}, {'accuracy': 0.71045}, {'accuracy': 0.72696}, {'accuracy': 0.7420099999999998}, {'accuracy': 0.75029}, {'accuracy': 0.7624099999999999}, {'accuracy': 0.77171}, {'accuracy': 0.7881}, {'accuracy': 0.7842399999999999}, {'accuracy': 0.79577}, {'accuracy': 0.7990900000000001}, {'accuracy': 0.80722}, {'accuracy': 0.80694}, {'accuracy': 0.81809}, {'accuracy': 0.81613}, {'accuracy': 0.8221699999999998}, {'accuracy': 0.827}, {'accuracy': 0.8308300000000001}, {'accuracy': 0.8235899999999999}, {'accuracy': 0.83117}, {'accuracy': 0.8288499999999999}, {'accuracy': 0.8360799999999999}, {'accuracy': 0.8348099999999998}, {'accuracy': 0.83277}, {'accuracy': 0.84559}, {'accuracy': 0.8463800000000001}, {'accuracy': 0.84913}, {'accuracy': 0.8409300000000002}, {'accuracy': 0.8459900000000001}, {'accuracy': 0.8383200000000001}, {'accuracy': 0.8468500000000001}, {'accuracy': 0.8541000000000001}, {'accuracy': 0.85247}, {'accuracy': 0.8542299999999999}, {'accuracy': 0.8548}, {'accuracy': 0.8533899999999999}, {'accuracy': 0.85545}, {'accuracy': 0.8590099999999999}, {'accuracy': 0.8553200000000001}, {'accuracy': 0.84947}, {'accuracy': 0.85602}, {'accuracy': 0.8526499999999999}, {'accuracy': 0.8617800000000001}, {'accuracy': 0.85997}, {'accuracy': 0.85978}, {'accuracy': 0.85664}, {'accuracy': 0.86303}, {'accuracy': 0.86301}, {'accuracy': 0.8565400000000001}, {'accuracy': 0.8560800000000001}, {'accuracy': 0.86624}, {'accuracy': 0.86262}, {'accuracy': 0.8606999999999999}, {'accuracy': 0.8645799999999999}, {'accuracy': 0.8684700000000001}, {'accuracy': 0.8687399999999998}, {'accuracy': 0.86675}, {'accuracy': 0.86751}, {'accuracy': 0.86973}, {'accuracy': 0.8647}, {'accuracy': 0.86929}, {'accuracy': 0.8630799999999998}, {'accuracy': 0.8700999999999999}, {'accuracy': 0.87156}, {'accuracy': 0.87361}, {'accuracy': 0.8699200000000001}, {'accuracy': 0.87062}, {'accuracy': 0.87279}, {'accuracy': 0.8724999999999999}, {'accuracy': 0.87353}, {'accuracy': 0.8677300000000001}, {'accuracy': 0.8677400000000001}, {'accuracy': 0.8759399999999999}, {'accuracy': 0.8765000000000001}, {'accuracy': 0.8656799999999999}, {'accuracy': 0.87651}, {'accuracy': 0.8694700000000001}, {'accuracy': 0.87898}, {'accuracy': 0.8754199999999999}, {'accuracy': 0.8677699999999999}, {'accuracy': 0.8748400000000001}, {'accuracy': 0.88039}, {'accuracy': 0.8757400000000001}, {'accuracy': 0.8738000000000001}, {'accuracy': 0.8725999999999999}, {'accuracy': 0.8800699999999999}, {'accuracy': 0.8767999999999999}, {'accuracy': 0.88027}, {'accuracy': 0.8787900000000001}, {'accuracy': 0.881}, {'accuracy': 0.87666}, {'accuracy': 0.8811199999999999}, {'accuracy': 0.8777699999999999}, {'accuracy': 0.8802200000000001}, {'accuracy': 0.88005}, {'accuracy': 0.8767099999999999}, {'accuracy': 0.88141}, {'accuracy': 0.8816200000000001}, {'accuracy': 0.8833499999999999}, {'accuracy': 0.8785000000000001}, {'accuracy': 0.88282}, {'accuracy': 0.8805400000000001}, {'accuracy': 0.87858}, {'accuracy': 0.88316}, {'accuracy': 0.87924}, {'accuracy': 0.88279}, {'accuracy': 0.8838000000000001}, {'accuracy': 0.8812000000000001}, {'accuracy': 0.8848800000000001}, {'accuracy': 0.88659}, {'accuracy': 0.8847299999999999}, {'accuracy': 0.88534}, {'accuracy': 0.8863}, {'accuracy': 0.8853000000000002}, {'accuracy': 0.88659}, {'accuracy': 0.88506}, {'accuracy': 0.8803699999999999}, {'accuracy': 0.8870699999999999}, {'accuracy': 0.88538}, {'accuracy': 0.88482}, {'accuracy': 0.8842099999999998}, {'accuracy': 0.88713}, {'accuracy': 0.8888600000000002}, {'accuracy': 0.8878300000000001}, {'accuracy': 0.88717}, {'accuracy': 0.88902}, {'accuracy': 0.8842800000000001}, {'accuracy': 0.8868600000000001}, {'accuracy': 0.88757}, {'accuracy': 0.8852299999999997}, {'accuracy': 0.8870799999999999}, {'accuracy': 0.8827299999999999}, {'accuracy': 0.8892800000000001}, {'accuracy': 0.8878600000000001}, {'accuracy': 0.88957}, {'accuracy': 0.88697}, {'accuracy': 0.88934}, {'accuracy': 0.8872300000000001}, {'accuracy': 0.88841}, {'accuracy': 0.8862500000000001}, {'accuracy': 0.8910300000000001}, {'accuracy': 0.8903099999999998}, {'accuracy': 0.8904800000000002}, {'accuracy': 0.89115}, {'accuracy': 0.8894399999999999}, {'accuracy': 0.8880800000000001}, {'accuracy': 0.8882200000000001}, {'accuracy': 0.8906799999999999}, {'accuracy': 0.8886900000000001}, {'accuracy': 0.8914900000000001}, {'accuracy': 0.8905000000000001}, {'accuracy': 0.88738}, {'accuracy': 0.8893199999999999}, {'accuracy': 0.8899700000000001}, {'accuracy': 0.89115}, {'accuracy': 0.88719}, {'accuracy': 0.89185}, {'accuracy': 0.89369}, {'accuracy': 0.8914799999999999}, {'accuracy': 0.8909499999999999}, {'accuracy': 0.8925500000000002}, {'accuracy': 0.8916999999999999}, {'accuracy': 0.89176}, {'accuracy': 0.89238}, {'accuracy': 0.8885400000000001}, {'accuracy': 0.88968}, {'accuracy': 0.8957200000000002}, {'accuracy': 0.8937299999999999}, {'accuracy': 0.8875499999999998}, {'accuracy': 0.8894499999999999}, {'accuracy': 0.89118}, {'accuracy': 0.8930400000000001}, {'accuracy': 0.89179}, {'accuracy': 0.89033}, {'accuracy': 0.89162}, {'accuracy': 0.89313}, {'accuracy': 0.8938299999999998}, {'accuracy': 0.89516}, {'accuracy': 0.88731}, {'accuracy': 0.89376}, {'accuracy': 0.89225}, {'accuracy': 0.8861399999999999}, {'accuracy': 0.8955500000000001}, {'accuracy': 0.8957499999999999}, {'accuracy': 0.89585}, {'accuracy': 0.89467}, {'accuracy': 0.8931700000000001}, {'accuracy': 0.8940000000000001}, {'accuracy': 0.89543}, {'accuracy': 0.89155}, {'accuracy': 0.8933099999999999}, {'accuracy': 0.89592}, {'accuracy': 0.8946099999999999}, {'accuracy': 0.8944300000000001}, {'accuracy': 0.8929199999999998}, {'accuracy': 0.8932199999999998}, {'accuracy': 0.89469}, {'accuracy': 0.8959199999999999}, {'accuracy': 0.89534}, {'accuracy': 0.85272}, {'accuracy': 0.88262}, {'accuracy': 0.8855899999999999}, {'accuracy': 0.8931000000000001}, {'accuracy': 0.88616}, {'accuracy': 0.8894400000000001}, {'accuracy': 0.8943200000000001}, {'accuracy': 0.8932399999999999}, {'accuracy': 0.8936900000000001}, {'accuracy': 0.8937700000000002}, {'accuracy': 0.89557}, {'accuracy': 0.8942500000000001}, {'accuracy': 0.89503}, {'accuracy': 0.89427}, {'accuracy': 0.8948400000000001}, {'accuracy': 0.89458}, {'accuracy': 0.89481}, {'accuracy': 0.8939100000000002}, {'accuracy': 0.89344}, {'accuracy': 0.8941099999999998}, {'accuracy': 0.89449}, {'accuracy': 0.8943399999999999}, {'accuracy': 0.8943700000000001}, {'accuracy': 0.89442}, {'accuracy': 0.89535}, {'accuracy': 0.89422}, {'accuracy': 0.8944300000000001}, {'accuracy': 0.89441}, {'accuracy': 0.89354}, {'accuracy': 0.8962000000000001}, {'accuracy': 0.89558}, {'accuracy': 0.8964100000000002}, {'accuracy': 0.89605}, {'accuracy': 0.89516}, {'accuracy': 0.89606}, {'accuracy': 0.8944699999999999}, {'accuracy': 0.8951099999999999}, {'accuracy': 0.8956}, {'accuracy': 0.8953900000000001}, {'accuracy': 0.89543}, {'accuracy': 0.8956}, {'accuracy': 0.8948}, {'accuracy': 0.89523}, {'accuracy': 0.89496}, {'accuracy': 0.89481}, {'accuracy': 0.89487}, {'accuracy': 0.89474}, {'accuracy': 0.89545}, {'accuracy': 0.89495}, {'accuracy': 0.8952799999999999}, {'accuracy': 0.8949400000000001}, {'accuracy': 0.8950400000000001}, {'accuracy': 0.8949199999999999}, {'accuracy': 0.8940300000000001}, {'accuracy': 0.89574}, {'accuracy': 0.89495}, {'accuracy': 0.89581}, {'accuracy': 0.89466}, {'accuracy': 0.89552}, {'accuracy': 0.8942500000000001}, {'accuracy': 0.8953300000000001}, {'accuracy': 0.8956700000000002}, {'accuracy': 0.89587}, {'accuracy': 0.89613}, {'accuracy': 0.89559}, {'accuracy': 0.89625}, {'accuracy': 0.89598}, {'accuracy': 0.8964999999999999}, {'accuracy': 0.8948899999999999}, {'accuracy': 0.8952899999999999}, {'accuracy': 0.8953900000000001}, {'accuracy': 0.89582}, {'accuracy': 0.89591}, {'accuracy': 0.89591}, {'accuracy': 0.8952199999999999}, {'accuracy': 0.8960500000000001}, {'accuracy': 0.89603}, {'accuracy': 0.89578}, {'accuracy': 0.89484}, {'accuracy': 0.89544}, {'accuracy': 0.8961600000000001}, {'accuracy': 0.8960800000000001}, {'accuracy': 0.8958900000000002}, {'accuracy': 0.89566}, {'accuracy': 0.89589}, {'accuracy': 0.89571}, {'accuracy': 0.89598}, {'accuracy': 0.89663}, {'accuracy': 0.89473}, {'accuracy': 0.89545}, {'accuracy': 0.8954200000000002}, {'accuracy': 0.8956900000000001}, {'accuracy': 0.89689}, {'accuracy': 0.8961499999999999}, {'accuracy': 0.89695}, {'accuracy': 0.89578}, {'accuracy': 0.8947600000000001}, {'accuracy': 0.8959900000000001}, {'accuracy': 0.89566}, {'accuracy': 0.8956900000000001}]\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": "dbef4f25-a311-4e52-87d2-b1f79873b9d7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cde28483-bf7d-4aac-855d-eaca858d218b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3ae90b1b-b84d-4a72-946b-a9c6b604847c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2e2e25dd-816e-42f4-a02c-edf143a1f27e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3ae522e4-15b1-477e-b6d6-ca24bad89624",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "12883e05-18ac-4eb3-803e-a9139fc87b39",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "24342e85-3d7b-4b1b-815e-815396b8037f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "11c5f1b8-dfec-4ae0-8c19-0a995c7caa02",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "94db0f3a-83b8-46b1-ac2d-7068f4f8d5b2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "91fa9d8c-f634-4063-8ccf-33bc9fda60d3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4964df1e-2cb8-46d4-8977-eb28ee115e29",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d411cc70-f7a0-46f4-8c08-61b71aab7c76",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6b5cc0b3-b3c4-48af-80af-355e8cd3ec81",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8c8d4572-45a0-458c-934a-7687b772c808",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c9457393-b4ba-4405-bb87-78d13bfe5ff7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a88e679-f3e5-4105-8d66-46a956291854",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "13a62cc4-3ff1-4a85-9926-29a51e5f2254",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ad710443-3df2-49d9-a00c-acc54c796f3c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b7b63138-79a5-4be8-8899-28852670b53d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bb11ccd1-d6e4-425f-86ac-85ecad7be7ee",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f19b7d53-df08-4493-8729-dd28b6f9b033",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0204a62a-4de0-442e-931e-9c6c5d8fbbdf",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "50299b95-0c78-4e53-a7b9-8b3f01c3f134",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0f018b99-074d-4d4a-8662-9b39443865ed",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "854481da-409e-4ab6-a625-45c7760f5d4a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "afbfce8d-375a-4e1f-a590-b28263a5f6a1",
   "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
}
