{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# External imports \n",
    "import torch\n",
    "from torch.utils.data import DataLoader\n",
    "from torch.distributions.mixture_same_family import MixtureSameFamily\n",
    "import torch.distributions as D\n",
    "import random\n",
    "import numpy as np\n",
    "from tqdm import trange\n",
    "import matplotlib.pyplot as plt\n",
    "from IPython.display import display, clear_output\n",
    "\n",
    "# Internal imports\n",
    "import sys; sys.path.insert(0, '..')\n",
    "from src import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "N_DIMS = 1\n",
    "NUM_SAMPLES = 20000\n",
    "BS = 500\n",
    "NUM_EPOCHS = 1000\n",
    "SEED = 10\n",
    "LR = 1e-2\n",
    "DROPOUT = 0.20\n",
    "DEVICE = 'cuda:1' if torch.cuda.is_available() else 'cpu'\n",
    "\n",
    "\n",
    "# Break by changing num datapoints, scales, means, or to 2D"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Setting seed for reproducibility\n",
    "random.seed(SEED)\n",
    "torch.manual_seed(SEED)\n",
    "np.random.seed(SEED)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define model\n",
    "model_cob = RatioCritic1D_K3(dim_input=N_DIMS, dim_output=3, dropout=DROPOUT)\n",
    "# model.apply(weights_init)\n",
    "\n",
    "# Define optimizer\n",
    "optim_cob = torch.optim.Adam(model_cob.parameters(), lr=LR)\n",
    "\n",
    "# Define distributions\n",
    "p, q, m = get_dists_1d_cob(mu1=-1., mu2=1., mu3=0, scale_p=0.1, scale_q=0.2, alphas=[0.25, 0.50, 0.75])\n",
    "\n",
    "# -5, 5, m_var=3.0\n",
    "# -10, 10, m_var=3.0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "m1, m2, m3 = m\n",
    "p_samples = p.sample([1000])\n",
    "q_samples = q.sample([1000])\n",
    "m1_samples = m1.sample([1000])\n",
    "m2_samples = m2.sample([1000])\n",
    "m3_samples = m3.sample([1000])\n",
    "\n",
    "plt.hist(p_samples.numpy(), density=True, histtype='stepfilled')\n",
    "plt.hist(q_samples.numpy(), density=True, histtype='stepfilled')\n",
    "plt.hist(m1_samples.numpy(), density=True, histtype='stepfilled')\n",
    "plt.hist(m2_samples.numpy(), density=True, histtype='stepfilled')\n",
    "plt.hist(m3_samples.numpy(), density=True, histtype='stepfilled')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling p\n",
      "Sampling q\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "Sampling p\n",
      "Sampling q\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n"
     ]
    }
   ],
   "source": [
    "# Define dataset & dataloader\n",
    "train_ds = DistDataset3Waymark(p, q, m, num_samples=NUM_SAMPLES)\n",
    "test_ds = DistDataset3Waymark(p, q, m, num_samples=NUM_SAMPLES) # Test dataset is only of size batch "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define dataloader\n",
    "train_dl = DataLoader(train_ds, batch_size=BS, shuffle=True)\n",
    "test_dl = DataLoader(test_ds, batch_size=BS, shuffle=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABDAAAANYCAYAAAAylB2vAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAADDvUlEQVR4nOzdf7xdVX3n//eHhB8WUUHwRyEYzFAtaKBw5Ydaf6ADGPsVndrey4wtdphJlVq1tLbYtFNrm/6ILbWOwTYjFq3WxDpqGYtShQRqkGCCEPlRagKxhPoj5kalKCLw+f5x9iEnJ+f3WXuvtfZ+PR+P/bj3nHvu3muvvfb7rrv2L3N3AQAAAAAApOyA2AUAAAAAAAAYhgEMAAAAAACQPAYwAAAAAABA8hjAAAAAAAAAyWMAAwAAAAAAJI8BDAAAAAAAkLzSBjDM7ANm9i0zu63jvSPM7HNm9tXi6+FlLR8AmsrMdpjZV8zsFjPbXLzXM3+t5T1mts3MtprZKR3zuaD4/FfN7IJY6wMAoG8NAFK5Z2BcIencrvcukXSNux8v6ZriNQAgvJe6+8nuPlO87pe/r5B0fDEtl/Q+qdUplvR7kk6XdJqk36NjDABRXSH61gAarrQBDHe/XtJ819vnSfpg8f0HJb26rOUDAPbRL3/Pk/Qhb7lR0pPM7OmSzpH0OXefd/c9kj6n/TvOAICK0LcGAGlhxct7qrt/vfj+G5Ke2u+DZrZcraOBOvTQQ0999rOfXUHxADTVli1bvu3uR8UuRyAu6Z/MzCX9tbuvUf/8PVrSvR2/u7N4r9/7+yCrAVStZnk9LfrWAJJUVlZXPYDxGHf3onPd7+drJK2RpJmZGd+8eXNlZQPQPGb2tdhlCOiF7n6fmT1F0ufM7F86fzgsf8dBVgOoWs3yOhj61gBSUlZWV/0Ukm8Wpyar+PqtipcPALXn7vcVX78l6ZNq3cOiX/7eJ2lRx68fU7zX730AQDroWwNolKoHMK6U1L6T/QWS/qHi5QNArZnZoWZ2WPt7SWdLuk398/dKSb9YPI3kDEnfLU5HvlrS2WZ2eHHzzrOL9wAA6aBvDaBRSruExMw+Kuklko40s51q3c3+TyR9zMwulPQ1ST9f1vIBoKGeKumTZia1Mv7v3P2zZvYl9c7fqyQtk7RN0vcl/ZIkufu8mf2BpC8Vn3unu3ffPA4AUBH61gBQ4gCGu5/f50cvK2uZANB07n63pJN6vL9bPfLX3V3Sr/SZ1wckfSB0GYGm+tGPfqSdO3fqwQcfjF2ULBxyyCE65phjdOCBB8YuShLoWwNAxJt4AgAANMnOnTt12GGHafHixSrOkkIf7q7du3dr586dOu6442IXBwCQiKrvgQEAANBIDz74oJ785CczeDECM9OTn/xkzlYBAOyDAQwAAICKMHgxOuoKANCNAQwAAAAAAJA8BjAAAAAaYPfu3Tr55JN18skn62lPe5qOPvrox14/9NBDpS//61//us4+++zSlwMAqC9u4gkAANAAT37yk3XLLbdIkt7xjnfo8Y9/vH7jN37jsZ8//PDDWriwvK7hZz/7WZ1zzjmlzR8AUH+cgQEAANBQr3/96/WGN7xBp59+un7zN39T73jHO/Rnf/Znj/38Oc95jnbs2CFJ+vCHP6zTTjtNJ598sn75l39ZjzzyyH7zW7x4sX7zN39Tz33uc3Xaaadp27Ztj/3ss5/9rF7xilfI3fWmN71Jz3rWs/Tyl79cy5Yt08c//vHS1xUAkD8GMAAAABps586duuGGG3TppZf2/cydd96pdevWaePGjbrlllu0YMECfeQjH+n52Sc+8Yn6yle+oje96U1661vfKkl65JFHdNddd+mEE07QJz/5Sd11112644479KEPfUg33HBDGasFAKghLiEBAABI1Py8tHatNDcnHXFEOcv4uZ/7OS1YsGDgZ6655hpt2bJFz3ve8yRJP/jBD/SUpzyl52fPP//8x77+2q/9miRp06ZNOv300yVJ119/vc4//3wtWLBAP/7jP66zzjor1KoAAGqOAQwAAIBErV0rXXxx6/uLLipnGYceeuhj3y9cuFCPPvroY68ffPBBSZK764ILLtAf//EfD51f5+NP299/5jOf0bnnnhuqyACAhuISEgAAgETNzUmXXtr6WoXFixfr5ptvliTdfPPNuueeeyRJL3vZy/Txj39c3/rWtyRJ8/Pz+trXvtZzHuvWrXvs65lnnimpdQbHy1/+cknSi170Iq1bt06PPPKIvv71r2v9+vWlrhMAoD44AwMAACBRRxxR3pkXvfzsz/6sPvShD+nEE0/U6aefrp/4iZ+QJJ1wwgn6wz/8Q5199tl69NFHdeCBB2r16tV6xjOesd889uzZo6VLl+rggw/WRz/6Ue3atUuHHHKIDjvsMEnSa17zGl177bU64YQTdOyxxz42yAEAwDAMYAAAADTMO97xjp7vP+5xj9M//dM/9fzZ7OysZmdnh877bW97m/70T//0sdcf/vCHdfbZZz/22sz03ve+97HXr3/960crNACg8RjAAAAAQGle97rXxS4CAKAmGMAAAABAEDt27Bj7d6644org5QAA1BM38QQAAAAAAMljAAMAAAAAACSPAQwAAAAAAJA8BjAAAAAAAEDyGMAAAABoiG984xuam5vTkiVLdOqpp2rZsmX613/9176f37Fjhx73uMfp5JNP1kknnaTnP//5uuuuu8Ze7p/8yZ/oIx/5yDRFBwCAAQwAAIAmcHe95jWv0Ute8hJt375dW7Zs0R//8R/rm9/85sDfW7JkiW655RbdeuutuuCCC/RHf/RHYy/76quv1tlnnz1p0QEAkMQABgAAQCOsX79eBx54oN7whjc89t5JJ52kn/7pn5a7621ve5ue85zn6LnPfa7WrVvXcx7f+973dPjhh+/3/oYNG/SiF71Ir3zlK/WsZz1Lb3jDG/Too48+9jsPPfSQjjrqKN1zzz0688wz9dznPle/8zu/o8c//vHlrCwAoJYWxi4AAAAAynfbbbfp1FNP7fmzT3ziE4+dZfHtb39bz3ve8/SiF71IkrR9+3adfPLJuv/++/X9739fmzZt6jmPm266SXfccYee8Yxn6Nxzz9UnPvEJvfa1r9XnP/95vexlL5MkveUtb9Eb3/hG/eIv/qJWr15dzooCAGqLMzAAAABSNT8vXXZZ62uJvvCFL+j888/XggUL9NSnPlUvfvGL9aUvfUnS3ktItm/frne/+91avnx5z3mcdtppeuYzn6kFCxbo/PPP1xe+8AVJ0mc/+1m94hWvkCRt3LhR559/viTpF37hF0pdJwBA/TCAAQAAkKq1a6WLL259ndKJJ56oLVu2TDWPV73qVbr++ut7/szMer6+6aabdNppp/X9HAAAo2IAAwAAIFVzc9Kll7a+Tumss87SD3/4Q61Zs+ax97Zu3ap//ud/1k//9E9r3bp1euSRR7Rr1y5df/31+ww6tH3hC1/QkiVLes7/pptu0j333KNHH31U69at0wtf+ELdfvvtevazn60FCxZIkl7wghdobTEYw1NJAADjYgADAAAgVUccIV10UevrlMxMn/zkJ/X5z39eS5Ys0Yknnqi3v/3tetrTnqbXvOY1Wrp0qU466SSdddZZWrVqlZ72tKdJ2nsPjJNOOkm//du/rfe///095/+85z1Pb3rTm/STP/mTOu644/Sa17xGn/nMZ3Tuuec+9pm//Mu/1OrVq/Xc5z5X991339TrBABoFm7iCQAA0BA//uM/ro997GM9f/aud71L73rXu/Z5b/HixfrBD34w0ryf8IQn6NOf/vQ+71199dX60Ic+9Njr4447Tl/84hcfe/3ud797xJIDAMAABgAAAEryuc99LnYRAAA1wiUkAFBDZrbAzL5sZp8uXh9nZpvMbJuZrTOzg4r3Dy5ebyt+vrhjHm8v3r/LzM6JtCoAMvCSl7xkv7MvRvEf//EfJZQGAFBXDGAAQD29RdKdHa//VNJfuPt/krRH0oXF+xdK2lO8/xfF52RmJ0iak3SipHMlXWZmCyoqO1Bb7h67CNmgrgAA3RjAAICaMbNjJL1S0vuL1ybpLEkfLz7yQUmvLr4/r3it4ucvKz5/nqS17v5Dd79H0jZJ+z+SAMDIDjnkEO3evZt/zEfg7tq9e7cOOeSQ2EUBACSEe2AAQP28W9JvSjqseP1kSd9x94eL1zslHV18f7SkeyXJ3R82s+8Wnz9a0o0d8+z8nceY2XJJyyXp2GOPDboSQN0cc8wx2rlzp3bt2hW7KFk45JBDdMwxx8QuBgAgIQxgAECNmNnPSPqWu28xs5eUvTx3XyNpjSTNzMxwWBkY4MADD9Rxxx0XuxgAAGSLAQwAqJcXSHqVmS2TdIikJ0j6S0lPMrOFxVkYx0i6r/j8fZIWSdppZgslPVHS7o732zp/BwAAAKgc98AAgBpx97e7+zHuvlitm3Be6+7/TdJ6Sa8tPnaBpH8ovr+yeK3i59d66wL9KyXNFU8pOU7S8ZJuqmg1AAAAgP1wBgYANMNvSVprZn8o6cuSLi/ev1zS35rZNknzag16yN1vN7OPSbpD0sOSfsXdH6m+2AAAAEALAxgAUFPuvkHShuL7u9XjKSLu/qCkn+vz+yslrSyvhAAAAMDouIQEAAAAAAAkjwEMAAAAAACQvCgDGGb2a2Z2u5ndZmYfNbNDYpQDAAAAyB19awBNUfkAhpkdLenNkmbc/TmSFqi4aRwAAACA0dG3BtAksS4hWSjpcWa2UNKPSfr3SOUAAAAAckffGkAjVD6A4e73SfozSf8m6euSvuvu/1R1OQAAAIDc0bcG0CQxLiE5XNJ5ko6T9OOSDjWz1/X43HIz22xmm3ft2lV1MQEAAIDk0bcG0CQxLiF5uaR73H2Xu/9I0ickPb/7Q+6+xt1n3H3mqKOOqryQAAAAQAboWwNojBgDGP8m6Qwz+zEzM0kvk3RnhHIAAAAAuaNvDaAxYtwDY5Okj0u6WdJXijKsqbocAAAAQO7oWwNokoUxFuruvyfp92IsGwAAAKgT+tYAmiLWY1QBAAAAAABGxgAGAAAAAABIHgMYAAAAAAAgeQxgAAAAAACA5DGAAQAAAAAAkscABgAAAAAASB4DGAAAAAAAIHkMYAAAAAAAgOQxgAEAAAAAAJLHAAYAAAAAAEgeAxgAAAAAACB5DGAAAAAAAIDkMYABAAAAAACSxwAGAAAAAABIHgMYAAAAAAAgeQxgAAAAAACA5DGAAQAAAAAAkscABgAAAAAASB4DGABQI2Z2iJndZGa3mtntZvb7xfvHmdkmM9tmZuvM7KDi/YOL19uKny/umNfbi/fvMrNzIq0SAAAAIIkBDAComx9KOsvdT5J0sqRzzewMSX8q6S/c/T9J2iPpwuLzF0raU7z/F8XnZGYnSJqTdKKkcyVdZmYLqlwRAAAAoBMDGABQI97yH8XLA4vJJZ0l6ePF+x+U9Ori+/OK1yp+/jIzs+L9te7+Q3e/R9I2SaeVvwYAAABAbwxgAEDNmNkCM7tF0rckfU7SdknfcfeHi4/slHR08f3Rku6VpOLn35X05M73e/xO57KWm9lmM9u8a9euEtYGAAAAaGEAAwBqxt0fcfeTJR2j1lkTzy5xWWvcfcbdZ4466qiyFgMAAAAwgAEAdeXu35G0XtKZkp5kZguLHx0j6b7i+/skLZKk4udPlLS78/0evwMAAABUjgEMAKgRMzvKzJ5UfP84Sf9Z0p1qDWS8tvjYBZL+ofj+yuK1ip9f6+5evD9XPKXkOEnHS7qpkpUAAAAAelg4/CMAgIw8XdIHiyeGHCDpY+7+aTO7Q9JaM/tDSV+WdHnx+csl/a2ZbZM0r9aTR+Tut5vZxyTdIelhSb/i7o9UvC4AAADAYxjAAIAacfetkn6qx/t3q8dTRNz9QUk/12deKyWtDF1GAAAAYBJcQgIAAAAAAJLHAAYAAAAAAEgeAxgAAAAAACB5DGAAAAAAAIDkMYABAAAAAACSxwAGAAAAAABIHgMYAAAAAAAgeQxgAAAAAACA5DGAAQAAAAAAkscABgAAAAAASB4DGAAAAAAAIHkMYAAAAAAAgOQxgAEAAAAAAJLHAAYAAAAAAEhelAEMM3uSmX3czP7FzO40szNjlAMAAADIHX1rAE2xMNJy/1LSZ939tWZ2kKQfi1QOAAAAIHf0rQE0QuUDGGb2REkvkvR6SXL3hyQ9VHU5AAAAgNzRtwbQJDEuITlO0i5Jf2NmXzaz95vZod0fMrPlZrbZzDbv2rWr+lICAAAA6aNvDaAxYgxgLJR0iqT3uftPSXpA0iXdH3L3Ne4+4+4zRx11VNVlBAAAAHJA3xpAYwwdwDCzJWZ2cPH9S8zszWb2pCmWuVPSTnffVLz+uFqhCwAAAGA89K0BNMYoZ2D8X0mPmNl/krRG0iJJfzfpAt39G5LuNbNnFW+9TNIdk84PAHJkZk80s79on85rZn9eXMcMAMDI6FsDaJJRBjAedfeHJb1G0v9297dJevqUy/1VSR8xs62STpb0R1PODwBy8wFJ35P088X0PUl/E7VEAIDSmdkqM3uCmR1oZteY2S4ze92Us6VvDaARRnkKyY/M7HxJF0j6/4r3Dpxmoe5+i6SZaeYBAJlb4u4/2/H6983slliFAQBU5mx3/00ze42kHZL+i6TrJX140hnStwbQFKOcgfFLks6UtNLd7zGz4yT9bbnFAoDa+4GZvbD9wsxeIOkHEcsDAKhG+wDiKyX9vbt/N2ZhACAnQ8/AcPc7JL1ZkszscEmHufufll0wAKi5N0r6YHHfC5M0L+n1UUsEAKjCp83sX9QatH6jmR0l6cHIZQKALAwdwDCzDZJeVXx2i6RvmdlGd7+45LIBQG0Vp/ueZGZPKF5/L26JAABVcPdLzGyVpO+6+yNm9oCk82KXCwByMMo9MJ7o7t8zs/8h6UPu/nvFDYIAAGMys9e5+4fN7OKu9yVJ7n5plIIBACphZj8n6bPF4MXvqPXI0z+U9I24JQOA9I1yD4yFZvZ0te6S/+mSywMAdXdo8fWwHtPjYxUKAFCZ33X3+4v7IL1c0uWS3he5TACQhVHOwHinpKslbXT3L5nZMyV9tdxiAUA9uftfF99+3t03dv6suJEnAKDeHim+vlLSGnf/RzP7w5gFAoBcDD0Dw93/3t2Xuvsbi9d3dz36DwAwvv894ntjMbNFZrbezO4ws9vN7C3F+0eY2efM7KvF18OL983M3mNm28xsq5md0jGvC4rPf9XMLpi2bAAASdJ9ZvbXkmYlXWVmB2u0s6IBoPFGuYnnMWp1qttHBv9Z0lvcfWeZBQOAOjKzMyU9X9JRXffBeIKkBQEW8bCkX3f3m83sMElbzOxzaj3h5Bp3/xMzu0TSJZJ+S9IrJB1fTKerdRrz6WZ2hKTfkzQjyYv5XOnuewKUEQCa7OclnSvpz9z9O8Wl2m+LXCYAyMIoo71/I+lKST9eTP+veA8AML6D1LrXxULte/+L70l67bQzd/evu/vNxff3S7pT0tFq3eH+g8XHPijp1cX356l1g2Z39xslPanoTJ8j6XPuPl8MWnxOrQ43AGAK7v59SdslnWNmb5L0FHf/p8jFAoAsjHIPjKPcvXPA4goze2tJ5QGAWnP36yRdZ2ZXuPvXylyWmS2W9FOSNkl6qrt/vfjRNyQ9tfj+aEn3dvzazuK9fu93L2O5pOWSdOyxxwYsPQDUU3Fp3/+U9InirQ+b2Rp3n/oyQgCou1EGMHab2eskfbR4fb6k3eUVCQAa4ftm9i5JJ0o6pP2mu58VYuZm9nhJ/1fSW4tHYT/2M3d3M/MQy3H3NZLWSNLMzEyQeQJAzV0o6XR3f0CSzOxPJX1RAe6DBAB1N8olJP9drWv1viHp62qd4vz6EssEAE3wEUn/Iuk4Sb8vaYekL4WYsZkdqNbgxUfcvX2E75vFpSEqvn6reP8+SYs6fv2Y4r1+7wMApmPa+yQSFd9bn88CADqM8hSSr7n7q9z9KHd/iru/WtJbyi8aANTak939ckk/cvfr3P2/S5r67AtrnWpxuaQ73f3Sjh9dKan9JJELJP1Dx/u/WDyN5AxJ3y0uNbla0tlmdnjxxJKzi/cAANP5G0mbzOwdZvYOSTeqldsAgCFGuYSkl5+X9BshCwIADfOj4uvXzeyVkv5d0hEB5vsCSb8g6Stmdkvx3m9L+hNJHzOzCyV9Ta0cl6SrJC2TtE3S9yX9kiS5+7yZ/YH2nhXyTnefD1A+AGg0d7/UzDZIemHx1i9J+ma8EgFAPiYdwOA0NwCYzh+a2RMl/bpa1z0/QdJbp52pu39B/TP6ZT0+75J+pc+8PiDpA9OWCQCwr+JpUTe3X5vZv0niTsgAMETfAQwz63ck0MQABgBMxd0/XXz7XUkvlSQze0G8EgEAIqJvDQAjGHQGxhZJrt6B+lA5xQGAejOzBWpdvnG0pM+6+21m9jNqXebxOLUeewoAaBae4gQAI+g7gOHux1VZEABoiMvVerrHTZLeY2b/LmlG0iXu/qmYBQMAlMfM/rd6D1SYpCdVWxoAyNOk98AAAExmRtJSd3/UzA5R6xHVS9x9d+RyAQDKtXnCnwEACgxgAEC1HnL3RyXJ3R80s7sZvACA+nP3D8YuAwDkjgEMAKjWs81sa/G9SVpSvDa1HgqyNF7RAAAAgHSNNIBR3HTuqZ2fd/d/K6tQAFBjPxm7AAAAAECOhg5gmNmvSvo9Sd+U9GjxtkviKCEAjMndvxa7DACAeMzsBe6+cdh7AID9jXIGxlskPYtrtAEAAICp/W9Jp4zwHgCgyygDGPdK+m7ZBQEAAADqyszOlPR8SUeZ2cUdP3qCpAVxSgUAeRllAONuSRvM7B8l/bD9prtfWlqpAAAAgHo5SNLj1ep/H9bx/vckvTZKiQAgM6MMYPxbMR1UTACAKZnZV9S6n1Cn70raLOkPuWwPAOrF3a+TdJ2ZXdG+H5KZHSDp8e7+vbilA4A8DB3AcPffr6IgANAwn5H0iKS/K17PSfoxSd+QdIWk/y9OsQAAJftjM3uDWn8DviTpCWb2l+7+rsjlAoDk9R3AMLN3u/tbzez/af+jhHL3V5VaMgCot5e7e+cN275iZje7+ylm9rpopQIAlO0Ed/+emf03tQazL5G0RRIDGAAwxKAzMP62+PpnVRQEABpmgZmd5u43SZKZPU97b+L2cLxiAQBKdqCZHSjp1ZLe6+4/MrP9DhYCAPbXdwDD3bcUX6+rrjgA0Bj/Q9IHzOzxkkytm7hdaGaHSvrjqCUDAJTpryXtkHSrpOvN7Blq/Q0AAAwx9B4YZna8Wp3pEyQd0n7f3Z9ZYrkAoNbc/UuSnmtmTyxedz6u+mNxSgUAKJu7v0fSezre+pqZvTRWeQAgJweM8Jm/kfQ+tU5pfqmkD0n6cJmFAoC6M7Mnmtmlkq6RdI2Z/Xl7MAMAUF9m9lQzu9zMPlO8PkHSBZGLBQBZGGUA43Hufo0kc/evufs7JL2y3GIBQO19QNL9kn6+mL6n1oAxAKDerpB0taQfL17/q6S3xioMAORk6CUkkn5YPKP6q2b2Jkn3SXp8ucUCgNpb4u4/2/H6983slliFAQCUy8wWuvvDko5094+Z2dslyd0fNrNHIhcPALIwyhkYb5H0Y5LeLOlUSa8Tp7kBwLR+YGYvbL8wsxdI+kHE8gAAynVT8fUBM3uyJJckMztD0nf7/hYA4DEDz8AwswWSZt39NyT9h6RfqqRUAFB/b5D0oY77XuwRg8MAUGdWfL1Y0pWSlpjZRklHSXpttFIBQEb6DmC0T3PrPEIIAAjD3W+VdJKZPaF4/T0ze6ukrVELBgAoy1FmdnHx/SclXaXWoMYPJb1c5D8ADDXoDIybJJ0i6ctmdqWkv5f0QPuH7v6JkssGALXn7t/reHmxpHdHKgoAoFwL1LqPnHW9/2MRygIAWRrlJp6HSNot6Sy1rtWz4isDGAAQVnenFgBQH19393fGLgQA5GzQAMZTitPcbtPegYs2n3bBxf01Nku6z91/Ztr5AUANTJ2tAIBklTpITd8aQBMMGsDod5qbFKaT/RZJd0p6QoB5AUAWzOx+9c5Qk/S4iosDAKjOy0qeP31rALU3aACjtNPczOwYSa+UtFKta74BoBHc/bDYZQAAVM/d58uaN31rAE1xwICflXma27sl/aakR/su3Gy5mW02s827du0qsSgAAABA1t4t+tYAGmDQAEYpp7mZ2c9I+pa7bxn0OXdf4+4z7j5z1FFHlVEUAKgdM/uAmX3LzG7reO8IM/ucmX21+Hp48b6Z2XvMbJuZbTWzUzp+54Li8181swtirAsAYDj61gCapO8ARomnub1A0qvMbIektZLOMrMPl7QsAGiaKySd2/XeJZKucffjJV1TvJakV0g6vpiWS3qf1BrwkPR7kk6XdJqk32sPegAAkkPfGkBjDDoDoxTu/nZ3P8bdF0uak3Stu7+u6nIAQB25+/WSugegz5P0weL7D0p6dcf7H/KWGyU9ycyeLukcSZ9z93l33yPpc9p/UAQAkAD61gCapPIBDABA5Z7q7l8vvv+GpKcW3x8t6d6Oz+0s3uv3/n64phoAAABViTqA4e4beE41AFTH3V1hHoXdnh/XVANAIuhbA6g7zsAAgPr7ZnFpiIqv3yrev0/Soo7PHVO81+99AAAAIBoGMACg/q6U1H6SyAWS/qHj/V8snkZyhqTvFpeaXC3pbDM7vLh559nFewAAAEA0C2MXAAAQjpl9VNJLJB1pZjvVeprIn0j6mJldKOlrkn6++PhVkpZJ2ibp+5J+SWo9hcrM/kDSl4rPvbPEJ1MBAAAAI2EAAwBqxN3P7/Ojl/X4rEv6lT7z+YCkDwQsGgAAADAVLiEBAAAAAADJYwADAAAAAAAkjwEMAAAAAACQPAYwAAAAAABA8hjAAAAAAAAAyWMAAwAAAAAAJI8BDAAAAAAAkDwGMAAAAAAAQPIYwAAAAAAAAMljAAMAAAAAACSPAQwAAAAAAJA8BjAAAAAAAEDyGMAAAAAAAADJYwADAAAAAAAkjwEMAAAAAACQPAYwAAAAAABA8hjAAAAAAAAAyWMAAwAAAAAAJI8BDAAAAAAAkDwGMAAAAAAAQPIYwAAAAAAAAMljAAMAAAAAACSPAQwAAAAAAJA8BjAAAAAAAEDyGMAAAAAAAADJYwADAAAAAAAkjwEMAAAAAACQPAYwAAAAAABA8hjAAAD0ZWbnmtldZrbNzC6JXR4AAAA0FwMYAICezGyBpNWSXiHpBEnnm9kJcUsFAACApmIAAwDQz2mStrn73e7+kKS1ks6LXCYAAAA0FAMYAIB+jpZ0b8frncV7yNS1x12gR82CTN+zg3TH326JvUoAAKBBGMAAAEzMzJab2WYz27xr167YxcEQL9nxIZkUZDpMP5J+eXnVqwAAABqMAQwAQD/3SVrU8fqY4r3HuPsad59x95mjjjqq0sJhfBsW/6JcCjLdrwOlv15T9SoAAIAGWxi7AACAZH1J0vFmdpxaAxdzkv5r3CJhGmfd80FJHwwyryeodWdXAACAqjCAAQDoyd0fNrM3Sbpa0gJJH3D32yMXCwAAAA1V+QCGmS2S9CFJT1XrLNQ17v6XVZcDADCcu18l6arY5QAA9EbfGkCTxDgD42FJv+7uN5vZYZK2mNnn3P2OCGUBAAAAckbfGkBjVH4TT3f/urvfXHx/v6Q7xWP5AAAAgLHRtwbQJFGfQmJmiyX9lKRNPX7Go/kAAACAEdG3BlB30QYwzOzxkv6vpLe6+/e6f86j+QAAAIDR0LcG0ARRBjDM7EC1AvYj7v6JGGUAAAAA6oC+NYCmqHwAw8xM0uWS7nT3S6tePgAAAFAX9K0BNEmMMzBeIOkXJJ1lZrcU07II5QAAAAByR98aQGNU/hhVd/+CJKt6uQAAAEDd0LcG0CRRn0ICAAAAAAAwCgYwAAAAAABA8hjAAAAAAAAAyWMAAwAAAAAAJI8BDAAAAAAAkDwGMAAAAAAAQPIYwAAAAAAAAMljAAMAAAAAACSPAQwAAAAAAJA8BjAAAAAAAEDyGMAAAAAAAADJYwADAAAAAAAkjwEMAAAAAACQPAYwAAAAAABA8hjAAAAAAAAAyWMAAwAAAAAAJI8BDAAAAAAAkDwGMAAAAAAAQPKyGMD49+/8IHYRAAAAgFq4/8EfxS4CAEwkiwEMAAAAAADQbAxgAAAAAACA5DGAAQA1YWY/Z2a3m9mjZjbT9bO3m9k2M7vLzM7peP/c4r1tZnZJx/vHmdmm4v11ZnZQlesCAAAAdGMAAwDq4zZJ/0XS9Z1vmtkJkuYknSjpXEmXmdkCM1sgabWkV0g6QdL5xWcl6U8l/YW7/ydJeyRdWM0qAAAAAL0xgAEANeHud7r7XT1+dJ6kte7+Q3e/R9I2SacV0zZ3v9vdH5K0VtJ5ZmaSzpL08eL3Pyjp1aWvAAAAADAAAxgAUH9HS7q34/XO4r1+7z9Z0nfc/eGu9/djZsvNbLOZbd61a1fwggMAAABtC2MXAAAwOjP7vKSn9fjRCnf/h6rL4+5rJK2RpJmZGa96+QAAAGgOBjAAICPu/vIJfu0+SYs6Xh9TvKc+7++W9CQzW1ichdH5eQAAACAKLiEBgPq7UtKcmR1sZsdJOl7STZK+JOn44okjB6l1o88r3d0lrZf02uL3L5BU+dkdAAAAQCcGMACgJszsNWa2U9KZkv7RzK6WJHe/XdLHJN0h6bOSfsXdHynOrniTpKsl3SnpY8VnJem3JF1sZtvUuifG5dWuDQAAALAvLiEBgJpw909K+mSfn62UtLLH+1dJuqrH+3er9ZQSAAAAIAmcgQEAAAAAAJLHAAYAAAAAAEgeAxgAAAAAACB5DGAAAAAAAIDkMYABAAAAAACSxwAGAAAAAABIHgMYAAAAAAAgeQxgAAAAAACA5DGAAQAAAAAAkscABgAAAAAASF6UAQwzO9fM7jKzbWZ2SYwyAAAAAHVA3xpAU1Q+gGFmCyStlvQKSSdIOt/MTqi6HAAAAEDu6FsDaJIYZ2CcJmmbu9/t7g9JWivpvAjlAAAAAHJH3xpAYyyMsMyjJd3b8XqnpNO7P2RmyyUtL17+0Mxuq6BsozhS0rdjF6KQUlmktMpDWfpLqTwpleVZsQuQuy1btvyHmd0VuxyFlNqWlFZ5KEt/KZWHsvRHXu+LvnU4lKW/lMpDWfpLqTylZHWMAYyRuPsaSWskycw2u/tM5CJJoiyDpFQeytJfSuVJrSyxy1ADd6W0PVMpi5RWeShLfymVh7L0R15Phr71cJSlv5TKQ1n6S6k8ZWV1jEtI7pO0qOP1McV7AAAAAMZD3xpAY8QYwPiSpOPN7DgzO0jSnKQrI5QDAAAAyB19awCNUfklJO7+sJm9SdLVkhZI+oC73z7k19aUX7KRUZb+UioPZekvpfJQlnpJqQ5TKouUVnkoS38plYey9JdaeaKibx0UZekvpfJQlv5SKk8pZTF3L2O+AAAAAAAAwcS4hAQAAAAAAGAsDGAAAAAAAIDkJT2AYWbnmtldZrbNzC4pcTk7zOwrZnZL+3EvZnaEmX3OzL5afD28eN/M7D1Fmbaa2Skd87mg+PxXzeyCMZb/ATP7VufzuEMu38xOLdZvW/G7NmZZ3mFm9xX1c4uZLev42duL+d5lZud0vN9z2xU3mNpUvL+uuNlUv7IsMrP1ZnaHmd1uZm+JVTcDyhKrbg4xs5vM7NaiPL8/aB5mdnDxelvx88WTlnOMslxhZvd01M3JZW+njs8vMLMvm9mnY9VLk5nZr5rZvxTtYVUC5fl1M3MzOzJyOd5V1MtWM/ukmT0pQhmSaL/9MjWm7tyIXJYnmdnHi/Zyp5mdGbEsv1Zso9vM7KNmdkiFyx65f4TRVJUBRt96WFnoWyfUt7aE+tVDykPfWpLcPclJrZsQbZf0TEkHSbpV0gklLWuHpCO73lsl6ZLi+0sk/Wnx/TJJn5Fkks6QtKl4/whJdxdfDy++P3zE5b9I0imSbitj+ZJuKj5rxe++YsyyvEPSb/T47AnFdjlY0nHF9lowaNtJ+pikueL7v5L0xgFlebqkU4rvD5P0r8UyK6+bAWWJVTcm6fHF9wdK2lSsR895SLpI0l8V389JWjdpOccoyxWSXtvj86W24eLzF0v6O0mfHlS3ZdZLUydJL5X0eUkHF6+fErk8i9S6sd3X1JXzEcpytqSFxfd/qiK7Klx+Mu1XfTI18vbZJzcil+WDkv5H8f1Bkp4UqRxHS7pH0uOK1x+T9PoKlz9y/4hppPqkb03fmr5177Ik068eUp4rRN866TMwTpO0zd3vdveHJK2VdF6Fyz9PrQ6Eiq+v7nj/Q95yo6QnmdnTJZ0j6XPuPu/ueyR9TtK5oyzI3a+XNF/G8oufPcHdb/RW6/lQx7xGLUs/50la6+4/dPd7JG1Ta7v13HbFyN5Zkj7eY716leXr7n5z8f39ku5UqzNVed0MKEusunF3/4/i5YHF5APm0VlnH5f0smKZY5VzzLIMqpvS2rCZHSPplZLeX7weVLel1UuDvVHSn7j7DyXJ3b8VuTx/Iek3NbhNVsLd/8ndHy5e3ijpmIqLkEz7nSBTS9WdGzGZ2RPV+ofnckly94fc/TsRi7RQ0uPMbKGkH5P071UteMz+EYaLnQH0rYejbx2hblLqVw8pz6C6aUzfOuUBjKMl3dvxeqfK69y4pH8ysy1mtrx476nu/vXi+29IeuqQcoUub6jlH118P2253lSckvQB23u65rhlebKk73R04EcuS3H60U+pNQIZtW66yiJFqpviVK5bJH1LrUDaPmAejy23+Pl3i2UGac/dZXH3dt2sLOrmL8zs4O6yjLjMcbfTu9X6h/XR4vWgui21XhrqJyT9dHHa4HVm9rxYBTGz8yTd5+63xirDAP9drSMeVUqy/fbI1BjerX1zI6bjJO2S9DfF6brvN7NDYxTE3e+T9GeS/k3S1yV9193/KUZZOvTrA2A4+tb0rR9D33q/MiTTr+5VHvrWe6U8gFGlF7r7KZJeIelXzOxFnT8sRqaiHb2LvXxJ75O0RNLJanVg/rzKhZvZ4yX9X0lvdffvdf6s6rrpUZZodePuj7j7yWodxT1N0rOrWvawspjZcyS9vSjT89Q6de23yi6Hmf2MpG+5+5ayl9VkZvZ5a10P3z2dp9bR2iPUOi3xbZI+Nuy6yhLL8tuS/ldZy56gPO3PrJD0sKSPVFm2FA3K9wrLkFpuLFTrdPP3uftPSXpArVO6K1f843CeWoMqPy7pUDN7XYyy9JJA/wj90bcejL51/7JEqZuU+tW9ykPfeq+UBzDuU+va5bZjiveCK44wtE91/qRajfabxek1Kr62T4PuV67Q5Q21/Pu072nKY5fL3b9Z7ESPSvo/atXPJGXZrdYpTQtHLYuZHahWqH3E3T9RvB2lbnqVJWbdtHnr1OL1ks4cMI/Hllv8/InFMoO2546ynFucGujeupTgbzR53YyznV4g6VVmtkOtU9DOkvSXilwvdePuL3f35/SY/kGtkfNPFNv+JrVG60u7eWa/sqh1nedxkm4t2sMxkm42s6eVVZZB5SnqRmb2ekk/I+m/FZ3EKiXVfvvkewz75YaZfThieXZK2tlxtO3jag1oxPBySfe4+y53/5GkT0h6fqSytPXrA2A4+tb0relbD5FSv7qrPPSt23zCm/OUPal1BKLdAW3f0OPEEpZzqKTDOr6/Qa3r696lfW9ms6r4/pXa9yYpN/nem6Tco9YNUg4vvj9ijHIs1r439wm2fO1/k5ZlY5bl6R3f/5pa1y9J0ona92Ysd6t1I5a+207S32vfG75cNKAcptY1We/uer/yuhlQllh1c5SKm7pJepykf1brn6Ke85D0K9r3hjofm7ScY5Tl6R1192617otQ6nbqKtdLtPdGQ5XXS1MnSW+Q9M7i+59Q67RAS6BcOxT/Jp7nSrpD0lGRlp9M+1WfTI09deZG5HL8s6RnFd+/Q9K7IpXjdEm3q3XvC1PruuZfrbgMizVC/4hppLqkb03fmr5177Ik068eUh761u7pDmAUK7pMrTvSbpe0oqRlPLOoqFvV+iO9onj/yZKukfRVte6o397YJml1UaavSJrpmNd/V+uGJNsk/dIYZfioWqdI/UitIy8Xhly+pBlJtxW/814N+GeiT1n+tljWVklXat9gWVHM9y513L2237Yr6vumoox/r+JJBX3K8kK1TmHbKumWYloWo24GlCVW3SyV9OViubdJ+l+D5iHpkOL1tuLnz5y0nGOU5dqibm6T9GHtvZtyqW2443deor0hW3m9NHVS64/Ph4vtdbOks2KXqSjXDsUfwNim1oBOO0P+KkIZkmi/6pOpCbSTx3IjcjlOlrS5qJ9PacQnL5RUlt+X9C/FPv23GvC3qYRlj9w/Yhq5Tulb07emb71/WZLpVw8pD31r91ZBAQAAAAAAUpbyPTAAAAAAAAAkMYABAAAAAAAywAAGAAAAAABIHgMYAAAAAAAgeQxgAAAAAACA5DGAgSSY2X8UXxeb2X8NPO/f7np9Q8j5A0CTmNkKM7vdzLaa2S1mdnqJy9pgZjNlzR8A6oq+NeqKAQykZrGksULWzBYO+cg+Ievuzx+zTAAASWZ2pqSfkXSKuy+V9HJJ98YtFQBggMWib40aYQADqfkTST9dHNX7NTNbYGbvMrMvFUf7flmSzOwlZvbPZnalpDuK9z5lZluKI4PLi/f+RNLjivl9pHivPSJtxbxvM7OvmNlsx7w3mNnHzexfzOwjZmYR6gIAUvN0Sd929x9Kkrt/293/3cz+V5HTt5nZmnZmFln6F2a22czuNLPnmdknzOyrZvaHxWcWd2TtnUX2/lj3gs3sbDP7opndbGZ/b2aPL97/EzO7o/gb8WcV1gUA5IC+NWrF3D12GQCZ2X+4++PN7CWSfsPdf6Z4f7mkp7j7H5rZwZI2Svo5Sc+Q9I+SnuPu9xSfPcLd583scZK+JOnF7r67Pe8ey/pZSW+QdK6kI4vfOV3SsyT9g6QTJf17scy3ufsXyq8JAEhXMWjwBUk/Junzkta5+3Xt/C0+87eSPubu/8/MNkja5O6/ZWZvkfRbkk6VNC9pu6STJB0m6R5JL3T3jWb2AUl3uPufFb//G5J2SPqEpFe4+wNm9luSDpa0WtINkp7t7m5mT3L371RSGQCQMPrWqCvOwEDqzpb0i2Z2i6RNkp4s6fjiZze1A7bwZjO7VdKNkhZ1fK6fF0r6qLs/4u7flHSdpOd1zHunuz8q6Ra1Tr8DgEZz9/9QawBiuaRdktaZ2eslvdTMNpnZVySdpVYnte3K4utXJN3u7l8vzuC4W62slqR73X1j8f2H1crnTmdIOkHSxuLvwQVqdba/K+lBSZeb2X+R9P1Q6woANUXfGlkbdn0TEJtJ+lV3v3qfN1ujyQ90vX65pDPd/fvFUbtDpljuDzu+f0TsKwAgSXL3RyRtkLShGLD4ZUlLJc24+71m9g7tm7/tPH1U+2bro9qbrd2ng3a/Nkmfc/fzu8tjZqdJepmk10p6k1oDKACA3uhbI2ucgYHU3K/W6cRtV0t6o5kdKElm9hNmdmiP33uipD1FwD5braN1bT9q/36Xf5Y0W1wLeJSkF0m6KchaAEANmdmzzKzzCNzJku4qvv92cYnJayeY9bHWukGo1LrZXPdpxTdKeoGZ/aeiHIcWfw8eL+mJ7n6VpF9T65IUAMBe9K1RK4x8ITVbJT1SnK52haS/VOsUs5uLm/3skvTqHr/3WUlvMLM71epM39jxszWStprZze7+3zre/6SkMyXdqtbRvt90928UIQ0A2N/jJf1vM3uSpIclbVPrcpLvSLpN0jfUuuZ5XHdJ+pX2/S8kva/zh+6+q7hU5aPFNduS9Dtqdcz/wcwOUeuo4sUTLBsA6oy+NWqFm3gCAIBozGyxpE+7+3NilwUAAKSNS0gAAAAAAEDyOAMDAAAAAAAkjzMwAAAAAABA8hjAAAAAAAAAyWMAAwAAAAAAJI8BDAAAAAAAkDwGMAAAAAAAQPIYwAAAAAAAAMljAAMAAAAAACSPAQwAAAAAAJA8BjAAAAAAAEDyFsYuwCiOPPJIX7x4cexiAKixLVu2fNvdj4pdjpyR1QCqQF5Pj7wGULaysjqLAYzFixdr8+bNsYsBoMbM7Guxy5A7shpAFcjr6ZHXAMpWVlZzCQkAAAAAAEgeAxgAAAAAACB5DGAAAAAAAIDkMYABAAAAAACSxwAGAAAAAABIHgMYAAAAAAAgeUEHMMzsA2b2LTO7rc/PzczeY2bbzGyrmZ0ScvkAgOHIagDIA3kNAPsKfQbGFZLOHfDzV0g6vpiWS3pf4OUDAIa7QmQ1AOTgCpHXAPCYoAMY7n69pPkBHzlP0oe85UZJTzKzp4csA8a3Z/u8rpu7THu2D9p0wHC0pTyQ1Xli/0IotKV8kNd5Yh9DCLSj3qq+B8bRku7teL2zeG8/ZrbczDab2eZdu3ZVUrim2rpirU5fd7G2rlhb6nKm2Ql7/S47dXqqaksoHVmdoByyut/vk9dpIatrhbxOUBX7GFldf2R1b8nexNPd17j7jLvPHHXUUbGLU2tLV85p0+ylWrpybp/3Q4fYNDth9+/u2T6vO196kc5gp05Kv7ZUNv7gxkNWV2fQ/hVyH5i2w9T5++1y3frmy+mEJYSsbibyujpV9K3J6vqLldVS4nnt7kEnSYsl3dbnZ38t6fyO13dJevqweZ566qmeivltu33D7Gqf37Z7pPdztmF2tf9AB/uG2dX7vD/puk5TR92/2yrbQb5x0Wyt6nxadWyHo+jXVschabMHzsOUp7pntXvv/aGu+0jIvJ62jjp/v12ua5etqmW9T6OubXGQEFntTl53/Sz7vCaryeqU1bUtDpNy37rqkH2lpM9IMklnSLpplHmmFLL9NmaoP8op6bfDhh7YCFm2pqtjOxxFiPZAh7heWe3ee3+o6z4yTl6T1Wmoa1scJFR7IK/rlddkNVmdsrq2xWFS7luHDtiPSvq6pB+pdQ3ehZLeIOkNxc9N0mpJ2yV9RdLMKPNNKWRjnIGRWqiMO7CB6qTWVsYRu+xN6hA3Iavd4xzVi92Ou/UqD1mdhtTayjhil528rldek9VkdcpSayvjiF32LAYwyppSCtkYcgmw2DsJ8ha7nTepQ1zW1PSsdo/fjkdBVmNasds5eU1eTyt2Gx4FWY1pxW7nZWV1sjfxxF4xb+AyjsOXHKEXr71Ihy85InZRJta+Yc3Xrt0e/M7OZUv6ZjsjmKSd577OqJ8c8roOWS219v/1r3yXNrzyXWR1xchr5I6srk6IrG7Pp8oMqUNm1TaryxgVCT01YZSYUdY0tEcqNy6anWrEMsaIZ+xR1hhCrrM4okdWj4i8TsOG2dX+kBb6Q1pIVmeAvE5rakJek9VpCJHV7flUmZ1kdbpZHT1AR5maELIhG0tVgV3HPwztddpxzbap7gYdo27quD2GCbnOdIjJ6lGFymuyejrz23b7tctW+fplq8jqDJDXaU1NyGv61mmYNKvbvxsrr+u4LUaRQ1ZHD9BRpiaEbMjGUtWIYVNHJvuJWR9NDdmQ6BCT1aMKtb+R1XGQ1fkjr8nrUdC3zl+s+iCrw2AAAyOLNUqc+84+bfljrj9/8KZHh5isrlrMI3o55zVZDfKavK4afevxhSh7rPUnq8NgAGNMOe/wucp9Z8+5/FX+g5LCfMsoAx3iOFntTl7HkHPe5Vz2fm29jH2grlntTl6HmOhb5yHnvMu57FVmdVnzHXeeOfWtowfoKNMkIRt6pyG0+5vmvhEpqds2LusPRwrzLaMMdIjjZLV7ntcp5yj2vR9Cybns/ZSRaXXNanfyOsQUu29dx/04FLI6XSnkalnzzKlvHT1AR5lSGCXOeRSxbNRNmnIaJR53vjmNEjdpSuEMDPKoP+omXSkcfStjvpyBke4Uu29NHvVH3aQrhVwta5459a2jB+goUwrX6dVxFHFc455ORZ2hW8ptgg4xWV0n415WRr2hU+rtgbzOP69Tb2NVIasxrZTbRFlZfYAwksOXHKEXr71Ihy85oufP92yf13Vzl2nP9vmKS1adrSvW6vR1F2vrirX7vN+vbvp9HvU2aF8Y1iaasB+hXMOyWmpGO+u1rw2qG/K6mfrtC6O0hybsRygPWd1CVmMU9K27lDEqEnqKPUo8iiac7pXCqUgoz6Tbq/v3Bu0Lw5YRcz8SR/QakdXu5HWIzyOuSbZXr9/pty+MMn/yOu8ph7wmq6f/POKib80lJEnLMVByLDPCa7eD9ctWjR1w89t2+8ZFs/4DHfTY701z86mYbZIOcTOy2j2/7MutvCjPpHndK6s75zfJTbjJ67ynHPI6x+zLscwIb5qs3jC72q/t+j361vtO0QN0lCmHkM1RyiPb/AGoTrsdXLts1dh1vmF2tT+og33jotmev5dyG+tGh5isTlXK+xFZXa1J87pOWe1OXoeYyOtypLovkdXVmiarf6CDff2A30u1jfVSVlYvjHbtCqJbunJOm4qvqWlfz7VJ0ovXXhS7OLXWbgcnr5x77HrLPdvntXXFWi3teK/f795YfO31uZTbGJCLlPcjsrpak+Y1WQ1UI9V9iayu1jRZvUnSSSN8JrU2VqkyRkVCT4wS91bn0dQU1i2FMsRS9uhuqLoNuY3EET2yuiR1zpIU1i2FMsRUZl6nmNXu5HWIibzeX52zJIV1S6EMMeWQ1aHnVVZWRw/QUaZJQ7asHSWVHTCnU4hylGv9hmifZbfxUHUbchvRISary5JrluQi1/pNdXCgU4pZ7U5eh5gmyWuyGtPItX6blNWh58UAxgTK2lFS2QHL2BFCzzOVP0qTSK3so5YnlfY5SIp/DOgQk9VlIavLlVrZyery5tNGXsfJa7I6/nxTy7txpFZ2srr8eTGAMYEcgig1oXfSHHb6XIxal3Vun2WiQ0xW54SsThdZXT7yOk5ek9WTSfXoeNOR1eUrK6utNe+0zczM+ObNm2MXoxFGvXljrPk12deu3a77Xr9CR1+xUs84a0ns4tSOmW1x95nY5cgZWV0dsjpde7bP69Y3Xy6XdPJ7LqQ+S0BeT4+8rk7IfCWrwyGry1dWVh8Qeoaoxp7t87pu7jLt2T4fdL6HLzlCL157UbCduD0/SaWUt0l2rLlap9z7Ke1Yc/XQz/ZqH2W1mVGFXH7sdQHGUUZ7JavTdfiSI2SHHaozr/pdbV2xdujnU8trshpNlUPfmqwOJ/esDr382OsyljJO6wg9cafk/eV2Cllu5U3ROKew9arv2Nsg9VMoxSnJZHVJYu9748iprCnLOa9Tz2p38jrERF7vL6f8y6msKcs5q0MvP6e+dfQAHWUiZPeX2/VYuZU3d73qe5JtkOpNgcpoT3SIyeqy5JR/OZW1LlLL69Sz2p28DjGR1/vLKf9yKmtdpJbVKc+rrays5h4YGeL6N1TlurnLdPq6i7Vp9tLHTlmsK66pnh5ZvS+yGlUirzEO8novshpVIqunxz0wMrR1xVqdvu7ika7XAqaxdOWcNs1eqqUr5yb6/ayupwMCI6tRpWnymqxGk5HVqBJZPT0GMDI07T+VTcPOPrlpbzxFpwBNRlaPh6yezjR5TVajycjq8ZDV0yGrp7cwdgEwvs47EGO49s6+SaLeKrZ05Zw2FV+BpiGrx0NWx0NWo8nI6vGQ1fGQ1S2cgYHa6zeyXtUIch1Gqiddh0lGmetQXwDGR1ZPj6wGULZBZ6yQ16OpMqunWV6qGMBA7fXb2as6DasOp3tVuQ51qC8A4yOrp0dWAyjboH+iyevRVF3+3OurGwMYFUh51KuMso06z9j1UtU1jzleW9m9bapchxzrC/URO5f6IavJ6l7IajRV7FzqJ2ZWl7X8cZDX/XVum6rLn2N9DVTGs1lDT1U9q7qsZyqvX7bKH9JCX79sVdD5hrBhdrX/QAf7htnVlc+zjGU3Vei228Rto5KeVd2kqaqsdi8nr+e37faNi2b9wQTbPlldD2R1GOR1PnndtL51zKwua/lNRV5Pr6ys5iaeHca9Kc2oz432rq8pKeNmMKPOkxvRhBP6hkpsG6SujLzeumKtTr/3k9qy6DXJtX2yuh7IajRN0/rWMbO6rOU3FXmdsDJGRUJPqY4SjzqSVtbo8yhiLruOUq3PVMs1SGplFkf0sslq93LyOnabjL38Okm1LlMt1yAplpm8ziev6VtjkJTrMuWy9ZJiecvK6ugBOspUZad4HCk2lG5NPF2pTFXXZw5tbFKptU06xPXNavc89qXU9omckdXhpNguyev65nUO+1KK+0SuyOpwUmyXZWU1l5B0GfXUNSmP50ZzulJYVddnnZ+1TdvENMbJaom8bhqyOhzaJaZBVmMQsjqcRrXLMkZFQk9VjhKnOHqVkjqPXKaoV32zDcohjuiR1TVCTlSLrK4WeZ1PXpPVg5ET1epX32yHcpSV1TxGtUuVj5npfJxO7Mcejaqq5wiHqo/u+ZRZz2XMu9eztm998+V6/rq36NY3Xx5sOUBuqn4kWG55XeUz38nr3lm9dcVanbHuYt350ouSbitAmcjqwcjq8ZY1rV5ZLdG3zk7oERFJ50q6S9I2SZf0+PmxktZL+rKkrZKWDZtnqtfpDTNsNK9zVDqXEeqqRihD1Uf3fMqs51DzHlbH1xaPDrt2ikeHMdK8PzXsiB5Zva+65XWV+zh53bue24/l/YEOmmo55PX+mpTXZWS1Z5zXZPXkyGr61lUrK6tDh+wCSdslPVPSQZJulXRC12fWSHpj8f0JknYMm+80IRuzMXXudMNOL6XR7ytUfXTPp8x6DjXvYWEdYjnj/kFowunRDesQk9Vd2vvE+mWrhp5eGrusqSGvyeuqNSWvy8pqzziv6VtPjqwmq6uWywDGmZKu7nj9dklv7/rMX0v6rY7P3zBsvtOEbMzR185GmMMoMNJQRXiNu4xe7bdud45uSofYyeqe2u3r2mWryGqMjLzeXxV10pS8LiurPeO8pm+NSZDV+8s5q0MH7Wslvb/j9S9Iem/XZ54u6SuSdkraI+nUPvNaLmmzpM3HHnvsxBU3zsbJYQQRYZQ1Cp27cW5uVPW6lx3qTekQO1kdbd4YH1nd27BLV2LmdRUd8KbkdcisdvIaJSOv90dW12cA42JJv158f6akOyQdMGi+3CkZoZV1HWDuUl6fYaE+beg3pUPsZDUyQlb3lvL6jJLF5HXcrHbyGiUgr/eX8rrknNWhg3aUU91ul7So4/Xdkp4yaL5VhWydRvxyELO+6z5KPGm5xjkDIzXT/pFoSofYyWqMiawu1yRlyzmr3cnrUaeystrJ61qKXdd1z2uyeny5DGAsLILzOO292dCJXZ/5jKTXF9//pKR/l2SD5pvrnZIxWMqjkrkLXbc5bKtUR4lTnMhqjCOH/T9nIes3l21FXsfNaievaymX/T9XZPX4ysrqhQrI3R82szdJulqtOyd/wN1vN7N3FitwpaRfl/R/zOzXJHkRuh6yHL3s2T6vrSvWaunKuf2e/Ys4lq6c06bia7c92+d1y5svl0k66T0Xss3GNKhuU5hfGdrP9sZwZDXGQVaXK2S+5pDVEnk9KrIa4xi2/3/t2u267/UrdPQVK/WMs5ZUW7gaIKsTUsaoSOgpxChxLiNd48jl9KNJbJhd7Q9poT+khbXaZkiXGnJEr8yJrO6vrnlNViMG8jp+XpPV+dm4aNYflXzjotnYRUFDlJXVQc/ASFkuI13j2LpirU5fd7E2SWmOjk1h6co5feH+B1pH9Wq0zabB0Q40QR2zWqpvXpPV+yOr0QRkdX6OvmKlvvj61le0kNeZKmNUJPTEdXq9xRolrvPodNXGqcu6Hu1IhTiiR1aXKEZuktXhkNVpIa/J67KQ1Xkbty7J63KVldUHRB4/wRTa1yWNOmK4Z/u8rpu7THu2z0+13Pbo9NYVa6eaT5mmXddQdTXMOHW5dOWcNs1eWsnRjmHrX1X9AHURI69zyGopj7wmq4FmIKv7q1tWS9Xl9SjrTl6PoYxRkdATo8RhhBplzGGkeNp17fX7Zax3qnU5rP5Gqd9e65bq+rqXN0rcpImsDidEXqe8v3XKIa9TrcsmZrU7eR1iIq/DIKun+32yerzPdK9fquvbVlZWRw/QUSZCNozUG3lI0z6rudfvN+k0s2H1N0r99qqvlOuQDjFZnRLyevTPNzmvm5jV7uR1iIm8DoOsHv3zZPXgupskr1OvPwYwgJINC4Em/ZEKoayjemVtBzrEZDXyMOlZBeitzDMwyOt0J/IaZSOrwyvrDIzcsjp6gI4yEbKjmbTxER4t1EMeyhptpkNMVleFrJ4O9ZAP8jrdibwejqyeDvWQj9yyupE38azrTVImvQlQLjcP6iXkthz3xk2Io8ob5CEusjrM76Ui1PYkq/NBXjdHHfOarCarmyK7rC5jVCT0FHqUuHuUqS4jhLmPFE9SjvXLVvlDWujrl60qsWTolEp7CU0c0SOrK5J7Vk9Slvltu33joll/MOFrdesmpfYSGnlNXleBrCarq5BSewmtrKyOHqCjTKFDtruhxL4BSp0b7jgm2Q7XFgMY1zKAUZnY+0tZ6BCT1ZOUqanG3Ratzx/kGxfNNr7uqpLC/lIW8pq8Hrc8TUVWpy/2vlImBjBKFDvk6txwxzHtk0NCzrfupqmTutYnHWKyehTkdcu0d6MPMc+mqMNR4NDIa/J6GLK6pYysnmS+TUBW748BjCmk3jBSL1/uxv0j1t4eO67ZVtvtwh/2/dEhjp/V7unnYerlyxlZ3Rt5vT/yOn5ep56FqZcvd+PkElndXAxgTGGSBjUs+OoYjHVcJ/fx16vdXjYump2oMz1N/Q2aR8jtM+28UmorocpChzh+VrtP/k8sWZ2/umR1qGWEmlcq7SVkOcjr+HlN33o0dVwn9/HWa9KsHnc5k8yDrC63LAxgTKHXRhi2YYYFcx1H2eq4TpOYdKQ4RP0NmkdK26eOZaFDHD+r3cd/xjlZ3VypZnWoZYSSSllCloO8jp/X9K1HU8d1Gtc0Z2DQt867LAxgBNbeMOuXreq5MzFKjHGFaDOdnxn3H7kq1bEsdIjTzur2Nh63w5xSWw2ljutUpbKzetR5VCWVsnAGRloTfetq1HGdqhTi7An61vHKwgBGYO0Nc+2yVUFGmFJqdEjTuKOZVY7E0n7LC9kmTWVmdfsreY2ypZzV7rRfd/I6xETfGrmbJHvpW1errKxeqIY6fMkRevHai7Rn+7w2HXaolq6cm2p+W1es1enrLtYmSS9ee1GYQiJ5e7bPa+uKtVq6ck6HLzli4GeXrpzTpuLrKMb9/CTa5ff7H9AZV/0u7RfJaWe1FG6fIK+bpy5ZvXTlHO0XyaJvjWmVmdWT/s646FtXoIxRkdBT2Y96CiHVUbZpypXqOqUkpevVJtEu/7V9TvdMVRltUxzRa0RWu6ebbZOWK9X1SUldsrrfpVSpKqus5HUz8jrVtk5Wlyf3rHbPs2+dW1ZHD9BRphxCNpTQDWiaIKhDiAy7Tjnk/HOUa/nLaJt0iMnqcZSx70zarsnq8eafo1zLX1bbJK/J63Gk0reuQ1a7l5vXuWZdpxzXIbesjh6go0wxQjZW4wvdgJp+BkZnfdblDwc4AyPViayeTpOP6pHV9ZTbUb0mTVXndcycSqVvXYesdiev6yi3rI4eoKNMMTrFsXbIuoRbKhgl3iu38laNDjFZPQ72p7DI6r1yK28M5HV+eR3zH132qbDI671yK2/VGMCoGA1yNE2up9xGnXMrb9XoEJPVddbkesot+3IrbwzkdX553eQMGkfT6ym3/MutvFUrK6sb+xSSYTrvfI/+UrhD9Dh3LA6pijsZh5RbeYFRkNWjSSGrpTh5nVv25VZeYBRk9WianNVSfvmXW3nr4oDYBaibPdvndd3cZdqzfT7K71dt6co5bZq9NOqO2w77rSvWVrrc9h/jKoN9GqmVN7e2jnohq+OIkdepZd8wKZY3t/aOemlSXjc5q6U082+Q1MqbU1ufBgMYCruxp93hYwXGpFLYcVMJe4wnt7aO+MjqyaWQ1RJ5navc2jviCv1PVJPymqzGNHJq69PgEhKFPV1r2lOJOBVpfNOclrhn+7xuffPlckknv+fC6H8wmoS2jnGR1fmbNK/J6rho7xhH6MsgyOvqkdV5akpbt9b9NdI2MzPjmzdvLm3+sa7zQnzXzV2m5697iyTphtm/5PrMxFS5b5rZFnefKXUhNUdWoyxkdfrI67yUmddkdXOR1emrQ1ZzCYnSOV1rmNCn5A2aX1OuoVq6ck4bl/2RvrDsjx4brWzKureNu75VtsOmnAqH0eSS1VLY/YSs7p3VUnPWv22c9a0yqyXyGnuR1WQ1WR2vb92IrC7j0SahpxiP5ktR6Ef1DJpfkx8LFHrdU38k1rjrW2U7rLLuxGP5yOqAQu4nZHV/Idc/9ax2H299q8xqd/I6t4m8biGrq0FWh/38NPOqQ1ZHD9BRJkK2JXSDGzS/HMJhXKOuU+h17wySqut1lOWNW6Yq22FZy+yFDjFZHVLINktWh/nsMN2dvirrtoy/TzGyuozl9kJek9ehkNWTI6un/9ykn49RxkkwgFEjdQyxHMQa/e7c3lWXYcPsan9QB/vGRbNZt7cq6o0OMVndC3ldvRSyuupytJe1ftmq7NsbeZ3HVLe8JqurR1bn3d5yzmqeQhJB6LszYzSx7szbeSfnqsuwdOWcttxwvU6595PatOJF2ba3ptxVGekhr6uXQlZXXY72svz+B3RG5u2NvEYMZHX1yOq821vOWc1TSCLg7szoVmaboL2NhrvaT69uWS2x/2B/5HV85PX06pbX7DvoRlbHx1NIaiSnuzNXqco78KamzDsC096AybH/9BYqY3PLaom8BlLEvtMbfWuyuo4YwEAyQgZNbo8IWrpyTptmL83yNK5p9fuDmNsfSqBJQmVsblktkdfkNZAP+tZk9Sjv54Z7YCAZIa/Fyu26ru7r+WKq+rS4ftetcj0rkK5QGZtbVkvp5HWMU5jJayAv9K3j5xFZXYLQdwWVdK6kuyRtk3RJn8/8vKQ7JN0u6e+GzbNud0pGfdXhLthV31W6X51VXZdq2F3tyWo0GVk9GfK6Hlnt5DUykntek9Ul5GLQmUkLJG2X9ExJB0m6VdIJXZ85XtKXJR1evH7KsPkSsuVrN+gd12zLOiRiKyOkyg6b7vnn/odiUg3rEJPVmercP5u6r4aQY1Z3L6PJ278peV1WVjt5XQn61mHkmNdkdUsuAxhnSrq64/XbJb296zOrJP2PceZLyJavHQ4bF81GeaZzSDGDooxllz1yG+s53qlpSofYyeqsde6vue+7ZHWay8hBU/K6rKx28roS9K3TXTZ962qUldWh74FxtKR7O17vlHR612d+QpLMbKNaI8vvcPfPds/IzJZLWi5Jxx57bJDC8cib/trXtS1efo42rXmRlq6cy7a+Yl7fVcb1dmVfc5jbNY0IgqzOVPf+2v4+xzojq9NcBpISLKuLzwTN6xxzp0r0rcPIMa/J6pKFHA2R9FpJ7+94/QuS3tv1mU9L+qSkAyUdp1YwP2nQfEONElc5GlaH04Umqa8Y693vEghO2cM41JAjek5W76MOWe2eR14PulytLtsB1WhKXpeV1R4or1O5Z1ZOcsjqXsukb41JlJXVoYN2lFPd/krSL3W8vkbS8wbNN1SnuMoAqMOpQ5PUV4z17rfMOmyDXITct2J1UJrSIXayeh91yYkc8nrQ8uqyHVJXh6x2b05el5XVHiivq24DdciJHLJ60DLrsA1yEHrfqlvfOnTQLpR0dzEC3L7Z0IldnzlX0geL748sRoqfPGi+OVynx40QW1IYJY5ZlqYK+Qct1h/HpnSInawmqwuxz8CIWZamqkNWuzcnr8vKas8gr3tlQlNzgr5184TO17r1rcsI22WS/lWtuyavKN57p6RXFd+bpEvVetzTVyTNDZtn6iHrzohkCMNCkdBMVx2O6jWlQ9yeyGqyelJkdb7qkNXuzcrrMrLaM8hrsjoMBo7zxBkYQ3KxjJmGnlIPWXdCIIRhf6z4YzY+2uXomtQhLmsiq5uBrA6Pdjke8rr+ec0+EQaX7oVH2xxdWVkd+ikkjVXGHXKbZtgde5t2R98Qd6qOeddoIEVk9fTI6n2R1UB4ZHUYg/K4aVktkdd1wQAGkjHsj1XT/piFCMiU/jjl+ugwAPsiq/dFVgNI1aA8blpWS/XK6yZnNQMYqK3cd+wQAZnSH6fWH41f0803XK+fXH9ZltsEQHhkdYpZfbG+eP8DOuCwQ7PdLgDCyj2rpXrldZOz+oDYBQDK0t6xt65YG7soj9mzfV7XzV2mPdvnh362HZB1CaOlK+d086LX6NR7P5XUNgEQF1mdlqUr57Rp9lKZlNx2ARBPilktNTevm5zVDGDU3Dg7dR10rm97x459ilenVMO/rcz2cviSI/ST6y/TjYltEyAFTctqae86L15+Dlk9prKz+sVrL9JJ77kwue0CpKBpeZ1yVktp5zVZXZIy7gwaekr9Tskpa9odhkOtb1l3GE79zsXrl63yh7TQ1y9bFbsolRN3tSerI2paVruHWWeyunlZ7U5eh5jI68k1La9Tzuqy5z2tDbOr/UEd7BsXzSZZvrKVldXcA6PmUrnRTFVCrW9ZdxhO5bq5frzrK4BqNC2rpTDrTFYDqFrT8jrlrJbSzuulK+e05Ybrdcq9n9SmFS9Ktpy5sdbgSNpmZmZ88+bNsYuBCqRyg6BUylG1pq63JJnZFnefiV2OnJHVzZJCXqRQhhiaut5t5PX0yOvmSCEvUihDLE1e97KymntgICllXMc2yfVndbrJzziaut4AxpdCXjc1s5q63gDGR1bH1eR1LwsDGEhKGTfeTPnmPrlq2g2sAOyPvE4fWQ2ArE4fWT0eBjCQlDJGKRcvP0c3L3q1Fi8/J9g8h6l7EPGHC0DovN6zfV6P3v+Ablz2B5VeW17nvCarAdC3Th9ZPR4GMFB7O9ZcrVPu/ZR2rLm6smXWJYj6/bFI8RG1APK2dcVanXnV78oOO7TSU23rnNdkNYAy0LeeHFk9PQYwEFX3TlzG6GqMUKhLEPX7Y8H1fECz9Mrm0HkdKzfrnNdkNdA89K3TRlYHUMazWUNPPKu6vrqfLd3vWdMpP+O5zppU7yrpWdVNmsjq+uqVzb3ea1JmpKZJdU9ek9foj7512ppU72VlNWdgIKru0dTO150jxnU5baxKIUbcGREGIPU+8tV+b/Hyc8jqKZHXAELp17fuzGqpPpdkVImsTkQZoyKhp1CjxE0a8aqDzhFjtt34+o24h1DH7SGO6JHVmAhZPT3yejzkdRp5Xce2VWfdOcP2Gx9ZPZ6ysjp6gI4yheoUs+OWK3R9sn2mq4My66/MAI+FDnG6We1OHoQWsj7ZNi3kdXXI6zTymqwuH1kdHlldHQYwAuhudHVsKIOUHVxNq88qpFqndfwjSIc43ax2T3dfKEMV+1eT6rMqqdYpec3UayrrDIxU94MykNV5SrVOyerRp+gBOspU1o2G6thQBil7h617fcZYv7rXaUroEKeb1e7N2heq6FzVvT7J63ojr9PN6ybtB2T19MjqemMAo2HK2LnGmSc79/6G/aHKoc5yKGMsdIjJ6knFvnyO/Xp/g/I6h/rKoYwxkdfk9STI6vTQt643BjAyM21jnnZUN/by62hYneZQZ9wHpj86xM3Mave4eRliH8whe6o2qF5zqC/uLTAYed3MvCar64e+db0xgJGZaUNy/bJVfu2yVdkOgDRRZ52lWn8x7gOTal10o0PczKx2n3w/aLftHddsm7iNh9gHc9nHUpFjVrtzGWgn8rqZeR2zb01Wx5FjXtO33osBjMzsuGabb1w06zuu2Tb279YlJFMoQyy5dDS5AdVedIibmdXuk+d1XbI6pXJULZesDj2vXnLJanfyOsSUY17H7FunkpGplCOGXPKavvVeDGBkJvZpainIZecqAx3NvXJpz3SIm5nV7tOfgZF62x5FTpkSElm9V07tmbxuZl7Tt84rU0Ijr/fKpT2XldXWmnfaZmZmfPPmzbGLMZY92+e1dcVaLV05p8OXHBG7OFFQB+WhbsMzsy3uPhO7HDnLMasl9ieJOigL9VoO8np6OeY1+xN1UCbqNryysvqA0DNEy+FLjtCL11603w6wZ/u8rpu7THu2z0cqWViD1qdfHeQk1e1Vh7oFUtFrf0p1358GeV29OtQrkAqyuh6Zkuo2q0PdNgUDGBXbumKtTl93sbauWBu7KEHUbX261X39APRWx32/juvUqe7rB2B/ddzv67hOneq+figfAxgVW7pyTptmL9XSlXOxixLEJOuT6shrLzlvr5TrOeWyAVLe+34/465Tbvtprtss5XpOuWyAlO9+Pwh96zSlXMcpl60UZdxYI/SU442GmmDSG8jkdJOcnKVczymWTdwUjqyuKbI6bSnXc6plI6/J67oir9OVch2nWraysnph5PETlKjsm9G0TwHbJOnFay8a+feWrpzTpuIrN8wpT2c9pyblsgFVI6ubLeU8TLlsQNWqyEHyOl0p52HKZStFGaMioaemjxKnOhob4hE+qY0Y5vJYIoQnjuiR1VMiq6tDVjcbeU1eT2uSDKkiB8lr1ElZWR09QEeZmh6ykwZRDoERs4y9lt2u6/XLVj32sxzqEXtNur3oEJPV0yKrq1t+Z123f7bjmm3J1yP2RV6T17FMktexc3BU9K0RWmpZzSUkGZj0tKD244BSFrOMvU7Ta9e13/+Azih+Jmmi0/kQx6SnXwLTIqvL071fd9Z1+2c33/BqnX7vp9j3M0JeI5ZJ8jp2Do6KvjVCSy6ryxgVCT3VZZSY0ca0DNoenT8Lvd1SaQeplCO01EaJmzTVJavd67t/5GqUvA59BkYqbSCVcpSBvCavp1Xn/SNHMfrWKbWBlMoSUmpZHT1AR5nGDdkqG884y0rtmjTEkUo7SKUcqaBDTFZ3Yv9AKm0glXKkhLyuNq+r/qeMvjXGkVIbSKksKWAAYwxVNp5xljXuH4C6juI1XSrbtV85Uilf1egQk9WdyGuksk3J6v2R19XmddX/lNG3xjhS2qbk9b6yGcCQdK6kuyRtk3TJgM/9rCSXNDNsnnU6qjcORvEQQ1PbXdM6xGR1WE3dbxBPk9tck/K6jKz2MfM65TMwxtXk/QbxNLXdZTGAIWmBpO2SninpIEm3Sjqhx+cOk3S9pBvL6BSPYn7bbl+/bJVfu2xVsqNhdRqtq9O61N0k26oO27dhHWKyOrA67APu9VmPJmhqVrs3J6/LymovKa93XLPNNy6a9R3XbAs+71Dqsg+412td6q6pZwrlMoBxpqSrO16/XdLbe3zu3ZJeKWlDrE7xhtnV/pAW+kNaWPvRsBR2gjqPPJZ1A7mc1GH7NqVD7GR10mLndR325X7I6vps36bkdVlZ7SXl9cZFs/6o5BsXzQafd2piZ7V7ffbnbmR1fbZtLgMYr5X0/o7XvyDpvV2fOUXS/y2+7xu0kpZL2ixp87HHHhu4OvM5qhdCv52gTqdvx9Su342LZicOm9zrJ/fyuzenQ+xkddJi53Ud9uV+yOr8y9/WlLwOmdVeQV7ncAZGKLGzuuplVYmszr/8bbUYwJB0QBGui32EoG1PqT3qKbdG1a+8rYA4yDcums1mXVIUYqS4LiOtOWtKh9gblNXu5DX2Iqvroyl5XVZWe4J5TVajjayuj1wGMAae6ibpiZK+LWlHMT0o6d+HhW1qIZvaTjFp6M9v2+0bF836gwmtS2oG1W3IP7a5/eGuo6Z0iL1BWe2eVl5Ps5+T18NVcfd3sjoNTcnrsrLaE8zrlLLanb51maroW5PVachlAGOhpLslHae9Nxs6ccDnkzyqN6zRh9gpQu5Y04Q+O/hgg+o2tT+2mE5TOsTeoKwe9TPTLmNU02YGeT1Yv/olq+unKXldVlZ7gnmdUla707cuE33r5shiAKNVTi2T9K9q3TV5RfHeOyW9qsdnk+wUV7HzhFwGQVmeqs7AyEld17spHeL2RFZXv4y67jupqOIMjNzUdd2blNdlZLXXMK9Dz7+u+04K6Fvvr67rnc0ARhlTaqPEIZfR5Dvs5q6uYTNMXUfHm9QhLmsiq5Gipma1O3nN1Jy8JqvzR1aT1aNOBwj7OXzJEXrx2ot0+JIjRv6dPdvndd3cZdqzfX6sZexYc7VOX3extq5YO/U86y61+ti6Ym3fbZe7QXW9dOWcNs1eqqUr5yKUDNgrlayeZL51llpd1DmrJfIaeSg7r8nq8aVWF2Q1WT2yMkZFQk+p3Wiol0lHzgaNNtZ1NG5SqdVHnUeKY9d1jLoVR/TI6gGGtcnY+0xKUquLOme1e9z6jlW35DV53Q9ZPbrU6oKsLled+tbRA3SUKWbIdm7ssq7Z4rrd0VAf1Yld1zFCng4xWT3OMkLOt26oi2rFrO9YHXLymrweZxmh5lk31EW1Ytd3nfrW0QN0lClmyHZu7LI2fOwROSA1dRolbtJEVgPNwhkY+U7kNdAsdepbL4x27Uomlq6c06biq6R9vi9rGU23Z/u8tq5Yq6Ur58a6VrLseaE67WtZgVGR1dUjq0FWYxLkdfXIa9Qqr8sYFQk9TTpKHPtUnRylUGchR80ZgZ9OCu2hKuKIHlmdkRTqjKxORwrtoUrkdZy8blo7CyGVOiOv05FKm6hCWVld66eQxLybbWp39h1VCncADnkn3irv6pvrNh8khfaA+iOrx5fCvplrVkv5bvd+UmgPqL/Y7SzH/TZ2nbXlmtc5bvNhUmkTWStjVCT0lPJRvX7LyPWu4E0aFQytjiPSTWoP4ogeWR3BpOvepH2zDLG3e2hNaw/kdZy8rqqdpZjXZHUcdctq92a1ibKyOnqAjjKl/KinfjtW6MY5zvzG3dmbtCOVqVc9jlq3bIP46BCT1SGMO79x8pqcCKe7LsnqvJDX5HUIZfWtyYlwJu1bsw3SwABGoqraQUIE545rtvnGRbO+45ptE8+7THUMm1HrNpVt0GR0iMnqEEIMIM9v2+3rl63ya5et2uf9VHKCrI6/DZqOvCavQyirb51STjQ1r1PaBk3GAEZJUtmxh5UjRDk3Lpr1RyW//XGnTHSWQAiDllXHsEn5qF4qbT+EEOtChzjtrHZPo81WkdUbZlf7Q1roD2mBb1w0O/ZZAqGkeBp3WcjqaoRaF/I67bxOoc1WdZS+V986lax2b25ex2qDKbT9UFLuW0cP0FGmMkM2lR27inLsuGab3/64U/xBHRRtfQetZ512+hyk0vZDCLEudIjTzmr3NNpsFWVon4Fxw9Ne7Q9GXN+qTuPGYCm0+1BCrQt5nXZep9BmqyoDfWt0SqHth5Jy3zp6gI4yhQzZSa97LVtV5Yi9vrGXj71S2BahypDyKHGTpjKzut97VUvljLUqxF4+WlLZDiHKwRkY6Ux171uT1YghhW3RhL519AAdZQoZstOMJqXQKDulVp4cTVOH1P9go9RPSiPVdIjrk9Xuae2fKZUlZ5PWI/U/HHndvCmVvE5t/0ytPDmib10esro1RQ/QUaYyRol3XLNt7B0kpQbhnl55cjRNHVL/g41SPyn9oaJDXJ+sdk9r/0ypLDmbtB6p/+HI6+ZNqeR1avtnauXJEX3r8pDVrSl6gI4ylXGdXmcDGLahp+1IlyWlBpqrkKPEbI995VYfdIjTz2r3we2q82cptb+UypKzkGdgsE32lVt9kNfp53WOWe2e376QIvrW5cmtPhjACKyzAQwbzUp9NDC3xpyyaeoy9XbSbZx1TbmNcU11OlPZWe0+eD/LYR9MeV/KTVPyetz1TLmNkdfpTDH71jnsfynvR7lpSla707fuxgBGiUY9AyPFBuae386dsjpdx9nWr1zjrGvK9RKq/dMhTj+r3Uc/AyNV5HU4KefSpHqVa9z1TLleyOt0pph961T3v05kdTgpZ9Kk6FuPhgEM9JXqzp2jnOpy1LL2C6GqRonL7gSkPkrcpImsHi6njEldLnU5Tjl75WWVZ2CQ182ZyOvBcsmXHORSl9Nm9bjzIKsnn6IH6ChTSiGby06I+hs1vGK32djLHxUdYrIaKMM4Hc3Y7Tb28kdFXtcnr3Npc6g/sjq8srL6AGEsW1es1enrLtbWFWtjF+Uxe7bP67q5y7Rn+3wS80Fvoet36co5bZq9VEtXzg383OFLjtCL116kw5ccEWS53YatV9nLB3pJMaulMDlAVpcrVlZL5eblKOtFXqNqZDWmEbKOyeqMlDEqEnpKZZTYPc0Rr1CnEXG9X7lSr99J23bq6zUqcUSPrK5AiP2lLvtcqlKv36ZntTt5HWJKJa/Jakwj9TqepH2nvk7jKCurowfoKFMqIZuqUOGf6h+REOVKYd1SKMMgwwKzX/lTX69R0SEmq6tQlzzrZ9qypbBuKZRhkKZntTt5HWIirwcjq8v9/VBSKUc/g/KarJ58ih6go0yEbBi57hCMgldjWPuYtA5zaXd0iMnqVOSyz/QybdaS1cM1PavdyesQE3kdRk77TSeyuhqD2sc0dZhLu2MAA1PLNWxSGAXPJSjKVPfTlukQk9WpyGWf6SWFrG16Xtc9q93J6xATeR1GTvtNJ7I6vpSfQhIKAxiY2jQ7Sh1DZtLHJdWxLsqUS33RISarU0FW72+SvF6/bFUt66IsObUd8pq8TsWk+01O+9s4yOpq5NJ+yspqnkLSoe53Cx7njrXddZHqXaKnMc46LV5+jm5e9GotXn7O2HVR93Y1TOPvlIxS1Hm/Iqv3N0leP/rA98nqMZDVKEPd96tJ85qsJqun0fi8LmNUJPRU1SjxtKfj5DIaNoruushx3YaVuaozMHI5zauXHLf7pMQRvWyy2p28bqtDVruXk9fjHtUjq/NBXueT12T1XnU4m5esnl6u234SZWV19AAdZaoqZKdtULnvUJ1S2blSuT5slHLU8W7CdWrTw9Ahzier3cnrtpTyJZe8JqvzR17nk9dk9V6pZAxZHVed2vQwDGBUbJKdg+vg+otxU7Gq67WOgdSEttlGh7g5WR3j93JS97wmq/NHXjcnr8nq/sjqPDWhbbYxgBHApJcMlL3suu6gnSZdx5x28pzKiv3RISarR1k2ed1fLhmYSznRH3mdRl7HvqSWvjVZjbQxgBHAODt66J1m0LKbsIOmtI6dZYlRrjKXGbueYy9/GnSIyepRlp1zGx9VKuvYXY6qy1X28mLWcyrbeFLkdRp5Pe4/0PStw0ppHWP2reuc1SksfxoMYARAZyGcFNYnxKlzMUboy1xm7CMOsZc/DTrEZHXsZZchhfUJdZpz1flS9vJi5mXOWe1OXoeYYpyBEVrs5YeUyrrk2Leuc1ansPxpMICRgFTCpQxVnAZY9ZHSUcqRyhkY7fd2XLNtqvLEbqOxlz8NOsRkdQ6amtVllGvc5Xe+f+2yVb5+2aqpysJA3eTI63rkde7tcJAcs3rScnSXhawOK/byp8EARgJyHgEbporTAEPXX847dLd23WxcNFvbNjauqrcvHWKyOgdkdXwbZlf7Q1roD2lhLdvYuGJsX/K6HnlNVu+VQlZPWo5UkdX7qlNWRw/QUaYUQta9Xjt1t/ltu339slV+7ZSjlMOWEaP+Jl1uleUNdQZGmarefqP+YQ5VLjrEZHUOqsiK3LJ62t+dZFkhjuqVqcr6qDqr3cnrEFMKeU1Wh1kGWd1/WWT1XnXK6vAzlM6VdJekbZIu6fHziyXdIWmrpGskPWPYPFMI2SaoeiS8qp120vWq85GBSaTaPkKVq2kdYrI6b1Xuj6ln9bS/W0cpto+QZWpSXpeR1U5eVybFfXFaZHU4KbaPHLI6dMgukLRd0jMlHSTpVkkndH3mpZJ+rPj+jZLWDZsvIRveoPswpHaEfVo5nIGRg1TrgzMwyOo6G3Rtb2pHbaaVy1G9HKRYHzkc1UttKiurnbwuRey+NVmdnxTrI4esDh20Z0q6uuP12yW9fcDnf0rSxmHzLSNkYzSYlBppCiOgKdVH3VHXwzWlQ+xkddLL7UZWNw/1PVxT8rqsrPYa5XVK+0vsvE6pLpqA+h6urKw+QGEdLenejtc7i/f6uVDSZ3r9wMyWm9lmM9u8a9eugEVs2bpirU5fd7G2rlgbfN4pLbOfpSvntGn2Ui1dOTfW7+3ZPq/r5i7Tnu3zU5fh8CVH6MVrL9LhS46Yel7TCrleKUqp7SEJZHWiy+1GVu+r7lktpdP2kIRgWS3VM69T2l9i5zVZXa2U2l7TLIy1YDN7naQZSS/u9XN3XyNpjSTNzMx46OUvXTmnTcXXKuzZPi+//wF9cdkf6OSKljlIO+TG1d5ZN0kT/X6q6rpebVW3d9RH07JaSiuvyep91XW9OpHXmMSwrJbql9cpZbVEXneq4zp1I6vjCX0Gxn2SFnW8PqZ4bx9m9nJJKyS9yt1/GLgM++k1Clj1KOXWFWt1xlW/qwMOO7SyZZYx+jnp6HLqcluvcbdtSqPySEKSWS3t37ZjtN2q85qsHl1u6zXJtiWv0SGbrJbq37cu66yC3HJtFDmuE33rjIS8HkWtMzrulnSc9t5s6MSuz/yUWjckOn7U+U57nV7sa9Lc41wnlcJ6oxwxt21dr/lTQ66p9oSz2j2N3KrrDY1RPbK6HE3J67Ky2gPkdQq5RVYjJPI6vLKyOuglJO7+sJm9SdLVat05+QPufruZvbNYgSslvUvS4yX9vZlJ0r+5+6tClqNbCqf4THpa2TRSWO+c7Nk+r60r1mrx8nO0Y83VWrpyLtlR1Zjb9pY3X64XXvXb+sL9D+il//i2ypeP6aWa1VIauVV1XqewzrnZs31et775crmkk99zIVndA1mdP7J6MLI6fblktUReZ6WMUZHQU5Me9VTXEbgctEdeNy6aZYR9gPXLVvlDWujrl62aaj6ptXU15IhemRNZjapsmF3tD2mhP6SFZHUfdc1qd/I6xNSUvE6x/TYJWT2auuZ1WVkd7Sae6K0JN71JVXvkdfHyc7RpzYv2GYFtn52R8lkZVTnpPRfqhsMO1UlTjlDT1pEz2m9cS1fOaeP9D7SO6pHVPZHVAO03NrJ6NOT1mMoYFQk9TTNKnNpI1DBVlje3uplUiPXkusfwUmt/4ogeWT0Gsjo8sjpNKbY/8jpeXqfYHgYhq8sx7bqS1eVIrQ2WldWhn0KSnJDP6J3m7sMpPg+57OcXp7LOIdYzx7spT6LKbcbdm9EpdB5N2pZTya1OVTxrPoX1JqtHR1YjllSyetTfPXzJEVq6ck5bV6wtfX9pSlZL069rU7JaIq9LUcaoSOgplaN61xbXJ107wfVJo440VjkiWfYoXRnrMkmZUxuNDKGsdWryiLg4olebrJ7ftru4l81BY7flJma1exp5Xcesdi9nvZqc1e7kdYgphTMwpslq9/TyuilZPenvpI6+dXhlZXX0AB1lSuVGQ9PcYGXUnSLHQOhXZjpt5QlZD53bKcf2Fwod4vpk9YbZ1f5gcUPecdtyE7N62M8mRV63hKoHsnov8roeeT1NVrvXN6/J6jjoW4fHAEYCmtwAB6nbkcgchKwH/nC10CEmq+uu6n2d7dASqh7I6r3I63rkNRnRG1kdB33r8BjAqBA78nior8FC10/s+dV1e9MhJqvrjvoaLHa2ljG/um5z8pq8rjPqargU8jXk/Oq6zRnAqBCjZs1QVViEbk+x22edriXtRIeYrEaayOq0yxCj401ek9dIT5VZULe8JqvHmxZGuG9oEgY9f3jpyjltKr6iXjq3e1XPSg7dnmK3z6qW35hnWWOofnkde19Audrb/dH7H9CZV/0uWZ1oGchqtNG3bqaqs1qqX16T1WMqY1Qk9FTGKHHskTbE0bnd63q6Vl1wBkZ+U1lH9MjrZmpv9/XLVpHVCavTUb0mTfStEQpZnYc6ZXVjz8CIPdKGODq3e/tZyU0y6OhIapq4fdAbed1M7e1+UgZ5FRpZjRyR1c3U5KyW8snrOmX1AbELEEt7I6bc0HK3Z/u8rpu7THu2z8cuymOavt3bp49tXbE2dlGAkTV9vy1bilktNXu7k9XIUZP32SqQ1Wkir6vX2AGMEFINklSksEOXuY3GnXcK7WXpyjltmr0066Mjg+oxhTpGmmgb/aWQ1VJ524isjqdfXaZQx0gTbaM/srq6soyjDnmdXVaXcV1K6CmFZ1X3kuK1find1yGFspS5jcadd0rtJYVtM6lB9ThNHYtrqmub1e5p7X9tqeyHqZSjrG1EVsfTry6nrWPyur55ndL+15bKfphKOVLJ6jLLMolUts8kcsvq6AE6ylRGyIZoZFU01HGXkdKOHNok9V3mNsr5Gc85t5NB9ThNHdMhrm9Wh5xPyPnnvB8OMmldl7WNyOp4+tXltHVMXtc3r8nq6uSe1WWWZRI5t5Pcsjp6gI4yNflOyeOWM6UdObRctlkO6txOJkWHmKyexiTlrOt+mMs2y0Fd28i0yGvyelJk9V45bK+c1LWdTKOsrG7sPTCWrpzTjcv+QI/e/0B61/V0GPe6qjrfSKdXXYxzbVay13FVqF0HkmrbTlAvdc1qqb55TVaHkcud7YG2HPKarN6rX12Q1+Ohbx1BGaMioaeyrtNj5HG4sk7XD2Wcbcj2TqsOpm0/odufOKJHVmeurFNAQyCrx5dSPUzThspof+Q1eZ0z+tb1klIdNKVvHT1AR5nKCtkUQqJMIdZv0E6Zwg47zjrWfXuPIqU6mLb9hG5/dIjJ6lhCrV9ZN+EKgaweX0r1ME0bKqP9kdfkdQxlZ/Wwn1WFvB5PSnXQlL519AAdZUrlTsll7NBlNvoQjTD1UWLkqymjxE2ayOrJhOowpHwGBvLGGRj1m3LL6xT+qS47q4f9DBimKX3r6AE6ypRKyJZxSlWZI60xO/EEMHJDh5isDjXPcZHVwHjI6+bldQqXNYybl6N8PoWBGaAsDGAkILejeuMI/QckhVPgyhJzm6XSXuqIDjFZHWqeZSKrRxd7m8Vefp2R183L6xz/0R8lX1MYmIkt9vaKvfw6YwAjEXVt5NP8ARn1vbqI+Qekrn+8UkCHmKzOwbSd/e7361pP7vHzMvby64y8Jq9zMM0ZGE3qW8fOytjLrzMGMCYUemdPuZHHCraU66QMnIFRT3SIyeoqkdfli52XsZdfZ+Q1eV0Vsrp8sbMy9vLrjAGMCYUOgJQbeaywS7lOmoptMj46xGR1lchruLM9JkVek9dVIavhzvaYFAMYE0q5wQ0q2yQ/m2ZdU64njK9JI/eh0CEmq/sZVrZJMnnS9U25njA+snoy5DV53U/o/jN9a7iT1ZNiAKOGBu0Mk/6sjLIgP/zRHB8dYrK6n2H52O/nZDWGIasnQ16T1/1M0n8uK1fJ6/ogqydTVlYvFKJZunJOm4qvoX5WRlmQn8OXHKEXr70odjGAWhiWj/1+TlZjGLIaCGuS/nNZuUpe1wdZnRZrDY6kbWZmxjdv3hy7GJXYs31eW1es1dKVczp8yRGxiwM0hpltcfeZ2OXIGVkNoArk9fSaktdkNRBPWVl9QOgZYjpbV6zV6esu1tYVa2MXBTWxZ/u8rpu7THu2z8cuClAbZDVCI6uB8MhqhEZWx8clJInhdDOE1v7jvUni9DcgELIaoZHVQHhkNUIjq+PjDIwOKYyota+x4jQ3TKq7HS9dOadNs5dq6cq5Stv4pMtKYT9E+mK3E7Ia08o9q6f9XTRD7DZCVmNaqWR1r7KU/XvJKuPOoKGnae+UPOqdY0e5WzB3oa0G9Ty5aZ5gE/LRjpPefTvWXbvFXe2jZ7U7eZ0b6nhy0z5tbJK6D5nV0/7uNMjr+HlNVueHep5MjKzu93v0rVtT9AAdZZo2ZEfdaKM0MB6JVI1rl63yh7TQr122KnZRSlHmH5FpnmceMhhDBnYV6BDHz2p38jo3ZHU58y6rfYfM6ml/dxrkdfy8JqvzU+e8rltW9/s9+tatKXqAjjKNG7LdGynkRqvb6GWq67O+CNn1NQxZ93SPSOQWjCHRIa4+q93J63GkuD5kdUsueZ1iG5oEeV19XpPVo0t1feqc13XL6ml+LyXZDGBIOlfSXZK2Sbqkx88PlrSu+PkmSYuHzXPckA19hGEc047SVS3VUe8U66qXccrZ+VmOSKS3jZvWIU4hq933b+dkdX8pZkKqddWtzKx2T3PbhJTadm5SXpeR1T5BXsfK6kHLSq1dtqWaB6nWV6dxy9j+/I5rtpHVnt42zmIAQ9ICSdslPVPSQZJulXRC12cukvRXxfdzktYNm++0o8Tu1TXYaa+TqlpqDT0344xmj7v967Jt+q1HakcCGtYhTiKr3fdvH2R1f3XJhBjKzGr3emybQetAXtcrq32CvI6V1YOWRVbXz7hZ08S+NVntwR+jepqkbe5+tySZ2VpJ50m6o+Mz50l6R/H9xyW918ysWMkg2ncc7lTVY5QGLYdHOaVjz/Z5bV2xVktXzk11Z+pHH/i+DtCjevSB7w/97Ljbv1c7zlG/x01511dUKomslvZv52R1b6EyK0ch1r3MrJbqkdeDHg1IXkfT+KwetKwUs7rJqs5qqZl9a7Jawc/AeK2k93e8/gVJ7+36zG2Sjul4vV3SkYPmG+LGcOgt1dHrsoVa79RGOlOUy6mfasgRPSers9TUrHYPs+5k9XA5XVbVlLwuK6udvC5VU/OarK4GWR3+DIxgzGy5pOWSdOyxx0YuTX01dfQ61Hqf9J4LdcNhh+qkhtXfOPqNdtdhFBxkdVWamtVSmHUnq4cblMnkdT2Q19Voal6T1dUgqyVrDY4EmpnZmZLe4e7nFK/fLknu/scdn7m6+MwXzWyhpG9IOsoHFGRmZsY3b94crJwA0M3Mtrj7TOxyVIGsBpCzpuR1WVktkdcAyldWVh8QeH5fknS8mR1nZgepdTOhK7s+c6WkC4rvXyvp2mEhCwAIiqwGgPSR1QDQJeglJO7+sJm9SdLVat05+QPufruZvVOta2CulHS5pL81s22S5tUKYwBARchqAEgfWQ0A+wt+Dwx3v0rSVV3v/a+O7x+U9HOhlwsAGB1ZDQDpI6sBYF+hLyEBAAAAAAAIjgEMAAAAAACQPAYwAAAAAABA8hjAAAAAAAAAyWMAAwAAAAAAJM9yeFS0me2S9LUxfuVISd8uqTgxsD7pqtO6SM1en2e4+1FlFqbuJshqqV5trk7rIrE+KavTukjjrw95PSX61rVanzqti8T6pCyJrM5iAGNcZrbZ3WdilyMU1idddVoXifVB9eq0jeq0LhLrk7I6rYtUv/Wpo7ptozqtT53WRWJ9UpbKunAJCQAAAAAASB4DGAAAAAAAIHl1HcBYE7sAgbE+6arTukisD6pXp21Up3WRWJ+U1WldpPqtTx3VbRvVaX3qtC4S65OyJNallvfAAAAAAAAA9VLXMzAAAAAAAECNMIABAAAAAACSl/UAhpmda2Z3mdk2M7ukx88PNrN1xc83mdniCMUc2Qjrc7GZ3WFmW83sGjN7RoxyjmLYunR87mfNzM0s+iN5Bhllfczs54vtc7uZ/V3VZRzHCG3tWDNbb2ZfLtrbshjlHIWZfcDMvmVmt/X5uZnZe4p13Wpmp1RdxqYjq9PNaqleeU1Wk9WYTp3ymqxON6uleuV1nbJayiCv3T3LSdICSdslPVPSQZJulXRC12cukvRXxfdzktbFLveU6/NSST9WfP/GVNdnlHUpPneYpOsl3ShpJna5p9w2x0v6sqTDi9dPiV3uKddnjaQ3Ft+fIGlH7HIPWJ8XSTpF0m19fr5M0mckmaQzJG2KXeYmTWR1ulk96voUn0s+r8lqsppp6m1Um7wmq9PN6jG2TxZ5XbesLsqYdF7nfAbGaZK2ufvd7v6QpLWSzuv6zHmSPlh8/3FJLzMzq7CM4xi6Pu6+3t2/X7y8UdIxFZdxVKNsG0n6A0l/KunBKgs3gVHW539KWu3ueyTJ3b9VcRnHMcr6uKQnFN8/UdK/V1i+sbj79ZLmB3zkPEkf8pYbJT3JzJ5eTekgsjrlrJbqlddkNVmN6dQpr8nqtNUpr2uV1VL6eZ3zAMbRku7teL2zeK/nZ9z9YUnflfTkSko3vlHWp9OFao18pWjouhSnGi1y93+ssmATGmXb/ISknzCzjWZ2o5mdW1npxjfK+rxD0uvMbKekqyT9ajVFK8W4+xbCIqvTzWqpXnlNVpPVmE6d8pqsTlud8rppWS1FzuuFVS0I4ZjZ6yTNSHpx7LJMwswOkHSppNdHLkpIC9U61e0lao3gX29mz3X378Qs1BTOl3SFu/+5mZ0p6W/N7Dnu/mjsggG5yD2rpVrmNVkNYB9kdbLqlNdkdUA5n4Fxn6RFHa+PKd7r+RkzW6jWKTu7Kynd+EZZH5nZyyWtkPQqd/9hRWUb17B1OUzScyRtMLMdal07dWXCNxsaZdvslHSlu//I3e+R9K9qhW6KRlmfCyV9TJLc/YuSDpF0ZCWlC2+kfQulIavTzWqpXnlNVpPVmE6d8pqsTjerpXrlddOyWoqc1zkPYHxJ0vFmdpyZHaTWjYSu7PrMlZIuKL5/raRrvbjzSIKGro+Z/ZSkv1YrZFO9Dkwasi7u/l13P9LdF7v7YrWuO3yVu2+OU9yhRmlrn1JrhFhmdqRap73dXWEZxzHK+vybpJdJkpn9pFpBu6vSUoZzpaRfLO6YfIak77r712MXqkHI6rTVKa/JarIa06lTXpPV6Wa1VK+8blpWS7Hzepw7fqY2qXUH1H9V686vK4r33qnWDiu1GsffS9om6SZJz4xd5inX5/OSvinplmK6MnaZJ12Xrs9uUMJ3Sh5x25hap+7dIekrkuZil3nK9TlB0ka17qR8i6SzY5d5wLp8VNLXJf1IrdH6CyW9QdIbOrbN6mJdv5J6W6vjRFanm9WjrE/XZ5POa7KarGaaejvVJq/J6rT3oTrldZ2yuihv0nltRSEAAAAAAACSlfMlJAAAAAAAoCEYwAAAAAAAAMljAAMAAAAAACSPAQwAAAAAAJA8BjAAAAAAAEDyGMAAAAAAAADJYwADAAAAAAAkjwEMAAAAAACQPAYwAAAAAABA8hjAAAAAAAAAyWMAAwAAAAAAJI8BDAAAAAAAkDwGMAAAAAAAQPIYwAAAAAAAAMljAAMAAAAAACSPAQwAAAAAAJA8BjAAAAAAAEDyGMAAAAAAAADJYwADAAAAAAAkjwEMAAAAAACQPAYwAAAAAABA8hjAAAAAAAAAyWMAAwAAAEiQmX3AzL5lZrf1+bmZ2XvMbJuZbTWzU6ouIwBUiQEMAAAAIE1XSDp3wM9fIen4Ylou6X0VlAkAomEAAwAAAEiQu18vaX7AR86T9CFvuVHSk8zs6dWUDgCqtzB2AUZx5JFH+uLFi2MXA0CNbdmy5dvuflTscuSMrAZQBfJ6H0dLurfj9c7iva93f9DMlqt1loYOPfTQU5/97GdXUkAAzVRWVmcxgLF48WJt3rw5djEA1JiZfS12GXJHVgOoAnk9GXdfI2mNJM3MzDh5DaBMZWU1l5AAAAAAebpP0qKO18cU7wFALTGAAQAAAOTpSkm/WDyN5AxJ33X3/S4fAYC6yOISEgAAAKBpzOyjkl4i6Ugz2ynp9yQdKEnu/leSrpK0TNI2Sd+X9EtxSgoA1WAAAwAAAEiQu58/5Ocu6VcqKg4ARMclJAAAAAAAIHkMYAAAAAAAgOQFHcAwsw+Y2bfM7LY+Pzcze4+ZbTOzrWZ2SsjlAwCGI6sBAACQo9BnYFwh6dwBP3+FpOOLabmk9wVePgBguCtEVgMAACAzQQcw3P16SfMDPnKepA95y42SnmRmTw9ZBoxvz/Z5XTd3mfZsH7Tp4sqhjGA75YKszlMu+1cu5WwythEAIFdV3wPjaEn3drzeWby3HzNbbmabzWzzrl27KilcU21dsVanr7tYW1esLXU503SYepWRDlh6qmpLKB1ZnaAcsloir3NAVgMAcpXsTTzdfY27z7j7zFFHHRW7OEPl3DlbunJOm2Yv1dKVc/u8H3qdpukwdZdxz/Z53fnSi3QGHbCk9GtLZct5/8sdWV2dQftXyPWa9p/bznK2y3Xrmy/nH+aEkNUAgGy5e9BJ0mJJt/X52V9LOr/j9V2Snj5snqeeeqqnYn7bbt8wu9rnt+3e5/0Ns6v9BzrYN8yujlSy8PqtU7866Pf+qD8fv2wH+cZFs0HmVxch6zgnIfY/SZs9cB6mPNU9q9177w91zGr38fK6+qw+2K9dtqqR2TRIE/M61P7XtLwuY0otrwHUT1lZHX6GgzvFr5T0GUkm6QxJN40yz5RCdtx/6nM27mBNlf8Y1LG+Q6jrP2fDhGgPTesQ1z2r3XvvD3XNjnHymqxOQxPzOlR7aFpelzGlltcA6qesrLbWvMMws49KeomkIyV9U9LvSTqwONPjr8zMJL1Xrbvff1/SL7n75mHznZmZ8c2bh36sEnu2z2vrirVaunJOhy85orbLnKQ8qZWziXLeBrHLbmZb3H2m8gVH0ISslsjrfuVJrYxNlfN2iF32JuV1WVLLawD1U1ZWBx3AKEvTQ/a6uct0+rqLtWn2Ur147UWxi9MIsTtnTRS7ndMhnl7Ts1qK346bhqyOI3Y7J6+nR14DKFtZWZ3sTTybZtCNrWLdbKuJQt1wLsaNynK/Odok7Tz3dUaeyOs0hLiZM1k9GfIaABALAxiJGHTX98OXHKEXr70ouaNLdeyMtLeDS1P9ExLjEXW5PxZvknae+zojT7nldR2zWmpth1Pu/aS2LHo1WV0x8hoAEMvC2AVAy9KVc9pUfJ1WVafUtjsjm6TanCrd3g4nT1B3nfUecnuOumy//wF9cdkf6OQGHfmtup4BKVy7I6un07kdxqk/sjoO8hoAEEQZdwYNPXGn5PFUdWfzut1dftr1iXlH+SbezT40cVd7srpiZPVkyGqQ1+Q1gPSVldWcgVFDVR3laJ9C2pb7zdSmPUoZ8+gSR7aA/MTKainvvCarAQBortreA6Ou1/yOItY12Llf3zrtzfdiXvvea9ll7QMpzLfJ+3cdNXV7xsyMnPO6blktlbMPkNUAgDqq7QBG6M4Zf4T7a9fN4uXnZH33/RRvvjeNsv5BSWG+Of/zhf2F3J5kdX+ddZPz01LqltVSOZlGVgMA6qi2l5CEPk2zrjdBC2Fv3cR5Hjx6K+tU5RTmy2nY9RJye5LV/XXXDfWTjjIyjawGANSRte6vkbaZmRnfvHlz1DLkfL1wKP3qYNz3UW+DtnvKbcLMtrj7TOxy5IysTkevesh130R5cv37TV5PL4W8BlBvZWV1bS8hCW3YKatNOG2536mg/eqGU0ebadB2H9YmmrAfoVyjXF7QhHbWa18bVDfkdTP12+6jtIcm7EcAgPQwgBFIjp2/cTsf414znfM11k00aWe0+/cGbfdhbSLH/Qj5ya2dTbJvktf1Nkmb6PU7/bb7KO0ht/0IAFATZTybNfSUw7Oqp30ufQwpP48+x/rMVbuu1y9bNXZ7mN+22zcumvUf6KCevzfudoy53VXSs6qbNOWQ1e755QtZjbZJ8zp0Vk/6O6GQ183JawD5KiurOQMjkBzvip7yETeO7FSnXdcujd0etq5Yq1Pv/ZRuXvSanr837nbMcT9CfnJrZ2Q12ibN69BZLeW3HwEA6qG2TyHBcO3OR4q4c3l12nV98og3++v+3RuLr70+V/Z2TP1Gc0AIZDXaJs1rshoAUBecgZGxOt9AK4UjO3Wu30696nrUo3HDtlO/n4eqW47+Igd1zhKyulqT5jVZDQCoi1oPYJTVqUmls0SHoFyp1e+o7S5E+yz7lPVQdZvyqfUYHVmNaaRWv1VmtVRuDpLVAIDklHFjjdDTpDcaKuvGZ6ncUK2MG2iFnmfON3hLreyjtrtU2ucgqdWte3k3GmrSRFb3RlaXK7Wyk9XlI6/j5TUAjKqsrK71PTDKuqYzlWt+y7guun20ZZMUZN6h51el1K47H7XdpdI+B0mtbhEXWT0+snqv1PKErAYAoDy1HsAo6w9vCn/Qy7ohVugOVQ4dtLpJoX0C46hzVkvl5DVZna7DlxyhpSvnhm7zVNonAAA5qfU9MOqsrGt+Q9+QrbODlsK16DkbZ5v3urY69v0AQi4/9roA4ygjr8nqtOWc12Q1ACBltT4Do85yO1qW8+nJqRhnm/eq79jbIOTyY68LMI6c8pp9K4yc85qsBgCkjAGMDOX4PPWcOvCpGud04171Pck2CNnWQrYB2hNy0Ln/5PLPG/tWGDnnNVkNAEiZtW4QmraZmRnfvHlz7GIk47q5y1pHNGYvzaZTjDw1qa2Z2RZ3n4ldjpyR1ftq0v6D+JrU3sjr6ZHXAMpWVlZzBkaGOKKBqkzb1nI8WwgIhaxGlaZpb2Q1ACAX3MQzQ6Fv3lZ33ERsctO2tbJuNgvkgKweD1k9nWnaG1kNAMgFAxioPTpm8SxdOadNs5eOfR03/8QAzUNWx0NWAwBywQAGaq9fx6yqzlcdOnmTrsMkRwT5JwZoJrJ6emQ1AKDuuAcGaq/f3eCrerxbHR4jV+U6cN8AoJnI6umR1QCAuuMMjA5lHX352rXbdcOxc/ratduDzjeEMtZ51HnGPto1ySmzKS8npO5tU+U6cN8AjKKs7Fr/yndpwyvfldxReLKarO6FrAYANI67Jz+deuqpXoUNs6v9BzrYN8yuHunz89t2+4bZ1T6/bffAz21cNOuPSr5x0WyIYgY17jqHnGcZy26qUdviqJq4bSRt9gTyLuepqqx2LyevN8yu9oe00B/SwuTaPlldD2R1GE3Ka0nnSrpL0jZJl/T4+bGS1kv6sqStkpaNMt8q8xpAM5WV1VxC0mHc0yFHPVXz6CtW6ouvb32t2rBHo5VxCuio8+T003BCnzbMtkHqysjrpSvn9IX7H5BJOilC2x+U12R1PZDVGIeZLZC0WtJ/lrRT0pfM7Ep3v6PjY78j6WPu/j4zO0HSVZIWV15YAKhKGaMioadUR4lDH0kpQ1OPzpSl6m0+6vJyaIvdUiuzGnREr6wp1ax2T6+99UJeh0NWh5NimZuS15LOlHR1x+u3S3p712f+WtJvdXz+hlHmnXJeA6iHsrKaMzCm0O+GYynh6ExYVd/kbdTl5dAWu9XhhnnIRw77CHkdDlkdDlkd1dGS7u14vVPS6V2feYekfzKzX5V0qKSX95uZmS2XtFySjj322KAFBYCqMIDRZdglF7nJsbOUsqr/wajzPzR1XjeUr25ZLZHXIZHV4dR53WrifElXuPufm9mZkv7WzJ7j7o92f9Dd10haI0kzMzNecTkBIAieQtKlyueax76z+yRyLHNIVd91vdfy6rINuIM9plFlVkv57Xe5lTc0sjocsjqq+yQt6nh9TPFepwslfUyS3P2Lkg6RdGQlpQOACIIPYJjZuWZ2l5ltM7NLevz8WDNbb2ZfNrOtZrYsdBmmUeUjyDo74Ll0dKr6pyFUfXTPp8x6rmob3vrmy/X8dW/RrW++fOJ55NLeUB6yejy55XWOg/F1y+utK9bqjHUX686XXjTVcnJobyjNlyQdb2bHmdlBkuYkXdn1mX+T9DJJMrOfVGsAY1elpQSAKoW8oYakBZK2S3qmpIMk3SrphK7PrJH0xuL7EyTtGDbfaW40FPPmU8OW3fnzXG7eVlV9hqqP7vmUWc+h5j2sjq9dtsof0kK/dtmqiZeRS3urkhpyUzgnqydafm55XWV9kte963l+227fuGjWf6CDplpODu2tag3L62WS/rXI7BXFe++U9Crfm88bixy/RdLZo8yXm3gCKFtZWR06ZEu5W/I0IRvzD3/nssfpHCNcfXTPp8x6DjXvYW02xHLGnUevz9etzTasQ0xW91n++mWrhrbrurX9aZHX5HXVmpTXZU0MYAAoWy4DGK+V9P6O178g6b1dn3m6pK+odSflPZJOHTbfXI/q5XbEDmlIsaPZq/1W3abLrpcmdYjJ6v7Lv3bZKrIaI4vdbnuJnddV1EmT8rqsiQEMAGWr0wDGxZJ+vfj+TEl3SDqgx7yWS9osafOxxx4buj57yuFoD8Io64hh7vqtTwpH9MrugDepQ0xWx5k3xkdW9zbs0pWYeV3FYEmT8rqsiQEMAGUrK6tD38Qz2N2S3X2Nu8+4+8xRRx0VuJi9lXnTM+7inZZQ27rqJyGUbZz1qbpND7tpIze6GwtZ3QdZnRayurd+69Pv8cJVtutRbrBLXgMAJhZyNETSQkl3SzpOe28Md2LXZz4j6fXF9z8p6d8l2aD5VjVKXLcjNKlL5fKeFOYT2qTl6vd7OVwCNW0Z1aAjemQ1xkFWl2uSsuWc1e7kdQoTZ2AAKFtZWV1Gxzj43ZJDhGzKnZemGtSBmd+2269dtsrXL1vFNptA6E5sDvvPtGVsWoeYrMaoyOpyhczrXPYf8jr+xAAGgLKVldULpz+HY1/ufpWkq7re+18d398h6QWhlztM+3TLTZJevPaiqhePHpaunNOm4mu3rSvW6oVX/bYk6YbDDmWbjWlQ3U6iffpxynIoY0rIaoyKrC5XyLzOJQdzKScAID3BBzBSFfofuhT0u9Y1F4M6MEtXzukL9z8gk3RSjbbZNMbZ3nQOkas6ZrWUd16T1eMZd1uT1wAAjK4xAxh17CDU+Ujl4UuO0Ev/8W2xi5GUOm9voK2OWS3Vd/8lq/dX120NAEAKQj+FBBUa5U7fnULd9TuHu4fnUEZpvHKOu70BpCNGXtcxB2MhqwEASAMDGBkb97FoTXoc3bRlrKpDnepjS4etfw7/cAApiZHXOWS1lEdek9UAAKSBAYwGCXVUKIejS9OWsVdntYyOYKp1OayzPkpnvld90ZkGRhMiG1LNl2455HWqdUlWAwAap4xHm4SeeNQTqtD5WLdej3gL/WjSlA17xN0oj8DrVV8p16F4LB9ZjSx050+T87qJWe1OXoeYyGsAZSsrqxtzE09gmO4br3XffK2uT0foZdiNFEe50WKv+gpRhzk/zQHA9LqzulceNSWvU85qibwGAITHJSQ1MukpnzmfKhqy7MNOEa7yuuY66FVfIeowl+v6gX6amNVSuPKPcjkHeT26srJaIq8BAOE1cgAj905gP5N2FHLuYNz65sv1/HVv0a1vvnzqedHhzUOq16IjPLI6zO+lYM/2ed350ot0RoDyk9X5IK8BAKE1cgCjuxNYl07ypB2FVDoYk2wH7/qK8sXeX/jnpTnI6jC/V4Zxt8XWFWt1yr2f1JZFr06i/E2Qwv5CXgMAQmvkPTC6r+3svp62aqGuER3lWteQvxfaJNvh5PdcqBsOO1Qn0yGuTOz9Bc2RWlZLYfI696yWxt8WnduSf2arkcL+AgBAaI08A6P7iEDso1o5nxYc0iTbYZSjO0293nyQadYt9v6C5kgtqyXyum3cbUFWT27S9UthfwEAILRGDGAM++Pfq2NVZYcolU5G7E5gWaeajvsPR7sebn3z5bX9R2Waf8JSOyU4drtFWIO2Z+ysltLI6xTafBk5QFb3Nmlek9UAgDpqxADGJH/8h/1OyD/EqXQy6npkcdx/ONr14NJYvxeiTQyaR5VPXBkmpY5oXdttU427PavMaimNvK5rm69LVodaRltd8rqu7RYAUDF3T3469dRTfRrz23b7htnVPr9t937v7bhm234/6/c7nTbMrvYf6GDfMLt6qrKlZNg6N8Wk9RCiTQyaR0ptLqWyhGq3kjZ7AnmX8zRtVrvvvz07Xw/KcrK6eVLN6lDLCCWVsoRst+R1GnkNAIOUldXRA3SUqYyQbf9B37hodqI/7HQg0W1YmxilzQz6Zy2lNpdSWUKhQ5x2Vm+YXT3RP2J1bKuYTtlZPeo8qpJSWUIhr9PMawDoxABGYMPOwJh0fnXqICCscf/5qvKoGe23vJBt0lRmVvf7R3HaeQLdUs5qd9qvO3kdYmIAA0DZysrqRj5GVdr3cXTPOGv6x4vV8XFloR7vWmfj1FH3IyGHGffzk2iX3+9/QGdc9bu1ar+oh+5Hh4Zon3XLa7J6uLpk9dKVc7VrvwAAjKMRN/GsQgp3pu9lmpt31eGGW53rX8aNzMapo3Fv/lfFzQInvQlebKnclA55qltek9XD1SWr24MYKbbfXshqAEBojT0DI7Tuo4STCn0kbZojNVUcVSpb5/pLCn7UKvc6apf/5MyO3HIEEtMIkddlnPUwabvOPYcksnqYzvKH6m9UgawGAITGAEYfsU7JDf3HfppOW06dpH661z9kB7YOp23nuo1z/2cE4dQlq6XJ23Wu+3EnsnqwXLcxWQ0ACK6MG2uEnmLcaCjWY8dyuzlXbuUNKZVH042qydtqFOKmcGT1GHLbn3Irb0hkdf2Q13nmNYBmKSurOQOjj1hHDXI7ypLC6aGxjq7ldmQphW0FhEZWjyaV/T9GXpPVAADUBwMYfeTWOY0lhY5hrM5ebm0khW3VqQ6ndSO+3PbDWFLZ/2PkdW5tJJVt1Ym8BgCkgqeQBDbtHbdzu2N3FXdfHyanO7LHlMK26lSHJycgX2R1HOT1cKlsq07kNQAgFQxgKGxHdNo/8nQSxpdiZw/D8Y8MxkVW54+8zhN5DQBIBZeQKOwprdOe+pniqaN1tmf7vG598+VySSe/50I61RUa5bRuTltGJ7K6ucjquMhrAEAqOANDYY8sTHt0adDv53bKcg62rlirF1z123rhVb/d2COpKbcrjnKjUy5ZLaW9X+WIrG5JuV2R1wCAKjCAoXxOaQ3dORjUEUq5kxTS0pVz2rjsj/SFZX/02D9FTVn3tnHbVej6GTQ/TltGp1yyWgqb12R176yWmrP+beO0qyqzWiKvAQAVKePZrKEnnlXdEvrZ8BtmV/sPdLBvmF091s/qLvS6h95uoY1bvtD1k0pbU0nPqm7SRFbvFXK/J6v7C7n+qWe1+3hlrGtWu5PXISbyGkDZysrq6AE6ykTIlmNQRyiHjty4Rl2nMgeKqq7XMpYXep6jzK+KeqNDTFaniqwO89lhuv9Br7Ju65LVZSy3F/KavAaQPgYwaqSOHc4cxDp61Lm9qy7DhtnV/qAO9o2LZrNub1XUGx1isroX8rp6KWR11eVoL2v9slXZtzfyOo+pjnkNIC1lZTVPIYkg5J30MbpYTw3ovHt7vzKUdff2pSvntOWG63XKvZ/UphUvyra98cQHxEJeVy+FrB5UjjLyur0sv/8BnZF5eyOvAQBlstbgSNpmZmZ88+bNsYsRDI8aK19udXzd3GWtf5JmLw3eac2tLmIxsy3uPhO7HDmrW1ZL7D9ly7F+yev4yOvp1TGvAaSlrKzmKSQR5HQn/SqFvGN6bo9zK/Pu7bQ3YHLsP72Fyuvcsloir1EtMzvXzO4ys21mdkmfz/y8md1hZreb2d9VXUYAqBIDGEhGyI5sbo9za3Kntd8/Qk17PCKQk1B5nVtWS+Q1eV0dM1sgabWkV0g6QdL5ZnZC12eOl/R2SS9w9xMlvbXqcgJAlYIPYDBSjEmF7MjG6mDWoRNX9Tr0+0coxyOzOSGrMY1QeU1WTy7GOpDXlTtN0jZ3v9vdH5K0VtJ5XZ/5n5JWu/seSXL3b1VcRgCoVNCbeHaMFP9nSTslfcnMrnT3Ozo+0zlSvMfMnhKyDMhX9w3UclTGDf+qvia66psW9rvhGzeCKw9ZjWnlntdk9WTI68odLenejtc7JZ3e9ZmfkCQz2yhpgaR3uPtne83MzJZLWi5Jxx57bPDCAkAVQp+BwUhxptpHcr527fbsj0rFVMbp0GUf2eo+ilf1Kd39jsA2+TTtCpDVmercX+twFkEsOWa1tO/2j3H5DXmdpIWSjpf0EknnS/o/ZvakXh909zXuPuPuM0cddVR1JQSAgEI/RjXoSDGq0+543XzDq3X6vZ/K+hFuMe/iXsZRybKPbHUfxcv9yCpGQlZnqnN/lZT1I17J6vF153WO2x1juU/Soo7XxxTvddopaZO7/0jSPWb2r2oNaHypmiICQLVCD2CMusz2SPExkq43s+e6+3c6P1TGaW48nqy/dsdr8fJztGnNi7R05Vy29RXjtNoylT2gwKm/6IOsTlD3/tr+Psc6I6vHR143zpckHW9mx6k1cDEn6b92feZTap158TdmdqRag893V1lIAKhS6EtIRh0pvtLdf+Tu90hqjxTvo4zT3Kq8yVRup/a2O17POGvJY0fhJ6mvGOvd7xKIxcvPyWobxMKpv41EVhdyzerDlxyxz/c55PWgy9Vy2w6xkNfN4u4PS3qTpKsl3SnpY+5+u5m908xeVXzsakm7zewOSeslvc3dd8cpMQBUwN2DTWodsbtb0nGSDpJ0q6QTuz5zrqQPFt8fqdZpzE8eNN9TTz3VQ5jftts3zK72+W27g8xvkA2zq/0HOtg3zK4ufVllmaS+Yqx3v2XWYRvkIuS+VeV+2knSZg+YhylPZPVedcmJHPJ60PLqsh1SV4esdm9WXpc1hcprAOinrKwuo2O8TK0jddslrSjee6ekVxXfm6RLJd0h6SuS5obNM4eQ7f5DHvMPe0wx1rvfMpu6DWII+c9HrH9kmtYhJqubndXu1a/7oOU1eTtUqQ5Z7d68vC5jyiGvAeQtmwGMMqYcQpajR9Mb1oGlgzu+quqsDkf16BCT1RgNWR0eWT0e8roZeQ0gb2VldYybeNYSN9aa3rAbutXthm9VqKrOQt68jqegoExk9fTI6vDIagAARsMARiD8IZ/esH8smvaPR4inCjStzoBhyOrpkdX7IqsBAKiOtc7uSNvMzIxv3rw5djGASl03d1nriNzspbX4hyv1xzya2RZ3n4ldjpyR1Wgisrp65PX0yGsAZSsrq0M/RhVIRu6P5et8xGAdtE6R/jXd+dKLst0mAMIjq9PSvpzlljdfnvV2AQDUEwMYNZd7x3Aa7U7Y1hVrYxflMeNsj/ap7qkeARvX0pVzunnRa3TqvZ9KapsAKSCryepUtAdkTEpuuwAAwABGzaXYMSxTZ6dzmqNiZf0zkfr2KPOfqMOXHKGfXH+ZbqzRkUoglNSzoQztvFm8/ByyekxlZ/WL116kk95zYa3OLAEA1AM38ay5pt0YrPtO7pNej1zWHeFT3x63vvlyveCq39bG+x/QS/7xbcHnzw0Ugd5Sz4Yy7M3Zye8dQVaXk9USeQ0ASBMDGDXXtA5IqE5nWZ3X1LeHd30FUI3Us6EMIXKWrAYAoFkYwEBSpr37eahOZ+qd17Kc/J4LdcNhh+rkRI86AkhHCnlNVpPVAIBm4R4YSEoZ1x03+eZ446rbzegAlIe8joesBgA0FQMYSEoZj6NL/WZsOeKfDADkdfrIagBA3TCAgaSUcVRp8fJzdPOiV2vx8nOCzXOYunca+ScDQOi83rN9Xo/e/4BuXPYHld48s855TVYDAOqGAQxEVUXHcceaq3XKvZ/SjjVXl7aMbnXpNPbbPmUceQWQriqyeuuKtTrzqt+VHXZopZdG1DmvyWoAQN1wE09E1f0IvGlvCtdLjMfhpf4IvlH1e0RhU2+cBzRVrywIndexcrPOeU1WAwDqhgEMRNXdcez3D/M0HeUYHbi6dBrr0rEHMJ1eWRB6UCNWbpLXAADkg0tIEFX3NdSdp7t2ng5bl1N8qxTilO9+17jX+ZpxAPvrlQXtvF68/ByyekrkNQAAo2nUGRhlXJ6AsDqPhF03d9ljR/c4sjS+fmezpD5vgKzOQzuvyerpkdcAAIymUWdgdB8Z4qhEWKHrs/NsjKY+836aOi3z5m3cGA5l6nUUn7wOK2R9ktUt5DUAAOVr1ABG9x/xpp3qWvY/AKHrs8kd4bZp6rTM+mPboEy9/uFqUl5X9cSPUPVJHrSQ1wAAlK9Rl5B036iraae6jnMa6SSncNe9PmOc1l73OgV66XVTxSbtC+Oe8k9e74+8BgCgnhp1Bka3lI9KlHEEbpzTSCc5kpRyfYYwrE7K2Gah67S7jJyWj1yknC9lXj43CvJ6f4PqpKzcC1mnvcpIXgMA0PABjDJN29GY9vTeXssfp3PFNbP7G1YnOZzi3l3GHMoMlC1mXk+b1RJ53cugOskh93qVMYdyAwBQOndPfjr11FP///buP8bS6r7v+OcLK6hMqQM2VSK8eDHFlam7ttmRMUpl4jgtZCwBVdzOuHLqSLSr2HJTya0lHOTIAq0rLypRrQxKVrWVH1ILjqtaK5kIKbs7WFnClsE/iCHCmqXrghPF9g5FlgsmyN/+ce9lL5d77zw/znmec87zfkmPdu7OnXvPOc+5nznzPOc5j+dmc23DX9CFvrm2Uftnd7bP+onVw3589bDvbJ/t/P3RzM72Wd9c2/Cd7bOv+jr2e7X5udjl7Oo9QpC05QnkXc5bjlnt3jwvJ337zLHtxn2crO5ejlnd5rXavGeqyOvh5jWAfMTK6t4DtMqWY8ieObbtJ/eu+Zlj27V/NsSANoWBSApl6EvsP0py+qMnl7IyIB5mVrs3z+tSsjqlcnSNrD4np7KS18PNawD5iJXVg1rEs0tnjjyo6575ik4dea/e/Iv17rseYiGweYvgdW3I956PvZhbTovF5VRWDFPTvC4lq6Xh5jVZfU5OZQUADJeNDo6kbWVlxbe2tvouRi2LVkDvY2X0vgyprsifmT3m7it9lyNnOWa1ND+rhpZfQ6sv8kZet5drXgPIR6ysZhHPSBYtwlbaIlzLFr8rYZV7Vn0Hyjcvq0rLaom8BgAA+eMSko6VNkWz9GnHpdcPwHylZbVUfp6VXj8AAMAMjM6VcJZrWpPb9+V0lizn2xOm3M4plw2QystqqX6e5fY5zTWvU27nlMsGABgmDmCgsabXTOc0NTvnP2JSbueUywaUZvJHqKRaeZbb5zTXvE65nVMuGwBgmLiEpGCxF2VrOl13emo2C8fFk/IU+JTLBnSNrB62lPMw5bIBAIaJGRgZaDqFM/aZk6bTdafPkvV5dmdeu5Y0XTbls5Eplw1oiqyOZ7ZtyepupFw2AMAwcQAjA00HjrGvBw4xsOnzmuV57Tr5v2/9xhdeGRyXNFAeAvYX+kJWxzPbttOPJ5/57x4/zWc/M+Q1AKAuLiHpUNMpuE2ncE4GrSnrs4zz2nXyf/6jH+s94ynXkljZPiPciQAhNMlrsjqe2badfjz5zH/94Vt13TNf4bOfEfIaAFAXBzBaqjPIbfqLuu+BY6nmtevk/547vaNTF1/0ymA55DXAqVxLnko5QuOabcxTt783yWuyOp7Ztp1+PPnM7zt4o04deS9ZnRHyGgBQV5EHMLr8ZV9nkMsv6nzMDpZD/lGSyhmnVMoRGn9E5iPVrJbI65xMf+bf/ItkdU7IawBAXcHXwDCzm8zsKTPbNrPblzzvV8zMzWwldBm6XGysznXBda9D5trQMvV9Lflu5aDfDQNZvRx5DbIaAID0BJ2BYWbnS9qQ9E8lPSvpUTM76u5PzjzvYkn/XnpliYGgujxzFvPsQUlnXUqeAltXKmecFpWjpH6H+cjq8Er53JDV55DVAACkJ/QMjHdL2nb3p939JUn3SbplzvPukvQ5SS8Gfn9J1c6cPXd6R5sfuFsnPnB3smcvUjn7E0Lft+CLqbQV8Jv0O84EZoesDqyUvCar80FWD0MKs+UAICWh18C4XNIzU4+flXTd9BPM7FpJe939q2b2ycDvX9njd9ynn3/gNyVJD198UZJnL0Kd/UnhjFrJ15OXtgJ+k37HmcDskNWBlZLXZHU+yOrypTJbDgBS0ukinmZ2nqR7JP1ahecelHRQkq644orgZdl/aF0nf/RjuaR3FjhQm7ZowNLlQDmVqbgxhFgBv+8/Wtoq+Y+eISKr+9N3XpPVy5HV6Ngrs+Ukycwms+WenHneZLZcbwebAaAz7h5sk3S9pAenHn9K0qemHr9e0g8lnRlvL0r6K0kry173wIEDnpKd7bO+ubbhO9tn+y6Ku+9enkXf31zb8Bd0gZ/cu5ZMXXISsh+M9sWFvrm2EaBkaELSlgfMw5S3oWS1e1p5XaUs5HV4ZHV5hpLXkj4o6b9OPf5VSb8z85xrJf2P8deby3Jao4PNW5K2rrjiilb7AAB2EyurQ6+B8aikq83sSjO7QNK6pKOTb7r78+7+Rnff5+77JD0i6WZ33wpcjqhSu0Z4t/Isus58/6F1fX3vP9eBZ76STF1Ss+x64ZD9oJTr55GNQWS1lFZeVykLed3corwmq1Gqqdly/6HK8939iLuvuPvKZZddFrdwABBJ0EtI3P1lM/u4pAclnS/pi+7+hJndqdERmKPLXyENu00RDTEFM+Q01KblueSqS/W2E/fqkTuaTaUdgmXXC4ecilvytG2kZyhZLbX/nKaQ1RJ5XcWivCarkbHvSdo79fhN4/+buFjS2yVtmpkk/ayko2aW5QFnAKjCRrM70raysuJbW93l8EPr944GQWv3RBuodPEeaC/3651jKLVNzOwxd2f19hbIavSp1Gxqo9Q2GUpem9keSd+R9H6NDlw8KulfufsTC56/Kek/Vjl40XVeAxieWFkd+hKSInQxRXTyHvsO3sgtzRK27DaPQ70dXUpT8jFsZDWmLcrroWa1RF7nzt1fljSZLfeXkr40mS1nZjf3WzoA6AcHMOZY9kfrInUHSJP3OHPkwYWDiyEPuuZJrT1KHhgua2uuAUcqUsnqJq9bstTaouSslsjr0rn7A+7+Vne/yt0Pjf/vt+Zd6ufuv8ClIwBKxwGMQJoOkJYNLkofdNWVWnuUPDBc1tZN/misK7U/gFCOGFnd5nVLlFpblJzVUr95TVYDALoWdBHPEk1fPypp4bWkbRbS3H9ofe7rcr/2V0utPUpezK3vtl62eCowT59Z3eZ1S5RaW5Sc1VK/7U1WAwC6xgGMXUz/cpa08Bd1mwHSogFA6YOuumiP7vTd1qn9AYT09ZnVbV+3NLRFt/psb7IaANA1DmDsYvaXc4xf1AwAXi3kqumlrsDelb7ajz+AUBdZ3T2yOh1kNQBgKIpeAyPEtZnT14/Gupa0izUFqkrhetaQ1093eS12Cm0XWmrXsqNMZHV9KeRNrlktpdF+IZHVAIChKHoGRp/XZuZ6NimF61lDnuXs8oxpCm0XGmec0QWyur4U8ibXrJbSaL+QyGoAwFAUfQCji1/oiwa/uQ7IUxgEhZyS2uX01hTaLjSmB6MLQ83qZeXaTQp5k2tWS2m0X0hkNQBgKIq+hKSL6b6Lpm2Gvm1bnemui8q06DWm/z+lKdK5mdd2VfdbadOZgTqGmtXLyjXvdcjqcGbbj6wGACAT7p78duDAAU/VzvZZ31zb8J3ts1HfZ3Ntw1/Qhb65ttG4TMdXD/tL2uPHVw83fu2YumrLLlVt2z72QYnt3YakLU8g73LeyOr6n+V55drZPusn9675C7rgVa9DVsdDVueFvC47rwGUIVZW9x6gVbaYIZvKwGC3coQo54nVw/6SzveHf+7W1wyWu2qDZe+VyuA8pKpt20c/LKm9Q7QfA+K0s9o9jbzuIqs31zb8RV3oD//srX5i9fArr9V1/Re9X0nZMUFWdyNU+5HX6ec1AHAAI5JUBgZdlGNyVu/FHuu7rJ4p/HEyJCW1d4jPDwPitLPaPY287iqrN9c2/MTq4V7ru6iuJWVHDkpq71CfH/I6/bwGAA5gBDI7EEhlYNBVOfqub9/vH1JJdelLqDZkBkYaW8ysXvR/XUtlxloX+n7/UEqpR99CtCMzMNLZOIABIDYOYATS5uh/aoOg1MqTozZtmMLZ4JRVaduU2pABcTlZ7Z5WPqZUlpw1bceUciZV5PXwNg5gAIgtVlYXfReSeSYrzu87eOMrK4nvtqr45Pvf+o0vzF0tvi+LVq9HdW3acPbuBaxO/2pV2jb0HSBQjnlZLS3/nE1/L6V8TKksOWvajvNyhrx+NfIaAJCNGEdFQm8xjhJPn0nY7azC5PvHVw8ndRaNs3rthbykKKWzUynIrX+KM3rJZ/W8x4uem1L/S6ksOSOv48mtj5LXaeY1AEyLldW9B2iVLUbITv+y7mJV+ZhSL19OSrrEaDd1ypty3bimOp0tdlbPe7zsuSnKoYy5GEpe1y1rynUjr9PZOIABIDYOYGAhziSFk/LAr6kQt0JM+Q8FVrVPZyOrd0dehzOUvK7bZ8hrtiobeQ0gtlhZvae3a1cyNbm2ev+hdV1y1aV9F0fS+LrU8b9o55KrLtUN932s72JUUrUvTq5tPiW9qm51+k2bPrbo/UOh/2OeFLNaor+GlEte1+mL8/Kybp8hrwEARYtxVCT0ltJR4pLPnpV4NqtkVfti7P2a+yVYE+KMHlmdiVw+Uxip0xdj7tsqr51L3yKvy8prAGWKldWDuwtJWymuwh1qNXVWyo8r9Kr3Vfvi5Czlbmf+mpZvt35T9f2BkFLMailMDpDVcfWV1VK1vIyV1VXfHwCAPnEJSU0pTlkNNeWTqZ1xhZ6aG7ovNi0f/QYpSjGrpTA5wGcuLrIaAIB0MQOjAFXP7ux21ibVMy8hzoaFPqPWRKpnhCd2K9+iNky13wApqpIDuWa11D5ryerdkdUAgCHjAEYBqg5Kcp12HKLcKdQ99cHjbuVr2oYp/EECpKJKDqSQV021LXsKdSeryWoAQLq4hGRAcp0+GqLcbV9jehV5SUne3SC2pm0Ye1V7oDS5ZrXUvuwh6j7J630Hb9SZIw+S1RWR1QCAHNhogdC0rays+NbWVt/FGLRUb0nYRp06PbR+72hgt3aPJL3yNYO83eXSd8zsMXdf6bscOSOr+5fL562uJnn99b236tpnvkJWV5RT3yGv2yOvAcQWK6u5hGRKCdfuhjJblxSm9da12/6oU6d9B2/U1/feqn0Hb6x9fXTO/SJE2VOfjo08kdcjJWS1FCevf+bQJ8nqGshqAEAWYtybNfTW1b2q69yrPcbPp2S2LrncG37abvujTp3a7Nuc+0XOZa9Lke5VPaStq6x2J68nSshq9zTyOuc+kXPZmyCv88prAMMUK6t7D9AqW1ch23bgl+vAcZ7QdWn6em3KEbIOVV5r0XNy7hc5l70uBsT5ZLU7eT0Rox6l5zVZnT/yOq+8BjBMHMAIoM4v+C7/gB/CwGMIZ8RyKiteiwExWV3l9cjr8D/XtVzKicXI63TyGgAWiZXVg7oLSZ0VtkOvxr3s9Yaw8nfTVdFzWo2/allzWigN6EOqWR3j/VJUel6T1QAAZCzGUZHQW+ln9XI8o5djmSemy95HPWKe/et7v/T9/m2IM3pkdYXXy62P51beabNl77ousWdq9Llvcu4X7uR1iI0ZGABii5XVvQdolY2Qja/uYCaFKbhNB2DTZe+jHjEHjn3vl77fvw0GxGR1Doaa1fMexxb7j/w+900K/aIN8pq8BpA+DmAkIPczFsvUHcw0aYvQ7dd0ANb3DIxlZTpzbDvrhQn7fv82GBCT1TkYalbHKFdTO9tn/fjqYT+xerhVWZiB0Rx5XU5eAygXBzASkPsZi2V2ts/6idXDfrzlgGyZ0O2X+wBs2qRtTu5dK7aP1dX1/mVATFbnINTBzmXI6uU21zb8Je3xl7SnyD5WVx/7l7wuJ68BlCtWVp8Xek0NM7vJzJ4ys20zu33O9z9hZk+a2eNmdszM3hy6DLHsP7SuU2v3JL9AWROXXHWp7OKLdP0Dn9bjd9wX5T1Ct98lV12qG+772K6Lqz13ekcPrd+r507v1Hr9pj/XxKRtLv/9Q8n2sS7bQzq3WOJu/bHrcpWCrM7TJPfOHHmw0uejidyyuu3P1rX/0Lr+bPWzOrn62WT7WJftQVYDADoV8miIpPMlnZb0FkkXSPqWpGtmnvM+Sa8bf/1RSffv9rocJQ5v3hmTrs+idPV+pd8SsCupXn8eqlwa0Bk9sjofiz4HXeZ16lnd9mdL1GV7dJ3V7sPK61gbeQ0gtlhZHfo2qu+WtO3uT0uSmd0n6RZJT04dMDkx9fxHJH04cBlQwbxbAU7OkvVZhhhKvyVgV7puj6r9kf3UCFmdiUU52WVep57VbX+2RF22B1kNAOhS6EtILpf0zNTjZ8f/t8htkv5k3jfM7KCZbZnZ1g9+8IOARRzpYypjStMnm04RDlmHrqZ5V52+HOrnUhRiv6XaHqmWK3FkdaLvO4usjv+zqSk1r1MsEwAgP8HXwKjKzD4saUXS3fO+7+5H3H3F3Vcuu+yy4O9f9ZrN3N9zkaYDiZB1SGkwk8ofK7Gk1PeQlyFmdZ/vO4usfrXSs1pKp+8BAJCi0JeQfE/S3qnHbxr/36uY2S9JukPSDe7+k8BleI3nTu/o8Tvu0/5D668MwLqeyvjc6R35j36sP1+9S+/MePpkqVNAu5oiHcq8Pr1MqfsNjSWZ1dJr+3YffbeEvC71M196Vkvl7jsAAIIIuaCGRgdEnpZ0pc4tDPePZp7zLo0Wj7u66uu2XWgohcW9+ihDabeuiym3tkqhT5dGA1oULtWsdk+jb6e6YC3ya6sU+nOJBpbXN0l6StK2pNvnfP8TGq1f9LikY5LeXOV1WcQTQGyxsjroJSTu/rKkj0t6UNJfSvqSuz9hZnea2c3jp90t6e9K+mMz+6aZHQ1ZhnlSuKVeH2VgGmp1kzO9j99xXxZTk/vs00OYwl26VLNaGmZek9XVTS8YmUMOkdVow8zOl7Qh6ZclXSPpQ2Z2zczTviFpxd33S/qypMPdlhIAumWjgyNpW1lZ8a2trb6LkZ0mU1eH7KH1e3Xd/Z/QI6t3yS6+iHZb4MQH7tY/eeA39Wern9X7vvrJvosTjJk95u4rfZcjZ2R1M2R1fQ+t36v33P8JPbb3Vr3txL202xylZrU0nLw2s+slfcbdbxw//pQkuft/WvD8d0n6HXf/+d1em7wGEFusrO5tEU/MF/KMSUoLr+VgcqbMJc6GLmEz/zbF2UHkjKzu1/5D63ps76269pn/SVYvQFYXIdgdowCgFMUfwMjtFy9Tifsz+SPinZ+/7TVTfnPrRzG94/O36eG1/6J3fP62Vq9DX8e03D5j9N9+XXLVpXrbiXt1au23yeoFyOph2e2OUePnRL3tNQB0ofgDGLn94u3yetmhDPTq1nPe2dDc+lFTVdoq1NniFNY6QDpy+4yR1eGR1dWR1YNR945RN/uSO0Z55NteA0AXij+AEfIX73ePn9bDV6zru8dP1/7ZFAegsQd6qdQ5RD2HMoDrcvDPtHlMC/kZe+70jjY/cLdOfODu2vmTSm5N6+JzmUK9yerqyOrBeFTS1WZ2pZldIGld0qsWVB6ve/F7Gh28+H4PZQSAbsW4tUnoLZVbPZ3cu+Y/lfzk3rXaP1v1Vmpd3nIt1O3oFr1OjLo0KXNut92rImSdpl+rxLaqSgO6LV+sLZWs3lzb8Je0x1/Sntr5M8Ssdk8jr0vNnxj7r9S2qmpIeS1pVdJ3NLqt9R3j/7tTowMWkvSnkv5G0jfH29Eqr5tKXgMoV6ys7j2Yq2yphOyZY9t+cu+anzm2Xftnqw42chyULBr4xqhLl380pCxkO9CmI0MaEMfaUsnqne2zfmL1sB9fPVw7f4aY1e7kdUyh2oH2PIe8LievAZQrVlZzG1W01uUtALnd4EjIdqBNR4ZyW76YyOq0df1ZJ1tGQrUD7XkOed0eeQ0gNm6j2qEUrgXOSZfXx+Z4LW7o/hR6EFu3Tfl8IBX0xXq6zs/c8jpGVj+0fq8kBWmHJu3JZwQAUBoOYMwxlFXMh66rgV3o/tR3/+zq/Rl4Yzd9fxbQDbI67TKQ1QCALu3puwB9WXYWe/+hdZ0a/4uyTO/3ycDulEZnx2IJ3Z/67p9dvX9X+wfpW5TXfX8WENdkv//0Rz/W9Q98mqxOtAxkNQCgS4NdA+Oh9XtHv3DX7uEX7oBM7/fJQQyuJ05T19d7c011e7GuqSavh2my3x9ZvUt28UVkdaL6WJuDvG6PNTAAxBYrqwc7AyOFMyPo3vR+n1xPPCQ5LQI3xP2D+cjrYZrs93dkkFehkdUAAMw32DUwcltcLEcpXhc79P2ewjXZbaXYrxDX0D+3saX6mRryfi8hq6V0+xYAIF+DPYARAr+Yl0thABZzH9V97RT6y/5D6zq1do/2Hbyx97I0taxfpdDGSBN9Y7EUslqKt4/I6v4s6lsptDEAIFPunvx24MABT9Hm2oa/oAt9c22j76K8Ymf7rG+ubfjO9tm+ixK8LE1eL+Y+qvvaKfWXlMpS17J+0KZekrY8gbzLeUs1q93T7POp5HUKWe0ebx+R1f1Z1Bfa1ou8LjuvAZQhVlb3HqBVthghG2LA1sXgs+575D7YWaZJ3WLuo7qvncofK6mVJaQ29WJAXG5Wh3ydkK9fal43rVesfURWp6dtvcjrNPMaAKbFymruQpL4qvZ1y5nTwl91lVw39I9V7dsjq+uVs9RMK7VeSAd53R53IQEQW6ysHuwaGPsPreuR1bv00x/9OOlrMCfXwVZdfb/kRc/m1a3OdbRcc0sbID+lZrVUbl6T1WHQDgAAvNZgD2BcctWlsosv0vUPfLr3hcuW6XuAu2wAlcLgqs7ic6ksVNenlNqgbf9Jof8hPrK6ukWfiRQ+K2R1fSm1Q5s+lEL/AwCUY0/fBejT5B7zdc6Y5STENN7JAOqU9Jpp0cu+15U6+7D0/V1FSm3Qtv+k0P/QjZT6bQyhLrlY9JlI4bNCVteXUju06UMp9D8AQEFiLKwRektloaE6i05VfW7MBbrqLKS2qBzLytf0e4B7+z4Suo+JReHI6kCvWVeIrF72PbIabbXpJzH6GHldTl4DKFesrO49QKtsqYRsnUFm1efGXIW+zqChajmqvmapq+ujXAyIyepQr1kXWQ3UQ16Xk9cAyhUrqwd9CUldMabAxpwiOrkmu4qq5ag6FTSlqa+h9bnCPqv7A7sjq8lqqf+87Pv9AQAoUoyjIqG3lI4SD3267bz6D61N+jxjydnSeMQZPbK6IE0uJylN33nZ9/uXjLwuK68BlClWVhd/F5LQq1+ntCr4rC5W+p630n7KbRJDk9sllvDeQExDymopfl4vuitK6u0SUt952ff7AwBQouIvIQm9+nXK0237Wuk75TaJoc50777em6nLyM2Qsloir7vQZ1ZXfX+yGgCAeoqfgRH6DMiis1pNLDsD1+R7bera5mxgyDZBGEM6y4oy5JrVy76/7Oea1rftzA3yOi1kNQAA9RQ/A6PvMzDLLDsD1+R7berKfdrLMqSzrChDrlm97PvLfq5pfcnqspDVAADUU/wBjJTNG7hMppPuO3ijTmn+2bkYAx4GUWVJ+Y9BIDfLsnr/ofWF+UlWYzdkNQAA9dhogdC0rays+NbWVt/F6MRD6/eOzq6t3cOgBuiQmT3m7it9lyNnZDWALpDX7Q0prwH0I1ZWF78GRm5YtRyhdXF3GmBoyGqERlYDALA7LiFJDNNJERrXzAPhkdUIjawGAGB3g5iBUfWsBmc/UILZfjx9prjLPt70vfgcDht5jaHIPavb/iwAAE0M4gBG1duUVXkev6y7QTs3N9uPp2+buFsfD3nQoentAbmt4LCR13mhjZtrk9VSs7YPmdVtfxYAgEbcPfntwIED3sbO9lnfXNvwne2zrZ+3ubbhL+hC31zbaFUmLHd89bC/pD1+fPVw30WJomqfDP3au71v0/497+ea1jFm2ywjacsTyLuct7ZZ7U5e54asjvPasfp3yKxu+7NtkNdp5DUALBMrq3sP0Cpb3ZDta8CRo1Trc2I8KD5R0KB4uq2rDDz72DddHnRIre8xIO4+q93J6zpSrA9Z/dqf6UqXuZta3yOv+8lrAKgjmwMYkm6S9JSkbUm3z/n+hZLuH3//lKR9u71m3ZANfYahjrZnVLqW6hnKFNtqnjrlnG5rzh6nV7+hDYhTyGr31/YDsnqx1D4z7um21ayYWT37MyVKrX5Dy+sYGwcwAMSWxQEMSedLOi3pLZIukPQtSdfMPOdjkn53/PW6pPt3e90QMzC6+uW77H1SGwC4u585tu0n9675mWPbfRelU6EG3XXOPtZ9z1z+MNjNonqk1veGNCBOJavdX9s/yOr5drbP+vHVw35i9XD2mVBXiCyMmdWhyti3ZXUgr8vbOIABILZcDmBcL+nBqcefkvSpmec8KOn68dd7JP1Qki173S6vq475PikOcFIcqHchVL2P3fAZf1nn+bEbPhOoZOVZ1Nap9b0hDYjJarI6JyHqTlbvLqeDekPK61gbBzAAxBYrq/dUXu2zmsslPTP1+FlJ1y16jru/bGbPS3rDeHD8CjM7KOmgJF1xxRWtCzZZ3Tu2Ze/TVRnq2H9oXafG/w5JqHqfd9Hr9FOdp/Muel2YghVoUVsPte8lgqwmq7MRou5k9e6WtfOQ+x8AIC02OjgS6MXMPijpJnf/N+PHvyrpOnf/+NRzvj1+zrPjx6fHz/nhvNeUpJWVFd/a2gpWTiCU507v6PE77tP+Q+u65KpL+y4OWjCzx9x9pe9ydIGsxtCQ1WUZUl7HQl4DiC1WVoeegfE9SXunHr9p/H/znvOsme2R9HpJZwOXA+hEimdqgQrIagwKWQ0AQBnOC/x6j0q62syuNLMLNFr47ejMc45K+sj46w9KOu4hp4EAAHZDVgMAACA7QWdgjK+T/rhGi7+dL+mL7v6Emd2p0SIeRyV9QdIfmdm2pB2NBs4AgI6Q1QAAAMhR6EtI5O4PSHpg5v9+a+rrFyX9i9DvCwCojqwGAABAbkJfQgIAAAAAABAcBzAAAAAAAEDyOIABAAAAJMjMbjKzp8xs28xun/P9C83s/vH3T5nZvh6KCQCd4QAGAAAAkBgzO1/ShqRflnSNpA+Z2TUzT7tN0nPu/g8k/bakz3VbSgDoFgcwAAAAgPS8W9K2uz/t7i9Juk/SLTPPuUXSH4y//rKk95uZdVhGAOhU8LuQxPDYY4/90My+W+NH3ijph7HK0wPqk66S6iINuz5vjlmQIWiQ1VJZfa6kukjUJ2Ul1UWqX5+h5PXlkp6ZevyspOsWPWd8i+znJb1Bc9rTzA5KOjh++BMz+3bwEqejtM/IPKXXkfrl7x/GeNEsDmC4+2V1nm9mW+6+Eqs8XaM+6SqpLhL1QTt1s1oqax+VVBeJ+qSspLpI5dUnVe5+RNIRqfw2L71+Uvl1pH75M7OtGK/LJSQAAABAer4nae/U4zeN/2/uc8xsj6TXSzrbSekAoAccwAAAAADS86ikq83sSjO7QNK6pKMzzzkq6SPjrz8o6bi7e4dlBIBOZXEJSQNH+i5AYNQnXSXVRaI+6F5J+6ikukjUJ2Ul1UUqrz5BjNe0+LikByWdL+mL7v6Emd0pacvdj0r6gqQ/MrNtSTsaHeSoovQ2L71+Uvl1pH75i1JH4yAtAAAAAABIHZeQAAAAAACA5HEAAwAAAAAAJC/rAxhmdpOZPWVm22Z2+5zvX2hm94+/f8rM9vVQzMoq1OcTZvakmT1uZsfMLNn7oO9Wl6nn/YqZuZklfRuhKvUxs3853j9PmNl/67qMdVToa1eY2Qkz+8a4v632Uc4qzOyLZvb9Rfezt5HPj+v6uJld23UZh46sTjerpbLymqwmq3FOadk7T2l5PKukfF6ktNyeVVKOz9NLtrt7lptGixmdlvQWSRdI+paka2ae8zFJvzv+el3S/X2Xu2V93ifpdeOvP5pqfarUZfy8iyV9TdIjklb6LnfLfXO1pG9IumT8+O/3Xe6W9Tki6aPjr6+RdKbvci+pz3slXSvp2wu+vyrpTySZpPdIOtV3mYe0kdXpZnXV+oyfl3xek9VkNVvt/pNN9raoYzZ53KR+4+cln88t92E2ud2wftnk+II6dp7tOc/AeLekbXd/2t1fknSfpFtmnnOLpD8Yf/1lSe83M+uwjHXsWh93P+Hu/2/88BGN7geeoir7RpLukvQ5SS92WbgGqtTn30racPfnJMndv99xGeuoUh+X9PfGX79e0l91WL5a3P1rGq28vsgtkv7QRx6R9DNm9nPdlA4iq1POaqmsvCaryWqcU1r2zlNaHs8qKZ8XKS23ZxWV4/P0ke05H8C4XNIzU4+fHf/f3Oe4+8uSnpf0hk5KV1+V+ky7TaOjWSnatS7j6UN73f2rXRasoSr75q2S3mpmJ83sETO7qbPS1VelPp+R9GEze1bSA5L+XTdFi6LuZwthkdXpZrVUVl6T1WQ1zikte+cpLY9nlZTPi5SW27OGluPzBM/2Pa2Kg16Y2YclrUi6oe+yNGFm50m6R9Kv9VyUkPZoNMXtFzQ6uv81M/vH7v5/+yxUCx+S9Pvu/p/N7HqN7jH/dnf/ad8FA3KRe1ZLReY1WQ0MUAl5PKvAfF6ktNyeRY7XlPMMjO9J2jv1+E3j/5v7HDPbo9G0nLOdlK6+KvWRmf2SpDsk3ezuP+mobHXtVpeLJb1d0qaZndHoeqijCS88VGXfPCvpqLv/rbv/b0nf0ShsU1SlPrdJ+pIkufufS/o7kt7YSenCq/TZQjRkdbpZLZWV12Q1WY1zSsveeUrL41kl5fMipeX2rKHl+DzBsz3nAxiPSrrazK40sws0Wnzo6Mxzjkr6yPjrD0o67uPVRBK0a33M7F2Sfk+jAE75+q+ldXH35939je6+z933aXRN4s3uvtVPcXdVpa99RaMjwzKzN2o03e3pDstYR5X6/B9J75ckM3ubRmH6g05LGc5RSf96vAryeyQ97+5/3XehBoSsTltJeU1Wk9U4p7Tsnae0PJ5VUj4vUlpuzxpajs8TPtvrrPiZ2qbRqqbf0Wh11zvG/3enRh9eadQB/ljStqT/JektfZe5ZX3+VNLfSPrmeDvad5mb1mXmuZtKfNXkCvvGNJrG96Skv5C03neZW9bnGkknNVot+ZuS/lnfZV5Sl/8u6a8l/a1GR+lvk/Trkn59at9sjOv6F6n3tRI3sjrdrK5Sn5nnJp3XZDVZzVar/2SVvQ3rmFUe163fzHOTzucW+zCr3G5Qv2xyfEH9Os92G78wAAAAAABAsnK+hAQAAAAAAAwEBzAAAAAAAEDyOIABAAAAAACSxwEMAAAAAACQPA5gAAAAAACA5HEAAwAAAAAAJI8DGAAAAAAAIHn/H+22SDqyobS1AAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 1080x864 with 9 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Set up viz\n",
    "fig, [[ax1,ax2,ax3], [ax4, ax5, ax6], [ax7, ax8, ax9]] = plt.subplots(3, 3,figsize=(15,12))\n",
    "\n",
    "line, = ax1.plot([0,1],[0,1])\n",
    "x, y = np.random.random((2, 500))\n",
    "scat1 = ax2.scatter(x,y,label='True p/q',alpha=0.9,s=1.,c='b')\n",
    "scat2 = ax2.scatter(x,y,label='CoB p/q',alpha=0.9,s=1.,c='r')\n",
    "test_line, = ax3.plot([0,1],[0,1])\n",
    "\n",
    "ax1.set_xlabel(\"Iteration\")\n",
    "ax1.set_ylabel(\"Train Loss\")\n",
    "ax1.set_xlim([0,NUM_EPOCHS*NUM_SAMPLES//BS])\n",
    "ax1.set_ylim([0,10])\n",
    "\n",
    "ax2.set_xlabel(\"Samples\")\n",
    "ax2.set_ylabel(\"Log Ratio\")\n",
    "ax2.legend(loc='best')\n",
    "ax2.set_xlim([-6,10])\n",
    "ax2.set_ylim([-1500,5000])\n",
    "\n",
    "ax3.set_xlabel(\"Iteration\")\n",
    "ax3.set_ylabel(\"Test Loss\")\n",
    "ax3.set_xlim([0,NUM_EPOCHS*NUM_SAMPLES//BS])\n",
    "ax3.set_ylim([0,10])\n",
    "\n",
    "scat3 = ax4.scatter(x,y,label='True p/q from p',alpha=0.9,s=1.,c='b')\n",
    "scat4 = ax4.scatter(x,y,label='CoB p/q from p',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat5 = ax5.scatter(x,y,label='True p/q from m1',alpha=0.9,s=1.,c='b')\n",
    "scat6 = ax5.scatter(x,y,label='CoB p/q from m2',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat7 = ax6.scatter(x,y,label='True p/q from m2',alpha=0.9,s=1.,c='b')\n",
    "scat8 = ax6.scatter(x,y,label='CoB p/q from m2',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat9 = ax7.scatter(x,y,label='True p/q from m3',alpha=0.9,s=1.,c='b')\n",
    "scat10 = ax7.scatter(x,y,label='CoB p/q from m3',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat11 = ax8.scatter(x,y,label='True p/q from q',alpha=0.9,s=1.,c='b')\n",
    "scat12 = ax8.scatter(x,y,label='CoB p/q from q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "plt.tight_layout()\n",
    "\n",
    "loss_store = []\n",
    "test_loss_store = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABCkAAANYCAYAAADpL7eNAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAACZ9ElEQVR4nOzdeZyWdb3/8ddnNgYYtgFEBAREFHEXxK3M1NxLrSw8mbacn22e7Fh5LDstpz37tZ3SDr8stSw00/KUZWqZqbkAueEKboAgm7JvM/P9/XHfgwMOMMx2Xfc9r+fjcT/mvq97+1ww85lr3vf3+70ipYQkSZIkSVLWKrIuQJIkSZIkCQwpJEmSJElSThhSSJIkSZKkXDCkkCRJkiRJuWBIIUmSJEmScsGQQpIkSZIk5UKXhhQR8dOIWBwRj7XYVh8Rt0XEM8Wvg7qyBklSQUSMioi/RsTjETE7Ii4sbm+1L0fBDyJiTkQ8EhGHZLsHktSzeWwtqSfo6pEUVwEnbbXtEuCOlNJ44I7ibUlS12sAPplSmggcDnwsIiay7b58MjC+eDkfuKL7S5YktXAVHltLKnNdGlKklO4Clm+1+XTg6uL1q4EzurIGSVJBSmlhSmlW8foq4AlgBNvuy6cD16SC+4CBETG8e6uWJDXz2FpST1CVwXsOSyktLF5fBAxr7UERcT6FT+7o3bduUmO/XRkzuC/9arMoWVJPMHPmzKUppaFZ19EdImIMcDBwP9vuyyOAeS2eNr+4bWGLbVv06759+06aMGFC1xUuqcfrSb26jXb62NpeLak7tLdfZ/oXf0opRUTaxn3TgGkA+x5wcFpzyle4/LzJHLdPq31XkjosIl7IuobuEBF1wG+AT6SUVkbE5vu215e3pWW/njx5cpoxY0ZnlitJW+gpvbo92npsba+W1B3a26+zOLvHy83DhYtfF+/wGcXj502NO3XcLEnaSkRUUwgork0p3VjcvK2+vAAY1eLpI4vbJEn5sfPH1pKUY1mEFDcD5xWvnwf8bkdPiGJK0dhkSCFJ7RWFIRNXAk+klL7T4q5t9eWbgXOLZ/k4HFjRYkixJCkfdvrYWpLyrEune0TEr4BjgCERMR/4AvAN4PqI+CDwAvCuHb9O4WtDU1NXlSpJPcFRwHuBRyPioeK2z7LtvnwLcAowB1gLvL9bq5UkbaGzjq0lKc+6NKRIKZ29jbuO25nXaZ4t3eB0D0lqt5TS3bzWUrf2ur6cUkrAx7q0KKmH2bRpE/Pnz2f9+vVZl5J7tbW1jBw5kurq6qxLyY3OOraWpDwriVNlNI+kcLqHJEkqZfPnz6dfv36MGTOGlovWakspJZYtW8b8+fMZO3Zs1uVIkrpRFmtStEPhl/gmp3tIkqQStn79egYPHmxAsQMRweDBgx1xIkk9UEmEFI6kkCRJ5cKAom38d5Kknqk0QoriV9ekkCRJkiSpfJVGSOHZPSRJkjps2bJlHHTQQRx00EHsuuuujBgxYvPtjRs3dvn7L1y4kBNOOKHL30eSVLpKY+HM4liKBqd7SJIktdvgwYN56KGHAPjiF79IXV0dn/rUpzbf39DQQFVV1x0e/ulPf+LEE0/ssteXJJW+khhJ0Tzfw+kekiRJnet973sfH/7whznssMO4+OKL+eIXv8i3v/3tzffvt99+PP/88wD84he/YMqUKRx00EF86EMforGx8XWvN2bMGC6++GL2339/pkyZwpw5czbf96c//YmTTz6ZlBIXXHABe++9N8cffzynnHIKN9xwQ5fvqyQp/0oipNi8JoUjKSRJkjrd/Pnzuffee/nOd76zzcc88cQTXHfdddxzzz089NBDVFZWcu2117b62AEDBvDoo49ywQUX8IlPfAKAxsZGnnrqKSZOnMhNN93EU089xeOPP84111zDvffe2xW7JUkqQSUx3QOgqiJodE0KSZLUwyxfDtOnw9SpUF/fNe9x1llnUVlZud3H3HHHHcycOZNDDz0UgHXr1rHLLru0+tizzz5789d///d/B+D+++/nsMMOA+Cuu+7i7LPPprKykt12241jjz22s3ZFklTiSiakqKwIp3tIkqQeZ/p0uOiiwvWPfrRr3qNv376br1dVVdHU4oOh9evXA5BS4rzzzuPrX//6Dl+v5elDm6//8Y9/5KSTTuqskiVJZaokpnsA1FRWsMmQQpIk9TBTp8J3vlP42h3GjBnDrFmzAJg1axbPPfccAMcddxw33HADixcvBmD58uW88MILrb7Gddddt/nrEUccARRGYhx//PEAHH300Vx33XU0NjaycOFC/vrXv3bpPkmSSkfJjKSorqpgU6PTPSRJUs9SX991Iyha8453vINrrrmGfffdl8MOO4y99toLgIkTJ/KVr3yFE044gaamJqqrq/nRj37E6NGjX/car7zyCgcccAC9evXiV7/6FUuWLKG2tpZ+/foBcOaZZ/KXv/yFiRMnsvvuu28OMiRJKpmQoqoiDCkkSZI6yRe/+MVWt/fu3Zs///nPrd737ne/m3e/+907fO1Pf/rTfPOb39x8+xe/+AUnnHDC5tsRwQ9/+MPNt9/3vve1rWhJUtkrmZCi2ukekiRJJemcc87JugRJUokomZCixukekiRJuff888/v9HOuuuqqTq9DklSaSmbhzOpKp3tIkiRJklTOSiakqKpwJIUkSZIkSeWsZEKK6qoKNromhSRJkiRJZatkQoqayqDBkRSSJEmSJJWtkgkpCmf3MKSQJEnqiEWLFjF16lTGjRvHpEmTOOWUU3j66ae3+fjnn3+e3r17c9BBB3HggQdy5JFH8tRTT+30+37jG9/g2muv7UjpkqQeoKRCCqd7SJIktV9KiTPPPJNjjjmGuXPnMnPmTL7+9a/z8ssvb/d548aN46GHHuLhhx/mvPPO42tf+9pOv/ett97KCSec0N7SJUk9RAmFFMGmBkdSSJIktddf//pXqqur+fCHP7x524EHHsgb3/hGUkp8+tOfZr/99mP//ffnuuuua/U1Vq5cyaBBg163/c477+Too4/m1FNPZe+99+bDH/4wTU1Nm5+zceNGhg4dynPPPccRRxzB/vvvz+c+9znq6uq6ZmclSSWpKusC2qq6soKGJkMKSZKk9nrssceYNGlSq/fdeOONm0dLLF26lEMPPZSjjz4agLlz53LQQQexatUq1q5dy/3339/qazzwwAM8/vjjjB49mpNOOokbb7yRd77zndx+++0cd9xxAFx44YV85CMf4dxzz+VHP/pR1+yoJKlkldBIigo2Od1DkiT1NMuXw+WXF752obvvvpuzzz6byspKhg0bxpve9CYefPBB4LXpHnPnzuV73/se559/fquvMWXKFPbYYw8qKys5++yzufvuuwH405/+xMknnwzAPffcw9lnnw3Ae9/73i7dJ0lS6SmpkGKj0z0kSVJPM306XHRR4WsH7bvvvsycObNDr/G2t72Nu+66q9X7IqLV2w888ABTpkzZ5uMkSWpWQiFFeHYPSZLU80ydCt/5TuFrBx177LFs2LCBadOmbd72yCOP8Pe//503vvGNXHfddTQ2NrJkyRLuuuuuLYKFZnfffTfjxo1r9fUfeOAB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\n",
      "text/plain": [
       "<Figure size 1080x864 with 9 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|▍         | 45/1000 [01:16<27:02,  1.70s/it]\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-12-5758e8a809c9>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     12\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     13\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mepoch\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mtrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mNUM_EPOCHS\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 14\u001b[0;31m     \u001b[0;32mfor\u001b[0m \u001b[0mp_batch\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mq_batch\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mm_batch1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mm_batch2\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mm_batch3\u001b[0m \u001b[0;32min\u001b[0m \u001b[0miter\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtrain_dl\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     15\u001b[0m         \u001b[0mmodel_cob\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtrain\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     16\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/sr/lib/python3.7/site-packages/torch/utils/data/dataloader.py\u001b[0m in \u001b[0;36m__next__\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    361\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    362\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__next__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 363\u001b[0;31m         \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_next_data\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    364\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_num_yielded\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    365\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_dataset_kind\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0m_DatasetKind\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mIterable\u001b[0m \u001b[0;32mand\u001b[0m\u001b[0;31m \u001b[0m\u001b[0;31m\\\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/sr/lib/python3.7/site-packages/torch/utils/data/dataloader.py\u001b[0m in \u001b[0;36m_next_data\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    401\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_next_data\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    402\u001b[0m         \u001b[0mindex\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_next_index\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# may raise StopIteration\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 403\u001b[0;31m         \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_dataset_fetcher\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfetch\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mindex\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# may raise StopIteration\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    404\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_pin_memory\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    405\u001b[0m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0m_utils\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpin_memory\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpin_memory\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdata\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/sr/lib/python3.7/site-packages/torch/utils/data/_utils/fetch.py\u001b[0m in \u001b[0;36mfetch\u001b[0;34m(self, possibly_batched_index)\u001b[0m\n\u001b[1;32m     42\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mfetch\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     43\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mauto_collation\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 44\u001b[0;31m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0midx\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     45\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     46\u001b[0m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/sr/lib/python3.7/site-packages/torch/utils/data/_utils/fetch.py\u001b[0m in \u001b[0;36m<listcomp>\u001b[0;34m(.0)\u001b[0m\n\u001b[1;32m     42\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mfetch\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     43\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mauto_collation\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 44\u001b[0;31m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0midx\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     45\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     46\u001b[0m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/cob_pytorch/src/dataset.py\u001b[0m in \u001b[0;36m__getitem__\u001b[0;34m(self, idx)\u001b[0m\n\u001b[1;32m    106\u001b[0m         \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mm_samples3\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mshape\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    107\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__getitem__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0midx\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 108\u001b[0;31m         \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mp_samples\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mq_samples\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mm_samples1\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mm_samples2\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mm_samples3\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    109\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    110\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__len__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "## CONFIRM q_list_test in validation/visualization in Akash's code\n",
    "\n",
    "model_cob.train()\n",
    "\n",
    "if torch.cuda.is_available():\n",
    "    model_cob = model_cob.to(DEVICE)\n",
    "    \n",
    "i = 0\n",
    "# loss_crit = torch.nn.CrossEntropyLoss()\n",
    "loss_crit_cob = torch.nn.functional.cross_entropy\n",
    "\n",
    "\n",
    "for epoch in trange(NUM_EPOCHS):\n",
    "    for p_batch, q_batch, m_batch1, m_batch2, m_batch3 in iter(train_dl):\n",
    "        model_cob.train()\n",
    "        \n",
    "        i += 1\n",
    "        \n",
    "        optim_cob.zero_grad()\n",
    "        \n",
    "        # CUDA\n",
    "        if torch.cuda.is_available():\n",
    "            p_batch, q_batch, m_batch1, m_batch2, m_batch3 = p_batch.unsqueeze(1).to(DEVICE), q_batch.unsqueeze(1).to(DEVICE), m_batch1.unsqueeze(1).to(DEVICE), m_batch2.unsqueeze(1).to(DEVICE), m_batch3.unsqueeze(1).to(DEVICE)\n",
    "            \n",
    "        logP = model_cob(p_batch)\n",
    "        logQ = model_cob(q_batch)\n",
    "        logM1 = model_cob(m_batch1)\n",
    "        logM2 = model_cob(m_batch2)\n",
    "        logM3 = model_cob(m_batch3)\n",
    "        \n",
    "        p_label = torch.empty(p_batch.shape[0], dtype=torch.long, device=DEVICE).fill_(0)\n",
    "        q_label = torch.empty(q_batch.shape[0], dtype=torch.long, device=DEVICE).fill_(1)\n",
    "        m1_label = torch.empty(m_batch1.shape[0], dtype=torch.long, device=DEVICE).fill_(2)\n",
    "        m2_label = torch.empty(m_batch2.shape[0], dtype=torch.long, device=DEVICE).fill_(3)\n",
    "        m3_label = torch.empty(m_batch3.shape[0], dtype=torch.long, device=DEVICE).fill_(4)\n",
    "        \n",
    "        loss_cob = loss_crit_cob(logP, p_label) + loss_crit_cob(logQ, q_label) + loss_crit_cob(logM1, m1_label) + loss_crit_cob(logM2, m2_label) + loss_crit_cob(logM3, m3_label)\n",
    "        loss_cob.backward()\n",
    "        optim_cob.step()\n",
    "        loss_store.append(loss_cob.item())\n",
    "\n",
    "        # Validation/Test\n",
    "        if i % 50 == 0:\n",
    "            model_cob.eval()\n",
    "            \n",
    "            with torch.no_grad():\n",
    "                for p_batch, q_batch, m_batch1, m_batch2, m_batch3 in iter(test_dl):\n",
    "                    gt_lr_p_q_from_p, _, true_kl_p_q = get_gt_ratio_kl(p, q, p_batch, calc_true_kl=True)\n",
    "                    gt_lr_p_q_from_m1, _ = get_gt_ratio_kl(p, q, m_batch1, calc_true_kl=False)\n",
    "                    gt_lr_p_q_from_m2, _ = get_gt_ratio_kl(p, q, m_batch2, calc_true_kl=False)\n",
    "                    gt_lr_p_q_from_m3, _ = get_gt_ratio_kl(p, q, m_batch3, calc_true_kl=False)\n",
    "                    gt_lr_p_q_from_q, _ = get_gt_ratio_kl(p, q, q_batch, calc_true_kl=False)\n",
    "\n",
    "                    if torch.cuda.is_available():\n",
    "                        p_batch, q_batch, m_batch1, m_batch2, m_batch3 = p_batch.unsqueeze(1).to(DEVICE), q_batch.unsqueeze(1).to(DEVICE), m_batch1.unsqueeze(1).to(DEVICE), m_batch2.unsqueeze(1).to(DEVICE), m_batch3.unsqueeze(1).to(DEVICE)\n",
    "                    \n",
    "                    logP = model_cob(p_batch)\n",
    "                    logQ = model_cob(q_batch)\n",
    "                    logM1 = model_cob(m_batch1)\n",
    "                    logM2 = model_cob(m_batch2)\n",
    "                    logM3 = model_cob(m_batch3)\n",
    "\n",
    "                    p_label = torch.empty(p_batch.shape[0], dtype=torch.long, device=DEVICE).fill_(0)\n",
    "                    q_label = torch.empty(q_batch.shape[0], dtype=torch.long, device=DEVICE).fill_(1)\n",
    "                    m1_label = torch.empty(m_batch1.shape[0], dtype=torch.long, device=DEVICE).fill_(2)\n",
    "                    m2_label = torch.empty(m_batch2.shape[0], dtype=torch.long, device=DEVICE).fill_(3)\n",
    "                    m3_label = torch.empty(m_batch3.shape[0], dtype=torch.long, device=DEVICE).fill_(4)\n",
    "\n",
    "#                     log_ratio_p_q_from_cob = logP[:, 0] - logP[:, 1]\n",
    "#                     kl_from_cob = torch.mean(log_ratio_p_q_from_cob)\n",
    "                    \n",
    "                    lr_p_q_cob_from_p = logP[:, 0] - logP[:, 1]\n",
    "                    lr_p_q_cob_from_m1 = logM1[:, 0] - logM1[:, 1]\n",
    "                    lr_p_q_cob_from_m2 = logM2[:, 0] - logM2[:, 1]\n",
    "                    lr_p_q_cob_from_m3 = logM3[:, 0] - logM3[:, 1]\n",
    "                    lr_p_q_cob_from_q = logQ[:, 0] - logQ[:, 1]                    \n",
    "                    \n",
    "                    test_loss_cob = loss_crit_cob(logP, p_label) + loss_crit_cob(logQ, q_label) + loss_crit_cob(logM1, m1_label) + loss_crit_cob(logM2, m2_label) + loss_crit_cob(logM3, m3_label)\n",
    "\n",
    "                    # Visualize\n",
    "                    line.set_data(range(len(loss_store)), loss_store)\n",
    "                    ax1.set_xlim( 0, len(loss_store) )\n",
    "                    \n",
    "                    scat1.set_offsets(np.vstack([p_batch.cpu().squeeze(), gt_lr_p_q_from_p.cpu().detach()]).T)\n",
    "                    scat2.set_offsets(np.vstack([p_batch.cpu().squeeze(), lr_p_q_cob_from_p.cpu().detach()]).T)\n",
    "                    ax2.set_xlim( -5., 5. )\n",
    "                    ax2.set_ylim( -400, 200)\n",
    "                    \n",
    "                    scat3.set_offsets(np.vstack([p_batch.cpu().squeeze(), gt_lr_p_q_from_p.cpu().detach()]).T)\n",
    "                    scat4.set_offsets(np.vstack([p_batch.cpu().squeeze(), lr_p_q_cob_from_p.cpu().detach()]).T)\n",
    "                    ax4.set_xlim( -5., 5. )\n",
    "                    ax4.set_ylim( -400, 200)\n",
    "                    \n",
    "                    scat5.set_offsets(np.vstack([m_batch1.cpu().squeeze(), gt_lr_p_q_from_m1.cpu().detach()]).T)\n",
    "                    scat6.set_offsets(np.vstack([m_batch1.cpu().squeeze(), lr_p_q_cob_from_m1.cpu().detach()]).T)\n",
    "                    ax5.set_xlim( -5., 5. )\n",
    "                    ax5.set_ylim( -400, 200)\n",
    "                    \n",
    "                    scat7.set_offsets(np.vstack([m_batch2.cpu().squeeze(), gt_lr_p_q_from_m2.cpu().detach()]).T)\n",
    "                    scat8.set_offsets(np.vstack([m_batch2.cpu().squeeze(), lr_p_q_cob_from_m2.cpu().detach()]).T)\n",
    "                    ax6.set_xlim( -5., 5. )\n",
    "                    ax6.set_ylim( -400, 200)\n",
    "                    \n",
    "                    scat9.set_offsets(np.vstack([m_batch3.cpu().squeeze(), gt_lr_p_q_from_m3.cpu().detach()]).T)\n",
    "                    scat10.set_offsets(np.vstack([m_batch3.cpu().squeeze(), lr_p_q_cob_from_m3.cpu().detach()]).T)\n",
    "                    ax7.set_xlim( -5., 5. )\n",
    "                    ax7.set_ylim( -400, 200)\n",
    "                    \n",
    "                    scat11.set_offsets(np.vstack([q_batch.cpu().squeeze(), gt_lr_p_q_from_q.cpu().detach()]).T)\n",
    "                    scat12.set_offsets(np.vstack([q_batch.cpu().squeeze(), lr_p_q_cob_from_q.cpu().detach()]).T)\n",
    "                    ax8.set_xlim( -5., 5. )\n",
    "                    ax8.set_ylim( -400, 200)\n",
    "            \n",
    "                    test_loss_store.append(test_loss_cob.item())\n",
    "                    test_line.set_data(range(len(test_loss_store)), test_loss_store)\n",
    "                    ax3.set_xlim( 0, len(test_loss_store) )\n",
    "                    \n",
    "                    clear_output(wait=True)\n",
    "                    display(fig)\n",
    "                    break\n",
    "\n",
    "            model_cob.train()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save({\n",
    "    'model': model_cob.state_dict(),\n",
    "    'optimizer': optim_cob.state_dict()\n",
    "}, '1D_cob_best1.pth')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_cob = RatioCritic1D_K3(dim_input=N_DIMS, dim_output=3, dropout=DROPOUT)\n",
    "\n",
    "ckpt = torch.load('1D_cob_best.pth')\n",
    "model_cob.load_state_dict(ckpt['model'])\n",
    "model_cob = model_cob.to(DEVICE)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "                    print('iteration: ',i)\n",
    "                    print('KLD: ', true_kl_p_q)\n",
    "                    print('CoB: ', log_ratio_p_q_from_cob.mean())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "m1, m2, m3 = m"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[Normal(loc: -0.5, scale: 0.09013878554105759),\n",
       " Normal(loc: 0.0, scale: 0.11180339753627777),\n",
       " Normal(loc: 0.5, scale: 0.1520690619945526)]"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "m"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_gt_log_ratios(p, q, m1, m2, m3, samples):\n",
    "    p_lp = p.log_prob(samples.cpu())\n",
    "    q_lp = q.log_prob(samples.cpu())\n",
    "    m1_lp = m1.log_prob(samples.cpu())\n",
    "    m2_lp = m2.log_prob(samples.cpu())\n",
    "    m3_lp = m3.log_prob(samples.cpu())\n",
    "    \n",
    "#     return p_lp - q_lp,  p_lp - m1_lp, m1_lp - m2_lp, m2_lp - m3_lp, m3_lp - q_lp #p_lp - m_lp, q_lp - m_lp, m_lp - q_lp # p/q, p/m, q/m, m/q\n",
    "    return p_lp - q_lp #, p_lp - m2_lp, q_lp - m2_lp, m1_lp - m2_lp, m3_lp - m2_lp\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_gt_log_ratios(p, q, m1, m2, m3, samples):\n",
    "    p_lp = p.log_prob(samples.cpu())\n",
    "    q_lp = q.log_prob(samples.cpu())\n",
    "    m1_lp = m1.log_prob(samples.cpu())\n",
    "    m2_lp = m2.log_prob(samples.cpu())\n",
    "    m3_lp = m3.log_prob(samples.cpu())\n",
    "    \n",
    "#     return p_lp - q_lp,  p_lp - m1_lp, m1_lp - m2_lp, m2_lp - m3_lp, m3_lp - q_lp #p_lp - m_lp, q_lp - m_lp, m_lp - q_lp # p/q, p/m, q/m, m/q\n",
    "    return p_lp - q_lp, m1_lp - q_lp, m2_lp - q_lp, m3_lp - q_lp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "#######\n",
    "with torch.no_grad():\n",
    "    model_cob.eval()\n",
    "    for p_batch, q_batch, m_batch1, m_batch2, m_batch3 in iter(test_dl):\n",
    "        if torch.cuda.is_available():\n",
    "            p_batch, q_batch, m_batch1, m_batch2, m_batch3 = p_batch.unsqueeze(1).to(DEVICE), q_batch.unsqueeze(1).to(DEVICE), m_batch1.unsqueeze(1).to(DEVICE), m_batch2.unsqueeze(1).to(DEVICE), m_batch3.unsqueeze(1).to(DEVICE)\n",
    "\n",
    "\n",
    "        logP = model_cob(p_batch).cpu()\n",
    "        logM1 = model_cob(m_batch1).cpu()\n",
    "        logM2 = model_cob(m_batch2).cpu()\n",
    "        logM3 = model_cob(m_batch3).cpu()\n",
    "        logQ = model_cob(q_batch).cpu()\n",
    "\n",
    "        log_ratio_p_q_from_cob_from_p = logP[:, 0] - logP[:, 1]\n",
    "        log_ratio_p_q_from_cob_from_m1 = logM1[:, 0] - logM1[:, 1]\n",
    "        log_ratio_p_q_from_cob_from_m2 = logM2[:, 0] - logM2[:, 1]\n",
    "        log_ratio_p_q_from_cob_from_m3 = logM3[:, 0] - logM3[:, 1]\n",
    "        log_ratio_p_q_from_cob_from_q = logQ[:, 0] - logQ[:, 1]\n",
    "        \n",
    "        true_log_ratio_p_q_from_p = get_gt_log_ratios(p, q, m1, m2, m3, p_batch)\n",
    "        true_log_ratio_p_q_from_m1 = get_gt_log_ratios(p, q, m1, m2, m3, m_batch1)\n",
    "        true_log_ratio_p_q_from_m2 = get_gt_log_ratios(p, q, m1, m2, m3, m_batch2)\n",
    "        true_log_ratio_p_q_from_m3 = get_gt_log_ratios(p, q, m1, m2, m3, m_batch3)\n",
    "        true_log_ratio_p_q_from_q = get_gt_log_ratios(p, q, m1, m2, m3, q_batch)\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set up viz\n",
    "fig, [ax1,ax2,ax3] = plt.subplots(1, 3,figsize=(8,3))\n",
    "p_batch = p_batch.cpu()\n",
    "\n",
    "scat1 = ax1.scatter(p_batch,true_log_ratio_p_q,label='True log p/q',alpha=0.9,s=10.,c='b')\n",
    "scat2 = ax1.scatter(p_batch,log_ratio_p_q_from_cob_from_p,label='Multi-class K=3 log p/q',alpha=0.9,s=10.,c='r')\n",
    "\n",
    "scat3 = ax2.scatter(p_batch,true_log_ratio_p_m,label='True log p/m',alpha=0.9,s=10.,c='b')\n",
    "scat4 = ax2.scatter(p_batch,log_ratio_p_m_from_cob_from_p,label='Multi-class K=3 log p/m',alpha=0.9,s=10.,c='r')\n",
    "\n",
    "scat5 = ax3.scatter(p_batch,true_log_ratio_q_m,label='True log q/m',alpha=0.9,s=10.,c='b')\n",
    "scat6 = ax3.scatter(p_batch,log_ratio_q_m_from_cob_from_p,label='Multi-class K=3 log q/m',alpha=0.9,s=10.,c='r')\n",
    "\n",
    "ylim = [-100, 150]\n",
    "xlim = [-3, 3]\n",
    "ax1.set_ylabel(\"Log Ratio\")\n",
    "ax1.legend(loc='best')\n",
    "ax1.set_xlim(xlim)\n",
    "ax1.set_ylim(ylim)\n",
    "\n",
    "ax2.set_ylabel(\"Log Ratio\")\n",
    "ax2.legend(loc='best')\n",
    "ax2.set_xlim(xlim)\n",
    "ax2.set_ylim(ylim)\n",
    "\n",
    "ax3.set_ylabel(\"Log Ratio\")\n",
    "ax3.legend(loc='best')\n",
    "ax3.set_xlim(xlim)\n",
    "ax3.set_ylim(ylim)\n",
    "\n",
    "# ax1.get_xaxis().set_visible(False)\n",
    "ax2.get_xaxis().set_visible(False)\n",
    "ax3.get_xaxis().set_visible(False)\n",
    "ax2.get_yaxis().set_visible(False)\n",
    "ax3.get_yaxis().set_visible(False)\n",
    "plt.tight_layout()\n",
    "plt.subplots_adjust(wspace=0, hspace=0.0)\n",
    "\n",
    "plt.savefig('1D_demo_cob_K=1_p.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "ename": "TypeError",
     "evalue": "can't convert cuda:1 device type tensor to numpy. Use Tensor.cpu() to copy the tensor to host memory first.",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mTypeError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-21-0995318f4d5b>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      6\u001b[0m \u001b[0mscat2\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0max1\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mscatter\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mp_batch\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mlog_ratio_p_q_from_cob_from_p\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mlabel\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'Multi-class log p/q'\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0malpha\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0.9\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0ms\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m1.\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mc\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'r'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      7\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 8\u001b[0;31m \u001b[0mscat3\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0max2\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mscatter\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mm_batch1\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mtrue_log_ratio_p_q_from_m1\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mlabel\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'True log p/q'\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0malpha\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0.9\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0ms\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m1.\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mc\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'b'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      9\u001b[0m \u001b[0mscat4\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0max2\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mscatter\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mm_batch1\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mlog_ratio_p_q_from_cob_from_m1\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mlabel\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'Multi-class log p/q'\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0malpha\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0.9\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0ms\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m1.\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mc\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'r'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     10\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/sr/lib/python3.7/site-packages/matplotlib/__init__.py\u001b[0m in \u001b[0;36minner\u001b[0;34m(ax, data, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1436\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0minner\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0max\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdata\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1437\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mdata\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1438\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0mfunc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0max\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0mmap\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msanitize_sequence\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1439\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1440\u001b[0m         \u001b[0mbound\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnew_sig\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbind\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0max\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/sr/lib/python3.7/site-packages/matplotlib/cbook/deprecation.py\u001b[0m in \u001b[0;36mwrapper\u001b[0;34m(*inner_args, **inner_kwargs)\u001b[0m\n\u001b[1;32m    409\u001b[0m                          \u001b[0;32melse\u001b[0m \u001b[0mdeprecation_addendum\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    410\u001b[0m                 **kwargs)\n\u001b[0;32m--> 411\u001b[0;31m         \u001b[0;32mreturn\u001b[0m \u001b[0mfunc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minner_args\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0minner_kwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    412\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    413\u001b[0m     \u001b[0;32mreturn\u001b[0m \u001b[0mwrapper\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/sr/lib/python3.7/site-packages/matplotlib/axes/_axes.py\u001b[0m in \u001b[0;36mscatter\u001b[0;34m(self, x, y, s, c, marker, cmap, norm, vmin, vmax, alpha, linewidths, verts, edgecolors, plotnonfinite, **kwargs)\u001b[0m\n\u001b[1;32m   4436\u001b[0m         \u001b[0;31m# np.ma.ravel yields an ndarray, not a masked array,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   4437\u001b[0m         \u001b[0;31m# unless its argument is a masked array.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 4438\u001b[0;31m         \u001b[0mx\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mma\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mravel\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   4439\u001b[0m         \u001b[0my\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mma\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mravel\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0my\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   4440\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mx\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msize\u001b[0m \u001b[0;34m!=\u001b[0m \u001b[0my\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msize\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/sr/lib/python3.7/site-packages/numpy/ma/core.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, a, *args, **params)\u001b[0m\n\u001b[1;32m   6768\u001b[0m             \u001b[0ma\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0ma\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   6769\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 6770\u001b[0;31m         \u001b[0mmarr\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0masanyarray\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0ma\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   6771\u001b[0m         \u001b[0mmethod_name\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__name__\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   6772\u001b[0m         \u001b[0mmethod\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mgetattr\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmarr\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmethod_name\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/sr/lib/python3.7/site-packages/numpy/ma/core.py\u001b[0m in \u001b[0;36masanyarray\u001b[0;34m(a, dtype)\u001b[0m\n\u001b[1;32m   7996\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0misinstance\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0ma\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mMaskedArray\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mdtype\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mNone\u001b[0m \u001b[0;32mor\u001b[0m \u001b[0mdtype\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0ma\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdtype\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   7997\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0ma\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 7998\u001b[0;31m     \u001b[0;32mreturn\u001b[0m \u001b[0mmasked_array\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0ma\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdtype\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mdtype\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcopy\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mFalse\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkeep_mask\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0msubok\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   7999\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   8000\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/sr/lib/python3.7/site-packages/numpy/ma/core.py\u001b[0m in \u001b[0;36m__new__\u001b[0;34m(cls, data, mask, dtype, copy, subok, ndmin, fill_value, keep_mask, hard_mask, shrink, order, **options)\u001b[0m\n\u001b[1;32m   2830\u001b[0m         \u001b[0;31m# Process data.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2831\u001b[0m         _data = np.array(data, dtype=dtype, copy=copy,\n\u001b[0;32m-> 2832\u001b[0;31m                          order=order, subok=True, ndmin=ndmin)\n\u001b[0m\u001b[1;32m   2833\u001b[0m         \u001b[0m_baseclass\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mgetattr\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdata\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'_baseclass'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0m_data\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2834\u001b[0m         \u001b[0;31m# Check that we're not erasing the mask.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/sr/lib/python3.7/site-packages/torch/tensor.py\u001b[0m in \u001b[0;36m__array__\u001b[0;34m(self, dtype)\u001b[0m\n\u001b[1;32m    478\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__array__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdtype\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    479\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mdtype\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 480\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumpy\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    481\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    482\u001b[0m             \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumpy\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mastype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdtype\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcopy\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mFalse\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mTypeError\u001b[0m: can't convert cuda:1 device type tensor to numpy. Use Tensor.cpu() to copy the tensor to host memory first."
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x216 with 5 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Set up viz\n",
    "fig, [ax1,ax2,ax3, ax4,ax5] = plt.subplots(1, 5,figsize=(12,3))\n",
    "p_batch = p_batch.cpu()\n",
    "\n",
    "scat1 = ax1.scatter(p_batch.cpu(),true_log_ratio_p_q_from_p,label='True log p/q',alpha=0.9,s=1.,c='b')\n",
    "scat2 = ax1.scatter(p_batch.cpu(),log_ratio_p_q_from_cob_from_p,label='Multi-class log p/q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat3 = ax2.scatter(m_batch1.cpu(),true_log_ratio_p_q_from_m1,label='True log p/q',alpha=0.9,s=1.,c='b')\n",
    "scat4 = ax2.scatter(m_batch1.cpu(),log_ratio_p_q_from_cob_from_m1,label='Multi-class log p/q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat5 = ax3.scatter(m_batch2.cpu(),true_log_ratio_p_q_from_m2,label='True log p/q',alpha=0.9,s=1.,c='b')\n",
    "scat6 = ax3.scatter(m_batch2.cpu(),log_ratio_p_q_from_cob_from_m2,label='Multi-class log p/q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat7 = ax4.scatter(m_batch3.cpu(),true_log_ratio_p_q_from_m3,label='True log p/q',alpha=0.9,s=1.,c='b')\n",
    "scat8 = ax4.scatter(m_batch3.cpu(),log_ratio_p_q_from_cob_from_m3,label='Multi-class log p/q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat9 = ax5.scatter(q_batch,true_log_ratio_p_q_from_q,label='True log m3/m2',alpha=0.9,s=1.,c='b')\n",
    "scat10 = ax5.scatter(q_batch,log_ratio_p_q_from_cob_from_q,label='Multi-class log p/q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "ylim = [-400, 300]\n",
    "xlim = [-3, 3]\n",
    "ax1.set_ylabel(\"Log Ratio\")\n",
    "ax1.legend(loc='upper right')\n",
    "ax1.set_xlim(xlim)\n",
    "ax1.set_ylim(ylim)\n",
    "ax1.set_title('p')\n",
    "\n",
    "ax2.set_ylabel(\"Log Ratio\")\n",
    "ax2.legend(loc='best')\n",
    "ax2.set_xlim(xlim)\n",
    "ax2.set_ylim(ylim)\n",
    "ax2.set_title('m1')\n",
    "\n",
    "ax3.set_ylabel(\"Log Ratio\")\n",
    "ax3.legend(loc='best')\n",
    "ax3.set_xlim(xlim)\n",
    "ax3.set_ylim(ylim)\n",
    "ax3.set_title('m2')\n",
    "\n",
    "ax4.set_ylabel(\"Log Ratio\")\n",
    "ax4.legend(loc='upper right')\n",
    "ax4.set_xlim(xlim)\n",
    "ax4.set_ylim(ylim)\n",
    "ax4.set_title('m3')\n",
    "\n",
    "ax5.set_ylabel(\"Log Ratio\")\n",
    "ax5.legend(loc='upper right')\n",
    "ax5.set_xlim(xlim)\n",
    "ax5.set_ylim(ylim)\n",
    "ax5.set_title('q')\n",
    "\n",
    "\n",
    "# ax1.get_xaxis().set_visible(False)\n",
    "# ax2.get_xaxis().set_visible(False)\n",
    "# ax3.get_xaxis().set_visible(False)\n",
    "# ax4.get_xaxis().set_visible(False)\n",
    "ax2.get_yaxis().set_visible(False)\n",
    "ax3.get_yaxis().set_visible(False)\n",
    "ax4.get_yaxis().set_visible(False)\n",
    "ax5.get_yaxis().set_visible(False)\n",
    "plt.tight_layout()\n",
    "plt.subplots_adjust(wspace=0, hspace=0.0)\n",
    "\n",
    "plt.savefig('1D_demo_cob_K=3_logp/q.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "sr",
   "language": "python",
   "name": "sr"
  },
  "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.7.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
