{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# External imports \n",
    "import torch\n",
    "from torch.utils.data import DataLoader\n",
    "from torch.distributions.mixture_same_family import MixtureSameFamily\n",
    "import torch.distributions as D\n",
    "import random\n",
    "import numpy as np\n",
    "from tqdm import trange\n",
    "import matplotlib.pyplot as plt\n",
    "from IPython.display import display, clear_output\n",
    "\n",
    "# Internal imports\n",
    "import sys; sys.path.insert(0, '..')\n",
    "from src import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "N_DIMS = 1\n",
    "NUM_SAMPLES = 20000\n",
    "BS = 500\n",
    "NUM_EPOCHS = 1000\n",
    "SEED = 10\n",
    "LR = 1e-2\n",
    "DROPOUT = 0.20\n",
    "DEVICE = 'cuda:1' if torch.cuda.is_available() else 'cpu'\n",
    "\n",
    "\n",
    "# Break by changing num datapoints, scales, means, or to 2D"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Setting seed for reproducibility\n",
    "random.seed(SEED)\n",
    "torch.manual_seed(SEED)\n",
    "np.random.seed(SEED)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define model\n",
    "model_cob = RatioCritic1D_K3(dim_input=N_DIMS, dim_output=3, dropout=DROPOUT)\n",
    "# model.apply(weights_init)\n",
    "\n",
    "# Define optimizer\n",
    "optim_cob = torch.optim.Adam(model_cob.parameters(), lr=LR)\n",
    "\n",
    "# Define distributions\n",
    "p, q, m = get_dists_1d_cob(mu1=-1., mu2=1., mu3=0, scale_p=0.1, scale_q=0.2, alphas=[0.25, 0.50, 0.75])\n",
    "\n",
    "# -5, 5, m_var=3.0\n",
    "# -10, 10, m_var=3.0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "m1, m2, m3 = m\n",
    "p_samples = p.sample([1000])\n",
    "q_samples = q.sample([1000])\n",
    "m1_samples = m1.sample([1000])\n",
    "m2_samples = m2.sample([1000])\n",
    "m3_samples = m3.sample([1000])\n",
    "\n",
    "plt.hist(p_samples.numpy(), density=True, histtype='stepfilled')\n",
    "plt.hist(q_samples.numpy(), density=True, histtype='stepfilled')\n",
    "plt.hist(m1_samples.numpy(), density=True, histtype='stepfilled')\n",
    "plt.hist(m2_samples.numpy(), density=True, histtype='stepfilled')\n",
    "plt.hist(m3_samples.numpy(), density=True, histtype='stepfilled')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling p\n",
      "Sampling q\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "Sampling p\n",
      "Sampling q\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n",
      "torch.Size([20000])\n"
     ]
    }
   ],
   "source": [
    "# Define dataset & dataloader\n",
    "train_ds = DistDataset3Waymark(p, q, m, num_samples=NUM_SAMPLES)\n",
    "test_ds = DistDataset3Waymark(p, q, m, num_samples=NUM_SAMPLES) # Test dataset is only of size batch "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define dataloader\n",
    "train_dl = DataLoader(train_ds, batch_size=BS, shuffle=True)\n",
    "test_dl = DataLoader(test_ds, batch_size=BS, shuffle=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABDAAAANYCAYAAAAylB2vAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAADDvUlEQVR4nOzdf7xdVX3n//eHhB8WUUHwRyEYzFAtaKBw5Ydaf6ADGPsVndrey4wtdphJlVq1tLbYtFNrm/6ILbWOwTYjFq3WxDpqGYtShQRqkGCCEPlRagKxhPoj5kalKCLw+f5x9iEnJ+f3WXuvtfZ+PR+P/bj3nHvu3muvvfb7rrv2L3N3AQAAAAAApOyA2AUAAAAAAAAYhgEMAAAAAACQPAYwAAAAAABA8hjAAAAAAAAAyWMAAwAAAAAAJI8BDAAAAAAAkLzSBjDM7ANm9i0zu63jvSPM7HNm9tXi6+FlLR8AmsrMdpjZV8zsFjPbXLzXM3+t5T1mts3MtprZKR3zuaD4/FfN7IJY6wMAoG8NAFK5Z2BcIencrvcukXSNux8v6ZriNQAgvJe6+8nuPlO87pe/r5B0fDEtl/Q+qdUplvR7kk6XdJqk36NjDABRXSH61gAarrQBDHe/XtJ819vnSfpg8f0HJb26rOUDAPbRL3/Pk/Qhb7lR0pPM7OmSzpH0OXefd/c9kj6n/TvOAICK0LcGAGlhxct7qrt/vfj+G5Ke2u+DZrZcraOBOvTQQ0999rOfXUHxADTVli1bvu3uR8UuRyAu6Z/MzCX9tbuvUf/8PVrSvR2/u7N4r9/7+yCrAVStZnk9LfrWAJJUVlZXPYDxGHf3onPd7+drJK2RpJmZGd+8eXNlZQPQPGb2tdhlCOiF7n6fmT1F0ufM7F86fzgsf8dBVgOoWs3yOhj61gBSUlZWV/0Ukm8Wpyar+PqtipcPALXn7vcVX78l6ZNq3cOiX/7eJ2lRx68fU7zX730AQDroWwNolKoHMK6U1L6T/QWS/qHi5QNArZnZoWZ2WPt7SWdLuk398/dKSb9YPI3kDEnfLU5HvlrS2WZ2eHHzzrOL9wAA6aBvDaBRSruExMw+Kuklko40s51q3c3+TyR9zMwulPQ1ST9f1vIBoKGeKumTZia1Mv7v3P2zZvYl9c7fqyQtk7RN0vcl/ZIkufu8mf2BpC8Vn3unu3ffPA4AUBH61gBQ4gCGu5/f50cvK2uZANB07n63pJN6vL9bPfLX3V3Sr/SZ1wckfSB0GYGm+tGPfqSdO3fqwQcfjF2ULBxyyCE65phjdOCBB8YuShLoWwNAxJt4AgAANMnOnTt12GGHafHixSrOkkIf7q7du3dr586dOu6442IXBwCQiKrvgQEAANBIDz74oJ785CczeDECM9OTn/xkzlYBAOyDAQwAAICKMHgxOuoKANCNAQwAAAAAAJA8BjAAAAAaYPfu3Tr55JN18skn62lPe5qOPvrox14/9NBDpS//61//us4+++zSlwMAqC9u4gkAANAAT37yk3XLLbdIkt7xjnfo8Y9/vH7jN37jsZ8//PDDWriwvK7hZz/7WZ1zzjmlzR8AUH+cgQEAANBQr3/96/WGN7xBp59+un7zN39T73jHO/Rnf/Znj/38Oc95jnbs2CFJ+vCHP6zTTjtNJ598sn75l39ZjzzyyH7zW7x4sX7zN39Tz33uc3Xaaadp27Ztj/3ss5/9rF7xilfI3fWmN71Jz3rWs/Tyl79cy5Yt08c//vHS1xUAkD8GMAAAABps586duuGGG3TppZf2/cydd96pdevWaePGjbrlllu0YMECfeQjH+n52Sc+8Yn6yle+oje96U1661vfKkl65JFHdNddd+mEE07QJz/5Sd11112644479KEPfUg33HBDGasFAKghLiEBAABI1Py8tHatNDcnHXFEOcv4uZ/7OS1YsGDgZ6655hpt2bJFz3ve8yRJP/jBD/SUpzyl52fPP//8x77+2q/9miRp06ZNOv300yVJ119/vc4//3wtWLBAP/7jP66zzjor1KoAAGqOAQwAAIBErV0rXXxx6/uLLipnGYceeuhj3y9cuFCPPvroY68ffPBBSZK764ILLtAf//EfD51f5+NP299/5jOf0bnnnhuqyACAhuISEgAAgETNzUmXXtr6WoXFixfr5ptvliTdfPPNuueeeyRJL3vZy/Txj39c3/rWtyRJ8/Pz+trXvtZzHuvWrXvs65lnnimpdQbHy1/+cknSi170Iq1bt06PPPKIvv71r2v9+vWlrhMAoD44AwMAACBRRxxR3pkXvfzsz/6sPvShD+nEE0/U6aefrp/4iZ+QJJ1wwgn6wz/8Q5199tl69NFHdeCBB2r16tV6xjOesd889uzZo6VLl+rggw/WRz/6Ue3atUuHHHKIDjvsMEnSa17zGl177bU64YQTdOyxxz42yAEAwDAMYAAAADTMO97xjp7vP+5xj9M//dM/9fzZ7OysZmdnh877bW97m/70T//0sdcf/vCHdfbZZz/22sz03ve+97HXr3/960crNACg8RjAAAAAQGle97rXxS4CAKAmGMAAAABAEDt27Bj7d6644org5QAA1BM38QQAAAAAAMljAAMAAAAAACSPAQwAAAAAAJA8BjAAAAAAAEDyGMAAAABoiG984xuam5vTkiVLdOqpp2rZsmX613/9176f37Fjhx73uMfp5JNP1kknnaTnP//5uuuuu8Ze7p/8yZ/oIx/5yDRFBwCAAQwAAIAmcHe95jWv0Ute8hJt375dW7Zs0R//8R/rm9/85sDfW7JkiW655RbdeuutuuCCC/RHf/RHYy/76quv1tlnnz1p0QEAkMQABgAAQCOsX79eBx54oN7whjc89t5JJ52kn/7pn5a7621ve5ue85zn6LnPfa7WrVvXcx7f+973dPjhh+/3/oYNG/SiF71Ir3zlK/WsZz1Lb3jDG/Too48+9jsPPfSQjjrqKN1zzz0688wz9dznPle/8zu/o8c//vHlrCwAoJYWxi4AAAAAynfbbbfp1FNP7fmzT3ziE4+dZfHtb39bz3ve8/SiF71IkrR9+3adfPLJuv/++/X9739fmzZt6jmPm266SXfccYee8Yxn6Nxzz9UnPvEJvfa1r9XnP/95vexlL5MkveUtb9Eb3/hG/eIv/qJWr15dzooCAGqLMzAAAABSNT8vXXZZ62uJvvCFL+j888/XggUL9NSnPlUvfvGL9aUvfUnS3ktItm/frne/+91avnx5z3mcdtppeuYzn6kFCxbo/PPP1xe+8AVJ0mc/+1m94hWvkCRt3LhR559/viTpF37hF0pdJwBA/TCAAQAAkKq1a6WLL259ndKJJ56oLVu2TDWPV73qVbr++ut7/szMer6+6aabdNppp/X9HAAAo2IAAwAAIFVzc9Kll7a+Tumss87SD3/4Q61Zs+ax97Zu3ap//ud/1k//9E9r3bp1euSRR7Rr1y5df/31+ww6tH3hC1/QkiVLes7/pptu0j333KNHH31U69at0wtf+ELdfvvtevazn60FCxZIkl7wghdobTEYw1NJAADjYgADAAAgVUccIV10UevrlMxMn/zkJ/X5z39eS5Ys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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=1.,c='b')\n",
    "scat2 = ax2.scatter(x,y,label='CoB p/q',alpha=0.9,s=1.,c='r')\n",
    "test_line, = ax3.plot([0,1],[0,1])\n",
    "\n",
    "ax1.set_xlabel(\"Iteration\")\n",
    "ax1.set_ylabel(\"Train Loss\")\n",
    "ax1.set_xlim([0,NUM_EPOCHS*NUM_SAMPLES//BS])\n",
    "ax1.set_ylim([0,10])\n",
    "\n",
    "ax2.set_xlabel(\"Samples\")\n",
    "ax2.set_ylabel(\"Log Ratio\")\n",
    "ax2.legend(loc='best')\n",
    "ax2.set_xlim([-6,10])\n",
    "ax2.set_ylim([-1500,5000])\n",
    "\n",
    "ax3.set_xlabel(\"Iteration\")\n",
    "ax3.set_ylabel(\"Test Loss\")\n",
    "ax3.set_xlim([0,NUM_EPOCHS*NUM_SAMPLES//BS])\n",
    "ax3.set_ylim([0,10])\n",
    "\n",
    "scat3 = ax4.scatter(x,y,label='True p/q from p',alpha=0.9,s=1.,c='b')\n",
    "scat4 = ax4.scatter(x,y,label='CoB p/q from p',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat5 = ax5.scatter(x,y,label='True p/q from m1',alpha=0.9,s=1.,c='b')\n",
    "scat6 = ax5.scatter(x,y,label='CoB p/q from m2',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat7 = ax6.scatter(x,y,label='True p/q from m2',alpha=0.9,s=1.,c='b')\n",
    "scat8 = ax6.scatter(x,y,label='CoB p/q from m2',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat9 = ax7.scatter(x,y,label='True p/q from m3',alpha=0.9,s=1.,c='b')\n",
    "scat10 = ax7.scatter(x,y,label='CoB p/q from m3',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat11 = ax8.scatter(x,y,label='True p/q from q',alpha=0.9,s=1.,c='b')\n",
    "scat12 = ax8.scatter(x,y,label='CoB p/q from q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "plt.tight_layout()\n",
    "\n",
    "loss_store = []\n",
    "test_loss_store = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABCkAAANYCAYAAADpL7eNAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAACZ9ElEQVR4nOzdeZyWdb3/8ddnNgYYtgFEBAREFHEXxK3M1NxLrSw8mbacn22e7Fh5LDstpz37tZ3SDr8stSw00/KUZWqZqbkAueEKboAgm7JvM/P9/XHfgwMOMMx2Xfc9r+fjcT/mvq97+1ww85lr3vf3+70ipYQkSZIkSVLWKrIuQJIkSZIkCQwpJEmSJElSThhSSJIkSZKkXDCkkCRJkiRJuWBIIUmSJEmScsGQQpIkSZIk5UKXhhQR8dOIWBwRj7XYVh8Rt0XEM8Wvg7qyBklSQUSMioi/RsTjETE7Ii4sbm+1L0fBDyJiTkQ8EhGHZLsHktSzeWwtqSfo6pEUVwEnbbXtEuCOlNJ44I7ibUlS12sAPplSmggcDnwsIiay7b58MjC+eDkfuKL7S5YktXAVHltLKnNdGlKklO4Clm+1+XTg6uL1q4EzurIGSVJBSmlhSmlW8foq4AlgBNvuy6cD16SC+4CBETG8e6uWJDXz2FpST1CVwXsOSyktLF5fBAxr7UERcT6FT+7o3bduUmO/XRkzuC/9arMoWVJPMHPmzKUppaFZ19EdImIMcDBwP9vuyyOAeS2eNr+4bWGLbVv06759+06aMGFC1xUuqcfrSb26jXb62NpeLak7tLdfZ/oXf0opRUTaxn3TgGkA+x5wcFpzyle4/LzJHLdPq31XkjosIl7IuobuEBF1wG+AT6SUVkbE5vu215e3pWW/njx5cpoxY0ZnlitJW+gpvbo92npsba+W1B3a26+zOLvHy83DhYtfF+/wGcXj502NO3XcLEnaSkRUUwgork0p3VjcvK2+vAAY1eLpI4vbJEn5sfPH1pKUY1mEFDcD5xWvnwf8bkdPiGJK0dhkSCFJ7RWFIRNXAk+klL7T4q5t9eWbgXOLZ/k4HFjRYkixJCkfdvrYWpLyrEune0TEr4BjgCERMR/4AvAN4PqI+CDwAvCuHb9O4WtDU1NXlSpJPcFRwHuBRyPioeK2z7LtvnwLcAowB1gLvL9bq5UkbaGzjq0lKc+6NKRIKZ29jbuO25nXaZ4t3eB0D0lqt5TS3bzWUrf2ur6cUkrAx7q0KKmH2bRpE/Pnz2f9+vVZl5J7tbW1jBw5kurq6qxLyY3OOraWpDwriVNlNI+kcLqHJEkqZfPnz6dfv36MGTOGlovWakspJZYtW8b8+fMZO3Zs1uVIkrpRFmtStEPhl/gmp3tIkqQStn79egYPHmxAsQMRweDBgx1xIkk9UEmEFI6kkCRJ5cKAom38d5Kknqk0QoriV9ekkCRJkiSpfJVGSOHZPSRJkjps2bJlHHTQQRx00EHsuuuujBgxYvPtjRs3dvn7L1y4kBNOOKHL30eSVLpKY+HM4liKBqd7SJIktdvgwYN56KGHAPjiF79IXV0dn/rUpzbf39DQQFVV1x0e/ulPf+LEE0/ssteXJJW+khhJ0Tzfw+kekiRJnet973sfH/7whznssMO4+OKL+eIXv8i3v/3tzffvt99+PP/88wD84he/YMqUKRx00EF86EMforGx8XWvN2bMGC6++GL2339/pkyZwpw5czbf96c//YmTTz6ZlBIXXHABe++9N8cffzynnHIKN9xwQ5fvqyQp/0oipNi8JoUjKSRJkjrd/Pnzuffee/nOd76zzcc88cQTXHfdddxzzz089NBDVFZWcu2117b62AEDBvDoo49ywQUX8IlPfAKAxsZGnnrqKSZOnMhNN93EU089xeOPP84111zDvffe2xW7JUkqQSUx3QOgqiJodE0KSZLUwyxfDtOnw9SpUF/fNe9x1llnUVlZud3H3HHHHcycOZNDDz0UgHXr1rHLLru0+tizzz5789d///d/B+D+++/nsMMOA+Cuu+7i7LPPprKykt12241jjz22s3ZFklTiSiakqKwIp3tIkqQeZ/p0uOiiwvWPfrRr3qNv376br1dVVdHU4oOh9evXA5BS4rzzzuPrX//6Dl+v5elDm6//8Y9/5KSTTuqskiVJZaokpnsA1FRWsMmQQpIk9TBTp8J3vlP42h3GjBnDrFmzAJg1axbPPfccAMcddxw33HADixcvBmD58uW88MILrb7Gddddt/nrEUccARRGYhx//PEAHH300Vx33XU0NjaycOFC/vrXv3bpPkmSSkfJjKSorqpgU6PTPSRJUs9SX991Iyha8453vINrrrmGfffdl8MOO4y99toLgIkTJ/KVr3yFE044gaamJqqrq/nRj37E6NGjX/car7zyCgcccAC9evXiV7/6FUuWLKG2tpZ+/foBcOaZZ/KXv/yFiRMnsvvuu28OMiRJKpmQoqoiDCkkSZI6yRe/+MVWt/fu3Zs///nPrd737ne/m3e/+907fO1Pf/rTfPOb39x8+xe/+AUnnHDC5tsRwQ9/+MPNt9/3vve1rWhJUtkrmZCi2ukekiRJJemcc87JugRJUokomZCixukekiRJuff888/v9HOuuuqqTq9DklSaSmbhzOpKp3tIkiRJklTOSiakqKpwJIUkSZIkSeWsZEKK6qoKNromhSRJkiRJZatkQoqayqDBkRSSJEmSJJWtkgkpCmf3MKSQJEnqiEWLFjF16lTGjRvHpEmTOOWUU3j66ae3+fjnn3+e3r17c9BBB3HggQdy5JFH8tRTT+30+37jG9/g2muv7UjpkqQeoKRCCqd7SJIktV9KiTPPPJNjjjmGuXPnMnPmTL7+9a/z8ssvb/d548aN46GHHuLhhx/mvPPO42tf+9pOv/ett97KCSec0N7SJUk9RAmFFMGmBkdSSJIktddf//pXqqur+fCHP7x524EHHsgb3/hGUkp8+tOfZr/99mP//ffnuuuua/U1Vq5cyaBBg163/c477+Too4/m1FNPZe+99+bDH/4wTU1Nm5+zceNGhg4dynPPPccRRxzB/vvvz+c+9znq6uq6ZmclSSWpKusC2qq6soKGJkMKSZKk9nrssceYNGlSq/fdeOONm0dLLF26lEMPPZSjjz4agLlz53LQQQexatUq1q5dy/3339/qazzwwAM8/vjjjB49mpNOOokbb7yRd77zndx+++0cd9xxAFx44YV85CMf4dxzz+VHP/pR1+yoJKlkldBIigo2Od1DkiT1NMuXw+WXF752obvvvpuzzz6byspKhg0bxpve9CYefPBB4LXpHnPnzuV73/se559/fquvMWXKFPbYYw8qKys5++yzufvuuwH405/+xMknnwzAPffcw9lnnw3Ae9/73i7dJ0lS6SmpkGKj0z0kSVJPM306XHRR4WsH7bvvvsycObNDr/G2t72Nu+66q9X7IqLV2w888ABTpkzZ5uMkSWpWQiFFeHYPSZLU80ydCt/5TuFrBx177LFs2LCBadOmbd72yCOP8Pe//503vvGNXHfddTQ2NrJkyRLuuuuuLYKFZnfffTfjxo1r9fUfeOAB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\n",
      "text/plain": [
       "<Figure size 1080x864 with 9 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|▍         | 45/1000 [01:16<27:02,  1.70s/it]\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-12-5758e8a809c9>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     12\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     13\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mepoch\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mtrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mNUM_EPOCHS\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 14\u001b[0;31m     \u001b[0;32mfor\u001b[0m \u001b[0mp_batch\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mq_batch\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mm_batch1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mm_batch2\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mm_batch3\u001b[0m \u001b[0;32min\u001b[0m \u001b[0miter\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtrain_dl\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     15\u001b[0m         \u001b[0mmodel_cob\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtrain\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     16\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/sr/lib/python3.7/site-packages/torch/utils/data/dataloader.py\u001b[0m in \u001b[0;36m__next__\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    361\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    362\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__next__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 363\u001b[0;31m         \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_next_data\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    364\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_num_yielded\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    365\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_dataset_kind\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0m_DatasetKind\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mIterable\u001b[0m \u001b[0;32mand\u001b[0m\u001b[0;31m \u001b[0m\u001b[0;31m\\\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/sr/lib/python3.7/site-packages/torch/utils/data/dataloader.py\u001b[0m in \u001b[0;36m_next_data\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    401\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_next_data\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    402\u001b[0m         \u001b[0mindex\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_next_index\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# may raise StopIteration\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 403\u001b[0;31m         \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_dataset_fetcher\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfetch\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mindex\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# may raise StopIteration\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    404\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_pin_memory\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    405\u001b[0m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0m_utils\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpin_memory\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpin_memory\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdata\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/sr/lib/python3.7/site-packages/torch/utils/data/_utils/fetch.py\u001b[0m in \u001b[0;36mfetch\u001b[0;34m(self, possibly_batched_index)\u001b[0m\n\u001b[1;32m     42\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mfetch\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     43\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mauto_collation\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 44\u001b[0;31m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0midx\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     45\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     46\u001b[0m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/sr/lib/python3.7/site-packages/torch/utils/data/_utils/fetch.py\u001b[0m in \u001b[0;36m<listcomp>\u001b[0;34m(.0)\u001b[0m\n\u001b[1;32m     42\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mfetch\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     43\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mauto_collation\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 44\u001b[0;31m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0midx\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     45\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     46\u001b[0m             \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdataset\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mpossibly_batched_index\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/cob_pytorch/src/dataset.py\u001b[0m in \u001b[0;36m__getitem__\u001b[0;34m(self, idx)\u001b[0m\n\u001b[1;32m    106\u001b[0m         \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mm_samples3\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mshape\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    107\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__getitem__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0midx\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 108\u001b[0;31m         \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mp_samples\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mq_samples\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mm_samples1\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mm_samples2\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mm_samples3\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0midx\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    109\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    110\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__len__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "## CONFIRM q_list_test in validation/visualization in Akash's code\n",
    "\n",
    "model_cob.train()\n",
    "\n",
    "if torch.cuda.is_available():\n",
    "    model_cob = model_cob.to(DEVICE)\n",
    "    \n",
    "i = 0\n",
    "# loss_crit = torch.nn.CrossEntropyLoss()\n",
    "loss_crit_cob = torch.nn.functional.cross_entropy\n",
    "\n",
    "\n",
    "for epoch in trange(NUM_EPOCHS):\n",
    "    for p_batch, q_batch, m_batch1, m_batch2, m_batch3 in iter(train_dl):\n",
    "        model_cob.train()\n",
    "        \n",
    "        i += 1\n",
    "        \n",
    "        optim_cob.zero_grad()\n",
    "        \n",
    "        # CUDA\n",
    "        if torch.cuda.is_available():\n",
    "            p_batch, q_batch, m_batch1, m_batch2, m_batch3 = p_batch.unsqueeze(1).to(DEVICE), q_batch.unsqueeze(1).to(DEVICE), m_batch1.unsqueeze(1).to(DEVICE), m_batch2.unsqueeze(1).to(DEVICE), m_batch3.unsqueeze(1).to(DEVICE)\n",
    "            \n",
    "        logP = model_cob(p_batch)\n",
    "        logQ = model_cob(q_batch)\n",
    "        logM1 = model_cob(m_batch1)\n",
    "        logM2 = model_cob(m_batch2)\n",
    "        logM3 = model_cob(m_batch3)\n",
    "        \n",
    "        p_label = torch.empty(p_batch.shape[0], dtype=torch.long, device=DEVICE).fill_(0)\n",
    "        q_label = torch.empty(q_batch.shape[0], dtype=torch.long, device=DEVICE).fill_(1)\n",
    "        m1_label = torch.empty(m_batch1.shape[0], dtype=torch.long, device=DEVICE).fill_(2)\n",
    "        m2_label = torch.empty(m_batch2.shape[0], dtype=torch.long, device=DEVICE).fill_(3)\n",
    "        m3_label = torch.empty(m_batch3.shape[0], dtype=torch.long, device=DEVICE).fill_(4)\n",
    "        \n",
    "        loss_cob = loss_crit_cob(logP, p_label) + loss_crit_cob(logQ, q_label) + loss_crit_cob(logM1, m1_label) + loss_crit_cob(logM2, m2_label) + loss_crit_cob(logM3, m3_label)\n",
    "        loss_cob.backward()\n",
    "        optim_cob.step()\n",
    "        loss_store.append(loss_cob.item())\n",
    "\n",
    "        # Validation/Test\n",
    "        if i % 50 == 0:\n",
    "            model_cob.eval()\n",
    "            \n",
    "            with torch.no_grad():\n",
    "                for p_batch, q_batch, m_batch1, m_batch2, m_batch3 in iter(test_dl):\n",
    "                    gt_lr_p_q_from_p, _, true_kl_p_q = get_gt_ratio_kl(p, q, p_batch, calc_true_kl=True)\n",
    "                    gt_lr_p_q_from_m1, _ = get_gt_ratio_kl(p, q, m_batch1, calc_true_kl=False)\n",
    "                    gt_lr_p_q_from_m2, _ = get_gt_ratio_kl(p, q, m_batch2, calc_true_kl=False)\n",
    "                    gt_lr_p_q_from_m3, _ = get_gt_ratio_kl(p, q, m_batch3, calc_true_kl=False)\n",
    "                    gt_lr_p_q_from_q, _ = get_gt_ratio_kl(p, q, q_batch, calc_true_kl=False)\n",
    "\n",
    "                    if torch.cuda.is_available():\n",
    "                        p_batch, q_batch, m_batch1, m_batch2, m_batch3 = p_batch.unsqueeze(1).to(DEVICE), q_batch.unsqueeze(1).to(DEVICE), m_batch1.unsqueeze(1).to(DEVICE), m_batch2.unsqueeze(1).to(DEVICE), m_batch3.unsqueeze(1).to(DEVICE)\n",
    "                    \n",
    "                    logP = model_cob(p_batch)\n",
    "                    logQ = model_cob(q_batch)\n",
    "                    logM1 = model_cob(m_batch1)\n",
    "                    logM2 = model_cob(m_batch2)\n",
    "                    logM3 = model_cob(m_batch3)\n",
    "\n",
    "                    p_label = torch.empty(p_batch.shape[0], dtype=torch.long, device=DEVICE).fill_(0)\n",
    "                    q_label = torch.empty(q_batch.shape[0], dtype=torch.long, device=DEVICE).fill_(1)\n",
    "                    m1_label = torch.empty(m_batch1.shape[0], dtype=torch.long, device=DEVICE).fill_(2)\n",
    "                    m2_label = torch.empty(m_batch2.shape[0], dtype=torch.long, device=DEVICE).fill_(3)\n",
    "                    m3_label = torch.empty(m_batch3.shape[0], dtype=torch.long, device=DEVICE).fill_(4)\n",
    "\n",
    "#                     log_ratio_p_q_from_cob = logP[:, 0] - logP[:, 1]\n",
    "#                     kl_from_cob = torch.mean(log_ratio_p_q_from_cob)\n",
    "                    \n",
    "                    lr_p_q_cob_from_p = logP[:, 0] - logP[:, 1]\n",
    "                    lr_p_q_cob_from_m1 = logM1[:, 0] - logM1[:, 1]\n",
    "                    lr_p_q_cob_from_m2 = logM2[:, 0] - logM2[:, 1]\n",
    "                    lr_p_q_cob_from_m3 = logM3[:, 0] - logM3[:, 1]\n",
    "                    lr_p_q_cob_from_q = logQ[:, 0] - logQ[:, 1]                    \n",
    "                    \n",
    "                    test_loss_cob = loss_crit_cob(logP, p_label) + loss_crit_cob(logQ, q_label) + loss_crit_cob(logM1, m1_label) + loss_crit_cob(logM2, m2_label) + loss_crit_cob(logM3, m3_label)\n",
    "\n",
    "                    # Visualize\n",
    "                    line.set_data(range(len(loss_store)), loss_store)\n",
    "                    ax1.set_xlim( 0, len(loss_store) )\n",
    "                    \n",
    "                    scat1.set_offsets(np.vstack([p_batch.cpu().squeeze(), gt_lr_p_q_from_p.cpu().detach()]).T)\n",
    "                    scat2.set_offsets(np.vstack([p_batch.cpu().squeeze(), lr_p_q_cob_from_p.cpu().detach()]).T)\n",
    "                    ax2.set_xlim( -5., 5. )\n",
    "                    ax2.set_ylim( -400, 200)\n",
    "                    \n",
    "                    scat3.set_offsets(np.vstack([p_batch.cpu().squeeze(), gt_lr_p_q_from_p.cpu().detach()]).T)\n",
    "                    scat4.set_offsets(np.vstack([p_batch.cpu().squeeze(), lr_p_q_cob_from_p.cpu().detach()]).T)\n",
    "                    ax4.set_xlim( -5., 5. )\n",
    "                    ax4.set_ylim( -400, 200)\n",
    "                    \n",
    "                    scat5.set_offsets(np.vstack([m_batch1.cpu().squeeze(), gt_lr_p_q_from_m1.cpu().detach()]).T)\n",
    "                    scat6.set_offsets(np.vstack([m_batch1.cpu().squeeze(), lr_p_q_cob_from_m1.cpu().detach()]).T)\n",
    "                    ax5.set_xlim( -5., 5. )\n",
    "                    ax5.set_ylim( -400, 200)\n",
    "                    \n",
    "                    scat7.set_offsets(np.vstack([m_batch2.cpu().squeeze(), gt_lr_p_q_from_m2.cpu().detach()]).T)\n",
    "                    scat8.set_offsets(np.vstack([m_batch2.cpu().squeeze(), lr_p_q_cob_from_m2.cpu().detach()]).T)\n",
    "                    ax6.set_xlim( -5., 5. )\n",
    "                    ax6.set_ylim( -400, 200)\n",
    "                    \n",
    "                    scat9.set_offsets(np.vstack([m_batch3.cpu().squeeze(), gt_lr_p_q_from_m3.cpu().detach()]).T)\n",
    "                    scat10.set_offsets(np.vstack([m_batch3.cpu().squeeze(), lr_p_q_cob_from_m3.cpu().detach()]).T)\n",
    "                    ax7.set_xlim( -5., 5. )\n",
    "                    ax7.set_ylim( -400, 200)\n",
    "                    \n",
    "                    scat11.set_offsets(np.vstack([q_batch.cpu().squeeze(), gt_lr_p_q_from_q.cpu().detach()]).T)\n",
    "                    scat12.set_offsets(np.vstack([q_batch.cpu().squeeze(), lr_p_q_cob_from_q.cpu().detach()]).T)\n",
    "                    ax8.set_xlim( -5., 5. )\n",
    "                    ax8.set_ylim( -400, 200)\n",
    "            \n",
    "                    test_loss_store.append(test_loss_cob.item())\n",
    "                    test_line.set_data(range(len(test_loss_store)), test_loss_store)\n",
    "                    ax3.set_xlim( 0, len(test_loss_store) )\n",
    "                    \n",
    "                    clear_output(wait=True)\n",
    "                    display(fig)\n",
    "                    break\n",
    "\n",
    "            model_cob.train()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save({\n",
    "    'model': model_cob.state_dict(),\n",
    "    'optimizer': optim_cob.state_dict()\n",
    "}, '1D_cob_best1.pth')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_cob = RatioCritic1D_K3(dim_input=N_DIMS, dim_output=3, dropout=DROPOUT)\n",
    "\n",
    "ckpt = torch.load('1D_cob_best.pth')\n",
    "model_cob.load_state_dict(ckpt['model'])\n",
    "model_cob = model_cob.to(DEVICE)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "                    print('iteration: ',i)\n",
    "                    print('KLD: ', true_kl_p_q)\n",
    "                    print('CoB: ', log_ratio_p_q_from_cob.mean())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "m1, m2, m3 = m"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[Normal(loc: -0.5, scale: 0.09013878554105759),\n",
       " Normal(loc: 0.0, scale: 0.11180339753627777),\n",
       " Normal(loc: 0.5, scale: 0.1520690619945526)]"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "m"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_gt_log_ratios(p, q, m1, m2, m3, samples):\n",
    "    p_lp = p.log_prob(samples.cpu())\n",
    "    q_lp = q.log_prob(samples.cpu())\n",
    "    m1_lp = m1.log_prob(samples.cpu())\n",
    "    m2_lp = m2.log_prob(samples.cpu())\n",
    "    m3_lp = m3.log_prob(samples.cpu())\n",
    "    \n",
    "#     return p_lp - q_lp,  p_lp - m1_lp, m1_lp - m2_lp, m2_lp - m3_lp, m3_lp - q_lp #p_lp - m_lp, q_lp - m_lp, m_lp - q_lp # p/q, p/m, q/m, m/q\n",
    "    return p_lp - q_lp #, p_lp - m2_lp, q_lp - m2_lp, m1_lp - m2_lp, m3_lp - m2_lp\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_gt_log_ratios(p, q, m1, m2, m3, samples):\n",
    "    p_lp = p.log_prob(samples.cpu())\n",
    "    q_lp = q.log_prob(samples.cpu())\n",
    "    m1_lp = m1.log_prob(samples.cpu())\n",
    "    m2_lp = m2.log_prob(samples.cpu())\n",
    "    m3_lp = m3.log_prob(samples.cpu())\n",
    "    \n",
    "#     return p_lp - q_lp,  p_lp - m1_lp, m1_lp - m2_lp, m2_lp - m3_lp, m3_lp - q_lp #p_lp - m_lp, q_lp - m_lp, m_lp - q_lp # p/q, p/m, q/m, m/q\n",
    "    return p_lp - q_lp, m1_lp - q_lp, m2_lp - q_lp, m3_lp - q_lp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "#######\n",
    "with torch.no_grad():\n",
    "    model_cob.eval()\n",
    "    for p_batch, q_batch, m_batch1, m_batch2, m_batch3 in iter(test_dl):\n",
    "        if torch.cuda.is_available():\n",
    "            p_batch, q_batch, m_batch1, m_batch2, m_batch3 = p_batch.unsqueeze(1).to(DEVICE), q_batch.unsqueeze(1).to(DEVICE), m_batch1.unsqueeze(1).to(DEVICE), m_batch2.unsqueeze(1).to(DEVICE), m_batch3.unsqueeze(1).to(DEVICE)\n",
    "\n",
    "\n",
    "        logP = model_cob(p_batch).cpu()\n",
    "        logM1 = model_cob(m_batch1).cpu()\n",
    "        logM2 = model_cob(m_batch2).cpu()\n",
    "        logM3 = model_cob(m_batch3).cpu()\n",
    "        logQ = model_cob(q_batch).cpu()\n",
    "\n",
    "        log_ratio_p_q_from_cob_from_p = logP[:, 0] - logP[:, 1]\n",
    "        log_ratio_p_q_from_cob_from_m1 = logM1[:, 0] - logM1[:, 1]\n",
    "        log_ratio_p_q_from_cob_from_m2 = logM2[:, 0] - logM2[:, 1]\n",
    "        log_ratio_p_q_from_cob_from_m3 = logM3[:, 0] - logM3[:, 1]\n",
    "        log_ratio_p_q_from_cob_from_q = logQ[:, 0] - logQ[:, 1]\n",
    "        \n",
    "        true_log_ratio_p_q_from_p = get_gt_log_ratios(p, q, m1, m2, m3, p_batch)\n",
    "        true_log_ratio_p_q_from_m1 = get_gt_log_ratios(p, q, m1, m2, m3, m_batch1)\n",
    "        true_log_ratio_p_q_from_m2 = get_gt_log_ratios(p, q, m1, m2, m3, m_batch2)\n",
    "        true_log_ratio_p_q_from_m3 = get_gt_log_ratios(p, q, m1, m2, m3, m_batch3)\n",
    "        true_log_ratio_p_q_from_q = get_gt_log_ratios(p, q, m1, m2, m3, q_batch)\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set up viz\n",
    "fig, [ax1,ax2,ax3] = plt.subplots(1, 3,figsize=(8,3))\n",
    "p_batch = p_batch.cpu()\n",
    "\n",
    "scat1 = ax1.scatter(p_batch,true_log_ratio_p_q,label='True log p/q',alpha=0.9,s=10.,c='b')\n",
    "scat2 = ax1.scatter(p_batch,log_ratio_p_q_from_cob_from_p,label='Multi-class K=3 log p/q',alpha=0.9,s=10.,c='r')\n",
    "\n",
    "scat3 = ax2.scatter(p_batch,true_log_ratio_p_m,label='True log p/m',alpha=0.9,s=10.,c='b')\n",
    "scat4 = ax2.scatter(p_batch,log_ratio_p_m_from_cob_from_p,label='Multi-class K=3 log p/m',alpha=0.9,s=10.,c='r')\n",
    "\n",
    "scat5 = ax3.scatter(p_batch,true_log_ratio_q_m,label='True log q/m',alpha=0.9,s=10.,c='b')\n",
    "scat6 = ax3.scatter(p_batch,log_ratio_q_m_from_cob_from_p,label='Multi-class K=3 log q/m',alpha=0.9,s=10.,c='r')\n",
    "\n",
    "ylim = [-100, 150]\n",
    "xlim = [-3, 3]\n",
    "ax1.set_ylabel(\"Log Ratio\")\n",
    "ax1.legend(loc='best')\n",
    "ax1.set_xlim(xlim)\n",
    "ax1.set_ylim(ylim)\n",
    "\n",
    "ax2.set_ylabel(\"Log Ratio\")\n",
    "ax2.legend(loc='best')\n",
    "ax2.set_xlim(xlim)\n",
    "ax2.set_ylim(ylim)\n",
    "\n",
    "ax3.set_ylabel(\"Log Ratio\")\n",
    "ax3.legend(loc='best')\n",
    "ax3.set_xlim(xlim)\n",
    "ax3.set_ylim(ylim)\n",
    "\n",
    "# ax1.get_xaxis().set_visible(False)\n",
    "ax2.get_xaxis().set_visible(False)\n",
    "ax3.get_xaxis().set_visible(False)\n",
    "ax2.get_yaxis().set_visible(False)\n",
    "ax3.get_yaxis().set_visible(False)\n",
    "plt.tight_layout()\n",
    "plt.subplots_adjust(wspace=0, hspace=0.0)\n",
    "\n",
    "plt.savefig('1D_demo_cob_K=1_p.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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TYcOHbjxxhsr/XodOnTgwIEDRz/wGNxyyy3s2LEjpq8p4Sn3JBTlnoSgvJNQUiH3ilx77bW0b9+etm3bsnbt2uL26667jsLCwiM+d8OGDbRr145LLrmEn/3sZxw8eLBSMXz3u2W3J1zzZtmGxx6r1OsmqyCTXLj7D46wbwwwppz22UBKTJpfu3ZtFixYAEDbtm2L1wsLC8nKSo57O+/YsYN69eqFDkNiTLknoSj3JATlnYSSCrlX5LnnniM7O5uFCxfy8MMP8+ijj7J3716qVat21Fjr1KnDrFmzqF27NsOHD2f27NlceeWVlYqjbl344ovI+p1TWnFHdjbsjw4dvO02uPXWSr1uMkquDEhTAwYM4Pbbb6dbt248/fTTPPHEEwCMGjWKBQsW4O7ceuutdOrUicsvv5wvirLvEB999BGdOnWiTZs2jI1Obbl+/Xpat27NVVddRefOndm4cWOZ51x00UUMGDCAvLw8Zs2aBcAHH3zA6aefDsCIESNo164dN998MwMGDIjPD0CCUe5JKMo9CUF5J6GEzr2bb76Zc889l6eeeorevXvTokUL3n//fYDiGUu/+uorWrRoAcCiRYto164dGzdupF27dlxzzTW0bNmSF154gUsvvZS2bduye/du6tatS+3atYtfp0qVKlTWnDllt7dOeLFkwx3mzav0aycbFVgJ0qZNG15//fVy982aNYumTZsyb948br/9dh5//PFyjxs7diwPPPAAb731FvPnz2fr1q2MHz+eCRMmMHXqVD777LNvPWf79u2MHj2ahQsX8utf/xqA119/na5du7Jt2zaWLFnCokWLaN++fexOVpKKck9CUe5JCMo7CSVU7hUUFDB69GheeeUVhg0bxvPPP8/jjz/O5MmTAdi3bx9t27ZlyJAhXHTRRQDMmTOHrl27ApHC68UXX+Tee+8lPz+f119/ne7du/Paa68Vv8fWrVuZM2cOl156aaV/Pq1ald1uObInnHRSScNPf1rp1042KrAOI9Y342sVzarSF10WTZ64Zs0a8vPz6dChA2PGjKHgMG+6fv16zj//fABatmzJhg0b2LBhAy1atKBKlSqcc84533pOvXr1aNq0KTVr1iz+q8Nf/vIX2rRpw6ZNm4r/ktHq0KyXIOJxE0jlnlSEck9C0f+3Ekq65F79+vVp0KABjRo1Ijc3l+rVq9OoUaPi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\n",
      "text/plain": [
       "<Figure size 864x216 with 5 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Set up viz\n",
    "fig, [ax1,ax2,ax3, ax4,ax5] = plt.subplots(1, 5,figsize=(12,3))\n",
    "p_batch = p_batch.cpu()\n",
    "\n",
    "scat1 = ax1.scatter(p_batch.cpu(),true_log_ratio_p_q_from_p,label='True log p/q',alpha=0.9,s=1.,c='b')\n",
    "scat2 = ax1.scatter(p_batch.cpu(),log_ratio_p_q_from_cob_from_p,label='Multi-class log p/q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat3 = ax2.scatter(m_batch1.cpu(),true_log_ratio_p_q_from_m1,label='True log p/q',alpha=0.9,s=1.,c='b')\n",
    "scat4 = ax2.scatter(m_batch1.cpu(),log_ratio_p_q_from_cob_from_m1,label='Multi-class log p/q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat5 = ax3.scatter(m_batch2.cpu(),true_log_ratio_p_q_from_m2,label='True log p/q',alpha=0.9,s=1.,c='b')\n",
    "scat6 = ax3.scatter(m_batch2.cpu(),log_ratio_p_q_from_cob_from_m2,label='Multi-class log p/q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat7 = ax4.scatter(m_batch3.cpu(),true_log_ratio_p_q_from_m3,label='True log p/q',alpha=0.9,s=1.,c='b')\n",
    "scat8 = ax4.scatter(m_batch3.cpu(),log_ratio_p_q_from_cob_from_m3,label='Multi-class log p/q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "scat9 = ax5.scatter(q_batch.cpu(),true_log_ratio_p_q_from_q,label='True log m3/m2',alpha=0.9,s=1.,c='b')\n",
    "scat10 = ax5.scatter(q_batch.cpu(),log_ratio_p_q_from_cob_from_q,label='Multi-class log p/q',alpha=0.9,s=1.,c='r')\n",
    "\n",
    "ylim = [-300, 200]\n",
    "xlim = [-3, 3]\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_title('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_title('m1')\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_title('m2')\n",
    "\n",
    "ax4.set_ylabel(\"Log Ratio\")\n",
    "ax4.legend(loc='lower left', prop={'size': 8})\n",
    "ax4.set_xlim(xlim)\n",
    "ax4.set_ylim(ylim)\n",
    "ax4.set_title('m3')\n",
    "\n",
    "ax5.set_ylabel(\"Log Ratio\")\n",
    "ax5.legend(loc='lower left',prop={'size': 8})\n",
    "ax5.set_xlim(xlim)\n",
    "ax5.set_ylim(ylim)\n",
    "ax5.set_title('q')\n",
    "\n",
    "\n",
    "# ax1.get_xaxis().set_visible(False)\n",
    "# ax2.get_xaxis().set_visible(False)\n",
    "# ax3.get_xaxis().set_visible(False)\n",
    "# ax4.get_xaxis().set_visible(False)\n",
    "ax2.get_yaxis().set_visible(False)\n",
    "ax3.get_yaxis().set_visible(False)\n",
    "ax4.get_yaxis().set_visible(False)\n",
    "ax5.get_yaxis().set_visible(False)\n",
    "plt.tight_layout()\n",
    "plt.subplots_adjust(wspace=0, hspace=0.0)\n",
    "\n",
    "plt.savefig('1D_demo_cob_K=3_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
}
