{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "df1 = pd.read_csv(\"./outputs/dumbbell_improvement/exp/acc.csv\")\n",
    "df1['NonIID'] = df1['Bucketing'].apply(lambda x: True)\n",
    "\n",
    "df2 = pd.read_csv(\"./outputs/dumbbell/exp/acc.csv\")\n",
    "df2['Bucketing'] = df2['Agg'].apply(lambda x: False)\n",
    "df2['RandomEdge'] = df2['Agg'].apply(lambda x: False)\n",
    "df2 = df2[~df2['NonIID']]\n",
    "\n",
    "df = pd.concat([df1, df2])\n",
    "df = df[df['Group'] == 'clique 1']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAtEAAAClCAYAAACa5aH5AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAABvvUlEQVR4nO3dd4AU5f348ffM9r1e9noD7ui9944CgiIlIipij1GTGDWW4E9j7DHJN2pMotHElmDBgohYUFEBFZDeOe6O673t3daZ5/fHHgcIHBzcccXnlax7tzs785mZD3OfnXnmeRQhhECSJEmSJEmSpDOmtnUAkiRJkiRJktTRyCJakiRJkiRJkppJFtGSJEmSJEmS1EyyiJYkSZIkSZKkZpJFtCRJkiRJkiQ1kyyiJUmSJEmSJKmZjG0dwE/J5MmT+etf/8rrr79ORkYG1113Hffccw/r1q0jMjISAJ/PR69evbjnnntwOBxtHLHUEvLy8pgyZQoPP/wwCxYsaHz9xRdf5MCBAzz++ONnNd8ePXqwYcMGIiMjueqqq7jiiiuYPn06V111Ffn5+YSEhACBnBo2bBh33XUXwcHBLbJO0olaaz/D+d/X77zzDo888ghJSUkIIfD7/SQnJ/OHP/yBmJiYs57vT1lnyo/vvvuOG264gS5dujS+VldXR3p6Oo899hgRERFnPe/OojPt7/NxPMjLy2PatGl079698bX6+nri4uJ49NFHSU5ObpHltDR5JrodWLJkCe+//z7vv/8+H374IRkZGVx//fVomtbWoUktRFVVnnjiCbKyss7L8n7729825tT7778PwJ133nlelv1Tdr73M7Tevh46dCjvv/8+K1asYNWqVcTHx/P000+f83x/yjpTfqSkpBw3348//hhVVXnppZfOed6dRWfa3+fjeGC1Wo+L/ZNPPqF79+785S9/adHltCRZRLcziqLw85//HLfbzbp169o6HKmFWK1WrrnmGu644w68Xu9x79XW1nLnnXcya9YsZs+ezZNPPonf7wegX79+PPPMMyxcuJDJkyfzn//8p9nLNplM3HvvvWzcuJHMzMyWWB3pFJraz9B+9vU999zDO++8c8bz9fl8OJ1OeXXsHHXW/ABwOp1UVFQQFhbW7Lg6q866v8/mePDMM8/wzDPPnPH0AB6Ph9LS0nadU7KIbqd69OjB/v372zoMqQXdfPPN2Gy2E75VP/zww4SHh/PBBx+wfPly9u3b13g2x+v1EhERwbJly3j66af505/+hMfjafayrVYraWlpMqfOg1PtZ+hY+3rTpk1ccsklXHzxxYwdO5bvv/+e+fPnn9M8pc6TH4cPH+aSSy5h1qxZjBo1iiVLljB58mSuvvrqc5pvZ9NZ9vf5OB643W4uueQSZs+ezejRo7n00kvp0qVLu76KKttEt1OKomCz2do6DKkFqarKH//4Ry699FLGjh3b+PpXX33F//73PxRFwWw2s3DhQl5++WVuvPFGAKZMmQJAnz598Hq91NfXY7FYmr18mVPnx6n2M7T9vl6wYAFer5fCwkK+/fZbXn75ZQYPHswDDzxwwrRDhw7ln//8JwC6rvPKK69w/fXXs2rVKhRFaXZMUkBnyY8jzTkAli9fzl/+8hemTJmCyWRqdjydWWfZ32d7PLjlllvIy8ujrKwMgM8++4ykpCT+9re/nTDtkeYcAF9//TV33XUXY8aMISgoqNnrfL7IIrodEkKwa9currzyyrYORWphCQkJPPjgg9x9993MmTMHCByQjqXreuMlPaDxoHnkQCWEaPZyXS4XmZmZZGRknGXkUnOcbD9D2+/rt956Cwhcvh0+fDhz5849o3mqqspll13GY489Rnl5OdHR0c2OSzqqs+XHvHnz2LZtG7/5zW9Yvnw5RqMsLY7V2fZ3c44HR4rlI005brvttjNaxrhx47jmmmv4zW9+w0cffdR4s2R7I5tztDOapvG3v/2NiIgIhg0b1tbhSK1gxowZjB8/npdffhmAsWPH8vrrryOEwOv18uabbzJ69OgWW57b7ebRRx9l/PjxJCYmtth8pab9eD9Dx97Xn376KYmJiY09CUnnprPlxx133EFJSQmvvfZai863s+hs+/t8HA+uvfZaQkND2/UNzfLrYjvwn//8hxUrVqAoCpqm0a9fP55//vm2DktqRUuXLmXz5s2NPz/88MPMnj0bn8/HuHHj+PnPf35O83/yySf5+9//jqqq+P1+Ro8eze9+97uWCF1qhmP385Hf28O+PpPutY60gVQUBb/fT3h4OH/7299QVZXi4mJuvPFGnn/+eWJjY88p/p+yjpwfPxYWFsadd97JY489xqxZs9i2bRvLli3jhRdeONvQO52OvL/P9Xhwpmegj2Uymbj//vu5/vrrWbBgAR6Ph6VLlzY2+WgPFHE21wckSZIkSZIk6SdMNueQJEmSJEmSpGZqkSLa6XQya9Ys8vLyAFi/fj2zZ8/mggsuOK5blz179jBv3jwuvPBCfve73x3XgF6SJEmSJEmSOopzLqK3bdvG5ZdfTnZ2NhBoyH7ffffx3HPPsWrVKnbu3MnatWsBuOuuu7j//vv5+OOPEULw5ptvnuviJUmSJEmSJOm8O+ci+s033+SBBx5oHD99+/btpKamkpycjNFoZPbs2axevZr8/HzcbjcDBw4EYO7cuaxevfpcFy9JkiRJkiRJ5905987xyCOPHPd7SUnJcUNBxsTEUFxcfMLrDoeD4uLic128JEmSJEmSJJ13LX5j4ck6+1AU5ZSvS5IkSZIkSVJH0+L9RMfGxjYO7wiBM9MxMTEnvF5aWtrYBOTHKivr0PX22/NeVFQw5eXOtg7jtNp7nKqqEBHR/OE8ZX60jPYeZ2fND2j/2x46RoxnkyMyP1pGR4ixsx5DOsK2h/Yf59nmx7FavIgeMGAAWVlZ5OTkkJSUxMqVK5k3bx6JiYlYLBY2b97MkCFDeO+99xg/fvxJ56Hrol0nMNDu4zuio8TZHDI/Wk5HibM5OkJ+QMfY9h0hxuaS+dFyOkKMZ6Mj5Eh7j++IjhLn2WrxItpisfD4449z22234fF4mDBhAtOnTwfgqaeeYunSpdTV1dG7d28WL17c0ouXJEmSJEmSpFbXYkX0559/3vjzqFGjWLFixQnT9OzZk7fffrulFilJkiRJkiRJbUKOWChJkiRJkiRJzdTizTmk1qcLQXmVC79HQ/Pp+L1+fB4/Hrcfr1fD7dXweDVUg0JNrSfwIQUECoHWSQJVVVAVBRUFVQ00sFdVBYNBRVVVDEYFRVHQNB1NE4FnXUfXAm3FhBAIPdAbywkdryigQOPrQggQR987IjjEwsKFg1pzU0mSJEmSJLUKWUS3E1VVLjZ8e5iSwlqiY4PJ6Omga2oERkPgYoHL42fbvhJ2bC2kpsiJTRcodOwuAsMibG0dgiRJkiRJ0lmRRfSPCCGoq/VSU+UiJNyK0WJE0wXaMXfrqmYjlQ1neFUFQuxmVFVp/LyvuBjd6wFdR2ja0WdA6H708nz8pVnUlRSSUxtBni+BCiUGFBWj7uFwcR2Htxez3l9DtDcfu1ZLmTmRCnM8QlGJ8VcS6zuMTa/DpHuw4MGoezDhQ1V0VHRUBIoqUBEIVIQg8GrDGWkFAuelBSiKQKCgoaCrKhqBh66oqOgYEBjQMQgBCngNAq8KHkXgNYAXga4E5q8pBH5WFPyKQEegKwINQAGNwPIB7GYHMOX87mBJkiRJkqQW8JMpor0+P4cLaiksrKXe5cPl9uHx+PF4NbwuH546H7rbj+rTUY9pnuBBUA/UIXAjMKJghoaHgolAw3KDomAUOqquoyCw+WoI8lZj91YR5KvG4q/HbQyi3hSKyxxGvcmB05yBrpqwaE5SnTuJ92QTqtRSZwylzJxAmTmefFsGumLEqjlJc+0lwZdLsL/2mLYSOpoQ+BuetYbCGBEokgOT6QhEY4sK0fCfxlcaXjhJqwyEAE2ADvgFKA3LtQAWcbR1hiKOfgbBGZ0jt8TYz2AqSZIkSZKk9qdTFtFut4/vN+VzcH8ZrloPwuPFoENT91FadDchWiUhVBOqVGMzuqkMSaHckEitx4bPpR2dWAGTxYjRZsRgNqA4q7GWFWDxOBGqgrAb8Znt1FocFNOF40tKgUHxYzKrRIea6dXHQUqvKOqMw6j11VHrq8PlcyH8Lux+F8LjxF3rhyA/xUoERSICEHg1L8X1pZS6ytGERlPMBjNWgwVLw7PZYMZitGBpeO3Is1k1YTKYMKmBh0FR8Qs/Pt2PX/fj0/wARFrDibRGEGWLIMwcikE1nNV+OnL2XpIkSZIkqaPpNEV0VZWbb78/TM7+UjSnFwUVVfgI16qxep1YPbXYfE6soh6TUcdoEBgNCiYjGA1gcDnRXR50lweh6QCEcIg0E5hDQI2PxZ/UB4sBglUfrkonWp0bT04x3pIKDBaF4HiBzaFiiOuGFuKgxKyTSw35LqjyACE6epALJx48moeDfjdfuevwb/afdJ0UFKxGK1aDBaX6SAvowLPRYCLW7qC/ow9x9hhigxxEW6MwqAZURUVFISYmjPIyJ6oiO2GRJEmSJElqSR2uiK6r9/LJmkxqymrwO+vQPX50v4qOCQCrVkd03WEctTmEu4oxWlSsKYnYh/XDPmg4loQkFPXURaUQAuFx4ysvx3VgP/U7fsB18CDarmLYVYwXqG2Y1m8Cl10lb1AweT0c+IOC0UxW3LqXkvpsfN5AcawYFMIjwrCbbFgUCzaDlXBLGFaDhRBzMMHmIELNIYSYAj/bjbbAtAbLORXAxoaCWpIkSZIkSWpZHaqI/vKrgxxYfxA/NhShY/XXE+SrxdbwiHQVEBnkw5aWiq3XZGzde2OOj2+yaP4xRVHwmQwUhugU9gilKKkXRc5IaovzMBaV47Io1NlUnDYDmAyEmUKwmKwYVSNGxYhRNRBhCqdnZAbxQXEkBMUSFxSLxWBuxS0jSZIkSZIknU8doojOL6jm0zfW4/LYsXl99KtZT0K0gjkuApMjDlNML0yOWCzJyajW5nWb5vTVUegsIrc2n1xnAbm1+RTVlTTeZmdUDMTYHcQndiM2YyTRtii6xSdicFsJs4TKM72SJEmSJEk/Qe26iNZ1nRVvrqcky40QZrpU/UD/vkHEXb4U1dS8M7u60ClwFpFVk0OBs5iiumIK64qp9Tkbpwkzh5IcksBAR1+SQhJJCIolyhp5wo1zDkcIpaW1P16EJEmSJEmS9BPRqkX0888/z/LlyzGbzcycOZObb76ZPXv2sHTpUpxOJ0OHDuX3v/89RuPJw1j73jcUZgsi64vpa80m467rMTtiz2jZft1PVvVhMquzyKzK5lB1Dm7NDYDVYCEuKJa+0b2IC4ohPiiOpOAEwiwhLbbukiRJkiRJUufVakX0+vXr+eCDD1i+fDk2m41bbrmFTz75hKeffpqHH36YgQMHct999/Hmm2+yaNGiEz6v6Tq5eyqxazD94q6EDbvitMt0euvYVb6XHeV72FO+v7FoTgiKY2jcQLqFpdE1LJUoaySKIrtXkyRJkiRJks5OqxXRu3fvZuzYsQQHBwMwbtw4Xn31VdxuNwMHDgRg7ty5PP300yctor9+81PqDOH0MewibNglp1xOva+ezSXb+L5oC1nVOQgEoeYQBsf0p290T9LDuxJkkoN6SJIkSZIkSS3njItor9eLqqqnbHrxY3369OHRRx/lpptuwmaz8fnnn2M0GnE4HI3TOBwOiouLT/ispuscPujGrrsZdvOCE97Xhc7eigN8W7iJbWW78Ot+EoLimJE2hb7RvUgOSZQ3/EmSJEmSJEmtpsmKuLy8nOeff55PP/2UgoICVFUlKSmJ6dOns2TJEiIjI0/52VGjRjF37lyuuuoqwsPDGTVqFN9+++0J052sWcXWD76kzhhOf1smKb27Nr4uhODbvB94ZetyyusrCTYHMbXrWCZ2GUmXiJTz2kTD4egY7ac7SpzNERUV3NYhnFZH2e4dJc7m6Aj5AR1j23eEGJtL5kfL6Qgxno2OkCMdZdt3lDjP1imL6Pfee49XXnmF6dOn8/zzz5OSkoKmaeTm5vL1119zzTXXsGTJEi699NKTft7pdDJt2jSuueYaAP7973+TmJjIpk2bGqcpLS0lJibmhM9m52oEeasZ+osFjb1gVHmqWbbvXXaU7SY5JJE5fS+iX3RvTKoRNCgrc54wn9bSUXrnaO9xqqpyVger8nInui5aIaKW0d63+xHtPc7Omh/Q/rc9dIwYzyZHZH60jI4QY2c9hnSEbQ/tP86zzY9jnbKIrqmp4e2330b90UAl3bt3p3v37ixZsoRXX331lDPOy8vj7rvvZvny5bhcLt566y3+8Ic/sGPHDjZv3syQIUN47733GD9+/AmfdRlCSYssxBIagi501hV8x3sHP0ITGpemX8SkpLEndDsnSZIkSZIkSefLKYvoxYsXN/lBg8HAkiVLTvl+z549ueCCC7j44ovRNI0lS5YwZMgQnnrqKZYuXUpdXR29e/c+6XLsvmpG3bAAr+bluW0vcaDqEN0j0lnUYx4Oe9SZr50kSZIkSZIktYIzvrEwPz+fv/71r7jdbm666Sb69Olz2s/ccsst3HLLLce91rNnT95+++0mP5cY48dksbKpeCsHqg4xP+NiJiaNkd3SSZIkSZIkSe3CGRfRTz31FFdddRWKonD//ffzzjvvtFpQQxZcCMCu8r0EmexMSBotC2hJkiRJkiSp3ThlP3B333035eXljb+7XC4SExNJTk7G6/W2alBGgwFd6Owu30fvyB6yuzpJkiRJkiSpXTnlmegFCxbwy1/+kilTpnD11Vfzi1/8gl/96lf4fD5+/etft3pgOTV5OH119Inq2erLkiRJkiRJkqTmOOUp3qFDh/Lqq69isVi48sorcTqdLFu2jOXLlzN16tRWD2xX+R4UFHpH9Wj1ZUmSJEmSJElSczTZTsLlcjFv3jyee+45PvroI371q19RWFh4XgLbWb6XLmGpcshuSZIkSZIkqd05ZXOOv//973z44Ydomsa1117LH/7wB7Zv385vf/tbRo4ceUKvGy2p1usktzaf2V2nt9oyJEmSJEmSJOlsnfJM9EcffcTKlStZsWIF//vf/wDo378/r7766klHGWxJ+ysPAdBXtoeWJEmSJEmS2qFTnokODQ3lhRdewO12k5SUdNx7CxYsaNWgDlRlEm4JIzE4vlWXI0mSJEmSJEln45Rnop999lmsVisxMTE88cQT5zMmMquy6BPVQ/YNLUmSJEmSJLVLpzwTres6V111VZMfLi8vJyqq5Yfh9mge+kT1avH5SpIkSZIkSVJLOOWZ6Pvuu49///vfVFdXn/Ce0+nkX//6F/fcc0+rBGVQDPSISG+VeUuSJEmSJEnSuTrlmejnnnuOl156iVmzZtGlSxdSU1PRNI3c3FyysrJYvHgxzz33XJMzf//993n++ecBGD9+PHfffTd79uxh6dKlOJ1Ohg4dyu9//3uMxuPDSAtNwWq0tMDqSZIkSZIkSVLLO2URraoq119/PVdeeSXffvsthw4dQlVVLrjgAkaPHo3ZbG5yxi6Xi0ceeYTVq1cTGhrK5Zdfzvr163n00Ud5+OGHGThwIPfddx9vvvkmixYtOu6zGZHdWmbtJEmSJEmSJKkVnLKIPsJqtTJx4kQmTpzYrBlrmoau67hcLux2O36/H6PRiNvtZuDAgQDMnTuXp59++oQiuke4LKIlSZIkSZKk9uu0RfTZCg4O5le/+hUzZszAarUyfPhwTCYTDoejcRqHw0FxcfEJn42yRaLrorVCkyRJkiRJkqRz0mpF9N69e1m+fDlffPEFISEh3Hnnnaxbt+6E6U7WjV1UVHBrhdViHI6Qtg7hjHSUOJtD5kfL6ShxNkdHyA/oGNu+I8TYXDI/Wk5HiPFsdIQc6SjbvqPEebZOW0RXVFQQGRnZ7Bl/8803jBo1qrELvLlz5/Liiy9SVlbWOE1paelJRz8sL3e26zPRDkcIpaW1bR3GabX3OFVVOauDlcyPltHe4+ys+QHtf9tDx4jxbHJE5kfL6AgxdtZjSEfY9tD+4zzb/DhuHqebYNasWdxxxx1s2rSpWTPu2bMn69evp76+HiEEn3/+OcOHD8disbB582YA3nvvPcaPH392kUuSJEmSJElSGzntmejPP/+cDz/8kCeffBKXy8XChQu55JJLCA5uunofO3Ysu3fvZu7cuZhMJvr168eNN97ItGnTWLp0KXV1dfTu3ZvFixe32MpIkiRJkiRJ0vmgCCHO+JrFd999x3333UdFRQVz5szh1ltvbZURC+WllJbR3uOUl9raVnuPs7PmB7T/bQ8dI0bZnKPtdIQYO+sxpCNse2j/cbZEc44zurHwq6++4q233mLz5s3Mnj2buXPnsnbtWm6++WbefPPNcwpAkiRJkiRJklqLLgRl1W7yS53kldaRX+rE7dV45Bdjz2m+py2iJ06cSEREBIsWLeKPf/wjVqsVgB49evDGG2+c08IlSZIkSZIkqaX4/Dp5pU5yS5wcLq4ltyTws9urNU4THWalb9dzb0lx2iL6z3/+Mz169CAoKAiv10t5eXljE441a9accwCSJEmSJEktRQiBq85HTZWrQ3RXJ50bl8dPZn41+/Oq2J9bTVZhDT6/DoDVbCApJpjRfeNIjgkmyRFMQnQQNosRVT2xi+XmOm0RXVRUxD333MMnn3xCfn4+l19+OY8++iiTJ08+54VLkiRJkiSdDSEEbpePqgoX1RUuKsrqKC9xUlZSh7veR1iEjX6Dkto6TKkF6bqgsLyOQwU1HCqs4VBBDXmlToQAVVFIiQ1m0qBE0hPDSIkNJjrchnqS8UhaymmL6H/84x+88sorAHTp0oV3332XX/ziF7KIliRJkiTpvPF6/ORlV5GbVUFZsZOqinq8nqOX6BVVwRRkQrMYqDMp1JjaMFjpnAkhKK92k1VUS1ZhDdmFNWQX1TY2y7BZjHSND2HWqDS6J4fTNSEUm+XUZa2uCyrL6ykrdlJWXIu73s/Ca4edU4ynLaJ1XScuLq7x9/j4eHRdP6eFdkRffPEZr776HzRNw2BQmDp1OosWBbrn++ijlSxf/iZ+vx8hdGbNmsOCBQsbP9vU+/Pnz+aZZ/5JZuYB9u7dw/XX/7xN1k+SJEmS2hMhBBWldeRkVnD4UAXF+TXousBkNhDhCCIkNpgqn0ZBrZtipwePDtT6CbWbSIgOomdKRFuvgtRMQgj251axbkcRWw+W4XT5ADCoCskxwYzqE0fXhFC6JoQSG2lv8iyzx+2nKL+awtxqCvOqKS2sRdMCva4YjCpp3Zo/kOCPnbaIjoyMZNmyZcyfPx9FUXj33XeJjo4+5wV3JKWlJTz77P/x0kuvERYWjt2usnDhIlJSUikvL+f995fz5JN/JTo6mtraWn7zm1uw2azMmjWH999/p8n3jxg7dgJjx05ou5WUJEmSpDam64Ki/Gqy9peRtb+c2mo3AOHRdqK6RFCha+wtc1KRXwlAkNVI9+RwRiYl0yU+hIToIELsZoAWafMqnR9l1S7W7yxi3Y5CSqvcWM0GBmVEk54YRlp8KEmOYEzGpscHrK/zBgrm3GoKcqsoL6kDAnkQHRdMn8EJOGJDiI4NJjzKjvE08zsTpy2iH3roIX7zm9/w0EMPoSgKffr04amnnjrnBXckVVVV+P1+3G43YWEQFBTE0qUPYjZb+POfn2Tp0t83frEICQnhd7/7PXV1gZ338ssvNvn+EatWfcCWLZv53e8eZP782YwdO4Ft234A4N57/x/du/c8j2ssSZIkSeeH5tfJy67k0P4ysg+W4673oaoKwdF2jIkhHKpxsbGsFspqCbaZ6JkSzoyUCHqkhJMQHdSqbV6l1lVS5eKdtZls3FOCAHqlRnDJ2C4M6R6DxWxo8rP1Ti95OZUUHK6mMLeKqgoXAEaTSmxCKEPHphKfFEZsQiim08zrbJ22iE5LS+Odd96huroag8Fw2pEK29K6HYV8s73wjKcf2z+eMf3iTztdRkZ3xo2bwM9+dgndu/dgzJjRjBkzmeDgEEpKiunTp+9x06eldQECxXdT7zclNDSUf//7v3zzzVc88siDvPzysjNeL0mSJElqz9wuH3nZlWTtLyMnswKfV8NgVFFCzJSrgmynB72kBrvFSI+UcCaPSKFXSgQJDlk0dwZOl4+V67NZszkPg6owY2QqEwcmEB1uO+VnfF6N/JxK8rKryMuppLKsHgCzxUB8Uhg9B8STkBxGdGwwBsO5n2U+E6ctoisqKlixYgV1dXUIIdB1nZycHP70pz+dj/jajTvvvJerr76O77//lm3bNnHTTdfwwAN/AOBUYz4euZR05mNCHnXxxXMBGDt2PI888iBVVVWEh4efTeiSJEmS1GZqq90UF9RQXhLoPaO8tA5njQcAxahSZ1LIQ6PGr2F26nRPDmf+sGR6pUaQHBMsm2V0InVuH19vK2Tl+mxcHj9j+sdz6biuRIRYTjq9z6dxOLOCzL2l5Bwsx+/XMRpV4pLC6NE3lsTUCKJj2y5HTltE//rXv8ZqtXLw4EFGjx7N+vXrGTJkyPmIrdnG9DuzM8vNtX79N7hc9UyZcgEXXXQxS5ZcwYsvvsLKle+TkJDI3r27GThwcOP0W7Zs5ttv13Pzzbed9v1TMRiOXnoQQkdVz8+3KkmSJEk6F26Xj/ycKvKyK8nLrqSmyt34njAbqBM6leg4Ebh1nXRHGJNTE+mVGklafAjG83QWUWpdQghKKus5kFfNwfxqDuZVk18WaMrat0skCyalkxxzYusGXRfkHqpg/+4Ssg+U4ffp2OwmevSPo2v3aOKTwjCcY3tmb3ERru3biFo0/5zmc9oiuqCggM8++4wHH3yQhQsXctttt/HLX/7ytDN+6623eO211xp/z8vL45JLLmHq1Kk89thjeDweZsyYwe23335OK3A+WK1W/vKXP9K7d1/i4xMQQpCdfYiMjB6MGTOOZ5/9P5544s9ERUVTVVXFs8/+H3PmzANg0aKrmnz/VNas+Zj58xeydu0XpKZ2ITQ09HysqiRJkiQ1m6veS+beUg7sLqEorwYItE01hlgoMEClpuECHEFmUmLD6RUTTNeEUNITwzCbWqe9qtQ2qp0eNuwq5rs9xeQU1QKB7ui6JYYyvFcMvdIiSU8MO+Fz5SVO9u0sZv+uYlx1Pqw2I937xNKtp4OElPBzPtusu13UbvyemvXrcB3YjyU2Blq7iD5yQ1xaWhr79+/n4osvxu/3n3bGCxYsYMGCBQAcOHCAW265hRtuuIHLL7+cV199lfj4eG666SbWrl3LhAntu1eKwYOHcu21N/Db3/4av9+PwaAydOgIrrnmBkwmEz6fn9tvvwVFURFC55JL5jJ79hwA5syZ3+T7p7JjxzZWrlyBzWbld797sNXXUZIkSZKaw+fTyNpfxoHdJeRlVaLrgohoO4NGJVPs1fh8dyG1FU4GZURzxdBkUuNCmuzHV+q4/JrOlgNlrNtRyM5DFehC0CMlgkVTM+h5TFt2j9tPYW4Ve7YV4nb78bh8uF0+SouclBU7UVWF1PQoevSNJaVbZLPbNntyD1P15ee4MjMDbWmFAAQI8JWXIbxezHHxRM9bQMS4cee83qfN5qioKP71r38xcOBAnnnmGYKDg3E6nc1ayIMPPsjtt99Obm4uqampJCcnAzB79mxWr17d7otogBkzZjFjxiwAHI4QSktrG99bsGDhcf1C/1hT77/99gcAxMcnMHPm7MbXf/7z24iPT2iJ0CVJkjolv++nN2ZBe6Drgi3fHWbNh3upr/NiDTIRlx6JKcpGnS54a2chlbUeeqdFMHd8N7omyCupndnB/GpeWb2XvNI6IkIszBiZwui+cfTvGddYK9XVeti2MY/dWwvxeY8OkKOqClabiZAwC2OnppPeOwabvXmj5Og+L86NG6n68nPchzJRTCZsPXqhmkygAA03otp79SJkxCisXbuhKMr5Gfb7oYce4sMPP2To0KH07duXp59+mjvvvPOMF7B+/XrcbjczZsxg5cqVOByOxvdiYmIoLi4+4TMdYax7hyOk1eZtMKhERga1yDJaM8628lPPj5bUUeJsjo6QH9Axtn17irG+zkthXjVF+dUU5ddQlF+NX9P51e+mNGs+Mj/OTfbBMlYu30FFSR1ug0I2GrV1GuwPtHtWVYUeKRHcccUQBmQ4TjO39qkj5Eh7yA9nvZeXV+1h9YZsosNt3HP1MEb2jcdwTHGqCIUNX2SybXMeQhf0GZjAkFGphEXYsNnNmC0GlGb0tiKEwFtRSX12NnVZ2TgPZVG9fTv+Wie2xAS6XHcNjkkTMIWcn+1z2iL6iSee4MknnwTgrrvu4q677mrWApYtW8Y111wDBFb+x0628crLnej6WXRpcZ78+Ex0S3vjjfcBznkZrR3nuVJV5awOVj/1/Ggp7T3Ozpof0P63PbR9jEIIyoqd5BwsJyezgpLCo7HYg80YgkyYwu3Nnq/Mj+bTdUFWVgVff3EIV1k9HgQFiiAhNYLZXaOIDLUSEWIhIsRCqN3ceIavrdehsx5D2jo/dCH4fk8xy9YcpLbeywXDkpkzrgtWs5GK8kBLhZLCWnb9UMDeHUUYjCq9B8QzYHgSoQ1d2Pk0DV+tC06xGv6qKur378VfWYm/sqLhuRJfaQla7dEPmaId2Hr3JWzcBGw9eqIoClVuwH367XO2+XGs0xbRe/fuRQjRrG8KR3i9XjZu3Mjjjz8OQGxsLGVlZY3vl5SUEBMT0+z5tgW/38/rr7/MJ598hNFowOv1MWPGLK666hpeeul5/v3vF/jHP16ib9/+jZ/561//xFtv/Y9vvtnUhpFLUscjhKC40t0hzghJLUPXBZVldRQX1FKcX8PhrArqnV4AgiNthKWFUeHTyKyoo9rpAqeLNKX9FjodmRCCyvJ68nOqOJxVQW52FcKvoyHwhloYMCyR345Px+vytnWoUisTQpBZUMPh4lpyS5zkljjJK3Xi9emkxYVw+4IBpMaFNE6bn1PFDxsOk59ThdVmYsjoFPoNTcTWMIpkk8vSNOp2bKf6m6+o274N9EBzLcVixRQRgTEigqABg7AkJ2NJTsGSlITBHtSq6386py2iHQ4HF110EQMGDCAo6GiwS5cuPe3M9+3bR1paGnZ74GzBgAEDyMrKIicnh6SkJFauXMm8eU33UtFe/OlPT1BZWc4//vFvunZNIDu7kPvuu4ugoMAf+ZiYWL74Yk1jEa3rOlu3bm7LkCWpQ9F0nV0Hyti6rYiivGqig8z0Xjq1rcOSWlFFWR2Ze0opzKumpKAWn6+hraRBwW1UKVYFFbqOv8IJFRATYaNvt2jSk8JITwon0dG2f0A7I59P4+N3dpGbFRhW26dAldBxJIRy8dR0UhICvSqEBVsolUV0p/fu11msXJ8NBIZYT44JZnz/BLolhjGsZwyKApXl9eRlVbJ/VzElhbXYg82MmtSV8VO7U1PrOu0yfOVlVK/9kup136BVV2EICyPigumEDB+ByRGDwXbqAVja2mmL6EGDBjFo0KCzmnlubi5xcXGNv1ssFh5//HFuu+02PB4PEyZMYPr06Wc17/OppKSYTz5ZxbvvfkRIQzuboKBgfvObu8nKyqSqqpKxY8ezbt1X3HZboMu+7du30qdPfw4c2N+WoUtSu3XkzGNmZgU7dxVTU16PpeHEYrACkZHNv1QvtX+11W4O7C5hz44iahqG6fWZVKr8GrUInAisVhMpsSEMjLKTEB0UeETZsVuPv+FIjlzXsnxejVVv76DgcDU1QUay6jykJIRxxZR0uiWc2CWZ1LkdLq7lo29zGN4rhp9NSicixIKiKPh9Gof2lfHlqn3k5VRSVxv4MhUeaWP8hRn06BeH0ahisRpP2VwDAj1pVKz+iNqN34EQBPUfQNjY8QT1649iPLE8zXcWkldbwPC4wWfVOqI1nLaIvvXWW8965jNnzmTmzJnHvTZq1ChWrFhx1vNsim//Onz7vjrj6U09xmPqPua00+3Zs4u0tK4n9NWcmppGamoamZkHCQsLJz4+gT17dtGrVx/WrPmUKVOm8d57bzd7PSSpM/J5NYoLaijMrQ7cIFZQg9bQu4IPgTnYTHJqBAP6x5GYHI7xHDvTl9oHn1cj73AVe/aUUJBTha+hiYYTQTkCp1EhKS6IngmhdI0PpWtCKJGh1jaO+qfH6/Gz8s0dFOfXkImOalS4fk5fhvRwtJuCRTp/dF3w8uq92K1GrrygB8G2wBfY2mo3q9/ZRVmxE6vNRFJaOIlpESSlhje2d26KEALX3j1UrF5F/a6dKBYrEVOmET7tAkyRUSePReisOfwVHxz6GE1o7Ks8yKKe8zCqbd9d4mkjmD179klf/+CDD1o8mPbs2IPI6tWreeaZv6HrGmazhVGjAoX45MnT+OKLNXTv3pOdO7dx++3NuwlTkjoTTdMpOFzF4cwKCvOqKSt2cuTeYr9RpcLvx2tU6ds7lmmjU4k+gwOw1H4JIXDV+6iqqKeirI68/BoKDlfjrvGgAAJBHSCCTDhSwumTFkHX+FDio+0Y5Iisbcrj9vPO61upLK0jE53BgxOZP6kbFjkIyk/WZ5vzyCqs5aaL+zQW0Pk5VXzy3i7cPi95GVvp3jOBnilpJIecfqRoj89D5ter8K5Zi724CiUkhOi58wmbMAlD0KmbZZW7KnllzzIOVmUx0NGXOHsMq3M+p9pTw/X9rsJmPP0Xbl3ofFu4mb0V+1EVFYNiwKCqhFvDuDpq7plvlJM4bRF9//33N/7s8/n47LPP2u3NgKbuY87ozHJz9ejRi+zsQ9TVOQkKCmb69OkMGTKGwsICbrvtpsbpxo+fyM03X8fw4SMZMGCwHKpb+snxuH3kZFaQfaCcw4cq8Hk1DEaV2IQQuvaLZWdRLXtKagm3m7hweBpj+8djNbf92QTp7Giazq4dxezYnEdthQuhHb3RT0dQD+hWI3FJYfTpHUPvrlHYrXJ/tyd1dV7+9+/NeJ0eiqwGrp3Tjz5pkW0dltSGyqpcvPNVJv27RTG8VwxCCHZuLmDdmoPodg8Hem0gIymZrWU7+L54MxnhXZmcPI6+0b0AqPPVU+OtpVDLY+/hg1Sv+4aEzVmE12o4QwxsHBHOvq52Lu4RyVj7yU+eCCH4vugH3tz/PiC4qtfPGBE3BEVRiLZF8d99y/m/H/7BzQOuIdxy6qZGu8v38e7BDymoKyLcEoZBMaAJDU1oRFjDgFYuoocPH37c76NHj2bhwoXcfPPN57TgjiQuLp4LL5zJww8/yH33PYDDEYKmaaxf//VxhXJYWDhxcfH861//4JZbftWGEUvS+eH36xTlVZOfU0VeTiWlhbUIAfYgM+m9YkjLiMIUauH9dVls2l5AsM3Ez6ZmMHFgIibZXKPD0XSdHZkV7D9cSWFmBVS6MQtwI6hGYLQaCYuwExsfQmpSKBlJ4bJpRhvRNB2/Tw+0Sz0FZ52H//zzexSvhjE5jHvm9T2h3bnU+eTU5LI6+3OyqnMYnzSKKSkTsBgCvWcIIXjl430oisJVF/TA79f5+pMD7NtRjDe6kkOpm1jYdw6j4odS76tnXcH3rM1bzz93vIzVYMGjeUHXSSj10TXPQ48cD4lunfq4CLRLJjJgzHQyNBev732bN/a/x9bSnVzZawGR1ggACuuK2VKyna2lO8l3FtItLI3FvRcSbTv6xW5UwjBCLaH8a+erPLXpb9zU/2pi7Q5Mqqmx1UC+s5B3D37Inor9RFsjua7vlQxy9DuuVcF5GWzlxyorKykpKTnnBXc0d9xxD8uWvc4vf3kTBoOKy+WmT59+PPXU03z66erG6SZPnspLL71wXFd3ktRZuOq9FBfUUlJQ0zDgRQ2aX0dRICYhlMGjUkhNjyLCEcT2zHLe25LHjkPlmI0GLh6TxoXDU+Swvx1QvdvHl5vz+XZzHtT7iEbBjIJiMxKXEUWvPrGkyCGd2w3Nr7Pif9uoLK9n5oJ+xCWeOGJgncvHiy9sxOTVSBucwMwLurdBpNL5dLAqi9XZa9hTsR+b0UZqSBIfZn3KN/nfMbvrhYyIH8J3u0vYmVXB5ZPTKc6q5MNvsqlzeqlOzqEs6SA397uanpEZANhNdqalTmRy8ji2Fm6lZPMGojNLCcksQnV7wGjE1LMXsRdehK1nr8YC1mKycMuA61hX8B3vHFzJI9/9meFxg9lXmUlxfQkKCl3DUlnY41LGJIxAVU484dInqge3D/o5z21/icc3/rXxdbNqwmwwU+erx2a0Mi9jNuMSR2FqpfbTijjZCCjH+HGb6IKCAi677DJ++9vftkpAIDs6byntPU7ZEX7baipOn1ejqqKeqgpX4Lm8nuKCWmqrA6OSKQpEOoJITAncVJKQHIbZYiSnqJZvthfy7e4i6tx+IkIsjO4bx9ShyYQFnb6f0GN11vyA9p8jQghUo5H13xxi165iaspcWBEoBP4IpnSLZNCIZOKTw9r0prOzyZHOnh9CCL5ctZ+9O4pQTCoGATPm9yUpLaJxmjqXl+df2Ii13k9yv1hmXdTzvMZ4vnTWY8iRba8LnZL6MswGE3ajHYvB3Pjv0av5KHWVUVxfSkl9KXsq9nOwKotgUxBTUsYzLnEUNqOVzKps3jm4kuyawzgsMZTtTyROCSKuLhRfrQLhHnITtqNGefnFgGtJCI47IR6ttpaC557BdWA/anAwwf0HEDRgEKkTRlLh9De5LuWuCl7b8xYHqg6REd6VQTH9GODoS5jlzIaKr3RXsa1sF17Ni1fz4dW9+DQfwaYgJiaPJch08l6e9KpC/Ds/JvHS285oOafSrDbRiqIQGRlJt27dzmmhkiS1L0IISoucHNhVTNb+MmprPMe9HxJmxREXTJ/BCcTGh+CIC8FkNhz3+RXrsnjv6yyMBpXB3aMZ2y+e3mmRLXLJTGpd1XVePtuUy+G8atwVLoz1fuxCoKKgIbAHm0lPj6ZnTwcx8SGY5RnndmvHpnz27iiiWIVCn48eqHzwxnbGTu9OvwHxOF0+/v7iJoLr/cSlR51VAS21LV3X2Vy8lY+y11BYV9z4uqqo2I02jKqRak8NgqNfBKJtUczPuJgxCcMxKibqPX4Ol9dy6LABS85YrOUH8dsq6eK0Y68Lo9ZWS1XPLExxXroGx7Eg4xLCLCcOpe0tKiL/6b/grygn7tobCBkxEsUQ+NtgsNnA2fQXrShbJL8afBM+3X9WZ4sjrOFMTDrze+F0dy3eze/h2/0lxsjT3xB5OqeNOCUlhX/84x88+OCDHDp0iKeeeoqHHnqI6Ojoc164JEltRwhBVUU9B/eUcmBXMVUVLlSDQkrXSHoNjCc80k54pI2wCBvGJu7S14Xgf58eYM0PeYzqE8eiaRkEyXaVHUKd28eqddls3ZxPpA52FKyAajUSlRRKZHwIg/rHExFiaetQpTOQm1XB+s8z8VoNlOoad/5sMOu3FlC6s4SvP9rHxj3FlFTUE+b0EZUcypx5fdo6ZKkZdKGzuXgbn276gvyaIuLsMSzscSkGxUCdr556v4t6vwu/5ifaFkmMPRqTFsqefV527a5m5Q9+3vRswOPVsALhKISgEIpCOg6odGALNdBnWhz9+idjNTX9775+/z4K/vY0iqKSdOfd2NIzznrdWqu5xRHC78W3aw2eLSvA58bUaxLW4ec+2N9po77nnnuYPHkyAImJiQwfPpx7772XF1544ZwX3lEUFhawYMHFXHzxpfz2t79rfP3AgX1cc80V3HffA8ycOZs33/wv77//DqqqYjAYufjiS5k7dwEAb7zxOh999GHjZz0eN7m5h3nnnQ/54IP3ALjuupuQpNagaTp5WZWUl9ZRWR5onlFV4cLrCVxqS0gOY8CIZLr1iMbSjALYr+n8a+Vuvt9TwoXDk1kwKV0OgNEBuDw+Vq7J5ODOYkJ1QRIK4dF2evWLIy0jivBIe4e4XC8dVV3p4tP392C0m9hU5+aai3qRkRRORlI4hSNSWPHGdtzZVYQCYY4g5l02QPb/3E64/R6qPNVUe2qo9tZQ5amm1uvEq3nx6X68ug+f5qOovoQyVznJYQlc1/dKBjr6nrS9sK4LtmeW88XafHYeygYFeqdGkBJhx+D04a9y46/3ARASbiU5LYL45DDik8IICTuzG4FrNqyn6D8vYnbEkPCr2zE72mevbXpNKb49X+Db+xXC48SQ3B/LyMswRCSenxsLKysrWbx4MRAYcXDJkiW8995757zgjiYsLIzvvtuApmmNr61Z8ynh4YF2Zi+++E+2bdvCM8/8k8jIKCorK7nvvjuoqalmyZLrueyyK7jssiuAwBnA++67k8GDhxITE9sm6yP9NNTXedm9tZBdWwqobxjkIijETESUnYHDkrDYTaSlRxJ8Fj0ouL1+/vbuTnZlVbBgUjdmjEht6fClFlJT7yUzv5rM/BoOZVVgLK7DhkKYqpDW08Gwkck44k68VNveCV1v6xDOu+pKF0X5NZjNBswWI2aLAaPJwMfv7EIXgq0uLwO7Oxjd92jb1XhHMNfdNIKP3t2Fs8bD3CsGYZC947QJXegUOIvIqskhq/owWdU5lLjKTpjObDBjUc2YDCZMqgmzaiTaGsml6RcxpdcIysvqgEA9UVHjIb/MSV5pHfmlTvblVlFR4yEs2MzsMWn0jQ9l89psKrJr8AHxyWF0GxVFSqKNsIRTtyoQQlC5ehUVH38Efn9DP/8ChEB4vdh69iLh5lub7Oe5LQhdR8vbjnfX52i5O0BRMKYOwtR3KsaEXi26rNMW0ZqmUVxcTGxsoNgrKyvjNPcidko2m52MjO5s27aFuLhJAHz//bcMHToct9vN//73Kq+++iaRDSPuRERE8NvfLuXGG5ewcOGVWK1Hi5RXX/03JSUl/P73j7XJukidX2lRLds35XNwTwm6JkjuGsHE6d2Jb7gBsM7tY8PuEj7bmEPCoTL6p0cxoFv0GV+2r6n38te3tpFdVMs1M3syrn9CK6+RdDacLh/PvrOD/blVACQqCvFCRTUZ6DM8iVEjU5psqtMeCE3DV16Or6QYX2kJ3pISfKUl+EqKUYHovz/T1iGeF16Pn83rc9i+Mf+kN70pCpSHmzF4BIun9zjhLLPRZGD2z/ojhJBnoFtBUV0xle5q6vz1gaYVvsCz01dPnb+OOl89dd46ary1ePXAWeBgUxBdwlIZET+ESGsE4ZYwwiyhhJlDsRpPfSw+cvZ5494SXlm9lzr30Zv3IkMtpMSEsHByBgMzonE5vSx/5QcMBpWx09JJSwtF2/YdFctfo7isDM/kKUTP+xmq5fjl6T4fJa/+h5r167D37Y85Pj5wW3FD7hjCwoiYMu2kw3O3FSEE/pwf8G58B70yH8UWhnnwxZh6TkANbp2+z0+79kuWLGHOnDmMGzcORVFYv379GffM8fnnn/Pss89SX1/P2LFjWbp0KevXr+exxx7D4/EwY8YMbr/99nNeiSO+K9zMhsKNZzz9qPhhjIgfcsbTT5oUGJHwwgsnsWfPLtLTMxBC4Ha7sFptxMcfX0h06dIVs9lETk42PXoEbt7YsmUzb775X55//mXM5ub1ViBJp1NcUMPGb7LJPVSJyWyg94B4+g5JJCIqcIdyTZ2XFRsy+fyHPNxejZ4p4eSWONl6sAzYR0pMMP3To5k2NIkQ+8nzs7TKxZ/f2EpFrYdbL+3HoO6O87iGEoDL7WPZf7cRHGLh0kt7YzSeWAjX1Ht56n9bKKpwMXtoEq7saqrL6knv5WDcBRlYbe2r3brQdXwlxbizsnBnZ+EtKsRXUoKvohyOuQKomM2YHDGYYuMI6tq1DSM+P4QQ7N9VwrdfHKK+zkvPfnH0H5aIrgs8bj9ej4bX42dbbiXf7yjk1rn9CD3Fv11AFtCt4Ivcb3j7wIoTXrcYzASbgggy2QkyBeGwRRFiDiYlJIkuoalE2yLPen9s2lvCP9/fRWpcCGP7xZHoCCbJEXRcP99ej5+P3t6J5teZNac7yrb1lLz2KVptLdZu6dh79abq8zXU795N3PU3YU1LA47vbSPqkkuJnHVxu84bIQRa/m48G99GL81CDYvDOvnnGLsORWnlttannfv8+fPp27cv3377LQaDgeuvv56MjNM3Hs/NzeWBBx7grbfeIioqiquvvpq1a9fywAMP8OqrrxIfH89NN93E2rVrmTBhQousTGsbO3YcL7zwd3RdZ82aT5k8eRpr1nwCKMc18ziW33/0G2JFRTm///1S7r33ARISEs9T1NJPQUlhLRu/yeZwZgVWm5GRE7vQZ1BCYy8K9W4/K9Zl8eWWfHx+nWG9YrhyZm+CTSpCCArK6tieWc62zHI+3JDNV1vzuerCngzpcXyBnFNUy1/e2oam6dy5cCAZSeFtsLY/bcXldSx7+QfMXh13SR3/fGYDl17Wn4SEo11CVTs9/HHZVsorXcwfkEDOtmJUVWXqxb3I6N1+2i76ysupWf8Nrv37cWcfQne5AFAsFsxx8VjT0ggZNhxTTCymmBjMMTEYwsIb/6B35p5fhBAUHK7mu6+yKM6vISY+hOnz+hCbcGLXX7uzK/h0ZxGj+8YxWH6pPa/2VhzgnYMr6Rfdm2kpEwky2bCb7AQZ7RjU1rnKs2FHAf9csYuuiaHcvmDASftn13XBZyt2U1FWx6iwfCoffw3hcRPUrz8RMy7CltEdRVEIGTaC4n//i8OP/YGo2ZcQPGgIBc/+FX9lBXE3/pzQ4SNbZR1air/oAN5N76AV7EEJjsI64TqMGaNRWmnb/9hpi+ji4mKWLVt2XO8cv//973E4mv6H+umnnzJz5kzi4gLtsv7yl7+Qk5NDamoqycnJQKAP6tWrV7dYET0ifkizziw3l90eRHp6Bps3b+aHHzby85/fypo1n2C1WvH7/Rw+nE1KSlrj9IcOZaLrgtTUNDRN48EHf8eMGbMYM2Zcq8UodQ5H/oA64oKb7E6srtbDVx8fIPtgORarkRETutB3cMJxn9l6sIxXVu+lus7L6D5xzByVSnxUUOONY4qikOgIJtERzIyRqeSVOPnXh7v527s7GNk7lkXTuhNsM7Eru4K/vbMDu9XIXZcPITG6fbWD+ynYvr+Uz97bjVWHrkMSqPf4ydtZzLuvbKHX8EQmTepGldPLn17/AWONlyEmI5k/FJKYGs7ki3qcVdv3liZ0nfrdO6n68gvqtm0FwJKcQsjwkVi7dMHapSvm+AQU9afZZtdV72PDl5l8vy6b6goXNruJSTN70KNf7HFnA31+jY17S/jih3wyC2qIDrOyaOrZ944gNV+Zq4KXdr5OrN3Bkt4LsRpb/9/Xlv2lPPfeTtJig7l0QCJb1x8muUsECSnhqKoSuDp+8CDffLyXHGcoPUo2EJSbTfCQIURMuxBLcspx8wvq3YfUB/5AyeuvUP7eO5S//y6G4BCS7roHW7f0Vl+fsyGEQCvci3fz+2iFe1FsoVhGX4Gp10QUw/m9wnbaIvruu+8+oXeO++6777S9c+Tk5GAymbjuuusoLS1l0qRJZGRkHFd8x8TEUFxc3MRc2p/Jk6fypz/9iR49emNsaAtktVpZvPhaHnvsDzz66B+JiIiksrKCJ598hCuuWIzVauX5559DURSuv/7nbbwGUnvn82p8+dE+Du4pJSTMypRZPYlPDjthutysCj77YC9+n8bw8Wn0G5J4XPFcW+/lf2sO8O2uYhIdQdw2rz9d4k/fgX1STDBLFw9l1YYcPlifzZ6cSsb2j2f1d4eJi7Jz+4IBcijn80wIwapvsti77jA2FEZM7caQoUkA7Onl4KN3d7Pv+3yyDpRTXucl3qujAgnJ4QwYlkhCSnibXY7Vvd5AW+aiIrz5edRsWI+vtARDSCiRMy4ibMJETFE/7S5ThRB8sT6HPVsKUJw+FMBjVKiyqtQbBEXb84nMKScq1EpUmJWyKjdfbSvA6fIRF2nn8qkZjOkbj72JIb6lluXRvDy/42V0BDf2u/q8FdCvvruTvnYzQeUevvxwHwBbv8slKNhMt4wIIvd/TVFWKQdjxtDFXM6wK6YS1L8/qunUTXwMwcHE3XgzQQMG4vxhM46fLcQU3f6uaAgh0PJ24v1hBVrxARR7OJaRlweK59N0x9daWq13Dk3T2LRpE6+++ip2u51f/OIX2Gy2E6Y72YH9bEYYak0eTxAGg4rDEcIll8zkiSce5le/+hUORwhWq4mQECtXX30b8fHR3HHHrY03bixcuJArrgj0yPHqq/8mKSmJm266+rh5P/zwwwQFBXa+w9Hyd8e3xjzbWnvLj5M52+1eXupkxX+3UVpcy8gJXdm3s4j3/ruV0RO7MXF6d4xGA7ou+OqT/Xz12QEcsSHMXzwYR+zR5fn8Guu3F/Kv93dSW+9l0QU9mD+lO6aT3I3fVJzXXdqfScNT+cv/fuDDDTn06RrF0mtHENzO2tL+WEfIDzjzHCksq+Old7ZRt78cu6Iwf8kQevc9OkiAwxHCkP6JPPOPDbjzawhCIaNfLBfO7EV0zLlti7PJY6FpVP6wheJPP6PuUBaesnI45mb00N696LL4CqJGjUA1nf9cam/5cTinkldf3oxW7QYFfCFmDFE2QkKtOCwGNE1QWuXiUEEN3+8pQdcFqgIj+sZz0egu9M+IbrMvSJ3x7wucPkeEEPxlw78oqCvi3nG30ie+S4vHUFnrJq/YSW5JLTn51RQdLEcvqycDFYsGvQYm0G9wIokp4RzYU8KWr/ax44dChNIdYrrTNT2SRTfORDWc+RWdmNkXwuwLW3Q9WiJHhK5Rt+97qta/i7coE0NoNFEX3kDIwMmoxra9t+y0w37PmjWLF1988bjeOa677jref//9Jmf8f//3fzidTpYuXQrA66+/zurVqzEYDPznP/8B4L333uO7777jsceO76Wiowy52d619zg7+5CszZV9oIw1K/eiqgpTL+5FcpdIfF6NdWsy2bOtkChHEKOndOOHDYfJz6miR79Yxk3LQDUqZBfVsjenkj05lRzIq8bn10mNC+Hamb1IPkUhdaZx+jWdnVkV9EmLwHSSG9haS2fNDzj1tq+qqGfzusOUlzpxu/zU13sRWmBdFKPCJZf1Jz45/KTzFEKwaVcx0RE2uiSeeOWipWI8Fc3ppHrd11R/8Tm+slIMYeHYe/XCHBuHKTYWc2wc5thYVOuJJ1POVkce9rumysXnnxyg4FAlOoKIlHDmXdoHq810ym2v64IqpweDQSUsqG2Lh/b+9wVa7xjySfYXvH/oI+Z0m8m01InnEGGArgvySp0cyKvmYH41B/OqKK/xoAKxKMShYgTUEDPjJnRhzNiuVFbVA4HmUZUfr6bsveXokTG4Ji2kRtgYOaErlja+MnGuOSI0H74D6/FuW4WoLkYJi8U8YCamjDEohnNft7PNj2M1q3cOgA0bNpxR7xyTJk3i7rvvpqamhqCgIL7++mumT5/O888/T05ODklJSaxcuZJ58859xBhJ6siqK13s3lrI1u9yccQFc+GlfRo7vDeZDUyc0Z0uGVF88dE+Pli2HaNRZdikrtRZVJ5fuZvdORW4PIEbW5McQUwYmEDv1Ej6dYvE0ALtSo0GlYHpP+3L7a2tttrNpnU57NtRhMGoYgmzkl/vwaPpxMcE0z8jml59YgmPtJ9yHoqiMOyYvoFbg9A0qr/5Cl9xMcLvQ/f5EH4/ustF/a6dCJ8PW/ceRM9fQPDAwe2q+6v2orK8nq3f5bJ3RxG6ENSYDVwypze9u0ad9rOqqsimVG0sq/owKw6tZmjsQKamnP39XNVOD9szy9meWX7cMTw82Ex6fChDo0OoyavB79VI6RrJ0LGpjTeVGk0GhK7jzsyk/MMV1O/cQfDQYcQuXoLB3vHvVRFCx7f3K7yb30PUV6FGp2GZegvGtCHt7l6JZvfOkZKSwiuvvMLs2bOb/NyAAQO4/vrrWbRoET6fjzFjxnD55ZfTtWtXbrvtNjweDxMmTGD69OkttjKS1BH4vBr5OZXkZlVy+FAFNVVuAHr0iyVlQBzr95WwP7eK7KJaDKpCkM1EsM1EcGIIxmo3+R4/G744AAT6BB3WM4beaZH0TIkgtI3PTknNU1/nZcuGw+zcUoAQYIy2s6/OTXlZLb1SI7hicjopsefnkrm/qgrVZjuhv9gjvMVFFL34Au5DmShmM4rRhGIyoZiMqEYToaPGED5pCpaGG8elo4QQFOXVsPW7XLIPliOAEnTiM6L41UW9ZVvmDmRV1qcEmexc3mNes5rRaLpOVmEtOw8FekHKKQqcoY0IsTC8Vyzdk8OJthjJ21/Owd0lVPh1UrpFMnTM0eJZq6+jfudOKvfvonzTD+hOJ4rJRMxVVxM2fmK77obuTGmV+Xi+fhmtaD+GuO6YJ96AIbF3u123M/qXGx8fj8fj4b///S/19fVcddVVZzTz+fPnM3/+/ONeGzVqFCtWnNifYnv2pz89wY4d2/D7feTl5ZKeno7fr7NgwUIee+whHnjgYaZNO/pl4M03/8vTT/+Zt95acULf0dJPhxCCwtxqyoqdVFW6qK6op7rCRW2NBwCjSSUhOZzwlDAOVNTz1t5iPDsKAHCEW+mREo4C1Lp81Ll8lFTW4/JopMYGc9ngRPp2jSIhyt5uDy7Sqfm8GpvW5fDDhsNofp1KAxzWNaiso2/XKK4akEC/rmffh+yZ0mprqd30PTXfbsCdeRDVbidszDjCJk2BhraMQgiqv/yC0reWoRhNxN94MyHDR7RqXJ1JXnYl33+VRXFBLUJVKEDHF2xi3pSeDO8lR6ztSHJqctldsY9Lus5ocjCUI0qrXOzKqmBXVgW7cypxefwoCnRLCGPu+K4MSI8mPtLGoX1l7PyhgK35NRhNKmmxKgnF2wneW0r9NjeZbjfC40F3u0EIjCEhBPXrT3D/gdj79OkcZ5/9XrxbPsC7bRWYrIGu6rqPbfd/35osog8dOsR//vMfPvjgAxITE3G73Xz++eeEhHTOmwlO5Y477gagsLCA2267iffff5/S0lpWrfqAmJhYvvxyzXFF9Nq1XxAc/NPaRtLxqirq+ebTg+RmVQJgthgIj7QTlxxGzwgbYY4g9pU5+WJbARWHPESFWhjTL47uyeFkJIWf8ciBUscihGDb5gI2fpON3+2nEkGZSaFXdwfTezjo0yUSSyuPICh0HeeWH6hZ9zV1u3aCpmFOTCJqzly8BflUfv4ZlZ99QvWQwViHjaL667XU79yBvU9fYpdchykiolXj6yzqnV7WfZ7Jwd0lqBYDuYpOlaoyY2wXLhyWjLmdjxQpneij7DUEGe2MTxp1ymmcLh/f7ylm3Y4isgprgCNXDB306RJFr9QIgm0mfF6N3dsK+eKtndTVegiLsDFiaDQRWz/Gt3Y7pphYjLGxKJYYVKsF1WrFEBSMvVdvkocPoKyi/nytdqsSQsef/QOe795C1BRjTB+FZdTlqLbT9yTVHpyyiL7hhhvYtWsXM2fO5JVXXqFfv35Mnjz5J1dAn87AgYPZtm0LLpcLm81GUVEhdrud4OD2dQe4dH74fRpfrt7HN58fxGBQGTOlGxl9YrDaTLg8fnZnV7LlQBkbN2Tj13R6pUawaGp3BqZHd+qBI37qKqpcbNteyN4fCsCtUYdAibEzbXQagzKiMTbjDvqzJYSgbttWyt57B29eLsaISCKmXUjoiFHHNcFwVFVStfZLar9eS+WmzShmMzFXXEXYxMnt/qxQeyCEYPfWQr798hBer0apAQ57vIzuF8/cCV0JD5ZfkDui3NoCdpTtZlaXC07ozk4IwbaD5azbWci2g2X4NUGSI4gFk7oxMD2auMijVwxd9T42fp3Njs35eNx+EpLDGDcpBfu2L6l+8zM0qxXHoisJnzAJxXDyL1qner0jEZoff8NNg3p1EUpYLLaZd2JM6tvWoTXLKYvoPXv20Lt3bzIyMkhrGAqyvR9Aa9avo/qbr854+rCx4wkdPeaclmkwGBg+fBQbNqxj8uSpfP55YCTDF1/85znNV+pYdF2Qk1nO+jWZ1FS5Se8dw6hJXSiv87FmawE7DpWTmV+DLgQ2i5Gx/eOZMjiRRIf8stUZZedX88PWQorzq/FUuzFrAgUFLxDWJZyr5/XDfpIuB8+FEAJvYQG624MxNARDSCiqxYIQgvrduyh/7x3cWYcwxcQSd8NNhAwbcdKbdIzhEURfcik9rr6cnK++xRyfgNnRfkY5bK8CAyRV8e3aLEoKaqk3KGQKjfTUSO4f343UOHkCqiNbnb0Gq8HKhKTja4aaei8vfbiH7ZnlhNpNTB6cxOi+cY33MtTXeck+WE5xQQ3F+bWUFNTg9+ukZUQxYHActgObqXjhJaqdtYSNm0DUpXMxhnSMs7BnQ3jq8O37Bu+O1Yi6StSoFKxTbsbYZeh5G2WwJZ2yiP7yyy/59NNP+e9//8ujjz7KhAkT8Hg85zO2DmPy5Kl88MF7TJ48la+//pI//vFpWUT/BAghKC2q5cCuEg7uLaXe6SU80sa0n/Vje14lD/93CyWVgWGMU2NDmDkqhb5douiWGNoivWZI7U9ufjUfrtqHv7weAwo6YLYbCY8JpkvXSAb0i8PeRBdmzSWEwJN7GOemjdRu3oSvuOi49xWzGdVmQ6uuxhgZReySawkdNeaMzmSpJhPB/Qeec4ydXb3Ty76dRezeWkhNlRtNgRx0wmOC+eXEdHqmyuYvHV2Bs4itpTuYkTYFu+loF417sit4fuVu6lx+Fk3NYOKgRIwGFY/bxw8bDrNnW2HjjeOqqhAVE0yvAfH06BmOum09lX/9B06nE1vPXjjmX4a14YRlZyN8Hvw5W/Bnfoc/dwfofgzxPTGPvxZDUt92f4K2Kacsoo1GIzNmzGDGjBkcPHiQZcuW4Xa7ueCCC7jmmmu4/PLLz2ecZyR09JhzPrN8NgYPHsqTTz7CoUMHCQsLl005OrmaKhd7dxRzcHcJ1ZUuVINCUloEdckq24pr+PTNrSgK9EqNYObIVAakR7d5n65S6yoorOGjVftwl9ahAPYoO2PHpdE1PRpjC59xBvBVVlK99nNqv/sOX2kJqCr2Hr2ImHYBxohItNoatNraxoe1a1dCx45vk8FNOiMhBHnZlezaUhjobUMXuI2BmwYtkTYWTejGwDYcBEVqWauz12AxmJmUHOjq16/pvP9NFqs25DSO4poSG4Kzxs32jfns3laIz6uRmBpOn0EJxCaG4ogNRvF5qFy9iqon16C7XAT1H0DkRbPb7fDa58qdfwDX1+/iz9kCfi+KPRxTnymY0kdhcKS1dXgt4ox650hPT2fp0qXccccdrFixgmXLlrXLIrqtGAwGhg0bwZNPPsrcuT9r63CkVuD362TtL2Pv9kLysqsASEwNp//wJPJcXlZtzMXp8tE9OZxLJmbQIzFUFs6dnBCCPbtL+G59Dq5yFwKBKdLG9Bk9STnJMO0tsTz3oUyq1nxK7eZNoOvYe/chcsZFBA8ajEHer9LqvB4/+3YUs/OHfKoqXBhMBqpMCoc9fqIjgrlsTBqDezhQZfHcaRTVlfBDyXampU4kyGSnpt7Ls8t3cDC/mnH941k0tTtC01mzci8Hd5cghCC9dwwDhycTHRs4oSaEwLl5IyX/ex2tpobgIUOJnDkLa0pqG69d69BrSvB8/za1h74HSxCmjDEY00diiMtAUTrXVdhmdU5ps9m47LLLuOyyy1orng5r8uRpfPzxKsaOHd/WoUgtyFnrYdv3uezbUYzH7Sck1MKwcWl07xvDrrxqXvnqEGXVbnqlRrBgUjfS4kI7xEhe0tmrqXGzdu0hDu8rR/Xr+BGo4Vamz+hBt1a4dK85nTi3bqHqy8/xZGeh2mxETJlG+KQpmByOFl+edCJnrYctGw6zb2cxPq9GSKSNimAjh5weUuJCuGF0TwZkRMviuRP6OOdzTKqRycnjcHn8/OXNbRSU1XHjxb0Z2TsOZ42bD97YQW2Viz6DExgwLKlxsCwAX2kpxa+/Sv3O7VhSUkm87ddY01p+mPD2QLideH5YgW/3GlANhI9dgD99Moq55UYpbW9kD+/NEB+fwNtvf9D4+8yZs5k5MzDozNChw1mzZl3je8dOJ3U8zloPW7/NZffWwCAYXbpH03tgPImp4RzMr+bP7+zgcLGTlJhgfnPZAPqktX6fvlLbKimp5cMVe3GV1aMAHgPEZUQyZUJXYqNbtp9WX3kZzi1bcG79Adf+faDrmOLiiLniKkJHjUG1ylHrzpe87Eo+fX8PXo+f5PRIcjw+Ps+pxBFu5dZ5/RiYLpttdFYl9WVsLNrC5ORxWFUbf3lzG3klTm6b14/+3aKpLK9n5Rvb8Xr8zLqsPwkp4Y2f1X0+qj77lPIP3gNFxbFwEeGTpnSKnjWOED4PWnkOemkWWmk2/sPbwOfC1H0c5qGXEpmW0ulPKMkiWpKO8ePiuUe/WAaPSiE03Ea108O/Vu5hw64iIkIs3DC7NyN6x8qzT52cs9bDhx/sofxwNToCwqwMGZHM8IHxLXKDqBACf1kZroMHGh/e/DwAzAmJDc01hmBJTZXF2nkkhOCHDYf5/qtswqPsRPZz8MGWAnQhmDO2CzNGpmAydp6CSDrRJzlfYFQNTEoaxz/e38Xew1XcMLs3/btFU1pUy8o3dqAocPHlA3A09L6iezxUf72WitWr0KqqCB40BMflV2CKjGzjtWkZR4bk9u38DL0qH4QAQLGHY0zqi3nwbAyRP51RS2URLf3k+X0a2QfL2b+zuHFwlGOLZ7+m88n3h3nvmyx8fp2LRqUya1QaFrP8A9qZeT1+Pv3kANm7SlAQeIJMXDi9B70zos96nkLX8ZWXUX5wN+W79+PJzcV1KBOtugoA1WrF2i2d0JGjCR48GHNsXAutjdQcbpePz1fuJSezgm69HOx2e9n+fS4D06O5fGoGjvDOe3laCih3VfBd0WbGJYzk3c8L2HKgjMunZjCqTxz5OZV8tHwXVpuJWZf1IzzSju52U/Xl51R+vBqttgZb9x5EXXcj9l6923pVWoxWkY/763+jFx9EjemGedDFGBxdUB1pqPbwtg6vTcgiWvrJKsytZu/2IjL3leLzagSFmOk/LIk+g+IJDbeh6TobdhWxcn02heX19O0ayaKp3YmLtLd16FIrEkLw/fe5bP4qG0UT1JsURk7oytghSc0+E+yvqsSVmYn7UMPj8GGEJ9DlFYqCKSYWe8+e2NIzsKVnYE5MOmnfzdL5U1JYwyfv7aGu1sPYael8fbiC7VkVXHlBdyYPTmrr8KTz5JOcL1BR8OSn8c2OQi4ek8a0ocns21nMlx/tIyzCxuzL+hMUYqF28yaKX/0PutOJvVcfImdfjL17j7ZehRYj/F68P6zAu+0jFLMN68TrMWaMkVfGaOUievHixZSXl2M0Bhbz0EMPcfjwYf7+97/j8/lYsmQJV1xxRWuG0GL8fj+vv/4yn3zyEUajAa/Xx4wZs7jqqmtaJJEef/wPzJkzj549O8+31vaqpsrN+s8zydpfhslsoFsPBxl9YkhICUdVFXx+jS9+yOOj7w5TVu0mITqIW+f2Y5DssqrTy8qtZPX7e8Hpxa1A18HxXDQ5HdMZdlPnr6qibtcO6nftwnVwP/6KCgAUoxFLSiqho8dgSU4mrl9P6u0RqBY5el17IYRg6/d5fL82C3uwmUuuGMCHW/PZtK+Un01KlwX0T0i1p4YNhZuIFd354vsKJg1OZNaoVL757CA7NuWTkBLGhZf2wWJSKHnjf1R9+jGWtC7E3Pbrdt9dnV5fjVa0D61gH3pFLkLzg9BA1wPPAjCaUIwWMJpRjBa08sOI2lKM3cdgGbkQ1Sp7Ajqi1YpoIQSHDh3iyy+/bCyii4uLuf3223nnnXcwm80sXLiQESNGkJ7evpMO4E9/eoLKynL+8Y9/07VrAtnZhdx3310EBQUzb965d2t3zz33t0CUUlP8Po0t3+Wy5dtcFAVGTOhCv6GJGI0q5TVudhwqJ6uwhi+3FlBT56VbQiiXT81gQPqJd90LTUP4/Qi/H93vQ3jcCE9gYJV6dxjeGg+KwQRH2kzqGmh+0DWEroEWOGAJXQdNRwgNNA3h8yO0wHwDBzcBiMDzkZ9/rOG9QNM0vbGN2umIICvOOvdZb8/GZR8TA0IPRNjwutAFOjoAiqIS2IoKKAogEEc+euR/ouE1wGi3EzV73rnFd4bKqly8/8EeXPk1AISlhnPVJb0Jtp+6m0Ktvg5fWRn+8jJcBw9St2sn3rxcAAyhodh79MR6QTrWrt2wJKc09tEshCAowkJ9QSl6dWUgBxRQUGj4IbDLj+zLxn0feJvjptMDuXUkr448hB7YF3rg+dSUhv+rx8w7oK7Khr+6viGWI3kIR3Pw1J89lSP798gcj/ykC9H4rAd+akj7I/ksGv7d+NF8bnS/B+FzY7BYiLrgmtMu93TqnV7WrNxLXnYlXXtEM2F6Bsu/zmbdjiIuHpPG9BEp57yMpgghQPMhfB50dz317hLchWUItwvh96OYAsUMJjOqyQwGU2C76HrDNtIDP+v+wHFG8weOUcc++zWE/0ixdGx+aCBE4ATBMQ9FUX50LDlynAnkgd9uot7pafj92Pw4W0eOCxyTSsrRX47NseOOx8e8JnR0BLquowkNgz2IqDnzmx3J1/nfous6h7bFMGlQInNHp/HhmzspOFxF/6GJjJrcDa2qgtz/+zvuzIOET56K42cLUYxtf3FfCB28LnRXNaKuClEfeOjVJWhF+9CrCgMTGi0YolNRrEGgqIHRAhu6nxOaD/xehLceUV+FYg/DOv4ajInyJN+PtdoeP3ToEIqicMMNN1BeXs7PfvYzgoKCGDlyJOHh4QBceOGFrF69mltvvbW1wmgRJSXFfPLJKt599yNCGvpiDQoK5je/uZusrEwqKsp5/PE/UFxchMFg4MYbb2HkyNFs2vQ9zz33NIqiEBISwoMPPorJZOTBB39HeXk5ANdeewNjx07g1ltv5NprbwTgpZeex2AwUlJSRO/efbj77vsxm2Wfw2dC1zW00gJ8Rbn4yopxlRRTVVpDidNCJhm41SBifLlk1G3F8k4dmW/poGkousAmBL2FoA+gqAoUAJvgkKIgdIHQBWiA1vQfi5zztK6dnSXGAa1QRAu/B1FXhbOynG1bc8k75MTpCcKv2IgWZQwx7SbocC3Vf/JR5dcaihANoekIXUP3CjSPQGjHzFQBNdyImhGEFmPBFWamRjmMrzYb/9ZP8W/V8SHQjxQ5jYWtgqaApoBPUdAUBb8CmhJ43d/4voLgaG1x5FkAugI6SsMz6A3THnnvVKl67LL8DT8LAp/lR59TGhamNCxVHFnej5YNIM7j1RoHkfztHOdx+FAFn6/ci9erMf7CDLqn2/nio6+o2nGAG+JUuufvp+T5arT6usCXXL+G7j9alAa+8AaOI0LTEScUpCDUhi2nKAiFwEMIhF8Hvw6aQNEA7Uy+ikhnyhLjgLMoojcWbcFXmshFQ3sxrruDd17ZgqvOy+QZGWT0iKR+53aKXnwe4fcR87OLCeoaj2/3ZwivC+H3gM+N8B15DjzwugI/+z0n+Ud57JflI1+eOe5LTaDAVVCMJlwmM5piDJyoUVXweY4ux3eKEyNmG4bYDMzdx2FM6IEanYqitn3R39G12hasqalh1KhRPPjgg7jdbhYvXsyMGTNwHNOvaUxMDNu3b2+xZe7bUcTe7UWnn7BBz/5x9Oh3+ht39uzZRVpaV0JDjx/PPjU1jdTUNO6//x4GDx7KwoVXkp+fxy9+cT3//vfrvPzyi9x117306tWHt95axv79eykvLyMuLoE//vGvZGdn8eGHKxg7dsJx8929exf/+c/rJCencv/99/DOO2+ycOGVZ7xenZ3b7WfHlhxytx+ktsKDQfNi89di89Ri9dRi9tbjMoVQbXVQbU3CbQoBFezeSvpWf0OwvwivQcGlKvhNCn6ris+o4DOAL3CcQmmoQhQCP2sq+I0KPqOC33DkAbqqoB15bvjrp4rAZxQB6o/OCgfOqygoioqqHnlWURUVTW1YjgJ+FfxK4I+xgoKh4cyQioKCiqqAiora8L6g4Q9zwxm+U517NCgqJsWAUVWxGk2NhWDgTKCORuAMqIqKioJBUTEoR5ZzomPPjYuGM6gG1YBBMaAqCmrD5wPTHjnb3LCdoKF5jHJ0u6A01B0KQUGhJyzvTLjdPjav20fhjgO4avzoQsUi3FiFCxt12EQ9tYRSZEzFbQxGEWYiXIUkVO8jpi4HHag2KmhGBc3Q8FCVwD4xGXHbFaqDVaqDDNQEqdQEGagMNeAzHdvk49g9oABHbkJt+pCrAEZFxYAh8KyoGJXAvgicGTx6DlcgGnLgyD469qE07r9TNUEKzNvQ8FAb93UgDgWLxYjXozUU1Q37reHk5JH5B5atNGRl4PnISfJTlYNK4xJoyO/Ab4EcOxo7ypEz7kefVYMR1WBGMZpQFAN2c/PvT9B1nV078sn8bifVZR6chBPkq2Jo+VpMf68gS4c0Ag9yofzI51TQDQr6kbxoePYbAscRn8GIXw18IRJCoAjReBxofCAajy0o4LUb8BmN+EwKXqPSeIzxGQI/+w0Kunr8PNSG+dJwDDjy70VRjv8CFCjWFTCoCIMBxaCC0YCiBvZZ4N9oIAdAQQgdXehoeuAMtTim0jtydUlRlMC/b9WA2WQGASrK0S8HRz7VmB8KhiOZ0Xi15ehzYN46ugC94RqEImg41qkN/2qUxpwIZEjjhayGz4vGfxdH8lFVDBgUlRD72Q16FF5uZkBJPFr2Vt5ZF45JczO4cA3KM+UcbJjGaIOI7mDIXoE7+5gPG80oJiuYrCgmC4rJhmINQQlxNLxu4aT/NtSGIrmxYG7Y8kIcvSIjdND8WEzgrqsPXL3QNRSjJTBvsw3FZEUx21DsYSj2cFR7OIo9PBCPbI7Y4lqtiB40aBCDBg0CwG63M3/+fB577DF+/vOfHzfdyXZqVNTZDZtdEFqNqRk9JoSE2nA4Tt+2JzTUhslkaJx29erV/P3vf0fXdcxmM3l5efzxj48TEhKCw9GLQYMGkpeXyfTpF7B06W+ZOnUqU6ZMYcyYMWRnZ/PCC89RU1PBxIkTufPOXxMcHIzZbCQ8PPAHYfjwYQwZ0g+An/1sHm+++SYOx81nsUU4o/XraN5+aRPVVW4UYSLEU40QgnJzDL7gVAg5WsjoBhduWyXO0MM4Q6uoD6lms0HFbkzFarJiM1oJMtsIMgcRbLITZLYTZrZjUo2Bg7iiNP5xMqoGjKrxmIfhJM8GzAYzJoMRk8GEWTVhMpgaCxzlyCVSqVUtf2kjVVVeIAK7XolRuKhX7VQbIvGr1sClaqFh0wuxGXbhDCtiX4Rgk92A1+TAbwCTwYTdZMNmsmI32Qgy27CZbNhNNqwGC0EGI+FqYD+bVCNmgwmL0YzZYMZiNGMxBH42N+TCkekMyoltq1XVgKlhXk0VvVLLePvvX1FaDWAj2FNPkmcrodpuCiPAmWjDaVOpsxlwWRVcFrXxoRkDXxrMDfvTrJowGwN5cuQRZLJhNVowGkwnHCNMx+SLyRA4jpgNpsb5mVQjRoPx+C9CDT8bFQOqqmJQAgXskfek1uHIG01hvQu7r5oUfR892Y0tCVRrDAabDWNwCJGD+2KKdGAMicIQHIEhOALVbA00i5AadcYa5FitVkRv2rQJn8/HqFGjgMA388TERMrKyhqnKSkpISYm5oTPlpc70fXmN65KSA0jIbVfsz5zJh2Bx8encfDgQbKzCwkKCmb69OkMGTKGwsICbrvtJjRNp6zMibvhKorH46Oy0slFF81jwIDhrF//NY899jgTJ07h6quv47XX3uLbbzfwzTdf8cIL/+L119/G6/VTVVUPgKaJxriqquqP+7052vvIeaqqnNUXphj3XlCyKIuupiQhnIjkdILMbiyKwOSzonrMhIRYCQ+PJtjcE7vRTpDJjtVoxdRal68EDU09jm53FzouPK2zvBbQWfMjzncIk7WA/fHl7I7SiLBHEmIOIdgURJAhCDvBBFtsBNu7YTf1w24MFEA2gw2b0YrFaGm5PGnICWhoatHw8vHbXuDBB/haZpktpL3nB5xdjgR5y9HFIQqjS9iTACnJvam3TCfIZCfGFEQXkx270YbNGCiIrQYrNqMFi8GCobUKpCN50pACR7b90ZePZI+/dZZ/FjprfgBk2A6S3NVGdN8+GBwXBtqj/8gx/7QDx/9aHag/h2jPXEfY9tD+4zzb/DhWqxXRtbW1PP300yxbtgyfz8e7777LH//4R+666y4qKiqw2Wx88skn/OEPf2itEFpMXFw8F144k4cffpD77nsAhyMETdNYv/5rVFVlyJChrFz5XmNzjh07tnHHHfdyww1Xc9dd9/Kzny0iJCSUb75Zy/Llb1BQkM9tt/2GkSNHM2/eLJxO53HL2759K6WlJURFRbN69YeMGDG6jda8ffp2dBkpwb2YmTCcbmFp8syddJy1w3KpctcwLHYIVyWNJjkksa1DktqR70bsx6CYGJtwMcPjBhNkkl1WSscbseSKszqRJ/30tFoRPWnSJLZt28acOXPQdZ1FixYxZMgQbr/9dhYvXozP52P+/Pn079+/tUJoUXfccQ/Llr3OL395EwaDisvlpk+ffjz11NPY7XaefPIRVq36AEVRuPvupURHR3PTTbfwyCO/x2AwYLFYuOuue4mNjePBB3/H4sWXYTQaufbaGxtvVjwiOtrBww8/QGlpCcOGjWD27Dlts9Lt1G+H3YpZkV2DSSd3Qeok+kf3JdjUskNxS53D9f2uItGeIL98S5J0zhQhzrA/rPPobJtznC+teYnihx828dJLz/Pss8+f87w666WUn3J+tKT2HmdnzQ9o/9seOkaMZ5MjMj9aRkeIsbMeQzrCtof2H2dLNOeQdyZIkiRJkiRJUjPJTgLbmcGDhzJ48NC2DkOSJEmSJElqgjwTLUmSJEmSJEnNJItoSZIkSZIkSWqmdtmcQ1Xb/13THSFGaN9xnm1s7XmdjugIMUL7jrMz5wd0jDjbe4xnE197X6cjOkKc7T3GznwM6QgxQvuOsyVia5e9c0iSJEmSJElSeyabc0iSJEmSJElSM8kiWpIkSZIkSZKaSRbRkiRJkiRJktRM7ebGwg8++IC///3v+Hw+lixZwhVXXNFmsTz77LN89NFHAEyYMIHf/va33HvvvWzevBmbzQbArbfeyrRp01i/fj2PPfYYHo+HGTNmcPvtt5+3OBcvXkx5eTlGY2A3PvTQQxw+fPik27Gt4nzrrbd47bXXGn/Py8vjkksuweVyNWt7tqf8gI6RIzI/2o7Mj5bRUvkB7StHOkJ+QPvPEZkfMj9OpyVz5KREO1BUVCQmTZokKisrRV1dnZg9e7Y4cOBAm8Sybt06cdlllwmPxyO8Xq9YvHix+OSTT8SsWbNEcXHxcdO6XC4xYcIEcfjwYeHz+cS1114rvvzyy/MSp67rYsyYMcLn8zW+dqrt2JZxHmv//v1i2rRpory8vFnbsz3lhxAdI0dkfsj8aMpPKT+aWre20BHyQ4iOlyMyP2R+nM655MiptIvmHOvXr2fkyJGEh4djt9u58MILWb16dZvE4nA4uOeeezCbzZhMJrp160ZBQQEFBQXcf//9zJ49m6effhpd19m+fTupqakkJydjNBqZPXv2eYv70KFDKIrCDTfcwMUXX8xrr712yu3YlnEe68EHH+T222/HarU2a3u2p/yAjpEjMj9kfjTlp5QfIP/GnI2OliMyP2R+nM655MiptIvmHCUlJTgcjsbfY2Ji2L59e5vEkpGR0fhzdnY2q1at4r///S/ff/89Dz30EHa7nZtuuom3334bu91+QtzFxcXnJc6amhpGjRrFgw8+iNvtZvHixcyYMeOk2/Fk2/d8xXnE+vXrcbvdzJgxg9zcXEaOHHnG27M95Qd0jByR+SHzoyk/pfwA+TfmbHSkHJH5ESDz49TONUdOpV2ciRYn6apaUdq2g+4DBw5w7bXXcvfdd9O1a1f+9re/ERUVhc1m46qrrmLt2rVtGvegQYN48sknsdvtREZGMn/+fJ5++umTxtMetu+yZcu45pprAEhOTm7W9mwP8Z9Me84RmR8yP5ryU8oPkH9jzkZHyhGZH0fJ/Di5c82RU2kXRXRsbCxlZWWNv5eUlBATE9Nm8WzevJklS5Zwxx13cOmll7Jv3z4+/vjjxveFEBiNxjaNe9OmTWzYsOG4mBITE08aT1tvX6/Xy8aNG5k8eTJAs7dnW8d/Mu09R2R+yPxoyk8pP0D+jTkbHSVHZH7I/DidlsiRU2kXRfTo0aPZsGEDFRUVuFwuPvnkE8aPH98msRQWFnLLLbfw1FNPcdFFFwGBDfzoo49SXV2Nz+fjjTfeYNq0aQwYMICsrCxycnLQNI2VK1eet7hra2t58skn8Xg8OJ1O3n33Xf74xz+edDu2ZZwQSNi0tDTsdjvQ/O3ZnvIDOkaOyPyQ+dGUn1J+gPwbczY6So7I/JD5cTotkSOn0i7aRMfGxnL77bezePFifD4f8+fPp3///m0Sy4svvojH4+Hxxx9vfG3hwoXceOONXH755fj9fi644AJmzZoFwOOPP85tt92Gx+NhwoQJTJ8+/bzEOWnSJLZt28acOXPQdZ1FixYxZMiQU27HtooTIDc3l7i4uMbfe/bs2aztqShKu8kP6Bg5IvND5kdTfkr5AfJvzNnoKDki80Pmx+m0RI6ciiJO1ghEkiRJkiRJkqRTahfNOSRJkiRJkiSpI5FFtCRJkiRJkiQ1kyyiJUmSJEmSJKmZZBEtSZIkSZIkSc0ki2hJkiRJkiRJaiZZRJ+hyZMns2PHDp599lk+++yzFp33tddeS0VFBQA33HADBw8ebNH5S+eHzBGpKTI/pKbI/JCaIvOjfWoX/UR3JN999x3p6ektOs9169Y1/vzCCy+06Lyl80/miNQUmR9SU2R+SE2R+dG+yCK6GdauXcvOnTt58sknMRgMTJgwgaeeeoqNGzeiaRq9e/dm6dKlBAcHM3nyZPr378++ffv4zW9+g9Fo5J///Cder5eKigrmzJnDr3/9a+69914Arr76ap5//nmuuOIK/vrXv9KvXz/eeOMNXn31VVRVJTo6mvvvv58uXbpwzz33EBwczL59+ygqKqJr1678+c9/JigoiKeffppPP/0Uk8lEREQEjz32WJsPgfxTInNEaorMD6kpMj+kpsj8aIeEdEYmTZoktm/fLq688krx0UcfCSGEeOaZZ8Tjjz8udF0XQgjxpz/9STzwwAON0z/77LNCCCF0XRdXXnmlyMrKEkIIUVRUJHr16iXKy8uFEEJ079698ecjy1m/fr2YOnVq4+vLly8XM2bMELqui7vvvltcdtllwuPxCK/XK+bMmSPefvttUVBQIAYPHiw8Ho8QQogXX3xRfPrpp+dl+0gyR6SmyfyQmiLzQ2qKzI/2SZ6JPgdffvkltbW1rF+/HgCfz0dUVFTj+0OHDgVAURT+8Y9/8OWXX7Jy5UoyMzMRQuByuU4576+//pqZM2cSGRkJwNy5c3nkkUfIy8sDYNy4cZjNZgC6d+9OdXU1sbGx9OzZk0svvZTx48czfvx4Ro0a1SrrLp0ZmSNSU2R+SE2R+SE1ReZH25NF9DnQdZ377ruPCRMmAFBXV4fH42l83263A1BfX8+ll17K1KlTGTp0KPPmzeOzzz5DNDHi+sneE0Lg9/sBsFqtja8rioIQAlVVee2119ixYwcbNmzg0UcfZcSIESxdurRF1ldqPpkjUlNkfkhNkfkhNUXmR9uTvXM0k8FgaEyisWPH8vrrr+P1etF1nfvvv58///nPJ3wmJycHp9PJr3/9ayZPnsz333/f+Jkfz/OIsWPHsmrVqsY7ZpcvX054eDipqamnjG3v3r3MmjWLbt26cdNNN7FkyRL27dvXUqsunSGZI1JTZH5ITZH5ITVF5kf7Is9EN9OkSZN44okn8Pl8/OIXv+CJJ57g0ksvRdM0evXqxT333HPCZ3r06MHEiROZMWMGoaGhpKSkkJ6eTk5ODikpKUybNo1Fixbx3HPPNX5mzJgxLFmyhKuvvhpd14mMjOSf//wnqnrq7z09e/ZkxowZzJs3D7vdjtVq7dTfANsrmSNSU2R+SE2R+SE1ReZH+6KIps7nS5IkSZIkSZJ0AtmcQ5IkSZIkSZKaSRbRkiRJkiRJktRMsoiWJEmSJEmSpGaSRbQkSZIkSZIkNZMsoiVJkiRJkiSpmWQRLUmSJEmSJEnNJItoSZIkSZIkSWomWURLkiRJkiRJUjP9f5mtpBA3oNXqAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 864x144 with 5 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "plt.rcParams[\"font.family\"] = \"Times New Roman\"\n",
    "plt.rcParams[\"font.size\"] = 2\n",
    "plt.rcParams[\"legend.columnspacing\"] = 0.5\n",
    "plt.rcParams[\"legend.handlelength\"] = 1\n",
    "plt.rcParams[\"legend.borderaxespad\"] = 0\n",
    "plt.rcParams[\"legend.labelspacing\"] = 0.1\n",
    "plt.rcParams[\"legend.frameon\"] = False\n",
    "\n",
    "\n",
    "sns.set()\n",
    "aggregators = ['SCClip', 'GM', 'MOZI', 'TM', 'Gossip']\n",
    "colors = sns.color_palette()[:len(aggregators)]\n",
    "\n",
    "fig, axes = plt.subplots(nrows=1, ncols=5, figsize=(12, 2), sharey=True)\n",
    "\n",
    "def plot_iid(df, ax):\n",
    "    for agg, c in zip(aggregators, colors):\n",
    "        _df = df[df['Agg'] == agg]\n",
    "        ax.plot(_df['Iterations'], _df['Accuracy (%)'], color=c, label=agg)\n",
    "\n",
    "    ax.legend(loc='lower left', bbox_to_anchor=[0.1, 0.])\n",
    "    ax.set_xlim(0, 750)\n",
    "    ax.set_xlabel(\"Iterations\")\n",
    "    ax.set_title(\"IID\")\n",
    "\n",
    "plot_iid(df[~df['NonIID']], axes[0])\n",
    "\n",
    "def plot_noniid(df, ax):\n",
    "    for agg, c in zip(aggregators, colors):\n",
    "        _df = df[df['Agg'] == agg]\n",
    "        ax.plot(_df['Iterations'], _df['Accuracy (%)'], color=c, label=agg)\n",
    "    ax.set_xlim(0, 750)\n",
    "    ax.set_xlabel(\"Iterations\")\n",
    "    ax.set_title(\"NonIID\")\n",
    "\n",
    "plot_noniid(df[(df['NonIID']) & (~df['Bucketing']) & (~df['RandomEdge'])], axes[1])\n",
    "\n",
    "def plot_bucketing(df, ax):\n",
    "    for agg, c in zip(aggregators, colors):\n",
    "        _df = df[df['Agg'] == agg]\n",
    "        ax.plot(_df['Iterations'], _df['Accuracy (%)'], color=c, label=agg)\n",
    "\n",
    "    ax.set_xlim(0, 750)\n",
    "    ax.set_xlabel(\"Iterations\")\n",
    "    ax.set_title(\"NonIID + B.\")\n",
    "\n",
    "plot_bucketing(df[(df['NonIID']) & (df['Bucketing']) & (~df['RandomEdge'])], axes[2])\n",
    "\n",
    "def plot_edge(df, ax):\n",
    "    for agg, c in zip(aggregators, colors):\n",
    "        _df = df[df['Agg'] == agg]\n",
    "        ax.plot(_df['Iterations'], _df['Accuracy (%)'],  color=c, label=agg)\n",
    "\n",
    "    ax.set_xlim(0, 750)\n",
    "    ax.set_xlabel(\"Iterations\")\n",
    "    ax.set_title(\"NonIID + R.\")\n",
    "\n",
    "plot_edge(df[(df['NonIID']) & (~df['Bucketing']) & (df['RandomEdge'])], axes[3])\n",
    "\n",
    "\n",
    "def plot_both(df, ax):\n",
    "    for agg, c in zip(aggregators, colors):\n",
    "        _df = df[df['Agg'] == agg]\n",
    "        ax.plot(_df['Iterations'], _df['Accuracy (%)'],  color=c, label=agg)\n",
    "\n",
    "    ax.set_xlim(0, 750)\n",
    "    ax.set_xlabel(\"Iterations\")\n",
    "    ax.set_title(\"NonIID + B. + R.\")\n",
    "\n",
    "plot_both(df[(df['NonIID']) & (df['Bucketing']) & (df['RandomEdge'])], axes[4])\n",
    "\n",
    "axes[0].set_ylim(45, 100)\n",
    "axes[0].set_yticks([50, 60, 70, 80, 90, 100])\n",
    "axes[0].set_ylabel('Accuracy (%)', labelpad=-2)\n",
    "for i in range(5):\n",
    "    axes[i].tick_params(axis='y', which='major', pad=-4)\n",
    "    axes[i].tick_params(axis='x', which='major', pad=-2)\n",
    "\n",
    "fig.subplots_adjust(wspace=0.093)\n",
    "\n",
    "fig.savefig(\"./dumbbell_acc.pdf\", bbox_inches=\"tight\", dpi=720)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "d55a7d355c2d2bc0905cf312cf31c7bd25efc90d5ad78f8099868776121b8193"
  },
  "kernelspec": {
   "display_name": "Python 3.8.5 64-bit ('base': conda)",
   "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.8.5"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
