{
 "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.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": 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": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABCEAAAI4CAYAAABUe/OXAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAAC4gElEQVR4nOzdd3zW9bn/8deVDSFM2UOmICiiIG5N1QbctUOlh9bRHqs/Pa12WEHPqW1VtLW71B6OorV4FGv1VK0jrjjrAIoLpIKAgiBLAoTsXL8/vt+EJGTfM7nfz8fj9r4/n++6cnP7zSfX/Rnm7oiIiIiIiIiIxFpaogMQERERERERkdSgJISIiIiIiIiIxIWSECIiIiIiIiISF0pCiIiIiIiIiEhcKAkhIiIiIiIiInGhJISIiIiIiIiIxEXMkhBmttDMtpjZu/Xq+prZ02b2QfjcJ1bXFxGRfcxsuJk9b2YrzOw9M/tOWN/kfdkCvzWz1Wb2tpkdkdifQEQktaltLSJdRSx7QtwNzGxUdy3wrLuPA54NyyIiEntVwPfcfSJwNHCFmU2k+fvyacC48HEpcHv8QxYRkXruRm1rEekCYpaEcPcXgR2Nqs8B/hS+/hPwhVhdX0RE9nH3Te6+LHy9G1gJDKX5+/I5wD0eeA3obWaD4xu1iIjUUttaRLqKjDhfb6C7bwpfbwYGNrejmV1K8O0bubm5UydMmADAOxuL99v30KG9oh6oiKSWpUuXbnP3/omOIx7MbCRwOPA6zd+XhwIf1ztsQ1i3qV5ds/dqEZFYSaX7dRtE3LaGfe3rvJwMRvbLjVmwIpI6WrpXxzsJUcfd3cy8he0LgAUA06ZN8yVLlgAw8tq/77fvklvOiFGUIpIqzGx9omOIBzPrAfwVuMrdd5lZ3bbW7stNae5eLSISK6lyv26vjratAcbMfZzqGueUCQO486IjYx+siHR5Ld2r4706xqe13XnD5y1xvr6ISMoys0yCBMS97v5QWN3cfXkjMLze4cPCOhERSR5RaVtb67uIiERNvJMQjwAXhq8vBP4W5+uLiKQkC7o83AmsdPdf1tvU3H35EeDr4SoZRwPF9br8iohIcohq27pdXeFERDooZsMxzOw+IB84wMw2AD8CbgEeMLNvAOuB82J1fRERaeA44GvAO2a2PKybS/P35ceB04HVwF7g4rhGKyIiDcSybV07Ms9daQgRib2YJSHcfVYzm06J1TVFRKRp7v4yzfe43e++7EFL9IqYBiWSYiorK9mwYQNlZWWJDqVTyMnJYdiwYWRmZiY6lKQQy7a1YagfhIjES8ImphQRERFJJRs2bCAvL4+RI0dSf1JY2Z+7s337djZs2MCoUaMSHU7KUBpCROIh3nNCiIiIiKSksrIy+vXrpwREG5gZ/fr1U6+ReNFHUkTiSEkIERERkThRAqLt9F7Fn6aEEJF4UBJCRERERCSFje3fA4A05X1EJA6UhBARERFJAdu3b2fKlClMmTKFQYMGMXTo0LpyRUVFzK+/adMmCgoKYn4dab8/f2M6AFkZ+tNARGJPE1OKiIiIpIB+/fqxfPlyAG644QZ69OjB97///brtVVVVZGTErmn45JNPMmPGjJidXzquX49sJgzKS3QYIpIilO4UERERSVEXXXQRl112GUcddRTXXHMNN9xwA7fddlvd9kMOOYR169YBsGjRIqZPn86UKVP41re+RXV19X7nGzlyJNdccw2HHnoo06dPZ/Xq1XXbnnzySU477TTcnSuvvJLx48dz6qmncvrpp/Pggw/G/GcVEZHkoCSEiIiISJIqLIS5c4PnWNmwYQOvvvoqv/zlL5vdZ+XKlSxevJhXXnmF5cuXk56ezr333tvkvr169eKdd97hyiuv5KqrrgKgurqaVatWMXHiRB5++GFWrVrFihUruOeee3j11Vdj8WOJiEiS0nAMERERkSRUWAizZ0N5OdxxByxaBLGYUuErX/kK6enpLe7z7LPPsnTpUo488kgASktLGTBgQJP7zpo1q+756quvBuD111/nqKOOAuDFF19k1qxZpKenM2TIEE4++eRo/SgiItIJKAkhIiIikoSKioIERG4ulJQE5VgkIXJzc+teZ2RkUFNTU1cuKysDwN258MILmTdvXqvnq7+0Zu3rJ554gpkzZ0YrZBER6cQ0HENEREQkCeXnQ3Z2kIDIzg7KsTZy5EiWLVsGwLJly1i7di0Ap5xyCg8++CBbtmwBYMeOHaxfv77JcyxevLju+ZhjjgGCnhSnnnoqACeeeCKLFy+murqaTZs28fzzz8f0ZxIRkeSinhAiIiIiSaigIBiCUVQUJCDisbrll770Je655x4mTZrEUUcdxUEHHQTAxIkTufHGGykoKKCmpobMzEzmz5/PgQceuN85PvvsMyZPnkx2djb33XcfW7duJScnh7y8YPWFc889l+eee46JEycyYsSIukSFiIikBiUhRERERJJUQUFskg833HBDk/XdunWjsJlZMM8//3zOP//8Vs/9gx/8gFtvvbWuvGjRIgrq/RBmxu9///u68kUXXdS2oEVEpEtQEkJEREREYmb27NmJDkFERJJIp0tCvPvjGVzz4Fs8/s7mRIciIiIiIvWsW7eu3cfcfffdUY9DRESSV6ebmLJHdgbdMjtd7kREREREREQk5XW6JISIiIiIiIiIdE6dPgmRmW6t7yQiIiIiIiIiCdfpkxD9crMTHYKIiIiIiIiItEGnT0KIiIiISNts3ryZCy64gDFjxjB16lROP/10/vWvfzW7/7p16+jWrRtTpkzhsMMO49hjj2XVqlXtvu4tt9zCvffeG0noIiLSRSgJISIiIpIC3J1zzz2X/Px81qxZw9KlS5k3bx6ffvppi8eNGTOG5cuX89Zbb3HhhRdy8803t/vaTz31FAUFBR0NXUREupBOn4RwPNEhiIiIiCS9559/nszMTC677LK6usMOO4wTTjgBd+cHP/gBhxxyCIceeiiLFy9u8hy7du2iT58++9UXFRVx4okncsYZZzB+/Hguu+wyampq6o6pqKigf//+rF27lmOOOYZDDz2U66+/nh49esTmhxURkaSltS5FREREklVhIRQVQX4+RNiT4N1332Xq1KlNbnvooYfqejts27aNI488khNPPBGANWvWMGXKFHbv3s3evXt5/fXXmzzHG2+8wYoVKzjwwAOZOXMmDz30EF/+8pd55plnOOWUUwD4zne+w+WXX87Xv/515s+fH9HPIyIinVOn7wkhIiIi0iUVFsLs2TB/fvBcWBizS7388svMmjWL9PR0Bg4cyEknncSbb74J7BuOsWbNGn79619z6aWXNnmO6dOnM3r0aNLT05k1axYvv/wyAE8++SSnnXYaAK+88gqzZs0C4Gtf+1rMfh4REUleSkKIiIiIJKOiIigvh9zc4LmoKKLTTZo0iaVLl0Z0jrPPPpsXX3yxyW1m1mT5jTfeYPr06c3uJyIiqUVJCBGRFGBmC81si5m9W6+ur5k9bWYfhM99wnozs9+a2Woze9vMjkhc5CIpLD8fsrOhpCR4zs+P6HQnn3wy5eXlLFiwoK7u7bff5qWXXuKEE05g8eLFVFdX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n5UrV7J48WJeeeUVli9fTnp6Ovfee2+T+/bq1Yt33nmHK6+8kquuugqA6upqVq1axcSJE3n44YdZtWoVK1as4J577uHVV1+NxY8lIiJJSsMxREREJDUUFARDMIqKggRENOYnmDEDXnihYTlK6nfcKCkJyrGYUuErX/kK6enpLe7z7LPPsnTpUo488kgASktLGTBgQJP7zpo1q+756quvBuD111/nqKOOAuDFF19k1qxZpKenM2TIEE4++eRo/SgiItIJKAkhIiIiqaOgILp/yb/1VsvlCOTnB1NXRLPjRlNyc3PrXmdkZFBTU1NXLguHl7g7F154IfPmzWv1fPWX1qx9/cQTTzBz5sxohSwiIp2YhmOIiIiIdNSKFS2XI1DbceOKK6Izh2ZbjBw5kmXLlgGwbNky1q5dC8App5zCgw8+yJYtWwDYsWMH69evb/Icixcvrns+5phjgKAnxamnngrAiSeeyOLFi6murmbTpk08//zzMf2ZREQkuagnhIiIiEhHbd7ccjlC0e640ZovfelL3HPPPUyaNImjjjqKgw46CICJEydy4403UlBQQE1NDZmZmcyfP58DDzxwv3N89tlnTJ48mezsbO677z62bt1KTk4OeXl5AJx77rk899xzTJw4kREjRtQlKkREJDUoCSEiIiISLTk5iY6gTW644YYm67t160ZhMzNgnn/++Zx//vmtnvsHP/gBt956a1150aJFFNTLpJgZv//97+vKF110UduCFhGRLkFJCBEREZGOKCyEbdsa1l1+eWJiSWKzZ89OdAgiIpJElIQQERGR1DJvHjz6KJx1FsyZ0/HzfP3r4L6vnJsb2fm6gHXr1rX7mLvvvjvqcYiISPJSEkJERERSx7x5cN11QfLgtdeCuo4mDrZubVguLY0sNhERkRSg1TFEREQkdTz6aJCASEsLnh99tOPn6t+/5bKIiIjsR0kIERERSR1nnQVmUFMTPJ91VsfPddhhLZdFRERkPxqOISIiIqmjduhFNOaE+Mc/Wi6LiIjIftQTQkRERFLLnDnw6quRTyJZUdFyOcls376dKVOmMGXKFAYNGsTQoUPrymbGlClTOOSQQzjrrLPYuXMnEEw02a1bt7r9pkyZwj333NOu627atKnBEp0iIpLa1BNCREREUkthIRQVQX4+RPLHcXV1y+Uk069fP5YvXw7ADTfcQI8e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mnNuP14S4VpgJ/A3M7saON3MPjWzJcAZeA3NOq/4z0uAz5xzW/2eFGvx6mqATc65j/zXz+DVz8FOBEYBH/n/D67CazAXARXAn8zsIqAsXD+riEgHpba1xNzBxvuIxJoBP3DOvdlgoZfVLW1UngxMdM6V+d+epYVw3Mqg17Xob0VEBADnXC1QCBT6SYfvAGOA8c65TWZ2Fw3r37r6NEDDujXAgbq1cbfMxmUD3nLOfb1xPGY2ATgTuAS4Di8JIiIiTVPbWmJOPSEk3pTgdc2t8ybwX2aWDGBmI8wso4ntugF7/UryCLxvzepU123fyAfAf/hj43oDpwKzw/JTiIh0QGY20syCvwkbC6z0X+/yh2tccgi7zjVv0kvwJlBr3EV3FnCymQ3z48jw/x9kAt2cc68DP8Ib3iEiIgeobS1xRxkoiTeLgVq/69dTwO/wumvN9yew2Qlc0MR2/wa+a2bL8RrEs4LeewxYbGbznXOXBy1/GZgILML71u1m59w2v6IVEZEvywT+x8y6AzXAGryhGfuApcA2vDHAbbUS+H7dfBDAo8FvOud2+sM+nvPHMAPcgde4/peZpeF9u3fjIRxbRKQjU9ta4o4mphQREZGYMbPBwKvOudGxjkVEREQiT8MxRERERERERCQq1BNCRERERERERKJCPSFEREREREREJCqUhBARERERERGRqFASQkRERERERESiQkkIEREREREREYkKJSFEREREREREJCr+Hxogbx68GMX8AAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 1080x576 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 52%|█████▏    | 209/400 [23:01<21:02,  6.61s/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-9-2c4985508e84>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     56\u001b[0m         \u001b[0mq_label1\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mempty\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mm_batch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mshape\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdevice\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mDEVICE\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfill_\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     57\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 58\u001b[0;31m         \u001b[0mloss_tre1\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mloss_crit_tre\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlogP1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mp_label1\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0mloss_crit_tre\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlogM1_1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mm_label1_1\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     59\u001b[0m         \u001b[0mloss_tre2\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mloss_crit_tre\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlogM1_2\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mm_label1_2\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0mloss_crit_tre\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlogQ1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mq_label1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     60\u001b[0m         \u001b[0mloss_tre1\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbackward\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/disk_c/han/ananconda3/envs/sr/lib/python3.7/site-packages/torch/nn/functional.py\u001b[0m in \u001b[0;36mbinary_cross_entropy_with_logits\u001b[0;34m(input, target, weight, size_average, reduce, reduction, pos_weight)\u001b[0m\n\u001b[1;32m   2538\u001b[0m         \u001b[0;32mraise\u001b[0m \u001b[0mValueError\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"Target size ({}) must be the same as input size ({})\"\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mformat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtarget\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msize\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0minput\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msize\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2539\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 2540\u001b[0;31m     \u001b[0;32mreturn\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbinary_cross_entropy_with_logits\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtarget\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mweight\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mpos_weight\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mreduction_enum\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   2541\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2542\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",
    "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": 10,
   "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": 28,
   "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 = q_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": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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jc01Y8YMRo8eTadOnRg+fDj79++Pw1FpW17nFBIrr8kglXM8ZcoUbrjhBvr3789FF13EOeecA4SK1de//vU4/eujcM4l7dfgwYNdPKxfvz4u+00k+/fvd845V1tb68aMGePmzZvXZJspU6a4hx9++Ji2mpoad7y8LFmyxI0ePTrqumjHva1yrJyGxCuvzaUcx19zctxYr1693O7du90FF1zgDh8+fFLvHy0PwBoX5W+4uvikVaZOnUphYSEDBgwgLy+Pa665plk/l5GRodlRA0x5TX6tzTGEuh3jNdp8NOrik1ZpeKdWLFOnTm3xfktKSiLP0Yj34pVXCY7m5Lix+mexvKYzKBERCSQVKBERCSQVKBERCSQVKBERCSQVqAS1c+dOrr/+enr37s3gwYO56qqrYg5LA6GLnB07dqSwsJDzzz+fiy66iHfeeSfqdgMGDIhn6ADs2LGDUi8eLEkgymnyS/Qc19bWMmjQoLi/Tz0VqATknOPaa6+lpKSELVu2UFFRwbRp0/joo4+O+3O9e/emsrKSN954g/Hjx/Pggw96FHFTCxYs4IorrvDt/YNGOU1+yZDjZcuWcfHFF3v2fipQCWjJkiWkp6czceLESNv555/P8OHDcc7x7//+7wwYMICCggLmzJkTdR+ffvrpMQNARlNTU8NNN91EQUEBF1xwAUuWLAFC43F94xvfoF+/flx77bUMHTo06jMwubm53H333RQUFFBcXMzmzZsj6xYsWMCoUaNwznHnnXfyxS9+kcsvv5yrrrqKuXPntuawJLRkyml5eTkjRoxg7NixnHvuudx7770899xzFBcXU1BQEBnWKtUkSo6PN/1NfY63bt1K3759mTBhAn369OHGG2/kL3/5CxdffDH5+fmsWrWqNYeoCT0H5ZWysjYbM+Wtt95i8ODBUdfNmzcv8mlrz549DBkyhEsuuQSALVu2UFhYyP79+zlw4ACvv/76cd9n+vTpmBnr1q1j48aNlJaWsmnTJn71q19xxhlnsH79et566y0KCwtj7uO0005j3bp1zJo1i+9973v86U9/oq6ujnfeeYd+/foxb9483nnnHdavX89HH31Ev379uPnmm1t9bDylnEbN6a5du3jjjTfYsGEDXbp04dxzz+XWW29l1apV/OIXv+Dxxx/nsccea+2h8laK5bh++pvFixdz3nnn8c1vfvOY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\n",
      "text/plain": [
       "<Figure size 432x288 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=(6,4))\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,600])\n",
    "\n",
    "ax2.set_ylabel(\"Log Ratio\")\n",
    "ax2.legend(loc='best')\n",
    "ax2.set_xlim([-6,10])\n",
    "ax2.set_ylim([-500,600])\n",
    "\n",
    "ax3.set_ylabel(\"Log Ratio\")\n",
    "ax3.legend(loc='best')\n",
    "ax3.set_xlim([-6,10])\n",
    "ax3.set_ylim([-500,600])\n",
    "\n",
    "ax4.set_ylabel(\"Log Ratio\")\n",
    "ax4.legend(loc='upper right')\n",
    "ax4.set_xlim([-6,10])\n",
    "ax4.set_ylim([-500,600])\n",
    "\n",
    "ax5.set_ylabel(\"Log Ratio\")\n",
    "ax5.legend(loc='upper right')\n",
    "ax5.set_xlim([-6,10])\n",
    "ax5.set_ylim([-500,600])\n",
    "\n",
    "ax6.set_ylabel(\"Log Ratio\")\n",
    "ax6.legend(loc='best')\n",
    "ax6.set_xlim([-6,10])\n",
    "ax6.set_ylim([-500,600])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "ax1.get_xaxis().set_visible(False)\n",
    "ax2.get_xaxis().set_visible(False)\n",
    "ax3.get_xaxis().set_visible(False)\n",
    "ax5.get_xaxis().set_visible(False)\n",
    "ax6.get_xaxis().set_visible(False)\n",
    "ax1.get_yaxis().set_visible(False)\n",
    "ax2.get_yaxis().set_visible(False)\n",
    "ax3.get_yaxis().set_visible(False)\n",
    "ax5.get_yaxis().set_visible(False)\n",
    "ax6.get_yaxis().set_visible(False)\n",
    "plt.tight_layout()\n",
    "plt.subplots_adjust(wspace=0, hspace=0.0)\n",
    "\n",
    "plt.savefig('cob_vs_tre_from_q.png')\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "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
}
