{
 "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 = 33000\n",
    "BS = 500\n",
    "NUM_EPOCHS = 800\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 = RatioCritic1D(dim_input=N_DIMS, dim_output=3, dropout=DROPOUT)\n",
    "# model.apply(weights_init)\n",
    "\n",
    "# Define optimizer\n",
    "optim = torch.optim.Adam(model.parameters(), lr=LR)\n",
    "\n",
    "# Define distributions\n",
    "p, q, m = get_dists_1d(mu1=-5., mu2=5., mu3=0, scale_p=1., scale_q=1., scale_m=2.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: 2.0)\n",
      "Sampling m\n",
      "torch.Size([33000])\n",
      "torch.Size([33000])\n",
      "torch.Size([33000])\n",
      "Sampling p\n",
      "Sampling q\n",
      "Cauchy(loc: 0.0, scale: 2.0)\n",
      "Sampling m\n",
      "torch.Size([33000])\n",
      "torch.Size([33000])\n",
      "torch.Size([33000])\n"
     ]
    }
   ],
   "source": [
    "# Define dataset & dataloader\n",
    "train_ds = DistDataset(p, q, m, num_samples=NUM_SAMPLES)\n",
    "test_ds = DistDataset(p, q, m, num_samples=NUM_SAMPLES) # Test dataset is only of size batch "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 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": "iVBORw0KGgoAAAANSUhEUgAABC4AAAEYCAYAAACTNLexAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAAAxrElEQVR4nO3de7hdVX3v//enSSTIXQyIBE2kCAW5VAOIIEWgIaA/kYoCp2i0nl+KP6mo9YLac8RWK14Ooi295BEEBCFIoXKscpVIQQUS5I5IuEkiSAQEUQFJvr8/1txhE/ZOdsjee8299vv1POtZc44515jfsbPWXCPfNeaYqSokSZIkSZLa6I+6HYAkSZIkSdJgTFxIkiRJkqTWMnEhSZIkSZJay8SFJEmSJElqLRMXkiRJkiSptUxcSJIkSZKk1hqxxEWSU5I8mOTmfmUvSnJJkjua501G6viSNF4luSfJTUmuT7KgKRvw/JuOryZZlOTGJK/uV8/sZv87kszuVnskSfatJY1vIzni4lRg1kplxwKXVdU2wGXNuiRp+L2hqnapqhnN+mDn3wOBbZrHHOBfodMZBj4F7A7sBnzKDrEkddWp2LeWNE6NWOKiqq4AHl6p+GDgtGb5NOAtI3V8SdKzDHb+PRg4vTp+DGycZAvgAOCSqnq4qh4BLuG5HWZJ0iixby1pPJs4ysfbvKrub5YfADYfbMckc+j8+sd66633mu22224UwpOkoVu4cOGvqmpKt+MYQAEXJyng36tqLoOff7cE7uv32sVN2WDlz+K5WtJY0OLz9dqyby2pZ6zqXD3aiYsVqqqaTvVg2+cCcwFmzJhRCxYsGLXYJGkoktzb7RgGsVdVLUmyGXBJkp/237i68++a8FwtaSxo8fl62Ni3ljTWrepcPdp3FfllMwSZ5vnBUT6+JPW8qlrSPD8InE9njorBzr9LgK36vXxqUzZYuSSpPexbSxoXRjtxcQHQNzP9bODbo3x8SeppSdZLskHfMjATuJnBz78XAO9s7i7yWuDRZtjxRcDMJJs0k3LObMokSe1h31rSuDBil4okOQvYB3hxksV0Zqc/HjgnyXuAe4G3j9TxJWmc2hw4Pwl0zvHfrKoLk1zLwOff7wIHAYuA3wHvBqiqh5P8A3Bts9/fV9XKk8JJkkaJfWtJ49mIJS6q6ohBNu03UseUpPGuqu4Cdh6g/CEGOP9WVQHvG6SuU4BThjtGSUP3hz/8gcWLF/PEE090O5QxYfLkyUydOpVJkyZ1O5RhZ99a0njWtck5JUmStGqLFy9mgw02YNq0aTQjqTSIquKhhx5i8eLFTJ8+vdvhSJKG0WjPcSFJkqQheuKJJ9h0001NWgxBEjbddFNHp0hSDzJxIUmS1GImLYbOv5Uk9SYTF5IkSZIkqbVMXEiSJGlADz30ELvssgu77LILL3nJS9hyyy1XrD/11FMjfvz777+fmTNnjvhxJEnt5uSckiRJGtCmm27K9ddfD8Bxxx3H+uuvz4c//OEV259++mkmThy57uSFF17IAQccMGL1S5LGBkdcSJIkacje9a53cdRRR7H77rvz0Y9+lOOOO44vfelLK7a/6lWv4p577gHgjDPOYLfddmOXXXbhr//6r1m2bNlz6ps2bRof/ehH2XHHHdltt91YtGjRim0XXnghBx54IFXF0Ucfzbbbbsv+++/PQQcdxLnnnjvibZUktYOJC0mSpB5y8cXwiU90nkfK4sWL+eEPf8gJJ5ww6D633XYb8+bN46qrruL6669nwoQJnHnmmQPuu9FGG3HTTTdx9NFH84EPfACAZcuWcfvtt7P99ttz/vnnc/vtt3Prrbdy+umn88Mf/nAkmiVJaikvFZEkSeoRF18MRx4JTz4JX/sanHEGjMQUEW9729uYMGHCKve57LLLWLhwIbvuuisAv//979lss80G3PeII45Y8fzBD34QgKuvvprdd98dgCuuuIIjjjiCCRMm8NKXvpR99913uJoiSRoDTFxIkiT1iPnzO0mL9daD3/62sz4SiYv11ltvxfLEiRNZvnz5ivUnnngCgKpi9uzZfO5zn1ttff1vY9q3/L3vfY9Zs2YNV8iSpDHMS0UkSZJ6xD77wDrrdJIW66zTWR9p06ZN47rrrgPguuuu4+677wZgv/3249xzz+XBBx8E4OGHH+bee+8dsI558+ateN5jjz2AzoiN/fffH4C9996befPmsWzZMu6//34uv/zyEW2TJKldHHEhSZLUI2bO7FweMn9+J2kxGncSfetb38rpp5/ODjvswO67784rX/lKALbffns+85nPMHPmTJYvX86kSZM46aSTePnLX/6cOh555BF22mkn1llnHc466yyWLl3K5MmT2WCDDQA45JBD+P73v8/222/Py172shXJDUnS+GDiQpIkqYfMnDkyCYvjjjtuwPJ1112XiweZCfSwww7jsMMOW23dH/nIR/j85z+/Yv2MM85gZr9GJOGf//mfV6y/613vGlrQkqSeYOJCkiRJrXLkkUd2OwRJUouYuJAkSVLX3HPPPWv8mlNPPXXY45AktZeTc0qSJEmSpNYycSFJkiRJklrLxIUkSZIkSWotExeSJEmSJKm1TFxIkiRpUA888ACHH344W2+9Na95zWs46KCD+NnPfjbo/vfccw/rrrsuu+yyCzvvvDOve93ruP3229f4uMcffzxnnnnm2oQuSeoRJi4kSZI0oKrikEMOYZ999uHOO+9k4cKFfO5zn+OXv/zlKl+39dZbc/3113PDDTcwe/Zs/vEf/3GNj33RRRcxc+bM5xu6JKmHmLiQJEnSgC6//HImTZrEUUcdtaJs55135vWvfz1VxUc+8hFe9apXseOOOzJv3rwB63jsscfYZJNNnlM+f/589t57b974xjey7bbbctRRR7F8+fIVr3nqqaeYMmUKd999N3vssQc77rgjf/d3f8f6668/Mo2VJLXWxG4HIEmSpGF08cUwfz7ssw+s5YiFm2++mde85jUDbjvvvPNWjKr41a9+xa677sree+8NwJ133skuu+zCb37zG373u99x9dVXD1jHNddcw6233srLX/5yZs2axXnnncehhx7KpZdeyn777QfAMcccw3vf+17e+c53ctJJJ61VeyRJY5MjLiRJknrFxRfDkUfCSSd1ni++eMQOdeWVV3LEEUcwYcIENt98c/7sz/6Ma6+9FnjmUpE777yTE088kTlz5gxYx2677cYrXvEKJkyYwBFHHMGVV14JwIUXXsiBBx4IwFVXXcURRxwBwDve8Y4Ra48kqb1MXEiSJPWK+fPhySdhvfU6z/Pnr1V1O+ywAwsXLlyrOt785jdzxRVXDLgtyYDr11xzDbvtttug+0mSxhcTF5IkSb1in31gnXXgt7/tPO+zz1pVt++++/Lkk08yd+7cFWU33ngj//3f/83rX/965s2bx7Jly1i6dClXXHHFs5INfa688kq23nrrAeu/5ppruPvuu1m+fDnz5s1jr7324pZbbmG77bZjwoQJAOy5556cffbZAN5lRJLGKRMXkiRJvWLmTDjjDHjf+zrPaznHRRLOP/98Lr30Urbeemt22GEHPv7xj/OSl7yE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\n",
      "text/plain": [
       "<Figure size 1080x288 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Set up viz\n",
    "fig, [ax1,ax2,ax3] = plt.subplots(1, 3,figsize=(15,4))\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",
    "plt.tight_layout()\n",
    "\n",
    "loss_store = []\n",
    "test_loss_store = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABC4AAAEYCAYAAACTNLexAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAABaPUlEQVR4nO3deXhU5fn/8fedPYSwyr6DoIICCqKISxQbcau1tlZbXNu6fLXVttYKdlGr0qq12tb6q6VoLS5Ql7pUBbXGHREQEVFkF5A9rNmTuX9/zEmYQBICWWbJ53Vdc2XOc86ccx9mePLknmcxd0dEREREREREJBYlRTsAEREREREREZHaKHEhIiIiIiIiIjFLiQsRERERERERiVlKXIiIiIiIiIhIzFLiQkRERERERERilhIXIiIiIiIiIhKzmixxYWZTzGyjmS2MKOtgZq+a2ZLgZ/umur6ISEu0P3Wvhf3JzJaa2QIzOyriNZcExy8xs0uicS8iIrKb2tYi0pI1ZY+LR4Bxe5TdBLzu7gOB14NtERFpPI9Q/7r3dGBg8LgCeBDCDWHgN8AxwCjgN2oMi4hE3SOobS0iLVSTJS7c/S0gf4/ic4B/Bs//CXyjqa4vItIS7Wfdew7wqIfNAtqZWTfgNOBVd893963Aq+zdWBYRkWaktrWItGQpzXy9Lu6+Lni+HuhS24FmdgXhbwDJysoaceihh1bb/8na7VXPj+jRttEDFRHZl7lz5252907RjqMeaqt7ewCrI45bE5TVVr6XfdXVIiKxII7q6/3VaG3rDTuK2bizRO1qEYmauurq5k5cVHF3NzOvY/9DwEMAI0eO9Dlz5lTb3/em/1Y9n/O7M5soShGR2pnZqmjHsL/2VfcewPnqrKtFRGJBPNbX+6uhbet7X/2CP72+RO1qEYmauurq5l5VZEPQDZng58Zmvr6ISEtUW927FugVcVzPoKy2chERiS1qW4tIi9DciYvngcrZ6S8Bnmvm64uItES11b3PAxcHq4scC2wPuhzPAHLNrH0wKWduUCYiIrFFbWsRaRGabKiImT0B5AAHmdkawjPU/w6YbmbfB1YB5zfV9UVEWqL9rHtfAs4AlgKFwGUA7p5vZr8FPgyOu83d95wQTkREmpHa1iLSkjVZ4sLdL6xl19imuqaISEu3P3WvuztwTS3nmQJMacTQROQAlJWVsWbNGoqLi6MdSlzIyMigZ8+epKamRjuURqe2tYi0ZFGbnFNERERE6rZmzRqys7Pp27cvZhbtcGKau7NlyxbWrFlDv379oh2OiIg0ouae40JERERE6qm4uJiOHTsqaVEPZkbHjh3VO0VEJAEpcSEiIiISw5S0qD/9W4mIJCYlLkREREREREQkZilxISIiIiI12rJlC8OHD2f48OF07dqVHj16VG2XlpY2+fXXrVtHbm5uk19HRERimybnFBEREZEadezYkfnz5wNwyy230Lp1a2644Yaq/eXl5aSkNF1z8pVXXuG0005rsvOLiEh8UI8LEREREam3Sy+9lKuuuopjjjmGG2+8kVtuuYV77rmnav/hhx/OypUrAZg6dSqjRo1i+PDhXHnllVRUVOx1vr59+3LjjTdyxBFHMGrUKJYuXVq175VXXuH000/H3bn22ms55JBDOPXUUznjjDN46qmnmvxeRUQkNihxISIiIpJAZs6EiRPDP5vKmjVreO+997j33ntrPeazzz5j2rRpvPvuu8yfP5/k5GQee+yxGo9t27Ytn3zyCddeey3XX389ABUVFSxevJjBgwfz7LPPsnjxYhYtWsSjjz7Ke++91xS3JSIiMUpDRUREREQSxMyZMH48lJTA5MkwdSo0xRQR3/72t0lOTq7zmNdff525c+dy9NFHA1BUVETnzp1rPPbCCy+s+vmTn/wEgA8++IBjjjkGgLfeeosLL7yQ5ORkunfvzimnnNJYtyIiInFAiQsRERGRBJGXF05aZGVBQUF4uykSF1lZWVXPU1JSCIVCVdvFxcUAuDuXXHIJkyZN2uf5IpcxrXz+8ssvM27cuMYKWURE4piGioiIiIgkiJwcSE8PJy3S08PbTa1v377MmzcPgHnz5rFixQoAxo4dy1NPPcXGjRsByM/PZ9WqVTWeY9q0aVU/R48eDYR7bJx66qkAnHjiiUybNo2KigrWrVvHG2+80aT3JCIisUU9LkREREQSRG5ueHhIXl44adEcK4med955PProowwZMoRjjjmGQYMGATB48GBuv/12cnNzCYVCpKam8sADD9CnT5+9zrF161aGDh1Keno6TzzxBJs2bSIjI4Ps7GwAzj33XP73v/8xePBgevfuXZXcEBGRliEhEhfvLdvMcQMOinYYIiIiIlGXm9s0CYtbbrmlxvLMzExm1jIT6He+8x2+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\n",
      "text/plain": [
       "<Figure size 1080x288 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 800/800 [16:57<00:00,  1.27s/it]\n"
     ]
    }
   ],
   "source": [
    "## CONFIRM q_list_test in validation/visualization in Akash's code\n",
    "\n",
    "model.train()\n",
    "\n",
    "if torch.cuda.is_available():\n",
    "    model = model.to(DEVICE)\n",
    "    \n",
    "i = 0\n",
    "# loss_crit = torch.nn.CrossEntropyLoss()\n",
    "loss_crit = torch.nn.functional.cross_entropy\n",
    "\n",
    "\n",
    "for epoch in trange(NUM_EPOCHS):\n",
    "    for p_batch, q_batch, m_batch in iter(train_dl):\n",
    "        model.train()\n",
    "        i += 1\n",
    "        \n",
    "        model.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(p_batch)\n",
    "        logQ = model(q_batch)\n",
    "        logM = model(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 = loss_crit(logP, p_label) + loss_crit(logQ, q_label) + loss_crit(logM, m_label)\n",
    "        loss.backward()\n",
    "        optim.step()\n",
    "        loss_store.append(loss.item())\n",
    "\n",
    "        # Validation/Test\n",
    "        if i % 50 == 0:\n",
    "            model.eval()\n",
    "            \n",
    "            with torch.no_grad():\n",
    "                for p_batch, q_batch, m_batch in iter(test_dl):\n",
    "                    log_ratio_p_q, _, true_kl_p_q = get_gt_ratio_kl(p, q, m_batch, calc_true_kl=True)\n",
    "                    _, kl_from_p_q = get_gt_ratio_kl(p, q, p_batch)\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(p_batch)\n",
    "                    logQ = model(q_batch)\n",
    "                    logM = model(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 = loss_crit(logP, p_label) + loss_crit(logQ, q_label) + loss_crit(logM, m_label)\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(), 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( -25., 25. )\n",
    "                    ax2.set_ylim( -1000, 1000)\n",
    "            \n",
    "                    test_loss_store.append(test_loss.item())\n",
    "                    test_line.set_data(range(len(test_loss_store)), test_loss_store)\n",
    "                    ax3.set_xlim( 0, len(test_loss_store) )\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.train()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration:  52800\n",
      "KLD:  tensor(50.)\n",
      "CoB:  tensor(53.9747, device='cuda:1')\n"
     ]
    }
   ],
   "source": [
    "                    print('iteration: ',i)\n",
    "                    print('KLD: ', true_kl_p_q)\n",
    "                    print('CoB: ', kl_from_cob)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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8vIgIwPKyoLfeXlNf81DDz2U999/H4D333+fL774AoBBgwbx9NNP8/XXwWIHpaWlLF+ecMWGHZx88smx7sDCwkK+853v0KFDB0488URmzpwJBK2hum78V1VVxUbbPf7445x00km4OwsXLqRfv34AnHLKKTz++OMALF68OHafC+Cqq66KBUIi48aNY9CgQVx00UUNHs14xRVXxMI6/qe6nvHKyspi4VdWVkZBQUFslOB5550XG5X3yCOPcP755+9w/pAhQ2Lfz7fffktBQQFDhgxpUD13lQJKRBokPz/o1rv++qbr3qvt4osvprS0lF69enH//fdzxBFHAHDMMcdw5513kp+fT58+fRg8eHDs//xrO/vss+nevTvdu3fn0ksvZcKECRQVFdGnTx9uuumm2B/k2267LfbH+qmnnqJr1660b99+h/fLzs5m/vz59O7dm7/97W/ceuutFBUV0b9//1hr6rrrrmPjxo0cffTR3HrrreTk5MTOX7hwIQceeGC9n/t3v/sd3bt358orr6SqqoolS5bEPkP37t156qmnduv7hOA+00knnUTfvn0ZOHAgZ599dqzld9NNNzFr1ix69uzJG2+8wU033QTAggULuOaaawDo3Lkz//Vf/8WAAQMYMGAAt956K507d97t+tRHk8WKtFKffPIJRx99dLKrERnl5eWkpKSQmprKO++8w3XXXUdxcfEOx7Vr146NGzfWKLvzzjv57ne/y/DhwxO+d15eHnfffTdHHHEEP/zhD/coYFq6RP/uNFmsiEg9/v3vfzNs2DCqqqpIT0/noYceavC5v/rVrxp0XIcOHVp1OO0qBZSICNCzZ08++OCDnR5Xu/XUEIVNNaJkL6d7UCIiEkkKKBERiSQFlIiIRJICSkREIkkBJSJJ89VXXzF8+HB69OhBTk4OZ511Fv/85z/rPH7ZsmVkZWXRr18/+vbty/e//32WLFmS8LjGXqJiZ8aOHcvbb7+9W+e2a9cu9vqVV17hiCOOYPny5TtMlrunCgsL6dixY2ymiTvuuAMIZugYOHAgffv2pVevXtx2220Jz1++fDmDBg2iT58+5OXlUVJSAgQzo8fPYJGZmZlwotld5u6R+wGOBIrjftYDPwUmACviys+KO2c8sBRYAgzZ2TVycnJcpDX7+OOPk3r9qqoqP+GEE3zSpEmxsuLiYp8zZ06d53zx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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Set up viz\n",
    "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([-1000,1000])\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig('../plots/cob_mu5.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
}
