{
 "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",
    "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 = 100000\n",
    "BS = 500\n",
    "NUM_EPOCHS = 400\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",
    "\n",
    "model_tre1 = RatioCritic1D(dim_input=N_DIMS, dim_output=1, dropout=DROPOUT, tre=True) # CHANGE 1D MODEL FOR TRE\n",
    "model_tre2 = RatioCritic1D(dim_input=N_DIMS, dim_output=1, dropout=DROPOUT, tre=True)\n",
    "# model.apply(weights_init)\n",
    "\n",
    "# Define optimizer\n",
    "optim_cob = torch.optim.Adam(model_cob.parameters(), lr=LR)\n",
    "optim_tre1 = torch.optim.Adam(model_tre1.parameters(), lr=LR)\n",
    "optim_tre2 = torch.optim.Adam(model_tre2.parameters(), lr=LR)\n",
    "\n",
    "# Define distributions\n",
    "p, q, m = get_dists_1d(mu1=-1., mu2=1., mu3=0, scale_p=0.9, scale_q=1.1, scale_m=1.0)\n",
    "\n",
    "# -5, 5, m_var=3.0\n",
    "# -10, 10, m_var=3.0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "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([100000])\n",
      "torch.Size([100000])\n",
      "torch.Size([100000])\n",
      "Sampling p\n",
      "Sampling q\n",
      "Cauchy(loc: 0.0, scale: 1.0)\n",
      "Sampling m\n",
      "torch.Size([100000])\n",
      "torch.Size([100000])\n",
      "torch.Size([100000])\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": 7,
   "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": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABDAAAAI4CAYAAACcFxlBAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAABjM0lEQVR4nO3dfbhcVXnw/+/dJCRIeDciEDARERsUIsYgghSBhoBWpKKQp9Sg9In4QAWtImh/BS0+ilrFFx5rLkFAEIIUKrXKi0hEoQIJhndTAgRJGiSGN0Xekty/P2adMDk5JzlJzszeZ+b7ua59zd5rr9n7njOTNSv3rL12ZCaSJEmSJEl19mdVByBJkiRJkrQuJjAkSZIkSVLtmcCQJEmSJEm1ZwJDkiRJkiTVngkMSZIkSZJUeyYwJEmSJElS7bUsgRER50XEYxFxd1PZNhFxXUTcXx63btX5JalbRcTCiLgrIuZFxJxS1mf7Gw1fj4gFEXFnROzVdJzppf79ETG9qtcjSbJvLUnQ2hEY5wNTe5WdClyfmbsC15dtSdLge3tmTszMSWW7v/b3UGDXsswAvgWNTjFwOrA3MBk43Y6xJFXqfOxbS+pyLUtgZOaNwOO9ig8HLijrFwDvbtX5JUmr6a/9PRy4MBt+BWwVEdsDhwDXZebjmfkEcB1rdpwlSW1i31qSYHibz7ddZi4p648C2/VXMSJm0Pg1kM022+xNr3vd69oQnqRuNXfu3N9n5piq4xgkCVwbEQl8OzNn0n/7uyPwSNNzF5Wy/spXY1stqd06rL3eWPatJdVSq9rqdicwVsnMLJ3r/vbPBGYCTJo0KefMmdO22CR1n4h4uOoYBtF+mbk4Il4BXBcRv2neua72d33YVktqtw5rrweNfWtJddKqtrrddyH5XRmaTHl8rM3nl6SOl5mLy+NjwJU05rDor/1dDOzU9PSxpay/cklSfdi3ltRV2p3AuAromcl+OvDDNp9fkjpaRGwWEZv3rANTgLvpv/29Cnh/uRvJW4CnynDka4ApEbF1mbxzSimTJNWHfWtJXaVll5BExCXAAcDLI2IRjdnsvwBcFhHHAQ8D72vV+SWpS20HXBkR0Gjjv5+ZV0fEbfTd/v4YOAxYAPwJ+ABAZj4eEf8M3FbqfTYze08eJ0lqE/vWktTCBEZmTutn10GtOqckdbvMfBDYs4/yZfTR/mZmAif0c6zzgPMGO0apW7344ossWrSI5557rupQhoRRo0YxduxYRowYUXUotWDfWpIqnMRTkiSpmyxatIjNN9+ccePGUUZJqR+ZybJly1i0aBHjx4+vOhxJUk20ew4MSZKkrvTcc8+x7bbbmrwYgIhg2223dbSKJGk1JjAkSZLaxOTFwPm3kiT1ZgJDkiRJkiTVngkMSZKkLrBs2TImTpzIxIkTeeUrX8mOO+64avuFF15o+fmXLFnClClTWn4eSVLnchJPSZKkLrDtttsyb948AM444wxGjx7Nxz/+8VX7ly9fzvDhresaXn311RxyyCEtO74kqfM5AkOSJKlLHXvssRx//PHsvffenHLKKZxxxhl8+ctfXrX/9a9/PQsXLgTgoosuYvLkyUycOJEPfehDrFixYo3jjRs3jlNOOYU3vOENTJ48mQULFqzad/XVV3PooYeSmZx44onstttuHHzwwRx22GFcfvnlLX+tkqShzwSGJElSTV17LXzqU43HVlm0aBE333wzX/nKV/qtc9999zFr1ixuuukm5s2bx7Bhw7j44ov7rLvlllty1113ceKJJ3LyyScDsGLFCubPn8+ECRO48sormT9/Pvfeey8XXnghN998cyteliSpA3kJiSRJUg1dey0ccww8/zx85ztw0UXQiikk3vve9zJs2LC11rn++uuZO3cub37zmwF49tlnecUrXtFn3WnTpq16/OhHPwrALbfcwt577w3AjTfeyLRp0xg2bBg77LADBx544GC9FElShzOBIUmSVEOzZzeSF5ttBs8809huRQJjs802W7U+fPhwVq5cuWr7ueeeAyAzmT59Op///OfXebzm25/2rP/kJz9h6tSpgxWyJKlLeQmJJElSDR1wAIwc2UhejBzZ2G61cePGcfvttwNw++2389BDDwFw0EEHcfnll/PYY48B8Pjjj/Pwww/3eYxZs2atetxnn32AxgiOgw8+GID999+fWbNmsWLFCpYsWcINN9zQ0tckSeocjsCQJEmqoSlTGpeNzJ7dSF604w6k73nPe7jwwgvZfffd2XvvvXnta18LwIQJEzjzzDOZMmUKK1euZMSIEZxzzjm86lWvWuMYTzzxBHvssQcjR47kkksuYenSpYwaNYrNN98cgCOOOIKf/exnTJgwgZ133nlVkkOSpHUxgSFJklRTU6a0JnFxxhln9Fm+6aabcm0/M4YeddRRHHXUUes89ic+8QnOOuusVdsXXXQRU5peRETwzW9+c9X2scceO7CgJUldzwSGJEmSWuaYY46pOgRJUocwgSFJkqRBsXDhwvV+zvnnnz/ocUiSOpOTeEqSJEmSpNozgSFJkiRJkmrPBIYkSZIkSao9ExiSJEmSJKn2TGBIkiR1iUcffZSjjz6aXXbZhTe96U0cdthh/Pd//3e/9RcuXMimm27KxIkT2XPPPXnrW9/K/Pnz1/u8X/jCF7j44os3JnRJkkxgSJIkdYPM5IgjjuCAAw7ggQceYO7cuXz+85/nd7/73Vqft8suuzBv3jzuuOMOpk+fzv/9v/93vc99zTXXMGXKlA0NXZIkwASGJElSV7jhhhsYMWIExx9//KqyPffck7e97W1kJp/4xCd4/etfzxve8AZmzZrV5zGefvpptt566zXKZ8+ezf7778873vEOdtttN44//nhWrly56jkvvPACY8aM4aGHHmKfffbhDW94A//4j//I6NGjW/NiJUkdaXjVAUiSJKkf114Ls2fDAQfARo5guPvuu3nTm97U574rrrhi1SiL3//+97z5zW9m//33B+CBBx5g4sSJ/OEPf+BPf/oTt9xyS5/HuPXWW7n33nt51atexdSpU7niiis48sgj+elPf8pBBx0EwEknncSHP/xh3v/+93POOeds1OuRJHUfR2BIkiTV0bXXwjHHwDnnNB6vvbZlp/rlL3/JtGnTGDZsGNtttx1/8Rd/wW233Qa8dAnJAw88wNlnn82MGTP6PMbkyZN59atfzbBhw5g2bRq//OUvAbj66qs59NBDAbjpppuYNm0aAH/7t3/bstcjSepMJjAkSZLqaPZseP552GyzxuPs2Rt1uN133525c+du1DHe9a53ceONN/a5LyL63L711luZPHlyv/UkSRooExiSJEl1dMABMHIkPPNM4/GAAzbqcAceeCDPP/88M2fOXFV255138otf/IK3ve1tzJo1ixUrVrB06VJuvPHG1ZIOPX75y1+yyy679Hn8W2+9lYceeoiVK1cya9Ys9ttvP+655x5e97rXMWzYMAD23XdfLr30UgDvSiJJWm8mMCRJkupoyhS46CI44YTG40bOgRERXHnllfz0pz9ll112Yffdd+e0007jla98JUcccQR77LEHe+65JwceeCBf/OIXeeUr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\n",
      "text/plain": [
       "<Figure size 1080x576 with 6 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Set up viz\n",
    "fig, [[ax1,ax2,ax3], [ax4, ax5, ax6]] = plt.subplots(2, 3,figsize=(15,8))\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",
    "plt.tight_layout()\n",
    "\n",
    "loss_store = []\n",
    "test_loss_store = []\n",
    "\n",
    "loss_store_tre = []\n",
    "test_loss_store_tre = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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r7/+OgMGDKBXr16ViQoREWkalIQQERERSVK5ubFJPtx11101Lm/evDl5tVTBvOKKK7jiiisOuO9bb72V++67r3J+6tSp5EY9CTPjj3/8Y+X8VVddVbegRUSkUVASQkRERERiZuzYsYkOQUREkoiSECIiIiLSIFatWnXQj3nssccaPA4REUleKkwpIiIiIiIiInGhJISIiIiIiDQIww68kYg0aUpCiIiIiIhIg3FPdAQiksyUhBARERERERGRuFASQkRERKSJWL9+PVdeeSVHHXUUJ598Mueffz6ffPJJrduvWrWK5s2bM3jwYE444QROO+00li1bdtDHvffee3niiSfqE7qIiDQSSkKIiIiINAHuziWXXEJOTg6fffYZc+fOZeLEiWzYsGG/jzvqqKOYP38+H330EePGjeOee+456GO//PLL5ObmHmroIiLSiCgJISIiItIEvPHGG2RmZnLddddVLjvhhBM488wzcXduvfVWjj/+eAYOHMi0adNq3Mf27ds57LDD9lmen5/PWWedxQUXXEC/fv247rrrqKioqHzMnj176NixIytXrmT48OEMHDiQO++8k1atWsXmyYqISNLKSHQAIiIiIlKLvDzIz4ecHKhnS4JFixZx8skn17ju2WefrWzt8OWXX3LKKadw1llnAfDZZ58xePBgduzYwa5du5g9e3aN+3j//fdZsmQJRxxxBKNGjeLZZ5/lsssu49VXX+Xcc88F4MYbb+T73/8+3/72t5k0aVK9no+IiKQmtYQQERERSUZ5eTB2LEyaFEzz8mJ2qHfeeYcxY8aQnp5O586dOfvss/nggw+Avd0xPvvsM373u99x7bXX1riPoUOHcuSRR5Kens6YMWN45513AJgxYwbnnXceADNnzmTMmDEAfOtb34rZ8xERkeSlJISIiIhIMsrPh5ISaNkymObn12t3xx13HHPnzq3XPi6++GLeeuutGteZWY3z77//PkOHDq11OxERaVqUhBARaQLMbIqZbTSzRVHL2pvZK2b2aTg9LFxuZvYHM1tuZgvM7KTERS7ShOXkQFYWFBUF05yceu3unHPOoaSkhMmTJ1cuW7BgAW+//TZnnnkm06ZNo7y8nMLCQt56660qiYOId955h6OOOqrG/b///vusXLmSiooKpk2bxhlnnMHixYvp378/6enpAJx++uk89dRTABotQ0Sk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MURERESSUH4+lJRAy5ZQVBTMx6Kkwje+8Q3S09P3u81rr73G3LlzOeWUUwDYvXs3nTp1qnHbMWPGVE5vvvlmAGbPns2wYcMAeOuttxgzZgzp6el069aNc845p6GeioiIpAAlIURERESSUE4OPPxwkIDIygrmY6Fly5aV9zMyMqioqKicLy4uBsDdGTduHBMnTjzg/qKH1ozcf+mllxg1alRDhSwiIilM3TFEREREklBuLkydCtdfH0zjMbBE7969mTdvHgDz5s1j5cqVAJx77rk888wzbNy4EYDNmzezevXqGvcxbdq0yunw4cOBoCXFiBEjADjrrLOYNm0a5eXlrFu3jjfeeCOmz0lERJKLWkKIiIiIJKnc3PgkHyIuvfRSHn/8cY477jiGDRvGMcccA8CAAQO4++67yc3NpaKigszMTCZNmsQRRxyxzz62bNnCoEGDyMrK4sknn6SwsJDs7Gxat24NwCWXXMLrr7/OgAED6NWrV2WiQkREmgYlIURERESamLvuuqvG5c2bNyevlgqYV1xxBVdcccUB933rrbdy3333Vc5PnTqV3KhMipnxxz/+sXL+qquuqlvQIiLSKCgJISIiIiIxM3bs2ESHICIiSURJCBERERFpEKtWrTroxzz22GMNHockmHuiIxCRJKbClCIiIiIi0iCiBkcREamRkhAiIiIiIiIiEhdKQoiIiIiIiIhIXCgJISIiIiIiIiJxoSSEiIiISBOwadMmBg8ezODBg+nSpQvdu3evnDczBg8ezPHHH89FF13E1q1bgaDQZPPmzSu3Gzx4MI8//vhBHXfdunVVhugUEZGmTaNjiIiIiDQBHTp0YP78+QDcddddtGrViltuuQWAVq1aVa4bN24ckyZN4o477gDgqKOOqlx3KGbMmMHIkSPrE7qIiDQiagkhIiIikqzy8mDChGAaJ8OHD2ft2rUH9ZjevXtz2223MXDgQIYOHcry5csr182YMYPzzjsPd+eGG26gX79+jBgxgvPPP59nnnmmocMXEZEkpySEiIiISDLKy4OxY2HSpGAah0REeXk5r732GhdffHHlss8++6xKd4y33367xse2bduWhQsXcsMNN3DTTTdV7m/ZsmUMGDCA5557jmXLlrFkyRIef/xx3n333Zg/HxERST7qjiEiIiKSjPLzoaQEWraEoqJgPka1FXbv3s3gwYNZ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WLrXKyIiIiIy0qhtLSLZJtK7Y4iIiIiIiIjI6KEkhIiIiIiIiIikhZIQIiIiIiIiIpIWSkKIiIiIiIiISFooCSEiIiIiIiIiaaEkhIjIKGFmnzQzN7Px4Xszs3vMbJuZrTWz85PmvdXMtoaPW6OLWkRERERGkrTfolNERNLPzKYDi4A9ScXXAXPCx8XAfcDFZjYW+DwwH3BgpZk97O516Y1aREREREYa9YQQERkdvgV8miCp0GMx8FMPLAMqzWwycA3whLvXhomHJ4Br0x6xiIiIiIw4SkKIiIxwZrYYqHb3NX0mTQX2Jr3fF5YNVN7fsm8zsxVmtqKmpmYYoxYRERGRkUjDMURERgAzexKY1M+ku4G7CIZiDDt3vx+4H2D+/Pl+nNlFREREZJRTEkJEZARw96v7Kzezs4DZwBozA5gGrDKzi4BqYHrS7NPCsmpgYZ/ypcMetIiIiIiMOhqOISIygrn7Onef4O6z3H0WwdCK8939IPAwcEt4l4wFQIO7HwAeBxaZ2RgzG0PQi+LxqLZBREREREYO9YQQERm9HgOuB7YBrcAHANy91sy+BCwP5/uiu9dGE6KIiIiIjCRKQoiIjCJhb4ie1w7cPsB8PwJ+lKawRERERGSU0HAMEREREREREUkLJSFEREREREREJC2UhBARERERERGRtFASQkRERERERETSQkkIEREREREREUkLJSFEREREREREJC2UhBARERERERGRtFASQkRERERERETSQkkIEREREREREUkLJSFEREREREREJC2UhBARERERERGRtFASQkRERERERETSQkkIEREREREREUkLJSFEREREREREJC2UhBARERERERGRtFASQkRERERERETSQkkIEREREREREUkLJSFEREREREREJC2UhBARERERERGRtFASQkRERERERETSQkkIEREREREREUkLJSFEREREREREJC2UhBARERERERGRtFASQkRERERERETSQkkIEREREREREUmLSJIQZnatmW0xs21m9tkoYhARGS3M7AtmVm1mq8PH9UnT7gzr4i1mdk1SueppEZEsoTpbRLJJbrpXaGYx4F7gzcA+YLmZPezuG9Mdi4jIKPItd/9GcoGZnQ7cBJwBTAGeNLNTw8mqp0VEsoDa1iKSbaLoCXERsM3dd7h7J/ArYHEEcYiIjHaLgV+5e4e77wS2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\n",
      "text/plain": [
       "<Figure size 1080x576 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "## CONFIRM q_list_test in validation/visualization in Akash's code\n",
    "\n",
    "model_cob.train()\n",
    "model_tre1.train()\n",
    "model_tre2.train()\n",
    "\n",
    "if torch.cuda.is_available():\n",
    "    model_cob = model_cob.to(DEVICE)\n",
    "    model_tre1 = model_tre1.to(DEVICE)\n",
    "    model_tre2 = model_tre2.to(DEVICE)\n",
    "    \n",
    "i = 0\n",
    "# loss_crit = torch.nn.CrossEntropyLoss()\n",
    "loss_crit_cob = torch.nn.functional.cross_entropy\n",
    "loss_crit_tre = torch.nn.functional.binary_cross_entropy_with_logits\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",
    "        model_tre1.train()\n",
    "        model_tre2.train()\n",
    "        i += 1\n",
    "        \n",
    "        optim_cob.zero_grad()\n",
    "        optim_tre1.zero_grad()\n",
    "        optim_tre2.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",
    "        logP1 = model_tre1(p_batch).squeeze()\n",
    "        logM1_1 = model_tre1(m_batch).squeeze()\n",
    "        \n",
    "        logM1_2 = model_tre2(m_batch).squeeze()\n",
    "        logQ1 = model_tre2(q_batch).squeeze()\n",
    "        \n",
    "        p_label1 = torch.empty(p_batch.shape[0], device=DEVICE).fill_(0)\n",
    "        m_label1_1 = torch.empty(m_batch.shape[0], device=DEVICE).fill_(1)\n",
    "         \n",
    "        m_label1_2 = torch.empty(m_batch.shape[0], device=DEVICE).fill_(0)\n",
    "        q_label1 = torch.empty(m_batch.shape[0], device=DEVICE).fill_(1)\n",
    "        \n",
    "        loss_tre1 = loss_crit_tre(logP1, p_label1) + loss_crit_tre(logM1_1, m_label1_1)\n",
    "        loss_tre2 = loss_crit_tre(logM1_2, m_label1_2) + loss_crit_tre(logQ1, q_label1)\n",
    "        loss_tre1.backward()\n",
    "        loss_tre2.backward()\n",
    "        optim_tre1.step()\n",
    "        optim_tre2.step()\n",
    "        loss_store_tre.append(loss_tre1.item() + loss_tre2.item())\n",
    "    \n",
    "\n",
    "        # Validation/Test\n",
    "        if i % 50 == 0:\n",
    "            model_cob.eval()\n",
    "            model_tre1.eval()\n",
    "            model_tre2.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",
    "                    logP1 = model_tre1(p_batch).squeeze()\n",
    "                    logM1_1 = model_tre1(m_batch).squeeze()\n",
    "\n",
    "                    logM1_2 = model_tre2(m_batch).squeeze()\n",
    "                    logQ1 = model_tre2(q_batch).squeeze()\n",
    "\n",
    "                    p_label1 = torch.empty(p_batch.shape[0], device=DEVICE).fill_(0)\n",
    "                    m_label1_1 = torch.empty(m_batch.shape[0], device=DEVICE).fill_(1)\n",
    "\n",
    "                    m_label1_2 = torch.empty(m_batch.shape[0], device=DEVICE).fill_(0)\n",
    "                    q_label1 = torch.empty(q_batch.shape[0], device=DEVICE).fill_(1)\n",
    "                    \n",
    "                    test_loss_tre = loss_crit_tre(logP1, p_label1) + loss_crit_tre(logM1_1, m_label1_1) + loss_crit_tre(logM1_2, m_label1_2) + loss_crit_tre(logQ1, q_label1)\n",
    "                    \n",
    "                    log_ratio_p_q_from_tre = logM1_1 + logM1_2\n",
    "\n",
    "                    # Visualize\n",
    "                    \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( -50., 25. )\n",
    "                    ax2.set_ylim( -500, 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",
    "                    line2.set_data(range(len(loss_store_tre)), loss_store_tre)\n",
    "                    ax4.set_xlim( 0, len(loss_store_tre) )\n",
    "                    \n",
    "                    scat3.set_offsets(np.vstack([m_batch.cpu().squeeze(), gt_log_ratio_p_q.cpu().detach()]).T)\n",
    "                    scat4.set_offsets(np.vstack([m_batch.cpu().squeeze(), log_ratio_p_q_from_tre.cpu().detach()]).T)\n",
    "\n",
    "                    ax5.set_xlim( -50., 25. )\n",
    "                    ax5.set_ylim( -500, 200)\n",
    "            \n",
    "                    test_loss_store_tre.append(test_loss_tre.item())\n",
    "                    test_line2.set_data(range(len(test_loss_store_tre)), test_loss_store_tre)\n",
    "                    ax6.set_xlim( 0, len(test_loss_store_tre))\n",
    "                    \n",
    "#                     print('iteration: ',i)\n",
    "#                     print('KLD: ', true_kl_p_q)\n",
    "#                     print('CoB: ', kl_from_cob)\n",
    "                    \n",
    "                    clear_output(wait=True)\n",
    "                    display(fig)\n",
    "                    break\n",
    "\n",
    "            model_cob.train()\n",
    "            model_tre1.train()\n",
    "            model_tre2.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": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# fig, ax2 = plt.subplots(1, 1,figsize=(6,4))\n",
    "\n",
    "# x, y = np.random.random((2, 500))\n",
    "# scat1 = ax2.scatter(x,y,label='True Log p/q, KL = '+str(np.around(true_kl_p_q.item(),2)),alpha=0.9,s=10.,c='b')\n",
    "# scat2 = ax2.scatter(x,y,label='CoB Log p/q, KL = '+str(np.around(kl_from_cob.item(),2)),alpha=0.9,s=10.,c='r')\n",
    "\n",
    "# scat1.set_offsets(np.vstack([m_batch.cpu().squeeze(), 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_xlabel(\"Samples\")\n",
    "# ax2.set_ylabel(\"Log Ratio\")\n",
    "# ax2.legend(loc='best')\n",
    "# ax2.set_xlim([-25,25])\n",
    "# ax2.set_ylim([-100000,100000])\n",
    "\n",
    "# plt.tight_layout()\n",
    "# plt.savefig('../plots/cob_mu20.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_gt_log_ratios(p, q, m, samples):\n",
    "    p_lp = p.log_prob(samples.cpu())\n",
    "    q_lp = q.log_prob(samples.cpu())\n",
    "    m_lp = m.log_prob(samples.cpu())\n",
    "    \n",
    "    return p_lp - q_lp, p_lp - m_lp, q_lp - m_lp, m_lp - q_lp # p/q, p/m, q/m, m/q\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "#######\n",
    "with torch.no_grad():\n",
    "    model_cob.eval()\n",
    "    model_tre1.eval()\n",
    "    model_tre2.eval()\n",
    "    for p_batch, q_batch, m_batch in iter(test_dl):\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",
    "        p_batch = m_batch\n",
    "        logP = model_cob(p_batch).cpu()\n",
    "#         logQ = model_cob(q_batch).cpu()\n",
    "#         logM = model_cob(m_batch).cpu()\n",
    "\n",
    "        log_ratio_p_q_from_cob_from_p = logP[:, 0] - logP[:, 1]\n",
    "        log_ratio_p_m_from_cob_from_p = logP[:, 0] - logP[:, 2]\n",
    "        log_ratio_q_m_from_cob_from_p = logP[:, 1] - logP[:, 2]\n",
    "\n",
    "        logP1 = model_tre1(p_batch)[:, 0].cpu()\n",
    "        logQ1 = model_tre2(p_batch)[:, 0].cpu()\n",
    "\n",
    "        log_ratio_p_q_from_tre = logP1 + logQ1\n",
    "        log_ratio_p_m_from_tre = logP1\n",
    "        log_ratio_m_q_from_tre = logQ1\n",
    "        \n",
    "        true_log_ratio_p_q, true_log_ratio_p_m, true_log_ratio_q_m, true_log_ratio_m_q = get_gt_log_ratios(p, q, m, p_batch)\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set up viz\n",
    "fig, [[ax1,ax2,ax3], [ax4, ax5, ax6]] = plt.subplots(2, 3,figsize=(15,8))\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='CoB 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='CoB 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='CoB log q/m',alpha=0.9,s=10.,c='r')\n",
    "\n",
    "scat7 = ax4.scatter(p_batch,true_log_ratio_p_q,label='True log p/q',alpha=0.9,s=10.,c='b')\n",
    "scat8 = ax4.scatter(p_batch,log_ratio_p_q_from_tre,label='TRE log p/q',alpha=0.9,s=10.,c='r')\n",
    "\n",
    "scat9 = ax5.scatter(p_batch,true_log_ratio_p_m,label='True log p/m',alpha=0.9,s=10.,c='b')\n",
    "scat10 = ax5.scatter(p_batch,log_ratio_p_m_from_tre,label='TRE log p/m',alpha=0.9,s=10.,c='r')\n",
    "\n",
    "scat11 = ax6.scatter(p_batch,true_log_ratio_m_q,label='True log m/q',alpha=0.9,s=10.,c='b')\n",
    "scat12 = ax6.scatter(p_batch,log_ratio_m_q_from_tre,label='TRE log m/q',alpha=0.9,s=10.,c='r')\n",
    "\n",
    "ax1.set_ylabel(\"Log Ratio\")\n",
    "ax1.legend(loc='best')\n",
    "ax1.set_xlim([-6,10])\n",
    "ax1.set_ylim([-500,200])\n",
    "\n",
    "ax2.set_ylabel(\"Log Ratio\")\n",
    "ax2.legend(loc='best')\n",
    "ax2.set_xlim([-6,10])\n",
    "ax2.set_ylim([-500,200])\n",
    "\n",
    "ax3.set_ylabel(\"Log Ratio\")\n",
    "ax3.legend(loc='best')\n",
    "ax3.set_xlim([-6,10])\n",
    "ax3.set_ylim([-500,200])\n",
    "\n",
    "ax4.set_ylabel(\"Log Ratio\")\n",
    "ax4.legend(loc='best')\n",
    "ax4.set_xlim([-6,10])\n",
    "ax4.set_ylim([-500,200])\n",
    "\n",
    "ax5.set_ylabel(\"Log Ratio\")\n",
    "ax5.legend(loc='best')\n",
    "ax5.set_xlim([-6,10])\n",
    "ax5.set_ylim([-500,200])\n",
    "\n",
    "ax6.set_ylabel(\"Log Ratio\")\n",
    "ax6.legend(loc='best')\n",
    "ax6.set_xlim([-6,10])\n",
    "ax6.set_ylim([-500,200])\n",
    "\n",
    "plt.tight_layout()"
   ]
  },
  {
   "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
}
