{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7cac932d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import pandas as pd\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "0847c714",
   "metadata": {},
   "outputs": [],
   "source": [
    "xcol = 'num_units'\n",
    "xlabel = 'No. units'\n",
    "filename = 'benchmark-results.csv'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "976f5d5b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>model</th>\n",
       "      <th>exp_alias</th>\n",
       "      <th>time</th>\n",
       "      <th>gpu_memory</th>\n",
       "      <th>num_components</th>\n",
       "      <th>num_units</th>\n",
       "      <th>optimizer</th>\n",
       "      <th>backend</th>\n",
       "      <th>batch_size</th>\n",
       "      <th>input_shape</th>\n",
       "      <th>seed</th>\n",
       "      <th>num_params</th>\n",
       "      <th>use_tucker</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>OSOS</td>\n",
       "      <td>real</td>\n",
       "      <td>0.056292</td>\n",
       "      <td>2051825152</td>\n",
       "      <td>1</td>\n",
       "      <td>10</td>\n",
       "      <td>LandingSGD</td>\n",
       "      <td>geoopt</td>\n",
       "      <td>256</td>\n",
       "      <td>1,32,32</td>\n",
       "      <td>13124</td>\n",
       "      <td>34112400</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>OSOS</td>\n",
       "      <td>real</td>\n",
       "      <td>0.056332</td>\n",
       "      <td>2051825152</td>\n",
       "      <td>1</td>\n",
       "      <td>10</td>\n",
       "      <td>LandingSGD</td>\n",
       "      <td>geoopt</td>\n",
       "      <td>256</td>\n",
       "      <td>1,32,32</td>\n",
       "      <td>41541</td>\n",
       "      <td>34112400</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>OSOS</td>\n",
       "      <td>real</td>\n",
       "      <td>0.056807</td>\n",
       "      <td>2051825152</td>\n",
       "      <td>1</td>\n",
       "      <td>10</td>\n",
       "      <td>LandingSGD</td>\n",
       "      <td>geoopt</td>\n",
       "      <td>256</td>\n",
       "      <td>1,32,32</td>\n",
       "      <td>945345</td>\n",
       "      <td>34112400</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>OSOS</td>\n",
       "      <td>real</td>\n",
       "      <td>0.032349</td>\n",
       "      <td>1390787072</td>\n",
       "      <td>1</td>\n",
       "      <td>128</td>\n",
       "      <td>LandingSGD</td>\n",
       "      <td>geoopt</td>\n",
       "      <td>256</td>\n",
       "      <td>1,32,32</td>\n",
       "      <td>13124</td>\n",
       "      <td>22347904</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>OSOS</td>\n",
       "      <td>real</td>\n",
       "      <td>0.033682</td>\n",
       "      <td>1390787072</td>\n",
       "      <td>1</td>\n",
       "      <td>128</td>\n",
       "      <td>LandingSGD</td>\n",
       "      <td>geoopt</td>\n",
       "      <td>256</td>\n",
       "      <td>1,32,32</td>\n",
       "      <td>41541</td>\n",
       "      <td>22347904</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  model exp_alias      time  gpu_memory  num_components  num_units  \\\n",
       "0  OSOS      real  0.056292  2051825152               1         10   \n",
       "1  OSOS      real  0.056332  2051825152               1         10   \n",
       "2  OSOS      real  0.056807  2051825152               1         10   \n",
       "3  OSOS      real  0.032349  1390787072               1        128   \n",
       "4  OSOS      real  0.033682  1390787072               1        128   \n",
       "\n",
       "    optimizer backend  batch_size input_shape    seed  num_params  use_tucker  \n",
       "0  LandingSGD  geoopt         256     1,32,32   13124    34112400        True  \n",
       "1  LandingSGD  geoopt         256     1,32,32   41541    34112400        True  \n",
       "2  LandingSGD  geoopt         256     1,32,32  945345    34112400        True  \n",
       "3  LandingSGD  geoopt         256     1,32,32   13124    22347904       False  \n",
       "4  LandingSGD  geoopt         256     1,32,32   41541    22347904       False  "
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results = pd.read_csv(filename)\n",
    "results = results[results.columns[1:]]\n",
    "results.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "7f207f76",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = results.copy()\n",
    "\n",
    "df['dim'] = df['input_shape'].apply(lambda x: x.split(',')[-1]).astype(int)\n",
    "df['type'] = df['model'] + ' ' + df['backend'] + ' ' + df['optimizer'] + ' ' + df['use_tucker'].apply(lambda x: 'Tucker' if x else 'CP')\n",
    "\n",
    "type_to_label = {\n",
    "    'OSOS geoopt LandingSGD Tucker': r'$\\perp_\\mathbb{C}^2$ Tucker NO',\n",
    "    'OSOS geoopt LandingSGD CP': r'$\\perp_\\mathbb{C}^2$ CP NO',\n",
    "    'SOS geotorch SGD CP': r'$\\pm_\\mathbb{C}^2$ SGD',\n",
    "    'SOS geotorch Adam CP': r'$\\pm_\\mathbb{C}^2$ Adam',\n",
    "    'OSOS geoopt LandingAdam CP':  r'$\\perp_\\mathbb{C}^2$ Hadamard',\n",
    "    'OSOS geoopt LandingAdam Tucker': r'$\\perp_\\mathbb{C}^2$ Kronecker',\n",
    "}\n",
    "df['type'] = df['type'].apply(lambda k: type_to_label[k])\n",
    "\n",
    "df['gpu_memory'] = df['gpu_memory'].apply(lambda x: x / (1024.0 * 1024.0 * 1024.0))\n",
    "\n",
    "mask = ~((df['optimizer'] != 'LandingAdam') & (df['model'] == 'OSOS')) # & (df['num_params'] > 1e6)\n",
    "\n",
    "df = df[mask]\n",
    "\n",
    "from pandas.api.types import CategoricalDtype\n",
    "cat_type = CategoricalDtype(categories=list([x for x in type_to_label.values() if x in df['type'].unique()]), ordered=True)\n",
    "\n",
    "df['type'] = df['type'].astype(cat_type)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "086ba24c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<svg  width=\"550\" height=\"55\"><rect x=\"0\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#1f77b4;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"55\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#ff7f0e;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"110\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#2ca02c;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"165\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#d62728;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"220\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#9467bd;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"275\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#8c564b;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"330\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#e377c2;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"385\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#7f7f7f;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"440\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#bcbd22;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"495\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#17becf;stroke-width:2;stroke:rgb(255,255,255)\"/></svg>"
      ],
      "text/plain": [
       "[(0.12156862745098039, 0.4666666666666667, 0.7058823529411765),\n",
       " (1.0, 0.4980392156862745, 0.054901960784313725),\n",
       " (0.17254901960784313, 0.6274509803921569, 0.17254901960784313),\n",
       " (0.8392156862745098, 0.15294117647058825, 0.1568627450980392),\n",
       " (0.5803921568627451, 0.403921568627451, 0.7411764705882353),\n",
       " (0.5490196078431373, 0.33725490196078434, 0.29411764705882354),\n",
       " (0.8901960784313725, 0.4666666666666667, 0.7607843137254902),\n",
       " (0.4980392156862745, 0.4980392156862745, 0.4980392156862745),\n",
       " (0.7372549019607844, 0.7411764705882353, 0.13333333333333333),\n",
       " (0.09019607843137255, 0.7450980392156863, 0.8117647058823529)]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "def_palette = sns.color_palette()\n",
    "\n",
    "palette_dict = {\n",
    "    '$\\\\pm_\\\\mathbb{C}^2$ Adam': def_palette[1], \n",
    "    '$\\\\pm_\\\\mathbb{C}^2$ SGD': def_palette[0],\n",
    "    '$\\\\perp_\\\\mathbb{C}^2$ Hadamard': def_palette[3], \n",
    "    '$\\\\perp_\\\\mathbb{C}^2$ Kronecker': def_palette[2],\n",
    "}\n",
    "\n",
    "def_palette"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "666a4818",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAQ0AAACECAYAAACK2n6sAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAT59JREFUeJztvXl4G8eVL/rrBkBwx0JJlrWZBCVZiy2TICnHlj1xJFCRnYxzI5HUy01yM3ljkcrzzNz3ZSJSzDKJZxxLpH3f3JeJxwLpTJKJczMUSXmSOB5bAO3cOHEyIgEqsmU7EgFSi2UtJBYuILF13z+gKjUa3UADICnK5u/7+LGr6vTpc6oa1aeqTp1ieJ7nAaCzsxP79u0DQV9fH3bs2EHTvb292LNnD+YTHMfh0qVLKCoqAsMw8/rsRSxiEfHgeR4TExNQkwzxj1Kc9nq98yOZAJcuXcLq1avn/bmLWMQi5MEQS8NoNKK8vJwWeL1eGAwGALEeZnh4GGNjY/MqnN/vh16vx/DwMIxGIwAgHA4DADQajey1WP5MIOaXKZ1Ueao8cblcWbY6KpFfCV0mOorTC70t5cqS6ZQsTbCQdJQrJ3nT09NYvXr1DUujoaEBTU1Nkox4nkdHR4dS+WcNxNrR6/UoLi4GEBuyAADLsrLXABCNRuk9mUDML1M6qfJUeeJyubJsdVQivxK6THQUpxd6W8qVJdMpWZrgpusY8AKBMYBVAbo14K7/5qTajXQktNNoampCZWWl7MPkOhQp9PT0AAD6+/tRW1sLi8UCAOjo6IDJZILT6URdXR1MJpMiftFoNOGa/GikrgEgNzdXsbzJnpmqEVLRSZWnyhOXy5Vlq6MS+ZXQZaKjOL3Q21KuLJlOydIEN0XHq2fAvv8H4PIfgfcHgcBorNMwmhBdsRVYfg/Y8geBfL2kzHR4Mluw2+1wOp1obm6G2+1GfX09HA4H3G43rFYr2traAAD19fXo7u5Oymt8fBw6nQ4ej4eabkIFZmZmAAAqlYrmq1QqAEAoFEJOTk7Geoj5ZUonVZ4qT1wuV5atjkrkV0KXiY7idDL9F0JbypUl0ylZmmCuddRqtTfmJwMeRE//Anjzn6AaPy/Nh4nZEaryh4CtTUD5Q5T31NQUdDrdDUtjZGQEpaWlAIDXXnstgVl3dzeee+65lMJbLBZqWbjdblRXVwOIdSbCORO3251wbzAYRDAYpOnx8XEA8SYdx3GYmprC5cuXaT7DMCB9H6kgjuNS9rrJIOaXKZ1Ueao8cblcWbY6KpFfCV0mOorTyfRfCG0pV5ZMp2RpgrnWsbi4GCtXrgQ8I8Bv/ye4t3oBAHLdJ0c6jSE7cOE/gZ3fBbe5Lo6GdhoWiwU9PT2oqKhAY2Mjamtr4xR0OBxpKyK0LHw+H/R6PS3z+XwJ9IcOHcITTzyRkD8+Pg6WZaHT6TA+Po4PPvgARUVFWLJkCTiOA8Mwko1CXkCGYSTNXtLpqFQqcBwXRxuJRGiZHC3hFY1GqQzkx0zKhHzVajUikQh4ngfLsgm0PM/TP7VaHfdVEvISmrosy1K+ROdUupIyIi+RP1m9CGUQ8+V5HiqVisoux5c8V61Wg+M42nYqlSquvnmejysLh8OUh1hXuToU0qaqb6W0Qpmk2obIJHwPxWWkXkgZeQ7HcdBoNAnvodJ3Vqq+x8fHMTo6ipICNSJvWBE++yZ47e0omrkEb14ZACA34oOKC2EqZxkAIC80iqC6GBybA4aPQP/yAfjDOUDZx2m9005jaGiIVkJ3d3fC/Mbg4CDSQXt7O1pbW+m8hV6vl+wohGhtbcVXv/pVmh4fH8fq1auh0+no8CQ3Nxcsy2LZsmV0HCj3dc7Gt+NWsDSy1VGJ/Ero5trSyM3NveltOdeWxly8rwzDxFwlXH0oPPU8ACDCxIZAhunhGFGeETCsR044CIy+hwjUUIeuQc2HKB/9H9qB5aUI6NYBEHQaQpAOQzhkSTZJKobdbofFYoHZbEZPTw/q6upQXV2Nrq4uSmM2mxPu02q10Gq1CfnCipYbkkiZtKnGsMlwK3Qa2eqoRH4ldPMxPLnZbTkfw5PZ1pFhGCAaBgZ+fIOOYRFdXoH+TQfw9mQx3p/kMDoRgjqXwcpVOVhTEIWZ+RPW/ec3gdBk7J7xS8CfXga2/ncAgk6js7MTfr8fQOwHvX37djgcDrS1taG8vJzmpQKZ/DSZTPD5fLBYLKirq4PZbMbAwADsdjvcbjc6OzsVV4hwrCe8TqggAbKd31Xa66eikypPlZfM0U7qR5gNZkPPTHQUpxd6W8qVJdNJSZpgznSMBIGpq7Hr/KX4/bZ/wS+HGbz8qysIRTwJ5GoGWKEvwZ7Kf8cuVT9Mb7aC5SPAW93AHTtjNITYYrGgqakJ7e3tqKiooExcLhfcbjed3EwFk8kk6z3a2NioiIcY4olQgmRfp2xxK1gas4FbwdLIFreCpZEtZGWPxoYZ0ZK7cPTu7+N7x4cxGYwgdH1K5t5VeTh1NYSK27RwXAqABXB1fAb/+Nowfr16Hb628xgq7Z8HAj7gymkAgk6jr68Px48fTxCG5B07diyuM5lPCM024XWyr1O2ZvutYGlkq6OcLOnSzbWlsRDacq4tjTnRMRqJdRp5RnRt/h7+/uWzEHZZNSvy0LH855i6cx0Kxt7G6IZ7UWtfRssHL3jxrelCPPnQD1D12heBycsAAGrrS7mwKrUu5hpSzl0A4ma/hddiukwg5pcpnVR5qjxxuVxZtjoqkV8JXSY6itMLvS3lypLplCw9LzryUYDncKLyEJ62DyPKAzls7A8A3h4NYUp/J3S/fRKqq6cwOH1bXDkAuEcn8a9DeRi96y+B0BQAQachNaTQ6XT02uNJHP/MJ8LhMF3yAeLNMbIURvKFf2RZSu6/XJmQXzJaoQxStOvWrYPb7U64B0AcrZwuyYZmcjIp0Vssi7isvLwcQ0NDkjIoqSspvuK6kmtLqTpLR6dk8jU3N8vSyrWlnP7EnUBOp2RtKfUOZPKeivnG0zLgVFrYznOIRCNgGYBlAI4HtCxQtTwHuaNvI7RkI/gpD+7JvYIIH6NRMUCuClCzwK/PjOI3ht2IXvfuoJ3G0NAQJiYmEpQCYkufwiXZucazzz6LTZs2oaamBkB8LyxsnGRfp9lwekr360S8YYXo6upCWVlZwj3J+KR6NinLVsdk8hw9ejTOzV9KN+H9cjqloiN8hWXiOputtmxvb8fBgwdT0ilFXV0d2tvbU7aVVD2IMRttmcBXpUZIXYQ/uG5sNBVaEic/mMZoSTX67vhbXKlpxu/8SxIsDXLPb84FMLPkrpispKC1tRWVlZX4wQ9+QD0xx8fHcezYMVRVVWH//v1ZK6UUjz/+ON555x309/cDiG2U0Wg0UKvVUKvVYJiYMwtxjhH/F/7J0QhpU9EopW1vb0+graqqiqPx+/0ZySCXlwk/4T1yNGK5n376acV15ff7FeskxVf8bDk5x8fHFdfV+Pg43G43jEZj2nLK8S0vL4fD4ZiVd0/JO522nCyLMM8gxPGYicYsjMkwMBMFglzs+jNvrMCbwTX4lnsTvtPPIhSN5Uf5GF2EAwIR4PUzHryr2RDfaeh0OgwMDKCrqwt6vR4qlQoGgwEtLS04evQo9de4GUhloouvxXSZIF1Lw263w+PxoKuri+4IdjqdWLt2LWw2G4DYV7WqqgpWqxU2mw0tLS3o6emB3W5Hd3c36uvr43j29PSgo6MDVquV7tMRymWz2VBWVkb5tLS0xO1GJvd3dHTQTYR2ux1lZWXo6elBU1MTrFZrgp5OpxPl5eWw2+30HrFuQv5C+Qj/7u5uNDU1UfqOjg6qM+Frs9koXyKHuM6AmLMh0aG9vT2uLkl+U1MT1VGqjbq6umj9iu+32+1oaWlBd3c3bDYbenp64mjJvimbzYb29vY4i0u8h0r83sil5+t9jXDxeSo29gcAhTkq/F8fK0ffnzzwzABfvN8UVy68hwdwcYqlD0uAz+fjnU4n73a7pYrnDX6/nwfAj42N0byJiQn+9OnT/PT0NM9xHM9xHM/zfNw1z/N8OBzO6tlifkro6urqeIfDEVe+b98+/vjx4zTd2NjIHz58mOc4jne5XLxer+e9Xi/PcRy/b98+vru7m+c4jh8YGOAtFgt9hsVioXTkeeFwmK+rq+O7u7spf7PZzDscDt7hcND7eZ6n9xM5rVYr7/V6+YGBAUk9GxsbeZvNRtN1dXX8wMAATQv5C+UjtEeOHOE9Hg+tD5PJRGXX6/X0PlJnQr2EdeZwOPg9e/bQ59psNr65uZnK2NbWxvM8z7tcLt5sNsu20b59+6h8Qh2F9+v1et7j8dAyUq/Nzc20nlwuV1wbDwwM8Pv27Yt7lrA+5dLz8b5OT0/zvzkxyP/Zd3/Fr215kV/b8iK/qTX2t7blRf6Jn/+R3/yt/+DvaPklf0fLL/m/+ulAXHncPd/4Bf/Pr57kAfCSHqE6nS4tD9CFiNlYjpwrkLkCo9EIo9EIvV4Pnueh1+vphDOx+Ox2O/2CuN3uuHYhOgrnHiwWC6xWK/R6Pb2fwO12U0/c6upq6PV6Sc9cJZCTT46/y+WC1+uV3KiY6jlkbovwra+vp5OQwrpMtk1heHg4bu8TgVRbAIhri6amJlRVVdFnC/2NkvklpYO5el8ZAGBumA5Cu8M7FURJYQ4mPbEFhnytGlK2Nc8wAMPSSV3aaRw8eBBf//rXUwYCGRwchMPhwGOPPZapHmmDF5l34muGWViuxz6fDx6Ph76QvMhs1Ol0SSfHeJ6Hz+dDTU0NLBYLOI7Djh07EjY/SZm0JSUlVAZyPyC/fJ6OnkQuj8cjK5+YnvBtaWnBvn37UFlZSaOw8QKT2uv1wuPxYO3atZL1IQepjiCZ7GJ6cVooM4HRaITL5YLdbqeezKTj4PnE4QewMNzIAUDFMgAYgFUDXASq68VhAC/98X18+YG1uOibQYFWDe/UdFx5DCxULAswgD4v53rOdRw+fBhWqxVf+cpX8Nprr8VNho6MjKC3txf79++f9w4DSO5GTipJeA3Mjltuqh+SFJ3H40n4mor5kAk4ORqGYdDU1ETH9QzDYHh4GG63O+55wi88QVdXF/bu3Rt3P6GR+sqno6fQUpCTT4pvR0cHfD4fysvLwTAM3G43fD4f+vr6wDAMPB4PhoeHE+oAAPbu3YuBgQGaPzAwgIaGBppOtQmS8DKZTJJuA+L7peri0KFDMBgMdP7C5XLRsuHh4ThLT1yfcun5el/VZIKCYQFWjTDHICz41vzwt0OwvX0R/+4YwevvXEaYw41yhgVYFcI8g/wcDcqX5sd4Ch9w4MAB+P1+HD16FEePHqUvqclkQn19PY4cOZKVYpkiHA4jHA6DYRi6fZkXrIOTCud5XvZrJ/ef0InLhPyS0QplOHjwIKxWK8rLy9Hc3IyBgQEaUsBiscDhcMBut2NsbAw7duzA4cOH4fF40N3djdLSUvT19cHtdmP79u00REFbWxtdfqyrq6M6EbkA4MSJE9DpdHA6nTh48CAqKyvB8zy932Qyged51NfX4/jx43A6nThy5AhaWlpQVlaWoKfD4cDAwAB4nseOHTvA8zydZCW6CfkT+YT8rVYrDhw4gLVr12L79u2w2Ww4fvw4/H4/Dhw4gKeeegoHDx6kfE0mk2SdVVRUoL6+HlarFQaDAQMDA3juuedoXXo8Hmzfvj2uLkk9Cdtyz549cDgcKC0tpTrK3W8ymWC32+FyubBjxw4YjUZYrVaYTCa43W4cPHiQtnt/fz+1toTPI++K+D0SvkPi9ynZ+yr3nsq9/4RXjoqBLk8Fz3QEIY5BkZpFJMohHAV48OAQ228S5gANG/PRyGEZTERZaFQsIhyQr+bx53cvxdplRQAw+5G7ZgPPPvssnn32WUSjUZw5cwajo6MoLi4GwzCYnp7GhQsXUFZWRqMSpVvB80lLINXIJD8VXymQsr1796KlpQVVVVUZySke4imRYbb5zlc77d+/H0eOHMmIr5z+xPpQqlOytsxGf6n3KRgMYnh4GH0XeXT8dgQhDshV8YhwAMNf7zQ4HmqWdBoMIgByVAyCUQYaFtc7DQaH6+5G9cpCGI1GsFJK3GyI/TQAUD8NAmHlCHtxYqaRnj9T3wshv2S0QhmkaIXyCu8BEEcrp0uyoRmZ0/D5fIp0kpNfLJ/Uf7HMqepKTm9hXSlpS5Zl44LLZNKmhF91dTVOnjwpSyvXlnL69/X1obGxUVanaDQq25ZifqneV6XtI6ZlGAafuHMZVhmLwPEMOJ4ByzAI8ixCvAoRRo0ZXo0oo8YMr4KaZcHxDKI8g5kogwjP4PMfK8WfrbuNzrlIrp4sNGSyYS1bKOWXik6qPFWeuFyurK+vD06nE93d3XS1Il3Mhp6Z6ChOZ9qWZOhKHACTydfY2IiOjg7ZFaN0dPT5fHC73XEHjAUCAQwNDeHUqVO4ePEijfu5atUqbNmyBWvXrkVeXp5i3dJBMtnX3laE1kc24Osvvo1rE9NJ+YREc+t/vmUF6qvXQKNRg0TiXJDDEwISWHh0dJSuCkxMTODChQswmUw0EKtwVYH0utFoNKvZaDG/TOmkylPlicvlyrLVUYn8BOJQcql4KMmT0ytVW05PT8PlcuHkyZMYGRmhnUZpaSkqKipQXl4e9+OcjbaUK+M4DtPT03A6nXjjjTdw9WosdoXQciHppUuX4sEHH4TZbKbyzeX7OjMzg+HhYZSVlSE3Nxe/G7qGzl+fheO8FzNR6U4mV3V9MyTP4kvbSvGFrWuwrCj2O5ueno4PLLyQkcxEl7qWSqeLW8HSmA3rSo4Hz/O4cOEC3n33Xbz77ruYmppCQUEBNm7ciI0bN2L16tX03rm2NIQ/wFOnTuGVV17B5cuXE/iPjY3B4XBg+fLlePjhh3H33XfHDf9SIV1rCoh9xH7xi1/I7ssR4tq1a+jt7cXIyAgeffTROPeG+Xhft61ditW6XPzm7CheevsynOd84EWeGTkqFXbdfTs+fucyPLR+KXI06oQduJKWxsmTJ29a7AwhsrE0IpFI3BxIuphPSyMSiWB4eBgjIyPUpC0tLUVZWRkNwkvohdfZ6ignn8fjwSuvvAKHw0HLxWNzs9mMhx9+GEajcc4tjUgkApVKhd///vfo7e1V5HLNsiz27NmD++67j8o+25ZGIBBAT08PnE6npGWRLG02m7Fnzx4UFBRQHWf7fRVbGsCN09ImQlG8dXEcF7wBBEIxK9KYr4GpJBebV+jijlMQnrAma2nU1dXRyOQLARzH0SVX4fKSsJxAWC63hDUzM4Pp6Wnk5eUhLy8v6Wy0kAdJC2mFMojzk/Eh95w/fx4vv/wyzpw5k6D3+vXr8cgjj2DNmjWSesrpKCVnsll5IT+v14sXXngBw8PDkm3B8zyi0Sj6+/sxOjqKL3zhC3HHd8rxlaorcZsl0/HUqVPo6elRvEcjGo2ip6cHBQUFuPvuuxNkkaorsXxS74OwzOFwUAtD/O1NlXY6nSgrK8O2bdsoP7n3VUmbip8j5Ed+PyTqO8uyKMpRYVu5EQxTQh3LyMRtNBoFx3E02j2xNGg0eakKb2trg06nQ2dnJ0pKSmCxWLI+/i8dCJdcgcxMN6nxodfrxeDgIH7/+99jfHwcxcXFuO+++1BZWZn1maiZ4Pz583j++ecxOTkpWX7mzBlcunQJjz32GO04hEj15UwXPM/j1Vdfle0wxBgeHsarr76KvXv3zvpEtBChUAivvPJK2pu6OI7DK6+8gnXr1s3KaXRCBAIBvPHGG1nxeOONN1BZWYmCgoJZb0s5kOHaaGAUA1cG4B53IxAMgFWzWKpdis0lm3HP0nsS7hFCstPYs2cPAGDfvn0YHByE2WxGVVUVmpqaFAUXzhaPP/44Hn/8cTo8YRiGzoxLjaPF7tXAjcNnSNrn8+GnP/1pnNfi2NgYXnrpJbzzzjtxX0yyBEauCQ+pYyXFpq/f78ehQ4ewd+9emM1mST48zyMSieDll1/G1NRU3NdCfD01NYWXX34Zjz32GHJychL0ZBgGnZ2dCXKJ66m3N3ZIjvioTOGz3n//fbrVWwyxmU3gdDqxbds2OschtrKEsu3evRsmkynOAYnIVlxcDLvdjv3799Md1YSf2+3G5cuXM+qYLl++DLfbjU2bNsXJJ1Vn4rYktA0NDTSSPilzu924du0afU66wxMAuHr1KtxuN7Zs2UJppOQSP4N4oZJA4Hq9XvK9IH8sy9LfD8dx+I+R/8CLwy9i8OpgQn0t0SzBrrJd2GXahXtuu4feA9z4EEt2b62trXj++edRXV2NxsZGtLS0oKurC1VVVejt7cXJkyelbpszJFtyFVcSgdgcHBwclN0s5Xa7E3QS83O73XC5XLBYLGhubkZLS4sk3cDAQJxrstREHMMwOHfuHM6ePZtMbYozZ87g/PnzCfx4npeVSwgSAb6urg5NTU1xNEJ+7777btpf82g0ij/96U+SOg4PD8fJ1tramjDh6ff7aUdWU1ODtra2hDr74x//mJZMYhDfDAKlbQncCBIkLjt16lRWMon5KG1L4MYGukOHDtE8pRO+x4aP4bsnvivZYQCAN+zFz878DE87nsbA5Zj7vkqlivvdSXYaVqsVLpcL3d3d6O/vp2vROp0OZrM57Z2K2SKTGKFCTE9P480330z6jN/97neYnr6xhi3mJ3espJjOYrHE+UtIycXzPEZGRpLKIwYZMiiVSwjyEpJyclSmmN+7776blkwEp0+fltTRZrMlyCYef+t0OrS1tVH6pqamOJnC4XDW79vw8HBcqEilbUk6f2KFCN+1ixcvZiUTwaVLl1LKJUZTUxM6OzvR2tpK37Vk7z/BL12/xLOOZ8FAvnPRMBpoGA3+eO2P+NHpH+Hy5GVEo9H4E+Wkbuzu7sahQ4cSwtQBsd2KmTgRZYNMLA3hTPT09LRsKEOCiYmJuE5DzE+8sYmkU/XwcpZGKBSSuUMahF7IT61Wy8olB6vVKmlp8DyPQCCQlkwEwnoT8iXms1A2saVB0n19fXQ7vzA/HA5nHXQ3HA7H1bfStiSHfonLIpFI2u0nh2AwiHA4nFZbut1umEwmGkBISnYxpsPTeP386wjwAYT4EAo1hfjxhqfQl/t12CN/Azv//8K27Cn819LdCF0/Xe1/X/zfGLgykGBpSM5pDA8Pyy67Hj16NFkdzAmSWRpA4jwAEL+ElZeXh6KiIoyN3YiVKEZRUVGcQ5CYn9yxknJj/WTlPM+nfUI4oRfyi0Qiio67JBAflSnkx7Is8vPz05KJQMrLkVgRYtmkVpcYhsGOHTtgMBjQ1NSEV199leZrNJqsHdg0Gk1cfStpS6fTGRdOQFimVquzOuFdCK1WC41Gk1ZbEquxrq4O9fX1cDgcKd/D31/6PV6/8DpymBz8cPU3sPT0RUz85J8xeuUqDHv2wNvbC8zM4DOWHfjctlb80PAW/tcHv0D/5X58cs0n43hJWhoDAwNxLxaAtM3p2UQmloYQeXl5uP/++5M+Y9u2bXEvv5hfdXV1XKdDXJEztTTSDZ9IrD6lcokhPipTSr6NGzemJRPB5s2bJXWsqalJkE1saXR2dqK9vR0Mw8BgMCRs/9doNAnvYrog/i4EStvSbrejp6eHnggofNdWrVqVlUwEK1asSCmXEHa7nYZQJHFJpGQXw+13I8JH0L3qO8jrOIqx7z+L0JWrWHHoKXz/41NYcegpGD7/eUy/+XuM/f2T+PJbRnxl9efx2/d/C7ffnXpOo7a2FkePHsXJkyfpH4mUdDMQCoXoEQbhcDhu/Vnqv3DsSfIqKiroNnDxX1lZGSoqKpKGiK+srITJZMLx48dhtVppTEuO41BdXQ2PxwOe5+nW8H/7t3+j28ul+N1xxx1Yt25dwlhUfM3zPNavX481a9Yk8AFiZ+yWlZXBZrPhyJEj6OjooDRVVVXweDxwuVyor6/Hvn37UF5ejuPHj0uGxt+wYQO12sR/YpnIH8uyuPPOOyXboKKiIq7Ojhw5Eieb1+tFfX09ysrKKE1XV1dCXd1zzz2SMin9E7etsM7k2rKyshK7d++mx3iI6+ruu++WrBelaYItW7YkbUvyPNKWO3bsQGlpKWw2G5566qk4Gqk2JdfBUBD/UvZtBH/275g8ewZcTg6K6+vxTP4b+M3Ib9DK/Duee3AGRXv2IFxUiLF/+SE+O7wUeo0eE9MTCAaDN1wgeJEmfr8fZWVlCZGeBgcHFc/2Zwvx1vhr167RpddAIICLFy/SrfFiCE1f8gMg/30+H06ePIk333yT+mncf//9qKiogMFgiKMV8hOb1GK+yWilykh+Kj8NACgsLJT002AYhi4ri2WSk1Puv5BfV1cXTpw4obittm7dSv005PgmqyvxtVhHnucxPT2N73//+/jggw8Uy0Vw++2346//+q/pyfOp6kr8bCnZGCa2FP69732P7jXJBMuWLcPf/M3foKCgQLYtlbapUDZCS7bGl5aW4ifv/QT/5XQuLv//3wcTiYDlOCAvD7c/8R18m30Jf899GlODJ+H7+c/BRSJQT0+DXb4c6icPYKZ0BdYb1yMQCMBoNCbOaeh0OnR3d2PHjh1x+X19fRlXTroQ+2kI15mFa+hCc1E8potGo/S4A5JvNBqxfft23HfffXEeoQRy/MQmtfB/svxkfACgtLQUjY2NeOmll6hHqPBlWL9+PT71qU9h9erVkvwIndyzlfwX0qtUKuzatQvXrl1LGI6K65fIv2vXLsk2EfKVqyuptFSdabVa7Nq1C//6r/+a1pIwy7LYtWsXbeNUdSVOJ3u/CgsL8eCDD1L/F6l5mmRpAHjwwQdRWFhI86XkU9qm4ucQXgwT89N4yFCDmV8/C9X1CVw2FALUaqgYBrtMu8C6GEx0d4OJRKACwESj4N9/H/ozH0B919a4yVDJidAdO3bg4MGD6OjoAMMwaGhowHPPPSdFOi9IZr4D0pWWDOLOItkzU/FLRSdVLsxbs2YNGhsb6d4T4Y5N8d6TdPVUAjE/o9GIL37xi3jllVfgdDolVy5UKhXMZjN27doVt/dETke5PLn2k7p3y5Yt2LNnT9p7T4TmfzZtKVVWVVWF4eFhRZvVxKiqqso4qLMUUul4+6UALv7uTUAwgWvYswe+n/0bNnzwAXy33w7Dnj0Yu+7ERhA6/Q70//Xzcb87yU7jmWeeQW1tLVpbWwHEJkZbW1vjnEnmE5nscs3WLVfpjzIVnVS5OE+tVmPt2rVYu3at7FdD6t7ZcD2Wks9oNOJzn/scHnjgAbz33nt45513EAgEkJ+fj02bNmHDhg3zusuVePbed999KCgokN3lSrB8+XLs2rULW7ZsSatzTUYrVZafn4/PfOYzYBgmrY6jqqoKjz76aNxq1Zy/r9PXg2GIOtzIpUsInT8P8Dy069YllEevH6wlhGSnUVZWFjc82bFjh+JlPZ/PF+dGTSDlgq0Uwi+L1OY0qR+a1Bg5HcyXpSGVl+4XORvIyU+soDVr1mDnzp1J42lkoqMSvaTo7rnnHqxfvx5utxuDg4MJ1hmZsE62fJ5uXSQrKyoqwu7du1FaWorf/va3uHLliiz/ZcuW4YEHHqDxNOTmvzJBKh2ZXC0YADxZRbru7Ka+vnpD/ovL2fyCBMtOstOQOsdB6dkOYjdq4IbbbmNjIywWS8KpVKkgteQajUYRvB5KSOpFy3ar8a3QaczG1vi5+kHNZqch1pNhGJSXl6O8vJyuqInDQc7MzMy6jhqNJqHTZBgG+fn5ePDBB1FVVUUjd126dAnBYBBarRYrVqxIGbkr204jlW45ZWXQ3n03+NOnaQQNb28vDHv2xCyM62lW4LTGANBu2JDgJyP5xhkMBuzdu5ceUtPf34+9e/cqEt5iscSFzgeUu8cGg0HaEQCgxyiInbs4jsO5c+dontwPLZtx/63QaWSroxL5ldDNh6Vxs9uS52PLy6tWraKTl+J78vPzcdddd+Guu+4Cy7J0OzqQGEOEYK7mpsTQrlyJok9+EoHrK6DMzAwQCMD7k5/E0XG5uWAAsDMzYAoLkXfPPQnzWrK7XE0mE93ZR8LiZwrxITVyQ51Dhw7hiSeeSMifmJgAy7LQ6XSYmppCJBKBwWDA0qVLZ63S5wOzNaSYL74LEenoOpu0PM9jdHQUFy5cwLrrX2ZyH7H6ANBl00gkQsvIh46kxQGHhIGOiH8FGQqSH6y401GpVJK0ZOkWiFloJC7G5OQkwps3gd+8GezJk5i57pymnpgAGw4jdN1RLGd0FJGiQoSWLIH+0UdR+LF7qQ8SCcYja9tWVlbGdRQjIyMZHwKt1D22tbUVX/3qV2l6fHwcq1evRlFREd22npeXB5ZlodfrqZ/GQv06yZUvWhq3pqVhNBoxOTmJqakp+u4li0YG3NgzJGdpZBppTrgBT+q5QCzmB8uy0Gq1UKvVKLzvPminpnDtmWeQN3Iu7v686/uOorm5UE9MQn/vx1DyyMMAYvM2wI09RrJSHjt2LO5EKpvNRi2PdFFdXR13r9xSk1arlXTYElaEWq2GSqUCz/OztmkoHbz44ovweDzw+/1xHdxHDR/FeohEIohEIrh48WJCTBCpjjBZmoDkCy2ETCDX4RUXF8d1RvpPfAJqtRpTNjvGf/Ur8IK5HwDIuf126P/LZ1C8cydyr29dULR60tDQEHcYLoC4o+iSgcQfIDCbzTCbzRgYGKBxHch5mEohXj1hmJjDD9k0JPV1motGcDqdWL9+PcxmM3bu3InW1tabamlkq6OcLKnoxPVw8ODBtHVMptd8tGW6dGTooFarsXLlSvpxIyY7cT5UmiYg+WRJO1OIn0P0EG+s4zgO+du2QffQQyh65GEE3z6N6HQADMtCvXQZ1OZK5JlMcXwUrZ7s3buXRu8iGBwcVCS8xWKRPGxYeNJ2uhA2IrkWLv9JvWjAjR7SFwjhvcsT8AdC0OXnYMPyIujzk+9SJMf7CfmROBRutxvl5eVxB/EI6To6OuhmohMnTqC1tZUOr8jeEKPRCIZhaHCcsrIyuN1u7N+/H3q9Hg0NDfB6vXTViUTjEj8vnR9TxOdD8MwZRMfHoSouhnb9eqiu762Q+0F1dHTQA4EInVQ9iHm4XC7ambS1tcFoNKK5uRkOhwOdnZ0wm80pO43BwUHs27cP/f39895pOJ1O7Nu3jx4RSSZCyQeLhA8kX/F0/xOQtEqlkj23RQnk+IshrIOibdtQtG1bXLl42CO+B0iyekL2ZhAMDw9nNRk63yBfpzOXJ2D9jRu+wI2hjKEgB40PmrB+eZHs/cmifNntdtkNfMTKqqurA4C4fRxNTU2or6+nPjAMEzvoWRjspba2FjqdLq7Dqq2txfHjx2V1VIKZs2cx9i8/BCdYOmeNRpT8xZfokpsUksV0SFYPJpMJ1dXVYBiG+uTU19cDkB+eimE2m6nH6XzF0BQ/e74wOTl5U+LUZgJZP43S0lJ6bADPx6JU7969e16FIxCOA6Wu5SwNXyCU0GEAgHcqhI433PjmpzYmtTjEE3Butxv19fUwmUzo7u6GzWZLeK5er4fVakV1dTXMZjMOHjwInU4Ht9uNo0ePwmq1xrldt7S0wGg0JuglfHZlZSWsViv279+v+KspRMTnS+gwAIDzeDD2wx9hWfMBaFK8sMLniutBGP9CTC/Fg6C9vR1lZWVwOBzU25hhGJrPsmzcvFp7eztMJhP6+/tpZ+V0OukB0T6fD/39/dRVwO1208Oqn376aZSXlyfcu2/fPrS1tdEdtoQOQNyzSZuk0inddKY44zkD51UnLk1eAg8eRo0Rm0o24d5V9ya9L9Xzlego2Wn09/fD4XDQnpbneRw+fDjpw+YSZLlH2DkIFZHzEn3vgwl4A0HE3FT4uP+eqSDe+2AC95qM9Afa3t5O+Qh9TcrKyugW7v7+fiqHWAaGicXJOHz4MFpaWjAwMICDBw/iwIEDcLlcccFryT0kToaUXuQZxJNWrKdQDvFqijAveOYMol6PZD1EvR4Ez56FuqYmgQ/hLZ5TEteDWF5h59Hf34+jR4+CYRh6Ni+pq8rKSlgsFjrfZbFYqEVFLK1Dhw7RYWBFRQVqa2tx4sQJ2Gw27NixA5WVldDr9TAYDNi+fTtaWlrQ2NiIsrIyfPKTn8TXvvY1ALGOV+peIGZVCKNg7d69mz5b3M6kPogPBjkZLRwOxwW4Jsuf5Fp4RIBwRyu5jwSNFtISfsI2ZVkWLw29hOdPP4/Lk5cR4kPIYXIAHtBpdGjY2IBHyh7BbQW30fuFchK+5PdE5sZImVhesU6ATKdRW1ubEOrv61//uhTpnEB8hIHUWRjkWvx1i7M0ppOvrojLDxw4EPdD+NrXvhY3byGFhGf6fHReh+djJ5U7HA5UV1fHxaJkGAY9PT1obW1FY2Mjvva1r8nq4vf745zjhD9qJYiKwu4llCvcIpAMUsuiPM+jurqadgDFxcV0VyhwY57M5/NRXex2O6qrqyU7wMHBQTAMIzlkInMker0+oXMGQIMDS91LQgzabDZqpSgF+VHLLakK/TDEadIJANJzCVL4lftXaDvRhiluKtZZXIeKUWE6Mo0jp44gGAniy5u/jDxtovepOLK4VLmUDkLIhvt75plnYDKZqI9FV1dXxkuu6UK8NT4nJ4dOEmk0GtpDiidCST4QaxB9fo4giGrif31+Ttw94v/Ck7cJDh48iJqaGng8HhiNRjphTGhee+01mEwmGqWqtrYWPp8PBoMBjY2N6O3tpfc0NDSgs7MTtbW1CdvLhc+22+04evRoXLwFoaxiucW6qHQ62XrgwUAtissp5i014SusB4PBQDsGsQzCdhL+J9HDamtrcfLkSYyPj2NwcBBbt26Fy+WKO36C53n09vbS+hwcHITf78fJkyclo24Jr1mWRXd3t+y9RqORyrV161a43e6ETZHi90sYqoFMiJJ7yKoKy7LUAYu4n5M8IYSdDaER5gvpz/vO44X3XsAEF4t3y6pZfK78cwCAn7t+jsnwJDhw+OG7P8Rdy+7CJ+74RIJHqlhe4TOIVSGUV6iTrHOX3+/H4cOHYbFYMDQ0RPMz2f47W8gkRigAbFheBENBDrxTiRaHsSC2ipIM4q+n3W5HTU0NneTs6emRnNOw2+0YGIiFf/d6vThw4ACA2CpCR0cHrFYrfVnr6+uh1+vB87EQ9jabDTqdDgaDAT6fDy6XC88991xcBCmxnqmgXb8erNEITjBGJ1AbDMgRTYRKDdN4PhbhrKGhIaEejh49mlBXLpcLNpuNhvAzGo3o7u6mp5KZzWYcP34cNpsNer0eNpsNzc3NqKurQ1tbG2w2G8bHx+F2u9HX1wez2QybzQa73U7pW1pa4Ha74fP5YLfbYTKZ6ASt0Wikw57KykrJe51OJ9xuN3p6elBXV4c9e/bg6aefht1up6fCk2GT3JyG2GNTaZognQlex1UH3vXEIsbna/Lx5P1PoutPsQ/5E/c+gSf/80l4w16E+TBOjZ7CJ+74REp5lZQrOsu1r68vIQjP4ODgvK+eEEvD6/VSn5FAIICRkRGYTCZFHqFnLk+g4w13XMcht3oi/LEI+ZlMJtTV1dExr1zAWSnMpZ+G1JBADjNnz2Lshz+K6zhYoxElX/4LaK9vyU8G4XPF9ZCJjqn0EtOl00kmkz1TOp6PHec5MjISdzZqKo9QyfTkKHDlLSAyA7ZoObCqSpGOzw4+iyOnjgAAPr/h8xjyDaH/SmyeaOuyrSjXl+Onf/opAOCBFQ/gudrEGDhSnqOpykne5OSk/FmuO3bsoL18RUUFRkZGbupyayaWBonctX55Eb75qY2K/DRIlGdA+QHQN7PTIDoqQe66dbit+UCCnwZbXKzohU31g0pXx2R6ybVlppitTiNrS2N6AtG3XwTe+QVQuARRdRFyve8CSzdg3PRp6DY+lFw+JD6fQAUVWD611TIbloZkS/T29sJqtYJhGLz66qvgeR7Hjh27aUuumQThEUKfn4OPmUrSeqYUv+rqahw9epQ6b5lMppSdqRSfVHnicqV6poJar4d669a4PKWTqcLniuuhrKwswfdCid5yemWjoxSU8ktGJ56vIRD/+GTToWngxHN4W3U3Ttz+Dfx2eALToShMSxtwf7EaFUN26LQMYPq4rAy35d9Gr190vYgn73+Spnev243v/OE7NG3SScerSfURlCpX5Ebu9Xpx/PhxGhe0rKxMsUfoXCCTIDzZvnhSXx29Xp/g2SoV6i4Vn9myNGbjx5XJV1hcD8Ldlsn4ZmppzEVbpksnZ2mIVyNk08Ov4/W8nXjytcu4MnEOq/U5uOALwReYwYsng/iCeRv2XbmIFaumgRzpmBvmpWaUFZdheHwYgXAA33zzm/hs+WcBAP/wh39AKBwbgqsYFSqWVkjyULJ6Ii5XtHpCIKy8+T6KUQiyLi58oYQNmKwjkfI9EM8HSJUJ+SWjFcogxVeOj/Aesa7ie+TK5HSU00lOf7F8yepDrGcqHZXonUzHZHoqbdNkOgppleoo9NOIRCJxfhpC8550ptFoFEPBZTj86yu4NjGDH2zz487gKYwaKrDU+wa+cfkh/OKtq1iiuxON7jehWv8JST+NNUVr8MWNX8T/OPE/MM1Pg4tw+Nl7P6N+GmqowYFD3bo6VJRUUF8RoZ9GJBJJ6qdB5BX6aQj9N4AkbuQ7d+6EwWCA0+mkZ2zOF8R+Gpkg23HwrYCPgo7Ah0PPE2NaXPJPgwEwpl2N50PrMPo+h3tXrsfZs2NYmhdFt/MD7Fy9HOVJ+Px56Z8jEonA+rYVU6GpuDINq8Hudbvx2bWfhT5PP2e6pAzCMzQ0hMOHD8/rRGiyIwykTFah15qwXGjCy/2XKxPyS0ZLvkJSm7bk+IjvEeeJ7xEHbRHrp1SnZPKnqivxxHCqupLiK9Zbakgip7+StpTTX0o+KVq5thTzEL6PpDMjaaF5TywQtVqNt64GMRMFtCrgvWk9ftR/AQDw+rAWTdvW4IXfDeH9yRm8N5WHdQIfCfEwQqPR4HN3fQ53Lr0Tp66dwsj4CMJcGKvyV2GjcSO2rdwWt/FN7KchlldMQ+QV+mmIhyzzEoQnW2QyETrn0Z0V0kmVp8oTl8uVzcYmrtnQMxMdxemF3pbijweB0onQUDTWIUU5wBMEojwDHgy8gTAmIyzGroe1iEDZTlfzbWaYb7sx+Uys8lTn3s7ZRCgwu0F4skUmE6HZQo5fT08PPB4PfD4f3QyV7LlzORE6G8h0klBYD2R/Rzo6itMLUUdxWTYToaYlsbiirZ9eBV2+GkPX9Dg3No2dd63Av504Bw0L5OVosHKJLm39pJ6bKV3GE6HZBOGZCyQ7AFrqGhBtGw94gaungWkvkGcAlm0G8g1Jnyn14jidTuroVVtbi+bm5ptqaaS7ZdwX9GHIOwR/0A+dVoe1hrXQ5Sh7SYXPFdcD8XiVo5fLU2ppZLs1fi4tDfGPTy79Z+sNWLEmgp8P/SPeOvs2qlfdjy9XbcdKA4d3L+Zh1BvCvRtXYWtZeq4Bcs/NlE6qXFE08myC8MwFMnUjBwBcfQd48/tA4MZp3MgvAe7/K2DZJtlnSgXhIb4IbrebxohI9nWy2+0YGhpCY2Oj5BeXBJlxOBxzbmmc9Z7Fj07/CP6gn+bptXp8adOXUK4vl+UnFYRHXA9SMpEgPAzDoK2tDSaTCQ6HA01NTWhtbUVdXd28WBpk6/zZs2fnxNJQ6tx1ZvrXeOrEU9Cp9fj8+s8DAH5y5p8wxU3iW7XfRq+tAJ81Z34SfSqnLaV0Spy7JO8kQXiEGB4eTirMXIOcGk8gbGDx9mGej+0e5AMe8L/7J/CB0Vg+rp8kHhgF/+b3Y+W89KnuRF9hPs/zGBoags1mo9umhTKIaY8fP46nn346gQ9BRUVFXCwNKV2SDc3IRjKpZwvzfDM+/OjtH8EX9MXVgzfoxY9P/xjjwXHZevB6vQkyiOtBLC/Px7bz19TUoLq6GqWlpeB5HgMDAxgYGMDu3bsTljGT6S+np9x/4TU5uV4snxStXFuK650suZIdoQzDIBwO0yVLsmxJljXdHjd++t5Podfo8c2PfQMj/mG4/S78+/YX8JXVX8Ivh36OlkfLUX2HgfIl/Mh7T853IXlCGchGMo7jUtISXQhfMQ3RXyiDUCdAptMgQXjWrVuHdevWYe3atdi3b58U6Zzg2WefxaZNm+g2ZWFPJ2xgYe8v/hJwHAdceSfewhBiajRWngTiL4vb7cbevXtht9vR0NAg+VwCn8+H6upq6PV6GjKOoL29HT09PXRegPAh+S0tLZSn0+nEunXrYLfb0dPTg4MHD9J7hXtlkuGs9yx8QZ9kmTfoxRnfGUV8CMT1IFcHJM/n86G9vR379u2L06umpiaOh9Vqhd1uh9VqpcNhsf5CnZ9++mn09PTQjhmIWUaknsg2eCIf2Zzm8/novYQfkcdms9G2VYJoNJpgCYvT7429h/Pj5/Hpsk/j52d+jneuncbpa2/j70624dHLt+Fw4GEEAh8ofqYSOTKlkyoX5y3IIDziJVeNRhO3xEXGl8m2xgMAM+MFSJpkC/9fLyf3CF8+simLYW5sWCsvL0/oAKSW54DY8KaxsRFerxednZ2oqakBw8Q2ezEMg/r6emq6E13MZjNqa2sxMDCA1157DbW1tbTjKSkpocGMm5qaUF5eDovFQocAwmeL5RkPjd8oE9UDz/C0XGoJk8gm/BKL60FY92IZ3G43nn/+eXR0dNC9PQzDoKqqCgBQU1ODrVu34tixY1RHnuexc+dO2Gw2VFdXQ6fToaSkBLW1taitrUVLSws6OjpgMBhQX18Pp9OJ3t5eGqzIarXCYDBgeHiYhihgWRYdHR2ora1Fd3d33L3Hjh2jO3aJPOL6EOooXHIlmybJuJ8E8iVLrtFoFJyKAwcO9UssOOQ/ginE/CvCTBicyw3v//opln/zW2DvvD/p1ngC8TKqcHlUbk5FvM1dap6QOHKJl1yJTknPPbnZQXjEyNiNPC/5ZKe4XLhhjed5HDhwIOMNaw6Hg26d7+zsREdHB4DYKlRVVeKuRp7n4wLFiL/cZPlbr9cntE0q6LRJJjt5oDinWL5cIB8gP94Xlwnlb25uhl6vR319PY3iRWW77odjs9noD5fn+biVO+E8Csl3OBwoLy+P23F76NAh2hkJdyJ7PB40NTVh586dsFgstNOV2rVM5JHSMdPVk/LicizLW4aCE+/gqZLd+M6yHGxbtQ2P4G4E3n4F0OZi8sVjmK4yI2/9+oRnKMFNXz252UF4xFAyyy65tr9sc2zSU2qIkr8kVq7wuQQtLS2SQXiEcDqdaGpqotGk+vr6aMyGmpoauFyuBN4kopXFYoHD4YDf76dxJ+R0VTpRuNawFnqtXnKIYsw1Yr0h9YsqfpawHkgQHil6EnGssbERNpsNvb29NMAwicgOxE5SHxwcxM6dOxXpVVtbC7fbTX/wJDK6MDIXOdnPaDTCarVi586d1JoT30vo5J4tt3qSbEWIpDct3YS/rvhrhP/lP+F9/XU88cR34Pufvbhy6QXkLFsGw5498PzsZ5h5552MO43ZWCGSK0/4bYkJSBCeoaEhHD9+HEePHsXx48dvahCeTBCNRmPLqvf/VazjEIKsnqRYdhVDGHxG7kgGp9OJlpaWuDyDwYBDhw7B6XTSHxcZo5NAL2azGS6XKy5QjF6vjwsy43a7Kb3T6aRBZlJBr9XjS5u/BL1Wn5D/3zb/twRLpL29nf7ZbDZ6TaJtKakHt9uNgYEB9Pf3031LDQ0NaGxsREdHR1wAHODGERd2ux0dHR3UMpPTXxgIiey2bWxsxNjYGJ3XIO3hdrvhdAxg3//9F9izpw4rV64AouG4e4XyhKIheGe8GJ0exURoQtLCSBcPLH8gdhEIYNo5CEbEM7h8edbPmC/cEkF4RkdHaWT0iYkJXLhwASaTiY61hK7HwpiLdL+CQj+NTILwZBPURC4vWSAX4XW6R/lJ+WkUa4qTyi8ln7geMtExmV5J2zIDcNEwJmYi8M9E4Z8OI1ejQnGuGoZcBjmCOJocx2EqPIVr09cQjAah1+rhD/lh0Bpg1BoRDoVx7ty5uCA86RyWNPbjH+PSP/4jkJcP/aOPAgDUHAdfby/CGzdi3d99C3l33pmRjlKHJWVCJ1VO8qanp5MH4RHjZgbhydqNPN8AlD6Q8jniOQ0pvmLcTOeudB2e9Fo9qpdXx+Up/YqmcnzKJC+toWYWmA5F4QuEoM9loWJyoFYBhWwI3hktbtNEAfb6/APPwTvjRZ46D0vylmAiNIEVBSvw/uT70LAa5DGJW9YVx9MAkFezFQWVZkyfOIHxF16IlUejgEqFZZ96JOMOQ+q5mdJl5Ua+kBAOh+kaciQSiVtfF06CEt8Fck3+hLPf4v+EVlwm5Efyq6qq0NXVBZfLBYPBgPLyclRUVCTlK8VHahu9nC5S/gzCMikd5XSS+y+WT64+CF9xPZBgRGIeqfQWL5HL6a+0LeX0D4Q5FGo1uDIVQTgaAs8zYIpy4A2EoMtlkaOJzVcEwgHkqHIQjAYxGZ5EJBpBmAvDoDVgOjyNXHVunJ+GSqVCMBikAYRZlqXnC5MjCTgudixBbm4uNOvWQv//fAXqykpM9fUhOjEB7YYN0O3YAeYTD1HaVEcYiLe7kyVRjuOo9S1HGwwG4/iSdqErPQJ5iQxEp6Rb4282xFvjhTO5LHsjSjVRWrwSAcyN6zEJPpPqh5WKl9xXWE4XOX7Z6phMnmSQq4dUfIU6StEma8swH0Y4GoaG1SBHlfxITSneWoZHUa4agAoAg2iUR2k+C04gynW3N0keHDjJfLK0SnRK5VZeVFGBgi1bEPrUI+AmJ6FZtQpavT5utSgTqFQqRe2oUqmSvjNK3Mgl5zQWCqTmNCYnJ3H+/HmUlZXFhYuf9XFwirkKpXQLaU4jE/mV0CXTZyYUwlSIB8fz0KoZFOawUGu0Cfcl098b8MIT9CBfk4+p0BQMeQbotXqoWGX7LcKTk+BDIfD+cfDhEBhNDrjly6GeGAdbsgQqVew5M+EZXJq8hDxNHgo0BZgITaAopwjvT76PJXlLkM/n03cvkzkNYZqA5Hu93qyOZbwpcxrPPPMM3a240CDs6bRaLViWxbVr17BkyZKEr5fQlFN6AI0UlM5ppKJL5sMglyeli1RZMh2j0QjCUQ4swyAnyYs0G3rK6ROYCUHDRcCABccBbJTD6IwKutwIGMHXWUovcj0ZmsTVwFUsy1+GqeAU9Bo9pgJTiIaiKNam9i8BgEggAG5mBvzMNPhwGEw0CubaVYR5HjnhEMjvmOd5FLKFuDZxDR54UJRThAuTF5CrzoU6osaYbwwMw0jGosg0TUCOqMgUN2XD2pEjR+j5G+Jxoclkwvbt2xUJNRcQu7UuX74cly9fxsjICIDrPvccD5YBNNe/vNma7pn8mCKRKMIcDwYAywA5GvWcdhpyOs6EIlBzUTDRCMCyCKs0yFGzkrRz1mlwHCKhMEJgEOERC0enYqDlo7isUkGr0SjqNCZCE+A5Hh7eg1A0BBWrgopRIV+Tjzy1dCxNMbhQCNxMEAgFwUejYFQqMH4/wLJQBQIJeoSiIYS5MCb5SahYFaJsFEE2CIZhsHr16rgf0WydezI5ORl34Hq6mM8Na7TTaGtrk3RUAmLOXtlGI+/o6KBuvnV1dXQTkRKIV0+KiopQVFSEmZkZvO36AGvedyHs9YDJy4NvVTlWmm5HOBLNqvdWGtSE0J0euYxVVy8gsnIlIlEeelUYZ4Ia3L329gQ+UryFeeJyuTK/35+g45nzl7HCdw4Xb1uD9yejyGdZrJscwYWiO1BdvjJrPaXopMq8o1cR+d0fcKrcjA0//WdErl0Fe9tyMF/4C0xqC1B2x+2yegmvX3jnBUQDUZydOYt3Rt/B0vylWJq/FLtKd+GBValXxIh84zYbwu9fAjErwh98AENDA/IF3rWpdNRoNHSikSCd1ROptPjZmeKmrJ7IdRhALBp5Ns5dbrcbLpcLjY2NsFgsqK+vR3d3t+L7pdzINRoN3jp3FWsvv4szZZUYLpqBoUCFLf73cOZyMTatNtBxZyZIZ4wYDYWx2nMFo3eYUPTd74C7dAnjK1bgruYDcH8whg133C45RpTLSzYuFl6HQqEEHafCKgRuX4OSQ/8A3aVLUK9YgeG//Q42XhlG7pbE6JOzMRaWKisxlmBsagrGwlyofD7w10bB5OWjIBxATtFS5ObmyuolvC4rKcM/nf0nPH7v49DmavHQqofguOLAFD+luH3D4TCMDz+M0B/+E8Ghs1DpdMj99KeQt3Zt2jqKoTQIjzhNQPKVDi/kcNPdyKXg9XqVkibAbrfHHWAsF9k8GAwiGAzSNNmeL7eGXxDlcGXlRqxo+zuUXL0K9e23Y/i/fwsbRs+jcOPqjOUVPycV3bmrYzC4XRjKW4G7L11C6Nw5AMBUhMelmRA2Klw9kSuXKyssLEzgo8thEApzUAnkCIejYKcmwHMcGNFXIx090yljc7RQ33knVnT+f/A2/x0mAhGUqibAvPcnLL9rc1K9hNc77tgB34wPHc4OVK2swvf6v4e6jXWwrLnhYKdEdpVKhaKP/xmKPv5ns6ajVH66aQKptkwHs9GOcuXiPNppPP/883jsscckGb322mtx57qmC7IHQJiWwqFDh/DEE08k5Pv9fjAMA51Oh4mJCUSj0diEKKIIzATB6PXA+DiQk4PgzCQmQkGwXi80Gg1dny4sLIT/+unpubm5YBgG09PTAIDi4mIEAgEajr6oqIjKWFBQAJZlEbg+9iXDIhKyvqCgAGw0iMnCQuSxEeCOOxBZtgxYsgQsw0HNh+Dz+aBWq6HX6+H1eqn8ubm5mJycBADk5eXRGAccx9E9PzzPQ6VSIScnh+peUFCAUCiEa9euobi4GAaDAX6/PxY7IxjARn4KH2zahMiyZcjJy0O5dhLXlt0Otd8PvV6P8fFxcBwHtVoNrVaL8fFxqFQq5Ofng+M4zMzEAlbqdDpMTk4iGo2CYRjk5+fTj0deXmw+YXp6GtFoFMXFxZiYmKB1mJeXB+bO9cAnd8H4Ug/0436ENt8FbssWqLS5mJiYoD4ORFdS3wAwNTVF2+K+ovuwoWoDrs5cxWfXfRbLmGUIBUJgogzUajWmpmK7RgsLCxEKhRAKhcAwTNL6LiwsRDgcph8pEkOG4zjk5eUhJyeH0pL6npmZofISWpZlkZsb04e8WyRGBXlfSJmwvgEgPz8f4XAYMzMzGB8fx+rVq2l9i99ZYX1LvbN5eXnw+/1QqVTIzc2VfWdJmrRjbm4uVCoVrcP8/HwEg0Ha5nq9Hn6/P27SnS65Go1GuqwpBNnY8+qrryaUKUVHRweNqQnENjFJhQ+UsjRWr14dt+QqNCF/95Yba6+8jXeWV+Ls1SksLVTjnhk3PMb1KF+pm9clrLN//BPyJ87DVXIXZsJRbNDxKDh3AZqKzSgu1s3J8ERqmY7nebgHT2MpE0FoegbaHDVm/BOYvnMD1qy6PWs9lQ5PlOQpGZ4AC2M5Uq7sI73k2tDQQHcfCmEymdLeii1GdXV13A5Z8RF+BFqtlvpeCCEXI/S+zaUY5Djcfe4t3DU5Cc6rwuTKMpSvKKY9c6ZIdwlrxdqVuDisxj0jfwQ3PYNgWTk8ZSZsMBgV8ZbTMVmZlI4Mw6DcfBfeO3cJUUaNcCSEjZvvwtI86fH/bCzVKVmmk8qT00tMN99tmU7ZbC25LgQd5cpll1ybmprmbH+J2WymOzLdbjc6OzvTul8qRigJGLJl0x14f0kh3FcnUFKowT3rSgGAmtiZIt0lLL3eAH2lAVPrVyMSiWKZLrZ8RnppqSUsubxky3ZK5dpwx4pUKsrKki5dKn3k8uT0UiqTUsyVjlL5mS65Zov5XHK9JTxCvV4vnRNR7EWYpbl3K3iEZqujEvmV0M31LteF0JZyZcl0SpYmWEg6ypWTvMnJyViQIuENDQ0NKCkpwd69ezMUfW4gF4NR7nq2njlfMRfFecniTi5EPTPRUZy+FXWUyleaXog6ypWL86ilsX//fuj1etTU1NBgJ88991ymOswKsrE0yAx0prgVLI1sdVQivxK6ubY0FkJbzrWlsRB0lCsXWxp0TqO8vDzu0BthkN2bjVAoFLc1nuM45Obm0iUw8qKRpTWe5zExMYHi4mLJbcSEPtmWYyG/ZLRCGaT4El5kKY7cw7Is3ZnIMAxdfhTqQu6JRmNh5NVqdRw///UlVKU6SekfDofB8zzVU442EolQfwcldSVsJ6HewroSbiOX0p/wm5qaQmFhoWKdxPpLbfeWohXKkEx/4bOT6ST1bFJfLMvSNmVZNq4t53JrvNS7J9WWirbGC/0oAKTl5j3bEG+NF/Z64muSJo1AkM1mNSl+yeiS9e5SZVL3JNNFmE42QZUJ0tFTzjFIiocSvW+ltpTTP5lOUs+W0zHbtkxlYQjpUr2vqdqSdhqpPNeSOX/NNpKdGh+JRKjiZFu4Wq2m28SJiafVaulXAYhvLCB1aHghv2S0Qhmk+ArlJc8W3wPc2Cwl1IXcQ340pIzkkx2/SnVKpn+quhLKoKSulOgtjEEhpT/hl5OTE1dX6bapuD7laIUypNJfiU5Szyb1QkDuE7dlum1K+IpDJYhppd49qbYUyiKOFULnNFiWjXP1Hhsbow5VPM9jeHh4VidulEAqnoZSh6Bsd7nOh7NMts5d2eqoRH4ldHPt3LUQ2nKunbsWgo5y5bLOXY2NjWhqapJkxPM8jQ59M5DMpJW6BmKu59ksYaVj7qVbnipPysSVus5WRzlZ0qXLREdxeqG3ZbJhSzZpgoWgo1y57PAklXOXXIcylyBmEfGpB5R/nch+ikxxK1ga2eqoRH4ldHNtaSyEtpxrS2Mh6ChXLrQ0gBTOXSMjIygtLVUo9uzj4sWLWL06u92qi1jEImYXtNPo7OykO+rMZjO2b9+O3t5euq2d5M0nOI7DpUuXsH37dgwMDND8mpoa9Pf3y16TjW4XLlzIKhqSkHc2dFLlqfLE5eKyvr6+WdFRifxK6DLRUZxe6G0pV5ZMp2TphaijXHlNTQ1OnDiBiYmJG8MTcsZle3s7KioqKLHL5Yo7wm4+wbIsVq1aBbVaHVeZKpWKpuWugdj24WwaQcwvUzqp8lR54nK5smx1VCK/ErpMdBSnF3pbypUl0ylZeiHqKFeuUqmg0+niJ0L7+vpw/PjxBAYk79ixY3GdyXzi8ccfl03LXc/FczOlkypPladU59nAbOiZiY7i9K2oo1S+0vRC1FGuXJhHhye9vb0JIf+EMSizjRE6nyBLtX6/P+uv8ELFR0FH4KOh562mI11LkQrnJwxam+1hLvMJrVaLb3/725KxOT4s+CjoCHw09LzVdKSWxsGDB/GNb3wDRUVFCUTj4+N46qmncPjw4XkXcBGLWMTCArU0WltbUVlZiR/84Ac0huH4+DiOHTuGqqoq7N+//6YJORuora1FU1MTPfH8w4ienh7Y7Xa0t7ffbFHmDG63G+Xl5aivr0d9fb1skOpbHaQte3p6brYoieAF8Hq9fG1tLc8wDM+yLM+yLL927Vre6XTytzpsNtvNFmFO4XA4+La2Nt7lcvFer/dmizNncDgc9Lq7u/smSjJ38Hq9fF1dHe/1evm2trabLU4C4vxD9Xo9jh8/Dq/Xi4GBAQwNDeHs2bNzFgYwG/h8PrS0tCScx9LR0UG/tsKvkM/ng91uv6nu8OkiHR0HBgYwNjYGAGhpaZl3WbNBOnqS+LIdHR2oq6ubd1kzRTo66vV6mEwmVFVVJew+XwiQdETX6XSorKzMOqDwXGJgYCDhKARyKJPFYkFzczP98TidTpjNZlgslrQOabrZSEdHo9GImpoamEwmeDwe2WMiFiLS0ROI/QClotkvZKSjY09PD5qamuByueBwOG6CtMmR3RbJmwiLxZLQC8sdymQ2m+F2u2G32yUjri9UpKNjXV0d3G43enp6UFNTsyC/UHJIR09yLSy7FZDu+2q322G321FVVTWfYiqC4hPWbgUkO5TpZni0zgWS6UjOlfkwIJmeZrNZ9hiMWwlyOppMJjQ2Nt4coRTglrU0pCA8qevDio+CjsBHQ89bVccPVadRXV1NJwMB+UOZbmV8FHQEPhp63qo63rLDE7vdHjcTTUzWbA5lWmj4KOgIfDT0/DDpuKAPS1rEIhax8PChGp4sYhGLmHssdhqLWMQi0sJip7GIRSwiLSx2GotYxCLSwmKnsYhFLCItLHYai1jEItLCYqfxEQDZ2evz+W6pXb6LWJhY7DQ+5LDb7fQwb7vdjurq6pssUfYQO0otYn6x2Gl8yGGz2ehmvf7+/pSuypnshUjnntnYa9HW1javz1tEPG5ZN/JFzD5I6IDGxkZ6YE55eTndcdnR0QGTyQSbzYba2lpYLBZ6T2dnJ2w2G6qqqtDY2ChL29TUhJaWFlpGtvH7fD50dXXFxTvp6emhAa2NRiPq6upgt9vh8XjQ1dWFgYEBKpscrVg2IofJZILT6YTFYrll9nwsGNzs0GGLmF14vV6+ubmZ/pnN5oRrq9Uqe39dXV1cGD2z2UxD7JlMJpqv1+vj7rFarbzX601J29jYSEPYuVwuXq/X0/CEjY2N9NkOh4O3WCz0PovFQunq6uriwv6lohXK1tzcTO91uVxxfBahDIuWxocMer2emu92ux179+6F2Wym0aDI/EYyCGksFgusViusVitcLhd8Pp9kMN/q6mro9Xr61U5GS/gbjUYYjUYaU0Kv11NroaurC3q9Pi4QtNvtlrQKUtEKZdPr9aiqqkJ1dTW1qhaRHhbnND7EsNls9IfT39+vqMMQo6SkhP6oW1pa4PF4YDabYTQak96XjFZJVDGfz4eamhpYLBZYLJY4XYQ0brdbES2B0WjE8PAwmpqa0N3dvbialAEWO40PGUgA25aWFtjtdsnrVEccCK2Drq4u7N27Fx0dHfD5fLTjIT9WqSMhUtEqmZxsamqCzWaLk0kol8fjoelUtEIcOnQIer0edXV16O7uvuVijS4ELG6N/5CC+GQ0NzfT+KhKTPH6+nqYTCbU1tbC6XTCZDLR+KMtLS1oamqCz+ejp4rfd999+Nu//VtYLBY6wSlH+/DDD+Mv//IvYTab0dnZiUOHDqGjowOdnZ0wmUzYt28fTCYT2traYDKZ0NPTA7fbTTsfEn3c6XTCarWivLychjiUoiUTr0LZ2tvbabRvt9uNhoaGWyqe6kLAYqfxIUVPTw9MJhPMZjM6OjpgsVgUDU/q6+vR2tq6uKKwCFksDk8+pBD6ZLhcrrTmM26lc3sXMf9Y7DQ+pCgpKZG8Tgbiadnd3b3oFLUIWSwOTxaxiEWkhf8Db2gTUk6IQLgAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 275x137.5 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "from tueplots import bundles, figsizes\n",
    "import matplotlib.ticker as tck\n",
    "\n",
    "plt.rcParams.update(bundles.iclr2024(usetex=True))\n",
    "plt.rcParams.update(figsizes.iclr2024(nrows=1, ncols=1, rel_width=.5, height_to_width_ratio=0.5))\n",
    "\n",
    "plt.rc('text.latex', preamble=r'\\usepackage{amssymb,amsmath}')\n",
    "\n",
    "colx = 'num_params'\n",
    "colh = 'type'\n",
    "cols = 'time'\n",
    "coly = 'gpu_memory'\n",
    "\n",
    "k = 2.5\n",
    "\n",
    "fig, ax = plt.subplots(1, 1, squeeze=True, sharey=True)\n",
    "sns.scatterplot(\n",
    "    df,\n",
    "    x=colx,\n",
    "    y=coly,\n",
    "    size=cols,\n",
    "    hue=colh,\n",
    "    legend='brief',\n",
    "    alpha=0.7,\n",
    "    sizes=(36 / k, 512 / k),\n",
    "    ax=ax,\n",
    "    palette=palette_dict,\n",
    ")\n",
    "sns.scatterplot(\n",
    "    df,\n",
    "    x=colx,\n",
    "    y=coly,\n",
    "    hue=colh,\n",
    "    style=colh,\n",
    "    s=8,\n",
    "    legend=False,\n",
    "    alpha=0.7,\n",
    "    ax=ax,\n",
    "    palette=palette_dict,\n",
    ")\n",
    "\n",
    "\n",
    "ax.grid(linestyle=\"--\", which=\"major\", alpha=0.3, linewidth=0.5)\n",
    "ax.grid(linestyle=\"--\", which=\"minor\", alpha=0.3, linewidth=0.3)\n",
    "ax.yaxis.set_minor_locator(tck.AutoMinorLocator())\n",
    "\n",
    "ax.set_xscale(\"log\")\n",
    "ax.margins(x=0.05, y=0.18)\n",
    "\n",
    "handles, labels = ax.get_legend_handles_labels()\n",
    "del handles[0]\n",
    "del labels[0]\n",
    "\n",
    "labels[4] = ''\n",
    "\n",
    "fl = ax.legend(\n",
    "    loc=\"upper left\",\n",
    "    handles=handles[5:],\n",
    "    labels=labels[5:],\n",
    "    title=r'time per iteration (ms)',\n",
    "    ncols=5,\n",
    "    columnspacing=0.2,\n",
    "    borderpad=0.75,\n",
    "    handletextpad=0.25,\n",
    ")\n",
    "\n",
    "ax.legend(\n",
    "    loc=\"upper left\",\n",
    "    handles=handles[:4],\n",
    "    labels=labels[:4],\n",
    "    bbox_to_anchor=(0., 0.6),\n",
    "    ncols=2,\n",
    "    alignment=\"left\",\n",
    "    columnspacing=0.2,\n",
    "    handletextpad=-.25,\n",
    ")\n",
    "\n",
    "ax.add_artist(fl)\n",
    "\n",
    "ax.set_ylabel(\"GPU memory (GiB)\")\n",
    "ax.set_xlabel(r'\\# parameters')\n",
    "\n",
    "fig.savefig('nunits.pdf', dpi=250)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "50e063c6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 275x137.5 with 1 Axes>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ax.xaxis.set_label_coords(0.05, -0.05)\n",
    "\n",
    "from matplotlib.ticker import FuncFormatter\n",
    "\n",
    "def custom_label(x, pos):\n",
    "    if np.isclose(x, 10**5):   # Replace label for tick at 10\n",
    "        return \"\"\n",
    "    return r\"$10^{\" + f\"{pos+3}\" + r\"}$\"          # default formatting\n",
    "\n",
    "ax.xaxis.set_major_formatter(FuncFormatter(custom_label))\n",
    "\n",
    "fig.savefig('nunits.pdf', dpi=250)\n",
    "fig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f864b9b7",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
