{
 "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": "iVBORw0KGgoAAAANSUhEUgAABDAAAANYCAYAAAAylB2vAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAACUsUlEQVR4nOzdfbxVdZ33/9cnQFDAmwjvQIMcs8E7MgTN8jIkRGs0J0u5hgnL+Zn9ZEobNav5jdTYlFPZzeTVDFeaEqYYo5PTJGoqWTqpQHiHMaJiQpiEd3kv8Pn9sdehLZ4DBzh7r7X3eT0fj/3Ya33X2mu992afdb58zlrfFZmJJEmSJElSlb2h7ACSJEmSJEmbYgFDkiRJkiRVngUMSZIkSZJUeRYwJEmSJElS5VnAkCRJkiRJlWcBQ5IkSZIkVV7DChgRcUlEPBER99W1vTEiboyIB4vnnRq1f0nqrSJiWUTcGxGLImJ+0dbp8Tdqvh0RSyPinog4qG47U4v1H4yIqWW9H0mSfWtJgsaegXEpMGmDtnOBmzJzb+CmYl6S1PPek5mjM3NMMd/V8fdoYO/icSrwXah1ioHzgHHAWOA8O8aSVKpLsW8tqZdrWAEjM28Fntyg+TjgsmL6MuADjdq/JOk1ujr+HgfMzJpfATtGxG7AUcCNmflkZj4F3MjrO86SpCaxby1J0LfJ+9slM1cW048Du3S1YkScSu2vgQwcOPAdb3vb25oQT5K2zIIFC/6QmUPLzlFI4IaISODfMnMGXR9/hwGP1b12edHWVftreKyW1EoqdqzuCfatJbWlro7XzS5grJeZWXSuu1o+A5gBMGbMmJw/f37TsknS5oqIR8vOUOddmbkiInYGboyI39Qv3NTxd3N4rJbUSip2rO5R9q0ltZOujtfNvgvJ74tTkymen2jy/iWp7WXmiuL5CeAaamNYdHX8XQHsUffy4UVbV+2SpOqwby2pV2l2AeNaoGMk+6nAj5u8f0lqaxExMCIGd0wDE4H76Pr4ey3wkeJuJIcAzxSnI18PTIyInYrBOycWbZKk6rBvLalXadglJBFxBXAE8KaIWE5tNPuvAFdFxCnAo8CHG7V/SeqldgGuiQioHeN/mJlzI+IuOj/+/hQ4BlgKvAB8FCAzn4yIfwTuKtb7YmZuOHicJKlJ7FtLUgMLGJk5uYtFRzZqn5LU22Xmw8CBnbSvppPjb2YmcHoX27oEuKSnM0raMq+++irLly/npZdeKjtK5Q0YMIDhw4fTr1+/sqP0GPvWklTiIJ6SJEnqvuXLlzN48GBGjBhBcZaVOpGZrF69muXLlzNy5Miy40iSelCzx8CQJEnSFnjppZcYMmSIxYtNiAiGDBnimSqS1IYsYEiSJLUIixfd4+ckSe3JAoYkSZIkSao8CxiSJEnapNWrVzN69GhGjx7NrrvuyrBhw9bPv/LKKw3f/8qVK5k4cWLD9yNJqi4H8ZQkSdImDRkyhEWLFgEwffp0Bg0axFlnnbV++Zo1a+jbt3Fdy7lz53LUUUc1bPuSpOrzDAxJkiRtkZNPPpnTTjuNcePGcc455zB9+nS+9rWvrV++3377sWzZMgBmzZrF2LFjGT16NB//+MdZu3bt67Y3YsQIzjnnHPbff3/Gjh3L0qVL1y+bO3cuRx99NJnJtGnT2GeffZgwYQLHHHMMc+bMafh7lSSVzwKGJElSm7rhBvjc52rPjbJ8+XJuv/12Lrzwwi7XeeCBB5g9eza33XYbixYtok+fPlx++eWdrrvDDjtw7733Mm3aNM444wwA1q5dy5IlSxg1ahTXXHMNS5YsYfHixcycOZPbb7+9EW9LklRBXkIiSZLUhm64AaZMgZdfhu99D2bNgkYMIfGhD32IPn36bHSdm266iQULFnDwwQcD8OKLL7Lzzjt3uu7kyZPXP5955pkA3HHHHYwbNw6AW2+9lcmTJ9OnTx923313xo8f31NvRZJUcRYwJEmS2tC8ebXixcCB8PzztflGFDAGDhy4frpv376sW7du/fxLL70EQGYydepUvvzlL29ye/W3QO2Yvu6665g0aVJPRZYktSgvIZEkSWpDRxwB/fvXihf9+9fmG23EiBEsXLgQgIULF/LII48AcOSRRzJnzhyeeOIJAJ588kkeffTRTrcxe/bs9c+HHnooUDuDY8KECQAcfvjhzJ49m7Vr17Jy5UpuueWWhr4nSVJ1eAaGJElSG5o4sXbZyLx5teJFM+5A+sEPfpCZM2ey7777Mm7cON761rcCMGrUKM4//3wmTpzIunXr6NevHxdddBFvfvObX7eNp556igMOOID+/ftzxRVXsGrVKgYMGMDgwYMBOP7447n55psZNWoUe+655/oihySp/VnAkCRJalMTJzamcDF9+vRO27fddltu6GLE0BNPPJETTzxxk9s+++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+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4YYbuOmmmwCoqKhg2bJlDBw4kGeffZZly5axZMkSHn/8cd55551YnJaIiCQgdSERERERaYby86GkBLKzYffu6HIshpC47LLLSE1N3e82r7zyCvPnz+fkk08GoKioiG7dutW57ZgxY6rub775ZgDmzp3LiBEjAHjjjTcYM2YMqamp9OzZk7PPPrupTkVERBKcEhgiIiIizVBuLjz8cDR5kZERXY6F7OzsqsdpaWlUVlZWLRcXFwPg7owbN44pU6YccH/Vp0Dd+/jFF19k9OjRTRWyiIgkKXUhEREREWmGIhGYMQOuvz56H48JPPr06cOCBQsAWLBgAatWrQLgnHPO4emnn2bTpk0AbN26lTVr1tS5j5kzZ1bdjxw5Eoi24Dj33HMBOPPMM5k5cyYVFRVs2LCB1157LabnJCIiiUMtMERERESaqUgkPomLvS655BIef/xxjjvuOEaMGMHRRx8NwMCBA7n77ruJRCJUVlaSnp7O1KlTOeKII2rtY9u2bQwePJiMjAyefPJJNm/eTGZmJm3btgXg4osv5tVXX2XgwIEcfvjhVUkOERFp/pTAEBEREZGDctddd9VZnpWVRV49o4VeccUVXHHFFQfc96233sp9991XtTxjxgwi1bIwZsbvf//7quWrr766YUGLiEjSUwJDRERERBLW2LFjww5BREQShBIYIiIiIpIQVq9efdDPefTRR5s8DhERSUwaxFNEREREREREEp4SGCIiIiIiIiKS8JTAEBEREREREZGEpwSGiIiIiIiIiCQ8JTBERERE5IC2bNnCkCFDGDJkCD169KBXr15Vy2bGkCFDOP744/nmN7/J9u3bgeignFlZWVXbDRkyhMcff/ygjrthw4Ya06iKiEjLpVlIREREROSAOnfuzMKFCwG46667aNOmDbfccgsAbdq0qVo3btw4pk6dyh133AFAv379qtYditmzZzNq1KjGhC4iIs2EWmCIiIiINFd5eTBpUvQ+TkaOHMm6desO6jl9+vThtttuY9CgQQwfPpwVK1ZUrZs9ezbnnXce7s4NN9zAMcccw7nnnsv555/P008/3dThi4hIAlMCQ0RERKQ5ysuDsWNh6tTofRySGBUVFbzyyitceOGFVWWfffZZjS4kb775Zp3Pbd++PYsWLeKGG27gpptuqtrfsmXLGDhwIM8++yzLli1jyZIlPP7447zzzjsxPx8REUks6kIiIiIi0hzl50NJCWRnw+7d0eUYjSVRVFTEkCFDWLduHcceeyxf//rXq9Y1tAvJmDFjqu5vvvlmAObOncuIESMAeOONNxgzZgypqan07NmTs88+u+lPREREEppaYIiIiIg0R7m5kJERTV5kZESXYyQrK4uFCxeyZs0a3J2pU6ce9D7MrNbjF198kdGjRzdZnCIiktyUwBARERFpjiIRmDEDrr8+eh+HmTxat27Ngw8+yK9+9SvKy8sP6rkzZ86suh85ciQAr7zyCueeey4AZ555JjNnzqSiooINGzbw2muvNW3wIiKS8NSFRERERKS5ikTikrio7sQTT2Tw4ME8+eSTnHHGGVVjYOw1YcIEfvjDH9Z63rZt2xg8eDAZGRk8+eSTbN68mczMTNq2bQvAxRdfzKuvvsrAgQM5/PDDq5IcIiLSciiBISLSDJlZKjAPWOfuF5hZX+ApoDMwH/iuu5eaWQbwODAU2AJc4e6rg31MBK4BKoAfuvuc+J+JiCSiu+66q8byrl27aiw///zzVY+LiooatM9bb72V++67r2p5xowZRKolX8yM3//+91XLV1999UFELCIizYESGCIizdONwFKgXbB8H/Brd3/KzP6HaGLij8H9Nnc/ysyuDLa7wswGAlcCxwE9gZfN7Gh3r4j3iYhIyzR27NiwQxARkQSjMTBERJoZM8sBvgE8HCwbcDbwdLDJY8C3gscXBcsE688Jtr8IeMrdS9x9FbACGB6XExCRFmf16tV06dLloJ7z6KOPcumll8YoIhERSURKYIiIND+/AW4DKoPlzsB2d987ol4B0Ct43AtYCxCs3xFsX1Vex3NEJCTuHnYISUGvk4hI86QEhohIM2JmFwCb3H1+nI53rZnNM7N5mzdvjschRVqszMxMtmzZoi/nB+DubNmyhczMzLBDERGRJqYxMEREmpfTgAvN7Hwgk+gYGL8FOphZWtDKIgdYF2y/DugNFJhZGtCe6GCee8v3qv6cKu7+EPAQwLBhw/StSiSGcnJyKCgoQMnCA8vMzCQnJyfsMEREpIkpgSEi0oy4+0RgIoCZ5QK3uPu/mdlfgUuJzkQyDvh78JTnguV/BetfdXc3s+eAv5jZA0QH8ewPvBfHUxGRfaSnp9O3b9+wwxAREQmNEhgiIi3DT4CnzOxu4APgkaD8EeDPZrYC2Ep05hHcfbGZzQKWAOXA9ZqBRERERETCpASGiEgz5e75QH7weCV1zCLi7sXAZfU8/x7gnthFKCIiIiLScBrEU0REREREREQSnhIYIiIiIiIiIpLwQklgmNnNZrbYzD42syfNTPNciYiIiIgcAtWtRaSliHsCw8x6AT8Ehrn78UAqwaBxIiIiIiLScKpbi0hLElYXkjQgy8zSgNbA+pDiEBERERFJdqpbi0iLEPcEhruvA+4HPgc2ADvcPS/ecYiIiIiIJDvVrUWkJQmjC0lH4CKgL9ATyDazsXVsd62ZzTOzeZs3b453mCIiIiIiCU91axFpScLoQnIusMrdN7t7GfAMcOq+G7n7Q+4+zN2Hde3aNe5BioiIiIgkAdWtRaTFCCOB8Tlwipm1NjMDzgGWhhCHiIiIiEiyU91aRFqMMMbAmAs8DSwAFgUxPBTvOEREREREkp3q1iLSkqSFcVB3vxO4M4xji4iIiIg0J6pbi0hLEdY0qiIiIiIiIiIiDaYEhoiIiIiIiIgkPCUwRERERERERCThKYEhIiIiIiIiIglPCQwRERERERERSXhKYIiIiIiIiIhIwlMCQ0REREREREQSnhIYIiIiIiIiIpLwlMAQERERERERkYSnBIaIiIiIiIiIJDwlMEREREREREQk4SmBISIiIiIiIiIJTwkMEREREREREUl4SmCIiIiIiIiISMJTAkNEREREREREEp4SGCIiIiIiIiKS8JTAEBEREREREZGEpwSGiEgzYmaZZvaemX1oZovN7OdBeV8zm2tmK8xsppm1CsozguUVwfo+1fY1MShfZmajQjolERERERFACQwRkeamBDjb3U8AhgCjzewU4D7g1+5+FLANuCbY/hpgW1D+62A7zGwgcCVwHDAa+IOZpcbzREREREREqlMCQ0SkGfGoXcFienBz4Gzg6aD8MeBbweOLgmWC9eeYmQXlT7l7ibuvAlYAw2N/BiIiIiIidVMCQ0SkmTGzVDNbCGwCXgI+A7a7e3mwSQHQK3jcC1gLEKzfAXSuXl7Hc6of61ozm2dm8zZv3hyDsxERERERiVICQ0SkmXH3CncfAuQQbTUxIIbHesjdh7n7sK5du8bqMCIiIiIiSmCIiDRX7r4deA0YCXQws7RgVQ6wLni8DugNEKxvD2ypXl7Hc0RERERE4k4JDBGRZsTMuppZh+BxFvB1YCnRRMalwWbjgL8Hj58LlgnWv+ruHpRfGcxS0hfoD7wXl5MQEREREalD2oE3ERGRJHIY8FgwY0gKMMvdXzCzJcBTZnY38AHwSLD9I8CfzWwFsJXozCO4+2IzmwUsAcqB6929Is7nIiIiIiJSRQkMEZFmxN0/Ak6so3wldcwi4u7FwGX17Ose4J6mjlFERERE5FCoC4mIiIiIiIiIJDwlMEREREREREQk4SmBISIiIiIiIiIJTwkMEREREREREUl4SmCIiIiIiIiISMJTAkNEREREREREEp4SGCIiIiIiIiKS8JTAEBEREREREZGEpwSGiIiIiIiIiCQ8JTBEREREREREJOEpgSEiIiIiIiIiCU8JDBERERERERFJeEpgiIiIiIiIiEjCCyWBYWYdzOxpM/vEzJaa2cgw4hARERERSXaqW4tIS5EW0nF/C8x290vNrBXQOqQ4RERERESSnerWItIixD2BYWbtgTOBqwHcvRQojXccIiIiIiLJTnVrEWlJwuhC0hfYDEw3sw/M7GEzy953IzO71szmmdm8zZs3xz9KEREREZHEp7q1iLQYB0xgmFk/M8sIHuea2Q/NrEMjjpkGnAT80d1PBHYDt++7kbs/5O7D3H1Y165dG3E4EREREZFmS3VrEWkxGtIC429AhZkdBTwE9Ab+0ohjFgAF7j43WH6a6EVXREREREQOjurWItJiNCSBUenu5cDFwO/c/VbgsEM9oLtvBNaa2TFB0TnAkkPdn4hIMjKz9mb2673Nec3sV0E/ZhERkQZT3VpEWpKGJDDKzGwMMA54IShLb+Rx/wN4wsw+AoYAkxu5PxGRZDMNKAQuD26FwPRQIxIRkZgzs1+YWTszSzezV8xss5mNbeRuVbcWkRahIbOQjAeuA+5x91Vm1hf4c2MO6u4LgWGN2YeISJLr5+6XVFv+uZktDCsYERGJm4i732ZmFwOrgW8DbwAzDnWHqluLSEtxwASGuy8BfghgZh2Btu5+X6wDExFp5orM7HR3fwvAzE4DikKOSUREYm9v/fsbwF/dfYeZhRmPiEjSOGACw8zygQuDbecDm8zsbXf/UYxjExFpzn4APBaMe2HAVuDqUCMSEZF4eMHMPiGatP6BmXUFikOOSUQkKTSkC0l7dy80s+8Bj7v7nUH/OhEROURBc98TzKxdsFwYbkQiIhIP7n67mf0C2OHuFWa2G7go7LhERJJBQxIYaWZ2GNFB5u6IcTwiIs2amY119xlm9qN9ygFw9wdCCUxEROLCzC4DZgfJi58SnfL0bmBjuJGJiCS+hsxC8l/AHOAzd3/fzI4Elsc2LBGRZis7uG9bx61NWEGJiEjc/Ke77zSz04FzgUeAP4Yck4hIUmjIIJ5/Bf5abXklcEn9zxARkfq4+5+Chy+7+9vV1wUDeYqISPNWEdx/A3jI3f9hZneHGZCISLI4YAsMM8sxs2fNbFNw+5uZ5cQjOBGRZux3DSw7KGbW28xeM7MlZrbYzG4MyjuZ2Utmtjy47xiUm5k9aGYrzOwjMzup2r7GBdsvN7NxjY1NREQAWGdmfwKuAP5pZhk0rFW0iEiL15AxMKYDfwEuC5bHBmVfj1VQIiLNlZmNBE4Fuu4zDkY7ILUJDlEO/NjdF5hZW2C+mb1EdIaTV9z9XjO7Hbgd+AlwHtA/uI0g2ox5hJl1Au4EhgEe7Oc5d9/WBDGKiLRklwOjgfvdfXsw1tytIcckIpIUGpLt7eru0929PLg9CnSNcVwiIs1VK6JjXaRRc/yLQuDSxu7c3Te4+4Lg8U5gKdCL6Aj3jwWbPQZ8K3h8EdEZptzd3wU6BJXpUcBL7r41SFq8RLTCLSIijeDue4DPgFFmdgPQzd3zQg5LRCQpNKQFxhYzGws8GSyPAbbELiQRkebL3V8HXjezR919TSyPZWZ9gBOBuUB3d98QrNoIdA8e9wLWVntaQVBWX/m+x7gWuBbg8MMPb8LoRUSap6Br378DzwRFM8zsIXdvdDdCEZHmriEJjAlE+2X/mmgz4neINkUWEZFDt8fMfgkcB2TuLXT3s5ti52bWBvgbcJO7F+6dpjU4hpuZN8Vx3P0h4CGAYcOGNck+RUSauWuAEe6+G8DM7gP+RROMgyQi0twdsAuJu69x9wvdvau7d3P3bwE3xj40EZFm7QngE6Av8HNgNfB+U+zYzNKJJi+ecPe9v/B9EXQNIbjfFJSvA3pXe3pOUFZfuYiINI7x1UwkBI+tnm1FRKSaQx3x+PImjUJEpOXp7O6PAGXu/rq7TwAa3frCok0tHgGWuvsD1VY9B+ydSWQc8Pdq5VcFs5GcAuwIuprMASJm1jGYsSQSlImISONMB+aa2V1mdhfwLtHrtoiIHEBDupDURVliEZHGKQvuN5jZN4D1QKcm2O9pwHeBRWa2MCibBNwLzDKza4A1fJWI/idwPrAC2AOMB3D3rWb233zVKuS/3H1rE8QnItKiufsDZpYPnB4UjQe+CC8iEZHkUW8CI5hCr85VKIEhItJYd5tZe+DHRPs9twNuauxO3f0t6r9Gn1PH9g5cX8++pgHTGhuTiIjUFMwWtWDvspl9DmgkZBGRA9hfC4z5RAftrKsiXBqbcEREWgZ3fyF4uAP4GoCZnRZeRCIiEiL9OCgi0gD1JjDcvW88AxERaQnMLJVo941ewGx3/9jMLiDazSOL6LSnIiLSsmgWJxGRBjjUMTBEROTQPEJ0do/3gAfNbD0wDLjd3f8vzMBERCR2zOx31J2oMKBDfKMREUlOSmCIiMTXMGCwu1eaWSawEejn7ltCjktERGJr3iGuExGRgBIYIiLxVerulQDuXmxmK5W8EBFp/tz9sbBjEBFJdg1KYAR9trtX397dP49VUCIizdgAM/soeGxAv2DZiE4KMji80EREREREEtcBExhm9h/AnUTnp64Mih1QJVtE5OAdG3YAIiIiIiLJqCEtMG4EjlETZxGRxnP3NWHHICIi4TGz09z97QOViYhIbSkN2GYtsCPWgYiIiIiItAC/a2CZiIjsoyEtMFYC+Wb2D6Bkb6G7PxCzqEREREREmhEzGwmcCnQ1sx9VW9UOSA0nKhGR5NKQBMbnwa3V/2/vzsMtqet7378/djODoNhONAoa1NMagtgyRONFIM2gEU00wgkRh1yiV6JoHFDPjZijV02MGiPHhKMEEcMgkYhGGURQo0egQWYktAyhW5SW0RHo5nv/qNrtotm7x7121Vr7/Xqe9ayqX9Wq+qzaa9f+7e+qoX1IkiRJWj+bAlvT9L+3GWi/F3h5J4kkacSstYBRVe+biSCSNJskuYrmgsiD7gEWA+/3ukOSNF6q6pvAN5OcOHE9pCSPALauqnu7TSdJo2HKAkaSj1fV0Um+zMM72VTVS4aaTJLG29eAlcC/tOOHAlsCPwZOBP6gm1iSpCH7YJLX0/wNuAR4ZJK/r6q/7TiXJPXemo7A+Fz7/JGZCCJJs8z+VbX7wPhVSS6rqt2THN5ZKknSsC2oqnuT/AlNMfsY4FLAAoYkrcWUBYyqurR9/ubMxZGkWWNOkj2q6mKAJM/lNxdxW9FdLEnSkG2SZBPgpcAnq+qBJA872lmS9HBrvQZGkl2ADwILgM0n2qvqKUPMJUnj7s+AE5JsDYTmIm6vS7IVzT5XkjSe/gm4GbgC+FaSJ9P8DZAkrcW63IXkn4H3Ah8DXgi8BnjEMENJ0rirqkuA306ybTt+z8Dk07tJJUkatqr6BPCJgaZbkrywqzySNErWpRCxRVWdD6SqbqmqY4EXDTeWJI23JNsm+ShwPnB+kr+bKGZIksZXkscl+UySr7XjC4AjOo4lSSNhXQoY97W3eLohyVFJXkZzD2tJ0oY7AfgZ8Mft416aI94kSePtROAc4Int+H8CR3cVRpJGyboUMN5Mc2u/NwHPAQ7HKrEkbaynVtV7q+rG9vE+wGsLSdKYSjJx6vZjqup04EGAqlpBc0tVSdJarLGAkWQO8Mqq+nlVLa2q11TVH1XV92YonySNq18lef7ESJLnAb/qMI8kabgubp9/kWR7oACS7AXcM+WrJEmrTHkRzyRzq2rFYAdbkjRtXg+cNHDdi7vw6DZJGmdpn98KnAU8Ncl3gHnAyztLJUkjZE13IbkY2B34fpKzgC8Av5iYWFVfHHI2SRpbVXUF8DtJHtmO35vkaODKToNJkoZlXpK3tsNnAl+lKWrcB+yP+39JWqt1uY3q5sAdwL40h7qlfbaAIUkbqaruHRh9K/DxjqJIkoZrDs2F8LNa+5YdZJGkkbSmAsZj2yrx1fymcDGhNnbF7fU1FgPLqurFG7s8SRoDq3dqJUnj47aq+uthLdy+taTZYE0FjKmqxDANBQyau5tcBzxyGpYlSeNgOvatkqR+GnaR2r61pLG3pgLG0KrESeYDLwI+QHPItCTNCkl+xuSFigBbzHAcSdLM2W9YC7ZvLWm2WNNtVIdZJf448A7a+19PuvLkyCSLkyxevnz5EKNI0sypqm2q6pGTPLapqnW5LtEaJTkhye1Jrh5oe3SS85Lc0D4/qm1Pkk8kWZLkyiS7D7zmiHb+G5J4dxRJ2khVdecQF/9x7FtLmgXWVMAYSpU4yYuB26vq0jXNV1XHV9XCqlo4b968YUSRpHF0InDgam3HAOdX1S7A+e04wEHALu3jSOBT0BQ8gPcCewJ7AO+dKHpIkvrFvrWk2WTKAsYQq8TPA16S5GbgVGDfJCcPaV2SNKtU1beA1fffhwCfbYc/C7x0oP2kanwP2C7JE4ADgPOq6s6qugs4j4cXRSRJ/WDfWtKssaYjMIaiqt5VVfOraifgUOAbVXX4TOeQpFnkcVV1Wzv8Y+Bx7fAOwK0D8y1t26ZqlyT1jH1rSbPJjBcwJEndqapiGu924jnVkiRJmimdFjCq6kLvUy1JQ/eT9tQQ2ufb2/ZlwI4D881v26ZqfxjPqZak/rBvLWnceQSGJI2/s4CJO4kcAXxpoP1V7d1I9gLuaU81OQdYlORR7cU7F7VtkiRJUmc2+pZ9kqT+SHIKsA/wmCRLae4m8iHg9CSvA24B/rid/avAwcAS4JfAa6C5iHOS/wlc0s7310O+/Z8kSZK0VhYwJGmMVNVhU0x62K2x2+thvHGK5ZwAnDCN0SRJkqSN4ikkkiRJkiSp9yxgSJIkSZKk3rOAIUmSJEmSes8ChiRJkiRJ6j0LGJIkSZIkqfcsYEiSJEmSpN6zgCFJkiRJknrPAoYkSZIkSeo9CxiSJEmSJKn3LGBIkiRJkqTes4AhSZIkSZJ6zwKGJEmSJEnqPQsYkiRJkiSp9yxgSJIkSZKk3rOAIUmSJEmSes8ChiRJkiRJ6j0LGJIkSZIkqfcsYEiSJEmSpN6zgCFJkiRJknrPAoYkSZIkSeo9CxiSJEmSJKn3LGBIkiRJkqTes4AhSZIkSZJ6zwKGJEmSJEnqPQsYkiRJkiSp9yxgSJIkSZKk3rOAIUmSJEmSes8ChiRJkiRJ6j0LGJKkKSU5MMn1SZYkOabrPJIkSZq9LGBIkiaVZA5wHHAQsAA4LMmCblNpGB7II6hk2h4rEy794Lldvy1JkjRmLGBIkqayB7Ckqm6sqvuBU4FDOs6kafZAHsFcalqX+Qhg93cfYBFDkiRNKwsYkqSp7ADcOjC+tG1bJcmRSRYnWbx8+fIZDafpMd3Fi0H3fvnCoS1bkiTNPhYwJEkbrKqOr6qFVbVw3rx5XcfRBlhBhrbsR/7BPkNbtiRJmn0sYEiSprIM2HFgfH7bpjGyST047UWMB4HL/r9zeM67Fk3rciVJ0uw2t+sAkqTeugTYJcnONIWLQ4H/3m0kDcMm9eC0Lm8O8JxpXaIkSVIHR2Ak2THJBUmuTXJNkjfPdAZJ0tpV1QrgKOAc4Drg9Kq6pttUkqRB9q0lzSZdHIGxAvjLqrosyTbApUnOq6prO8giSVqDqvoq8NWuc0iSpmTfWtKsMeNHYFTVbVV1WTv8M5pv9XZY86skSZIkrc6+taTZpNOLeCbZCXg2cFGXOSRJkqRRZ99a0rjrrICRZGvgX4Gjq+reSaYfmWRxksXLly+f+YCSJEnSiLBvLWk26KSAkWQTmh3s56vqi5PNU1XHV9XCqlo4b968mQ0oSZIkjQj71pJmiy7uQhLgM8B1VfXRmV6/JEmSNC7sW0uaTbo4AuN5wJ8C+ya5vH0c3EEOSZIkadTZt5Y0a8z4bVSr6j+AzPR6JUmSpHFj31rSbNLpXUgkSZIkSZLWhQUMSZIkSZLUexYwJEmSJElS71nAkCRJkiRJvWcBQ5IkSZIk9Z4FDEmSJEmS1HsWMCRJkiRJUu9ZwJAkSZIkSb1nAUOSJEmSJPWeBQxJkiRJktR7FjAkSZIkSVLvWcCQJEmSJEm9ZwFDkiRJkiT1ngUMSZIkSZLUexYwJEmSJElS71nAkCRJkiRJvWcBQ5IkSZIk9d5IFDDuX/Fg1xEkSZKksbDyweo6giRtkJEoYPz05/d1HUGSJEkaC7+8f0XXESRpg4xEAUOSJEmSJM1uFjAkSZIkSVLvWcCQpDGR5BVJrknyYJKFq017V5IlSa5PcsBA+4Ft25Ikxwy075zkorb9tCSbzuR7kSRJklZnAUOSxsfVwB8C3xpsTLIAOBR4JnAg8L+SzEkyBzgOOAhYABzWzgvwYeBjVfVbwF3A62bmLUiSJEmTs4AhSWOiqq6rqusnmXQIcGpV3VdVNwFLgD3ax5KqurGq7gdOBQ5JEmBf4Iz29Z8FXjr0NyBJkiStgQUMSRp/OwC3Dowvbdumat8euLuqVqzW/jBJjkyyOMni5cuXT3twSZIkacLcrgNIktZdkq8Dj59k0nuq6ksznaeqjgeOB1i4cGHN9PolSZI0e1jAkKQRUlX7b8DLlgE7DozPb9uYov0OYLskc9ujMAbnlyRJkjrhKSSSNP7OAg5NslmSnYFdgIuBS4Bd2juObEpzoc+zqqqAC4CXt68/ApjxozskSZKkQRYwJGlMJHlZkqXA3sC/JzkHoKquAU4HrgXOBt5YVSvboyuOAs4BrgNOb+cFeCfw1iRLaK6J8ZmZfTeSJEnSQ3kKiSSNiao6EzhzimkfAD4wSftXga9O0n4jzV1KJEmSpF7wCAxJkiRJktR7FjAkSZIkSVLvWcCQJEmSJEm9ZwFDkiRJkiT1ngUMSZIkSZLUexYwJEmSJElS71nAkCRJkiRJvWcBQ5IkSZIk9Z4FDEmSJEmS1HudFDCSHJjk+iRLkhzTRQZJkiRpHNi3ljRbzHgBI8kc4DjgIGABcFiSBTOdQ5IkSRp19q0lzSZdHIGxB7Ckqm6sqvuBU4FDOsghSZIkjTr71pJmjbkdrHMH4NaB8aXAnqvPlORI4Mh29L4kV89Atun0GOCnXYdYT2aeGaOYGUYz90xmfvIMrae3Lr300p8nub7rHKvp6+e2j7nMtG76mAn6mauPmZ7edYAhsG/dX2aeGWaeOZ33rbsoYKyTqjoeOB4gyeKqWthxpPVi5plh5pkzirlHMfOIu75v27uvn4E+5jLTuuljJuhnrr5m6jpDV+xbzzwzzwwzz5w+5O7iFJJlwI4D4/PbNkmSJEnrx761pFmjiwLGJcAuSXZOsilwKHBWBzkkSZKkUWffWtKsMeOnkFTViiRHAecAc4ATquqatbzs+OEnm3ZmnhlmnjmjmHsUM4+yPm7vPmaCfuYy07rpYyboZy4zzQD71r1m5plh5pnTee5UVdcZJEmSJEmS1qiLU0gkSZIkSZLWiwUMSZIkSZLUe70uYCQ5MMn1SZYkOaYHeW5OclWSyyduw5Xk0UnOS3JD+/yotj1JPtFmvzLJ7gPLOaKd/4YkRwwh5wlJbh+8v/d05kzynHY7LGlfmyFlPjbJsnZ7X57k4IFp72rXf32SAwbaJ/3MtBe2uqhtP629yNXGZt4xyQVJrk1yTZI3t+293dZryNzbbZ1k8yQXJ7mizfy+Na0nyWbt+JJ2+k4b+l60YZL8RZIftD+vv+k6z4Qkf5mkkjymB1n+tt1GVyY5M8l2HWbp3ed/qn1VHySZk+T7Sb7SdRaAJNslOaP9PF2XZO8eZHpL+3O7OskpSTbvKMc694dmi779vmcE+tbr8znakIyxXz2xTPvVM7etR7tvXVW9fNBchOiHwFOATYErgAUdZ7oZeMxqbX8DHNMOHwN8uB0+GPgaEGAv4KK2/dHAje3zo9rhR01zzhcAuwNXDyMncHE7b9rXHjSkzMcCb5tk3gXt52EzYOf2czJnTZ8Z4HTg0Hb4H4E3TEPmJwC7t8PbAP/ZZuvttl5D5t5u6/a9b90ObwJc1G6TSdcD/D/AP7bDhwKnbeh78bFBP68XAl8HNmvHH9t1pjbHjjQXuLuF1fbjHeVZBMxthz88sZ/oIEcvP/9T7au6ztXmeSvwL8BXus7S5vks8Gft8KbAdh3n2QG4CdiiHT8deHVHWda5PzQbHn38fWcE+tbr8znakIzYr57IYb965rb1SPet+3wExh7Akqq6saruB04FDuk402QOoek80D6/dKD9pGp8D9guyROAA4DzqurOqroLOA84cDoDVdW3gDuHkbOd9siq+l41n9yTBpY13ZmncghwalXdV1U3AUtoPi+Tfmba6uq+wBnt6wff/8Zkvq2qLmuHfwZcR9Nx6+22XkPmqXS+rdvt9fN2dJP2UWtYz+D2PwPYr821Xu9lYzLPcm8APlRV9wFU1e0d55nwMeAdNJ+dzlXVuVW1oh39HjC/oyi9/PxvwL5qRiSZD7wI+HTXWQCSbEvzj8pnAKrq/qq6u9NQjbnAFknmAlsCP+oixHr2h2aDXv6+T6JXfWv71farNyDzVPqyrUe6b93nAsYOwK0D40vpvvNSwLlJLk1yZNv2uKq6rR3+MfC4dniq/F29r+nKuUM7vHr7sBzVHhZ2Qn5zmOf6Zt4euHvgn4Vpz9weSvVsmgrmSGzr1TJDj7d1mkO2Lwdup/lD9MM1rGdVtnb6PW2uvv1OjqunAb/XHmL4zSTP7TpQkkOAZVV1RddZpvBamm+CutD7z/8k+6oufZymEPZgxzkm7AwsB/45zWktn06yVZeBqmoZ8BHgv4DbgHuq6twuM61mqr/Rs0Eff99HtW89En29SfS2rzfIfvXwt/Uo9637XMDoo+dX1e7AQcAbk7xgcGJbzevFt3trMio5gU8BTwV2o+kE/V2naaaQZGvgX4Gjq+rewWl93daTZO71tq6qlVW1G8231HsAz+g20eyW5Otpzm1f/XEIzTevj6Y5FPHtwOkbe47pNGR6N/BXw86wnpkm5nkPsAL4/EznGwVr2r92kOXFwO1VdWmXOVYzl+Yw8U9V1bOBX9AcYt2ZtqN+CE1x5YnAVkkO7zLTVPr6N3qWGfm+9ShkbPW6rzfBfvXMGOW+dZ8LGMtozlmeML9t60z7rcLEIdFn0vywf9IekkT7PHG49FT5u3pf05VzGQ891Hlo+avqJ+0v14PA/6bZ3huS+Q6aw8rmTnfmJJvQ7LA+X1VfbJt7va0nyzwK27rNeTdwAbD3GtazKls7fds2V99+J0dWVe1fVc+a5PElmir7F9vDEy+m+aZ66BfNnCoTzbmvOwNXJLmZ5ud7WZLHd5Wp3U4keTXwYuBP2k5ZF3r7+Z9i/9ql5wEvaT9HpwL7Jjm520gsBZZW1cQ3fmfQFDS6tD9wU1Utr6oHgC8Cv9txpkFT/Y2eDXr3+z7Cfete9/UmMwp9PfvVD2sfar+6zXo3I9a37nMB4xJglzRXQ92U5oIhZ3UVJslWSbaZGKa5ANvVbaYj2tmOAL7UDp8FvCqNvWgOobyN5iJyi5I8qv2WYlHbNmzTkrOddm+SvdpvVV81sKxpNbGzar2MZntPZD40zRVxdwZ2obkoz6SfmfYfgwuAl0/y/jcmX2jOO76uqj46MKm323qqzH3e1knmpb1DQ5ItgN+nOcdwqvUMbv+XA99oc63Xe9mYzLPcv9FcyJMkT6O5eNNPuwpTVVdV1WOraqeq2onmH77dq+rHXWWC5urcNKcivKSqftlhlF5+/tewf+1MVb2rqua3n6NDafYtnR5Z0H6Ob03y9LZpP+DaDiNBc+rIXkm2bH+O+9Hss/tiqr/Rs0Gvft9HvG/d277eVPrc12vz2a+euW092n3rmqargQ7jQXN12f+kOSfnPR1neQrNFVSvAK6ZyENz/s/5wA00V95/dP3m6q7HtdmvAhYOLOu1NBc5WQK8ZghZT6E5XOkBms7666YzJ7CQ5hfxh8AngQwp8+faTFfSfOifMDD/e9r1X8/AFYSn+sy0P7+L2/fyBdo7JGxk5ufTHMZ2JXB5+zi4z9t6DZl7u62BXYHvt9muBv5qTesBNm/Hl7TTn7Kh78XHBv28NgVObn9WlwH7dp1ptXw304+7kCyhOT904vfwHzvM0rvP/1T7qq5zDeTbh/7chWQ3YHG7rf6Nab6z2QZmeh/wg3Y/8LmN/TuwETnWuT80Wx59+n1nRPrW6/M52pCM2K+eWKb96pnb1iPdt067AkmSJEmSpN7q8ykkkiRJkiRJgAUMSZIkSZI0AixgSJIkSZKk3rOAIUmSJEmSes8ChiRJkiRJ6j0LGBoJSX7ePu+U5L9P87Lfvdr4d6dz+ZI0myR5T5JrklyZ5PIkew5xXRcmWTis5UvSOLJfrVFmAUOjZidgvXa0SeauZZaH7Gir6nfXM5MkCUiyN/BiYPeq2hXYH7i121SSpCnshP1qjRgLGBo1HwJ+r/1W7y1J5iT52ySXtN/2/TlAkn2SfDvJWcC1bdu/Jbm0/WbwyLbtQ8AW7fI+37ZNVKXTLvvqJFcleeXAsi9MckaSHyT5fJJ0sC0kqW+eAPy0qu4DqKqfVtWPkvxVu5++OsnxE/vMdl/6sSSLk1yX5LlJvpjkhiTvb+fZaWBfe127791y9RUnWZTk/yS5LMkXkmzdtn8oybXt34iPzOC2kKS+s1+tkZOq6jqDtFZJfl5VWyfZB3hbVb24bT8SeGxVvT/JZsB3gFcATwb+HXhWVd3UzvvoqrozyRbAJcD/VVV3TCx7knX9EfB64EDgMe1r9gSeDnwJeCbwo3adb6+q/xj+lpCk/mqLBv8BbAl8HTitqr45sf9t5/kccHpVfTnJhcBFVfXOJG8G3gk8B7gT+CHwO8A2wE3A86vqO0lOAK6tqo+0r38bcDPwReCgqvpFkncCmwHHAd8FnlFVlWS7qrp7RjaGJPWU/WqNMo/A0KhbBLwqyeXARcD2wC7ttIsndrKtNyW5AvgesOPAfFN5PnBKVa2sqp8A3wSeO7DspVX1IHA5zSF4kjSrVdXPaQoQRwLLgdOSvBp4YZKLklwF7EvTUZ1wVvt8FXBNVd3WHsFxI82+GuDWqvpOO3wyzf550F7AAuA77d+DI2g63PcAvwY+k+QPgV9O13uVpDFkv1q9t7ZzmKS+C/AXVXXOQxqbivIvVhvfH9i7qn7Zfmu3+Uas976B4ZX4uyRJAFTVSuBC4MK2YPHnwK7Awqq6NcmxPHT/O7E/fZCH7lsf5Df71tUPF119PMB5VXXY6nmS7AHsB7wcOIqmgCJJejj71eo9j8DQqPkZzeHEE84B3pBkE4AkT0uy1SSv2xa4q93JPoPm27oJD0y8fjXfBl7Zng84D3gBcPG0vAtJGkNJnp5k8Fu43YDr2+GftqeYvHwDFv2kNBcIheaCc6sfWvw94HlJfqvNsVX792BrYNuq+irwFppTUiRJDfvVGjlWtzRqrgRWtoesnQj8Pc1hZpe1F/xZDrx0ktedDbw+yXU0nenvDUw7HrgyyWVV9ScD7WcCewNX0Hzb946q+nG7o5YkPdzWwD8k2Q5YASyhOZ3kbuBq4Mc05z2vr+uBN05c/wL41ODEqlrenqpySnveNsD/oOmcfynJ5jTfLL51A9YtSePKfrVGjhfxlCRJvZVkJ+ArVfWsrrNIkqRueQqJJEmSJEnqPY/AkCRJkiRJvecRGJIkSZIkqfcsYEiSJEmSpN6zgCFJkiRJknrPAoYkSZIkSeo9CxiSJEmSJKn3LGBIkiRJkqTes4AhSZIkSZJ6zwKGJEmSJEnqPQsYkiRJkiSp9yxgSJIkSZKk3htaASPJCUluT3L1QNujk5yX5Ib2+VHDWr8kzVZJbk5yVZLLkyxu2ybd/6bxiSRLklyZZPeB5RzRzn9DkiO6ej+SJPvWkgTDPQLjRODA1dqOAc6vql2A89txSdL0e2FV7VZVC9vxqfa/BwG7tI8jgU9B0ykG3gvsCewBvNeOsSR16kTsW0ua5YZWwKiqbwF3rtZ8CPDZdvizwEuHtX5J0kNMtf89BDipGt8DtkvyBOAA4LyqurOq7gLO4+EdZ0nSDLFvLUkwd4bX97iquq0d/jHwuKlmTHIkzbeBbLXVVs95xjOeMQPxJGnDXHrppT+tqnld52gVcG6SAv6pqo5n6v3vDsCtA69d2rZN1f4Q7qsljZKe7aung31rSWNpqv31TBcwVqmqajvXU00/HjgeYOHChbV48eIZyyZJ6yvJLV1nGPD8qlqW5LHAeUl+MDhxbfvf9eG+WtIo6dm+elrZt5Y0TqbaX8/0XUh+0h6aTPt8+wyvX5LGXlUta59vB86kuYbFVPvfZcCOAy+f37ZN1S5J6g/71pJmlZkuYJwFTFzJ/gjgSzO8fkkaa0m2SrLNxDCwCLiaqfe/ZwGvau9GshdwT3s48jnAoiSPai/euahtkyT1h31rSbPK0E4hSXIKsA/wmCRLaa5m/yHg9CSvA24B/nhY65ekWepxwJlJoNnH/0tVnZ3kEibf/34VOBhYAvwSeA1AVd2Z5H8Cl7Tz/XVVrX7xOEnSDLFvLUlDLGBU1WFTTNpvWOuUpNmuqm4EfmeS9juYZP9bVQW8cYplnQCcMN0ZJW2YBx54gKVLl/LrX/+66yi9t/nmmzN//nw22WSTrqNMG/vWktThRTwlSZK07pYuXco222zDTjvtRHuUlSZRVdxxxx0sXbqUnXfeues4kqRpNNPXwJAkSdIG+PWvf832229v8WItkrD99tt7pIokjSELGJIkSSPC4sW6cTtJ0niygCFJkiRJknrPAoYkSZLW6o477mC33XZjt9124/GPfzw77LDDqvH7779/6Ou/7bbbWLRo0dDXI0nqLy/iKUmSpLXafvvtufzyywE49thj2XrrrXnb2962avqKFSuYO3d4Xcuzzz6bAw44YGjLlyT1n0dgSJIkaYO8+tWv5vWvfz177rkn73jHOzj22GP5yEc+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": 75,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x216 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Set up viz\n",
    "fig, [ax4, ax1,ax2,ax3] = plt.subplots(1, 4,figsize=(10,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_samples.numpy(), density=True, histtype='stepfilled', label='p')\n",
    "ax4.hist(q_samples.numpy(), density=True, histtype='stepfilled', label='q')\n",
    "ax4.hist(m_samples.numpy(), density=True, histtype='stepfilled', label='m')\n",
    "\n",
    "\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",
    "\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\", rotation=270, labelpad=10)\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",
    "ax3.yaxis.tick_right()\n",
    "ax3.yaxis.set_label_position(\"right\")\n",
    "\n",
    "\n",
    "ax4.set_xlim([-2,2])\n",
    "ax4.set_ylim([0, 3])\n",
    "ax4.legend()\n",
    "\n",
    "\n",
    "ax1.get_yaxis().set_visible(False)\n",
    "ax2.get_yaxis().set_visible(False)\n",
    "\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": []
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7fa6c007a910>"
      ]
     },
     "execution_count": 40,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "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": [
    "fig, ax = plt.subplots()\n",
    "ax.hist(p_samples.numpy(), density=True, histtype='stepfilled', label='p')\n",
    "ax.hist(q_samples.numpy(), density=True, histtype='stepfilled', label='q')\n",
    "ax.hist(m_samples.numpy(), density=True, histtype='stepfilled', label='m')\n",
    "ax.set_xlim([-2,2])\n",
    "ax.legend()"
   ]
  },
  {
   "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
}
