{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from src.neural_nets.retrieve_logged_data.load_network_metrics import load_metrics\n",
    "from src.plotting.network_plotting_functions import plot_single_metric, plot_several_metrics\n",
    "from src.plotting.human_plotting_functions import _save_figure\n",
    "from src.neural_nets.linear_nets.training_modules import load_data\n",
    "from src.analytical_solutions.analytical_solutions import analytical_svs_shallow, ana_weights, ana_outputs, ana_loss\n",
    "from src.compute_network_stats import compute_summary_stats\n",
    "import matplotlib.lines as mlines"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [],
   "source": [
    "choice_temp = 0.2\n",
    "scale = 0.0002\n",
    "bucket_size = 1\n",
    "log_interval = 1 * bucket_size\n",
    "model_name = \"shallow_net\"\n",
    "folder = \"model_runs_linear\"\n",
    "save_folder = \"shallow_nets_bias\"\n",
    "bias_input = True\n",
    "metrics = [\"loss\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded loss from /loss.npy\n"
     ]
    }
   ],
   "source": [
    "metric_dict = load_metrics(model_name, choice_temp, scale, metrics, bias_input, folder)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_loss, se_loss = compute_summary_stats(metric_dict, \"loss\", bucket_size=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [],
   "source": [
    "# lets get our exact solutions for the weights now\n",
    "# start with loading data\n",
    "include_head_property = False\n",
    "include_bias_input = True\n",
    "include_control_planet = False\n",
    "batch_size = 8\n",
    "\n",
    "train_inputs, train_labels,_ = load_data(batch_size,\n",
    "                                        include_head_property,\n",
    "                                        include_bias_input)\n",
    "\n",
    "train_inputs = np.transpose(train_inputs)\n",
    "train_labels = np.transpose(train_labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [],
   "source": [
    "# load the input and output covariance matrices\n",
    "input_covar = 1/(batch_size)*(train_inputs @ train_inputs.T)\n",
    "output_covar = 1/(batch_size)*(train_labels @ train_inputs.T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [],
   "source": [
    "# get the decomposition of these matrices\n",
    "u, s, vt =  np.linalg.svd(output_covar, full_matrices=False)\n",
    "s = s[:,np.newaxis]\n",
    "_, delta, vt_input_cov =  np.linalg.svd(input_covar, full_matrices=False)\n",
    "delta = delta[:,np.newaxis]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [],
   "source": [
    "# hyperparameters\n",
    "t= np.arange(0, 15000, 1)[np.newaxis]\n",
    "a_0 = 0.00000115\n",
    "step_size = 0.001"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(9, 15000)"
      ]
     },
     "execution_count": 48,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# get solutions\n",
    "ana_sol_svs = analytical_svs_shallow(t, s, delta, a_0, step_size=step_size, batch_size=batch_size)\n",
    "ana_sol_svs.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(15000, 14, 9)"
      ]
     },
     "execution_count": 49,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# getting the analytical weights\n",
    "ana_weights = ana_weights(u, ana_sol_svs, vt)\n",
    "ana_weights.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [],
   "source": [
    "# calculate the analytical loss at each time step\n",
    "ana_loss = ana_loss(u, ana_sol_svs, vt, train_inputs, train_labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAArMAAAKZCAYAAACr0KNLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAABolAAAaJQGH6LfgAACMuUlEQVR4nOzdd3gU1f4G8Hd2N8lmN72HAAkl1NA7kaZIVbqAIooIXn+oWLFdRfTavRZUBLGA10oHFVDR0HtvoQYSkkBI78kmuzu/P0KGLNlNNsnW7Pt5njzMzJ6Z/ZKcwJuTM2cEURRFEBERERE5IZm9CyAiIiIiqi+GWSIiIiJyWgyzREREROS0GGaJiIiIyGkxzBIRERGR02KYJSIiIiKnxTBLRERERE6LYZaIiIiInBbDLBERERE5LYZZIiIiInJaDLNERERE5LQYZomIiIjIaTHMEhEREZHTUti7AKobvV6P3NxcaV+pVEIQBPsVRERERFRHoiiitLRU2vfz84NMVr8xVoZZJ5Obm4vAwEB7l0FERERkMVlZWQgICKjXuZxmQEREREROi2GWiIiIiJwWpxk4GaVSabCflZUFT09Ps88/deoUACAmJsaidRFVYh8ja2L/ImtjH7ONkpISg2mTt+abumCYdTK33uzl6elZpzBb2Vnqcg5RXbCPkTWxf5G1sY/ZR0NuZuc0AyIiIiJyWgyzREREROS0GGaJiIiIyGkxzBIRERGR02KYJSIiIiKnxTBLRERERE7LZZfmysjIwKFDh3Dw4EHpz7S0NOn11157DQsWLKjTNS9evIh//vkHu3fvxsmTJ5GUlISCggKo1WqEhISgR48eGDlyJCZPntyg9dSIqtLpdNBqtRBF0d6lAIBUR9VnbhNZCvsXWRv7WN0IggCFQgG5XG63GlwuzKalpaFv375ISkqy2DWXLVuGjz76SFpo+VZ5eXnIy8vDhQsX8Msvv+D555/HokWLMHHiRIvVQK5FFEXk5+cjLy8PRUVF9i7HgFarBQBcvnzZzpVQY8T+RdbGPlY/arUavr6+8PHxadCasfXhctMMSktLLRpkAWDNmjXVgqxKpUKnTp0wZMgQ9O7dGyqVSnrt+vXrmDRpEt5//32L1kGuQRRFZGZm4urVqw4XZAHAw8MDHh4e9i6DGin2L7I29rH6KSoqwtWrV5GZmWnz3xS63MhsVcHBwejRowd69uyJnj17Yty4cQ26XmBgIKZNm4YpU6agV69ecHNzk17TaDRYvnw55s2bh4KCAgDACy+8gK5du2LYsGENel9yLfn5+cjMzARQ8Y+un58fPD09bf6TsCmVv5rjVBqyBvYvsjb2sboRRRElJSXIzc2FRqNBZmYm3N3d4evra7MaXC7MBgQEYNWqVejVqxciIyMtcs2IiAgsXLgQjzzyiMnO7+HhgX/961/o0aMHBg4ciJKSEgAVgZZhluoiLy8PQEWfioyMtOs8JWP0ej0A/kdA1sH+RdbGPlZ3np6e8PX1RVJSEjQaDfLy8mwaZl1umoGPjw8mTZpksSALAF9++SXmzp1rVsfv2bMn5s6dK+0fO3YMly5dslgt1LjpdDppaoGfn5/DBVkiInJNcrkcfn5+ACqmHOh0Opu9t8uFWUcwZswYg/2zZ8/aqRJyNpU3JgAVPwkTERE5iqr/LzHMNnKBgYEG+/n5+XaqhJxN1Un1jjJHloiICDD8f6lyuoYtMMzaQWJiosF+SEiIfQohIiIicnIMs3awevVqadvNzQ09evSwYzVEREREzoth1saSkpLw448/SvujRo2y6R1/RERERI2Jyy3NZU96vR4PPfSQtCyXTCbDm2++2aBrnjp1qtZVFERRRFGZiBKtHlczsqHRijieVrGOXpcwLj3iTERRhFarhYeHB0pLS206J8lclTepFRcX27kSaozYv8ja2Mfqr6ysDHq9HhqNBufPn6/x3g5LPi6YI7M29OKLL2Lr1q3S/iuvvIKYmBirv2+ZTsS9q1Mwc/1VvLK7FP/Zr8Er/6Tj031ZVn9vIrKeESNGQK1W4/vvv6/X+d9//z3UajVGjBhh4crq5q233oJarcYjjzxi1zqIKu3cuRNqtRrt27e36fvye7J+ODJrI0uWLMEHH3wg7Q8aNAjz589v8HVjYmJqXaJJFEXIV6VCpzd8vFyZKEOnTp0aXAPZTmlpqfS8cKVS6ZCLeleOZlR9hLOjmDFjBr777juz2m7duhWDBw+2bkENJJNVjEd4eHjU6/Nd+chOmUxm169X5dMSFQpFrXU4cv8i83300Ud49tlnAQCPPfYYPv/8cztXdFNxcbG0hrcgCBbra8uXL0diYiLGjRuHrl27Gm3jjN+TVclkMshkMnh6eqJFixY1/h9V+VtqS2CYtYFffvkFjz32mLTfpUsXrFu3zmYL3guCAJW7HAWlWoPjxRrbrQFH5Eh8fHxq/UHOGeayN2/eHG3btq13rb6+vmjbti2aN29u4cqIavbtt99K2z/++CP++9//OuQP55a0fPlybN++HVFRUSbDLL8n64dh1so2bNiA6dOnS3Mb27Vrh7/++gv+/v42rcPLQ1EtzJbp9CjT6uGu4GwTci3dunXDtm3b7F1Gg/3vf/9r0Pnjx4/H+PHjLVQNkXn279+P06dPQyaTwcvLC7m5uVi7di3uu+8+e5dmd/yerB+mGCvavHkzJk+eLE0mb9WqFf755x+7rCurcjc+ClxcpjV6nIiIyBq++eYbAMAdd9yB6dOnGxwjqg+GWSvZsmULJkyYgLKyMgBAZGQk4uLi0KRJE7vU4+VhfBC+UMMwS1SbqKgoCIKAbdu2ISEhAdOnT0d4eDg8PT3RoUMHfPbZZ9LT2crLy/HBBx+gU6dOUKlUCAoKwn333Yfk5ORar33mzBncd999CA8Ph4eHB1q1aoUXXngBeXl5Rs8dPHgwBEHA8uXLDY5v27YNgiAgKioKALBixQoMGTIEgYGBEAQB69evB1Dxa09BEGqcG/zbb79h/PjxiIiIgIeHB0JCQtCrVy/Mnz8fV65cMWh79OhRLFiwALfddhuaNWsGDw8P+Pv7Y8CAAVi8eLHB45jJNRUXF+OXX34BUDGHfcaMGQAq5qhX3g9wq6r9PCcnB88++yxatmwJDw8PhIaGYtq0abh06ZLRc1NSUvDZZ59h1KhRaN26NVQqFby9vdG5c2f8+9//RlaW+TdCazQaBAUFQRAE/PXXXybbZWdnQ6lUQhAEHDp0SPp+3L59OwDgoYcegiAI0kfV7z9+T9YPpxlYwdatWzF27Fhp2YmmTZsiLi7OrnNgVO7Gv9TFZZw3S2Suo0ePYuzYsdBqtWjfvj1kMhnOnDmDuXPnIjExEW+//TaGDx+O7du3o23btmjZsiXOnTuHn3/+Gbt378bx48fh5+dn9NoHDhzA66+/Dq1Wi44dO8LPzw9nz57F+++/jw0bNmDbtm0ICwurc81PP/00PvnkE4SEhKBVq1Zm38xRWlqK+++/H2vWrAEA+Pv7o3PnzsjNzcWJEydw6NAhBAQE4KmnnpLOmT17Ng4fPgwfHx+EhYWhc+fOSE9Px65du7Br1y6sW7cOmzZtgkLR+P/refvtty1+zaCgILPuLl+xYgUSEhLq/T4vv/xyvc+tzcqVK1FQUABfX1+MHz8enp6eiImJwalTp/Dtt9/iP//5j8lzU1NT0a1bN6SkpKB9+/Zo3bo1zp8/j59++glbtmzB4cOH0axZM4NzPvnkE3z44YdQKpUICwtDTEwMcnJycPbsWZw8eRI//PADdu7cadb/zx4eHnjwwQfx0Ucf4auvvsKwYcOMtvv++++h0WjQtWtX9OzZE0ePHkVsbCxOnjyJ/Px8REdHG/yG1twbsfk9aZpzV++AduzYgbvuuku6S69JkyaIi4tDy5Yt7VqXmiOzLkWn0yEnJ8cu7135Q5yl1mj09/e32c2StXnhhRfw4IMP4uOPP4aXlxcA4Ouvv8bs2bOxcOFCXL58GVevXsWJEyek/6AuXLiAoUOH4sqVK/j444/x+uuvG732K6+8gjvuuAP/+9//EBwcDAA4fvw4xo8fj3PnzmHmzJnYtGlTnepNSUnB4sWL8d1332H69OnSmo/mrO/42GOPYc2aNfDx8cGSJUswZcoUafWEsrIyrFu3DgEBAQbnPPPMM4iJiUHnzp0NjsfHx2PmzJnYsmULPvnkEzz33HN1+ns4o/LycrtdU6vVWuX9LaHyxq8pU6ZIK/E8+OCDmDdvHpYvX47XX39d6me3ev311zFw4EDs3r0bERERAIBLly5h1KhROHfuHObPn49ly5YZnDNy5EiMHj0aAwYMMAhs6enpeOmll/Dtt99izpw5+P33382q/9FHH8XHH3+MDRs2ID093ei0wa+++goApB88unXrhl27dmHw4MHYvn07Xn75ZWlEui74PWkaw6wF7d27F6NHj5b+Ew8NDUVcXByio6PtXBmg9jAeBooYZhulnJwcLFq0yN5lWMRjjz2GoKAgi15z+/btNS7mHRkZicTExGrH27RpgyVLlhiE61mzZmHp0qU4ePAg1q1bh7179xqMtERHR+P555/H448/jt9++81kmFWr1VixYgV8fHykY126dMHy5csxaNAgbN68GQcPHkSvXr3M/nvqdDq88cYbeOCBBwyO13bX+KlTp6RQsGLFimprXrq7u2PKlCnVzjN1A0+HDh3w/fffo02bNli2bJnT/8dJ9XP+/Hns3LkTAAzC3P3334+XXnoJKSkp+Ouvv0yusert7Y2VK1caBLaWLVvi7bffxsSJE/Hrr79WO+eOO+4weq2QkBB8/fXX+PPPP7Fp0yZcv34doaGhtf4doqOjMWTIEMTFxWH58uV4/vnnDV7fu3cvTp8+DbVajWnTptV6PXPxe7JmDLMWcvDgQYwYMQKFhYUAgODgYMTFxaFt27Z2rqyCqZHZIi7PRS6otqW5wsPDjR6fNWuW0VHiHj164ODBg+jSpQv69u1b7fWePXsCAC5evGjyPWfNmmUQZCsNHDgQPXr0wOHDh7Fx48Y6hVkAePjhh+vUHgBWr14NURTRs2fPOi/enpKSgl9++QVHjhxBeno6NBqNNJ8YAM6cOYOSkpJa18emxqdyVLZt27bo16+fdDwsLAzDhw/Hxo0b8c0335jsc9OmTas28ghAulZ2djays7OrtSksLMSqVauwa9cupKamoqioSOqTBQUFEEURR48eNbuvP/roo4iLi8PXX3+NefPmGfxgXDkqO2XKFKPfz/XF78maMcxawLFjxzB8+HDk5+cDqJjX9M8//6BDhw52ruwmUzeAcWSWXFF9l+Yy9VuWyl811vZ65Q+7xtT0NMCYmBgcPnwY8fHx5pYKoOLfInNGm2518uRJAEBsbGydzluyZAmeeuopaDQak21EUUR2drb0a2JyDVqtVlpKztiv2GfMmIGNGzfi119/RWZmptHfxpgaHKraxwsLCw3C7N69ezFx4kRcu3atxvrqciPYuHHjEBYWhgsXLmDbtm0YMmQIACA/Px8rV64EAIs/OYvfkzVzyTA7e/bsWh//+Oabb+Ldd9+tdvyvv/7CwIEDDY7dd999BvMTAwICMG/ePLPruf/++3H//feb3b4+uDSXa/H39zd4UIctVc7HtNQC6LZek7kmarXa6PHKkZnaXq86GnKrmm7uqnytoKDArDormaqnNpU/mJu6Wc2YAwcOYM6cORBFEbNnz8bMmTPRpk0b+Pr6Qi6XQ6/XS6Pajjqf05Iqn6Bkj2sqFAqrvH9DbNq0CdeuXYNMJpOW46pqzJgxCAgIQHZ2Nr7//ns8/fTT1dqY6s9V59hWrukOVHy/jB8/HtevX8fAgQPx0ksvoWvXrggICIC7uzuAit987Ny5s0590s3NDTNnzsTbb7+Nr776SgqzP/30E4qKitC5c2f06dPH7OuZg9+TNXPJMFteXl7jTylAxVwzna76r+CrfqNUuvVGl/Pnz+P8+fNm12Ps15KWZnppLk4zaIzkcrnF55mai48brZ/r16/X+pq3t7dNaqn89Whubq7Z5yxfvhyiKGL8+PFYunRptdfrMvLVGFhzRYDaGJs7aW+V68jq9Xo0bdq01rbGwmxdbd68GdevX0fTpk2xefNmo/8m1bdfPvLII3j33Xexdu1aZGVlITAwsNqNX5bE78macZ1ZF2F6aS6OzBI5glOnTtX6mq2mLlXe+bx7926zz6lcCsrU+ph79uxpcF3knK5fvy6txBEYGIjQ0FCTHwBw+vRpHDhwoMHvW9kne/XqZTTIZmdn49y5c/W6dmRkJEaMGAGNRoP//e9/OHLkCI4cOQKVSmXyN6013XRaG35P1swlw2zlTyv1+TDWKRITE+t9PVEUsWDBAqv/nU2tZsCluYgcw9dff210GsGuXbtw6NAhAMDo0aNtUsvEiROlBd9rWhy+qsqwYGxuoiiK+O9//2vRGsl5fPfdd9BqtfD19UVycjLS0tJMfnTr1g2AZZ4IVlOfBIAPP/zQ6G9gzfXoo48CqLjpq3JUdvLkyfD19a2xnsqlO+uC35M1c8kw64rUJkZmeQMYkWMoLCzE1KlTkZmZKR07efKkdLPM8OHD67ySQX3FxMRI7zt58mSsXLnSYIpVWVkZVq1ahS1btkjHKn/Q/+KLL7B3717peG5uLh544AEpkJPrqVzFYOrUqbXeMf/QQw8BAH755ZcGr1Vd2Sf37duHxYsXS3PWtVotPv74Y7z77rsNmts/atQoNGvWDGfOnMHXX38NoOKeHFNat24NoOIJfTXNnzeG35M1Y5h1ESaX5uITwMgFHT16FLfddluNH6tWrbJpTW+++Sa2bduGiIgI9OjRAx06dEDnzp2RkJCA1q1bS4HAVhYtWoQxY8YgLy8PU6ZMQXBwMHr37o02bdrAx8cHkydPxunTp6X2s2bNQseOHZGfn4/Y2FhER0ejR48eCA8Px08//WR0zh41frt27ZJ+lT9z5sxa20+bNg0eHh7Iz89v8Pdgly5dpAA4Z84cNGnSBL169UJoaCieeeYZPPzwww26UUsul2PWrFkAKgJyTEwM+vfvb7L9tGnTIJPJsHLlSjRv3hwDBgzA4MGDDZ7YVRN+T5rGMOsi+NAEopvy8/Oxe/fuGj9SU1NtWlPv3r1x6NAhTJgwAampqUhISECLFi3w3HPP4eDBg2jSpIlN6/H09MT69euxevVqjBo1CgqFAseOHUNeXh66dOmC1157DRMnTpTaq9Vq7Ny5E0888QQiIiKQmJiI5ORkDBs2DNu2bTN6Bzs1fpXTBTp27IjevXvX2j4gIABjx441OLeh7//hhx+iQ4cOyM7OxoULF9CuXTt8++23Fglzs2bNklZTqGlUFqj4Hl+/fj0GDx6MwsJC7NmzB9u3b8exY8fMei9+T5omiHUd6ya7KikpMZjIXlxcbNZCxwkZhbjjw+3VjveOCsDKR/sZOYMcUWlpKS5fvgwAaNGihcWWv7IkrmZQN1FRUUhKSsLWrVtN3qhBN7F/kbXVpY8dPXoU3bt3h1KpxNWrVx1qKUF7qMv/UfXNM8ZwZNZFmF6aiyOzRERE9bFkyRIAFcuhuXqQtSeGWRfBhyYQERFZzvHjx/Hdd99BEASz572SdbjkQxNckdpdgd5RATienAONrmJmSa8of9zRvu6PuiQiInJVgwcPRklJCY4ePYry8nLMmDEDXbt2tXdZLo0jsy5CJhOw8tF+iPC5+fNLv1ZBeHRQKztWRURE5Fy2b9+OgwcPIiQkBM8++ywWL15s75JcHkdmXYyn4ubPL1zJgMj+EhMT7V0CEdUB75t3PByZdTGebjcfp8cwS0RERM6OYdbFKKuOzPKBCUREROTkGGZdDEdmiYiIqDFhmHUxnm43v+RcY9b5CMLNH0Y4b4uIiBxJ1f+XKp+MZgsMsy7GU3EzDHGNWeejUNy8Z7OkpMSOlRARERmq+v+SXG58fXtrYJh1MYarGXDOrLORy+VQq9UAgNzcXOh0/BoSEZH96XQ65ObmAgDUarVNwyyX5nIxVefMFpSWo1CjhUImQOlmu05HDePr64uioiJoNBokJSXBz88Pnp6eBlMQ7KmsrAyAbX/FRK6D/YusjX2sbkRRRElJCXJzc6HRaABU/D9lSwyzLuTnA1ew8nS+tJ9ZWIaY1/7EW+NjMK1PpB0ro7rw8fFBWVkZMjMzodFocP36dXuXZECv1wPgfwRkHexfZG3sYw0TFBQEHx8fm74nw6wLKSgtR1Zx9V9LF5Ry7qwzEQQBQUFBcHd3R15eHoqKiuxdkoHKn8w9PT3tXAk1RuxfZG3sY/WjVqvh6+sLHx8fm/+mkGHWhXh5uBk9Xsgw63QEQYCvry98fX2h0+mg0+mk0QR7O3/+PACgRYsWdq6EGiP2L7I29rG6kclkkMvlNp0jeyuGWRfirTT+5S4oLbdxJWRJ9v5H5FaVP5ErlUo7V0KNEfsXWRv7mPPhhBAX4mUqzHK9WSIiInJSDLMuxMfkyCzDLBERETknhlkXwjmzRERE1NgwzLoQk3NmNZwzS0RERM6JYdaFmJozy5FZIiIiclYMsy7Ey51zZomIiKhxYZh1ITKZAE9F9YWMuZoBEREROSuGWRejdq/+JS/T6qHRVn8yGBEREZGjY5h1MZ5uxr/knDdLREREzohh1sWo3Yw/L5nzZomIiMgZMcy6GJWpkVnOmyUiIiInxDDrYkxNM8gv5VqzRERE5HwYZl2MqWkGnDNLREREzohh1sWYmmbAObNERETkjBhmXYzKyNJcAOfMEhERkXNimHUxKpOrGXDOLBERETkfhlkXozY1zYAjs0REROSEGGZdjKebDLeOzcY08UG4j9Iu9RARERE1BMOsi+nb1BNLx4QbHHt3YmfMiG1hp4qIiIiI6o9h1sXIZQK83OUGx7iSARERETkrhlkX5HnLTWBcyYCIiIicFcOsC5LLBKiqjM5yJQMiIiJyVgyzLspbqZC2Oc2AiIiInBXDrIvyVrpJ25xmQERERM6KYdZFeXncHJnN5zQDIiIiclIMsy6K0wyIiIioMWCYdVE+njenGeSVcGSWiIiInBPDrAv6O6EQ59IKpP0d5zIw5L/bEH81345VEREREdWdovYm1NgcvVaKi+nF0n6BRosCjRbZRWV2rIqIiIio7jgy64LU7sa/7JxuQERERM6GYdYFeZkIs1zVgIiIiJwNw6wLMhVmOTJLREREzoZh1gVxmgERERE1FgyzLsjkNAOGWSIiInIyDLMuiNMMiIiIqLFgmHVBnGZAREREjQXDrAviNAMiIiJqLFw2zGZkZGDz5s144403MGbMGISHh0MQBOljwYIF9b62VqvFqlWrMGHCBLRu3RoqlQqBgYHo0qULnn32WRw/ftxyf5F68HIztTSX1saVEBERETWMyz0BLC0tDX379kVSUpJVrn/u3Dncf//9OHTokMHxkpISZGdn48SJE/j444/x9NNP4+2334aHh4dV6qiJyl2AIACiaHic0wyIiIjI2bhcmC0tLbVakL106RIGDBiAjIwM6VhwcDDatm2LwsJCxMfHo6ysDKIo4qOPPsKVK1ewcuVKCIJglXpMkQkCvD0U1UZi80rKIYqizeshIiIiqi+XnWYAVATNESNG4JVXXsH69esbdK3y8nLcfffdUpBVKpX45ptvcPXqVezcuRNHjx5FUlISpk6dKp2zevVqvPvuuw163/ry8XSrdkynF1FcprNDNURERET143IjswEBAVi1ahV69eqFyMhIi133q6++Qnx8vLS/cuVK3H333QZtwsLC8NNPP6GsrAxr164FALzzzjuYNWsWgoODLVaLOXw93ZCSU1LteF5JOdQeLtctiIiIyEm53Misj48PJk2aZNEgK4qiwQjruHHjqgXZSoIg4IsvvpDmyhYUFOCzzz6zWC3m8jUyMgtw3iwRERE5F5cLs9Zw4MABJCcnS/tz5sypsX1oaCgmTJgg7a9evdpqtZliKsxyeS4iIiJyJgyzFvDbb79J2yqVCkOGDKn1nFGjRknbZ86cQUJCglVqM8VHyZFZIiIicn4MsxZw7NgxabtXr15QKGqfcxobG2vyGrbgq2KYJSIiIufHMGsBVW/8io6ONuucyMhIuLndDJRnzpyxeF01MTnNgA9OICIiIifC29YbSBRFg3VrmzdvbtZ5MpkMERERSExMBABcvny5Xu9/6tQpKJVKs9tnZmYCAAqyjT+s4UJSCk76FtarFiLgZh87efKknSuhxoj9i6yNfcw2SktLLXYtjsw2UFFREfR6vbTv6+tr9rlV2xYUFFi0rtp4uVf/0nvIhWpPBSMiIiJyZByZbaCioiKD/bqMknp6ekrbhYX1Gw2NiYkxuE5tKn/SnNwzGhERmXh65XHptfWP34b24T71qoOoUmUf69Spk50rocaI/YusjX3MNkpKqq91X18cmW2g8nLDG6bMufnLWNuysjKL1WSOEG8lhrQLMTjGm7+IiIjI2TDMNpBKpTLYr8sckKptvby8LFaTubyVbhCEm/u5xQyzRERE5FwYZhvI29vbYL8uw+bFxcXStj3CrFwmwK/KqgY5xbYdHSYiIiJqKIbZBnJzczMItNeuXTP73Kptg4KCLFqXufxV7tI2wywRERE5G4ZZC2jXrp20XXWZrpoUFhYiJyfH6DVsyV9dJcwWMcwSERGRc2GYtYCOHTtK20ePHjXrnCNHjhjst2/f3qI1mctfVXWaAefMEhERkXNhmLWAgQMHStsJCQlITU2t9ZwdO3ZI2yqVCr169bJKbbUxmGbAkVkiIiJyMgyzFjBmzBjI5XJp/4cffqj1nKpthg8fXm1VBFsxmGbAObNERETkZBhmLSAwMBBjxoyR9hcuXIjc3FyT7X/55RecO3dO2n/ooYesWZ5JF64X4FruzdUXLqQX4omfj+LA5Wy71ENERERUVwyzFvLmm29Ko7PXrl3D/fffb3SZriNHjuDxxx+X9vv164e7777bZnVWtf5YKn47cXNFhYJSLX47fhUX0+v3NDIiIiIiW3PJMDt79mwolcpqH1W9+eabRttUnetaVYcOHfDaa69J+xs3bkS3bt3w6aefIi4uDr/++iuefPJJDBgwAFlZWQAAHx8fLF261Hp/0VpUnS9bFacbEBERkbMw/9mrjUh5eTk0Gk2NbXQ6HXQ6XbXjer3e5Dmvvvoq0tLS8MUXXwAAzp07hyeffNJoWx8fH6xZswYxMTF1qNyy/EyFWd4IRkRERE7CJUdmrWnRokVYs2aNyaW23NzcMH78eJw8eRJDhw61cXWGAtRuRo9ziS4iIiJyFi45Mrt8+XIsX77catefMGECJkyYgGPHjuHEiRO4du0aPD090bRpUwwcONBuT/u6lamR2VxOMyAiIiIn4ZJh1la6du2Krl272rsMk0zNmc1mmCUiIiInwWkGLqzq07+qyuU0AyIiInISDLMuzEfpBplQ/ThXMyAiIiJnwTDrwmQywei82byScuj0oh0qIiIiIqobhlkX52dkqoEoVgRaIiIiIkfHMOvi+OAEIiIicmYMsy7OZJjlgxOIiIjICTDMujhTD07IYpglIiIiJ8Aw6+ICvTyMHs8qZJglIiIix8cw6+KCTITZzEKNjSshIiIiqjuGWRcX5GV8zmwWwywRERE5AYZZFxeoNjEyyzmzRERE5AQYZl1cIEdmiYiIyIkxzLo402GWI7NERETk+BhmXVyAyh2CUP04bwAjIiIiZ8Aw6+IUcpnRByfkFJdDq9PboSIiIiIi8zHMEube3hptQr2k/REdQ3H01TshlxkZsiUiIiJyIAyzhBmxLdClqZ+0X64T4a92h2Bs/gERERGRA2GYJQCGTwLjfFkiIiJyFgyzBMDw4QmZXMmAiIiInATDLAEwfKxtZqEGoijasRoiIiIi8zDMEgDDMKvR6lFUprNjNURERETmYZglANUfnsAngBEREZEzYJglANXDLG8CIyIiImfAMEsAqj8JjDeBERERkTNgmCWIooisojJ4eyikYxuOpmLR1ot2rIqIiIiodgyzBAAY+P5W5Jdqpf1Np9Kw8J8LXNWAiIiIHBrDLEEQBAR7e1Q7XqbVI79Ea+QMIiIiIsfAMEsAgFAfpdHj6QWlNq6EiIiIyHwMswQACDEyMgsA6QVc1YCIiIgcF8MsATA9Mns9nyOzRERE5LgYZgkAjM6ZBTgyS0RERI6NYZYA1DDNIJ9hloiIiBwXwywBqGGaAW8AIyIiIgfGMEsAgBAf4yOzGRyZJSIiIgfGMEsAgBBvLs1FREREzodhlgAA/io3uMmFasev52v4FDAiIiJyWAyzBKDiKWDGRmdLynUo1PApYEREROSYGGZJwuW5iIiIyNkwzJIk1MRNYFyei4iIiBwVwyxJeBMYERERORuGWZJwZJaIiIicDcMsSTgyS0RERM6GYZYkwSZGZq9zZJaIiIgcFMMsSUJNjMxez+fILBERETkmhlmSmJozm8YwS0RERA6KYZYkAWp3eCiqd4lruaXQ6/kUMCIiInI8DLMkEQQBY7o0QUiVhyfc3i4Em58aAKH6k26JiIiI7I5hlgx8cE8XDIgOlvZFUUSrYC8ITLNERETkgBhmqZomfjdvBLuWx/myRERE5LgYZqmaJn6e0nZqbokdKyEiIiKqGcMsVRPue3NktqBUi0KN1o7VEBEREZnGMEvVVB2ZBYBrHJ0lIiIiB8UwS9VUHZkFgKucN0tEREQOimGWqvFWusFbqZD2r3JkloiIiBwUwywZ1cT35lQDTjMgIiIiR8UwawU5OTn4/PPPMXbsWERFRcHLywvu7u4ICgpCz549MWfOHOzatcveZdYozPfmgxP2Xc7Gl9sTkFtcZseKiIiIiKpT1N6E6mLp0qWYN28e8vPzq72WlZWFrKwsHD58GIsXL8btt9+Ob7/9FpGRkXao1LS5Px/F9vOZ0v6By9k4cDkbvVoEoHtzdztWRkRERGSII7MW9Prrr+Nf//qXQZD19/dH//79cfvtt6Ndu3YGT9KKi4vDbbfdhsTERDtUa5qnm9zo8Wu5vBGMiIiIHAvDrIXs27cPr7/+urQfGhqK1atXIzMzE7t378Y///yDM2fOIDExEZMnT5bapaSkYNasWfYo2aRwP6XR49fyOHeWiIiIHAvDrIV8+umnEEURACCXy/HHH39g4sSJkMkMP8XNmzfHL7/8gjFjxkjHKoOuo6h681dVfBoYERERORqGWQvZsWOHtD1y5Eh07drVZFtBEPDKK68YHHOkG8JufWhCpdQchlkiIiJyLAyzFpKeni5tx8TE1Nq+U6dOBvuZmZkmWtpeU3/jYTaZYZaIiIgcDMOshXh7e0vbZWW1L2FVWmp4M5W/v7/Fa6qvJn6eqHKfmiQlu1iaSkFERETkCBhmLaRPnz7S9vbt22ttf2ubAQMGWLym+nJXyBDuU/0msAKNFnkl5XaoiIiIiMg4hlkLefzxx6Xtw4cP49tvvzXZNicnBy+++KK0P3r0aHTs2NGq9dVVU3+V0ePJ2ZxqQERERI6DYdZCRo0aheeff17anzVrFh555BHs27cPhYWF0Gq1SE5OxjfffINu3brh7NmzAIDevXtj2bJl9irbpKYBpubNFtu4EiIiIiLTBJGTIC3q66+/xvz583Ht2rUa2wUGBuLhhx/G66+/DqXS+LquxpSUlEClujlqeuDAgTqdX3mjWVBQUI3tfjqRi59PVn+K2UPd/DChg4/Z70eux9w+RlQf7F9kbexjtlFaWorevXtL+8XFxfD0ND6QVhuOzFrYrFmz8Ouvv6Jbt24m27i7u2PmzJl49NFH6xREbSnUy/iTjq8Xam1cCREREZFpHJm1oKtXr+KRRx7Bxo0bpWP+/v5o164dlEol0tLScPbsWWlFAIVCgeeffx7/+c9/qj1cwZRbR2br+pPMyZMnAVRfGuxW+y5lYerSfdWOD24bjOUP9TZyBlEFc/sYUX2wf5G1sY/ZRkPzTFUcmbWQK1euoF+/flKQbd26NTZt2oSsrCzs2bMHcXFxiI+Px9WrV/HEE08AALRaLd5++2088sgj9izdqGYBpm4A45xZIiIichwMsxbywAMP4MqVKwCAVq1aYf/+/Rg5ciSEWxZsDQsLw6effooPP/xQOvbNN99g/fr1tiy3VmE+SrjJqy82m5JTwrVmiYiIyGEwzFrA3r17DdaNff/99xEQEFDjOU8//bTBk8I+/vhjq9VXH3KZYPSxthqtHhmFGjtURERERFQdw6wFbNmyRdp2c3PDqFGjaj1HEASMHTtW2t+7d69ZTw6zJZOPteVas0REROQgGGYtIDU1VdoODg42e4WC5s2bS9vl5eXIysqyeG0N0czEgxNSuNYsEREROQiGWQvw8PCQtktKzB+1LC42DIVV7+pzBKZuAkvKYpglIiIix8AwawFNmjSRtnNycpCQkGDWeQcPHpS21Wo1fH19LV5bQ0QGGg+ziZlFNq6EiIiIyDiGWQsYNGiQwb45N3MlJiZizZo10v7gwYMtXVaDRQWqjR6/nMUwS0RERI6BYdYC+vTpg44dO0r7ixYtwmeffWay/ZUrVzBmzBhoNDdXBZg9e7ZVa6yPFkFqtAvzNlii66HYKHx5fw87VkVERER0E8OsBchkMnz22WdQKG4+Anbu3Lno168fFi5ciC1btmDnzp1YtWoV5syZg44dO0pPGAGAu+66y2BlA0eh9lDgj6cGIibCcPpDiI9jPoKXiIiIXI+i9iZkjiFDhuCHH37Aww8/jKKiil/D79u3D/v2VX8kbFUjRozAL7/8YosS661FoBpHr+QC4HxZIiIiciwcmbWgKVOm4Pjx45gxY0atKxN07doV3333HTZv3gy12vjcVEcRFXSzvssMs0RERORAODJrYa1atcKyZcuwePFiHDlyBPHx8cjJyUFZWRl8fHwQERGBXr16oVmzZvYu1WwtqoTZ5JwSlOv0cJPz5yAiIiKyP4ZZK1Eqlejfvz/69+9v71IarGqY1elFpOSUGBwjIiIishcOr1Gtom4JrpczC+1UCREREZEhhlmqlZeHAsHeN59ydjmTTwAjIiIix8AwS2ZpUeUBClzRgIiIiBwFwyyZJSro5uoM+y9n4aMt53Epg9MNiIiIyL54AxjVatHWi/j1+FVp//z1Qpy/fgGRASq0DPayY2VERETk6jgyS7VykwsoLddXO57AkVkiIiKyM4ZZqlUrE6OvF9IZZomIiMi+GGapVtEh3kaPJzDMEhERkZ0xzFKtIvw94aGo3lWSsouh0ersUBERERFRBYZZqpVcJhi90UunF5HINWeJiIjIjhhmySzRIcbnzV7kVAMiIiKyI4ZZMktrE2H2QnqBjSshIiIiuolhlsxiKsxyZJaIiIjsiWGWzMJpBkREROSIGGbJLJGBashlQrXjlzKLoNOLdqiIiIiIiGGWzOSukCEyUFXteJlWj+RsrmhARERE9sEwS2YzNdWATwIjIiIie2GYJbOZugns/HWuaEBERET2wTBLZmsb5mP0+Jlr+TauhIiIiKgCwyyZrX2Yt9Hj59I4MktERET2wTBLZmsRpIa7vHqXuZRZhNJynR0qIiIiIlfHMEtmU8hliA6tPm9Wpxe53iwRERHZBcMs1Uk7E/Nmz3KqAREREdkBwyzVSftw4/Nmz/ImMCIiIrIDhlmqE1Mjs2n5pTauhIiIiIhhluqoXbg3ujT1haLKo21fGtUOn9/X3Y5VERERkatimKU6CfLywIbHb0OXZn7SsaQsPs6WiIiI7INhluql6txZPjSBiIiI7IVhluqlffjNubPn0gqg14t2rIaIiIhcFcMs1UvVG8GKy3S4ks2pBkRERGR7DLNUL+3CvCHcvAcM8ZxqQERERHbAMEv1ovZQICpQLe2fSs2zYzVERETkqhhmqd46RfhK2ycZZomIiMgOGGap3jo3vRlmT6TkQRR5ExgRERHZFsMs1VtMk5s3geWVlGPS4r14df0pO1ZERERErsahw6xer8eSJUsQGxsLf39/eHl5ISYmBvPnz0d+Pm84sqfk7GI88v1hg2OHr+Rgd0KmnSoiIiIiV2TzMPvOO++gefPmaN68OR5//HGT7bRaLUaPHo3HHnsM+/btQ15eHoqLixEfH4+33noLnTp1wsWLF21YOVUV7qtEmU5f7fjlzCIUarR2qIiIiIhckc3D7I8//oiUlBSkpqZi8uTJJtstWLAAf/75p8l5mMnJyRgxYgRKSkqsVSrVQCGXGTw4oZIoAqd5MxgRERHZiE3DbHZ2NuLj4yEIAkJCQjBw4ECj7TIzM/Hxxx9DEAQINxYzHTNmDJ5//nkMHz5cCriXL1/Gf//7X5vVT4aqrmZQFVc2ICIiIluxaZg9ceKEtD1o0CCT7X766SeUlJRIoXXVqlVYv3493n33XWzevBkffPABAEAURXz11VfWLZpMijERZrnmLBEREdmKTcNsYmKitB0TE2Oy3YYNGwAAgiBg6NChmDBhgsHrzz77LNq2bQsASE1NxenTpy1fLNXK1Mjs8RSGWSIiIrINm4bZrKwsaTskJMRoG41Gg71790rTC+677z6j7e666y5p+/jx4xaskswVHeIFpVv1LnQ5swg5RWV2qIiIiIhcjU3DbGlpqbTt6elptM2hQ4dQWloqTTEYOXKk0XatW7eWttPT0y1YJZlLIZehc4Sf0deOJefatBYiIiJyTTYNs0qlUtouKCgw2mbnzp0AKqYYtGnTxuQIbtUwXFxcbMEqqS66RfoZPX70So5tCyEiIiKXZNMwGxgYKG2fP3/eaJs///xT2o6NjTV5rby8m/MyPTw8LFAd1Ue3Zv5Gjx/lyCwRERHZgE3DbKdOnaTtjRs3Vns9JSUFu3btkubLDhkyxOS1UlJSpO2goCALVkl10b25n9Hjx67kQq83vkYwERERkaXYNMx26dIFwcHBAIBLly7hzTfflF7TarWYO3cudDodRFGEm5ubyfmyAHD48M1HqbZs2dJ6RVONQnyUiPCrPv+5QKPFxYxCO1RERERErsSmYVahUODhhx+Wbu567bXX0L17d9x7771o3769wZJc99xzDwICAoxep7i4GHv37pX2a1rmi6yvm4nRWc6bJSIiImuz+eNsX3nlFURHR0uB9vjx41i5ciUSEhKkNr6+vgajtrf67bffUFJSAkEQ0LZtW/j7G5+3SbbRrbmJebNXcm1bCBEREbkcm4dZlUqFrVu3IjY2FqIoSh9AxRO9QkND8euvvyIyMtLkNb744gtp+84777R6zVQzU/Nmj3BkloiIiKxMYY83bdKkCXbu3IkdO3YgLi4OaWlp8PT0RI8ePTBhwgSoVCqT5yYlJUEul0uPw50yZYqtyiYTOjTxgbtchjKd3uD4hfRC5JeWw0fpZqfKiIiIqLGzS5itNHDgQAwcOLBO50RGRiIuLs5KFVF9eCjk6BjhU21agShWTDUY1CbYPoURERFRo2fzaQbUOHU3MW/24OVsG1dCREREroRhliyidwvjK08cYJglIiIiK7LrNANzXbhwAfHx8SgvL0dUVBR69uxp75LoFr2ijIfZY8m5KC3XQekmt3FFRERE5ApsHmZTU1Nx7tw5AICPj0+NwTQ+Ph4zZ87EwYMHDY43bdoUH3/8MSZMmGDVWsl8AWp3RId44UL6zQclBHm549FBraDjk8CIiIjISmw+zeCll17CnXfeiTvvvFN6SIIxCQkJiI2NxcGDB6st35WcnIx77rkHS5YssVXZ9VJUVIQVK1Zg8uTJ6NChA/z9/aFSqdCyZUvExsbiySefxLp165CT0ziWsJo9oCVGxoRJ+6XleszoHwW1h1P8AoCIiIickM3D7KZNm6Rg+q9//ctku0cffRR5eXkAKp4IBkA6TxAEiKKIJ598EvHx8VauuH7WrFmDtm3bYurUqVi1ahXOnDmD3NxclJSU4PLly9izZw8+/fRTTJgwAa+++qq9y7WIyb2a4f8Gt5L2CzVanLlWYMeKiIiIqLGzaZi9cOECsrOzIQgCunbtiqZNmxptd/jwYfzzzz9SiI2OjsbatWsRHx+Pn376CeHh4RAEAVqtFm+88YYt/wpmee655zBp0iSkpqZKx4KCgtCrVy/cfvvt6NatW41r6TqzDuE+8KoyErv/cpYdqyEiIqLGzqa//62cKwsAvXv3Ntnuxx9/BFAxEuvj44OdO3ciOLhirdJ27dqhffv26NGjB/R6PX799VcUFRVBrVZbt3gz/fvf/8aHH34o7Q8dOhRvvPEG+vbtK4VzANDr9di/fz9WrVoFLy8ve5RqFQq5DD0i/bH9fAYAYP/lbMwa0NLOVREREVFjZdMwm5ycLG23bdvWZLs//vgDQMV0gvvvv18KspW6dOmC4cOHY/PmzdBoNDhy5AgGDBhgnaLrYMeOHXjnnXek/RdffNFgvyqZTIZ+/fqhX79+tirPZnq3CJDC7MHEbOj1ImQyoZaziIiIiOrOptMMCgpuzp/08/Mz2iY9PR1nz56V9idOnGi0XWxsrLRdtb296HQ6zJo1S5rXe9ddd5kMso1d35Y3l+nKLS7H+XTOmyUiIiLrsGmY1Wq1tbbZtWuXtO3h4WEQWqsKDw+XtnNzcxtcW0Nt3LgRFy5cAFAxovzJJ5/YtyA76hThB6Xbza7FBycQERGRtdg0zHp7e0vbGRkZRtts374dQEUg7N27N9zd3Y22qxwBBcwLyda2dOlSafuOO+5Aq1atamjduLkrZAaPt913iTeBERERkXXYNMxWXb3gyJEjRtv8/vvv0rapUVkAyM6+Odpn7xuotFot4uLipP277rrLjtU4hj4tAqXtXRcysfpQMuLOXrdjRURERNQY2TTMdu/eHUDFqOrvv/9ebXT2r7/+wuXLl6X9oUOHmrxW1ZURqk45sIcTJ06gpKRE2q+8qevYsWN47LHH0K5dO6jVavj4+CA6OhoPPPAANmzYYDC63JgUl2mhqPL02vxSLZ5bfQLLdifarSYiIiJqnATRxomqd+/eOHz4sLS9dOlStGnTBnv27MH06dNx7do1iKKIJk2aIDk52WA5q6o6d+6MU6dOQRAEHDlyBF26dLHlX8PA8uXL8dBDD0n7GRkZeP/99/Hhhx9Cr9ebPK9Hjx5YuXIlWrY0f+mqkpISgzVqDxw4AKVSafb5mZmZACrWvbWW9CItHl5/tdpxd7mAn+9pCnc5VzZozGzRx8h1sX+RtbGP2UZpaanBMq3FxcXw9PSs17Vs/gSwl19+WRqRPHDgALp27QqVSoWhQ4fi6tWrEEURgiDgmWeeMRlkL126hFOnTgEAlEolYmJibFa/MZUdHwA8PT3xyiuv4IMPPpCCbOvWrTFkyBB0794dCsXN1dAOHz6M3r17O8RqDJYUolagiXf1Vd/KdCLOZmjsUBERERE1VjZdZxYAxo0bh8ceewyLFi2SHktbqXL/tttuw5NPPmnyGj/99JPUvk+fPpDL5Sbb2kLV1RRKSkrw5ZdfAqiYbvDll1+iU6dO0uvZ2dl45ZVXsHjxYgBAVlYWJk2ahCNHjpi82a0mMTExdfpJ5uTJkwBgUJM1DLkI/Lj/SrXj1/Q+mNbJ9BrD5Pxs1cfINbF/kbWxj9lG1emZDWXzkVkA+Oyzz/Dll18iKirK4LhSqcTjjz+OP/74w2RALSsrwxdffAGgYu7tyJEjrV1urUpLS6sd69GjB/75559q3wwBAQH44osvMG/ePOnY6dOn8f3331u9TluKbW381zO7EzKNHiciIiKqD5uPzFaaPXs2Zs+ejcTERKSlpcHT0xPt27evdXQyJyfH4GEEI0aMsHaptTL2KN0vvviixhHTt956Cz/99BNSU1MBAN988w0efvhhq9Voa/1aBkIQgFtnZJ9IyUNBaTm8lW72KYyIiIgaFbuF2UpRUVHVRmhrEhoaigcffNB6BdXDrUuDtWvXzmBSszFubm6499578d///hcAcPDgQRQVFRkNxs7IX+2ODuE+OH013+C4Ti9i/6VsDO0QaqfKiIiIqDGxyzSDxubWOx579Ohh1nlV22m1WiQnJ1u0Lnu7zcRUg10XOdWAiIiILINh1gI6dOhgsB8YGGiipaFb2+Xk5FisJkfQ30SY3XYu3caVEBERUWNl92kGlbKzs7F//36cP38eOTk5KCgogLe3N/z9/dGmTRv07dsX/v7+tV/IDjp06GCwMoNGY97yU7feOFbf9dUcVZ8WAfBQyKDRGq61m5hVjMTMIkQFNY4pFURERGQ/dg2zoihixYoV+Pzzz7F3795a2/fv3x9PPPEE7rnnHpNr0NqDt7c3evTogUOHDgGoWAfXHFWfdgZUzAduTJRucvRtGYjt5zOqvbb9fAbDLBERETWY3aYZXLp0CbfddhumTZuGvXv3QhRFk493rXxtz549uPfeezFw4MBqQdDeJkyYIG3v3bsXhYWFtZ7z559/SttRUVF2fyyvNQxqE2z0OKcaEBERkSXYJcyePXsWffv2xb59+6oF2MrgWvXj1td3796Nvn374vz587Ysu0bTp0+XHitbWFiIhQsX1tj+yJEj+OOPP6T9cePGWbM8uxnc1niY3XspC6XlOhtXQ0RERI2NzcNsUVERRowYYfAIWJVKhQceeAArV67EuXPnkJubi/LycuTm5uL8+fNYtWoVHnzwQWnZKkEQkJGRgeHDh6O4uNjWfwWjmjZtiieeeELaf+ONN7B+/XqjbS9fvox77rlHetytUqnEc889Z4syba5FkBrNA1TVjpeW67H/crYdKiIiIqLGxOZh9r333sOVK1ekG6YmTpyICxcuYPny5Zg0aRKio6Ph4+MDuVwOHx8ftG7dGhMnTsSyZctw8eJFTJo0CaIoQhAEXLlyBe+9956t/womzZ8/H926dQNQ8aSy8ePHY+LEifjpp5+wY8cO/Pbbb3j22WfRqVMng3m1ixcvRkREhL3KtipBEEyOznKqARERETWUTcOsKIpYsmSJdPPWrFmzsGrVKoSFhZl1fkhICFauXInZs2dLUxAWL15scq6trXl5eWHTpk0Gj7Bdu3Ytpk2bhkGDBmHMmDH46KOPUFRUBACQy+VYuHAhZsyYYaeKbcPUvNnt56rfGEZERERUFzYNswcOHJCmF0REROCzzz6r13U+/fRTNG3aFACQlZWF/fv3W6zGhgoLC8OhQ4cwf/58BAcbD3GCIGDYsGHYu3cv5s6da+MKba9fq0C4y6t3tUuZRbiS5RjTRIiIiMg52XRprrNnz0rbkydPhoeHR72u4+HhgcmTJ+Ojjz6Srtu3b1+L1GgJ7u7ueP311/Hqq69i165dSEhIQHp6OlQqFSIiIjBw4ECEhITYu0ybUbkr0KdlAHZeqP7kr23n0/FAvyjbF0VERESNgk3DbHr6zTmSbdu2bdC1qp6fkeGYv65WKBQYPHgwBg8ebO9S7G5Qm2CjYTbuLMMsERER1Z9NpxkoFDezc3l5eYOuVfX8qtclxzS4rfGR6D0Xs1Ck0dq4GiIiImosbBpmqz7h6tixYw261vHjx41elxxTq2A1WtzyxC8PhQwzYqOqPe6WiIiIyFw2DbOVy1aJoojVq1cbrDVbF5mZmVi1apW037VrV0uUR1YkCAKGdQxFZODNNWc1Wj1m3dYCAWp3O1ZGREREzsymYbZ9+/aIioqCIAjIy8vD/fffD41GU6draDQa3H///cjNzQVQ8RjYDh06WKFasrQXR7TDujmxkAk3j/19hmvNEhERUf3Z/KEJzz//vLQu7JYtW3DbbbfhwIEDZp27b98+xMbGYsuWLQAqRvuef/55q9VKliUIAgLU7ugZGSAd2xKfZseKiIiIyNnZ/M6pRx55BN999x32798PQRBw+PBh9OvXD127dsXIkSPRpUsXhISEQKVSobi4GOnp6Th+/Dg2bdpkME9WEAT06dMHjzzyiK3/CtRAwzqG4kBixaNsdydU3ACm9uBNfERERFR3Nk8QMpkMGzduxMCBAxEfHy891vbo0aM13hRWOZpb2b5jx47YuHGj9DQxch53dgjFmxvPAADKtHrsOJ+BkZ3C7VwVEREROSObTzMAgICAAOzfvx8PP/ywQUgFID2mturHra/Pnj0b+/btg7+/vz3KpwaKDFSjTaiXtP9X/HU7VkNERETOzC5hFgDUajW++uornD59GnPmzEGzZs2k4HorURTRrFkzPP7444iPj8eXX34JtVpttC05hzs73FxOLe5sOsp1XJ6LiIiI6s7uExXbt2+Pzz//HJ9//jmuX7+Oc+fOIScnB4WFhfDy8oK/vz/atm3LtWQbmTs7hGHR1gQAQF5JOQ4mZqN/qyA7V0VERETOxu5htqrQ0FCzQ+vtt9+OxMRECIKAhIQEK1dGltY5whch3h5IL6hYmu2HfUnYejYdD8W2QBM/TztXR0RERM7CocJsXSQnJ0thlpxTl2a+2BJfsc7sppMVS3SF+igxa0BLe5ZFRERETsRuc2bJtf2wP0kKslVtPsV1Z4mIiMh8DLNkF3e0Nz6d5HBSDtLySm1cDRERETkrhlmyiwg/T3Rp5mf0tc2nrtm2GCIiInJaDLNkN6Niwowe33ySUw2IiIjIPAyzZDcjY4w/9etgUjbS8znVgIiIiGrHMEt20zxQhZgIn2rHRRH44zRHZ4mIiKh2DLNkV6M6GR+d3XSS82aJiIiodgyzZFemphocuJyN9AJONSAiIqKaMcySXbUIUqN9ePWpBnoR2HSCo7NERERUM4ZZsrvRnYyvarDh+FUbV0JERETOhmGW7G5Mlwijx49eycWVrGIbV0NERETORGGtC7/xxhvWujQAIDs726rXJ9tpHqhCt+Z+OHolt9prvx5PxeO3R9u+KCIiInIKVguzCxYsgCAI1ro8NTJjuzQxGmbXH7uKx4a0Zl8iIiIiozjNgBzC6M5NIDOSVy+mF+LMtQLbF0REREROwaphVhRFq35Q4xHs7YHY1kFGX9twPNXG1RAREZGzsNo0g61bt1rr0tRIje0agZ0XMqsd/+3YVbwwvB1kxoZuiYiIyKVZLcwOGjTIWpemRmp4x1C8vE6GMq3e4PjVvFIcSspB7xYBdqqMiIiIHBXnzJLD8Fa6YWj7EKOvrT/GqQZERERUHcMsOZSxXY2vObsl/jp0es6TJiIiIkMMs+RQBrcNhrfScPZLZIAKW54eCDnnzBIREdEtGGbJoXgo5JjRPwoDo2+ubJCUXYy8knI7VkVERESOimGWHM6zw9ri82nd4aG42T1XH06xY0VERETkqBhmySH5KN0wIiZM2l9zOIVzZomIiKgahllyWPf0aCZtX80rxZ6E6mvQEhERkWtjmCWH1a9VIJr4KqX9VYc41YCIiIgMMcySw5LLBEzs0VTa//N0Gm8EIyIiIgMMs+TQJlUJsxqtHr+fuGrHaoiIiMjRMMySQ4sMVBs8xnbVoRQUabRIzi62Y1VERETkKBhmyeHdU2V09lhyLnr8ZwteXnfSjhURERGRo2CYJYem0epwKaMIVZ/9VarVY+eFTI7OEhEREcMsOTZ3uQx/n7kOYyvM/nLwis3rISIiIsfCMEsOTRAE3Nu7udHXVh5KQblOb+OKiIiIyJEwzJLDm9A9Au6K6l01o0CDf85ct0NFRERE5CgYZsnh+ancMbpTuNHXfjqQbONqiIiIyJEwzJJTMDXVYOeFDN4IRkRE5MIYZskp9IryR+sQr2rHRRFYcZCjs0RERK6KYZacQs03giXzRjAiIiIXxTBLTmNCN+M3gqUXaPDPmXQ7VERERET2xjBLTsNf7Y5RMWFGX/thX5KNqyEiIiJHwDBLTsXUVINdFzNxMb3AxtUQERGRvTHMklPp3SIAbUKr3wgGAN/t4egsERGRq2GYJaciCAIe6Bdl9LU1R1KQX1pu24KIiIjIrhhmyemM7xYBb6Wi2vHiMh3WHE6xQ0VERERkLwyzNlRWVoaYmBgIgiB9REVF2bssp6P2UOCeHs2Mvvb93iTo9aKNKyIiIiJ7YZi1obfeegunT5+2dxmNwvR+kUaPX8osws6LmTauhoiIiOyFYdZGTp06hXfeecfeZTQaLYLUGNw22Ohr3+1JtG0xREREZDcMszag0+nw8MMPo7y8HEqlErGxsfYuqVF40MSNYFvPpSMpq8i2xRAREZFdMMzawCeffIIDBw4AAObPn4/WrVvbuaLGYVCbYEQGqqodF0Vg27kMO1REREREtsYwa2UJCQmYP38+ACAmJgbPPfecnStqPGQyAdP7Vp87+9iQ1niwf5TtCyIiIiKbY5i1skceeQTFxcWQyWT46quv4ObmZu+SGpV7ejZDqI8HQrw9pGN/nk7jigZEREQugmHWir766ivExcUBAP7v//4Pffv2tXNFjY+vpxt2v3A7Xrmrg3TsYnohtp/nNAMiIiJXwDBrJVevXsW8efMAABEREXj77bftXFHjpZDLMComDBF+ntKxr3ZesmNFREREZCsMs1YyZ84c5OXlAQA+++wz+Pj42Lmixk0hl2HmbS2k/T0JWTiVmmfHioiIiMgWGGatYMWKFdiwYQMAYNy4cRg/frydK3INU3o1M3jMLUdniYiIGr/qD7inBsnKysLcuXMBAD4+Pvj888+t+n6nTp2CUqk0u31mZsXTsU6ePGmtkuxqWEsV1sTnAwB+O34VY6KAEDW7uS019j5G9sX+RdbGPmYbpaWlFrsWR2Yt7KmnnkJ6ejoA4O2330ZERISdK3Itd7f1guJGr9aLwG9nC+xbEBEREVkVh6wsaPPmzfjhhx8AAH379sX//d//Wf09Y2Ji4OnpWXvDGyp/0uzUqZO1SrK7MUkC1h5JBQD8lVCE0b3bIi2vBNNNPDGMLMsV+hjZD/sXWRv7mG2UlJRY7FocmbWQgoICPProowAANzc3LF26FDIZP732MHtAS2m7uFyP2f87hP/8fgZpeZb7lQYRERE5BqYtC3nxxRdx5coVAMBzzz3Hn+js6HBSDtwVhl27TKfH17whjIiIqNFhmLWA+Ph4LF68GADQqlUr6fG1ZB/X80tRptVXO/7j/ivIKSqzQ0VERERkLQyzFpCeng5RrHh8akJCAjw9PSEIgsmP7777Tjo3KSnJ4LWnnnrKTn+LxuOh2BbwdJNXO15SrsOyPYm2L4iIiIishmGWGp0AtTvu7d3c6GvLd19GoUZr44qIiIjIWriagQW4ubkhMDDQ7PaFhYXQaDQAAJlMBn9/f+k1Ly8vi9fnimYPbIHv9yWiXCcaHM8v1eLHfUn416BWdqqMiIiILIlh1gJiY2OlRZbNMWPGDGmqQbNmzZCYmGilylxXuK8nJnZvil8OJld77audl/Fg/ygojUxFICIiIufCaQbUaP1rUCvIhOrHMws1WHU4xfYFERERkcUxzFKj1SJIjdGdmxh9bcm2BKMrHhAREZFzYZilRm3OYONzY1NzS7DmCEdniYiInB3DLDVq7cN9cEe7EKOvfR53kaOzRERETo5hlhq9J+6INno8NbcEKw9Vv0GMiIiInAfDrB0sX74coihCFEWuZGADXZv5YUjbYKOvLdp6ERqtzsYVERERkaUwzJJLePrONkaPX8srxQojy3cRERGRc2CYJZfQuakfhrY3Pnd20daLKC3n6CwREZEzYpgll/HUUOOjs9fzNfjlwBUbV0NERESWwDBLLiMmwhfDO4YafW3RtgSOzhIRETkhhllyKaZGZzMKNPhuT6JtiyEiIqIGY5gll9I+3AejOoUZfe37fUnQ6UUbV0REREQNwTBLLufJO9pAEAyP+XoqsHZOf8hlgvGTiIiIyCExzJLLaRvmjfFdIwwCbV6JFlvir9uvKCIiIqoXhllySc8Nb4vNcwegfbiPdOyTvy+guExrx6qIiIiorhhmySU18fNEu3AfvDiynXQso0CDb3ddtmNVREREVFcMs+TSBkYHoX+rQGl/yfZLyC4qs2NFREREVBcMs+TSBEHACyNujs4WarT4PO6iHSsiIiKiumCYJZfXpZkfRncOl/a/35eI5OxiO1ZERERE5mKYJQLw3LC2UNxYlqtcJ+LDv84BAPRcd5aIiMihMcwSAWgRpMa9vZtL++uPXcUr605i1Kc7+ZhbIiIiB8YwS3TD3DuioXaXS/s/7L+Cs2kFWLY70X5FERERUY0YZoluyCrSwF/tXu34oq0XkVGgsUNFREREVBuGWaIbyrUiUnNLqh0v1Gjx0ZZzdqiIiIiIasMwS3RDp6a+mNi9qdHXVhxMRvzVfBtXRERERLVhmCWqYt7wtlBVmTdbSS8Cb26MhyhydQMiIiJHwjBLVEWojxL/N6iV0df2JGRh86k0G1dERERENWGYJbrF7IEt0cRXafS1N36LR5FGa+OKiIiIyBSGWaJbKN3keGFkO6OvpeWX4tO4CzauiIiIiExhmCUyYkyXJujdIsDoa9/svIyL6QU2roiIiIiMYZglMkIQBPxnbAzkNx5xW5VWL+LV9ad5MxgREZEDYJglMqFtmDdmxkYZfW3vpSz8duKabQsiIiKiahhmiWrw5NA2CPXxMPram7/Ho5A3gxEREdkVwyxRDbw8FPj36A5GX0sv0OC/f/LJYERERPbEMEtUi7s7h6Nfy0Cjr323NxFHr+TYuCIiIiKqxDBLVAtBEPCfcR2hMHIzmCgCL645iTKt3g6VEREREcMskRlah3jjkYEtjb527noBlu5IsHFFREREBDDMEplt7h3RiApUGX3t07iLSMgotHFFRERExDBLZCalmxxvT+hk9LUyrR6buFQXERGRzTHMEtVB/1ZBmNKzWbXj3Zv74Yk7ou1QERERkWtjmCWqo5dHtUeQl+Has0eu5OKPU2l2qoiIiMh1McwS1ZGvyg0fTu6C7x7qbRBq5284hdziMjtWRkRE5HoYZonqYVCbYAxqG4w3xnaUjqUXaPDar6ftWBUREZHrYZglaoCRMWEYGRMm7W84dhWbTvJGMCIiIlthmCVqAEEQ8Oa4GASq3aVj/153EhkFGjtWRURE5DoYZokaKNDLw2DJrpzicry09iREUbRjVURERK6BYZbIAoZ3DMOE7hHS/t9nrmPVoWR8vy8JF64X2LEyIiKixk1h7wKIGovX7u6IPRezkJZfCgB4ae0p6EQR7cN9sG5Ofyjd5HaukIiIqPHhyCyRhfh6uuG9iTenG+huTDM4cy0f7/9xzl5lERERNWoMs0QW9Mdp4w9O+Hb3ZWw9l27jaoiIiBo/hlkiCxoRE27ytXmrjnOVAyIiIgtjmCWyoEFtgjHrthZGX8ssLMNzq45Dr+cqB0RERJbCMEtkYfNGtEWHcB+jr20/n4Fvd1+2cUVERESNF8MskYV5KOT49N5uULoZ//Z674+zOJaca9uiiIiIGimGWSIraB3ihdfu7mj0tXKdiMd+PIKcojIbV0VERNT4MMwSWcnUXs0wMibM6GupuSV4euUxzp8lIiJqIIZZIisRBAHvTOiECD9Po69vO5eBxdsTbFwVERFR48IwS2RFfip3LJrWHW5ywejrH/51DnsuZtq4KiIiosaDYZbIyro288MrozsYfU0vAnN/OYrrNx6BS0RERHXDMEtkAw/0i8RdnY0/UCGzsAyP/nAYGq3OxlURERE5P4ZZIhsQBAHvTuyMlsFqo68fvZKLV9adgijyhjAiIqK6YJglshEvDwUWT+thcv3ZVYdTsHxPom2LIiIicnIMsxZUUlKCv/76Cy+99BKGDx+O5s2bQ6VSQalUIjw8HAMGDMCLL76I+Ph4e5dKdtI2zBvvTOhk8vU3N57Bbt4QRkREZDaFvQtoDK5fv44nn3wSv//+O4qKioy2SUtLQ1paGnbt2oX33nsPU6ZMweeff46goCAbV0v2Nr5bU5xOzcfXu6o/1lanF7Hw7wvo3yoQgmB8BQQiIiK6iSOzFpCcnIwVK1ZUC7LNmzdH3759MWTIELRs2dLgtRUrVqBv3764evWqLUslB/HiyHYYEF39Bxl3hQzvTOjEIEtERGQmhlkLGzBgAL799lukpqYiKSkJe/fuRVxcHBISEnD69GmMGDFCapuQkIDJkyfzph8XpJDL8Nm93RAZqDI4XqbV45mVx1BazpUNiIiIzMEwawEymQzjx4/H8ePHsWPHDjz00ENo0qRJtXYdOnTApk2bMHnyZOnY7t278euvv9qyXHIQfip3fPVATwR7e6BPVIB0/HhKHp5ddZyPuiUiIjIDw6wFdO/eHWvXrkXnzp1rbSsIAhYvXgyV6uaI3Jo1a6xZHjmwNqHe2Pn8EHz3cG90aeYnHd944hre//Oc/QojIiJyEgyzdhAQEIDY2Fhp/+zZs3ashuxN6SaH0k2Or6b3QBNfpXR8yfYE/Lg/yY6VEREROT6GWTsJDAyUtvPz8+1YCTmKEB8llj3UG94eNxcZeXX9KWw9m27HqoiIiBwbw6ydJCYmStshISH2K4QcStswbyyZ3gMKWcVqBnoReOynIziVmofU3BJcTC+0c4VERESOhWHWDpKTk3HgwAFpv2/fvnashhxNbOsgvDvx5vzr4jIdHvhmP8Z9vhvTv9mP1NwSO1ZHRETkWBhm7eCdd96BXq8HUHFD2L333mvnisjRTOrRFE8NjZb2s4vLkVGowbW8Ukz/Zj+yCjV2rI6IiMhxCCIXObWpuLg4DB06VFpbdvLkyVixYoXZ55eUlBishHDgwAEolcoazjCUmVnxqFQ+eczxiaKI1+IycDSttNprrQPc8dbQEKjcHO/nUfYxsib2L7I29jHbKC0tRe/evaX94uJieHp61utajvc/YSOWmJiIqVOnSkE2JCQECxcutHNV5KjyNXqcyTQ+Ansxuwxvbc9AuY4/ixIRkWtT1N6ELCE7OxujRo1CRkYGAEAul+P7779HWFhYg64bExNTp59kTp48CQDo1KlTg96XbOM9t2A8teIYjP3+5MR1DRafKMMX07rDTe44P5eyj5E1sX+RtbGP2UZJieXu/3Cc/wEbscLCQowcORJnzpwBUDFP9ssvv8SwYcPsXBk5urFdI7Dg7o4mX98Sfx1zfz6Kcp3ehlURERE5DoZZKyspKcFdd91lsHrBJ598gocfftiOVZEzebB/lMHNYLfafCoNT684Bi0DLRERuSCGWSsqLS3F2LFjsX37dunYe++9h7lz59qxKnJGT94RjQf7RZp8/fcT1/DcquPQ6TmHloiIXAvDrJWUlZVhwoQJ2LJli3Ts9ddfx/PPP2/HqshZCYKA1+7uiAndIky2WX/sKp5ffQJ6BloiInIhDLNWUF5ejkmTJmHz5s3SsZdffhnz58+3Y1Xk7GQyAR/c0wV3d2liss2aIyl4bvVxTjkgIiKXwTBrYVqtFlOmTMFvv/0mHZs3bx7eeustO1ZFjYVcJuDjyV0wulO4yTZrj6TiyV+OoUzLQEtERI0fw6wF6XQ6TJs2DevWrZOOPfXUU3j//fftWBU1Ngq5DJ9M7YrhHUNNttl48hoe/eEwSst1NqyMiIjI9hhmLUSv1+PBBx/EypUrpWOPP/44Pv74YztWRY2Vm1yGz+7tjqHtQ0y2iTubjpnLD6JIo7VhZURERLbFMGsBoihi9uzZ+PHHH6Vjjz76KD799FM7VkWNnbtChkXTag60exKy8MC3B5BXUm7DyoiIiGyHTwCzgFWrVuHbb7+V9uVyOS5duoSRI0eafY0//vjDGqVRI+ehkGPx/T3w9Ipj+P3ENaNtDiflYMqXe7Hq0X7wVrrZuEIiIiLrYpi1gOLiYoN9nU6Hv/76y07VkKtxk8uwcGo3KN3kWH04xWibThG+8PLgtzsRETU+nGZA1AjIZQLen9jZ5IMVDlzOwpXsYqOvEREROTOGWQuYMWMGRFFs0AdRQ8lkAhaM6YhHB7Wq9lpSdgkmfLEHx5NzbV8YERGRFTHMEjUigiDghRFt8cKIdmgVrMaA6CDptayiMkxdug9xZ6/bsUIiIiLLYpglamQEQcD/DW6FjXMHYNmMXri3dzPptZJyHWb/7zB+OXDFjhUSERFZDsMsUSOldJNDIZfh7fGd8MydbaTjOr2IF9eexFsb46HTi9IxIiIiZ8QwS9TICYKAuXdE4/1JnSGXCdLxr3ZexqzvDmLbuXSMWrgTlzIK7VglERFR/TDMErmIyT2bYdmMXvBW3lyia+u5DMxcfhDnrhdg3KLd2HE+w44VEhER1R3DLJELGdgmGOvmxCIqUCUdq5xhkF+qxYPLDmDR1ovQc9oBERE5CYZZIhfTOsQLa/6vP/xU1Z8GJorAB3+ewyPfH+IjcImIyCkwzBK5oIvphcivIaz+fSYdYz7fhTPX8m1YFRERUd0xzBK5oD4tA/HtjF7wruERt0lZxRj/xW6sMfGIXCIiIkfAMEvkoga3DcG6x2LRKlhtsk1puR7PrjqOZ1YcQ6FGa8PqiIiIzMMwS+TCWod4YcPjt2FUp7Aa2609moq7Pt2Jkyl5NqqMiIjIPAyzRC7Oy0OBRfd1x79HtTdYh/ZWiVnFmLB4N77acYmrHRARkcNgmCUiCIKA2QNb4oeH+yDIy91ku3KdiLc2ncFDyw/ien6pDSskIiIyjmGWiCT9WgXi9ycGoE+LgBrbbT+fgWEf78CGY6kQRY7SEhGR/TDMEpGBMF8lfprdF8/c2QY1zDpAXkk5nvzlGOb8eARZhRrbFUhERFQFwywRVSOXCZh7RzRW/qsfIvw8a2y7+VQahn28A/svZdmoOiIiopsYZonIpJ5RAdg0dwBGxtS82kFRmRYR/jWHXiIiImtgmCWiGvmq3PDFtO54b2InqN3lRtuUluvx6T8XkFfMR+ASEZFtMcwSUa0EQcCUXs3xx1MD0a9loNE2Kw+l4I6PtmNHYhFvCiMiIpthmCUiszULUOHHWX2w4O4OULrJoHKXw8vj5mhtZqEGH+zOwoKtGUjOLrZjpURE5CoYZomoTmQyATNiW2DT3AFYfH8P/PPsYAzrEGrQ5si1Utz58XYs3paAcp0eAHAxvZAjtkREZHEMs0RULy2DvTCoTTBCfZRY+kBPLJ3eA+G+Sun10nI93vvjLEYt3Il1R1Ix+tOdmPb1fpxLK7Bj1URE1NgwzBKRRQzrGIYtzwzCmHbeBuvTXkgvxNMrj0Gj1WNPQhZGfboTC349zZvFiIjIIhhmichivDwUmN3DHx+OCEOnCF+jbXR6Ecv3JGLgB1vx1Y5LKC3X2bhKIiJqTBhmicjiWge4Y/1jsfjP2BjIBeOPEcsrKcdbm87gjg+3Y+2RFOj0nE9LRER1xzBLRFYhlwnwVblBV8tNX6m5JXhm5XGM/nQntp1L501iRERUJwyzRGQ1d3cOx8KpXRHmo6y17dm0AsxYdhBTl+7D3gQ+GpeIiMzDMEtEViMIAsZ2jcA/zw7C40Naw11e+z85+y9n496v9mHq0r3Yd4mhloiIasYwS0RWp/ZQ4LnhbfHPs4MwtmsTs87ZdykbU5cy1BIRUc0YZonIZpoFqLBwajf8/sRtGBAdZNY5laF28pd7EXf2OufUEhGRAYZZIrK5mAhffP9wH3z/cG90bOJj1jkHLmdj5vJDGPHJThy9kmPlComIyFko7F0AEbmuAdHBiG0VhN9OXMXCfy7gUkZRredcSC9AoNrdBtUREZEz4MgsEdmVTFZxk9iWpwdh4dSuaBmsrrG9XgQe/u4QVh5KhkbLBy4QEbk6hlkicgjyKqH2kyld0TLIdKi9kF6I51efwMD3t2LxtgTkFJXZsFIiInIkDLNE5FDkMgHjukVgyzMVobZtqLf0mofC8J+s6/kavPfHWfR95x88t+o4TqbkAQCKNFp8u+sy8orLbVo7ERHZHufMEpFDqgy1Y7s2wbZzGViyPQGPDWmFnOJyLN1xCaev5kttNVo9Vh9OwerDKejazA+tQ9RYfTgV7/5xFiNjwjClZzP0bRkImcz4o3WJiMh5McwSkUMTBAFD2oVgSLsQ6diYLk2wJyELX++8hG3nM1B1ta5jybk4lpwLACjT6rHh2FVsOHYVzQNUmNyzKSb1aIYw39qfSEZERM6BYZaInI4gCIhtHYTY1kFIyirCD/uSsOJgMvJLtSbPuZJdjP/+dR4fbTmPQW2CMaF7UwxtHwpPd7kNKyciIktjmCUipxYZqMa/R3fAM3e2xa/HU/HmxjMoqCHU6kVg67kMbD2XAbW7HMNjwjCuawT6twqEwozH7RIRkWNhmCWiRsHTXY47O4ThlfWnzD6nqEyHtUdSsfZIKoK8PHBX53CM6xaBLk19IQicX0tE5AwYZomo0QhQu+PvZwbhl4PJWH04BRkFGrPPzSzUYPmeRCzfk4gIP0+MiAnDiJgwdG/uDzlvHCMiclgMs0TUqEQGqvHCiHZ49s422HouAysOJmPruXTo9GLtJ9+QmluCb3Zdxje7LiPY2wPDOoTi/wa3QlN/lRUrJyKi+mCYJaJGSSGX4c4OobizQyjS80ux+kgKVh1KweXM2h+ZW1VGgQY/7r+Cx29vbaVKiYioIRhmiajRC/FRYs7g1vi/Qa1wNDkXG46m4vcT15BVhyeHPfDNAYyICcOwDmHo2MSHa9YSETkIhlkichmCIKB7c390b+6PV+7qgF0XM/Hrsav483Qaist0NZ57Ib0QF+Iu4rO4iwj29sDgNsEY3DYEt0UHwdfTDQDwv72JCPH2QL+WQfBVudnir0RE5PIYZonIJbnJZRjSNgRD2oaguEyLLfHXsenkNWw7lwGNVl/juRkFGqw6nIJVh1MglwnoEemP21oHYdHWi9Bo9RAEoFOEL/q3CsJtrYPQM8ofSjeuZ0tEZA0Ms0Tk8lTuCoztGoGxXSNQXKbFtnMZ+ONUGuLOpiPCT4mn72yDP06l4Z+z6dXWsNXpRRy4nI0Dl7OlY6IInEjJw4mUPCzZngB3hQw9mvsjtnUg+rQMRKcIX4ZbIiILYZglIqpC5a7AqE7hGNUpHKXlOqTllSIqSI0RMeEo1+lxOCkHW8+lY9vZDJy7XmDWNcu0euy9lIW9l7IAAO4KGbo09UXPqAD0jgpA90h/aaoCERHVDcMsEZEJSjc5ooLU0r6bXIa+LQPRt2UgXhrZHldzS7DtXAbizl7HP2fSYe7iX2VaPQ4m5uBgYg4WIwGCALQN9UbvFgHoEemPLk39EBmo4oMbiIjMwDBLRFRPTfw8cV+f5ugV5Y+/z6TX+zqiCJxNK8DZtAL8b28SAMBP5YbOTf3wyuj2aBPqbamSiYgaHT6InIiogZoHqvDjrD6YM7gVujTzgyVW7cotLseO8xnILymHKJr/wAciIlfDkVkiogbyUMgR2zoIsa2DAAB5JeXYdykLuy9mYvfFTCRk1O1BDVVNWrIXAWp3dG7qi85N/dDlxp/B3h5Sm3VHU3AurRDtw73RsYkPWgR58RG8ROQyGGaJiCzM19MNwzuGYXjHMADAtbwS7E3IujFPNhsX0wvrdL3sojJsO5eBbecypGMh3h5oH+6D9uE+2HUxA6dS86XXlG4ytA31RnSoN6JDvBAd6oXoEG9E+HnyYQ9E1OgwzBIRWVm4rycmdG+KCd2bAqgIp4cSs3EoKQcHLmfjVGoetPq6TSVIL9AgvSAD289nVHuttFyP4yl5OJ6SZ3Dc002OViFqRId4o3WI142g642m/p5wk3PWGRE5J4ZZIiIbC1C7Y1jHMAy7MXJbUqbD0eQcHL2Si+PJuTiRkoe0/FJ8eX93eHu63VizNhfHk/OQmltS7/ctKdfhVGq+wSguAChkApr6eyIqSI2oQDWiAlVoGeyFgW2CG/T3JCKyBYZZIiI783SXo3+rIPRvFSQdS8srhZ/KDUo3ucHxzEINTqXm4cy1Apy5lo/DSdlIzS1t0Ptr9SISs4qRmFUMoGKkt3mACjueH9Kg6xIR2QLDLBGRAwrzVRo9HuTlgcFtQzC4bQgA4Jtdl/Gf3+Mt/v5Xc0sw9vNdaH5jpDbyxp/NA1UI9vKQ1sC9d+k+ZBVp0NRfhQg/TzT190SEvyea+qsQ7qtEkJcHb0YjIqtimLWSixcv4n//+x82bdqE5ORk5OXlITw8HO3atcOUKVMwefJkqFQqe5dJRE5uXNcmaBmkRvy1fMRfy8eZq/m4nFWEhq7mpdWLRufdAhVPMKsMrkeu5ECj1eP8deM3tcllAoK9PBDmq0SYjxJhvkqE+igR5utR8eeNYyp3/ndERPXDfz0sTK/X44MPPsD8+fNRVlZm8FpiYiISExPxxx9/4O2338b333+PPn362KlSImoMAr08MKRdCIa0C5GOFZdpkZBehAvpBbiQXogL1wtxMb0ASdnFDQ65QMUTzC5nFuFyZu1Ljun0ItLyS5GWX/NUCG+lAqE+SgR5uaN9uA9eu7tjwwslIpfAMGthzz33HD7++GNpXy6Xo0OHDvD398fFixdx9epVAMCFCxcwZMgQbNu2Db1797ZXuUTUCKncFejU1BedmvoaHC8t1+FSRkXIvZheiPPXC5CYWYzErCJotHqDttP7RkLpJkNiVjGSsoqQlFVcrY0lFZRqUVBaiIvpwPV8De7qnI1AtQcCvdzh5aEw+mjfBb+exrW8EgSo3eGncoe/yu3Gn1W33eDr6QYFV2sgarQYZi3op59+MgiyQ4cOxdKlS9GiRQsAgCiK2LBhA2bOnImcnByUlJRgzJgxOHPmDPz9/e1VNhG5CKWbHB2a+KBDEx+D43q9iOsFpbicWRFaEzOLMCM2CuG+ngZt0vJLkZxdjNTcEqTmlOBgYjZ2XMi0eJ2XM4swcfFead9DIUOQV0Wwdddr4KuUo3XKGfx+4ioyC8tquNJNPkoF/NXu8PN0Mwi+vp5u8FYq4OPpBp8bf1a94Y6IHB/DrIVoNBq89NJL0n6fPn2wadMmuLm5SccEQcC4cePQrFkz9O3bF1qtFtevX8d7772Hd9991x5lExFBJhMQ7uuJcF9P9G9luk0TP0808bsZcNccTsHuhCzo6rhGbl1ptPqKAF1lWbJ/Ll2q0zXyS7XIL9UiqZZ23h4KnHx9eK3X+/nAFZxIyYO3UgG1uwJqDzlUN/5UuyuguvGn2kMOtYei4jV3OUeIiaxAEPnQb4v4+uuvMXv2bGn/6NGj6Nq1q8n2Tz31FBYuXAgAUKlUSEtLg7e3d63vU1JSYnDjWHFxMTw9PWs4w9DJkycBAJ06dTL7HKK6YB9zLVqdHmn5pUjNKUGK9FGMq3klSMsrxfV8DQo1WnuXaTYBQBM/z4rRWmXFqG3Fh5vBn2sOp+Bocm6dr++ukMHLQwGV+61hVw5PNzleHt0eId7GV7KodC2v4vOsVMjh6S6Dh0IOT3c5lG4V1+DqEQ3Df8Nso6F5piqOzFrImjVrpO3+/fvXGGQBYM6cOVKYLS4uxubNmzF58mRrlkhEZHEKuQxN/VVo6q+CqdtZCzXaG8G2FGl5FTeDVW5fv3FzWEaBBpUDvPPv6oC7uzRBZqEGWYVlyCrSILOwDJmFGlxMTkNuqQ5Fojvir+abeMf6E4EGPZiiNmVaPbK1Zcg2ce/cgOggNPVXQekmv/Ehq/hTIYeHmwweChk2n0zDGzUsx+Yul8HjxnkeChncFbKKY5XbN/YrtuXS9qQeEegRGVBj/QWl5ThwOVu6hkIug5tcgEJ240+5DAqZADe5DAq5ADdZxZ+V23ycMlkDw6wFFBcXIy4uTtofPXp0ree0adMGrVq1QkJCAgDgt99+Y5glokbJy0OB1iFeaB3iZbKNVqdHdnEZMgvKEOztIX3c6uTJcgCALLA5Rn+6y2o128uzq07U+LogAHIjN8NVVabTo0ynR0Fp3UbEfT0V0IsVYdjtRsD1UNzcdlfIkJBRhIe/O1Sn61YlEyp+AHKTCQZBeGSnMLNWsJi36jiKy3WQCwLkMgEyQYBCJkAmEyCXAQqZDDKhYlsuk1X8KQjStkx2o/2N8+UyAWp3BSb2aFrre59Ny0dWYZl0nkyqAZAJAgQBECBAJqvYlwkV0wsrtyvbyKocEwQB/qrab1DU3/hJT7hxDhlimLWA+Ph4g2W4+vfvb9Z5sbGxUpg9duyYNUojInIKCrkMId7KWn/FXql1iBe2PD0QmYVlyC0uQ05xOXKKb25X/TO3uBy5JeVmze1tF+aNST2a3lhdQYuC0vKKPzXlBsfMvfHM0kQR0FppduCS7ZewZHvd5iLXlV6sGJ2u+OzppOM7zmfgrY3x0siuonJE95bQ+/uJaygp15m6fL0Eqt0xsE1wRUgVBBSX6yETAI32ZmgWBAGfx13E7yeuWfS9AeDPpwaibVjN0wxXH07B82sqftC5GYgrw/LNgFz1tYr9qq9XtK8IxBXBe87gVpjau3mN751ZqMH9X++vOBcwOF9244B0HJDayW4cuPnazfoEAWgTWP2H1fpimLWA+HjDX/dER0ebdV7r1q2l7fPnz0On00Eul1u0NiKixshDIUd0qDeiQ81rr9eLKNBoDYJvXnE5CkrLb9wcVhFW24Z648H+UbVer/dbfyO9QNOwvwRJEjKKkJBx2S7vnVVUhl5v/V39hRUp0qYgoGIOihU8+ctRqD0UUgCUAqnsZgC8XmWdZlEEdKJ440eBhhW15kgqLqQXGgZdCFWCKVBUqsPZtIIGvY8xV9ItF0EZZi0gMTFR2lYoFAgPDzfrvObNb/40VFZWhqtXr6JZs2aWLo+IyOXJZAJ8PSvWnI0MbPj1Pru3G3KKy1Gk0aKoTIsijQ7FZVoUarQo1uhQVKZFcZmuYr/s5rGiG38aG1x1V8hwcsEwlJbpUarVobRch9JyPUrKK7cr9n/Yl4RdFy2/JBqZZs1b5a0RFM11MDEbBxOz7fLe5jx0xVwMsxaQn3/zJgRvb2/IZOYtveLra7igeUFB3Tv0qVOnoFSa92s5AMjMrPgHsPJuTSJLYx8ja3KU/qW68QH3Gx8G04EFAG43PqoTRREanYiSchGlWj1KtSKKy/XQ6YHzZ6rf2CUHoL7xAQBdA/XQazyh0Yko04nQaG/+qdGJ0Oj0KNOKKK/jMy7mDwpC22APlOsqztXqxRvbIrQ6oFwv4vT1Uvx8yvI33gV6yhHqpYBOL0InVry34XbFaGRuqfUe3EHOi2HWAoqKbv50UZdgeesSFIWFxp9tTkREjYcgCFAqBCgVQEVUrZvhrb0wvLXpm+kq6UVRCqY3Q2nFn+U3wmm5tC+iTZAHfDxqrsfLXYbMEt3N6+krHlmsvRE2b+5XBFCteOPPG+FUK1ZpfyOsAsCAKBUe7l7zw4P0ooixPyWb/XkyV7BKjucHBEGvr3iP7Nw8iCLg5eMDvVhxTC8CK07mISGn3OLvP7yVGl4eMujFihFgPSp+4BFxY18EknLLEZ9h+WktYV5yBHoqbrzXzfcUAWm7XCciKc/yf283Cy65zDBrAeXlN7/ICoX5n9Jb21a9icxcMTExXGeWHAr7GFkT+5d9dQIwbpDlrieKFcEXANzMuKN/1aNNodOL0OvFinmj+psfelGUQrNerAju+hthWqfXS+FZfyNs62+c7+vphnuqzJM22ce8EnD6av4t71nxd6gMvHpRvBFAbx7DLftilbZ6EZh/T09E+NX8//iqQ8n471/nqp+vr/p+Jt6/Bo8MbouZt7WosU1ydjEGvL+15gvVQ59WQbDU7YYMsxZQddHf0tLSGloaurWtl1ftP2kTERE1FoIgwE1u3lJTMpmAXlE1r4NrTY8MNPF4PBu4p2cz3NOzfvfUGIbnirBbMfoq1voDBFDxEJED/74DEFFl5Fa8OYJ7yzUNjqNyvvHN45U1yHXl+Pn/6vVXqoZh1gKqhtCSEvMX2y4uLjZ5HSIiIqKGEgQBcgGQo37r08plgtlL5tVFXfJSbfiQaAsICgqStgsLC82e+3rtmuF6dYGBFrjFloiIiMiFMMxaQLt27Qz2k5KSzDrvypUr0nZoaCj8/Wue/E5EREREhhhmLaBjR8NH8B09etSs844cOSJtt2/f3qI1EREREbkChlkLiIyMRGRkpLS/Y8eOWs/RaDTYv3+/tD948GBrlEZERETUqDHMWsi4ceOk7dWrV9c6sXnt2rUGN4CNHz/eWqURERERNVoMsxby0EMPQRAq7hTMycnBp59+arJteXk53n33XWm/R48e6Ny5s9VrJCIiImpsGGYtpEuXLpgyZYq0v2DBAmzZsqVaO51Ohzlz5uDEiRPSsbffftsmNRIRERE1Nlxn1oI+/PBD7Nq1CykpKSgtLcWoUaMwffp03H333fDz88OFCxewdOlSHD58WDpn5syZGDZsmB2rJiIiInJeDLMW1KRJE/z+++8YMWIE0tLSoNVqsWzZMixbtsxo+7Fjx2LJkiU2rpKIiIio8eA0Awvr0qULTp06hRkzZsDT0/izliMjI7FkyRKsX78ebm5uNq6QiIiIqPHgyKwVBAYGYtmyZfj000+xdetWJCcno6CgAKGhoWjXrh369u0r3SxGRERERPXHMGtF3t7eGDNmjL3LICIiImq0OM2AiIiIiJwWwywREREROS2GWSIiIiJyWgyzREREROS0GGaJiIiIyGkxzBIRERGR0+LSXE5GFEWD/ZKSkjqdX1paWq/ziMzFPkbWxP5F1sY+Zhu3fn5vzTd1wTDrZCq/ySoFBgbaqRIiIiIiyygtLYVKparXuZxmQEREREROi2GWiIiIiJyWIDZkkgLZnF6vR25urrSvVCohCIL9CiIiIiKqI1EUDaZO+vn5QSar3xgrwywREREROS1OMyAiIiIip8UwS0REREROi2GWiIiIiJwWwywREREROS2GWSIiIiJyWgyzREREROS0GGaJiIiIyGkxzLqAixcvYv78+ejZsydCQ0OhVCrRokULjBw5EsuXL0dxcbG9S6Q6ysjIwObNm/HGG29gzJgxCA8PhyAI0seCBQvqfW2tVotVq1ZhwoQJaN26NVQqFQIDA9GlSxc8++yzOH78eL2vba2+aM2aXVFJSQn++usvvPTSSxg+fDiaN28OlUoFpVKJ8PBwDBgwAC+++CLi4+PrdX32Mdel1Wpx8OBBfPbZZ5g9ezZuu+02NG/eHGq1GgqFAn5+fmjTpg2mTJmCZcuWobCwsF7vwf7lYkRqtHQ6nfjuu++K7u7uIgCTH9HR0eK+ffvsXS6Z4dq1a2JkZGSNX08A4muvvVav6589e1bs2bNnjdcWBEF85plnxNLSUrOva82+aK2aXVFaWpo4ZcoUUa1W19rHKj+mTJkiZmRkmP0e7GOu7cUXXzS7bwEQAwICxG+//dbs67N/uSaG2Ubs6aefNvhmkMvlYqdOncSBAweKTZo0MXjN09NT3L9/v71LplpcvnzZrP8A6hNmExISxODgYIPrBAcHi7fddpvYtWvXav+IT5o0SdTr9WZd21p90Zo1u6KDBw8a7U/NmzcX+/btKw4ZMkRs2bJltddbtWolpqam1np99jF64YUXDD5fHh4eYocOHcQBAwaIt99+u9i5c2ejgfHll1+u9drsX66LYbaR+vHHHw2+AYYOHSpeunRJel2v14vr1q0T/f39pTahoaFidna2Haum2lQNs8HBweKIESPEV155RVy/fn2DwmxZWZnYoUMH6XylUil+8803Ynl5udTm2rVr4tSpUw3e5+2336712tbqi9as2VVVDbMDBgwQv/32W6Mh9fTp0+KIESMMPq+xsbE1/ifLPkaiKIqvvfaaOGLECPHzzz8Xjx07Jup0umptCgsLxcWLFxt8vQCImzZtMnld9i/XxjDbCJWWlorNmzeXOn6fPn3EsrIyo20PHTokKhQKqe0LL7xg42qpLvLy8sRVq1aJiYmJ1V5rSJhdtGiRwfm//vqr0XZ6vV6cMGGC1M7b21tMT083eV1r9kVr1ezKDh8+LI4fP148fvx4rW31er04efJkg6/B+vXrTbZnH6O6OnbsmOjh4SF9XgcPHmyyLfuXa2OYbYS++uorg2+Qo0eP1tj+ySeflNqqVCoxPz/fNoWSRdU3zOr1erFZs2bSuePGjauxfVpamsF/MK+++qrJttbqi9asmcyXlZUlqlQq6fM6ffp0o+3Yx6i+Zs6cKX1O5XK5wahlJfYvYphthKr++q9///61tj937pzBN+uKFStsUCVZWn3D7L59+wzO/euvv2o9595775Xat2/f3mQ7a/VFa9ZMdXPnnXdKn9devXoZbcM+RvV16+jl1atXq7Vh/yIuzdXIFBcXIy4uTtofPXp0ree0adMGrVq1kvZ/++03q9RGjqnq11ulUmHIkCG1njNq1Chp+8yZM0hISKjWxpp90Vo1U90FBgZK2/n5+UbbsI9RfWm1WoN9b2/vam3Yv4hhtpGJj49HWVmZtN+/f3+zzouNjZW2jx07ZumyyIFV/Xr36tULCoWi1nOq9pdbr1HJmn3RWjVT3SUmJkrbISEhRtuwj1F9bd26Vdru0qULvLy8qrVh/yKG2Ubm1kXMo6OjzTqvdevW0vb58+eh0+ksWhc5rqp9xtz+EhkZCTc3N2n/zJkzNV63Ltc2py9aq2aqm+TkZBw4cEDa79u3r9F27GNUH+vWrcOGDRuk/Xnz5hltx/5FDLONTNVREoVCgfDwcLPOa968ubRdVlaGq1evWro0ckCiKCIpKUnar9oPaiKTyRARESHtX758uVoba/VFa9ZMdfPOO+9Ar9cDAARBwL333lutDfsYmUun0yErKwtxcXGYOXMmJk2aBFEUAQBz5szBtGnTqp3D/kUAUPu4NjmVqnPWvL29IZOZ9/OKr6+vwX5BQYFF6yLHVFRUJIURoHo/qEnVtsb6i7X6ojVrJvPFxcVhyZIl0v4999yDbt26VWvHPkY1adeuHc6dO2fy9VatWuG1117D9OnTjb7O/kUAR2YbnaKiImlbqVSafZ6np6fBfn2eh03Op2p/AerfZ4z1F2v1RWvWTOZJTEzE1KlTpVGzkJAQLFy40Ghb9jGqr4iICDz++OMYM2aMyTbsXwQwzDY65eXl0rY5E8pNta066Z0ar6r9Bah/nzHWX6zVF61ZM9UuOzsbo0aNQkZGBgBALpfj+++/R1hYmNH27GNUkwEDBmD48OEYPnw4br/9dnTp0gXu7u4AgNTUVDz99NNo0aIF1qxZY/R89i8COM2g0VGpVNJ2aWmp2efd2tbYHaPU+FTtL0D9+4yx/mKtvmjNmqlmhYWFGDlypHTjiSAI+PLLLzFs2DCT57CPUU2++uqrasdKS0uxevVqvPzyy0hOTkZOTg4mT56Mn3/+GZMnTzZoy/5FAEdmG52qnbukpMTs84qLi01ehxqvW9dsrG+fMdZfrNUXrVkzmVZSUoK77rrLYPWCTz75BA8//HCN57GPUV0plUrcf//9OHLkCDp06AAA0Ov1eOSRR5CTk2PQlv2LAIbZRicoKEjaLiwsNHtOzbVr1wz2qy6ETo2Xm5ubwT+st/aDmlRtW7XfGTtmyb5ozZrJuNLSUowdOxbbt2+Xjr333nuYO3dureeyj1F9BQUFYenSpdJ+Xl4efvjhB4M27F8EMMw2Ou3atTPYr7r8R02uXLkibYeGhsLf39+idZHjqtpnzO0vhYWFBiMkt/Y7Y8cs2RetVTNVV1ZWhgkTJmDLli3Ssddffx3PP/+82ddgH6P6io2NRdOmTaX9vXv3VmvD/kUMs41Mx44dDfaPHj1q1nlHjhyRttu3b2/RmsixVe0z9ekvgPE+Y82+aK2ayVB5eTkmTZqEzZs3S8defvllzJ8/v07XYR+jhmjWrJm0nZmZWe119i9imG1kIiMjERkZKe3v2LGj1nM0Gg32798v7Q8ePNgapZGDGjhwoLSdkJCA1NTUWs+p2q9UKhV69epVrY01+6K1aqabtFotpkyZYvAM+Xnz5uGtt96q87XYx6gh8vLypG1jo5zsX8Qw2wiNGzdO2l69enWtk8vXrl1rMKl8/Pjx1iqNHNCYMWMgl8ul/VvnpBlTtc3w4cOr3Z1byVp90Zo1U8WTmKZNm4Z169ZJx5566im8//779boe+xjVV3p6Os6ePSvtt2rVqlob9i+CSI3OsWPHREEQRAAiAPHdd9812basrEzs3Lmz1LZHjx42rJQsqfJrCEB87bXX6nTu+PHjpXPDw8PFnJwck21//vlng/f69ddfTba1Zl+0Vs2uTqfTidOmTTP4fD3++OMNvi77GNXHI488YvB53bNnj9F27F+ujWG2kZo6darU6ZVKpfjXX39Va6PVasVZs2YZfIP8+eefdqiWLKEhYfb06dOiXC6Xzh89erRYXFxcrd3hw4fFwMBAqV2/fv1qvba1+qI1a3ZVer1enDlzpsHX4dFHHxX1en2Dr80+Rn/++af47LPPileuXKm1bVFRkfjkk08afL2GDBlisj37l2sTRPHG8wipUbl69Sr69OmDlJQUABVPDZk+fTruvvtu+Pn54cKFC1i6dCkOHz4snTNz5kx888039iqZzDR79mx8//331Y5rNBppWy6XG32qzF9//WUwV6uq//znPwY39rRt2xZz5sxBTEwMCgsL8c8//+Drr7+WfoXm4+OD3bt3IyYmpsZ6rdkXrVWzq1q5ciWmTJki7cvlctxxxx0QBMHsa/zxxx8mX2Mfc23r16/H+PHjIQgC+vTpgwEDBqBz584ICQmBWq1GcXExUlJSsH//fqxZs8bgZq/w8HDs2rULLVu2NHl99i8XZu80TdZz7NgxMSwszOAnRVMfY8eOFcvKyuxdMpnhwQcfNOtrauxj69atNV57zpw5Zl3Hx8dH3LJli9k1W7MvWqtmV7Rs2bJ6963Kj9qwj7mudevW1atPde/eXTx//rxZ78H+5ZoYZhu5zMxMccaMGaKnp6fRb47IyEhxyZIl9i6T6sCaYVYURXHNmjVi+/btjZ7v5uYmjh8/XkxKSqpz3dbsi9aq2dXYIsyKIvuYq0pOThafffZZMSYmRpTJZLX2pdjYWPHbb78VtVptnd6H/cv1cJqBiygoKMDWrVuRnJyMgoIChIaGol27dujbt2+dfoVIruPYsWM4ceIErl27Bk9PTzRt2hQDBw5s8FNnrNkXrVUzWQf7mOsqKCjA8ePHcenSJWRkZKCkpASenp7w9fVFy5Yt0a1btwY/vIf9y3UwzBIRERGR0+I6s0RERETktBhmiYiIiMhpMcwSERERkdNimCUiIiIip8UwS0REREROi2GWiIiIiJwWwywREREROS2GWSIiIiJyWgyzREREROS0FPYugIjIEeXl5eHw4cNISEhAbm4uNBoN1Go1AgMDERkZiXbt2iE0NNTeZRIRuTyGWSKiKjZs2IDPP/8c//zzD2p72nfTpk1x2223YcSIEZg0aRLUanW1Ntu2bcO2bdsAAH5+fnjqqaesUDVZUm5uLj755BNp/8EHH0SLFi3sVxAR1UgQa/vXmojIBeTm5mL69On4/fff63X+3r170bdv32rHFyxYgNdffx0AEBkZicTExIaUSTawefNmjBo1StpPSUlBRESEHSsioppwZJaIXF5RURGGDRuGgwcPGhzv3bs3BgwYgJYtW0KlUqGgoABpaWk4cuQI9u/fj5ycHDtVTNZUtR+EhYUxyBI5OIZZInJ5CxYsMAgwnTp1wvLly9G9e3eT52i1Wmzbtg0///wzfvrpJ1uUSTZStS/06tXLjpUQkTkYZonIpRUVFeHzzz+X9iMiIrB9+3b4+/vXeJ5CocDQoUMxdOhQvP/++5DL5dYulWykapjt2bOnHSshInMwzBKRS/vnn39QWloq7T/xxBO1BtlbBQYGWrqsGp07dw5HjhxBeno6SkpKEBISgvbt26NPnz6QySyz4mJxcTG2bduG5ORk5OTkICwsDF27dkXXrl3rdb2CggIcPnwYZ8+eRV5eHrRaLVQqFcLCwtCiRQt06dIFnp6eFqm9IZKTk3H9+nVpn2GWyAmIREQu7JNPPhEBSB+bN2+2yHWrXtOcj8jIyBqvV1ZWJi5cuFBs0aKFyWsEBweLb7/9tlhaWmpWjQ8++KB07qBBg0RRFMWioiLxiSeeEL29vY2+R/v27ev0OUpMTBTvu+8+UalU1vj3d3NzEwcMGCCuXbvW7GtbyoULFyz+9SIi2+FDE4jIpRUXFxvsVx2ldRQJCQno3LkznnzySVy+fNlku4yMDLz88svo1asX0tLS6vw+aWlp6NOnDz777DMUFBQYbXPmzBmMHDkSr776aq3X27ZtG2JiYvDTTz/V+nktLy/Hzp07sWbNmjrX3VDHjh2r8zmdO3e2fCFEVC+cZkBELi04ONhg/48//sC4ceMafN1WrVoBALKzs6VVDxQKBSIjI422b9q0qdHjZ86cweDBg5Geni4dCw8Px5gxY9CxY0eo1WpcuXIFGzZskELZyZMnMXjwYBw6dAheXl5m1avX6zFt2jScOnUKABAbG4tRo0YhNDQUGRkZ+PPPP6X1cgHgzTffhL+/P5555hmj10tPT8f48eNRWFgoHevbty+GDBmCyMhIKJVKFBQUICUlBcePH8f27dtRUlJiVq2WdvXqVenrde3aNekHHLVajbCwMKPnDBw40Gb1EVEt7D00TERkT6dOnTL49bFcLheXLVtmseu/9tpr9f7VdElJiRgTEyOdLwiC+Oqrr4olJSVG2y9evFiUy+VS+9mzZ9d4/arTDGQymQhAVCqV4qpVq4y2//XXX0W1Wi2d4+HhIZ45c8Zo2wULFhi027hxY421FBcXiz/++KP4/vvv19jO2jp27CjV/eSTT9q1FiIyD6cZEJFL69ixI/r16yft63Q6PPTQQ+jatSs++OADHDlyBFqt1i61ffDBB9JIKQB89NFHeOONN6BUKo22f/TRR/Hhhx9K+19//TUSEhLMei+9Xg8AWL58OSZNmmS0zd13340ffvhB2tdoNPj3v/9ttG1cXJxBXVUfQmCMp6cn7rvvPsybN8+seq2hpKQEZ8+elfZrWpqNiBwHwywRubwlS5ZU+3X88ePH8fzzz6NHjx7w9vZG37598fjjj+Pnn39Gamqq1WvSaDRYtGiRtH/bbbeZ9SjcuXPnon379gAAURSxZMkSs9/z9ttvx5QpU2psM27cOIwePVra//XXXw3u/q9Udc5u27Ztza7Bno4fPw6dTiftM8wSOQeGWSJyeZ07d0ZcXBxatGhh9PXS0lLs378fixYtwn333YemTZsiNjYW33//vTSiaWl///23QUg0NTf1VoIg4MEHH5T2t2zZYvZ7/utf/6pzO61Wi02bNlVrU3WZrT179phdgz0dOXJE2lYqlWjXrp0dqyEiczHMEhGh4klPZ86cwaeffooOHTrU2n7Pnj144IEH0L17d5w7d87i9ezcuVPaVigUGD58uNnn9unTR9o+deoUioqKzDpv2LBhZrW78847DR4SceDAgWptevToIW3/8MMPWLBggckVEhxF1TDbuXNnKBS8R5rIGTDMEhHd4OHhgSeeeAKnT5/GqVOn8Nlnn2Hq1Klo27atyYcRHD9+HH369MHp06ctWkvV5aKioqKgUqnMPjc0NFTa1ul0uHbtWq3nNGvWDH5+fmZdX6lUIjo6Wto3FuYfffRRg8/Z66+/jvDwcEycOBFffPEFTp48abVR7fqqGma7detmx0qIqC4YZomIjOjYsaM0R/bs2bPIz8/H33//jaeeegpBQUEGbfPy8nDPPfcYzLdsqKysLGn74sWLEATB7I9bR5YrlwarSUhISJ3qq7qkmbHr9+rVCx9++CEEQZCOFRUVYe3atXjsscfQuXNnBAcHY+LEifjll1/svr5vWVmZwQ8knC9L5DwYZomIzKBWq3HHHXfg448/xuXLl/Hoo48avH7mzBmsXr3aYu+Xl5dnsWvd+mAIY+r6KFm1Wi1tV11LtqqnnnoK27Ztw4ABA4y+np2djbVr1+Lee+9Fq1atDFZKsLVTp06hrKxM2ufILJHz4IQgIqI68vLywuLFi5GVlYVVq1ZJx3///fdaVwMwV9VpBTUt3m8OU0t5VVXXBxZUnYdb04MZBg4ciB07duDChQvYvHkztm/fjj179lR7QtnVq1cxffp0XL582ayni1la1SkGCoUCnTp1snkNRFQ/DLNERPX0/PPPG4TZqmuUNlRgYKC03aNHD2zfvt1i1zam6hPGzJGRkSFt+/v719o+Ojoa0dHRmDt3LoCKz9Xvv/+Ob7/9FmfOnJHaLViwAOPHj0dMTEyd6mmoqmG2Q4cOZv0AQESOgdMMiIjq6dbAZcmpAZVrxQIVUxhEUbTYtY1JTk5Gbm6uWW1LS0tx4cIFab8+68i2a9cOzz33HE6dOmWwfq5er8ePP/5Y5+s1FG/+InJeDLNERPV0601LAQEB1dq4ublJ23W5e3/IkCHSdkZGBvbt21ePCuvmr7/+Mqvd33//bXCzW+/evev9njKZDP/9738NPnfx8fH1vl59iKJo8KS1Ll262PT9iahhGGaJiOpp165dBvutW7eu1qbqfNK6jNwOHz7c4Nf377zzTj0qrJuvvvrKrHZffvmltK1QKGp9VG1t5HK5weeuvLy8Qderq4yMDIM5wMa+jkTkuBhmicilbdiwAR999JFZd/xXVVJSUu1Gpbvvvrtau6ioKGk7Pz8fSUlJZl3fy8sLTz75pLT/22+/4bPPPqtTjUD10eOa/P3337WuyPDbb7/h999/l/bHjh1rsK5tpcTERLPft6SkBOfPn5f2q37OqpoxY4bBEmTbtm0z+z1qcuuSatnZ2Ra5LhHZBsMsEbm0jIwMPPvss4iKisK8efNw4sSJWs85deoUhgwZYvBgg3bt2mH8+PHV2vbu3dvg4QHz5s0za93XyradO3eW9ufOnYsnn3yy1rBVWFiIlStXYsiQIVi4cKFZ71VZ4wMPPIB169YZbbNx40bcd9990r6Hhwfeeusto22jo6Mxbdo0xMXF1bj+blFREWbMmGEwX9fY59GagoKCDFaPePfdd20+1YGI6k8QrX1XARGRA/v6668xe/Zsg2PNmjVDnz59EBMTg6CgIHh5eaGoqAiXLl3C7t27sX//foMbsry9vbFlyxaDx8hWdffddxuMZsrlckRFRRlMQWjSpAk2bdpU7dxLly5h4MCBSE1NlY6pVCoMGzYMvXr1QkhICGQyGfLy8pCYmIjjx49j37590Gg0ACqmJ7z44otG65oxYwa+++47AMCAAQPg5uaGuLg4aX/kyJEIDQ1FZmYm/vjjD2zdutXg/A8//BDPPPOM0WtXfVhCcHAw+vfvj65duyIkJARqtRp5eXk4efIk1q9fj8zMTKnt6NGjDT5XpuoFgK1bt2Lw4MFG29bV9OnTq61z6+/vbzCXd+rUqXjzzTct8n5EZEEiEZEL+/HHH0UA9f6Ijo4W9+/fX+N7JCcni9HR0TVeJzIy0uT5165dE2NjY+tV3/vvv2/yug8++KDUbtCgQWJaWprYqVMns6778ssv1/h3rk+td955p1hQUGDymsOHD5faenp6iteuXauxhrpIS0sT27dvX2N9n3/+ucXej4gsh9MMiMil3Xfffbh8+TI++eQTjB492qw1UwGgb9++WLRoEU6dOlXr3fxNmzbF0aNH8cUXX2DUqFFo3rw5VCqVwehlTcLCwrBz506sWbMG/fr1M5i2YOr9ZsyYgT/++MPkyKkxoaGh2LdvH5544gl4e3sbbdOuXTts2rTJ5PSCSj/++CPuu+8+sx720KVLFyxfvhx//vmnyQcwlJeXG9xwN2fOnAY9SOJWoaGhOHz4MD755BMMHjwYwcHBUCgMl2LnI26JHBOnGRARVSGKIi5duoTz58/jypUryM/Ph0ajgVqthq+vL1q3bo3OnTvDz8/PbjVmZ2dj9+7duHbtGrKysiCTyeDj44PIyEh06NDB5A1Ut6r6a/tBgwYZ3FBVXFyMbdu24cqVK8jJyUFoaCi6detWrzVYk5KSEB8fj6SkJOTm5kKn08Hb2xvNmjVD9+7dERkZWes1du7ciYEDBwKouDnu0qVLCA4OrnMtRNT48AlgRERVCIKAVq1aoVWrVvYuxaSAgACjKydYkkqlavCSW5UiIyPNCqw1qZzLC1TcCMcgS0SVOM2AiIgcXmWY9fX1xXPPPWfnaojIkTDMEhGRQyspKZGegPbss8+aPa+ZiFwDpxkQEZFD8/T0lJYaIyK6FUdmiYiIiMhpMcwSERERkdNimCUiIiIip8V1ZomIiIjIaXFkloiIiIicFsMsERERETkthlkiIiIicloMs0RERETktBhmiYiIiMhpMcwSERERkdNimCUiIqL/b7cOSAAAAAAE/X/djkBXCFsyCwDAlswCALAlswAAbMksAABbMgsAwJbMAgCwJbMAAGzJLAAAWzILAMCWzAIAsBV2J9EUl+2cEgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 714x680 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plot_single_metric(metric_array=mean_loss, \n",
    "                            se_array=se_loss,\n",
    "                            y_label=\"Loss\",\n",
    "                            chance_level=None,\n",
    "                            log_interval=log_interval, \n",
    "                            legend_str=\"Empirical\",\n",
    "                            line_width=1.4)\n",
    "ax.set_xlim([-100, 3600])\n",
    "ax.plot(ana_loss, color='C0', linestyle=\"--\", label=\"Analytical\", linewidth=2.5)\n",
    "\n",
    "handles, labels = ax.get_legend_handles_labels()\n",
    "custom_handles = [mlines.Line2D([], [], color='gray', linestyle=handle.get_linestyle(), linewidth=handle.get_linewidth()) for handle in handles]\n",
    "ax.legend(handles=custom_handles, labels=labels, ncol=2)\n",
    "\n",
    "fig_folder = f\"/{save_folder}/shallow_net_scale{scale}_choice_temp{choice_temp}/\"\n",
    "fig_name = \"loss_analytical\"\n",
    "_save_figure(fig_folder, fig_name, fig)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "behav-analysis-fmri",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
