{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Assessing the influence of the number of sampling steps on the sample quality"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2024-05-19 08:34:19.147490: I tensorflow/tsl/cuda/cudart_stub.cc:28] Could not find cuda drivers on your machine, GPU will not be used.\n",
      "2024-05-19 08:34:19.177684: E tensorflow/compiler/xla/stream_executor/cuda/cuda_dnn.cc:9342] Unable to register cuDNN factory: Attempting to register factory for plugin cuDNN when one has already been registered\n",
      "2024-05-19 08:34:19.177732: E tensorflow/compiler/xla/stream_executor/cuda/cuda_fft.cc:609] Unable to register cuFFT factory: Attempting to register factory for plugin cuFFT when one has already been registered\n",
      "2024-05-19 08:34:19.177765: E tensorflow/compiler/xla/stream_executor/cuda/cuda_blas.cc:1518] Unable to register cuBLAS factory: Attempting to register factory for plugin cuBLAS when one has already been registered\n",
      "2024-05-19 08:34:19.184338: I tensorflow/tsl/cuda/cudart_stub.cc:28] Could not find cuda drivers on your machine, GPU will not be used.\n",
      "2024-05-19 08:34:19.185593: I tensorflow/core/platform/cpu_feature_guard.cc:182] This TensorFlow binary is optimized to use available CPU instructions in performance-critical operations.\n",
      "To enable the following instructions: AVX2 FMA, in other operations, rebuild TensorFlow with the appropriate compiler flags.\n",
      "2024-05-19 08:34:20.234877: W tensorflow/compiler/tf2tensorrt/utils/py_utils.cc:38] TF-TRT Warning: Could not find TensorRT\n",
      "/data/Programming/IWR/BayesFlow/bayesflow/trainers.py:27: TqdmExperimentalWarning: Using `tqdm.autonotebook.tqdm` in notebook mode. Use `tqdm.tqdm` instead to force console mode (e.g. in jupyter console)\n",
      "  from tqdm.autonotebook import tqdm\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import pickle\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import scipy\n",
    "import seaborn as sns\n",
    "import tensorflow as tf\n",
    "from c2st import c2st\n",
    "from mmd import maximum_mean_discrepancy\n",
    "from mpl_toolkits.axes_grid1.inset_locator import mark_inset, zoomed_inset_axes\n",
    "from tqdm.autonotebook import tqdm\n",
    "from train import get_setup\n",
    "\n",
    "from inverse_kinematics import InverseKinematicsModel"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load the performance data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "computations_file = \"./computations/eval_dict_steps_performance_v2.0.pkl\"\n",
    "tasks = [\"gmm\", \"twomoons\", \"invkinematics\"]\n",
    "simulation_budgets = [8192]\n",
    "estimators = [\"cmpe\"]\n",
    "sampling_steps = [2, 4, 6, 8, 10, 15, 20, 30, 40, 50]\n",
    "run_idx = 0\n",
    "\n",
    "eval_dict = pickle.load(open(computations_file, \"rb\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "colors = [\"#4477AA\", \"#EE6677\", \"#228833\", \"#CCBB44\", \"#66CCEE\", \"#AA3377\", \"#BBBBBB\"]\n",
    "\n",
    "plot_settings = {\n",
    "    \"ac\": {\"name\": \"ACF\", \"color\": colors[0]},\n",
    "    \"nsf\": {\"name\": \"NSF\", \"color\": colors[1]},\n",
    "    \"fmpe\": {\"name\": \"FMPE\", \"color\": colors[5]},\n",
    "    \"fmpe10\": {\"name\": \"FMPE 10#\", \"color\": colors[2]},\n",
    "    \"fmpe30\": {\"name\": \"FMPE 30#\", \"color\": colors[4]},\n",
    "    \"cmpe\": {\"name\": \"CMPE (Ours)\", \"color\": colors[3]},\n",
    "    \"cmpe10\": {\"name\": \"CMPE 10#\", \"color\": colors[3]},\n",
    "    \"cmpe30\": {\"name\": \"CMPE 30#\", \"color\": colors[6]},\n",
    "    \"gmm\": {\"name\": \"GMM\", \"color\": colors[0]},\n",
    "    \"twomoons\": {\"name\": \"Two Moons\", \"color\": colors[1]},\n",
    "    \"invkinematics\": {\"name\": \"Inverse Kinematics\", \"color\": colors[2]},\n",
    "}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Plot the data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAnkAAAFyCAYAAACJJsz/AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/SrBM8AAAACXBIWXMAAA9hAAAPYQGoP6dpAAC0AklEQVR4nOydd3wUZf7H3zOzJT0h9B56EXtDrIhiP0Sxnb1ckxOx3enpiXh63O9sB3eoZzkEvNMTUCwniEexIGI5u9ICQVoIkJ5sm5nn98fsTHaT3WQDIbtJnrevlWTmO8989smzO5/5PmUUIYRAIpFIJBKJRNKuUJMtQCKRSCQSiUTS8kiTJ5FIJBKJRNIOkSZPIpFIJBKJpB0iTZ5EIpFIJBJJO0SaPIlEIpFIJJJ2iDR5EolEIpFIJO0QafIkEolEIpFI2iHS5EkkEolEIpG0Q6TJk0gkEolEImmHSJMnkUgkEolE0g7p8CZv4cKF3HLLLZx88snk5OSgKApXXXXVfpW1fft2brjhBnr16oXX66WgoICpU6dSVlbWwqolEolEIpFIGseVbAHJ5qGHHuKrr74iKyuLPn36sG7duv0qp7CwkDFjxlBSUsKECRMYPnw4n3zyCTNnzmTp0qWsXr2azp07t7B6iUQikUgkkth0+EzeE088wYYNG6isrOSpp57a73JuvvlmSkpKmDVrFosXL+ZPf/oTK1as4LbbbmP9+vXce++9LahaIpFIJBKJpHEUIYRItohUYdWqVYwdO5Yrr7ySF198MeHjCgsLGTx4MAMGDGDTpk2oap13rqqqomfPnpimSUlJCVlZWQdDukQikUgkEkkUHT6T1xKsXLkSgPHjx0cZPIDs7GxOPPFEfD4fa9euTYY8iUQikUgkHRBp8lqA9evXAzBkyJCY++3tGzZsaDVNEolEIpFIOjYdfuJFS1BRUQFAbm5uzP329vLy8rhlBAIBAoGA87sQgmAwSJcuXVAUpeXESiQSiUQi6RBIk9cK2MMeGzNrM2bMYPr06Q22f/rpp2RlZWGaJqWlpeTn5zfoEo48TyAQwOv1NnquROJasqz2rj0Zutq79kT1t+V205a1J0NXa7ebtqw9Ge+xvWs/EF3Dhw+PW+bBRpq8FsDO1NkZvfpUVlZGxcXinnvu4fbbb486pm/fvgwaNIicnBwMw2DTpk0MHjwYTdNiliGEoLKy0lnvLx6JxLVkWe1dezJ0tXftiepvy+2mLWtPhq7WbjdtWXsy3mN7197SuloLafJagGHDhgHxx9xt3LgRgKFDh8Ytw+v14vV6G2zXNM1pdKqqRv1eHyGEE9NUo28qriXLau/ak6GrI2hPRH9bbjdtWXsydLV2u2nL2ltal2zzLa+rtZATL1qAsWPHArBs2TJM04zaV1VVxerVq0lPT2f06NHJkCeRSCQSiaQDIk1eMwiFQqxbt47CwsKo7YMGDWL8+PEUFRUxe/bsqH3Tpk2jpqaGa665hszMzNaUK5FIJBKJpAPT4btrFy9ezOLFiwEoLi4GYM2aNVx33XUAdOnShUcffRSAHTt2MGLECPr3709RUVFUOU8++SRjxoxhypQpLF++nBEjRrB27VpWrlzJ0KFDefjhh1vrLUkkEolEIpFIk/fll18yd+7cqG2bN29m8+bNAPTv398xeY0xaNAgPvvsM+6//36WLl3K22+/Tc+ePZkyZQrTpk0jPz//oOiXSCQSiUQiiUWHN3kPPPAADzzwQEKxBQUFznIosejbty9z5sxpIWUSiUQikUgk+48ckyeRSCQSiUTSDpEmTyKRSCQSiaQdIk2eRCKRSCQSSTtEmjyJRCKRSCSSdog0eRKJRCKRSCTtEGnyJBKJRCKRSNoh0uRJJBKJRCKRtEOkyZNIJBKJRCJph0iT1wEpKiri/EkXNHg0m0QikUgkkvaDNHkdjKKiIsZffA6bB5Uw/uJzpNGTSCQSiaSdIk1eB8IyeGcTONNN+sBsAme6GX/x2dLoSSQSiUTSDunwz65NdYQQMV9NxdbHzuAFznTjzvcC4M734j8DzrzobJYtWkJBQUFCZSV6znjvYX/L2Z/ztYb2ZOtqj9oT1Z9sXR1Ve7J1JVrWgdR9W9Z+MHV1VO0HoktRlEY1HkykyUsxZs+ezezZszEMA4CKigqEEBiGQSAQoKKiAk3TYh4rhKC6uhqIblQ//vgjE6+dRGi81zF4Nu58L4Ez4YyLzuK1uQvp169fo2Ules5IDkT7/sS1tvZk6Grv2hPV35bbTVvWngxdrd1u2rL2ltYl2/yB6crLy4tb5sFGmrwUY/LkyUyePJnKykpyc3PJzc0lJycHwzAoKSkhNze30Q8QQG5ublQDvOWuW/Edp5Bez+DZuPO9+I4Lcstdt7Jq6YpGy0r0nJEciPb9iWtt7cnQ1d61J6q/Lbebtqw9Gbpau920Ze0trUu2+ZbX1VpIk5fiKIoS85VIvM3cv89h/MVn488LNMjkAYRKA2R9pjB30Zyo4xI5XyJxB6J9f+NaW3tr62rv2pujPxXfY0fQ3tq69iemJctqa9pbUlcicR1Be0vrag3kxIsOQEFBAcsWLSXtvyFCpYGofaHSAK5lfpYtWho1Jk8ikUgkEknbRpq8DkIsoxcqDbBn4VbGTj6bXn17J1mhRCKRSCSSlkSavA6EbfS874bwba4i+FYpXSf15/3Stbz5/TvJlieRSCQSiaQFkSavg2EZvSUMLOzGh2+8x5jDR2MKkz+/N4vN+4qSLU8ikUgkEkkLIU1eB6SgoIC3Fr7JoIGDeOTcB8jxZrO3ppQHlz9GTbA22fIkEolEIpG0ANLkdXD65vXmnrFTAfhgyxrm/+8VTGEmV5REIpFIJJIDRpo8CZcc9hPOHHIqAE+tmcOXO79NsiKJRCKRSCQHijR5EhRF4aGz7qVrZmeqgzU8+N9H2VtTmmxZEolEIpFIDgBp8iQAdMnM58Hxd6MoCt8Uf88za+cSMvRky5JIJBKJRLKfSJMncThzyGlcPOp8AP75xUI+3f5FkhVJJBKJRCLZX6TJkzgoisK9p99O/059CRhBHv/4abaV70i2LIlEIpFIJPuBNHnA9u3bueGGG+jVqxder5eCggKmTp1KWVlZwmUIIfjHP/7B6NGjyc7OJiMjgyOPPJJZs2ZhGMZBVN+y5KRl88ez7sOtutlSvpW/fPh3uayKRCKRSCRtkA5v8goLCzn66KOZM2cOxx13HLfddhsDBw5k5syZnHDCCezbty+hcq655hpuvPFGtmzZwmWXXcbPfvYzgsEgt956K5dddhlCiIP8TlqO0f2P5tqjLwPgrR+W8dYPy+SyKhKJRCKRtDFcyRaQbG6++WZKSkqYNWsWt9xyi7P99ttv54knnuDee+/l6aefbrSMxYsX8+KLLzJgwAA++eQTunTpAkAoFOLSSy9l0aJFzJ07l+uuu+5gvpUW5dYTf85HWz7h+70bmPnh3zm0x0hGdh+abFkSiUQikUgSpENn8goLC1m2bBkDBgxg8uTJUfumT59OZmYm8+bNo7q6utFyXn31VQDuuOMOx+ABuN1u/vCHPwDw17/+tYXVH1zSPencd+odZLjT2V29h0ff+xv7ahPvvpZIJBKJRJJcOrTJW7lyJQDjx49HVaOrIjs7mxNPPBGfz8fatWsbLae4uBiAgQMHNthnb/vf//7XrDF+qcCwLoO4+YQbAHhvy0cs+GoxQSOUZFUSiUQikUgSoUN3165fvx6AIUOGxNw/ZMgQli1bxoYNGxg3blzccuzs3ZYtWxrs27x5c9T5Ro8eHbOMQCBAIBBwfq+srATAMAznZZpmo5M4hBBOjKIoBxRnx1x75OV8sOVj1m77nGc+mc+hPQ5hdL+jm1VWsrS3RFmJaE+GrvauPVH9bbndtGXtydDV2u2mLWtvaV2yzR+YLk3TGi33YJJ0kzdr1iwyMzO58cYbG+yrrq7GNE1ycnLiHn/bbbdRWVnJ888/3+xzV1RUAJCbmxtzv729vLy80XLOP/98XnrpJR5//HEuv/xy8vPzAdB1nWnTpjlxjWXyZsyYwfTp0xtsLywsJCsrC9M0KS0tZdOmTQ2yjjZCCAKBAF6vt8lG31RcZMwvh13N+t2bKPdXMGvF07iP/hU5adkJl5VM7QdaViLak6GrvWtPVH9bbjdtWXsydLV2u2nL2pPxHtu79gPRNXz48LhlHmySbvKmTp1Kz549Y5q8IUOGsGfPHnQ9/pMXXn75ZUpKSvbL5DWFPSO2sQYEcPnll/Piiy+yZMkSRo4cyU9+8hMyMjL473//S2FhIUOGDGHjxo2Nuvl77rmH22+/3fm9srKSvn37MmjQIHJycjAMg02bNjF48OC45QghqKysJCcnp8lG31RcZMxQZSh3Kjdz37sz+Gzv17y79wOmnPhzMjzpCZWVTO0HWlYi2pOhq71rT1R/W243bVl7MnS1drtpy9qT8R7bu/aW1tVaJN3kQZ2Zau6+A8XO1NkZvfrYXabxMn02qqryxhtvMHPmTObPn8/8+fNxu92MGTOGuXPn8utf/5qNGzfSrVu3uGV4vV68Xm+D7ZqmOY1OVdWo3+sjhHBimmr0TcXVj7n48J/wftEalm1cxUtfv8qRfQ7j7GGno6ImdM5kaj+QshLRngxdHUF7Ivrbcrtpy9qToau1201b1t7SumSbb3ldrUWHnngxbNgwADZs2BBz/8aNGwEYOrTppUNcLhd33HEHX375JT6fj8rKSpYuXcrIkSP58ssvSU9P55BDDmk58a2MR3Nz37jb6ZHdDV/Iz8wP/86mvVsoKiri/EkXUFRUlGyJEolEIpFIIujQJm/s2LEALFu2DNOMXuy3qqqK1atXk56eHneyRCLMnz8fv9/PpZdeitvtPiC9yaZ3bi/uHXsbmqKxad8WHnljFmdcdBabB5Uw/uJzpNGTSCQSiSSF6NAmb9CgQYwfP56ioiJmz54dtW/atGnU1NRwzTXXkJmZCViLG69bt47CwsIGZdldu5F8+umn3H333WRlZXH//fcfnDfRypw5dCwTR51HqDTAP2fMITTeS/rAbAJnuhl/8dn7bfRkRlAikUgkkpYlJcbkJZMnn3ySMWPGMGXKFJYvX86IESNYu3YtK1euZOjQoTz88MNO7I4dOxgxYgT9+/dvYEbOPPNMMjIyGDVqFFlZWXz33Xe8/fbbeL1eXn311Zhr6LVF3JqLSwsu4MmpT9Dl4v64861xhO58L/4z4LQLT+cfz89hwIABeDQ3bs2NpqgE9SBBPYhX9aIq0fcWRUVFjL/4HGqOFYy/+BzefXUpBQUFSXh3EolEIpG0Hzq8yRs0aBCfffYZ999/P0uXLuXtt9+mZ8+eTJkyhWnTpjnLoTTFpEmTePnll5k/fz4+n49evXpx0003cffdd7crw1JUVMQVV19Bp4l9HINn4873EjoLLvrpxZx960/o1acXeem55Kbl0jXUifXGFjRVI83lJc2dhtflpby4lMm/vBnzrEzS870E8gKMu2g8Sxb8h6GDYq9fKJFIJBKJpGk6vMkD6Nu3L3PmzGkyrqCgIO5s37vuuou77rqrpaWlHNf+8nqqjxGk5zecCQyW0cs4rTNvzn6NHtcMitqX4U4nJy2bHG82Wd5MRLnBir8tIWtC96iMYOhMOO3CcTz8xMMMGzKcHG82mZ500t3ppLvS0JtYsLKoqIirf3YN85+dx4ABA1rmjUskEolE0sZICZNXWlrK6aefHnM7EHNf/RhJ6zD36TmMv/hs/HmBBpk8gFBpAP97ZZz+y7MIZZuU+Soo91Wgmzq1IR+1IR/FVSWESgPsWbiVrpP6x8wIcm4ud91yFz+f9isKBgxARUFVNbyqB6/wkLkng/yMTmR7s0h3p5PhTifDk87uHcWcM+l82fUrkUgkkg5PSpi8YDDIqlWr4u5vbB80vVixpOUoKChg2aKlltE7gyiDFioNEPpPGb/50z106dUVBfC4PLgVF0ZpkOrMALWhWir8VTz/u6fodEbPmEYRrHI9p+Qy8w9/oe/1w+md05PeuT3pkdWVbt4udDY7UVxdYj2GRlHQVJXK3RX8+e4ZaOfmOl2/p104jueff57+/fujqRqaquJSXaiKiqao+AI+FL+KS3OhKSqa6kJTVWfcYFFREdf8/FpemvMvBg0aFFNrqtKWtUPb199WkfWePGTdS1qapJu8a6+9NtkSJM0kltELlQbwvBvgtX+/Qdfe1lp6NcFaKv1VVPgq0TUV020ZrGxPFpN/N4WZv3+MUJ4nbkawamUJPSYNIGSEKCr7kaKyH6NiumZ2pk9uL/rm9SKtxs0LDz2H+7xO0V2/Z8FV117FrQ/dQZeeXUBRUABFUVFRcOkuFI+ColmmT1UUVEVDUzXKdu3l/tvuwxiTxtiJ43j0b4/Tu19vQHFMoKoo1k2GAN0XwlPtRVOsRTCt8yiAFSOEIFQbxOuvm3xixSnRNyoC/DV+0kP7UBXV2RdZnhACf42fcrMKVbX3K05523/czhXXXIH/OI0zJ53FS/Neom//vnWnCA87EAiEENRW1VApqq2TODHUi6ml1KgIaxBR5YRlI4TAV13LnlCp9Z5jxJnCJFDjxxvc49SLfR6b7Vu38bObfkZwtJtxF53JM889G677aIQQBGoCeP0NHzMUObJCCEGwNoDH1/jjiBqLiXwvTZZlmpRVlxLcbd2ENHq+2sYeyyQSikusLOvxTcHaIJ4aT8y4Hdt28Kuf/4rQaDenX3QmTz3zFL37Nqz3unPGLsv+PVFdLfMew+c0TcqryggU6yiNPF4r0fN5fWmJaW9G21KIXfe/qNfm+/TrE/H5r/seCdT4SQvutcqq9x1if09Yn0U/ZWZlRAxRZSGgtrqWGsXX4DzRcYKa2hpCLh2l3neX9TMIU+AP+akMVKGp0QsBR75ffyiAO+hDVdWI77RwlP2zAN0w0E293neg0ujfYn9pz+ZaEQfzkRKS/aayspLc3FwqKiqcx5pt3LiRIUOGNLqaeEVFBbm5uU1+KTUVl0hMUVERZ150NjXHCjI/VeJ2jeq6zrr16+hZ0IuAEcQX8uML+dmwaQNTfnUL6rk5DTKC+n/Kmf7EH+jXvx/7akrZVrGTbeU72V6xg+3lOynzV0TFx+v6tfcH3trHr/8wlX79+5HuSiPN5cWluhABE9MDAhPDNDGFwBQGxdt3M+M3f8B1Xp5jYkP/KeOOGb+1zKJdTwjLTAjQQgq628QxQAjquyZXSLNiYlSpY50EuHQV3RU7jsgYLRxjH6zA3p17mHnvY7jP7xSlfepDd9ClV9c6w2X/Xc2I86l15TuiEtXUTO2Gy7TqqF772rtzDzPve8wx7Lb+W8P6456vMZrSpYgDeI8xggVkVHuozQo2/TdssTpV9rssBYW9O/fwlxj1PjVGvQsSrK8WrtNEy2qRuj8Ibd6KaXjJtdr84wm1eUWAFnE+gYhpGmPqsr+SIiS4Qla7UVT7i8T6J9LAKUJBCykYbuEYywhFzv+9lS6COWb4+MiPthJ2gqAGAU/EOeqZRVunEgS89n6rDMcOKopVjUFQvGr4ebOWiVXtMhWFsI1E+E3UdBVN0ZzyVEVFQWHXjl385td3oJ/gJf0TwfLXlsUd4tNS187WRJq8FKUtmDyALVu2NDnJoTHtllE8i8CZHufLTVlaze8fe4CMzln4Qj6EEHjdXmvcnTsdLaRSq/jZUbmLbeU7eOG+Z1GPzSB9YHZcnb7NVVR8WBI1GURBccbyWf9mkO5OR5SFWDF7adSEEAiPN3xzHzfe/ws69+xifYmE7zIVgBBoHi18hxqxL/xlo6AgQgLNq6EqasSx0bHWl5dAS3PFLMv+j4CJlu6KutMt3r6Lu6f8FuWc7AbaxZIq/jTr/+jRp2eDv7XpN1DTGn9UT1MxLVFWc/UfqC4hRFSGzvDpqGla+Gpjb6fuZwTCFJgBA8Wrhi9c9r6IbJ8hCO7z4+7sRVGjs6LOeUVdOVbmJfo89oXYFCZmwED1akRG2NqsWIFhlxW+ittf7PWzqGbAQPGoUZnWPTv38Ng9/xeVCbfrPfSfMu74428aGj0BImiietX4dS9wtEdldhpkXQUiYDp14cQR/bcygwaaVyPSTTUoyxToZUHcnay6ryOiLKzzWbpixyAEZsC02kw9ExWVeHe0189eRVaDVZbm1ah3Qvbs2M3Dv3kI17m5DereeLuC6Y//gR59ejq9BtZnv+77IR7N/SzaOiP3WdvC79FvgFd15Ds3uOFjTFNgloZQO7kg3Ltgt2NhfzqEAL8Ar4KoV4eR5xemgKAAD1ZcZK+CfZApIAjCE9HWI3+q+wCghMBwCeePUtfuS3jk7v/DHXEzn/bfEMsWxU5YSJMnaTHaislLJK4p7bEygv3796c6WEOFv5JyXyW7q/dQWltKTaAWETDAo5LuSSfTk0H57jJ+d+vdDYyBTag0QNlr2xly1eGIHIXaUC26GXuGbiJZwcb2JwsFBb0syO4FWxrVvnfRVvpcPhRPflr0znpJx5gkEnMAZQVL/Wx/eUPU+ouR2Pp7XToYT35anamKuBg1MD/26aK6leVXXiRttc23Bw607u3uS8sAWkNQlPCwE+vm0jLNanicsXXDWHfTqCoqiqBuf/19EWUoIlyOGqccFETAxJ3udrbV7VdQ7HIMUF3W+OjY2q38GwZobq1eOWq02Q0JNK81ntp5385Ncd3v2DfXquacp3TXXh773Z9j3tjEM3rS5B0khBDMmjWLF154gQ0bNuDxeDjyyCOZOnUqP/nJT5It76DQkUweJJYRDOhBKnwVFO8roVbxsbt6L9WBanwhP3t2lvDX3z/hdK/axMoACSEImSFqArXUVNfgUwP4Qn5qQ7U8e/eTBI/UmswKBtZWcOTkMXUZGWFimgKh2L+L8J2uaf0e/tk0w9sJxwgzIjbG780wJMXzCsk9qVuzM5qpQlvXfyDUdVc1zGIpEd2XSniDUu/3ehFWF1uDbJeVEqk/rmnz89+QNaZLk/Ve89E+Bt10mLMt6tJRrwvQibEzko1c6+pfgmK3eFH3j9LwmJhlxurBbHBYw3KitsQ5T/2tMc+XwPvaMXc9OSd2zDafTBIx17GMXls0eUmfePHZZ58xfvx4OnXqxPfff4/X27DCr7jiChYsWABYFejz+Vi1ahXvvfceM2bM4De/+U1ry5a0MAUFBby18E1yc3PjxnhdHrpmdcFjuMnNzUUgqApUU+GvpKJfJb1n9eLuKb+B83KjxrXc9ae7UfNc7Kstw6260FTNmgDizSJHyYrqzij488PcPeW3jU4I0dYEmDVrZrO7DfenaxGIMIQCQXjcoGli+HXwKM5Fr/jwYh66a3qj2lldyx///Ee69upWdz4EImBY3U1xrsbxY+pdyKK65+K9v9gxe0aV8H+/ndGk/hmPzKBbr+7hntJwt5vdpabUqVPCA4MUlOi4egPfIwd7mwEDLc0VNdC7bpiS4ngZ02+gpWkRg9CjRgyBEIT2BvB0SUNRlZjmjXA5B7sLvKm44iN2JdTmn/zr7FZp8wdclikI7vU7dX/Qz3cAZRUf23Tdq2v8zJ71V7r17o4pBIZpOJ99K5ttOt8PpjCdG0VTmBFxETejwr7JNK3vkYCOcFst2z7O3l93jIkRNMAVbv8R+yJjQtUh1Ayt7vgY5ZghE6ERY3/4Jhfr+800TIQqovc5x4TLM0zrxrpeOfXPKUyBqdTVwca3v2xydYfqY4Jc+8vreW/pyrh/+7ZA0k3eihUrKC8v58orr4xp8F566SVeeeUVALp3786ECRPIzMxk8eLFbNmyhfvuu48LLriAESNGtLZ0SZJRFZXctBxy03IgDw7tOZLjXzuScy49H99xQdwfh3jy70+R170TvpAPvx5AN3V8IT+6aaAbOmoQ9BrDGUOiZanc9sc7efTu/4MYWUHz7UoefOIP5PXIx68H6sYzC8A0UQwjPHO2YRYGIRCmCSIyE9MwgxNJ3Zi96O1CCEwjeqxTzuBs/vzXR6yLxjkNl7cRS6p45G+Pxh6T50rgItVEjBPnTqCsGDHdh3Xjkb892iz9QghMLUFdSgK6hIHqSaAsl4HqaqQsU2CqujXLsBGjkQr06NOTP836v0brPdZYTsmBk0jd/9+sPzds82aCbd7Tika2hcx1wuc7kBubw5o211mfKcxdNCduuW2FpHfXnn/++SxZsoR333035qLHxx9/PJ9++ilDhgzho48+onPnzgD4fD5OOukkvvzyS2677TYeffTR1pZ+UOlo3bUteb54Xb+mMAkZOkEjSMjQCegBKisq0NLd6Ka13Z75u2XLZu677V60c+uygvp/yrnrT/fQNTwAvW7gMSAEakjBdNd1x0bpRiBM0EIqutuInkpLxAVfUepmu7ojZow26AqyZ9fWGVSbPTtLmJXgTL2osiJnqDozAJWGMeF9URk9O/MlrPdouOu6r+w/kxJRljNTr552BYU9O0t49J4/Rw2GDv2nnDtn/MbJQDr1G1FWvK5tu8tQDaoYUTObI0fxRZQVMWvR1hTdhRdjpqSoM/X2nzVyhqdVRj19om6WMUqdjgaxInqWZFTPqBDOSV26hu4yGh8PGW5bhtusG/geLmzvzj3M/H1is5oVu74iZ3jHIkK7PQki5l8pMq7unmi/yzqQ2bX28iONxUDE36mJOCLLivhcRBJrRnkwYmZz9N+83udViewPF3UZ7YjPoqI2vKG0J3DZ31vOdqXuFtT6HRAKalABL3XZ8vC/TrZbCLQyMDupVvY61hAEgTWhwhtei1Spy5BHDjsQAgjaE2PsyR51++2/kfBbk8/2xzA2NslLjslrQUaOHMmGDRuoqKggMzMzat/u3bvp2bMniqLwwgsvcPXVV0ftf/PNN5kwYQJHH300n376aWvKPuhIk5d87Zu3bGb8xedQeyykfyJY/PKr9OvfzzkW6oyeKUxqqqrJyMoMlyUiYixMMxyTXdfOY00OMIVJbVUNaVnp1M26tM9lm0ITX7WPtMw058sxUtO2rdu44cYbCB7vwrNW5/nnn6dPvz5RMfYxQlhr7nkzvdSfgRgZE6z148nw1l0EAdP+F9OJDdYEcKd7EIpooEsIqx50Xyj85VxXN3ZdCQS7tu3irlvuwDjBi7YmwCN/e4ye4WyGWu/iYfj0cFn22oV1Mw7ViLox/DqudLczSByINpkC9NoQ7gwPmqpGnaOO8HqHvqBTF9Fdv+GiTJOyHaV06t05qs3X7w4P1PjxZtatwxarG1mI8LpomekNZlNGluar9pGele7UQ339dre1v6aW9KyMmN3W27Zu48prrsR/vEbaWoN/zftX1PqKVjXV/V1rq2vJCJcVFSPqYnzVdeeLVU5TcZExtVWNx4DVlnb/uItu/XrEnX1aV1Z6o+erq9N6jriRuFiXVKvefaRlhmNinG/7j9u57vprCRzvwrtW5x//mEPvvr2jP4fh7wB/tR9PprUOSd33Ql3XponpfBa1dKvDzu7GtOOEEBjCxPDp1lIlED7O1mx1nQrTxBAmwm8iPDg3sdHfb9bvapnAyCOy8wJ7cpT9+VeCYLoFKML2v07dOjfO4Ztmw2U63yNOhF2mCZquWDe6lvOzCrMdccSfLN4NcSxz3d5m1ya9u7a4uJicnJwGBg/go48+AqwvnwsuuKDB/nHjxgGwefPmgysyidgfxvqvpmITLfNAYvanrLakfUDBAJa+8h9+esOV/GvBPxtdJFMIgRZUyM1o4sNvuMnNSsB8igS+SNT4MYM7D+C/C9+xtC9sWntrmv6EyhoAx7x6uKX/1fj6U/HmAMI3NuUbGdK1iRsbd4Lncx1Ye4iKU+LH9T60J8sWLk283YgKcnOa0EWCupqIS7QswzDwp9XQL7d343XfSD04MYnWaRNxQggqtMZjBub3590EPrNCCCo8qdHmI42nbuhs2ljIoMGDUDU1yniKcKwpTCorKsnKyYq6iYmcaNbwppmoMiLHF9o3GUCDMpzfwzcQ9g1xZBkUwLEvHMGNN92E7/ggGZ8I3nn1Hfr37x/XrO/P9SeZZi/pJq+mpgaXK7aMzz//HIDBgweTl5fXYH9GRga5ublUVVUdTImtyuzZs5k9e7b1uC6goqLCuuMyDAKBABUVFY1+cVVXVwONN6pE4lqyrLasvVOnTjwz6+906tSJioqKlNHV3rUnqj9V241s8y2vK9GyWqruZZtvXpxhGOihELXVNY3Wuxk0MP1Gg3IU6jLZqlDRdBW33viYPCEMMkVEplUh+l9bu6aR5cqKWVb3wV14bc5CfnbLz3n2H88ccN3HionlX1qLpJu8zp07s3v3bkpKSujWrVvUvjVr1qAoCscee2zc44PBIB6P52DLbDUmT57M5MmTne7a3Nxcp7u2pKSE3NzcRj9AQEJ3ZU3FtWRZ7V17MnS1d+2J6m/L7aYta0+GrtZuN21Ze0vrau9t/tBDD2X+s/MaHVLU0rpai6SbvMMPP5xly5bx4osvcvvttzvbS0pK+PDDDwE47bTTYh5bXFyMz+djyJAhrSE1KSiKEvOVSHyi5R7ssjqC9tbW1d61N0d/Kr7HjqC9tXXtT0xLltXWtLekrkTiOoL2ltbVGsR/JkorcdlllyGE4MEHH+S1114jGAxasyOvvppQKITX62XixIkxj/3ggw8AGDVqVGtKlkgkEolEIkl5kp7Ju/rqq5k9ezaff/45kyZNitqnKAq33nor+fn5MY99+eWXURSFk046qTWkSiQSiUQikbQZkp7J0zSNJUuWcOaZZzaYlXLttdfy0EMPxTxu8+bNvPHGGwAxZ95KJBKJRCKRdGSSnskD6NKlC++88w7r16/nm2++AeCYY46JuU6NjaqqLF68GLfbzeDBg1tJqUQikUgkEknbICVMns2wYcMYNmxYQrEFBQWNmkCJRCKRSCSSjkzSu2slEolEIpFIJC2PNHkSiUQikUgk7RBp8iQSiUQikUjaIdLkSSQSiUQikbRDpMmTSCQSiUQiaYdIkyeRSCQSiUTSDpEmD9i+fTs33HADvXr1wuv1UlBQwNSpUykrK2tWOW+88QZnnHEGffr0IT09nYEDB3LJJZewZs2ag6RcIpFIJBKJJDYd3uQVFhZy9NFHM2fOHI477jhuu+02Bg4cyMyZMznhhBPYt29fQuXceeedTJgwgS+//JKzzz6bW2+9laOOOorXX3+dE088kXnz5h3kdyKRSCQSiURSR0othpwMbr75ZkpKSpg1axa33HKLs/3222/niSee4N577+Xpp59utIzi4mKeeOIJunfvztdff023bt2cfStXruT0009n2rRpXHPNNQftfUgkEolEIpFE0qEzeYWFhSxbtowBAwYwefLkqH3Tp08nMzOTefPmUV1d3Wg5W7duxTRNjj/++CiDBzB27Fiys7PZu3dvi+uXSCQSiUQiiUdKm7zHH3+cBx988IBj4rFy5UoAxo8fj6pGV0V2djYnnngiPp+PtWvXNlrOkCFD8Hq9rF27lpKSkgbnqKqq4swzz9wvjRKJRCKRSCT7Q0p31z7yyCOUlJRw//33H1BMPNavXw9YJi0WQ4YMYdmyZWzYsIFx48bFLSc/P59HHnmEqVOnMnLkSCZOnEiXLl3YtGkTb7zxBuPHj2+yyzcQCBAIBJzfKysrATAMw3mZpolhGHHLEEI4MYqiHFBcS5bV3rUnQ1d7156o/rbcbtqy9mToau1205a1t7Qu2eYPTJemaY2WezBJaZN3sKmoqAAgNzc35n57e3l5eZNl3XLLLfTv35/rrruO5557ztk+ePBgrr322gbduPWZMWMG06dPb7C9sLCQrKwsTNOktLSUTZs2Ncg62gghCAQCeL3eJht9U3EtWVZ7154MXe1de6L623K7acvak6GrtdtNW9aejPfY3rUfiK7hw4fHLfNg06FNXlMIIQAabUA2M2bM4L777uPWW2/l17/+NT169GDdunXcc889XHnllXz55Zf8+c9/jnv8Pffcw+233+78XllZSd++fRk0aBA5OTkYhsGmTZsYPHhw3LsCIQSVlZXk5OQ02eibimvJstq79mToau/aE9XflttNW9aeDF2t3W7asvZkvMf2rr2ldbUWHdrk2Zk6O6NXH7vLNF6mz2bFihX87ne/Y+LEiTz++OPO9qOOOorXXnuNoUOH8thjj/GLX/yCQYMGxSzD6/Xi9XobbNc0zWl0qqpG/V4fIYQT01SjbyquJctq79qToasjaE9Ef1tuN21ZezJ0tXa7acvaW1qXbPMtr6u1SOmJFwebYcOGAbBhw4aY+zdu3AjA0KFDGy3nP//5DwBjx45tsC8jI4PjjjsO0zT54osvDkSuRCKRSCQSScJ0aJNnm7Jly5ZhmmbUvqqqKlavXk16ejqjR49utJxgMAjAnj17Yu63t8fK1EkkEolEIpEcDFLG5Nlp0shXSUkJQogG212ulullHjRoEOPHj6eoqIjZs2dH7Zs2bRo1NTVcc801ZGZmAhAKhVi3bh2FhYVRsSeffDIAzzzzDDt27Ijat2TJElavXk1aWhpjxoxpEd0SiUQikUgkTZEyY/LsSQ6J7Gsstrk8+eSTjBkzhilTprB8+XJGjBjB2rVrWblyJUOHDuXhhx92Ynfs2MGIESPo378/RUVFzvZJkyZxxhln8N///pcRI0YwceJEevTowQ8//MBbb72FEII//elPdO7cucV0SyQSiUQikTRGypi8+t2lAD179qSkpKTJtWsOhEGDBvHZZ59x//33s3TpUt5++2169uzJlClTmDZtGvn5+U2Woaoqb7/9NrNnz+bll1/mtddeo7a2lvz8fM4991ymTJnC+PHjD9p7kEgkEolEIqlPypi8ZNK3b1/mzJnTZFxBQUHcLKLb7Wbq1KlMnTq1hdVJJBKJRCKRNJ+UGZMnkUgkEolEImk5pMmTSCQSiUQiaYdIkyeRSCQSiUTSDklpk5fILNqWnGkrkUgkEolE0l5I6YkXd911F9XV1QccI5FIJBKJRNLRSGmTd8cdd7RIjEQikUgkEklHI6W7ayUSiUQikUgk+4c0eRKJRCKRSCTtEGnyJBKJRCKRSNoh0uRJJBKJRCKRtEOkyZNIJBKJRCJph6T07FqJtQ5grFdTsYmWeSAx+1NWe9SebF3tUXui+pOtq6NqT7auRMs6kLpvy9oPpq6Oqv1AdCmK0qjGg4k0eSnG7NmzmT17NoZhAFBRUYEQAsMwCAQCVFRUoGlazGOFEM6agY01qkTiWrKs9q49Gbrau/ZE9bfldtOWtSdDV2u3m7asvaV1yTZ/YLry8vLilnmwkSYvxZg8eTKTJ0+msrKS3NxccnNzycnJwTAMSkpKyM3NbfQDBJCbm9tko28qriXLau/ak6GrvWtPVH9bbjdtWXsydLV2u2nL2ltal2zzLa+rtUi6yTv99NPp3LkzCxYsSLaUlERRlJivROITLfdgl9URtLe2rvauvTn6U/E9dgTtra1rf2Jasqy2pr0ldSUS1xG0t7Su1iDpJm/VqlX06NEj2TIkEolEIpFI2hVydq1EIpFIJBJJO0SaPIlEIpFIJJJ2iDR5EolEIpFIJO0QafIkEolEIpFI2iFJn3gB1lpwN9xww34frygKzz//fAsqkkgkEolEImnbpITJ8/v9zJ07d7+OFUJIkyeRSCQSiURSj5QweW63mxNOOCHZMiQSiUQikUjaDSlh8vLz81m5cmWyZUgkEolEIpG0G+TEC4lEIpFIJJJ2iDR5EolEIpFIJO0QafKA7du3c8MNN9CrVy+8Xi8FBQVMnTqVsrKyhI5/4YUXGjz7rv6rsYceSyQSiUQikbQ0KTEmL5kUFhYyZswYSkpKmDBhAsOHD+eTTz5h5syZLF26lNWrV9O5c+dGyzjiiCOYNm1azH0ffPABK1as4JxzzjkY8iUSiUQikUhi0uFN3s0330xJSQmzZs3illtucbbffvvtPPHEE9x77708/fTTjZZxxBFHcMQRR8TcZ88a/vnPf95img8UX1CnsjZAbm6ylUgkEolEIjlYJL271jRNdu7cmZRzFxYWsmzZMgYMGMDkyZOj9k2fPp3MzEzmzZtHdXX1fpX/7bff8vHHH9O7d2/OO++8lpDcIpSU1fL91n3s2Lt/70sikUgkEknqk3STlwhCCGbOnMmRRx5JZmYmnTp14vTTT+eNN944oHLtZVvGjx+PqkZXRXZ2NieeeCI+n4+1a9fuV/l///vfAbjxxhtTakzexvXreHfZOyx+90N+LKlMthyJRCKRSCQHgaR313722WeMHz+eTp068f333+P1ehvEXHHFFSxYsACwDJ/P52PVqlW89957zJgxg9/85jf7de7169cDMGTIkJj7hwwZwrJly9iwYQPjxo1rVtk+n48XX3wRVVW56aabmowPBAIEAgHn98pKy3wZhuG8TNPEMIy4ZQghnBhFURrs37t3L5dceR17/S7UnN4Ely7nmZl/5vnnn+XI4QVRxzRVVnPiWkJ7c+JaW3sydLV37Ynqb8vtpi1rT4au1m43bVl7S+uSbf7AdCUzyZN0k7dixQrKy8u58sorYxq8l156iVdeeQWA7t27M2HCBDIzM1m8eDFbtmzhvvvu44ILLmDEiBHNPndFRQUAuXEGp9nby8vLm132K6+8Qnl5Oeeddx59+/ZtMn7GjBlMnz69wfbCwkKysrIwTZPS0lI2bdrUIOtoI4QgEAjg9XpjNsBrbvwl6rDz6d2tv7OtqmQrN15/HU/N/iv52WnOcU2Vleg5gRbR3py41taeDF3tXXui+ttyu2nL2pOhq7XbTVvWnoz32N61H4iu4cOHxy3zYJN0k/f++++jKAoTJ06Muf8vf/kLYGXVPvroI2em60MPPcRJJ53El19+yfPPP8+jjz7a4tqEEACNNqB4PPPMMwD84he/SCj+nnvu4fbbb3d+r6yspG/fvgwaNIicnBwMw2DTpk0MHjw47l2BEILKykpycnIaaP7+++/xqTn0iDB4ANnd+lPmyuXTdTs44+TjGdqnE5qqNFpWoue0OVDtzY1rbe3J0NXetSeqvy23m7asPRm6WrvdtGXtyXiP7V17S+tqLZJu8jZv3oyiKBx//PEN9u3evZtPP/0URVG47777opYySU9P54EHHmDChAm89957+3VuO1NnZ/TqY3eZxsv0xeP777/no48+ok+fPpx77rkJHeP1emNmMjVNcxqdqqpRv9dHCOHE1G9cmzdvRsnpHfM4T35fKvcV88O2UoSAkf07o2lq3LISPWckB6K9uXEtWVYi2pOhqyNoT0R/W243bVl7MnS1drtpy9pbWpds8y2vq7VI+sSL4uJicnJyyMzMbLDvo48+AqxM2gUXXNBgvz1ObvPmzft17mHDhgGwYcOGmPs3btwIwNChQ5tVbipOuBgyZAiiakfMfTUlWxk0aBD52Wms217KN0V7CelmKyuUSCQSiUTSkiTd5NXU1ERNOIjk888/B2Dw4MHk5eU12J+RkUFubi5VVVX7de6xY8cCsGzZMkwz2tRUVVWxevVq0tPTGT16dMJl+v1+5s+fj6qq3Hjjjful62AwcuRI8j0hqvdsjdpeVbKV6spSvixW8Lg0uuSks2F7GV9tLiGkNz4IVSKRSCQSSeqSdJPXuXNn/H4/JSUlDfatWbMGRVE49thj4x4fDAbxeDz7de5BgwYxfvx4ioqKmD17dtS+adOmUVNTwzXXXONkGUOhEOvWraOwsDBumQsWLKCsrIxzzz03oQkXrcmil+fj2bqcHR/MY9fXy9n2/lzKvnqDQ87+OV9u3sOLy78HoFteBlt2VbB+Wym+oJ5k1RKJRCKRSPaHpJu8ww8/HIAXX3wxantJSQkffvghAKeddlrMY4uLi/H5fPTuHXusWSI8+eSTdOvWjSlTpnDhhRdyzz33cPrpp/PEE08wdOhQHn74YSd2x44djBgxotHlVOwJF6n0hAubLl268N5/lzDzj/dx3gnDueeu23hh/stcf/5oPC6VzcUVPLf0G/xBne6dMthZWsMXG3dTGwglW7pEIpFIJJJmknSTd9lllyGE4MEHH+S1114jGAyyZcsWrr76akKhEF6vN+7M2w8++ACAUaNG7ff5Bw0axGeffcZ1113H2rVreeyxxygsLGTKlCmsWbOmyefWRvLDDz/w4YcfNmvCRTI48fijOPe880jr1AtfQGdI707ceNahZKe7KSmv5Zm3v2ZfpZ+uuels31vF5xt2U1UbTLZsiUQikUgkzSDps2uvvvpqZs+ezeeff86kSZOi9imKwq233kp+fn7MY19++WUUReGkk046IA19+/Zlzpw5TcYVFBQ4y6rEYsSIEY3uTxXSvS5G9s8nr1xn484KsnQ3PTtn8bNzDufFFd9TUl7LP5Z9y8Un9Gdw324Ul9Xw2YZijhrSndzMhjOAJRKJRCKRpB5Jz+RpmsaSJUs488wzEUI4L4Brr72Whx56KOZxmzdvdh5rFmvmraRx3JrGqIKuHDGoK0HdoKS8ltxMDzeefSgDeuQSCBm89MFmvtq8h175Weyr9PHZ+mJKq/zJli6RSCQSiSQBkp7JA2us2DvvvMP69ev55ptvADjmmGMoKCiIe4yqqixevBi3283gwYNbSWn7QlUVBvfqRFaah6+37GHHvmp6dMrk6nEjWfzRJr7esofX1xRSURPk1MP6UFJey2frizlySDe65mYkW75EIpFIJJJGSAmTZzNs2DBn7bqmKCgoaNQEShKnR34mGV4XX2/Zw8591XTLy+CiEweTk6by4Q+7WfX1NsprAlxw/ED2Vfn5bEMxRwzqTs/8hmsbSiQSiUQiSQ2S3l0rSQ1yMr0cM7QHg3t1Yk+Fj2p/iLGH9uSC0YNQFfiysIR/rvyBvEwvwZDJ5xuL2b53/9YnlEgkEolEcvCRJk/ikOZxcfjArhxa0IVaf4jymgBHD+7GT08faS2xsquC55d+g9etgYDPN+5m6+7KZMuWSCQSiUQSA2nyJFFomsqwvvkcM7QHmqqwu6yGQT3zuOGsQ8lKd7O7vJZnl3xNSDdxqypvvLuaF/61gK+//jbZ0iUSiUQikUSQMmPydu/ezTPPPMPnn3+OYRgccsghXHPNNYwcObLR44477jj27dvX6FMoJM1DURT6dM3GDHVh8x4/O/ZV0aNTJj8/5zDmL/+ePRU+nnptNTvefwHdlYW7Ux+efvF18j0hXl/wIl27dk32W5BIJBKJpMOTEiZv1apVXHjhhc4zaIUQvP322zz22GNMnjyZP//5z3EfXbZt27aYj0STHDi5mV6O69yJb4v2sXV3JZ2z07jpnMN4aeUPvP70oww88RKyu/V34qtKtnLuRT9l1btvk5nmTqJyiUQikUgkSe+uLS4u5uKLL6ayshKv18upp57KxRdfTI8ePTAMg7/+9a+ceOKJ7NmzJ9lSOyQZXjdHDe7OiP6dKa8J4A/qnDLATWZOfpTBA8ju1p/ykJt/vbGKot0VGIaZJNUSiUQikUiSbvJmzpxJWVkZAwcO5IsvvmDFihUsWLCAbdu2MXPmTNLT0/nf//7HKaecwo4dO5Itt0PidqmM6t+Zo4d2xxSC739YT1bX/jFj0zr348etm/l0fTFr1xezt9LXymolEolEIpFACnTXLlmyBEVRmD17dtQaeaqqcsstt3DKKacwYcIE1q9fz8knn8zy5csZMGBAEhW3LpFPAan/RJDGYhMtszkx/bvlkO5xsfvHwQRefyvmcRW7tqBmnknXnDR27atiT3kNA7rngG4kVXtLlHWg52zt99iWtSeqP9m6Oqr2ZOtKtKwDqfu2rP1g6uqo2g9El6IojWo8mCTd5G3evBlN0xg3blzM/Ycffjhr1qxh/PjxfPfdd47RS3TR5LbG7NmzmT17NoZhAFBRUYEQAsMwCAQCVFRUoGlazGOFEFRXVwONN6pE4uLFeBU4++Qj+NvjtVSVbG0wJs9fU85HP5psrfmW8Uf0JivLw7qiHWSKGjzpxXTrlImqNjxna2jfn7hE6j0Zutq79kT1t+V205a1J0NXa7ebtqy9pXXJNn9guvLy8uKWebBJuskLBoNkZWXhcsWX0rNnT9577z3OOussPv/8c0499VSWLVvGYYcd1opKW4fJkyczefJkKisryc3NJTc3l5ycHAzDoKSkhNzc3EY/QAC5ublNNvqm4hqLyc2Ftxa9xIRLr6Loew9p+f0IlW8jHT8/v306X2yrYce+WuYs38ihBV0Ye3gf9Cof326vol9IZUjvfPKyvEnR3ty4ROo9Gbrau/ZE9bfldtOWtSdDV2u3m7asvaV1yTbf8rpai6SbvO7du7N9+3YqKyvJycmJG5efn8/y5cs555xzWLNmDaeffjpLlixpRaXJQVGUmK9E4hMtd39ievfqwdr332XZqjWs+fR/5HU/n1GjRpGV7uZkX5DlX/zIl4UlfFO0lx+27eOYghxOPKIHW0uq2FPhY3DvTgzonovHrSV0vpbU3py4ROu9tXW1d+3N0Z+K77EjaG9tXfsT05JltTXtLakrkbiOoL2ldbUGSZ94cfjhhwOwYsWKJmNzcnJ49913Oe200ygtLeXMM8+koqLiYEuUxEFTFc4eewK/vO4yzjz1eEKGwfZ91aiKwsQTh/DL8w6noHsOuiH4uLCCv//nG3aX1aIoCl8V7uGj73eya191k2MqJBKJRCI5WHz//fcsX76c77//PtlSWpykm7wzzjgDIQRz585NKD4jI4O3336bs846i8rKSvx+/0FWKGmKDK+bUQVdOHlUH4b36UQgZLBjbxU5mV6uHz+Ky08dRl6Gi2p/iNfXbOKllesIhHTKqv18/MMuvthUQlVtMNlvQyKRSCQdiL1793LqGefw05vv5em3v+GnN9/LqWecw969e5MtrcVIenftRRddxNSpU3nzzTf59ttvGTVqVJPHpKWl8cYbb3DFFVfw6quvtoJKSSLkZHo5bGA3+nXLpWh3BVtLKimr9lPQPYcbT+3NtyXw3jfbKS6rYd5/v2d4n3xOOawPG3eW8ennXxIs384pJxzH4Ycfmuy3IpFIJJIUQQiBKcA0rVmrhhAYhkltIIRSE8AERHi/KQRGOM40BYZpUlNdzb5aYcUIMIVAN0yuv/oKtCFn0SNiAmH1nq1cfPnVvPff9jEcLOkmr0+fPvz4448YhkGnTp0SPs7tdvPKK6+wevVqTFMuuptK5GV5OSKrG/265bB5Vzk79lRg+kMcNbg3RwzqzqqvtvHphl2s217Ktxu3snXVP3Cl5+LJ78vf5r5GrjvIv+b9g0H9e6fEmAaJRCJpDb7//nvef/99QqEQhx6auje7USYqvFyIrusEgjoVNUFQFMdwOf+GjZljuFAc06YbJrppYhiWKQvqBrU1VeiUEgiZBHWdoG4S0g1CuoluGAR1k2DAj4FGyBSEdIFuGOi6VZZuWOfTDRPDMNBN0M3wNtOkrPhHimtVhtdb1D+ra3+KN7r5/vvvm3ysalsg6SYPLKO3P6iqysknn9zCaiQtRX52Gp2yutOvazbffFdJRXUAU1E446j+HDesB0s/L2Lh32I/Hu2iy67m6Tkv0rtLNt1yM0j3pkRTlUgkkhZn7969XHz51ZQG3JDTi6dffod8b4hFL8+nS5cujR4by0xZGSxBVW0QQ/WHM1giKhNmZ7lqa6rZUyOcshzD5RgiQShkUFNTRUjsJWQYBA2TUMgkZFimK2SYBEM6em0l+reVhHTQzbAhC5djGy7d0NFNBcM+V9jY2efSDevcB73Oi7eR3bUg5j4lpzebNm2SJq+lWLVqFe+//z7Z2dncdtttCR3z+OOPU11dzemnn85JJ510kBVK9hdFUeick0avzlkc0r03W3ZXUryvGhQ4vo/Cu526xHw82t7v0vnk86/o1W8gWekeenXOomd+JvnZaUl6JxKJRNJ87ExVUDeoDYQwTSsTZnUrWtmriZOuRAw8M7rbsGQr5068gufn/otQ2AQZJuiGQW1NNTr7COgmQcNE1w0ryxUyCZomum4SChmEQgF0YWW6dN1AN4STMXPMnG6brjrDVRdn/Ww2a3JcWYvWn6qAS1Nxu7TwvypuTcWlqbgUgdvtrtvm7NNwaQouTUVTFVSh4/Z4nd9dmkrxYA//eO6ZmOcUlTsYPHhwi76PZJF0k+f3+7nqqqvYtWsX//73vxM+rm/fvlx22WXMnTuXdevW4Xa7D6JKyYGiKApdc9PplpfJ7vJaNu8q5+P31uPN7xsz3tOpLy+9/SHjxmczpGcetf4QhTvLyc300DVToZ+WRl6WV3bnSiSSFkWEx3QZhkkgaFDtC2IKy5gZTpei9bMpBLpuUlNdhas8ZGW9wpmtQMCgJhDCHwzhC+r4fbUEhYtAyCAYMpxuyJ1bN1NcozK4frdht/6s/1Llzif+TUaXPlHGLJkLEmiqUs9QWcbLpaqoIoQ3LR1PhCFzaXVxkYbL7dLQVAVNVdE0Jfyz9buqgGoG0TzpqKqCEPa4POH8jBBgBBCaFxQF+0pgV40CKKqCKkAx/SiudFRNRVGsGac98w8jQ/E1WNS/es9W8j2hdpHFgxQweYsWLWLnzp2MHTuWSZMmJXzcJZdcwpNPPsn777/Pa6+9xqWXXnoQVUpaClVV6JmfSbe8DEIVx/H6W2/HjKsqKSK3z3A+XV/Mp+uLycvyckj/Lgzonk1ZmUnRviBd8zLp3SVLdudKJB0YEdE9aZiCkB7CH9Qpqw4AVobKMEWUSdMNk5rqStR9AQxDEDIEwZBOjT+EL6DjC+n4gzoBv4+AoRHSLVMW0A2C4XFhId0gZIT/DRmEDBH+3erG1I3EnFjJxu9I79wv5r6sbgXs3rmNrpnd4x4fZbS06IyWpgg84UyXtU9z9rldKpqioBLC7UkLmzAVl6qghQ2ZpqqoqoKmKGhmAMWThqoomMJ+fBdh4yVAmKj+fRhpnUFpuHCHYr/MAKo7DUUJGy5VQcUyZPbaciqg6OBOS8PtUlFV1crMqSqay9KoKBDy1ZCRlY2mqaiKYr3U6H8VBWqrq8jJzcVlm7zw/mWLX+bSK6+leKPVTU7lTqebvL2Q9Cvj4sWLURSFX//6180+9pZbbuG9995j0aJF0uS1MTRV4bQxx9Atw6C6ZCtZ9cbkdU3T+dVl4/l6yx5++HEf5dUBVn+3g9XfQfe8dEb270K/2iA79laRle6mZ77Vnds5J531637gq6++4vDDD+eQQw5J4ruUSNoerTH43wiPu7LHhum6QWVNgBA+Z3ZkpCmzZ0PWVFWilPgtQ6Vbpqw2oBMIGfhDOoGggT+oE6wpI/B1pTU43zFjZrRBC3dfBsP7dOPgTODTVAWPS8PjUvC6XXjcLrxuDa9bw+PWqMw6lHff+FfMY4Nl27jy4nPpP2CwZbY0FU0BxQjiCme5UBSEWZflsk2XEALFCGBqXtRwj0d926limS7FlYYaNlm26SJsmhRVQRECxTBxp9kZOMt0aWrYeGmWmSor9tO1V3dcLs0xh3a5mmpl22prqsjJybWyemqEKatnzCoqKpp8skRFhZbQEy80M0BOhqdBXPfu3Xjvv0v45ptv+OCDDzj55MkpPeFlf0i6yfv8888Ba7285mIfY5chaXu8+vJ8Lr78anZtdKPk9CJUth2vWcuUex4mJ8PDOccM4PzjB7Jhexlfb9nDxh3l7C73sbt8GwrQr3sOw3p3Yl+lny9/2MxfHr6XoJqBltcbnn6ZfE9ig5clko5OY4P/O+V3djJiplk3a7GyOkBA1EZl0iIzZ8GgTm1NFcJdi26Y1PpD1PhDVlYsFMIfNAiEDAJBg2DQT8BQo0yZPZvSyZjp4YxZeFvjlO9XPagKeNwaXpeG26WS5nFZv4e3edwaHlfYpLk03C4FTeh409Jwu1zWWLFwtskVzjAZpokI+TBVr5UFA6d7kWE9+OjNf8R8FniG4uPwQ0ehKNaQF9usKbqJ5vU4GTqnq1Ozuk1dmhUb9NeQkRnOdNUzU5GmKzsnx+pujTB6WjNNl2EYbKzdy8CejT/WrIIguU0MtWntBfJHjhyJ2+1myJAhrXre1iDpJq+kpITs7Gyys7ObfWxOTg7Z2dkUFxcfBGWS1qBLly68998lfPfdd3z11Vccdthh9Bs4lNIqHzv31VBa6aM2qNMtL4OJY4ZgCpNvNxfz3bZKtpZUsnW39dJUhR/efJyex15E13qDl8+/+Ke8/dYbZKW78bjiP5dQImlPiIiMmD1jUTesjJnfrIkaZ6Ybgp9e/lPUweOjBv9XlWzl9PMu4Xf/9xSBoE4gpOMPmeGfDYLBAEFDCXdVhgf+2zMudXv2pUFIFwmYsv1DUXDMl228XOikZ6RbmTNXXdbM41LD48UsY+bxpuNx1w3Sd2kqCpYJE6bAtI0ZEaYM6xchrG3W+LEAijs9qttQURXH6LlUBQyFjIxs63wuq2vUNmf/nDeHX/7iF+zc4EHN7Y1ZsYNOnhBvvPJPunbrGmXQFAWqKivIy8tr0ig1lemqM11pKWW6JC1H0k2eNZ5i/z/8dlr6QNi+fTv3338/S5cuZd++ffTs2ZMLL7yQadOmNWvtPoAPPviAv/zlL3z00UeUlpaSn5/PoYceytSpUzn33HMPSGd7ZuTIkfTu3dv5QsrJ8NC/Ww7VvhD7qnzs2lfDvioftf4QA7plMmpgT0KGybdFe/l6yx4KN27AdGc3mKmb1a0/Rd+7ePH1lQwdNpy8LC+dc9LJSveQlebCbIWp+hJJc7CXwqgzZmaDrkx7nzNBQDeora6EXbWEdINav05NIDzgP9yF6Q/pBAI6/mCAoK4QNEyCIcuQlezYwu4alaExZrrv+NLDzBeXkNVl/5a6qo+iEGW8bIPmVgVpXk+4S9M2bPZsSmsgvyZCeNLSrW2qlTFzTJm9GK5poPj2YqZ1RtQbG6YQHgOmgGIEUD1p4YyVihI2XG5nooCCCGlkZmXXTRIIZ8ScCQPhsnw11c6Yr6h9aribVIhGM2H9uuXw0ap3Euo2FELICWeShEm6yevSpQvbt2+nrKys2YaqrKyM6upq+vaNPUMzEQoLCxkzZgwlJSVMmDCB4cOH88knnzBz5kyWLl3K6tWr6dy5c0JlPfTQQ/z+97+nS5cunH/++fTs2ZO9e/fyxRdfsGrVKmnymomiKGRneMiOMHx7K2vZtmsPFQEdX9BgSO9OHDW4O8vNrbyxY0DMctx5fVn83zUc7Uunc3Y6nbLT6JTlJd3jwqvqdOsSpFNWOlnpbrLTPXjcddm+trI4qST5mBHdlaHwwrDl1QEESoQpi1h/zDCprq6KGmNWa8/IDOiOMfMHdAIBqyszoFszM4P1xpcFwzM1rQkERoOxV01RsrmQzK79Y+7L7laAXlVCdt+BURkxr1vDrRI2ZnXdmG6XtdyFbZQcYxZe1kILz5a0n2Bghm/0lfBMSdvA2F2a9rgtBVANFdXtQdO0hqbMnu2pKlTs8dGtVzfcbldDUxZhzHIdYxZtyqBpYxYVJ4Ixx3w1l/bcbShJDkk3eYcffjjbt29n6dKlXHHFFc06dskS67Ejhx122H6f/+abb6akpIRZs2Zxyy23ONtvv/12nnjiCe69916efvrpJst55ZVX+P3vf88ZZ5zBq6++2qD7ORQK7bdGSZ3hy0p30ykNNE86pVUBdpZWs6/SR9de/QmVNz5T98vCPc42t0ule14mXbPd5OeW0zk3g/ysNDLT3GRneND0Gm679RYqDS9qMxcnlbQMrWWwTVOEV8g38QV0lJoAhqBuJmaMsWjVERMAgiEDX1DHF7RmZvqDOv5gCH9VGYHvqgnoptW1GR5TZhs0K4tmjTELhH9uycSyokCaPcjfo+F1u/C6VTwapHu9pHlcjjnb10fl3/Ofj1mOXrGd6665kD4FQ6IW3CU8sJ/wEha2KVMix34poBoKqseLGs5yOWuc2WueuTTcqkLIX0Nmdk7dzE4lOnOmKgq11VXk5eXi0rQGpszGMAw2BksZ1Cuv0bFhqhEgM80ts2KSdk3STd7ZZ5/NW2+9xUMPPcRFF12E1+tN6LhAIMDDDz+Moiicd955+3XuwsJCli1bxoABA5g8eXLUvunTp/PMM88wb948Hn30UbKysuKWY5omv/3tb0lPT+df//pXzPGFqbSOXzAY5I5f38KTzz+XcH2nGlnpHrIzvPTvnkO1L8ihBV355zNPxBy8nO8Jcf3E09mxr5od+6rZta+aoG6yfW8V2/cClAKQ5tHolpdJ15x0Fs2+j85H/oRe9cb3nTPxCua++JKzMKe9sKamKvhqAwgtYC1NEB4AHe9CJIlPoqv/22PMAqGGa5k5q+hHGLPamiqUfUFrEH94xX5/SKc2aHVj+gJBfD4/AVMNTwzQw+YrbMrCGTPLqOkEdeHsi79Cf2mz37+CNfA/za3htY2YZmXMbGPmdWukeVy4w2PM3JqKK7IrU9PC64uJcL2Y1tCEiLXFlAhjVtD9MN6c33DNsKqSrWQqfo44/LAoU+bRrLXMgoFaMrOynbZevztTVaCmnjGLRaLjx0TIRZrHJY2ZRJIgSTd5119/PX/4wx9Yt24dl1xyCf/85z+bnIRRU1PDlVdeyQ8//ED37t259tpr9+vcK1euBGD8+PGoavTYjezsbE488USWLVvG2rVrGTduXNxyPvroI4qKipg0aRKdOnXiP//5D99++y1paWkcd9xxnHDCCful72Dxwt+eZMP7q5n7zLP8/JbmL12TamSle8hK9/DO6y8z8dKr2LHBjZbbm2DpNrxmLbfeO4Oc7DS65WUwengvPC6VSl+QXfuq2V5Szq5yP8WlNfiDBj+WVPL999/jV9Jjju/b9I3GX+YvoVf/gVEz7DwulXSXTlp6KV63y+kCUsOZC4/busApup+s8hAeJ0apW47AMYY4mR/7Yr0/JLOr2RrrWLdEhr20g226qmoChBSfE1v3DEy4ZNJPYdD4Bqv/n33h5cx6Zl54zTIre+YP6Phqq/GbrnBGzSCg6xFmzO7KNAiFdIKGiDJtia5llihWN6Yr3JVpkJFuDf5P84RnZ7pdeD11bcaelel1uerWNtMUZ3yZIQSmYSJ0f1TGzKZuQD6ophLuyrTWP3OyZC4Vj6Y5MzFD/hqysnPq2l/438WvvMi1198YnuneG1G5k87eEG+98e+Y2WvLmKnk5uY0asz0gPV+pTGTSFqfpJu89PR0nn76aS6++GL+85//MGrUKG699VbOP/98hg4dGhW7YcMG3nzzTf7617+ybds2VFXl73//O+np6ft17vXr1wPEHf8wZMgQli1bxoYNGxo1eZ9++ikAPXr04Oijj+brr7+O2n/KKaewcOFCunbtul86W5JgMMi/nnuOl8+cyE9nP8W111yDNzcn2bJahC5duvDBiqXOTN1DDjmU/oOGhtfSClFa5aeiJkBNIIRhmHTJSaNHTj7etCzcbpWKmiDFpTWs+u9GKroVxDxHeuf+fPLFt3Stjv94NUWh7oLuLLcQzrioJm63B6/H5cz084S7zNI9mpOpcYsgmqfCMn6aGh6Abg9SD1+sA7VUBBTnET62SSwv28fV191AWdCDEs6EdfKG+PeLc8nv3LnBsy5t0xWkFmvx2BjPwTRMfDVVFFcZYfMBhv0gcNMyIrphZdZCwVrQyjAF4fFidQvIBg0TPaQTDFqPWwo6x5kYpsmuHzezu1aLs/q/xn2zF5HWqRchvWVnaro1Ndx1qYb/BrYxc1kZtYjsmUtT0QiRlpZRZ9Y06+8AVmbfNE3Mmj0Y3vyowf/2JAFr1X0FzfSjeNIcs6+E1x2zbgzCM0FVBaH7yMjMxhXxlABrfJt1brsrs1OnPMe8xTJVjRmzzjm9+WDF0na9ZphE0tFIuskDmDBhAn//+9/59a9/zbZt27jrrru466678Hq9zmSMsrIyAoEAYH1ReTwennzySX7yk5/s93krKioAyM3Njbnf3l5eXt5oOSUlJQA89dRTDBw4kBUrVnDssceydetW7rjjDt555x0uueQSVq1aFbeMQCDgvD+AyspKwBpfYr9M08QwjLhl2DOVDcOIe9f8/Iz/4+Ju/chwubmoZwHPPzSDn/32LtROuc0uK9G4ltKeaNywYcPo2bMnOTnWhSw73QWkM7BHDoZhUhvUqfXrVPuC7CstpVpX8Id0VAQ9OqVz8nGH8c3nH8Us27/vR044YQxZXfMjZi2G/w3q2D1i1r7477cp7IHt9ss2eO7wbEOPS8WrCrxeD+6IcVfpHhcz7plM5iHn07Net9vZF17Ow3/5O7q9MGz4mZfBkIEeDBASGqGIRyfphmXuQuHuTkPX0YUS9XxL5zmX9jF6xLH7McCsqdX/S4u30zW7h7NNUxW8bjVsxlzhsWdahDGzt6m40ElLs5bMcEdktuxV8A3DRAT9mJrHWdHfxnlUkqKgIMJZMxeqvWSGqqAphP8+btwK1OKlS/dOuD3uqG79yOyZr6bKGfyvhg1e/cytEILKykqnPcdCCIERUHGpoCDizhpP9POjaRqDBw8+4M9sS36uEy2rpb5v2rL2ltaVit/zra39QHTFGxvaGqSEyQO48cYbOeaYY7j33ntZsmQJQgj8fj+7du2KilMUhXPPPZeHHnqII4444qBqsr/km+pmsBuGEIJFixY5d7+HHHIIr732GkOHDuW9995jzZo1cbtuZ8yYwfTp0xtsLywsJCsrC9M0KS0tZdOmTQ26liP1BgIBvN7YC00Gg0H+OXcer467EIDLB41k4muvcsIpJ+Pt1hUlJ6tuZlsTZSV6TqBFtDcnrjllpYsAueledG/divjdhvQk3aiIPT6JKi44YbBVbjgbo9jP6zFCmIqLoCEI6tYroJvWumK6SSBkWo9K0iFgiPC4r+j9evjibA3ON6nyNW/CTvXe7ZSHvFFdnWAvheHmj8+9RWYLLYXRHKz1whTcmhJ+PBGW0bJ/16xu7XL3IFYtfS1mGcHSrVx1/kkUFPTE47aO0VAQZgihaIBS94glBzP8AkwdRTWt1fxNBTUY/myHH6XkUUARBm7VEzWmzJ5IoIS7RRVFQQ+F8Hq1BuuX2e3NNE1Cwo8WLAVdxQDqXz7sdlpTWdaqbb4lPq/J0JVoWS31fdOWtSfjPbZ37Qeia/jw4XHLPNikjMkDa6btW2+9xY4dO1i1ahXr1q1j3759AHTu3Jnhw4dz2mmn0bt37xY5n52pszN69bGzafEyfTZ2tnHgwIENujfS09M566yzeP755/nkk0/imrx77rmH22+/Percffv2ZdCgQeTk5GAYBps2bWLw4MGNzhhr7I7/uaee4tKBI3Cr1vEeTeOy3gNZ/dYSbrh4EmpWDq6B/VA8noSyB4mcE2gR7c2Ja4my3nljAZf89Dp2bnCj5vRGr9hOthbgyaeeJTMnj2B4oddAyAzPwjQxgj6E5sUlBKop8JiCzIgyFSHACKK4vGia6piHumUdFBAQ1HV8vloMxUNINxtmDMP/+vwBAgbOo5z8IYOSsl1kx+lqzu5WQG1ZsWPy7PXKrMVaweN2Oc+0rFuSIiLjhYHH6w3HhNcws2dKuupW2VeMIJ60dKsLMyIzZXUBW1+oImSNMTMjn30JcGgBn73zUpzV/wMcctTx0c+mBDQzgDcjy8p02nrD3ZrOQ9FVBX9t5JIZOGMmbY0dvc03R3sydCVaVkvVfVvWnoz32N61t7Su1iKlTJ5N7969ufLKKw/6eYYNGwZYY/1isXHjRoAGYwPjlZOXlxdzv20CfT5f3DK8Xm/Mma6apjmNTlXVqN/rI4RwYuo3rmAwyEvPPMcrx58Ztf3yIaO45K1X+OlxY0gTAsMfxD2kADU7K25ZiZ4zkgPR3ty4liirR48eCY9PMk1rtf/y8goyMrMwTKJndoYXr9V1w5rh6UonZJhRi9Ea4WU8TCEwRPhxSKpVX+lpbiKTUwrWKvuaGURxp1n1GjY+Ww/N5pEnZsbUqZdv59fXTWTgoKFoEXerhmliBn0IV5rzfuzuSvt5mMI0wQwgVGvwv11btqy6TJdA0Q0Ue8JIOM2pqApuFecxT4qpkJaeicul4Q6PK9PCk1VemPMPJt/8S3Zs8KKFV//Pcwd59d/z6datW7R5U6wbooTWMqswyc3NOKjtJpK21uaboz0ZuhItKxH97V17S+uSbb7ldbUWKWnyWouxY8cCsGzZMkzTjErTVlVVsXr1atLT0xk9enSj5Zxyyim4XC42bdpEMBjE4/FE7f/2228BKCgoaNk30AxeeO45Lu7Wz8ni2Xg0jYsHj2T+vHlcf8GFKKOGE6z14RrcH5HmiVNaxyGRxUlVVcGjWGPAstLjL4haN+i9oSGxH9ium1a3cUV5OemZ2c422zAaprBmlwYNamqqwJXmPFzdMAW9+w8kXdTGzISliVp69RtEUDdRVWE9nDycZVNVBZfbFfEsTDXcrWpl9jS14XMw7bXMIh8yrih1i8zambLIZ2XW1UMji8z2yuPj95YlvPq/RCKRSGLToU3eoEGDGD9+PMuWLWP27NlRiyFPmzaNmpoafvGLX5CZaXW6hUIhCgsLcbvdDBo0yInt0qULl112Gf/85z/54x//yAMPPODse/fdd3nnnXfIzc3l7LPPbrX3Vp8v1n7C5vJiln65BwSYoRCKboAQ6MEg/dxpGBu3YJaW4znxGELfbcDo3hmRlYWSQmv8tVc0TUXTwIOG8AhEyEtubnoThtHrGCX7aQu6afLGwn9y5TXXW13NEZmwRf+eT7euXeu6OsMmTVGgqrKSTp3iPwvTOl/j65jZcS21yKxc/V8ikUgOjA5t8gCefPJJxowZw5QpU1i+fDkjRoxg7dq1rFy5kqFDh/Lwww87sTt27GDEiBH079+foqKiqHIef/xx1q5dy/Tp01m5cqUzu/a1115D0zSeffbZuN25rcFTc19wfrYzKdmo6Ju2YO4rRwQCBFZ8hNhXRmDpKjwnH4ehBwkZAveQAaiZGUnTLmka27S5UenfpycfNmMpDKt7IfndChKJRCJpWeJPI+kgDBo0iM8++4zrrruOtWvX8thjj1FYWMiUKVNYs2ZNws+t7datG2vXruW2227jxx9/ZNasWaxYsYLzzjuPDz74gEsuueQgv5Pmo+Zm4zl0BFqfnqjpaaSdNw61e1cIhgguX41WuA2jeA+hb9Zh7G3+yv2S5DJy5EhOP/10Ro4cmWwpEolEIkkCHT6TB9C3b1/mzJnTZFxBQUGjY4Dy8/N5/PHHefzxx1tS3kFF8XpwDx+EnpmBseVHPKccj75uI/o369G+XkeotALlmMMIfbsec0A/XH17ojQyxVwikUgkEklqIK/WEhRNw13QB/eoYagZabiHDsI99gSES8PcvovA8g8xK6ow1hcS+mETIhBMtmSJRCKRSBoghECYJsIwEKEQIhhEBIIInx+zphazugazshqzogqzrAKztBxfcQkP3n0PgZraZMtvcWQmT+Kgde2Mkp6GvqkI1TTQzz4VzwefIiqqrHF6Y46xPkA+nzVOr508Dk0ikUgkB45jsABME4TAfgyQME2EaVpGC9Vahsk0rd4xIerihUAYJkZNDXplTThOIEyD8EKbYBiYhkHI5yPoclvbTAGGCSL8M/byTwZBXSegalZZQlhrPwnT+XfuG4vZ9vmXzH3yKX5192+SVHsHB2nyJFGoWZm4DxkKaV7E1m14zjoV/dOvMLZsI/jhJ2jDB+EeOZSg7wfcgwpQeiT/ebwSiUQiCa9nGTZWwjSdDFYs02UbL6OqEiOoW4u11zNlkWXpNdWEdu9DMQWYBsIwLZNmWObLNAyMqnJCpTUYUGfe7BeWeQsZOkFFRUGJ2Af2r9a/At000FV7rTlrsXIUBVQFBQWhgGnqmJrbGkIUfnpN5EtRFQgvPK+4PeE4QLH/VQjqOv9+9x1eHn8RP50/nxtvn9pgGbS2jDR5kgYobjeuIQNwqQrKzj24jjkctWtnQp9+hbGuELGvDPeYYwh9vwF9Xyl3zHiIJ+f8I+ZizhKJRNJesbNTdtcgUGeSIgyOMEyrm1AoTjZJRGSu7Jev1seDv7mbvz/2OOleb53JMoxwBss6V8hXa2WwBGAaVgbLtDNTlqEyDZOgESKguFAU27wRkcEKmzcMQooWXrjcov5ce9MUGJiW6VJV53GAkS9hvy8hEKoS23ghUPQQisdbt9+uM9NA0Q3rveo6qs+PQLHem2EgdAMM62WG47RAAAPFeu/2sYYR9bMwDFwhnUBE/UXGzPvmcyZ1Dz/PvXt/XnjuOX5+880Hs9m0KtLkSWKiqCpat854unRG37gFtU9P1C75BFasxtxTSmDpKrynjmbu4tfY8OFHPH//g/zsuutQMjNQPB4UrwclzQseucaeRCI5MBI1U3ZGSfgDmOWVKIoS00w16A4EKytld/uZJkI30H21BN0elLA5srNWlqGyzJKVnQoSUN3hskT4ccmRGTNByAgRVLSw1xF1j4uJyGC98MZitn3xFfNm/Y0bL7gwal+dUQJTGPUyWERnsBTVMmOqQHF7rYxWlNmyM2KgBvwomgslhgGyDRa6juYPIOz61I0Ghsk0dPJqa9Fd7vA20zFZ6BGGS9fxh+vXKT/GhEYXEGiiXWhAIk/3VnCeYB1F0DBYtPE7Fp57KQCXDxzBZU8/w3U33dRusnnS5EkaRe2Ui+ewEYQ2bUHsLCHtgjMIvvcxZsk+qpas5N/L3+TlMy/iitde5cqxZ+BVNYQCiqKC24XicmFmpGHUVqFnFEN6mmUAvV5r/0GYqRsMBrnj17fw5PPPyeyipEPirAJQ7+IZOSidWItVC0HA5+PB393Hcy/8g/S0tLhmSpgmZlUNpmldREX97kBimKmIbsK68VXh7JTfR9DlQUEkYKbsrBSAPQbLKt80redIh0oqMCAiLWV3+YW7A4WBrmgoddYsHGaZJgEYwsTUXDEyVzhmyZKhoGhqXXdg2ESB4vyu6EHLcGkR33lCgGGgGCaBQIBX3lnCy+Mv4op33uaqs8/Do6pRRsn+VwuGM1gxslzC2aajhXQCpqgrIzImfIzLNIn/wM06NKCpKXeZYNV5IyiRdR0LVQVNQ2gqqksDzXopkT9rGmgqIUXB7XGHf6+LUTQN7HhVxYdJuteL6nJFlffSW68zadihUc9zv6hbv3aVzZMmT9IkSnoa7pFDUTIyMIq24Rk7Bv2b9cx7dQGT+g0mw+Xm4p4FzH3yaa4ffw5qpxyUnBwULRMhTER5JWZtFUb1JoSiWB8+twvF7bYyf5kZhBS4/be/YfZf/4rX42l4UQnf+QrTxKitxqjxW1+89gUDnLg58+ay4f3VzPnzY9x0/fV1H3znA66iuFwITZWPxTpAYl34RTCE8Fv34FFZFLPuwm9WVWHoZt04ILsbKcJQ+Hw+HvzNb/n7o49bZsM6YfjfuvMbvlr0sspwe4jQZf9iWuXpfh+hPWV1T+Iwo+/tnRjPnqiyoi5JdlkBP0Gvty4ush0JgSFMjPJSgn4DTVGi99tFmSbBYJCA2xO2CvVPF27zQhAMBcJx9cpy3q9JUA8S0OI8acSOM00ro9Qgrq7MF15dyLZPP2fOAw9z48SLoroAnS4/RLgsIzy+iv02Uw2yU7HMlGKNwRKKGmGmGhou67nKAioFSl6+VVbYSDrdmoZpdQcGDOv7yIwYW2ZnlsKZJi0YwFDUiDLMKCNlH+cK6QQbdK3a2S7r3C7dwGeadWUZ0XZo3rqvmNSzwPk+feHPj3LN8MMb/i1JPIOlEjuDFRdFifiOrDNVaBqmqqC5XHXfoy7VMVe2KSsLBcnPykLVXGGTFRHjsgxXjTDJ8qZZ5ccwZYpitZ/KYIBMj7fRp/AEggG8jcTYcSIYwFUvLhgK8u+3/8OCk8+Nir+sYFi7yuZJkydJCEXTcA3sh5qZQWhTEWLoABZtL2Th6RMAuHzIKC5Z8gqXdeuHJ/IBz243Sqcc8jPSMLp1hU65KDnZKKqK0HXE3lIo3sOcN15j45q1zHn4T9zwkwvrLvxRn10FMzyGJBi+aDif2XBsMBTiX/Pm8/KZE7li3jx+etTx1p2ewLqzVlXQVOtfRSUkTALpaaher5Vh9LijvnT8us6Dd9/Ds888E2E0GtaPEMIac4PS8AtH1Iuxx+XEwYqrtjIkdlkxMjJmdTWmIeJ+wfl8Ph68+x6e+dvsuvE99QdX24Ova2vQy6qsu2z7ImVf/MIXrpDfR8AVrku7iyXCvAH1xgERZdCdjIwwCZk6IfvCr9Sr0vD46nlvLGbbF18z76+zufEnF0Z1b0XWg25aY4riftGHzYYhTMts2Magfr0DRtRgb/twpWFZpoEZHp8UCyEEIuBHGOWYsWLCFzJh6AgtWJdVizBKUWUZOkIX4exQvRjFjjERRGbo6pdZl/wS9bbbvwR1nZffetPKJv3nTa6ZeBEeryemmSI8vgq3xzLrdgbJNFFsE2MYqIEgItwWIo2UiDBflqEKRhgq20iZdYP8w119Abv9RY6xijBOwjTpqev47UxgHFqyO1AlsQxWPIKGwaJN39d1Gw4ZxSVLF3DFsSfg9Xgdk6RoVpYrpCi43e6YmSs7y4Wm4hOCdK8XxeWKMG2qEy9UlWrTIDs93YpppD03ZboMYVJdXka3vE5oSvxyCAZQEzFm4TZt9bWGW239m0U9hBk0IrrJ7Ticv70wTExTx1BU67sL63t13puLubjXgJjPc29P2Txp8iQJoygKWo+uKBlpzPnj/zGp/9CoNPfFQ0exoHYv1xx6NGZZBaKyGkIhRMk+MgC9aAd6XWEoOVmonXLRszL599tvWReWt//DT8eegUfVwh9o22jYd9smWiiIqajhrg7bjFixc99fzqTeg6y74d4DmbfwFW449wJEWhpKmsf6EvS4UBTVGruj64jqWsyqGutiIYTTnaAQHiPz+Ze88PCfuPEnE+PWjRCCkGkQtA1CHCMYFdMwomFczEuD9QUYEmGzqyj1iwBg7pvhZQH+79GG43tEnRcQZjjbomo4F/DwBd3OqgghMIWB0Nxhg0z0BT8c64wDcnkajBcSAIYAQ0cJBMBZ+sCsGw8U/t3v9/PvJf+x2sSSt7jypNPwuN0RmTzhaNf0EMLlshNMdRURmWETVpypuSLtU1SMEAJN1zE1u97DmTQ7LiJeM3QMLVxf9btGhcAUghy/D92bFl4som6f49eFwGXo4XqPp9v6n8swCKnhjFmklgiNdoxzXL3sonNO0yTk/PEjy4K5n66uyyb1KGDOnx7h2iOOa5idCv/sMkz8TWTDEzFTkJihSjQzFXcQiKKEb/I0hKpY3YGqbXxUp3vP/ldXwO12WabI3q6pKKptpKztfmGS7vXUmayIMhRNRagqNaZBVthw2ccq4ZvOlxctZNLwQxt8ny7y6tx46aSot3CgGaz6MQQDVq9KREx0LwoI00CEdISIuOl0elsAEb4ZDAQQ5VXhIYmRMXY5JiYGZsT3Vt29W93nxDJ5JkIN15Xd/e2MJ7SKVIRpfb1o1k07mhKuc8363WV9B2mhIK6MzHAWWANV4etntrOldBfvfFaCQBDSdTweL6gKumEwcO0nIE2epCOip3l5+T9vsWD0mVHbLx80kks/fJvrbr+VNLfHGiRdUYVeVs6+XbvJ8wehvBKzrNIyfxVVGBVVzF/3FZP62MZsAHP/MituNwXEvxgEDYMF76+suxsefAiXLHmFS7Sc6OwiWHfFXi9ur4dgRhpKWhpKuhfF60VJT0NJ8xLUVP699O2w0Xibq86fYBmNGAghUIRAaK4YY53CX1wIlJCJcGsxYuqVFRIIj5t49/9WTBDh9tSZsci6CIX4d+T4nvMuCI/vqct2OGN3DNPpllJsQx3VHRW+oIdCVr073VamtXZVvYyLSzfwC7ubKqKsCDPgBvxxayDcddV7oGPW5z75VKNdV4ksz52IiUg0c5NIXDZWdqexDI8KdTc+TcQ1lSlKJKaxuKBhsODTNRHZJOvzc1nPAQ0/P2Fitk5VrcuYa2Ez5YylUqNNlW2WVJWQgvX5csxRXUZKUa3uQL9pWJkpuwtQjTBn4X9NBbbVVNOvUyc0rW6IBqrqZKoS7Q6sTNBM+RI0U7EyWMFQkJdfe7VBt+HlA0dw6aJFXHXBBDwuVz3DFcLUzahxjnUZ87C5Mk1MQ8dQIsdDRieLTVNgYmCgoaq2c7L31y03IhAIYSA0I3yTZ9/YheNUDcWlQMiFkp1p/b3tv2Fk74mq4gr4LMOlRnS7q0q4nLqbRndNDZ5wr0/UOcM/CwX8VVV4cnNRtPiZfCEErooK3Lm5UTFPL/i387NhGGzcuJEhQ4agxWnrbRVp8iTN5oXnnmNS936x09y9Cpg3dz7XXzgRxe1CSfOi9e1FVX4W3fLy0RRrHJyo9SHKKvDv3cuidxay8EwrS3b5kFFc8s5CfnrCyXjcnrouVvsLQVUIAW6XK3yRqHu9uPo9Jg0dFX03POQQ/l2ylWtHHY3w+xG+QN10e70WpaYWM85jeeet+4pJvQbUjZF5aEaj5tNN0xmLRGJaoqwG43tm/Hm/jHMkiZqIiLxVEwXWmYHIi0EQwaLN61h4tpXBuHzIKC5ZtoifnjIWjyvCZIe/sHUhcKlq+Fe7KzaiqzIcFzJN3Hb2TYkuw/7ZiglnDhQloqi6YwQKIdPA7VxYGpYngIpggFxvWkT3sBIRYmU2g6aBxxnYH1sTgN/QSXO563XrRnc7+w2DNJcrriY76WiXpdgTA8L7/vnuOw0/P0NHsdAd5Ibzf+JkwOy/l1AVqg2d7LR0qyvQ3lcvI9SUmbLjAsEAniaMUlNmygo0MVSBkpVpTQCLUY41TCHcfexkY6ONkjBNhB5ppogbZ5o6puJz4gT1jBdWJrwug6VYMSjMe6ORbsNeBcx/+WVumDAx3FWvIhRLt6Ko1vuzM+tq3WdICU+A0/QgrvSMuokJWrRhQlFw+WrxZGaFs2HhTJi9P8JQuaur8ebmOt/DkftRrKE0ro0b8TRilIQQaBUVuOoZrlhxqqag5ubEjxPCMneNGDyJNHkpj/OFVO/VVGyiZe5PzBcff8Lm8mKWfrEHANM0UMPdp7qhM2BXFlqv7tbMu0AQs8aH8Ndi+k2EpqK43dbEi26deWn1KiYNGt7AmC1U/dxw8YSYuvwxLhrBUIiFf3uk4d3w4EO49MO3uf73v8PjdlvvJ6Q7hq+mupp03QB/EOH3O/8GqmtY9HY9o7HkFS4fcUTcrIaw5tg13BGxSYjoa3g8ouPiXPTinM8a3/MDC8+9pE770gVccdRx4e6Iel1T4W4plzu8JEPkxSDCfAWEidfjCX+xRmdhnAu/olBrGmSmpcXo4qrL7FTpIXJsA1SPl175N5OGHhLdJgaPZKFRzQ0XX1avnixzkIiJiNVumhuTaJwhTCrKy+jcxPgkXzCAO4HzmQlkipqKaSwuGAqx4IH3Gn5+Bo3k0pVvc80N1zfMYoe7A/F4oxq16Uy2CXfP6bo1VtU2U45RCpcB1ixcI4jhD0ZMLmmYmTIMAz2y2zr8/RSVnRICI+THsCdW2PtFXaAI6zQ1zeq+swtwZsRaJsy0TaBSL+Nkd/vaQxRCIZS0NCeDRYSZUjQVIUAL+NDsDJZjohS+fnZHRLchhHTd6iJGQTcNBpTk4T72cCdjLxQFd1WVlZmK0BDrb92UoRJCoFZUoDZhuhDh8Zdp3rhfYKl0jTqQsg70nLFikmlCpclLMWbPns3s2bMxwjOvKioqEEJgGAaBQICKiopG75Kqq6uBxhtVInGNxcyY9ZcGcVlZWVFxtQA9uyJ0HcMfILRtGzWd8lEDIcyaWggFCVRW8NKCBSw67YKo8i8fOIJJCxdw/imn4XG76rr5wl/q1aaBac/os0Twz7feaPRu+NkX53PlhRdZa0OFu4BETgY1mR6E29PgPb64aGFDozHsUP6Vq3DVxRfFrK8aPUSmK87sxgRjWqKsfy1ayKThDTMy//SEuCqOcU70fGaC2kWcOCEMhC6oCYWsLmdro73TmjizaAGLTjk/6jinTYw7I3psHoJqXUe4/MQ2w3Vtp9rQEao/nmd22pZQfBEXsshxbfXi1Nq4cQJBIOCj0iSGERf1yonovo918RBQberW+KQYp3PKEgYCLbYmJ0xQI0xMRYnS1eTnZ94LXHn+T+qKVcJlmSYiclFbQcRYTWtTtTBAddUZqPCYKjtGCXu6WtNEUc2w6YrMKgGqilAV/HoIzeN1xlU5WSd7QoqiYAL63j34unZHjRzPBXVPSwACfh++jMwGa8hFZVp9tfgys6Ji6rdrIQSB6mp89b4D68f4qhW0rMwGMX965mnnZ8Mw2LZtG3379o36nq/SQ1Fl1QT8KLWug/o939y4VLpGHQztB6IrLy8vbpkHG2nyUozJkyczefJkKisryc3NJTc3l5ycHAzDoKSkhNzc3EY/QAC5CaTCm4prybIMw2BPVSX5gwc62kVI59m//Y1LIiZv2Hg0jUl9BvHmeyu58dLL6roEwl+0aiBATkZG+Mvd6jrYsGsnW/btZGn5bgBM4TwdEV3XGbDZQ25aeng8mgGGbk26MEJkKQHsS7Hdhfbaa6+x8NSGRuPSxYu58byfNMhq2N0/2aaIc6OrWAkJE7LNxrN5MeMaXFisV7aIvlgHQyEWL17MglPOi6/dmaQQMXZH18kKhWfqOt1MdWZEmALT1MlUAhGD/6MzKNbkNmuMT2a4WypKddgAWOO0DbIjsyjh7so5r7/BJb0HxW8Tb/+HGyZeHFUPaJCjxjCVkd2G4ZkmObHMp+OvBOhGXUz9v1HYKFjZ4BA59s1BjPJMIdhTaZKTk4Ma8V6UiNmxQgiUYIAcO6sWmfGLKFJAdFxEGc6yJEKgBv3kpKVHvD+lQXlCCLRgkJy06Czq+u3bKNq7g6VlxQCEdAO3y9JtmCYDdmWSP2JYnckJd+G5amvJzcpyxkk5GaWwTgG4qqvJzcmJHoPlvHDahLuykrxOnRr9TqqoqGjyO8kwDPaaOp0G9m/0u1JtoiwhBEoC52vJ79O2/j3fnrW3tK7WQpq8FEcJf6nWfyUSn2i5B7usWNoVj5svv/qKzeXFvPPlHssgmKY1+FfBmt20cxveI0dFlSWEwF1RYQ22jTjf04teiYqJdTEQQkSMx9MRIR1PRQWetDRndqcIhZj3wgtM6hvbaFzUeyAvvv4aN1xYL5snRHhyQYyLfmSMrlvTA2PFRGSKMHRrAFyDOBEdo0f3/774+qtc3Htg49onTgr7BCWcIVFRFQXV63EyJEp4iRn7Z6GAKxTEnZbujINxjDc4F3gB+H21eDMzG1zQnUHvgKe2Bm92doOYb559is0Vu3nnf3sBy7R63O5wmzAZWNIZ7+ijnHMKIfBUVFhjhSLrKka2xYmL6Nqq3z4CFRWkJXDRaCrOMAzcGzfibWJ8Ukzt+xEX73ORaNzfX1sYpT2RQej2gPamugM1BFp2/CyXHaeGx1Yd6HdSS35Xtvb3aXv7nm9v2ltaV2sgTZ4kaTw19wXn50Tv0g8ERVHqVjv3eqwLCyZavXN+tXULmytKeOfL96wuxGCk0TAYWJKP9/gjw8Lr9HsqK/HmxBgoHL6zazQmKlzgqazAmx0/TgiBp6qyQcw3z8xmc7llkgSCkG2SwuN7LO1HRBkrAZauJi7WsWaoxYrTKioa1Gn9GFUFNSe7QcxT/5zv/JyQ2RAJDr4WwskkpcIXr0QikbQG0uRJJPWINJ8JT60XAsXjthZUbiSTpwSsZ/o2aUgC4aVcGisrGGgQ02yTFC5LIpFIJO2PuGtGSiQSiUQikUjaLtLkSSQSiUQikbRDpMmTSCQSiUQiaYdIkyeRSCQSiUTSDpEmTyKRSCQSiaQdIk2eRCKRSCQSSTtEmjyJRCKRSCSSdog0eRKJRCKRSCTtEGnyJBKJRCKRSNoh0uQB27dv54YbbqBXr154vV4KCgqYOnUqZWVlCZdRUFDQ4Pl39qtHjx4HUb1EIpFIJBJJQzr8Y80KCwsZM2YMJSUlTJgwgeHDh/PJJ58wc+ZMli5dyurVq+ncuXNCZeXm5jJ16tQG27OyslpYtUQikUgkEknjdHiTd/PNN1NSUsKsWbO45ZZbnO233347TzzxBPfeey9PP/10QmXl5eXxwAMPHCSlEolEIpFIJInTobtrCwsLWbZsGQMGDGDy5MlR+6ZPn05mZibz5s2juro6SQolEolEIpFI9o8OnclbuXIlAOPHj0dVo/1udnY2J554IsuWLWPt2rWMGzeuyfICgQAvvvgiP/74I5mZmRx22GGccsopaJp2UPRLJBKJRCKRxKNDm7z169cDMGTIkJj7hwwZwrJly9iwYUNCJq+4uJirr746atuAAQOYM2cOp5566oELlkgkEolEIkmQDm3yKioqAGvCRCzs7eXl5U2Wdf3113PyySdzyCGHkJ2dzebNm/nb3/7GM888wznnnMOaNWs4/PDD4x4fCAQIBAINtJWVlWEYBoZhUFlZSVlZWdzMoBCCyspKTNNEUZS450okriXLau/ak6GrvWtPVH9bbjdtWXsydLV2u2nL2pPxHtu79gPRpWka2dnZjeo8WHRok9cUQgiAhP4w06ZNi/p91KhRPP3002RlZfHYY4/xwAMP8Nprr8U9fsaMGUyfPr3B9oKCguaJlkgkEolEklJUVFSQk5PT6uft0CbPztTZWbP6VFZWRsXtD7/85S957LHHeP/99xuNu+eee7j99tud303TpLS0lM6dO6MoCpWVlfTt25dt27Y12lCOPfZYPv300yZ1JRLXUmV1BO2trSuRmLasHTpGu2nL2ltbV6IxLVn3bVl7S+pKJK4jaD8QXdnZ2U3qPBh0aJM3bNgwADZs2BBz/8aNGwEYOnTofp+jW7duANTU1DQa5/V68Xq9Udvy8vIaxOXk5DTaCDVNS+huIZG4liwL2rf2ZOjqCNqhfbebtqw9Gbpau920Ze0trUu2+ZbX1Rp06CVUxo4dC8CyZcswTTNqX1VVFatXryY9PZ3Ro0fv9znWrl0LwMCBA/dfaDOovxTMgcS1ZFktWU4qak+0rGS8x9Y+XypqTzROtvnm0d7bTVvWnmicbPPNo7X/1geM6OCMHz9eAGLWrFlR22+77TYBiF/84hfOtmAwKH744QexadOmqNhvv/1W7Nu3r0HZP/74oxg6dKgAxMMPP3xAOisqKgQgKioqDqicZCC1J4e2rF2Itq1fak8ebVm/1J4c2rL2pujQ3bUATz75JGPGjGHKlCksX76cESNGsHbtWlauXMnQoUN5+OGHndgdO3YwYsQI+vfvT1FRkbN9wYIF/OlPf2Ls2LEMGDDAmV371ltv4ff7Offcc7nzzjsPSKfX62XatGkNunTbAlJ7cmjL2qFt65fak0db1i+1J4e2rL0pFCHCU0g7MNu2beP+++9n6dKl7Nu3j549e3LhhRcybdo08vPznbiioiIGDBjQwOS99957PP3003zxxRcUFxdTU1NDXl4eRxxxBFdffTVXX311UqZOSyQSiUQi6bhIkyeRSCQSiUTSDunQEy8kEolEIpFI2ivS5EkkEolEIpG0Q6TJS3G2b9/ODTfcQK9evfB6vRQUFDB16lTKysqSLa1RCgoKUBQl5qtHjx7JlgfAwoULueWWWzj55JPJyclBURSuuuqqRo/56KOPOPfcc8nPzycjI4PDDjuMv/zlLxiG0UqqLZqjvaioKO7fQlEULr/88lbTvW/fPp577jkmTpzI4MGDSU9PJzc3l5NOOonnn3++wVJGNqlS783Vn0p1D/Db3/6WcePG0bdvX9LT08nPz+fII49k+vTp7Nu3L+YxqVL3zdGeavUei/nz5zt6nnvuuZgxqVL39WlMe6rV/f5ci1K13veHDj+7NpUpLCxkzJgxlJSUMGHCBIYPH84nn3zCzJkzWbp0KatXr6Zz587JlhmX3Nxcpk6d2mB7VlZW64uJwUMPPcRXX31FVlYWffr0Yd26dY3Gv/7661x88cWkpaVx2WWXkZ+fz5tvvsltt93G6tWrWbBgQSspb752gMMPP5wLL7ywwfZRo0YdBIWxWbBgAb/61a/o0aMHp59+Ov369WP37t28+uqr3HTTTbz99tssXLgwaqJSKtX7/uiH1Kh7gCeeeIKjjjqKM888k27dulFTU8PHH3/MAw88wDPPPMOaNWvo16+fE59Kdd9c7ZA69V6fbdu2ccstt5CVlUV1dXXMmFSq+0gS0Q6pVffNuRalar3vN8ldwUXSGM1Zwy/V6N+/v+jfv3+yZTTKihUrxIYNG4RpmmLlypUCEFdeeWXM2IqKCtGlSxfh8XjEp59+6mz3+XzihBNOEIB46aWXWkt6s7Rv2bJFAOLaa69tNX3xWL58uVi8eLHQdT1q+65du0Tfvn0FIBYsWOBsT7V6b67+VKp7Iax6i8Xvfvc7AYhf/vKXzrZUq/vmaE+1eo/ENE0xbtw4MXDgQHHnnXcKQDz77LNRMalW9zaJaE+1um/OtShV6/1AkN21KUphYSHLli1jwIABDVbPnj59OpmZmcybN6/ROylJ44wdO5YhQ4YktLzNggUL2Lt3L1dccQXHHHOMsz0tLY2HHnoIsNZcbC2aoz2VOP3005kwYQKapkVt79GjB7/85S8BWLVqlbM91eq9ufpTjbS0tJjbL730UsD63rFJtbpvjvZUZtasWaxYsYI5c+aQmZkZMybV6t4mEe1tmVSt9wNBdtemKCtXrgRg/PjxqGq0F8/OzubEE09k2bJlrF27lnHjxiVDYpMEAgFefPFFfvzxRzIzMznssMM45ZRTGlwg2wL23+Pss89usO+UU04hIyODNWvWEAgEUnZBzZ07d/L3v/+dffv20blzZ0444QQOO+ywZMty8Hg8ALjdbmdbW6r3WPptUr3u33zzTYAoTW2l7mNpt0m1ev/hhx+4++67ufXWWznllFNYsWJFzLhUrPtEtdukUt0nei1KxXo/YJKdSpTExk6FP/roozH3T548WQDiySefbGVlidG/f38BNHgNGDBArFq1KtnyGtBUl+cxxxwjAPHZZ5/F3H/IIYcIQHz//fcHU2ZMEu2ujfU67bTTxNatW1tZcUNCoZAYNWqUAMTSpUud7alc75HE05+qdf/II4+IadOmialTp4qTTjpJAOLII48Ue/fudWJSte4T0Z6K9R4KhcTRRx8thg4dKmpra4UQQkybNi1ml2eq1X1ztKda3TfnWpRq9d4SyO7aFKWiogKwBozGwt5eXl7eWpKaxfXXX8/y5cudJ4B88803/OIXv6CoqIhzzjmHr776KtkSm0Vb/ntkZGTw+9//ns8//5yysjLKysp47733GDt2LKtWrWLcuHHU1NQkVePdd9/Nt99+yznnnMNZZ53lbG8r9R5Pf6rW/aOPPsr06dP5y1/+wocffsg555zD0qVLoyZypWrdJ6I9Fev9wQcf5IsvvuCFF14gPT290dhUq/vmaE+1um/OtSjV6r1FSLbLlMTmZz/7Wcy7JJt77rlHAGLGjBmtrOzAuOOOOwQgLrzwwmRLiaKpbNiQIUMEIDZu3Bhzvz0od82aNQdTZkya0h6PUCgkjj/+eAGIv/zlLwdJXdM88cQTAhDDhg0Te/bsidqXyvVu05j+eKRK3RcXF4tXX31VDB06VPTs2VN8/vnnzr5Ur/vGtMcjWfW+du1aoWmauOuuu6K2x8uGpVLdN1d7PFKlzdvEuhalUr23FDKTl6LYdwz2nUV9Kisro+LaCvbg9Pfffz/JSppHe/x7uFwubrrpJiB5f4+ZM2dy2223MWLECFatWkWXLl2i9qd6vTelPx6pUPcA3bt3Z+LEibz77rvs27ePa665xtmX6nXfmPZ4JKPedV3n6quvZujQofzhD39I6JhUqfv90R6PVGnzNrGuRalS7y2JNHkpyrBhwwDYsGFDzP0bN24EYOjQoa2mqSXo1q0bQNK7B5tLY38PXdfZsmULLpeLgQMHtra0AyKZf49HH32UqVOnMmrUKFatWhVzYdJUrvdE9DdGKn0W+vXrx8iRI/nuu+/Yu3cvkNp1H0ks7Y3R2vVeXV3Nhg0b+OGHH0hLS4tajHf69OkA/OxnP0NRFGctt1Sp+/3R3hip1OZjaUmVem9J5OzaFGXs2LEALFu2DNM0o2bYVlVVsXr1atLT0xk9enSyJO4Xa9euBWhTHxKwls745z//ydKlS7niiiui9r3//vvU1tZyyimntJ0ZV2GS9feYMWMGv/vd7zjiiCN4991342bAUrXeE9XfGKn2Wdi5cyeAM+MwVes+FvW1N0Zr17vX6+XGG2+Mue9///sfX3zxBSeddBLDhg3jhBNOAFKn7vdHe2OkUpuPpSVV6r1FSXZ/sSQ+bXUx5G+//Vbs27evwfYff/xRDB06VADi4YcfToKy+LS1xZAjaUr7xx9/LAKBQIPtq1atEmlpaQIQq1evPtgyHR588EEBiKOPPjpmO4kkFeu9OfpTqe5/+OEHsWvXrgbbDcNwFhQeM2aMsz2V6r652lOp3hsj3ri2VKr7eMTTnkp139xrUVuo9+YiM3kpzJNPPsmYMWOYMmUKy5cvZ8SIEaxdu5aVK1cydOhQHn744WRLjMmCBQv405/+xNixYxkwYADZ2dls3ryZt956C7/fz7nnnsudd96ZbJksXryYxYsXA1BcXAzAmjVruO666wDo0qULjz76KAA5OTk8++yzTJo0idNOO43LL7+c/Px83njjDdavX8+kSZO47LLLUlL7b3/7W7777jtOO+00+vTpA8A333zD8uXLAfjDH/7AmDFjWkX33Llzuf/++9E0jZNPPplZs2Y1iCkoKHDeR6rVe3P1p1LdL126lLvuuotTTjmFQYMG0blzZ3bv3s17773H5s2b6dGjB88++6wTn0p131ztqVTv+0Mq1X1zSaW6b+61qC3Xe1yS7TIljfPjjz+K6667TvTo0UO43W7Rr18/MWXKlCYzCMlk1apV4vLLLxfDhg0Tubm5wuVyiS5duogzzjhDzJ07V5immWyJQoi6O9F4r1iPwvnwww/FOeecI/Ly8kRaWpoYNWqUePzxxxs85iqVtD/33HPivPPOE/379xeZmZnC4/GIvn37iksvvVS8//77KaUbEKeeemqD49pKvdfXn0p1/80334ibb75ZHH744aJz585C0zSRk5MjjjnmGDFt2rS43ympUPfN1Z5K9d4YTc1QTYW6j0c87alU9/t7LUrlem8uihBCHHwrKZFIJBKJRCJpTeTsWolEIpFIJJJ2iDR5EolEIpFIJO0QafIkEolEIpFI2iHS5EkkEolEIpG0Q6TJk0gkEolEImmHSJMnkUgkEolE0g6RJk8ikUgkEomkHSJNnkQikUgkEkk7RJo8iUQikUgkknaINHkSiUTSgiiKgqIoFBUVRW1/4YUXUBSF0047LSm6JBJJx0OaPIlEwm233YaiKCxYsMDZtnr1ahRF4corr2zy+FdffZULL7yQvn374vV6ycnJYejQoZx55plMnz6d9957D/kExfZPeXk5DzzwAA888ECypUgkEsCVbAESiST5fPjhhwCcfPLJDbaddNJJcY+rra1l0qRJLFmyxNnm8XhwuVwUFhayceNG/vvf/wJQVlZGXl7eQVDfNsjNzWXYsGH069cv2VIOGuXl5UyfPh1AGj2JJAWQmTyJpINTU1PDl19+yeDBg+nRo4ez/YMP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",
      "text/plain": [
       "<Figure size 600x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "point_kws = {\n",
    "    \"nsf\": dict(marker=\"^\", markersize=5, capsize=4, markeredgewidth=0.5, markeredgecolor=\"black\"),\n",
    "    \"ac\": dict(marker=\"D\", markersize=4, capsize=3, markeredgewidth=0.5, markeredgecolor=\"black\"),\n",
    "    \"fmpe\": dict(marker=\"V\", markersize=5, markeredgecolor=\"black\", markeredgewidth=0.5, capsize=4),\n",
    "}\n",
    "\n",
    "\n",
    "line_kws = {\n",
    "    \"gmm\": dict(marker=\"o\", linestyle=\"-\", markeredgecolor=\"black\", markeredgewidth=0.5, markersize=5),\n",
    "    \"twomoons\": dict(marker=\"^\", linestyle=\"-\", markeredgecolor=\"black\", markeredgewidth=0.5, markersize=6),\n",
    "    \"invkinematics\": dict(\n",
    "        marker=\"D\",\n",
    "        linestyle=\"-\",\n",
    "        markeredgecolor=\"black\",\n",
    "        markeredgewidth=0.5,\n",
    "        markersize=5,\n",
    "    ),\n",
    "}\n",
    "\n",
    "# less space between subplots\n",
    "# f, (ax1, ax2) = plt.subplots(1, 2, figsize=(6, 3), sharey=True, width_ratios=(0.90, 0.10), gridspec_kw={'wspace': 0.15})\n",
    "f, ax1 = plt.subplots(1, 1, figsize=(6, 3), sharey=True)\n",
    "tasks = [\"twomoons\", \"gmm\", \"invkinematics\"]\n",
    "budget = 8192\n",
    "for ax in [ax1]:\n",
    "    # CMPE: line with error bars\n",
    "    for task in tasks:\n",
    "        cmpe_c2st = [np.mean(eval_dict[task][budget][f\"cmpe{step}\"][\"c2st\"]) for step in sampling_steps]\n",
    "        cmpe_std = [scipy.stats.sem(eval_dict[task][budget][f\"cmpe{step}\"][\"c2st\"]) for step in sampling_steps]\n",
    "        ax.plot(\n",
    "            sampling_steps,\n",
    "            cmpe_c2st,\n",
    "            label=plot_settings[task][\"name\"],\n",
    "            color=plot_settings[task][\"color\"],\n",
    "            **line_kws[task],\n",
    "        )\n",
    "        ax.fill_between(\n",
    "            sampling_steps,\n",
    "            np.array(cmpe_c2st) - np.array(cmpe_std) / np.sqrt(1),\n",
    "            np.array(cmpe_c2st) + np.array(cmpe_std) / np.sqrt(1),\n",
    "            alpha=0.3,\n",
    "            color=plot_settings[task][\"color\"],\n",
    "        )\n",
    "\n",
    "    ax.set_ylim(0.50, 1.0)\n",
    "    # ax.set_title(task)\n",
    "    # log x axis\n",
    "    # ax.set_xscale('log')\n",
    "    # x labels as decimals\n",
    "    ax.xaxis.set_major_formatter(plt.FuncFormatter(lambda x, _: f\"{x:.0f}\"))\n",
    "    # larger tick labels\n",
    "    ax.tick_params(axis=\"both\", which=\"major\", labelsize=\"x-large\")\n",
    "    # minor grid every 0.01 units in y and x\n",
    "    ax.xaxis.set_major_locator(plt.MultipleLocator(5))\n",
    "    ax.xaxis.set_minor_locator(plt.MultipleLocator(1))\n",
    "    ax.yaxis.set_minor_locator(plt.MultipleLocator(0.05))\n",
    "    # 0.01 grid\n",
    "    ax.grid(which=\"minor\", alpha=0.2, zorder=-1)\n",
    "    # 0.1 grid\n",
    "    ax.grid(which=\"major\", alpha=0.5, zorder=-1)\n",
    "    # ax.set_xlim(0, 1.0)\n",
    "    ax.grid(zorder=-1, alpha=0.5)\n",
    "    sns.despine(ax=ax)\n",
    "\n",
    "ax1.set_xlabel(\"#Sampling steps\", fontsize=\"xx-large\")\n",
    "ax1.set_ylabel(r\"C2ST $\\pm$ SE\", fontsize=\"xx-large\")\n",
    "\n",
    "lines, labels = ax1.get_legend_handles_labels()\n",
    "# lines = [lines[0], lines[1], lines[3], lines[2]]\n",
    "# labels = [labels[0], labels[1], labels[3], labels[2]]\n",
    "# legend below plot with 1 row\n",
    "f.legend(\n",
    "    lines,\n",
    "    labels,\n",
    "    loc=\"lower center\",\n",
    "    ncol=4,\n",
    "    bbox_to_anchor=(0.5, -0.25),\n",
    "    fontsize=\"x-large\",\n",
    "    frameon=False,\n",
    "    markerscale=2.5,\n",
    ")\n",
    "f.tight_layout()\n",
    "f.savefig(\"./figures/steps_performance_c2st.pdf\", bbox_inches=\"tight\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "cons-mod",
   "language": "python",
   "name": "cons-mod"
  },
  "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.9.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
