{
 "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 = 33000\n",
    "BS = 500\n",
    "NUM_EPOCHS = 500\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(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(mu1=-1., mu2=1., mu3=0, scale_p=0.1, scale_q=0.2, scale_m=1.0)\n",
    "\n",
    "# -5, 5, m_var=3.0\n",
    "# -10, 10, m_var=3.0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# 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": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# # Combine all m distributions into a mixture\n",
    "# m = MixtureSameFamily(\n",
    "#     D.Categorical(torch.Tensor([0.33, 0.33, 0.33])),\n",
    "#     D.Independent(D.Normal(torch.Tensor([m1.loc, m2.loc, m3.loc]), torch.Tensor([m1.scale, m2.scale, m3.scale])),0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling p\n",
      "Sampling q\n",
      "Cauchy(loc: 0.0, scale: 1.0)\n",
      "Sampling m\n",
      "torch.Size([33000])\n",
      "torch.Size([33000])\n",
      "torch.Size([33000])\n",
      "Sampling p\n",
      "Sampling q\n",
      "Cauchy(loc: 0.0, scale: 1.0)\n",
      "Sampling m\n",
      "torch.Size([33000])\n",
      "torch.Size([33000])\n",
      "torch.Size([33000])\n"
     ]
    }
   ],
   "source": [
    "# Define dataset & dataloader\n",
    "train_ds = DistDataset(p, q, m, num_samples=NUM_SAMPLES)\n",
    "test_ds = DistDataset(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": "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6GLE0BNPPJETTzxxk9s+++yzueCCC9bPz5o1i4l1byIi+M53vrN+/uSTT+5eaElSy7OAIUmSpMqaMmVK2REkSRVhAUOSJEmVsGzZss1+zaWXXtrjOSRJ1eQgnpIkSZIkqfIsYEiSJEmSpMqzgCFJkiRJkirPAoYkSZIkSao8CxiSJEnqlscff5yTTjqJvfbai3e84x0cc8wx/M///E+X6y9btoxtt92W0aNHc+CBB/LOd76TJUuWbPZ+v/KVr3D55ZdvTXRJUhuwgCFJkqRNykyOP/54jjjiCB566CEWLFjAl7/8ZX7/+99v9HV77bUXixYt4u6772bq1Kn80z/902bv+/rrr2fixIlbGl2S1CYsYEiSJGmTbrnlFvr168dpp522vu3AAw/k3e9+N5nJ2WefzX777cf+++/P7NmzO93Gs88+y0477fS69nnz5nH44Yfzvve9j3322YfTTjuNdevWrX/NK6+8wtChQ3nkkUc49NBD2X///fn7v/97Bg0a1Jg3K0mqpL5lB5AkSVKD3HADzJsHRxwBW3kGw3333cc73vGOTpddffXV68+y+MMf/sDBBx/M4YcfDsBDDz3E6NGj+eMf/8gLL7zAHXfc0ek27rzzThYvXsyb3/xmJk2axNVXX80JJ5zAz372M4488kgAPvWpT/GJT3yCj3zkI1x00UVb9X4kSa3HMzAkSZLa0Q03wJQpcNFFtecbbmjYrn75y18yefJk+vTpwy677ML/+l//i7vuugv40yUkDz30EN/85jc59dRTO93G2LFjectb3kKfPn2YPHkyv/zlLwGYO3cuRx99NAC33XYbkydPBuCv//qvG/Z+JEnVZAFDkiSpHc2bBy+/DAMH1p7nzduqze27774sWLBgq7Zx7LHHcuutt3a6LCI6nb/zzjsZO3Zsl+tJknoPCxiSJEnt6IgjoH9/eP752vMRR2zV5saPH8/LL7/MjBkz1rfdc889/OIXv+Dd7343s2fPZu3ataxatYpbb731NUWHDr/85S/Za6+9Ot3+nXfeySOPPMK6deuYPXs273rXu7j//vt529veRp8+fQA47LDDuPLKKwG8K4kk9UIWMCRJktrRxIkwaxacfnrteSvHwIgIrrnmGn72s5+x1157se+++/LZz36WXXfdleOPP54DDjiAAw88kPHjx/PP//zP7LrrrsCfxsA48MAD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jRvHW9/6VgBGjRrF+eefz8SJE1m3bh39+vXjoosu4s1vfvPrtvHUU09xwAEH0L9/f6644gpWrVrFgAEDGDx4MADHH388N998M6NGjWLPPfdcX+SQJLU/CxiSJEltauLExhQupk+f3mn7tttuyw1djBh64okncuKJJ25y22effTYXXHDB+vlZs2Yxse5NRATf+c531s+ffPLJ3QstSWp5FjAkSZJUWVOmTCk7giSpIixgSJIkqRKWLVu22a+59NJLezyHJKmaHMRTkiRJkiRVngUMSZIkSZJUeRYwJEmSJElS5VnAkCRJkiRJlWcBQ5IkSZu0evVqRo8ezejRo9l1110ZNmzY+vmIYPTo0ey33378xV/8BU8//TRQG5Rz2223Xb/e6NGjmTlz5mbtd+XKla+5jaokqffyLiSSJEnapCFDhrBo0SIApk+fzqBBgzjrrLMAGDRo0PplU6dO5aKLLuLzn/88AHvttdf6ZVti7ty5HHXUUVsTXZLUJjwDQ5IkST3m0EMPZcWKFZv1mhEjRnDOOeew//77M3bsWJYuXbp+2dy5czn66KPJTKZNm8Y+++zDhAkTOOaYY5gzZ05Px5ckVZgFDEmSpHZ1ww3wuc/Vnptg7dq13HTTTRx77LHr2x566KHXXELyi1/8otPX7rDDDtx7771MmzaNM844Y/32lixZwqhRo7jmmmtYsmQJixcvZubMmdx+++3NeEuSpArxEhJJkqR2dMMNMGUKvPwyfO97MGsWNGgsiRdffJHRo0ezYsUK/vzP/5z3vve965d19xKSyZMnr38+88wzAbjjjjsYN24cALfeeiuTJ0+mT58+7L777owfP77n34gkqdI8A0OSJKkdzZtXK14MHFh7njevYbvadtttWbRoEY8++iiZyUUXXbTZ24iI101fd911TJo0qcdySpJamwUMSZKkdnTEEdC/Pzz/fO35iCMavsvtttuOb3/723z9619nzZo1m/Xa2bNnr38+9NBDAbjpppuYMGECAIcffjizZ89m7dq1rFy5kltuuaVnw0uSKs9LSCRJktrRxIm1y0bmzasVL5p0K9K3v/3tHHDAAVxxxRW8+93vXj8GRoePfexjfPKTn3zd65566ikOOOAA+vfvzxVXXMGqVasYMGAAgwcPBuD444/n5ptvZtSoUey5557rixySpN7DAoYkSVK7mjixIYWL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\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=10.,c='b')\n",
    "scat2 = ax2.scatter(x,y,label='CoB p/q',alpha=0.9,s=10.,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",
    "line2, = ax4.plot([0,1],[0,1])\n",
    "x, y = np.random.random((2, 500))\n",
    "scat3 = ax5.scatter(x,y,label='True p/q',alpha=0.9,s=10.,c='b')\n",
    "scat4 = ax5.scatter(x,y,label='TRE p/q',alpha=0.9,s=10.,c='r')\n",
    "test_line2, = ax6.plot([0,1],[0,1])\n",
    "\n",
    "ax4.set_xlabel(\"Iteration\")\n",
    "ax4.set_ylabel(\"Train Loss\")\n",
    "ax4.set_xlim([0,NUM_EPOCHS*NUM_SAMPLES//BS])\n",
    "ax4.set_ylim([0,10])\n",
    "\n",
    "ax5.set_xlabel(\"Samples\")\n",
    "ax5.set_ylabel(\"Log Ratio\")\n",
    "ax5.legend(loc='best')\n",
    "ax5.set_xlim([-6,10])\n",
    "ax5.set_ylim([-1500,5000])\n",
    "\n",
    "ax6.set_xlabel(\"Iteration\")\n",
    "ax6.set_ylabel(\"Test Loss\")\n",
    "ax6.set_xlim([0,NUM_EPOCHS*NUM_SAMPLES//BS])\n",
    "ax6.set_ylim([0,10])\n",
    "\n",
    "\n",
    "line3, = ax7.plot([0,1],[0,1])\n",
    "scat5 = ax8.scatter(x,y,label='True p/q',alpha=0.9,s=10.,c='b')\n",
    "scat6 = ax8.scatter(x,y,label='TRE p/q',alpha=0.9,s=10.,c='r')\n",
    "test_line3, = ax9.plot([0,1],[0,1])\n",
    "\n",
    "ax7.set_xlabel(\"Iteration\")\n",
    "ax7.set_ylabel(\"Train Loss\")\n",
    "ax7.set_xlim([0,NUM_EPOCHS*NUM_SAMPLES//BS])\n",
    "ax7.set_ylim([0,10])\n",
    "\n",
    "ax8.set_xlabel(\"Samples\")\n",
    "ax8.set_ylabel(\"Log Ratio\")\n",
    "ax8.legend(loc='best')\n",
    "ax8.set_xlim([-6,10])\n",
    "ax8.set_ylim([-1500,5000])\n",
    "\n",
    "ax9.set_xlabel(\"Iteration\")\n",
    "ax9.set_ylabel(\"Test Loss\")\n",
    "ax9.set_xlim([0,NUM_EPOCHS*NUM_SAMPLES//BS])\n",
    "ax9.set_ylim([0,10])\n",
    "\n",
    "plt.tight_layout()\n",
    "\n",
    "loss_store = []\n",
    "test_loss_store = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABDAAAANYCAYAAAAylB2vAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAADETElEQVR4nOzdeXxU9b3/8dcnC0kI+y4EBRFFFERBENdU7YDWaq0rvVQEe6396a3aqhXsrfZeBW2tbW1pb70KarEKtXqrtkLc4lpRQBQBEWSRsAiyhSV7Pr8/5hATkkAgmTkzyfv5eMxj5nzPmXM+ZzI5853PfBdzd0REREREREREEllK2AGIiIiIiIiIiByIEhgiIiIiIiIikvCUwBARERERERGRhKcEhoiIiIiIiIgkPCUwRERERERERCThKYEhIiIiIiIiIgkvZgkMM5tmZpvM7ONqZZ3M7CUzWx7cd4zV8UVE5Ctm1tvMXjOzJWa22MxuDMrrvC5b1INmtsLMPjKzk8I9AxGRlk11axGR2LbAeBQYvU/Z7cAr7t4feCVYFhGR2CsHfuzuA4FTgOvNbCD1X5fPA/oHt2uBP8Y/ZBERqeZRVLcWkRYuZgkMd38D2LpP8UXAY8Hjx4Bvxer4IiLyFXff4O4Lgsc7gaVAL+q/Ll8EPO5R7wIdzOyw+EYtIiJ7qW4tIgJpcT5ed3ffEDzeCHSvb0Mzu5bor35kZ2cPHTBgQNW6Ret2AHB097ZkpGkYDxEJ3/z58790965hx9EQZtYHOBGYS/3X5V7A2mpPKwjKNlQr2++1WkQk0STTtbqBmqRu/ekXO8lMT+XwTq1jGauISIPVd72OdwKjiru7mfl+1j8EPAQwbNgwnzdvXtW6Prf/A4Dnbsmlb5fsGEcqInJgZrYm7BgawszaAH8DbnL3QjOrWneg63Jd9netFhFJNMlyrT4Ujalbf/2B1+nfvQ1/+LehsQ9URKQB6rtex7v5whd7myAH95vifHwRkRbLzNKJJi+ecPdnguL6rsvrgN7Vnp4TlImISOJQ3VpEWpR4JzCeA8YFj8cBf4/z8UVEWiSLNrV4BFjq7g9UW1Xfdfk54KpgNpJTgB3VmimLiEhiUN1aRFqUmHUhMbMngVygi5kVAHcC9wKzzOwaYA1weayOLyIiNZwGfBdYZGYLg7JJ1H9d/idwPrAC2AOMj2u0IiJSg+rWIiIxTGC4+5h6Vp0Tq2OKiEjd3P0twOpZXeu67O4OXB/ToETkoJSVlVFQUEBxcXHYoSS8zMxMcnJySE9PDzuUJqO6tYhIiIN4ioiIiEjDFRQU0LZtW/r06UP1AXilJndny5YtFBQU0Ldv37DDERGRJpTUc5BGfyAUERERaf6Ki4vp3LmzkhcHYGZ07txZLVVERJqhpE5giIiIiLQkSl40jF4nEZHmSQkMEREREREREUl4SmCIiIiIyAFt2bKFIUOGMGTIEHr06EGvXr2qlktLS2N+/A0bNhCJRGJ+HBERSVwaxFNEREREDqhz584sXLgQgLvuuos2bdpwyy23VK0vLy8nLS12VcvZs2czatSomO1fREQSn1pgiIiIiMghufrqq7nuuusYMWIEt912G3fddRf3339/1frjjz+e1atXAzBjxgyGDx/OkCFD+P73v09FRUWt/fXp04fbbruNQYMGMXz4cFasWFG1bvbs2Zx33nm4OzfccAPHHHMM5557Lueffz5PP/10zM9VRETCpwSGiIiISDOVlweTJkXvY6WgoIB33nmHBx54oN5tli5dysyZM3n77bdZuHAhqampPPHEE3Vu2759exYtWsQNN9zATTfdBEBFRQXLli1j4MCBPPvssyxbtowlS5bw+OOP884778TitEREJAEldRcSTaIqIiIiUre8PBg7FkpK4OGHYcYMiMUQEpdddhmpqan73eaVV15h/vz5nHzyyQAUFRXRrVu3OrcdM2ZM1f3NN98MwNy5cxkxYgQAb7zxBmPGjCE1NZWePXty9tlnN9WpiIhIgkvqBIaIiIiI1C0/P5q8yM6G3bujy7FIYGRnZ1c9TktLo7Kysmq5uLgYAHdn3LhxTJky5YD7qz4F6t7HL774IqNHj26qkKUOrl8GRSQJqAuJiIiISDOUmwsZGdHkRUZGdDnW+vTpw4IFCwBYsGABq1atAuCcc87h6aefZtOmTQBs3bqVNWvW1LmPmTNnVt2PHDkSiLbgOPfccwE488wzmTlzJhUVFWzYsIHXXnstpufUElTLGYmIJDS1wBARERFphiKRaLeR/Pxo8iIeM5BecsklPP744xx33HGMGDGCo48+GoCBAwdy9913E4lEqKysJD09nalTp3LEEUfU2se2bdsYPHgwGRkZPPnkk2zevJnMzEzatm0LwMUXX8yrr77KwIEDOfzww6uSHCIi0vwpgSEiIiLSTEUisUlc3HXXXXWWZ2VlkVfPiKFXXHEFV1xxxQH3feutt3LfffdVLc+YMYNItZMwM37/+99XLV999dUNC1pERJKeEhgiIiIikrDGjh0bdggiIpIglMAQERERkYSwevXqg37Oo48+2uRxiIhIYkrqQTw1WrKIiIiIiIhIy5DUCQwRERERERERaRmUwBARERERERGRhKcEhoiIiIiIiIgkPCUwRERERKRBNm7cyJVXXkm/fv0YOnQo559/Pp9++mm9269evZqsrCyGDBnCCSecwKmnnsqyZcsO+rj33nsvTzzxRGNCFxGRZkAJDBERERE5IHfn4osvJjc3l88++4z58+czZcoUvvjii/0+r1+/fixcuJAPP/yQcePGMXny5IM+9pw5c4hEIocauoiINBNKYIiIiIjIAb322mukp6dz3XXXVZWdcMIJnHHGGbg7t956K8cffzyDBg1i5syZde6jsLCQjh071irPz8/nzDPP5Bvf+AbHHHMM1113HZWVlVXPKS0tpWvXrqxatYqRI0cyaNAgfvrTn9KmTZvYnKyIiCSktLADEBEREZEYycuD/HzIzYVGtmD4+OOPGTp0aJ3rnnnmmapWFl9++SUnn3wyZ555JgCfffYZQ4YMYefOnezZs4e5c+fWuY/33nuPJUuWcMQRRzB69GieeeYZLr30Ul5++WXOOeccAG688UZ+8IMfcNVVVzF16tRGnY+IiCSfJG+B4WEHICIiIpKY8vJg7FiYOjV6n5cXs0O99dZbjBkzhtTUVLp3785ZZ53F+++/D3zVheSzzz7jN7/5Dddee22d+xg+fDhHHnkkqampjBkzhrfeeguA2bNnc9555wHw9ttvM2bMGAC++93vxux8REQkMSV5AkNERERE6pSfDyUlkJ0dvc/Pb9TujjvuOObPn9+ofVx44YW88cYbda4zszqX33vvPYYPH17vdtI0XL8LikgSUAJDREREpDnKzYWMDNi9O3qfm9uo3Z199tmUlJTw0EMPVZV99NFHvPnmm5xxxhnMnDmTiooKNm/ezBtvvFEj6bDXW2+9Rb9+/erc/3vvvceqVauorKxk5syZnH766SxevJgBAwaQmpoKwGmnncZTTz0FoFlJmpChpJCIJAclMERERESao0gEZsyA66+P3jdyDAwz49lnn+Xll1+mX79+HHfccUycOJEePXpw8cUXM3jwYE444QTOPvtsfvGLX9CjRw/gqzEwTjjhBCZNmsTDDz9c5/5PPvlkbrjhBo499lj69u3LxRdfzIsvvsjo0aOrtvntb3/L1KlTGTRoEOvWrWvU+YiISPLRIJ4iIiIizVUk0ujERXU9e/Zk1qxZda775S9/yS9/+csaZX369KGoqKhB+27Xrh0vvPBCjbI5c+bw+OOPVy337duXf/3rX1XLv/nNbxoYuYiINAdKYIiIiIhIQnrppZfCDkFERBKIEhgiIiIiEqrc3FxyD2GMjl27djV9MCIikrCSegwMjZYsIiIiLYmr8tMgep1ERJqn5E5ghB2AiEiSMLNpZrbJzD6uVtbJzF4ys+XBfceg3MzsQTNbYWYfmdlJ4UUuIntlZmayZcsWfTk/AHdny5YtZGZmhh2KiIg0MXUhERFpGR4Ffg88Xq3sduAVd7/XzG4Pln8CnAf0D24jgD8G9yISopycHAoKCti8eXPYoSS8zMxMcnJywg5DRESamBIYIiItgLu/YWZ99im+CMgNHj8G5BNNYFwEPO7Rn3nfNbMOZnaYu2+IU7giUof09HT69u0bdhgiIiKhSeouJCIi0ijdqyUlNgLdg8e9gLXVtisIymoxs2vNbJ6ZzdOvwiIiIiISS0pgiIgIQWuLg+5Y7+4Pufswdx/WtWvXGEQmIiIiIhKlBIaISMv1hZkdBhDcbwrK1wG9q22XE5SJiIiIiIQmqRMYGoRbRKRRngPGBY/HAX+vVn5VMBvJKcAOjX8hIiIiImHTIJ4iIi2AmT1JdMDOLmZWANwJ3AvMMrNrgDXA5cHm/wTOB1YAe4DxcQ9YRERERGQfoSQwzOxm4HtE+1svAsa7e3EYsYiItATuPqaeVefUsa0D18c2IhERaSpNUbf2gx8GSUQk7uLehcTMegE/BIa5+/FAKnBlvOMQEREREUl2TVG3NotFZCIiTS+sMTDSgCwzSwNaA+tDikNEREREJNmpbi0iLULcExjuvg64H/gc2EB0cLi8fbczs2vNbJ6Zzdu8eXO8wxQRERERSXiqW4tISxJGF5KOwEVAX6AnkG1mY/fdzt0fcvdh7j6sa9eu8Q5TRERERCThqW4tIi1JGF1IzgVWuftmdy8DngFOPZQdabAhEREREWnhmqxuLSKS6MKYheRz4BQzaw0UER0Bf14IcYiIiCSvKVPg+ecpaDuAzXNX0nbPJjYccQptNq2ky66VpFeWkkY5O9M60q58GxnpFbRplwoXXgjTpoUdvYg0HdWtRaTFiHsCw93nmtnTwAKgHPgAeCjecYiIiCSVvDyYPp0tizdQsnErPTYvAqAX/6JXsEm/FUtrPa1z+ZbogzLwLcD06RQ++gwffP0n5M6ZGJ/YRSRmVLcWkZYkjBYYuPudwJ1hHFtERCSpTJhA2fQ/k0Y5AJ2qrTrUjpTtfAdn5t3B4tZPk1O0nBIyWRK5WQkNkSSlurWItBRhTaMqIiIiBzJhAj59elXyYl/WiF0bzsCiBbRjJ13ZzFl5k9iU2oOdhw+Mdk8RERERSTChtMAQERGR+uWPmkKnt5+n756PaVPHegdKyGQlfZnLKRybsZKulXWPgbEjpSPtKreRQTFt2L3fpEfXyi9g7Rf4pEmsnJZPv+VzYnSGIiIiIgdPCQwREZFEkJcH+fl8OGcjZy54lPo6iGylAy/baBaeOJ7XMyJ885swIej5cVQd23cJdn3LLXDkijxuLZ9MdzZRkpbFwKIF9YZz5Io8VmQPJvvk4zhs0niIRBp7hiIiIiKNogSGiIhImPLyYNo0yl6YTXm5M7BkD9GJwlMwKvmCrrRnB6lU8CrncO9Zc5g0CaYcRD4hEoGPPgKIBLeoN/tP4MQVT5FFUZ19SvvtWQSvL6L89VmsHH83R0/TGBkiIiISnqQeA8MPdfQyERGRRJCXR+kFF1M5cyapu3dQVJpGOakYYFQCxl973kzvziUMG1ROypw55Oc3XWOIM5ZPo43vYeHkOSxJGVTvdqlU0n/6JFZn9G+aA4uIiIgcgqROYIiIiCStvDwKz7+c9LI9QcIC2voOdlk7/tl9PB9nj+SNyD38x7qJfPlltAVFrHpxDJ0Y4biKj5h+1GTW0JtNdKWyju2OKF3BxtRedawRERERiT0lMEREROItL4/i8y+mbcWOGsXb6cD17WaQ/vg0Bu96J+7Tmk5YPpE+/jndfRMv9Rxf5zbdK9ezy1rzZv8JcY1NRGJLLZtFJBkogSEiIhIveXmQm0vppd8hvWJPrdWPtP8x35sVSYjxMkevm8bfTppMERm11mVTxOkrprOs3dAQIhMREZGWSgkMERGReMjLo+z8C/HXXyd955ZaH8B5RDhp1sSESF7sden8ibw1p5gCeta5/uidC9iV3Q2mTIlzZCIiItISKYEhIiISB599+xbSKkpqlO2gLUs4lt92n4zNmZNQyYu9IhFYOmcdz3aou0tJ9p7NVE6apCSGiIiIxJwSGCIiIrE0ZQrbOxzOkbsX1Vr1h7YTWTdnCTdtTKyWF/uKRODb26bx1lF1JzEM2D3pv5k/JS++gYmIiEiLktQJDA02JCIiiaxg1AR80iTa71hba910xmMTEztxsa8zlkfHxdhE11rrWlPEoEkX8OkEtcQQERGR2EjqBIaIiEiimj8lj+55f65V7sCM9PF8MXkaE+M7yUiTuHT+RD6cs4knM2q3xkinjCOn/2d0sFIRERGRJqYEhoiISAwUPp9POak1yj6nN29EJvPd0uRMXuwVicB3iqfx907jqdxnXSoVbB91mbqTiIiISJNTAkNERKQp5eXBpEn0GtCWXbSjmAzKSGM64/nL5M/JnZPEmYt9fGvLNN6MTK6VxGhPIYMnnackhoiIiDSptLADEBERaTYmTKDysccptzT6tGnH6vE3M+flneSTS78fRJK61UV9cudMZHav5YxaP71GeRqVDJp0PkwsDykyERERaW6UwBAREWkKU6bg06djQDoVlOwoJK1oJ2M/n8zYsGOLsdHrpvF2u3WcurNmi4t0Kii2VmTOeYGkGq1UREREEpK6kIiIiDTWlCmU3HlPjaIUysn33HDiCcFphXNYnXZUrfIMyigbfYEG9hQREZFGS+oEhqN5VEVEJGRTplA56Q7Sy3ZXFTnwBFeRM6FltTroW7ac3WTVKk/zMtZe8P0QIhIREZHmJLkTGMpfiIhIyAr++DzRlHoKDuwkmzuYzJvjp7XIXhNtfA+FtK1VnlO2mvUpvUKISERERJqLpE5giIiIhCovjy+2twIMoxIw7k+/g3aTJzJtWtjBhae9F7ImpU+t8sN8Pe93HhX/gERERKRZUAJDRETkUOTlUXr5WI7Z8wF7yGIpx3IH95D184nNcraRg7Xl7j/V2dFzyNaX4x6LiIiINA9KYIiIiByCldPzKSosYWdlNhWk8Vbnb9FuspIXew2dGOHto8bXKk+jkiLLCCEiEdkf9cwWkWSgBIaIiNTLzEab2TIzW2Fmt4cdT0LIy4NJk/h0Q1tKyaA1uym1DNLPzVXyYh9nLJ/GW3UkMTIppcxUBRFJFGYWdggiIg2SFnYAIiKSmMwsFZgKfB0oAN43s+fcfUm4kYUo6DZSUVzCGWkZ/DrrZjLLd/JeVi7fa2EzjjTUGcun8X7ndQzbWnMa1TScHdaO9l4YUmQiIiKSbJL65w/NQiIiElPDgRXuvtLdS4GngItCjilUe7uNbC/NpnxPCWefvJOtP57M92ZFWuSMIw118pY5FNOqVnk7drKolwb1FBERkYZJ6gSGiIjEVC9gbbXlgqCsiplda2bzzGze5s2b4xpcGPI996tuI2TwSY9cJk9GyYsGeHNOCeXUbqZ+3Pq8aLccERERkQNQAkNERA6Zuz/k7sPcfVjXrl3DDifmciZEuL7dDP43/XqubzeDHHUbabBIBF6bU1lroEAD1l/4/TBCEhERkSSjBIaIiNRnHdC72nJOUNZiRSLwvVkRdRs5RJEIzO9U+0U7rGS1upKIiIjIASmBISIi9Xkf6G9mfc2sFXAl8FzIMYUuEkHdRhrh5C1z+LjVSbXKj1+fx/wp6koiIiIi9VMCQ0RE6uTu5cANwBxgKTDL3ReHG1WcBVOmaoyGpjWoZD6r6VO7fNL58Q9GREREkoYSGCIiUi93/6e7H+3u/dz9nrDjiau8PLj8cvjVr6L3SmI0qbnj/1RrPIx0Klif0qvO7UVERESUwBAREanLtGn4jkIqS8vwHYUwbVrYETUrV06LsLiOriSH+Xp1JREREZE6JXUCw2v9diMiItIEpkyh9J8vV33OOLBhY+0pQKVxBpXMr/OTvP+kb8c9FhEREUl8SZ3AEBERaXJTpuB33EHazi0YUEEKhbRjOuPDjqxZevuo2q9rW3azrN3QEKIRERGRRKYEhoiISDW7/vhncAcMBzbSnSuYxaLDNO1ILJyxfBqr046qVX70zgXqSiIiIiI1KIEhIiKy15QpZKxdAexNXxh/4Abmto8wXg0wYqZv2XLW07NW+XGTLgghGhEREUlUSmCIiIgA5OVRcdd/k0oZlUAlRj5n8vdjJzJrFkTUACOmFs9ZR+U+ZRmUsbZ1/1DiEWlpXEPLiUgSUAJDREQEorOOlJbhGAYUk8UD6ZP4zW+UvIiHSATWpvSpVZ5TtEJdSURiTEMUi0iyCCWBYWYdzOxpM/vEzJaa2cgw4hAREQEgL4/iv88mhQoMp5RWTEn5Kaf9PKLkRRxtuftPtVphAOTccVXcYxFJJqpbi0hLEVYLjN8Cs919AHACsPRQdqKmbiIi0hRWTs+npNjZRkdKyeD/+DYrLpvIxIlhR9ayDJ0Y4TeRObWmVu3mX/DphCmhxCSSJJqkbi0ikujinsAws/bAmcAjAO5e6u7b4x2HiIjIXvmeSykZpFJOIe14otV4JkwIO6qW6cdzImyma63y9Kf+HEI0IolPdWsRaUnCaIHRF9gMTDezD8zsYTPL3ncjM7vWzOaZ2bzNmzfHP0oREWkxciZEuL79DB5Ku57vZczg1LvUdSRMSyM31yqz4qIQIhFJCqpbi0iLccAEhpn1M7OM4HGumf3QzDo04phpwEnAH939RGA3cPu+G7n7Q+4+zN2Hde1a+5cYERGRphKJwPdmRdh+62RueC6iriMhy50zkTk9x9cYD+MIX82b/dUsRqQOqluLSIvRkBYYfwMqzOwo4CGgN/CXRhyzAChw97nB8tNEL7oiIiKhiURg8mTNOJIoRq+bxmepx9YoO33FdJa1GxpSRCIJS3VrEWkxGpLAqHT3cuBi4Hfufitw2KEe0N03AmvN7Jig6BxgyaHuT0SkOTGz9mb2673NfM3sV0H/ZpEWZ/05361VdvTOBSzqNSqEaEQSk+rWItKSNCSBUWZmY4BxwAtBWXojj/sfwBNm9hEwBJjcyP2JiDQX04BC4PLgVghMDzWi5mrKFDj11Oi9JKTcORNZljGoVvnA9XkhRCPSNMzsF2bWzszSzewVM9tsZmMbuVvVrUWkRUhrwDbjgeuAe9x9lZn1BRo1FLi7LwSGNWYfQK1p1kREmoF+7n5JteWfm9nCsIJptqZMgTvuiM7H/e670TINfJGQdt95P0yq2eIiBXiz/wTOWD4tnKBEGifi7reZ2cXAauDbwBvAjEPdYVPVrUVEEt0BW2C4+xJ3/6G7P2lmHYG27n5fHGITEWmJiszs9L0LZnYaoOkXmtrzz+PuVJCCu8Pzz4cdkdRj6MQI77StPTDJ4BVPhxCNSJPY+wPiN4C/uvuOMIMREUkmB2yBYWb5wIXBtvOBTWb2trv/KMaxiYi0RD8AHgvGvTBgK3B1qBE1N3l5rNnQit6AUYljvN72m+SGHZfU67TCOZRYOq0oryrLoDjEiEQa5QUz+4RocvoHZtYV9IYWEWmIhoyB0d7dC4k2b3vc3UcA58Y2LBGRlsndF7r7CcBgYJC7n+juH4YdV7ORl0fp5WPpsOYD9pDNUo7lDu5h0k51H0l0S9qfVmM5gzI+HKppVSX5uPvtwKnAMHcvIzrt6UXhRiUikhwaksBIM7PDiA4m98KBNhYRkYO3dwA3M/uRmf0I+B7wvWrL0gRWTs+nqLCE3Z5NOan8H9/iPpvIN78ZdmRyIJU/mVRr7KvjFjyqQVgl6ZjZZUCZu1eY2U+Jjn3RM+SwRESSQkMSGP8FzAE+c/f3zexIYHlswxIRaXGyg/u2ddzahBVUc5PvuZSSQbbtpowMPu6Uyz33aPzOZDB0YoR3smuOhZGK45MmKYkhyeY/3X1nMN7RucAjwB9DjgkNjy8iyeCAY2C4+1+Bv1ZbXglcUv8zRETkYLn7n4KHL7v729XXBQN5ShPImRDh+tkzGF6Uz3tZuXzvyQiR2uNDSoLa88wcvhjVje5srlG+7t4/00tZKEkeFcH9N4CH3P0fZnZ3mAGZhXl0EZGGO2ALDDPLMbNnzWxTcPubmeXEI7gDcVemWESand81sEwORl4eTJpEhDy+NyvC1h9P5nuzlLxINpEIvHXSzbXKMws3hBCNyCFbZ2Z/Aq4A/mlmGTSsVbSISIt3wBYYwHTgL8BlwfLYoOzrsQqqoZS+EJHmwsxGEh3Ures+Y160A1LDiaqZyMuDyy+HoiL4wx+IzJpFZLIyF8nq0vkTWZz2JAMrFlWVdWI7Hw6dwAnzp4UYmUiDXQ6MBu539+3BWHO3hhyTiEhSaEi2t6u7T3f38uD2KNA1xnGJiLQ0rYiOdZFGzfEvCoFLQ4wr+U2bhu8opLK0DN9RCNP0JTfZFf/3/VTuU9Z3wdOhxCJysNx9D/AZMMrMbgC6uXteyGGJiCSFhiQwtpjZWDNLDW5jgS2xDkxEpCVx99fd/efAKe7+82q3B9xdAyc3wuIlVtViz4NlSW5DJ0YopF2NsnRKoq1tRBKcmd0IPAF0C24zzOw/wo1KRCQ5NCSBMYFoU7eNwAaivwReHcOYRERasj1m9ksz+6eZvbr3FnZQyex/y8dTSDtKaUUh7fjf8vFhhyRN4JWTbq+xnEkpZaMvUBJDksE1wAh3/5m7/ww4Bfj3kGMSEUkKB0xguPsad7/Q3bu6ezd3/xZwY+xDExFpkZ4APgH6Aj8HVgPvhxlQsuv+3QhXMItf8SOuYBbdv6vxL5qDS+dP5P3WZ9UYDyvNy9j07e+HFpNIAxlfzURC8FhNw0REGuBQRzy+vEmjEBGRvTq7+yNAWdCtZAJwdthBJbOJEyF3coR/jJxM7uQImm2z+Uj96aRaZV13r1YrDEl004G5ZnaXmd0FvAs8Em5IIiLJ4VATGMoSi4jERllwv8HMvmFmJwKdwgyoOZg4Ed55ByUvmpmhEyOU0KpW+dKrJocQjUjDuPsDwHhga3AbD8wKNSgRkSRRbwLDzDrVc+tMgiQwXPOoikjzc7eZtQd+DNwCPAzc1JgdmtllZrbYzCrNbNg+6yaa2QozW2Zmo6qVjw7KVpjZ7bX3KpIYXu/5b7XKenyxMP6BiBwEd1/g7g8Gtw+ItsIQEZED2F8LjPnAvOC++m0eUBr70A7s/z5YF3YIIiJNyt1fcPcd7v6xu3/N3YcS/YWuMT4Gvg28Ub3QzAYCVwLHAaOBP+ydcQqYCpwHDATGBNsmj7w8mDRJXQlagNHrprGR7jXKOrCD/FFTQopI5JAkxI+DIiKJrt4Ehrv3dfcjg/t9b0fGM8j6rNi0K+wQRESaRJA4GGNmt5jZ8UHZBWb2DvD7xuzb3Ze6+7I6Vl0EPOXuJe6+ClgBDA9uK9x9pbuXAk8F2yaHvDwYOxamTo3eK4nR7K2f/DiV+5QNy7s7lFhEDpHaFYuINEBa2AGIiAgQHcCtN/Ae8KCZrQeGAbe7+//F6Ji9qNlsuSAoA1i7T/mIGMXQ9PLzKdtdQlFKNlm7d5Oenw8RzTzSnA2dGGH3pCxaU1RVls0e8kdNIXeOBj6RxGBmv6PuRIUBHeIbjYhIckrqBIYrWS0izccwYLC7V5pZJrAR6OfuWxryZDN7GehRx6o73P3vTRjnvse9FrgW4PDDD4/VYQ7K/La5HFH0MOm+mx2WwZq2uQwNOyiJufzuV3L+F9NrlA3Juw9QAkMSxrxDXCciIoGkTmCs3Vp04I1ERJJDqbtXArh7sZmtbGjyInjOuYdwzHVEW33slROUsZ/yfY/7EPAQwLBhwxIiq/y3nRGWZs0g1/LJ91yO3RlRAqMFSH98GqWj/kwryqvK2rMj2oVILXAkAbj7Y2HHsD8aHF9EkkGDplEN+mb3NLPD995iHVhDrNuuBIaINBsDzOyj4Lao2vIiM/soRsd8DrjSzDLMrC/Qn2gXlveB/mbW18xaER3o87kYxdDkcnPh7ewIP0udzNvZEXJzw45I4iESgX90+G6t8s3nXxVCNCLJxTSEqIgkiQO2wDCz/wDuBL6AqjGyHBgcw7hERFqaY2O1YzO7GPgd0BX4h5ktdPdR7r7YzGYBS4By4Hp3rwiecwMwB0gFprn74ljF19QiEZgxA/Lzo8kM/fjecrSZOY3iUU+QWW2ytC4VX2gsDBERkWaiIV1IbgSOOZimzCIicnDcfU0M9/0s8Gw96+4B7qmj/J/AP2MVU6xFIkpctESRCMzK/jcu211zLIyBL/0ajYUhicLMTnP3tw9UJiIitTWkC8laYEesAxERETlkeXkwaZKmTBU6PDONIjJqlHXxzXpvSCL5XQPLRERkHw1pgbESyDezfwAlewvd/YGYRSUiItJQeXkwdiyUlMDDD0f7j6j5RYsVicB7rU/h5D2vV5UZsPSqyRy7Ue8LCY+ZjQROBbqa2Y+qrWpHtLueiIgcQENaYHwOvAS0AtpWu4mIiIQvP5+y3SUUVmZTtrskOviFtGipP51Ua6L1Hl98EEosItW0AtoQ/QGxep26ELg0xLhERJLGAVtguPvP4xGIiIhAMAPJvt+9dgDzgLs1HlFt89vmckTRw6T7bnZYBmva5mra1BZu6MQIS+4cxLFli6rKOlCowTwlVO7+OvC6mT26d9wjM0sB2rh7YbjRiYgkh3oTGGb2G3e/ycyep3ZlGne/MKaRiYi0TC8CFcBfguUrgdbARuBR4JvhhJW4/rYzwtKsGeRaPvmey7E7I0pgCEU/vx+fNIrqs0OOzPsZGsxTEsAUM7uO6LX+faCdmf3W3X8ZclwiIglvfy0w/hzc3x+PQEREBIBz3f2kasuLzGyBu59kZmNDiyqB5ebCww9HeLUkQkYG/CA37IgkEQydGKF0UirpVFSVtaKcD4dO4IT500KMTISB7l5oZv9GNGl9OzAfUAJDROQA6k1guPv84P71+rYREZEml2pmw939PQAzO5mvBncrDy+sxBWJRMftzM+PJjM0fqfs9WGncxi2tebsIwMXPAoogSGhSjezdOBbwO/dvczMarV2FhGR2g44BoaZ9QemAAOBzL3l7n5kDOMSEWmpvgdMM7M2RCdPKASuMbNsotdiqUMkosSF1Hbyljm4WY2yNJz5U/IYOlFvGAnNn4DVwIfAG2Z2BNFrvYiIHEBDZiGZDvyR6C9/XwMeB2bEMigRkZbK3d9390HAEOAEdx8clO1291khh5dY8vJg0qTovUg9VthRtcp6/Pz7IUQiEuXuD7p7L3c/36PWEK1ji4jIATQkgZHl7q8A5u5r3P0u4BuxDUtEpGUys/Zm9gDwCvCKmf3KzNqHHVfCycuDsWNh6tTovZIYUo9Vs5fXGom8c8m6UGIRATCz7mb2iJm9GCwPBMaFHJaISFJoSAKjJJjiabmZ3WBmFxOdw1pERJreNGAncHlwKyTaEk6qy8+nbHcJhZXZlO0uiQ6AIVKHSATy02t2F0mnjE8nqEeWhOZRYA7QM1j+FLgprGBERJJJQxIYNxKdwu+HwFBgLMoSi4jESj93v9PdVwa3nwMac2gf89vmsqMoA9+1mx1FGcxvmxt2SJLA5v58DjvJrlpOAfpNv0MtdySuzGzv2HNdgi6BlQDuXg7VpssJiUYRFZFksN8EhpmlAle4+y53L3D38e5+ibu/G6f4RERamiIzO33vgpmdBhSFGE9C+tvOCP+eNYNHs6/n37Nm8LedGpBR6jdxIpR8NQ45ACk4i2/RbCQSV+8F97vNrDNBzsDMTgF2hBYVYNiBNxIRSQD1zkJiZmnuXl69Ii0iIjF3HfB4tXEvtqFWb7Xk5sLDD0d4tSRCRgb8IDfsiCTRfXLUhZy+omZvrOzFc0OKRlqovVmCHwHPAf3M7G2gK3BpaFGJiCSR/U2j+h5wEvCBmT0H/BXYvXeluz8T49hERFocd/8QOMHM2gXLhWZ2E/BRqIElmEgEZsyIDn2Rm6spVOXAzlg+jdUpr3GEr64qO6JyNZ9OmMLR0yaGF5i0JF3N7EfB42eBfxJNapQA56LrvIjIATVkDIxMYAtwNnAB8M3gvlHMLNXMPjCzFxq7LxGR5sbdC929MFj80X43bqEiEZg8WckLabgt9/yJimpVHwf8uefDC0hamlSiA+G3BbKJ/pCYSnSsubaN3bnq1iLSEuyvBUa3IEv8MdHP+Oqd45pinJ8bgaVAuybYl4hIc6bOySJNYOjECP/47TjO+2J61T/VirQBHBNqVNKCbHD3/4rh/lW3FpFmb38tMPZmifdmitvscztkZpYDfAN4uDH7ERFpITQ4vEgTSX98Gn9OHU8lhgNnfTGT+VM0G4nERcyS0apbi0hLsb8WGLHMEv8GuI0maC4nItIcmNlO6k5UGJAV53BEmq1IBD5os5KUHdF/t2z2kPnryTBRfZEk5s6J4b5/g+rWItIC7K8FRkyyxGZ2AbDJ3ecfYLtrzWyemc3bvHlzLEIREUkY7t7W3dvVcWvr7vtLNovIQepQuqnGcp8v3w8pEmlJ3H1rLParurWItCT7S2DEKkt8GnChma0GngLONrMZ+27k7g+5+zB3H9a1a9cYhSIiIkkhLw8mTYreizTSu0d9t8Zya98Do0aFFI1Io6luLSItRr0JjFhlid19orvnuHsf4ErgVXcfG4tjiYhIM5CXB2PHwtSp0XslMaSROt8/kTJSa5RV6n0lSUp1axFpSRoyjaqIiEh48vMp211CYWU2ZbtLID8/7IgkyUUisJbeNcoM2JTRK5yAREREpEFCTWC4e767XxBmDCIiktg+3diWsj3lpO7awY6iDOa3zQ07JGkGHjjqT7XKupSuDyESkaajurWINHdqgSEiIokrL4+eM3+NA4bz+1Y387edmi1CGm/q8gh7yKhRVkp6SNGIiIhIQyiBISIiiSs/n7SKEgqtPWWk0yFlJ7m5YQclzcXdJz1HZbXlVpTx6YQpocUjIiIi+6cEhoiIJKz5bXPZVZpBa99NKRn0uDKXiBpgSBOZMj/CevtqLAwDuvz51+EFJCIiIvulBIaIiCSsv+2M8O9ZM3g0+3qubT2Dj3ooeyFN68t2R9ZY7li+Wa0wpEVy97BDEBE5ICUwREQkYeXmwtvZEX6WOpm3syPqPiJN7sUhk2p0IwFIf+rPocQiEhazsCMQEWmYtLADEBERqU8kAjNmRGdOzc1F3UekyQ2bFGHR64M4gUVVZZvoRt8QYxKJt48KdoQdgohIg6gFhoiIJLRIBCZPVvJCYiMSgVci97Ob1lSQwm5as+rKSWGHJSIiInVQAkNEpJkzs1+a2Sdm9pGZPWtmHaqtm2hmK8xsmZmNqlY+OihbYWa3hxK4SJz8eE6EF8Y/yxM9f8IL45/lymnKlomIiCQiJTBERJq/l4Dj3X0w8CkwEcDMBgJXAscBo4E/mFmqmaUCU4HzgIHAmGBbkWbrymkRxq2bzJVXApMmQV5e2CGJiIjIPpTAEBFp5tw9z93Lg8V3gZzg8UXAU+5e4u6rgBXA8OC2wt1Xunsp8FSwrUjzlpdH6eVjKf3FA1Sedz5MmBB2RCJxpZlIRCTRKYEhItKyTABeDB73AtZWW1cQlNVXXouZXWtm88xs3ubNm2MQrkj8rJyeT+WOQtIrSrDKCnz6dJiiKVWl5SivVAJDRBKbEhgiIs2Amb1sZh/Xcbuo2jZ3AOXAE011XHd/yN2Hufuwrl27NtVuRUKR77mkU1KjbNvPfh1SNCLxV16hBIaIJLakn0Z1Z3EZbTPTww5DRCRU7n7u/tab2dXABcA5/lUb4XVA72qb5QRl7Kc8dvLyNF+qhCpnQoTymWm0oryqrHX5thAjEomv8spKIDXsMERE6pX0LTAKthWFHYKISEIzs9HAbcCF7r6n2qrngCvNLMPM+gL9gfeA94H+ZtbXzFoRHejzuZgGmZcHY8fC1KnRew2gKCGIRGA7HWuUpVOu96O0GGqBISKJLukTGBprSETkgH4PtAVeMrOFZvY/AO6+GJgFLAFmA9e7e0Uw4OcNwBxgKTAr2DZ28vOhpASys6P3+fkxPZxIff7e5+ZaZYtvmR5CJCLxpzEwRCTRJX8CA11oRUT2x92Pcvfe7j4kuF1Xbd097t7P3Y9x9xerlf/T3Y8O1t0T8yBzcym1DIq27qbUMqLdSERC0OdPE/mQQQBBDcNYv051DWkZKpTAEJEEl/wJDF1nRUSSXh4RxjKDqX49Y5lBHhoDQ8IRicArkfvZQXsqSKECI7NT67DDEomLsorKsEMQEdmvpE9giIhI8svPhzke4YHOk5njEfUgkVD9eE6ERUd9m1QqSaWS01dMp2DUhLDDEok5tcAQkUSX9AkMtcAQEUl+ubmQkQG7d0fv1YNEwtZt2ycAWLDcM+9RDeYpzV50FhIRkcSV9AmMj9ZtDzsEERFppEgEZsyA66+P3msWVQnbgp7frEpeABjOF1fdElo8IrH0x387CdAgniKS+JI+gXHHsx+HHYKIiDSBSAQmT1byQhJD5/snUkyrGmVtvlgRUjQisZWaEk3XaRpVEUl0SZ/AEBEREWlqkQissGNqlGVSom4k0iylp0a/EqgFhogkOiUwREREROrw2PH3U1GtI4lRyYbJ00OMSCQ2vmqBoTEwRCSxKYEhIiLhycuDSZP0q7YkpMj9EdZwRNWyATveXRxeQCIxkpYaJDDUAkNEEpwSGCIiEo68PBg7FqZOjd4riSEJJhKBUrJqFpaWhxOMSAylpQRdSDQGhogkOCUwREQkHPn5UFIC2dnR+/z8sCMSqWXxSd/Fg24kjvHxid8NOSKRpvdVCwx1IRGRxJaUCYxLh+aEHYKIiDRWbi6llkHR1t2UWgbk5oYdkUgtl86fyDMn3cO8tJE8c9I9XDp/YtghiTS5NM1CIiJJIikTGCIikvzyiDCWGUz16xnLDPLQ/KmSmC6dP5GTy95h8AmwutepfDphStghiTSpqi4kGgNDRBJcWtgBHIo2GUkZtoiIVJOfD3M8wludI+zeDUflR8ccEElEn06YwlHTJ2GAT/8XnwJHT1NrDGke1IVERJJFUrbA6NE+M+wQRESkkXJzISMDdu+O3qsHiSSyrKf/XDWhqgEdnvpjmOGINKm9XUheX7Y55EhERPYvKRMYbTPVAkNEJNlFIjBjBlx/ffRerS8kkX1p3Wosdypar5lzpNlIsWgC46/zC0KORERk/5IygWFVv4GIiEgyi0Rg8mQlLyTxvXjiJMpJrVpOoYINk6eHGJFI08lW92wRSRJJmcAQERERiadhkyK8zekARIc5NFau1ICH0jx0bZvB4Jz2nHh4h7BDERHZr6RMYJgaYIiIiEgcRSLwwqBJ7KA9pbSikHa8fuSEsMMSaTI5HbPYWVwedhgiIvuVlO3FlL8QERGReIvcH2H8xbMYUZzP3MxcfjBJfZ+k+WiVmkJZhWYhEZHElpQJDBEREZF4i0SAZyPk50f4Qa7GbpHmJS01hbJyJTBEJLElZQJj3y4k67cX0bNDVjjBiIiISIsRiShxIc1TcVkF63cUs3FHMT3aZ4YdjohInZJyDIx9zVm8MewQREREpAWZPyWPhQOvZEPuGE2nKs3CPxZtAGDqaytCjkREpH7J2QJjn1Ew1mzZE1IkIiIi0tLMn5LHUZMupx07YCmUv/k30l58QU0zJKm1Sk2hpLySStfsOiKSuOLeAsPMepvZa2a2xMwWm9mNB7+TmovlleqvJyIiIvFR+Hw+2RRWLadWllH4/VvCC0hatCapWwOt0qJfCyqVvxCRBBZGF5Jy4MfuPhA4BbjezAY2ZocF24qaJDARERGRA2n3zVyMmt/yyj9fF1I0Ik1Tt26VuvdrgTIYIpK44p7AcPcN7r4geLwTWAr0Oph97DuNav6yzU0UnYiIiMj+DZ0Y4UM7qUZZUaUGPZRwNEXdGr5qgVFeoQSGiCSuUAfxNLM+wInA3DrWXWtm88xs3ubNNRMUqSn7pjBERERE4mfZEaOoqPaTSk/Ww4QJIUYkcuh1a4D0oAVGiaZSFZEEFloCw8zaAH8DbnL3wn3Xu/tD7j7M3Yd17dq1xroLBvdk/Gl94hOoiIiIyD6KRuSSsk9T+51PPBdSNCKNq1sDePB+3lNaHutQRUQOWSgJDDNLJ3qBfcLdnznY57dKS+HObx7X9IGJiIiINEDOhAir6FOjbHV5z3CCkRavsXVrgAcuHwJAZnpq0wUmItLEwpiFxIBHgKXu/kBT7feTjbUSzSIiIiIxEYnAz7v/iWIycKCcFF5sNybssKQFaqq69cl9OnFC7w6s3boH11SqIpKgwmiBcRrwXeBsM1sY3M5v7E5H/+ZN+tz+D86+P59dJeW68IqIiEhMjX08wt0pd1JKBk4K399+H/On5IUdlrQ8TVa3PuvornxYsIO5q7Y2bYQiIk0kLd4HdPe3qD2RSJNZ+eVujr9zzn63WfJfo8hKTyWasBYRad7M7L+Bi4BKYBNwtbuvD361+y1wPrAnKF8QPGcc8NNgF3e7+2Pxj1wksUUikN3rI1qtLQWgLYWk/Xk6TIyEHJm0JE1Zt/73M/ry4CvLufKhd7nkpBzuufh4np5fwPurtzKoV3tO7deFgT3bNcWhREQOSdwTGE3pk/8ezYD/nH3Qzxv4s7oTHN8/80hGH9+DgT3bkZEW7f+3tyWHkh0iksR+6e7/CWBmPwR+BlwHnAf0D24jgD8CI8ysE3AnMAxwYL6ZPefu2w7qqHl5kJ8PubnRb3oizVCHDg5rv1pOS1MLUElebTPTqx7/bUEBf1tQULX894Xra2x72dAc2mWls2lnCVefegStW6VxTPe2pGi2QBGJoaROYDT1IEN/emMlf3pj5X63mXHNCN5a8SWjj+/B4F7tdZEWkYS3z2j02VA1dcJFwOMezdS+a2YdzOwwIBd4yd23ApjZS8Bo4MkGHzQvDy6/HIqL4Q9/gFmzlMSQZmnuwAn0WjSbTIooJou5AyegYcYlmf3f9afxralvH3C7v87/Krnx/IdfJTeuOb0vnbJbceEJPendqTUAxWUVZKSl6AdBEWm0pE5gAHx0V4SfP7ekRoY4lsY+Ep1W+39e/6xGee4xXbn61D4M6NGOTzYWcuxh7ejeLjMuMYmIHIiZ3QNcBewAvhYU96LGb8cUBGX1lde132uBawEOP/zwr1ZMnw6FQd6ktDS6rASGNEM5EyJcO3sWw4vyeS8rl+9N0PtcktuQ3h1Yfe83ANi4o5i2mWnc9reP+MdHGxr0/EfeWgXAL+csq1F+Qk57BvRoR+S47pxzbHd+/+pyBvZsx9kDujftCYhIs5b0CYx2men86vIT+NXlJwCwcO12nl1QwGP/WhPXOPKXbSZ/2eb9bnNC7w58ubOER8efTE7H1hz7s9lcd1Y/bj9vAAAVlU6KqbuKiBw8M3sZ6FHHqjvc/e/ufgdwh5lNBG4g2kWk0dz9IeAhgGHDhnm1FbhHm3oYYBpYWZqpSASYFSE/P8JP2uYxNH8SkKuEnTQLPdpHf4yb+p2T+NVlFWzfU0aP9pk8kLeM6e+s5huDDuOp97/Kd5/RvwtvLv+yzn19WLCDDwt2MHPe2hrlx/VsR3ZGGtv3lPLpF7v4+sDuvLdqK/N/ei4PvrKcPl2y+daQXmr1LCIAWDLM1jFs2DCfN2/eIT9//fYilqwv5HuPH/o+Yu24nu1YvD76a+XT141k3fYizuzflaxW0W4ympNbJLGZ2Xx3HxZ2HAdiZocD/3T3483sT0C+uz8ZrFtGtPtILpDr7t8PymtsV5/q1+r5U/I4atLlZFBECVmsmDyLoRrYUJqzvDxKLx9LRXEJqZkZtJo1Q0mMBJQs1+pYa2zdui47ispon5XOG59u5qpp75GZnkJxWSUZaSmUlFce9P46tE5n+56yquU2GWmkGAw4rB2PjBtGRaWzs7ickvIKfjF7GQ+OOVH1ZZFmpL7rddK3wGiInh2y6Nkhq6o53F4frt2OA7M/3lirS0i87U1eAFz6P/+qtf6yoTnM/3wb153Vj3OP7U6n7FbxDE9EkpiZ9Xf35cHiRcAnwePngBvM7Cmig3jucPcNZjYHmGxmHYPtIsDEgznm33ZG+DhjFmdU5vNmSi7H74wwtAnORSRRrZyeT+fCElLcSS/ZwpZbJtP5IyUwpOVonxUdAPTUfp257qx+XHN6X7q2zaha7+489+F6fvvyclZ+ufuA+6uevADYVVIOwHurtjLortrTFf8h/zM27igiNSWFwzu1ZsWmXdx/2eAaLZsrKqM/3KaqNYdI0moRCYz6nNC7AxDt67e3GwdAwbY9dG2bweadJcz+eCPrtxcz7e1VIUUZtXegpNue/qiq7LbRxzDquB4s27iT8wcdFlZoIpL47jWzY4hOo7qG6AwkAP8kOoXqCqLTqI4HcPetwdSr7wfb/dfeAT0bqm1beKE0wvMewQxGtm2K0xBJXPmeyxX+IK2JfjHruOh1mDIFJh5U7k8k6aWlptSoV+9lZlw0pBcXDYkOqbRpZzF7Siro1KYVm3eW8M6KLxlwWDvGTXuPPaUVB33cB19ZXqvsOyMOp0PrdJ6eX8Af86M/VnZsnc4HP1NyUSRZtYguJE3J3VmzZQ/PLCjgk407GXpER6a8+MmBnxgnXzumK20z03lwzIlhhyLSoqhZcs1r9aRJ8Nvfghm4w403wuTJIQcoEkN5eTBkVDe68tV4WDva96bD9s9DjEr2pWt1VCLVreuyo6iMkrIK0lJT+LBgO187phs7i8vISEvl6J++WGPbE3La82HBjoPaf/d2Gfz3RcfTKbsVh3duTbe2mVRUOnc+9zFXn9qHo7op6y4Stvqu10pgNLEvd5VQWFTGY++spnObDK44uTcP5H1aa8CiePrjv53E8L6d+PO7azijf1eOPawtrVu16MY3Ik1OleKa1+q8PBg7FkpKICMDZmg4AGkBNlnNBMZmutLNN4UYkexL1+qoZKpb72vJ+kI6B602Nu4o5tyB3Zm7cguFxeXcN/sTVmza1ehj/PDso/jWib1Yu62INhlpDD2i44GfJCJNSgmMBOHuzF21lWsfn0dhcXlocQzq1Z4Terfn7m8NCi0GkeZEleLa1+q8PMjPh9xcJS+kZXgjNZczKl+vWn4z5SzOrMgPLyCpRdfqqOZUt67u43U7mP72an5x6WB++8pyCovKWLh2O5cNy+GOZz+u2q53pyzWbi1q8H7bZabx3ZFHsHZrET/75kDKKirZU1pBv65tYnEaIoISGElhT2k5P/v7Yp6eX8Dxvdrx8brCAz+pCY0beQTfP6sfPdplaqoqkYOkSnHLuVaL1OdXo/L4ft63yaSIYrL4U+QZfjxH2btEomt1VEu8Xn9RWMyukvKqpIO78+R7a5n07KJG7XfyxYP41ok9KSqtoHObjAM/QUQaRAmMJOXunPPA66zcvJtBvdqzaN3B9fE7VH+//jT6d29DVnoqm3eW0K1dZlyOK5KsVClu2ddqkb1+NSqP9LfzKTstV8mLBKRrdZSu11/ZsquEh99axY++fjTpqSls2lnM8HteOaR9nX5UF/58zXDMjG27S8lqlaqpXUUOkRIYzZC703fiP+N6zKeuPYVhR3QkLTUlrscVSXSqFOtaLVKD+lAlJF2ro3S93r9dJeXsLimn+z4/4FVWOpXu/P61FTz7wTrWbNlzwH394pLBfH1gd771h7c5Z0B3fvbNgbEKW6RZUQKjBXj+w/X8x5MfcMPXjuKJuWvYts/82bFw4uEduDVyDKce1SXmxxJJZKoU61otUiUvj9LLx1JRXEJqZgatZmkU20Sha3WUrtdNZ/POEkb95g227i5t0PZ/+fcRjDyyM7tLK6iodN5e8SXnHd8DM3XfFqmuvuu1pqJoRr55Qk++eUJPAG4ZdUxVecG2Pfz+1RU89X7Tz4Tywefb+c7Dc6uWn/z3Uzjx8A5kpqeyYtMujujcmnS11hARkRZk5fR8uu/YjZNCZcluCqbnc6QSGCLNUte2Gcz/6bn85uXlrNi8iwVrtrFhR3G923/nf+fWWT68byd+/50T6dZW3bZF9kcJjBYgp2Nr7r1kMPdeMpi3V3zJcT3bcevTH/HSki+a/Fhj/vfdOst/ePZRnHVMV1Z9uYdLh+Y0+XFFJAGsWxdtNq8vatLCfbqhLX0oAqKtXLcs3siR4YYkIjFkZtz89aOB6Jga//bwXAb2bMeIvp047aguTHxmEW8u/3K/+3hv1daqsTdevzWXIzpn85e5nzOkdwcG9mwX83MQSRbqQiJs2VXC4vWFXDXtvbge9/EJwzkhpwOpqUabDOXSJLmpWTIMM/N5rVvDs88qiSEt2ju5kzjx9QfIoAQDylIyaPXic/q/SAC6Vkepbh1/23aXcsqUVygpr2zQ9od3as3nW6NjbHzv9L7MfH8tj1x9MpXupKYYJ/fpFMtwRUKnMTDkoDz2zmrufG5xXI85+eJBvLl8M93bZXLN6X3p3al1XI8v0hiqFAcJDICzzooOXijSQk27Mo/vzPwmGUT7xDvwxVlXcFj+U+EGJrpWB1S3Dt/uknIu+59/sWRDIYNz2vNRwcHNNPjCf5xO5zateHflFo7q2pZBOe1jFKlIODQGhhyUcaf2YdypfWqUNWZaqYaoPg/3o++srrHuh2cfxc6Scr41pBeV7sxdtZWvD+xeNZe3iCSQTZvCjkAkVDkTIrw7cyRn8joQHZhv5UrjsHDDEpEEkp2Rxt9vOI2KSiczPZU+t/+DIb070DYz7YDdTQAu+N1bdZbfdG5/zujfhXdXbuXwTq0ZnNOePaUVdG7TinaZ6Sxev4OhR6j1hiQvtcCQg1ZcVoEZlJRXMviuvLDD4aqRR7Dqy91895QjKNhWRE7HLM4e0I0UM1JSEmdE53Xbi/hs0y7OPLpr3I65cvMu5q3ZxuXDetco/3JXCRlpKbTNTD+k/ZZXVLKxsJicjtFWMu5OpUNqtde7uKyCsorKGsdw90MaZXtTYTEl5ZUxbZXzUcF2DmufRde2GYf0fP2qF22B8T6GTb4HJk4MOxyRUN0yOI+fLrqcTIopJpM/nDWLSfnqQhI2XaujVLdOPCXlFaSlpFBSXsHEZxZx0ZCe9OyQxQ9mLGDVl7urtstIS6FVWgo7i8sP+hh9u2Sz6svd5N+SS58u2TXWbd5ZQpc2reqspxWXVZCRlqKZUiSu1IVEYm7Vl7t56v3P2V1Szox3Pw87nFqmjz+Z+178hJyOWRQWlfPe6q08fNUwPlq3gwdfWc6AHm25bFhvjuySTZc2GfTv3oZPv9jJhb9/G4Ap3x7Et0/qRUZaKne/sISH31oFQL+u2fzvVcP46/wCLjkph46t03nwleV8Y3BPBhzWlntf/IS/zP3q9Xhk3DBOPLwjHVuns3ZrEX+dv5YhvTtwzWPzmP/Tc1m3vYjM9FReXLSRy4blMG/NNvp1zSanY2uKSisoLa/k6QUFHN+zHa1bpTH2kbnc++1BXDn8cHYUlfHnf61mzuIvWLSuZlPEU47sxH9eMJA//2tN1Yw03zu9L8s37aK8spJRx/Xgg8+38+wH65hz05nsKinnhr8s4JrT+9KtXSYbdxRxzrHd6dk+i2N/Nrtqv/93/Wl8a2r0Nfrx14/mVy99CkD7rHR2FJVx2dAcLh2awxUPRQd4PfPoruwpKefyYb25/OTebN1dyvMfrue3ryyvMQXZCTntOaVfZ74x6LCqv8H08SezeN0OKh3+X24/fvjUB7y8dBN3ffM4Jj27iJP7dOSEnA6ccXRX2melM6BHW8ZPf58fRY6mX9c23PjUBxRsK+LLnSXsLCln1vdHckTn1iz/YhdjH/lqVPAxww/nW0N6UlRWwR/yP+PSk3JISTFu+euHZKWncvaAbnz7pF4UFpeRlZ7G1wZ0JTM9rcVXigdYG7+YO2g3eaLyF9Li5eXBHy/O48qiaaSmGn3/azxDJyqBETYlMKJUt04uC9duZ09JOace1QWA5V/s5Ou/foMjOrdmzZY9h7TPaVcPY82WPWzeWUJmeioPBPU3gFnfH8mRXbPZsL2YHu0zOfmel/nZBQOZcHrfJjmf+jz85kru/sdSFv98FNkhjo83f802+ndvQ7tD/KHvYJSWV9IqTTM21kUJDImrL3eV8PKSL7j9mUUH3likGVhz3wUtvlJsNsxhHsceC0uWhB2NSPjmT8ljwJ2Xk15RjGVlkv7MLA3kGTIlMKJUt05+1b/4llVUMvvjjXyysZCpr30GcEjjatTlkXHDuOaxeZzcpyMPXD6EHu0zSU9NobLS2bK7dL8tV9dvLyLFjD2l5RzZtQ0bdxTz21eWc9eFA8lISwVg2cad/GL2J/z+Oydx7gOvs257UdUsLA01++ONnHl0F7bvKWPWvLXceE5/zIzpb68iLcW4ZGgOr36yiW8MOqzeViRL1hfSq0MWGekpDPjP2ZxyZCeeunZkjW3yl23i1H5daJWWwsfrdtCzQxadslvV2Gb+mq28vmwz15xxJO2zvkqAFJdV0Co1hZQU44vCYkrLK6l056xf5vObK4bwrRN77fcci8sq2LyzpFZr5AO1bt5ZXMajb6/mmjP6Vr3m/1i0gS7ZrRjapyMZaams/nI3ndq0Yv32Io7u1rZRLdirx7N1d2mt16f6+Vzx0LtcelIvLj+5NxlpqWzaWUzn7IyqFt1KYEhCmLd6K7tLKxgX5xlPRGJNCYyvEhgaw1MkakPuGLq/PrNqOTqQ55MhRiRKYESpbt18bdlVQuc20aTCmi27STGjd6doK97qLWibyuSLB3HaUZ2rEg6LCnZQXlnJ6i27uXnmh1XbXXxiL579YB0AE07rS5e2rTh7QDcuePAtyiudEw/vwMYdxWzYUcwvLh3MsT3acfszH5GVnsrj1wznuhkLuG3UMWzeVcLEvy3iqWtP4e5/LOXlpV8AkNMxi4JtRQB0bZvBib07kLfkixqx3nfJIDLTU0kxY1dJOWOGHw5Ev+QPuiuPfl2z+cu/n8KIydEx/24ddQy/nLOMa07vS2l5JX9+dw0A13+tX1WiaNFdEdZvLyZv8Ua27Slj2turar1GkYHda8Wyr0V3RVi2cSevf7qZUcf1YPPOEgqLy4gM7FHj75aZnsKp/brw6idfjTdWvcVKUWkFO4rKmL9mG1v3lPLsggIWfL69zmNec3pfLhuWw+jfvFlVdubRXTmxdwc6tE7n+Q/X84tLB7P8i120z0rn1U82kZ2RxogjO/GXuZ8z/rQ+/CrvU/61cgt5N53JU++v5ZG3VnHD147ik407eXnpF4w+rgf/72v9OL5ne3736gp6d8ri2yflMPiuORTW0w1q0vkDuPrUvmSkpyqBIYmjsLiMgq1FrNtehAHvfLaFrFYp5C3+guWbdoUdnshBUwIjmsBo3XqeZlEVCbx9+JWMXDuravlfvS/ntM81E0mYlMCIUt26ZVq6oZCNhcUM6tWeDduLeejNlQzu1Z57/rk07NAOWo92mWwsLG70Psxgw47G7UeaXlZ6Kp/cfZ5mIZHE0S4znYE90xnYsx0A5w7sDsCtowYA0UEiz3/wTTbvLOHkPp0OmLUUkfD16AGPPabkhcherx85gePWziaTIorJ4vUjJ3Ba2EGJSIt17GHtOPawaN27S5sMfjfmRAAuG5ZDu8x0CovLyM5I44PPtzNvzVZ+MXsZAGkpRnllbH/0TjE4mEM0NnnRVPs4VGaQBO0IQlNUVlHvOo0YIgkpLTWFvJvP4oOfRXjoqmGsvvcbzLhmBFO/cxKr7/0Gy+4ezdHdNYWqSCLp1UvJC5Hqhk2KML71LH6T8mPGt57FsEn6BxGRxNOhdStSUowOrVuRnprC8L6d+H+5R7H456P4y7+PYMXk8/nkv0dz5cm9GXVcd+44/1g+m3w+H94ZoUubr8bAyEhLYeSRnfnrdV+NHTHp/AF8/PNRdG9X/1gZs286g0/vPo9LTsqhf7c2DOrVvmrdwCDh8qfvDuWUI6PTvz7xvREHPKeju7fhtKM6H/Rr0RAdWn81tsUj44bVO87D/iz46df5+sDu/Gvi2dx/2QlV5f8vt1+dMxb279aGh747lCM61xwD49ZRx9C6Vep+j7X3NdzXdWf147zje9T7vJ7tM/n1FSfUue5/xg6tsXxk12xuPKd/1fLxvdrt9/va/sZOObJLNtOvPrne9epCIs1GYXEZbVqlUenOjTMX8o+PNgBw4zn9+e0ry0OOTpo7dSHRtVqkLnl50TFhLmmbx9Cd+ZCbq0xfiNSFJErXa2kqxWUVPLNgHd8+qReZ6TW/SO8pLScrPRULBvL8zcvLufGc/ny2eRcX/v5tBvRoywv/cTppqSm1njfxmUXcft4AurfNBKg1sOSs99fSpW0rjunRjh/NXMik84+lW7sM7npuMcf3bM8Vw3vTrW0mZRWV/On1z8g9phtrt+6htKKSHUVl/OzviwF49v+dyl/mfk5JeSXb9pRy6dAcdpVEx2a449mPOffYbvxk9AA+37qHh95YyU/OG8BJh3dkxaZdHNY+s2rsibKKSi548C027Szm6R+cSklZJa9+8gWnHdWFEw/vyI1PfcCrSzdx6bAcrj3zSA5rn1XjfNZu3cPnW/dwWjDTzN7XdsB/zubcY7vz8Lial63NO0uYv2Ybo4MExJ7Sct5btZXcY7oxb/VWfjTrQ359xRCO69mO4rIK/vfNlVw0pBd/nbeW/30zOk7H6nu/UbW/Prf/A4jOTjOsTyfaZqRVDcZZVlHJik27OKZ7W179ZBPDj+xEu8x0+k78B+6w9L9GkxUkUZ5ZUMBtT3/E3EnnVI3F8sf8z2iflc6o47pTUel0bhMdqLO0vJKVX+5iy65SOrZuxfkPvlkjLg3iKS3a+u3RQX16dsiivKKSTzbupKS8gsE5Hfj7wvX0aJdJikFxeQUvLtrIpp0lvP7pZgAeHX8yC9du5/SjuvDch+t5/F/RAXxO7tORG885GjP4wYz5fHfkEazYtIt7vz2Y9TuK+MaDb9WK44Sc9ny4z4jQQ3p3oKS8kqUbCuuM/b5LBrGntIKfP197WodfX3ECs94vYN32Ij7f+tU0Wr06ZLGjqIxLTurFKUd25stdJWzZXcqo43qQkZbC2b96HYAfff1oHnjpU3p1yGJd8BpVd2SXbFYGc4+fcmQnPv1iV42pTve1N1l0VLc2fGf44WzbU0p6akrV1FxnD+hGaorxr8+2sKuknP7d2rB80y66tGnFl7vq3y/AGf27sHlnCTuLy6tibZWWwl3fPI6/vLeGvl3a8PyH6+nSphXH92pP/rLNtfZxeKfWfL51D1npqVVN0y4bmkObzDQKi8r524IC+ndrw03nHs2KTbv49Iud/GPRBo49rF2Nv88pR3ZiUK/2/O+bqxgzvDcDerTj6tP6tvhKsa7VIvXIy6Ps4suhuAgys0h/VrORhEUJjChdryVslZXeqNkuGqusopLisgra7meq1L3fk/c3y0esLdu4k96dsmjdqulGfnht2SZap6cy4sivWqi8uGgDCwu2M/G8Yxu8nx1FZeDQvnXTTDc75L/yGHlkZ/4YtO5QAkMkzjbtLCYtJYVO2a0oLqtg9ZbdDOhRdxMuiE6HtWRDIUN6d6hzfWFxGWkpRutWaRQHX76rZ7pfXvIFI/t1btC82XVNubR0QyGds1vRrV0mxWUVLFy7nVOO7MyOPWWUVVbSpU0GlZXO4/9azXdGHNHkc1av3bqHjYXFDDys3QHPoTLoJHmgD76P1+1g5Ze7Oa5nO/p13X+XI3fnX59tYWS/zvV+UK3+cjd9utQ9rZcqxbpWi9RnQ+6VdH99FuAYsHXQWXT+KD/kqFomXaujdL0WkURX3/Vag3iKxEi3oMkbRBMN+0teQLQ1QX3JC4gOfFp9f/vaOxBqQ9T1Bf3Yav3jMtNTOSXIylbPqqakGFef1rfBxzkYvTu1rjW3dX0amrE/vld7jq/Wj3J/zIxTqzXbq0t9yQsRkf1ZudLoHiQvANp+/G60b4laYYiIiBwUDeIpIiIiEkOvHzmeUqKDvDlGqaeycnp+uEGJiIgkISUwRERERGJo2KQId6fcxR5aU0IrUoBPN7QNOywREZGkowSGiIiISAxFIpB990TuS/8plaTgwNkLfx3tRiIiIiINpgSGiIiISIxNnAhXX7KT1BQjJdVIKd4dnV9VREREGkwJDBEREZE4KM9qS6vKIjIqdpNSUsSnG9WNRERE5GAogSEiIiISB4vf3ckesiijFY5R9sKcsEMSERFJKkpgiIiIiMTB0m65gNGKUlKo5NjNr8OUKWGHJSIikjSUwBARERGJg2GTInzO4QBUYgAU/PH5MEMSERFJKkpgiIiIiMRBJAKzu34Xx4K5SIzn+WbYYYmIiCSNUBIYZjbazJaZ2Qozuz2MGEREWhoz+7GZuZl1CZbNzB4MrsUfmdlJ1bYdZ2bLg9u48KIWaV56XjCUPWRRQQp7yKLjuUPDDkmaAdWtRaSliHsCw8xSganAecBAYIyZDYx3HCIiLYmZ9QYiwOfVis8D+ge3a4E/Btt2Au4ERgDDgTvNrGNcAxZppoYX5VNBGpvoTgVpDC/KDzskSXKqW4tISxJGC4zhwAp3X+nupcBTwEUhxCEi0pL8GrgN8GplFwGPe9S7QAczOwwYBbzk7lvdfRvwEjA67hGLNEP5nkupZdCBHaRTzqcbNJWqNJrq1iLSYqSFcMxewNpqywVEf+WrwcyuJfqLIECJmX0ch9iaUhfgy7CDOEiKOT6SMWZIzrjjGfMRcTrOQTOzi4B17v6hmVVfVdf1uNd+yuvad/Vr9S4zW9ZUcR+EZHxvNkZLOt9meK4d2vUgq99hFKWAUfn6HZVjbNJn26GQZnm+9QrrXBP2Wt0IqlsnLsUcH4o5fkKvW4eRwGgQd38IeAjAzOa5+7CQQzooijk+FHP8JGPcyRjzoTKzl4Eeday6A5hEtPtIk6t+rQ5LS/o7Q8s635Z0rtCyzrclnWuiUN06/hRzfCjm+EmEuMNIYKwDeldbzgnKRETkELn7uXWVm9kgoC+wt/VFDrDAzIZT//V4HZC7T3l+kwctIiJNQXVrEWkxwhgD432gv5n1NbNWwJXAcyHEISLS7Ln7Infv5u593L0P0abFJ7n7RqLX3quC2UhOAXa4+wZgDhAxs47B4J2RoExERBKP6tYi0mLEvQWGu5eb2Q1EK8OpwDR3X3yAp4XaPPkQKeb4UMzxk4xxJ2PM8fRP4HxgBbAHGA/g7lvN7L+JVooB/svdt4YTYoO0tL9zSzrflnSu0LLOtyWda0ypbp3QFHN8KOb4CT1uc/cDbyUiIiIiIiIiEqIwupCIiIiIiIiIiBwUJTBEREREREREJOEldALDzEab2TIzW2Fmt4dw/Glmtqn6PNlm1snMXjKz5cF9x6DczOzBINaPzOykas8ZF2y/3MzGVSsfamaLguc8aMEUAY2MubeZvWZmS8xssZndmOhxm1mmmb1nZh8GMf88KO9rZnOD48wMBqbCzDKC5RXB+j7V9jUxKF9mZqOqlcfkvWRmqWb2gZm9kEQxrw7+fgvNbF5QlrDvj2CfHczsaTP7xMyWmtnIRI9ZwmFmPzYzN7MuYccSK2b2y+B/4SMze9bMOoQdUyzE6hqYaKyez+3mbt/PT4mPRP2/qu//4FA+60OIvdF1wTjH2yR1qjjHfHPwvvjYzJ606HeHhHudLcbfHeMYc731DIvz95Y6uXtC3ogOQvQZcCTQCvgQGBjnGM4ETgI+rlb2C+D24PHtwH3B4/OBFwEDTgHmBuWdgJXBfcfgccdg3XvBthY897wmiPkwojMMALQFPgUGJnLcwX7aBI/TgbnB/mcBVwbl/wP8IHj8/4D/CR5fCcwMHg8M3icZRKeN/Cx4H8XsvQT8CPgL8EKwnAwxrwa67FOWsO+PYJ+PAd8LHrcCOiR6zLrF/0Z0GsE5wJp93+PN6UZ0Vpi04PF9e9/7zekWy2tgot2o53M77LjicN41Pj91i8trnrD/V/X9HxzsZ31IsTeqLhhCvI2uU8U53l7AKiCr2ut7dSK+zsT4u2McY66znkEI31vquiVyC4zhwAp3X+nupcBTwEXxDMDd3wD2HXn/IqL/+AT336pW/rhHvQt0MLPDgFHAS+6+1d23AS8Bo4N17dz9XY++Ix6vtq/GxLzB3RcEj3cCS4n+4yds3MGxdwWL6cHNgbOBp+uJee+5PA2cY2YWlD/l7iXuvorozArDidF7ycxygG8ADwfLlugx70fCvj/MrD3Ri+sjAO5e6u7bEzlmCc2vgduIXj+aLXfPc/fyYPFdICfMeGIk9DpAvOznc7vZ2vfzU+ImYf+vmrD+GldNVBeMmyasU8VbGpBlZmlAa2ADCfg6x/K7Yzxj3k89IyG+tyRyAqMXsLbacgGJ8YHe3d03BI83At2Dx/XFu7/ygjrKm0zQZOpEoi0aEjruoPndQmAT0X/Uz4Dt1f55qh+nKrZg/Q6g8yGcS2P9huiXpcpguXMSxAzRL3d5ZjbfzK4NyhL5/dEX2AxMD5poPmxm2Qkes8SZmV0ErHP3D8OOJc4mEP0Fp7lJ1DpATO3zud2c/Yaan58SH0nxf9XI+mu8/YbG1wXjqanqVHHj7uuA+4HPiSYudgDzSezXubqmqq+GpXo9IyFiTuQERsILfq1NyF/6zKwN8DfgJncvrL4uEeN29wp3H0I0wzccGBBuRPtnZhcAm9x9ftixHILT3f0k4DzgejM7s/rKBHx/pBFt2vZHdz8R2E20CV6VBIxZYsDMXg76v+57uwiYBPws7BibygHOde82dwDlwBPhRSpNZX+f281Jkn9+SowlU/01Sd/LSVenCsaMuIho8qUnkE0MWyTEUqK9tgeSqPWMRE5grCPan3mvnKAsbF/sbToV3G8KyuuLd3/lOXWUN5qZpRO9+D/h7s8kS9wAQTO214CRRJtSpdVxnKrYgvXtgS2HcC6NcRpwoZmtJtpM6mzgtwkeM1CVycbdNwHPEk0YJfL7owAocPe9v0g+TfTDN5Fjlhhw93Pd/fh9b0T7h/YFPgz+J3OABWbWI8x4G6O+c3X3vwOY2dXABcC/BRWi5iZR6wAxUc/ndnNV6/PTzGaEG1KLkdD/V01Uf42npqoLxlNT1ani6Vxglbtvdvcy4Bmir30iv87VNVV9Na7qqWckRMyJnMB4H+hv0RFmWxEdhOW5kGOCaAzjgsfjgL9XK7/Kok4BdgTNheYAETPrGGQQI8CcYF2hmZ0S9Mu6qtq+Dlmwr0eApe7+QDLEbWZdLRjd1syygK8T7fv4GnBpPTHvPZdLgVeDf6zngCstOvpwX6A/0cEZm/y95O4T3T3H3fsE+3vV3f8tkWMGMLNsM2u79zHRv+vHJPD7w903AmvN7Jig6BxgSSLHLPHl7ovcvZu79wn+JwuIDga3MeTQYsLMRhNtsnyhu+8JO54YSdQ6QJPbz+d2s1TP5+fYkMNqKRL2/6oJ669x04R1wbhpwjpVPH0OnGJmrYP3yd6YE/Z13keT1FfjGfB+6hlx/d5SL4/zSLIHcyM6OuunRMdDuCOE4z9JtK9VGdEK8TVE+1C9AiwHXgY6BdsaMDWIdREwrNp+JhAd5GQFML5a+TCiXx4/A34PWBPEfDrRpkkfAQuD2/mJHDcwGPggiPlj4GdB+ZFE/ylWAH8FMoLyzGB5RbD+yGr7uiOIaxnVZpKI5XsJyOWrkacTOuYgvg+D2+K9+03k90ewzyHAvOA98n9ER2VO6Jh1C+9GHTPtNKdb8P5dy1fX+P8JO6YYnWeodYA4nmedn9thxxWnc6/6/NQtbq95Qv5f1fd/cCif9SHFX/Ve5hDqgnGOtUnqVHGO+efAJ0Fd7c9EZ8FIuNeZGH93jGPM9dYzCOG71r43Cw4oIiIiIiIiIpKwErkLiYiIiIiIiIgIoASGiIiIiIiIiCQBJTBEREREREREJOEpgSEiIiIiIiIiCU8JDBERERERERFJeEpgSFIws13BfR8z+04T73vSPsvvNOX+RURaEjO7w8wWm9lHZrbQzEbE8Fj5ZjYsVvsXEWmOVK+WZKYEhiSbPsBBXWjNLO0Am9S40Lr7qQcZk4iIAGY2ErgAOMndBwPnEp1LXkREEk8fVK+WJKMEhiSbe4Ezgl/1bjazVDP7pZm9H/za930AM8s1szfN7DlgSVD2f2Y2P/hl8Nqg7F4gK9jfE0HZ3qy0Bfv+2MwWmdkV1fadb2ZPm9knZvaEmVkIr4WISKI5DPjS3UsA3P1Ld19vZj8LrtMfm9lDe6+ZwbX012Y2z8yWmtnJZvaMmS03s7uDbfpUu9YuDa69rfc9sJlFzOxfZrbAzP5qZm2C8nvNbEnwGXF/HF8LEZFEp3q1JB1z97BjEDkgM9vl7m3MLBe4xd0vCMqvBbq5+91mlgG8DVwGHAH8Azje3VcF23Zy961mlgW8D5zl7lv27ruOY10CXAeMBroEzxkBHAP8HTgOWB8c81Z3fyv2r4SISOIKkgZvAa2Bl4GZ7v763utvsM2fgVnu/ryZ5QNz3f0nZnYj8BNgKLAV+Aw4AWgLrAJOd/e3zWwasMTd7w+efwuwGngGOM/dd5vZT4AMYCrwDjDA3d3MOrj79ri8GCIiCUr1aklmaoEhyS4CXGVmC4G5QGegf7Duvb0X2cAPzexD4F2gd7Xt6nM68KS7V7j7F8DrwMnV9l3g7pXAQqJN8EREWjR330U0AXEtsBmYaWZXA18zs7lmtgg4m2hFda/ngvtFwGJ33xC04FhJ9FoNsNbd3w4ezyB6fa7uFGAg8HbweTCOaIV7B1AMPGJm3wb2NNW5iog0Q6pXS8I7UB8mkURnwH+4+5wahdGM8u59ls8FRrr7nuBXu8xGHLek2uMK9L8kIgKAu1cA+UB+kLD4PjAYGObua83sLmpef/deTyupeW2t5Ktr677NRfddNuAldx+zbzxmNhw4B7gUuIFoAkVERGpTvVoSnlpgSLLZSbQ58V5zgB+YWTqAmR1tZtl1PK89sC24yA4g+mvdXmV7n7+PN4Ergv6AXYEzgfea5CxERJohMzvGzKr/CjcEWBY8/jLoYnLpIez6cIsOEArRAef2bVr8LnCamR0VxJEdfB60Adq7+z+Bm4l2SRERkSjVqyXpKLslyeYjoCJosvYo8FuizcwWBAP+bAa+VcfzZgPXmdlSopXpd6utewj4yMwWuPu/VSt/FhgJfEj0177b3H1jcKEWEZHa2gC/M7MOQDmwgmh3ku3Ax8BGov2eD9Yy4Pq9418Af6y+0t03B11Vngz6bQP8lGjl/O9mlkn0l8UfHcKxRUSaK9WrJeloEE8RERFJWGbWB3jB3Y8POxYREREJl7qQiIiIiIiIiEjCUwsMEREREREREUl4aoEhIiIiIiIiIglPCQwRERERERERSXhKYIiIiIiIiIhIwlMCQ0REREREREQSnhIYIiIiIiIiIpLwlMAQERERERERkYSnBIaIiIiIiIiIJDwlMEREREREREQk4SmBISIiIiIiIiIJTwkMEREREREREUl4MUtgmNk0M9tkZh9XK+tkZi+Z2fLgvmOsji8i0lKZ2WozW2RmC81sXlBW5/XXoh40sxVm9pGZnVRtP+OC7Zeb2biwzkdERFS3FhGB2LbAeBQYvU/Z7cAr7t4feCVYFhGRpvc1dx/i7sOC5fquv+cB/YPbtcAfIVopBu4ERgDDgTtVMRYRCdWjqG4tIi1czBIY7v4GsHWf4ouAx4LHjwHfitXxRUSkhvquvxcBj3vUu0AHMzsMGAW85O5b3X0b8BK1K84iIhInqluLiEBanI/X3d03BI83At3r29DMriX6ayDZ2dlDBwwYEIfwREQOzfz58790965hxxFwIM/MHPiTuz9E/dffXsDaas8tCMrqK69B12oRSSYJdq1uCqpbi0izVN/1Ot4JjCru7kHlur71DwEPAQwbNsznzZsXt9hERA6Wma0JO4ZqTnf3dWbWDXjJzD6pvvJA19+DoWu1iCSTBLtWNynVrUWkOanveh3vWUi+CJomE9xvivPxRUSaPXdfF9xvAp4lOoZFfdffdUDvak/PCcrqKxcRkcShurWItCjxTmA8B+wdyX4c8Pc4H19EpFkzs2wza7v3MRABPqb+6+9zwFXBbCSnADuC5shzgIiZdQwG74wEZSIikjhUtxaRFiVmXUjM7EkgF+hiZgVER7O/F5hlZtcAa4DLY3V8EZEWqjvwrJlB9Br/F3efbWbvU/f195/A+cAKYA8wHsDdt5rZfwPvB9v9l7vvO3iciIjEierWIiIxTGC4+5h6Vp0Tq2OKiLR07r4SOKGO8i3Ucf11dweur2df04BpTR2jiByasrIyCgoKKC4uDjuUhJeZmUlOTg7p6elhh9JkVLcWEQlxEE8RERERabiCggLatm1Lnz59CFpZSR3cnS1btlBQUEDfvn3DDkdERJpQvMfAEBEREZFDUFxcTOfOnZW8OAAzo3PnzmqpIiLSDCmBISIiIpIklLxoGL1OIiLNkxIYIiIiIiIiIpLwlMAQERERkQPasmULQ4YMYciQIfTo0YNevXpVLZeWlsb8+Bs2bCASicT8OCIikrg0iKeIiIiIHFDnzp1ZuHAhAHfddRdt2rThlltuqVpfXl5OWlrsqpazZ89m1KhRMdu/iIgkPrXAEBEREWmm8vJg0qTofSxcffXVXHfddYwYMYLbbruNu+66i/vvv79q/fHHH8/q1asBmDFjBsOHD2fIkCF8//vfp6Kiotb++vTpw2233cagQYMYPnw4K1asqFo3e/ZszjvvPNydG264gWOOOYZzzz2X888/n6effjo2JygiIglFCQwRERGRZigvD8aOhalTo/exSmIUFBTwzjvv8MADD9S7zdKlS5k5cyZvv/02CxcuJDU1lSeeeKLObdu3b8+iRYu44YYbuOmmmwCoqKhg2bJlDBw4kGeffZZly5axZMkSHn/8cd55551YnJaIiCQgdSERERERaYby86GkBLKzYffu6HIshpC47LLLSE1N3e82r7zyCvPnz+fkk08GoKioiG7dutW57ZgxY6rub775ZgDmzp3LiBEjAHjjjTcYM2YMqamp9OzZk7PPPrupTkVERBKcEhgiIiIizVBuLjz8cDR5kZERXY6F7OzsqsdpaWlUVlZWLRcXFwPg7owbN44pU6YccH/Vp0Dd+/jFF19k9OjRTRWyiIgkKXUhEREREWmGIhGYMQOuvz56H48JPPr06cOCBQsAWLBgAatWrQLgnHPO4emnn2bTpk0AbN26lTVr1tS5j5kzZ1bdjxw5Eoi24Dj33HMBOPPMM5k5cyYVFRVs2LCB1157LabnJCIiiUMtMERERESaqUgkPomLvS655BIef/xxjjvuOEaMGMHRRx8NwMCBA7n77ruJRCJUVlaSnp7O1KlTOeKII2rtY9u2bQwePJiMjAyefPJJNm/eTGZmJm3btgXg4osv5tVXX2XgwIEcfvjhVUkOERFp/pTAEBEREZGDctddd9VZnpWVRV49o4VeccUVXHHFFQfc96233sp9991XtTxjxgwi1bIwZsbvf//7quWrr766YUGLiEjSUwJDRERERBLW2LFjww5BREQShBIYIiIiIpIQVq9efdDPefTRR5s8DhERSUwaxFNEREREREREEp4SGCIiIiIiIiKS8JTAEBEREREREZGEpwSGiIiIiIiIiCQ8JTBERERE5IC2bNnCkCFDGDJkCD169KBXr15Vy2bGkCFDOP744/nmN7/J9u3bgeignFlZWVXbDRkyhMcff/ygjrthw4Ya06iKiEjLpVlIREREROSAOnfuzMKFCwG46667aNOmDbfccgsAbdq0qVo3btw4pk6dyh133AFAv379qtYditmzZzNq1KjGhC4iIs2EWmCIiIiINFd5eTBpUvQ+TkaOHMm6desO6jl9+vThtttuY9CgQQwfPpwVK1ZUrZs9ezbnnXce7s4NN9zAMcccw7nnnsv555/P008/3dThi4hIAlMCQ0RERKQ5ysuDsWNh6tTofRySGBUVFbzyyitceOGFVWWfffZZjS4kb775Zp3Pbd++PYsWLeKGG27gpptuqtrfsmXLGDhwIM8++yzLli1jyZIlPP7447zz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5vWvfz177rkn73jHOzj22GP5yEc+smr6s571LG6++WYATj75ZPbYYw922203/vzP/5yVK1c+bHk77bQT73jHO/jt3/5t9thjD5YsWbJq2tlnn81BBx1EVXHUUUfx9Kc/nf3335+DDz6YM844Y+jvVZLUPQsYkiRJY+rcc+Hd726eh2Xp0qV897vf5aMf/eiU81x33XWcdtppfOc73+Hyyy9nzpw5fP7zn5903m233ZarrrqKo446iqOPPhqAlStXcv3117NgwQLOPPNMrr/+eq699lpOOukkvvvd7w7jbUmSeshTSCRJksbQuefC4YfDfffBpz8NJ58Mw7iExCte8QrmzJmzxnnOP/98Lr30Up773OcC8Ktf/YrHPvaxk8572GGHrXp+y1veAsBFF13EnnvuCcC3vvUtDjvsMObMmcMTn/hE9t133+l6K5KknrOAIUmSNIYuvLApXmy1FfziF834MAoYW2211arhuXPn8uCDD64a//Wvfw1AVXHEEUfwwQ9+cK3LG7wF6sTw1772NQ488MDpiixJGlGeQiJJkjSG9tkHNtusKV5stlkzPmw77bQTl112GQCXXXYZN910EwD77bcfZ5xxBrfffjsAd955J7fccsukyzjttNNWPe+9995AcwTH/vvvD8ALXvACTjvtNFauXMltt93GBRdcMNT3JEnqD4/AkCRJGkOLFjWnjVx4YVO8mIk7kP7RH/0RJ510Es985jPZc889edrTngbAggULeP/738+iRYt48MEH2WSTTTjuuON48pOf/LBl3HXXXey6665sttlmnHLKKSxfvpzNN9+cbbbZBoCXvexlfOMb32DBggU86UlPWlXkkCSNPwsYkiRJY2rRouEULo499thJ27fYYgvOneKKoa985St55StfudZlv/3tb+fDH/7wqvGTTz6ZRQNvIgmf/OQnV42/+tWvXrfQkqSRZwFDkiRJvXX44Yd3HUGS1BMWMCRJktQLN99883q/5sQTT5z2HJKkfvIinpIkSZIkqfcsYEiSJEmSpN6zgCFJkiRJknrPAoYkSZIkSeo9CxiSJElaqzvuuIPddtuN3Xbbjcc//vHssMMOq8aTsNtuu/GsZz2LP/iDP+Duu+8GmotybrHFFqvm22233TjppJPWa7233XbbQ26jKkmavbwLiSRJktZq++235/LLLwfg2GOPZeutt+Ztb3sbAFtvvfWqaUcccQTHHXcc73nPewB46lOfumrahjj77LM54IADNia6JGlMeASGJEmSps3ee+/NsmXL1us1O+20E+94xzv47d/+bfbYYw+WLFmyatrZZ5/NQQcdRFVx1FFH8fSnP53999+fgw8+mDPOOGO640uSeswChiRJ0rg691x497ub5xmwcuVKzj//fF7ykpesavvhD3/4kFNIvv3tb0/62m233ZarrrqKo446iqOPPnrV8q6//noWLFjAmWeeyfXXX8+1117LSSedxHe/+92ZeEuSpB7xFBJJkqRxdO65cPjhcN998OlPw8knw5CuJfGrX/2K3XbbjWXLlvHf/tt/4/d///dXTVvXU0gOO+ywVc9vectbALjooovYc889AfjWt77FYYcdxpw5c3jiE5/IvvvuO/1vRJLUax6BIUmSNI4uvLApXmy1VfN84YVDW9UWW2zB5Zdfzi233EJVcdxxx633MpI8bPhrX/saBx544LTllCSNNgsYkiRJ42iffWCzzeAXv2ie99ln6Kvccsst+cQnPsHf/d3fsWLFivV67Wmnnbbqee+99wbg/PPPZ//99wfgBS94AaeddhorV67ktttu44ILLpje8JKk3vMUEkmSpHG0aFFz2siFFzbFixm6Femzn/1sdt11V0455RR+7/d+b9U1MCa89rWv5U1vetPDXnfXXXex6667stlmm3HKKaewfPlyNt98c7bZZhsAXvayl/GNb3yDBQsW8KQnPWlVkUOSNHtYwJAkSRpXixYNpXBx7LHHPmT85z//+UPGv/zlL68a/tWvfrVOy3z729/Ohz/84VXjJ598MosGsifhk5/85KrxV7/61euRWJI0DixgSNIYSjIHWAwsq6oXJ9kZOBXYHrgU+NOquj/JZsBJwHOAO4BXVtXN7TLeBbwOWAm8qarOmfl3Imm2Ovzww7uOIEnqGQsYkjSe3gxcBzyyHf8w8LGqOjXJP9IUJj7VPt9VVb+V5NB2vlcmWQAcCjwTeCLw9SRPq6qVM/1GJI2/m2++eb1fc+KJJ057DklSv3kRT0kaM0nmAy8CPt2OB9gXOKOd5bPAS9vhQ9px2un7tfMfApxaVfdV1U3AEmCPGXkDkqZUVV1HGAluJ0kaTxYwJGn8fBx4B/BgO749cHdVTdwSYCmwQzu8A3ArQDv9nnb+Ve2TvGaVJEcmWZxk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\n",
      "text/plain": [
       "<Figure size 1080x864 with 9 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 500/500 [19:06<00:00,  2.29s/it]\n"
     ]
    }
   ],
   "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_batch 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_batch = p_batch.unsqueeze(1).to(DEVICE), q_batch.unsqueeze(1).to(DEVICE), m_batch.unsqueeze(1).to(DEVICE)\n",
    "            \n",
    "        logP = model_cob(p_batch)\n",
    "        logQ = model_cob(q_batch)\n",
    "        logM = model_cob(m_batch)\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",
    "        m_label = torch.empty(m_batch.shape[0], dtype=torch.long, device=DEVICE).fill_(2)\n",
    "        \n",
    "        loss_cob = loss_crit_cob(logP, p_label) + loss_crit_cob(logQ, q_label) + loss_crit_cob(logM, m_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_batch in iter(test_dl):\n",
    "                    gt_log_ratio_p_q, _, true_kl_p_q = get_gt_ratio_kl(p, q, m_batch, calc_true_kl=True)\n",
    "\n",
    "                    if torch.cuda.is_available():\n",
    "                        p_batch, q_batch, m_batch = p_batch.unsqueeze(1).to(DEVICE), q_batch.unsqueeze(1).to(DEVICE), m_batch.unsqueeze(1).to(DEVICE)\n",
    "                    \n",
    "                    logP = model_cob(p_batch)\n",
    "                    logQ = model_cob(q_batch)\n",
    "                    logM = model_cob(m_batch)\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",
    "                    log_ratio_p_q_from_cob = logM[:, 0] - logM[:, 1]\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",
    "                    m_label = torch.empty(m_batch.shape[0], dtype=torch.long, device=DEVICE).fill_(2)\n",
    "                    \n",
    "                    test_loss_cob = loss_crit_cob(logP, p_label) + loss_crit_cob(logQ, q_label) + loss_crit_cob(logM, m_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([m_batch.cpu().squeeze(), gt_log_ratio_p_q.cpu().detach()]).T)\n",
    "                    scat2.set_offsets(np.vstack([m_batch.cpu().squeeze(), log_ratio_p_q_from_cob.cpu().detach()]).T)\n",
    "\n",
    "                    ax2.set_xlim( -5., 5. )\n",
    "                    ax2.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": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "                    print('iteration: ',i)\n",
    "                    print('KLD: ', true_kl_p_q)\n",
    "                    print('CoB: ', kl_from_cob)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_gt_log_ratios(p, q, m1, 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",
    "    \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "#######\n",
    "with torch.no_grad():\n",
    "    model_cob.eval()\n",
    "    for p_batch, q_batch, m_batch1 in iter(test_dl):\n",
    "        if torch.cuda.is_available():\n",
    "            p_batch, q_batch, m_batch1 = p_batch.unsqueeze(1).to(DEVICE), q_batch.unsqueeze(1).to(DEVICE), m_batch1.unsqueeze(1).to(DEVICE)\n",
    "\n",
    "\n",
    "#         p_batch = torch.from_numpy(np.linspace(-1.5, 1.5, 1000)).unsqueeze(1).to(DEVICE)\n",
    "\n",
    "        logP1 = model_cob(p_batch).cpu()\n",
    "        log_ratio_p_q_from_p= logP1[:, 0] - logP1[:, 1]\n",
    "        \n",
    "        logP2 = model_cob(m_batch1).cpu()\n",
    "        log_ratio_p_q_from_m1 = logP2[:, 0] - logP2[:, 1]\n",
    "        \n",
    "        logP3 = model_cob(q_batch).cpu()\n",
    "        log_ratio_p_q_from_q = logP3[:, 0] - logP3[:, 1]\n",
    "        \n",
    "        true_log_ratio_p_q_from_p = get_gt_log_ratios(p, q, m, p_batch)\n",
    "        true_log_ratio_p_q_from_m1 = get_gt_log_ratios(p, q, m, m_batch1)\n",
    "        true_log_ratio_p_q_from_q = get_gt_log_ratios(p, q, m, q_batch)\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjgAAADQCAYAAAAK/RswAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAAAqgElEQVR4nO3de3xU5bX/8c8iIAHkkgAicnekIAqiiYCAAlEq4qlEf1SxysXSong/FkRLj6AtLQj11+oRW07xguVnxFaRo3gHrEqVixeuokFAAlSQcEcEkvX7Y4Y0gQAhzGTPTL7v12u/MvPsPbPXDIuwePazn8fcHREREZFkUiXoAERERESiTQWOiIiIJB0VOCIiIpJ0VOCIiIhI0lGBIyIiIklHBY6IiIgkncAKHDNrZmZzzWyFmS03s7si7elm9paZfRn5mRZpNzN71MxyzWyJmV0QVOwiIiIS34LswTkI/MLd2wFdgNvMrB1wH/COu7cG3ok8B7gCaB3ZhgFPVHzIIiIikggCK3DcfZO7fxx5vAtYCTQB+gHPRA57BsiOPO4HTPOwD4F6Zta4YqMWERGRRFA16AAAzKwlcD7wEdDI3TdFdv0LaBR53ARYX+xleZG2TcXaMLNhhHt4qFWrVkbbtm1jF7jISVq7di0tW7YMOgyRo1KOSrxbvHjxt+7e8PD2wAscMzsV+Dtwt7vvNLOife7uZnZCa0m4+xRgCkBmZqYvWrQomuGKRFVmZibKUYlnylGJd2a2rrT2QO+iMrNqhIub6e7+YqT5m0OXniI/N0faNwDNir28aaRNREREpIQg76IyYCqw0t0fKbZrFjA48ngw8HKx9kGRu6m6ADuKXcoSERERKRLkJapuwEBgqZl9Gmn7JTAemGFmQ4F1wLWRfbOBvkAusBe4qUKjFRERkYQRWIHj7u8DdpTdl5ZyvAO3xTQoERERSQqayVhERESSjgocERERSToqcERERCTpqMARERGRpKMCR0RERJKOChwRERFJOipwREREJOmowBEREZGkowJHREREko4KHBEREUk6KnBEREQk6ajAERERkaSjAkdERESSjgocERERSToqcERERCTpqMARERGRpKMCR0RERJKOChwRERFJOipwREREJOmowBEREZGkowJHREREko4KHBEREUk6KnBEREQk6QRa4JjZk2a22cyWFWtLN7O3zOzL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\n",
      "text/plain": [
       "<Figure size 576x216 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Set up viz\n",
    "fig, [ax4, ax1,ax2,ax3] = plt.subplots(1, 3,figsize=(8,3))\n",
    "p_batch = p_batch.cpu()\n",
    "\n",
    "p_samples = p.sample([1000])\n",
    "q_samples = q.sample([1000])\n",
    "m_samples= m.sample([1000])\n",
    "\n",
    "ax4.hist(p.numpy(), density=True, histtype='stepfilled')\n",
    "ax4.hist(q.numpy(), density=True, histtype='stepfilled')\n",
    "ax4.hist(m.numpy(), density=True, histtype='stepfilled')\n",
    "\n",
    "scat1 = ax1.scatter(p_batch,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,log_ratio_p_q_from_p,label='sDRE 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_m1,label='sDRE log p/q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat5 = ax3.scatter(q_batch.cpu(),true_log_ratio_p_q_from_q,label='True log p/q',alpha=0.9,s=1.,c='b')\n",
    "scat6 = ax3.scatter(q_batch.cpu(),log_ratio_p_q_from_q,label='sDRE log p/q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "ylim = [-300, 200]\n",
    "xlim = [-3, 3]\n",
    "ax1.yaxis.tick_right()\n",
    "ax1.set_ylabel(\"Log Ratio\")\n",
    "ax1.legend(loc='lower left', prop={'size': 8})\n",
    "ax1.set_xlim(xlim)\n",
    "ax1.set_ylim(ylim)\n",
    "ax1.set_xlabel('p')\n",
    "\n",
    "ax2.set_ylabel(\"Log Ratio\")\n",
    "ax2.legend(loc='lower left', prop={'size': 8})\n",
    "ax2.set_xlim(xlim)\n",
    "ax2.set_ylim(ylim)\n",
    "ax2.set_xlabel('m')\n",
    "\n",
    "ax3.set_ylabel(\"Log Ratio\")\n",
    "ax3.legend(loc='lower left', prop={'size': 8})\n",
    "ax3.set_xlim(xlim)\n",
    "ax3.set_ylim(ylim)\n",
    "ax3.set_xlabel('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",
    "# ax7.get_yaxis().set_visible(False)\n",
    "# ax8.get_yaxis().set_visible(False)\n",
    "# ax9.get_yaxis().set_visible(False)\n",
    "# ax10.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_cauchy_logpq.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
}
