{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "zdgemk5nHdbL",
    "outputId": "332d9159-5b7e-488d-cdf1-803b67f11603"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:\n",
      "The TensorFlow contrib module will not be included in TensorFlow 2.0.\n",
      "For more information, please see:\n",
      "  * https://github.com/tensorflow/community/blob/master/rfcs/20180907-contrib-sunset.md\n",
      "  * https://github.com/tensorflow/addons\n",
      "  * https://github.com/tensorflow/io (for I/O related ops)\n",
      "If you depend on functionality not listed there, please file an issue.\n",
      "\n",
      "1.15.0\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "%matplotlib inline\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "from IPython.display import display, clear_output\n",
    "from time import sleep\n",
    "from livelossplot import PlotLosses\n",
    "import tensorflow as tf\n",
    "import numpy as np\n",
    "import seaborn as sns; \n",
    "import imageio\n",
    "import glob\n",
    "import tensorflow_probability as tfp\n",
    "tfd = tfp.distributions\n",
    "from scipy.stats import norm, uniform\n",
    "import sys\n",
    "import matplotlib.pyplot as plt\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "slim = tf.contrib.slim\n",
    "from tqdm.notebook import tqdm\n",
    "import sys\n",
    "sys.path.append('../models/')\n",
    "sys.path.append('../')\n",
    "from kl_utils import *\n",
    "\n",
    "print(tf.__version__)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:From ../models/kl_utils.py:34: The name tf.reset_default_graph is deprecated. Please use tf.compat.v1.reset_default_graph instead.\n",
      "\n",
      "WARNING:tensorflow:From ../models/kl_utils.py:35: The name tf.random.set_random_seed is deprecated. Please use tf.compat.v1.random.set_random_seed instead.\n",
      "\n",
      "(100000,)\n"
     ]
    }
   ],
   "source": [
    "num_samples = 100000\n",
    "N=500\n",
    "bs=500\n",
    "deep=False\n",
    "reset(4)\n",
    "\n",
    "def get_data(mu_1=0.,mu_2=2.,mu_3=0.,scale_p=0.1,scale_q=0.1,scale_m=1.,mtype=\"mix\"):\n",
    "    \n",
    "    p = tfd.Normal(loc=mu_1, scale=scale_p)\n",
    "    q = tfd.Normal(loc=mu_2, scale=scale_q) \n",
    "   \n",
    "    m = tfp.distributions.Cauchy(loc=mu_3, scale=scale_m)\n",
    "    \n",
    "        \n",
    "    p_samples_ = p.sample([num_samples]) \n",
    "    q_samples_ = q.sample([num_samples])\n",
    "    m_samples_ = m.sample([num_samples])\n",
    "    \n",
    "    with tf.Session() as sess:\n",
    "        p_,q_,m_ = sess.run([p_samples_, q_samples_, m_samples_],feed_dict={})\n",
    "        sess.close() \n",
    "    \n",
    "    return p, q, m, p_,q_,m_\n",
    "\n",
    "mu_1=2.\n",
    "mu_2=-2.\n",
    "mu_3=0.\n",
    "\n",
    "scale_p=0.1\n",
    "scale_q=0.2\n",
    "scale_m=2.\n",
    "\n",
    "# Generate dataset\n",
    "p, q, m, p_list, q_list, m_list = get_data(mu_1,mu_2,mu_3,scale_p,scale_q,scale_m)\n",
    "_, _, _, p_list_test, _, m_list_test = get_data(mu_1,mu_2,mu_3,scale_p,scale_q,scale_m)\n",
    "\n",
    "print(p_list.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "QH5eP5NclBEf",
    "outputId": "1c6f6465-8bb3-4583-c235-2c914da988fb"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:From ../models/kl_utils.py:48: The name tf.variable_scope is deprecated. Please use tf.compat.v1.variable_scope instead.\n",
      "\n",
      "WARNING:tensorflow:From ../models/kl_utils.py:48: The name tf.AUTO_REUSE is deprecated. Please use tf.compat.v1.AUTO_REUSE instead.\n",
      "\n",
      "WARNING:tensorflow:From ../models/kl_utils.py:50: The name tf.get_variable is deprecated. Please use tf.compat.v1.get_variable instead.\n",
      "\n",
      "WARNING:tensorflow:From /disk_c/akash/anaconda/envs/iclr/lib/python3.7/site-packages/tensorflow_probability/python/layers/util.py:102: Layer.add_variable (from tensorflow.python.keras.engine.base_layer) is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "Please use `layer.add_weight` method instead.\n",
      "WARNING:tensorflow:From /disk_c/akash/anaconda/envs/iclr/lib/python3.7/site-packages/tensorflow_core/python/ops/resource_variable_ops.py:1630: calling BaseResourceVariable.__init__ (from tensorflow.python.ops.resource_variable_ops) with constraint is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "If using Keras pass *_constraint arguments to layers.\n",
      "WARNING:tensorflow:From ../models/kl_utils.py:122: softmax_cross_entropy_with_logits (from tensorflow.python.ops.nn_ops) is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "\n",
      "Future major versions of TensorFlow will allow gradients to flow\n",
      "into the labels input on backprop by default.\n",
      "\n",
      "See `tf.nn.softmax_cross_entropy_with_logits_v2`.\n",
      "\n",
      "WARNING:tensorflow:From ../models/kl_utils.py:132: The name tf.trainable_variables is deprecated. Please use tf.compat.v1.trainable_variables instead.\n",
      "\n",
      "WARNING:tensorflow:From ../models/kl_utils.py:135: The name tf.train.AdamOptimizer is deprecated. Please use tf.compat.v1.train.AdamOptimizer instead.\n",
      "\n"
     ]
    }
   ],
   "source": [
    "p_samples = tf.placeholder(tf.float32, shape=[None])\n",
    "q_samples = tf.placeholder(tf.float32, shape=[None])\n",
    "m_samples = tf.placeholder(tf.float32, shape=[None])\n",
    "\n",
    "dloss = get_loss(p_samples, q_samples, m_samples)\n",
    "optim = get_optim(dloss, lr=0.001)\n",
    "\n",
    "log_ratio_p_q, _, kld = get_gt_ratio_kl(p,q,m_samples)\n",
    "_, kl_from_pq, _ = get_gt_ratio_kl(p,q,p_samples)\n",
    "kl_from_cob = get_kl_from_cob(p_samples)\n",
    "\n",
    "log_ratio_p_m = get_logits(m_samples)\n",
    "\n",
    "init = tf.global_variables_initializer()\n",
    "sess = tf.Session()\n",
    "sess.run(init)\n",
    "\n",
    "# %matplotlib inline\n",
    "# sample_and_plot(sess, kl_from_pq, kl_from_cob, kld, p_samples, q_samples, m_samples, log_ratio_p_q, log_ratio_p_m, mu_1, mu_2, scale_p, scale_q, mu_3, scale_m, training=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABCcAAAEYCAYAAABvIZx7AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAAB1F0lEQVR4nO3deXhU5fn/8fedhSQEwiaLbAIqWgRBQRS1Sl0Qd21dW9RKW7/607ba2m9FbWu/KrGLVuvS1lpwwbpVbcUqjltccEFAFARREJB9h4SQPc/vjzOTTJJJMklm5swkn9d15Zo5y5xzz5nJmfPc51nMOYeIiIiIiIiIiF/S/A5ARERERERERDo2JSdERERERERExFdKToiIiIiIiIiIr5ScEBERERERERFfKTkhIiIiIiIiIr5SckJEREREREREfBW35ISZzTCzLWa2JGxeTzN71cy+DD72iNf+RUSkVkvPyWY2zcxWmNlyMzvFn6hFRCRE19Yi0t7Fs+bEw8DkevNuAF53zh0IvB6cFhGR+HuYKM/JZjYCuAg4JPiaB8wsPXGhiohIBA+ja2sRacfilpxwzr0N7Kg3+2zgkeDzR4Bz4rV/ERGp1cJz8tnAk865MufcKmAFMD4RcYqISGS6thaR9i4jwfvr65zbCOCc22hmfRpb0cyuAK4ASMvJG5vRrQ+jBnQDYPH63QAM2yeXr7YV17ymZ24nBnTPqVmemZ5GRVV1nfVGDehGUWkFq7fvJScznQP6dIm4/6pqx9KNhTXTedkZFJZWNlgvFFO40P7rL1uzfS+FpRXs17MzeTmZdZYt31REeTDW3KyGH0tltWNZMJ5I+0yEpuJPlMaObXOi+cxDdu2tYO3OveRlZ7Jfr86tjhUix1tWWc0Xm4sazI/ky817KK2s4sA+XcjOjM2N69Yew1RU/71G+94LSypYs2MvXbIy2LHm823Oud7xjdQ3jZ2TBwAfhK23LjivgfBzdW5u7tiDDz44juGKiDRuwYIF7fl83ZhWXVvrfC0ifmnqXJ3o5ETUnHMPAg8CZO17oBvw/buZn386AENu+C8AD19xFBc+WHv9fPH4QeR/+9Ca5f27ZbNhdykzrziKi4Lrzb/jdF5ftpkfPDKf0QO78Z9rjo24/917Kxj9f4Ga6ZO+0ZfXlm1usN78O05vMC+0/3nTTyMtzWrm/+jR+by6dDP3XjKWUw7pV+c1x/3+Tb7esZeHrziKI4f1arDN7XvKGHvba43uMxGueHQ+gaWb+fOUsUwe2a/5F8RB6Ni29BiEPvMxg7rz76uPaXLd/yxaz0+fXMSpI/vxlyljWx0rRI53xZYiTrrr7QbzI5l899t8vqmIZ376Tb6xb16bYmkqpvYq9F4/yj8NM4v6vc9ZspErZy3k2AP24fEfHbUm7oEmH4swz0VaMfxcPW7cODd//vx4xiUi0igz64jn66jpfC0iyaCpc3WiR+vYbGb7AgQftyR4/yIiUquxc/I6YFDYegOBDQmOTUREmqdraxFpNxKdnHgBuCz4/DLgPwnefxtEvGkoIpLKGjsnvwBcZGZZZjYUOBCY50N8IiLStBS+thYRqStuzTrM7AlgIrCPma0DfgPcATxtZj8AvgbOj9f+RURCnAOL1FChA2nJOdk595mZPQ0sBSqBq51zVb4ELiIigK6tRaT9i1tywjl3cSOLTozXPuOrg5dsRCSltfSc7Jy7Hbi9rfutqKhg3bp1lJaWtnVTHUJ2djYDBw4kM9OfTodFJHm1v2trEZG6krZDTBERSX3r1q2ja9euDBkyBOvo1Vea4Zxj+/btrFu3jqFDh/odjoiIiEhCJbrPiRTmb58T6vFCRFJRaWkpvXr1UmIiCmZGr169VMtEREREOiQlJ0REJK6UmIiejpWIiIh0VEpOiEi7p5pHIiIiIiLJTcmJqOlulohIqtm+fTtjxoxhzJgx9OvXjwEDBtRMl5eXx33/GzduZNKkSXHfj4iIiEiqU4eYUdO9VxGRVNOrVy8WLVoEwC233EKXLl24/vrra5ZXVlaSkRG/n8I5c+ZwyimnxG37IiIiIu2FkhMiScwpJyYSc9///vfp2bMnH3/8MYcffjhdu3atk7QYOXIkL774IkOGDGHWrFn8+c9/pry8nCOPPJIHHniA9PT0OtsbMmQIF154IW+++SYA//znPznggAMALznxm9/8BuccP/7xj3njjTcYOnQozjmmTp3Keeedl9g3LyIiIpKk1KxDRESSSiAAN97oPcbLF198wWuvvcadd97Z6DrLli3jqaeeYu7cuSxatIj09HQef/zxiOvm5eUxb948rrnmGq699loAqqqqWL58OSNGjOD5559n+fLlLF68mL///e+899578XhbIiIiIilLNSdEkpg67o8N5xzqNyY1BAIwZQqUlcFDD8GsWRCPLhvOP//8BjUg6nv99ddZsGABRxxxBAAlJSX06dMn4roXX3xxzeN1110HwIcffsiRRx4JwNtvv83FF19Meno6/fv354QTTojVWxERERFpF5ScSBGq3i8iHUFBgZeYyM2F4mJvOh7Jidzc3JrnGRkZVFdX10yXlpYCXlLrsssuIz8/v9nthQ8BGnr+8ssvM3ny5IjriEhseTWtDh7udxwiItJ6Kd2sQ+V1EZH2ZeJEyMryEhNZWd50vA0ZMoSFCxcCsHDhQlatWgXAiSeeyL/+9S+2bNkCwI4dO1izZk3EbTz11FM1jxMmTAC8mhcnnngiAMcddxxPPvkkVVVVbNy4saZ/ChFpm0AALroILrgAILer3/GIiEjrpUzNCSUiRETav0mTvKYcBQVeYiIRo3B+5zvf4dFHH2XMmDEcccQRDB/u3XwdMWIEt912G5MmTaK6uprMzEzuv/9+9ttvvwbbKCsr48gjj6S6uponnniCrVu3kp2dTV5eHgDnnnsub7zxBqNGjWL48OEcf/zx8X9jIu1YIAAzZ8ILL0BpKXiVn1x1c68TEZHklTLJiUhUQVZEpP2ZNCk+SYlbbrkl4vycnBwCjfS+eeGFF3LhhRc2u+2rr76a3/zmNzXTs2bNYlLYmzAz7rvvvprp73//+9EFLSIN5OfDrbdCeTlUVdVZpEtDEZEUltLJCRGRaKjmlSTalClT/A5BpN0JBGD6dHjnnVBNifrKyxIdk4iIxI6SEyIiIm2wevXqFr/m4YcfjnkcIu1ZIOD1K7F7d8NlGRleJ7q7d69bm/jIREQkVpScEEliGqVFREQ6skDA64Pmq6+gpKTusowMuOQS6NfP66PmlFN2FfoRo4iIxIaSEynCqWK6iIiIdBCBAFx/PXz2GWRmQna2l4yoqPAS91lZ8JvfwLRpfkcqIiKxouSESBIzde0lIiIdSKhfiXffre3ssizYk8S553qJCTO4/PLEjOYjIiKJo+SEiLR7ah4jIpLcQkmJ997zakfUV1WlhISISHuX5ncAItI4FapF2m7Tpk1cdNFF7L///owYMYLTTjuNL774otH1V69eTU5ODmPGjGH06NEcffTRLF++vMX7zc/P5/HHH29L6CLtXiAAhx4KkyfDW29FTkyA17eEEhMiIu2bkhMiItJuOec499xzmThxIitXrmTp0qVMnz6dzZs3N/m6/fffn0WLFvHJJ59w2WWXMX369BbvOxAIMEmlKZGIAgG46CI4+2xYvDhyMj49HQYN8mpUzJiR+BhFRCSxlJyIku5gix/U54RI27z55ptkZmZy5ZVX1swbM2YM3/zmN3HO8Ytf/IKRI0cyatQonnrqqYjbKCwspEePHg3mFxQUcNxxx3HuuecyYsQIrrzySqqrq2teU15eTu/evVm1ahUTJkzgiCOO4Fe/+hVdunSJz5sVSRGhYUGfeQZKSxsuz8iA44+Hl16Cr79Wp5ciIh2F+pwQEZHkEho7cOLENtfjXrJkCWPHjo247LnnnqupHbFt2zaOOOIIjjvuOABWrlzJmDFjKCoqYu/evXz44YcRtzFv3jyWLl3Kfvvtx+TJk3nuuec477zzeO211zjxxBMB+OlPf8pVV13FpZdeyv3339+m9yPSHsycCYWFkW/8jBoFf/yjmnCIiHREqjkRJd3BFj+oxk5saCjeFBIIwJQpcP/93mMgELddvfvuu1x88cWkp6fTt29fjj/+eD766COgtlnHypUrufvuu7niiisibmP8+PEMGzaM9PR0Lr74Yt59910A5syZw6mnngrA3LlzufjiiwG45JJL4vZ+RFJF6LctdG3Vuzd84xte841PP1ViQkSko1JywgetKnCqbCUiHUFBgTduYG6u91hQ0KbNHXLIISxYsCDiMhflyfiss87i7bffjrjM6mWuQ9Pz5s1j/Pjxja4n0lEEAnDjjXXzjFOnQl4eZGZCt24waxYsXarmGyIiHZ2SE1HSHWzxg8oz0uFMnAhZWVBc7D1OnNimzZ1wwgmUlZXx97//vWbeRx99xFtvvcVxxx3HU089RVVVFVu3buXtt9+uk1AIeffdd9l///0jbn/evHmsWrWK6upqnnrqKY499lg+++wzDj74YNLT0wE45phjePLJJwE0eod0KPn5cM45cM89dStCTZoETz8NP/+596iaEiIiAupzwhcqcIqINGLSJO82aoz6nDAznn/+ea699lruuOMOsrOzGTJkCHfffTfHHXcc77//PqNHj8bM+P3vf0+/fv1YvXp1TZ8Tzjk6derEQw89FHH7EyZM4IYbbmDx4sU1nWPeddddTJ48uWade+65h+9+97vcc889fOc732nT+xFJFYEA3HYblJRAWvBWWEFB7b/0pElKSoiISF0p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\n",
      "text/plain": [
       "<Figure size 1080x288 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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-4-eee19534b7db>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     37\u001b[0m         \u001b[0mps\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mp_list\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrandom\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mchoice\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mp_list\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mbs\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     38\u001b[0m         \u001b[0mqs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mq_list\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrandom\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mchoice\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mq_list\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mbs\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---> 39\u001b[0;31m         \u001b[0mms\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mm_list\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrandom\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mchoice\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mm_list\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mbs\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     40\u001b[0m         \u001b[0mfeed_dict\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m{\u001b[0m\u001b[0mp_samples\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mps\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mq_samples\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mqs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mm_samples\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mms\u001b[0m\u001b[0;34m}\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     41\u001b[0m         \u001b[0ml\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0m_\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msess\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mdloss\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0moptim\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mfeed_dict\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mfeed_dict\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32mmtrand.pyx\u001b[0m in \u001b[0;36mnumpy.random.mtrand.RandomState.choice\u001b[0;34m()\u001b[0m\n",
      "\u001b[0;32m<__array_function__ internals>\u001b[0m in \u001b[0;36mprod\u001b[0;34m(*args, **kwargs)\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    },
    {
     "data": {
      "image/png": "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0qVMnz6dzZs3N/m6/fffn0WLFvHJJ59w2WWXMX369BbvOxAIMEmlKZGIAgG46CI4+2xYvDhyMj49HQYN8mpUzJiR+BhFRCSxlJyIku5gix/U54RI27z55ptkZmZy5ZVX1swbM2YM3/zmN3HO8Ytf/IKRI0cyatQonnrqqYjbKCwspEePHg3mFxQUcNxxx3HuuecyYsQIrrzySqqrq2teU15eTu/evVm1ahUTJkzgiCOO4Fe/+hVdunSJz5sVSRGhYUGfeQZKSxsuz8iA44+Hl16Cr79Wp5ciIh2F+pwQEZHkEho7cOLENtfjXrJkCWPHjo247LnnnqupHbFt2zaOOOIIjjvuOABWrlzJmDFjKCoqYu/evXz44YcRtzFv3jyWLl3Kfvvtx+TJk3nuuec477zzeO211zjxxBMB+OlPf8pVV13FpZdeyv3339+m9yPSHsycCYWFkW/8jBoFf/yjmnCIiHREqjkRJd3BFj+oxk5saCjeFBIIwJQpcP/93mMgELddvfvuu1x88cWkp6fTt29fjj/+eD766COgtlnHypUrufvuu7niiisibmP8+PEMGzaM9PR0Lr74Yt59910A5syZw6mnngrA3LlzufjiiwG45JJL4vZ+RFJF6LctdG3Vuzd84xte841PP1ViQkSko1JywgetKnCqbCUiHUFBgTduYG6u91hQ0KbNHXLIISxYsCDiMhflyfiss87i7bffjrjM6mWuQ9Pz5s1j/Pjxja4n0lEEAnDjjXXzjFOnQl4eZGZCt24waxYsXarmGyIiHZ2SE1HSHWzxg8oz0uFMnAhZWVBc7D1OnNimzZ1wwgmUlZXx97//vWbeRx99xFtvvcVxxx3HU089RVVVFVu3buXtt9+uk1AIeffdd9l///0jbn/evHmsWrWK6upqnnrqKY499lg+++wzDj74YNLT0wE45phjePLJJwE0eod0KPn5cM45cM89dStCTZoETz8NP/+596iaEiIiAupzwhcqcIqINGLSJO82aoz6nDAznn/+ea699lruuOMOsrOzGTJkCHfffTfHHXcc77//PqNHj8bM+P3vf0+/fv1YvXp1TZ8Tzjk6derEQw89FHH7EyZM4IYbbmDx4sU1nWPeddddTJ48uWade+65h+9+97vcc889fOc732nT+xFJFYEA3HYblJRAWvBWWEFB7b/0pElKSoiISF0p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\n",
      "text/plain": [
       "<Figure size 1080x288 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plotlosses = PlotLosses()\n",
    "# train(sess, dloss, optim, plotlosses, N=N)\n",
    "\n",
    "\n",
    "loss_store=[]\n",
    "test_loss_store=[]\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,N])\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,N])\n",
    "ax3.set_ylim([0,10])\n",
    "\n",
    "plt.tight_layout()\n",
    "\n",
    "pbar = range(0,N)\n",
    "for j in pbar:\n",
    "    for i in range(num_samples//bs):\n",
    "\n",
    "        ps = p_list[np.random.choice(range(len(p_list)),bs)]\n",
    "        qs = q_list[np.random.choice(range(len(q_list)),bs)]\n",
    "        ms = m_list[np.random.choice(range(len(m_list)),bs)]\n",
    "        feed_dict = {p_samples:ps, q_samples:qs, m_samples:ms}\n",
    "        l,_ = sess.run([dloss, optim],feed_dict=feed_dict)\n",
    "        loss_store.append(l)\n",
    "        if i%50==0:\n",
    "            line.set_data(range(len(loss_store)), loss_store)\n",
    "            ax1.set_xlim( 0, len(loss_store) )\n",
    "\n",
    "            ps = p_list_test[np.random.choice(range(len(p_list_test)),bs)]\n",
    "            qs = q_list[np.random.choice(range(len(q_list)),bs)]\n",
    "            ms = m_list_test[np.random.choice(range(len(m_list_test)),bs)]\n",
    "            feed_dict = {p_samples:ps, q_samples:qs, m_samples:ms}\n",
    "\n",
    "            testl, xs, lpq, lpqm, kld_true, kld_cob = sess.run([dloss,m_samples, log_ratio_p_q, log_ratio_p_m, kl_from_pq, kl_from_cob],feed_dict=feed_dict)\n",
    "\n",
    "            scat2.set_offsets(np.asarray([xs,lpqm[:,0]-lpqm[:,1]]).T)\n",
    "            scat1.set_offsets(np.asarray([xs, lpq]).T)\n",
    "            ax2.set_xlim( -1., 1. )\n",
    "            ax2.set_ylim( -400, 100 )\n",
    "            \n",
    "            test_loss_store.append(testl)\n",
    "            test_line.set_data(range(len(test_loss_store)), test_loss_store)\n",
    "            ax3.set_xlim( 0, len(test_loss_store) )\n",
    "            print('epoch: ',j)\n",
    "            print('KLD: ', kld_true)\n",
    "            print('CoB: ', kld_cob)\n",
    "        \n",
    "            clear_output(wait=True)\n",
    "            display(fig)\n",
    "            \n",
    "            \n",
    "print('KLD: ', kld_true)\n",
    "print('CoB: ', kld_cob)\n",
    "\n",
    "ps = p_list_test[np.random.choice(range(len(p_list_test)),bs)]\n",
    "qs = q_list[np.random.choice(range(len(q_list)),bs)]\n",
    "ms = m_list_test[np.random.choice(range(len(m_list_test)),bs)]\n",
    "        \n",
    "sample_and_plot(sess, kl_from_pq, kl_from_cob, kld, ps, qs, ms, log_ratio_p_q, log_ratio_p_m, mu_1, mu_2, scale_p, scale_q, mu_3, scale_m)\n",
    "# with open(\"../models/kl_utils.py\", \"a\") as f:\n",
    "#     f.write(\" \")\n",
    "#     f.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "ename": "TypeError",
     "evalue": "Fetch argument array([1.8654219, 2.1975555, 2.1357305, 2.1089392, 2.1027296, 2.0635662,\n       1.907367 , 1.9077305, 1.877833 , 1.9443195, 1.9277153, 1.9847392,\n       1.695134 , 2.0427012, 2.0365894, 2.0145977, 2.0559826, 2.061621 ,\n       1.9518727, 2.0327802, 1.9607908, 1.8187155, 2.0307326, 1.8606565,\n       2.0107002, 1.8520222, 2.0490835, 1.9950736, 2.1242375, 1.982958 ,\n       2.0654273, 1.9501238, 1.926147 , 2.0260305, 1.8210969, 1.9984273,\n       1.9693581, 1.8334082, 1.9736323, 1.9516562, 2.2349524, 2.1637359,\n       2.0270193, 1.9426658, 2.0611258, 2.0239685, 1.9912816, 2.0517278,\n       2.061085 , 2.0644238, 2.086155 , 1.8636572, 2.0411284, 1.95912  ,\n       2.0037704, 2.1434016, 2.0090034, 2.0473154, 2.1342425, 2.064986 ,\n       1.9921297, 2.0547917, 2.152583 , 2.046934 , 1.996203 , 2.0835843,\n       1.8884397, 1.9606011, 1.9918784, 2.0657508, 2.0075796, 2.005409 ,\n       1.9443059, 1.9443344, 2.0553267, 1.8889552, 2.0779145, 2.051426 ,\n       1.8928688, 2.0715137, 2.067317 , 1.8936456, 1.8910722, 1.8821617,\n       1.9889914, 2.1538377, 2.0061557, 1.9214827, 2.0490816, 1.8098432,\n       2.0236814, 2.0515528, 1.9275724, 2.1627371, 2.069758 , 1.9032412,\n       2.1513648, 2.115444 , 1.939657 , 2.1086462, 2.2552412, 1.997185 ,\n       2.0472507, 2.122509 , 1.8883821, 1.9259651, 2.114003 , 1.9869269,\n       2.1457665, 2.1002564, 1.9755713, 2.0982928, 1.8837267, 1.8981224,\n       2.2530193, 2.040568 , 1.8232497, 1.8566784, 2.045957 , 2.0139537,\n       2.0902581, 2.1062567, 1.9434052, 2.005993 , 2.1142495, 2.1082187,\n       1.9820727, 2.0328465, 2.1560805, 2.044188 , 2.056334 , 1.9514188,\n       2.1592255, 1.8069599, 1.9810692, 1.856318 , 2.0031083, 1.9765884,\n       1.9846089, 1.956072 , 1.9547894, 1.8648735, 2.0552926, 2.061795 ,\n       1.9207226, 2.1019614, 2.01901  , 2.1097004, 2.02407  , 1.9638929,\n       1.8960495, 1.833455 , 1.9594959, 1.8857876, 2.1538563, 1.915187 ,\n       1.7499614, 1.9775933, 1.981234 , 2.0710661, 1.9098037, 1.9591907,\n       2.234987 , 2.0355632, 2.0121872, 2.076396 , 1.993393 , 2.0258393,\n       1.9940641, 1.9444991, 1.8870697, 2.0379155, 2.055931 , 1.8500917,\n       2.1103852, 1.955085 , 2.1665769, 2.0424566, 1.9676801, 1.9667585,\n       1.9633492, 2.1004963, 1.8827578, 2.1074054, 1.9704323, 2.0019019,\n       1.9785689, 1.8793744, 2.020839 , 2.0509796, 2.2229924, 1.8605093,\n       2.0129516, 2.134486 , 1.9344414, 1.8711281, 1.9017636, 1.970962 ,\n       1.9861463, 1.9895744, 2.0596597, 2.0852468, 1.9237735, 1.8630253,\n       1.9364474, 2.130681 , 2.0531013, 2.1431575, 1.8233039, 2.2414165,\n       2.2043417, 2.178008 , 2.051153 , 2.055254 , 1.9888495, 2.102437 ,\n       1.9199178, 2.0362227, 2.0276155, 2.088104 , 2.1543233, 2.063622 ,\n       2.0445862, 1.936782 , 2.1531613, 2.1325927, 1.8979104, 1.9802256,\n       2.1945407, 1.8801751, 1.9011354, 1.9487367, 1.819632 , 1.8786093,\n       2.0930326, 2.116372 , 1.9911766, 2.167138 , 1.8233294, 2.203879 ,\n       2.1312385, 1.8231099, 2.004325 , 1.8994882, 2.136447 , 2.0711067,\n       2.0160353, 2.1270764, 2.0682387, 2.018396 , 2.1432033, 2.2229648,\n       1.9980628, 1.8978634, 1.9811496, 2.0008698, 1.9657242, 2.0780127,\n       2.0396905, 1.8636926, 1.9185805, 2.0100255, 1.8998545, 1.9616259,\n       1.9651117, 2.0383964, 2.0354385, 1.8929874, 2.010974 , 2.017306 ,\n       1.9820234, 1.9195893, 1.9523463, 2.0609121, 1.9765694, 2.0042036,\n       2.0407956, 2.0348895, 2.1534877, 1.9699079, 2.0594506, 2.0498903,\n       1.9513882, 1.9391098, 1.9944174, 1.9175103, 2.1055787, 1.9017264,\n       2.0907521, 2.123268 , 1.9229623, 1.9170046, 2.0510504, 2.116082 ,\n       1.992574 , 1.9228145, 1.919255 , 2.02248  , 2.0705802, 1.9956083,\n       1.9475284, 2.0788639, 2.1250849, 2.1573894, 1.9858968, 2.028444 ,\n       1.9661502, 1.9807788, 2.0154326, 2.0725136, 1.9764662, 1.9204234,\n       2.1491048, 2.0733685, 1.8769157, 2.0352657, 2.0713487, 2.0879612,\n       1.9941818, 1.932777 , 1.9634038, 2.125091 , 2.112381 , 2.0335734,\n       2.2488925, 1.9741459, 2.036112 , 2.1199534, 2.1347682, 1.9538622,\n       1.9836658, 2.003674 , 1.9120182, 2.0605888, 2.1037703, 1.9808952,\n       2.0251787, 2.0503619, 2.065582 , 1.9361473, 2.0327473, 2.0685308,\n       2.1823924, 1.9449438, 2.030153 , 2.099775 , 2.0529494, 1.8566617,\n       1.864986 , 1.9152492, 2.048271 , 2.2010207, 2.0380244, 2.3100526,\n       2.0252216, 2.0906951, 1.985851 , 2.039298 , 2.0164382, 2.1220517,\n       1.9187176, 2.081197 , 1.8847811, 1.9722269, 2.0432982, 1.8686901,\n       1.9049264, 1.8077533, 1.9486483, 2.0921345, 2.0930164, 2.0297136,\n       1.8569776, 2.125936 , 1.865938 , 1.9699055, 2.075267 , 2.0538425,\n       1.8922474, 2.071622 , 2.0390954, 1.8950214, 2.1154833, 2.032021 ,\n       2.0816734, 1.9577699, 1.962571 , 1.889414 , 1.9421288, 1.9345027,\n       2.0178564, 1.9972911, 1.8666799, 2.1506166, 1.7556301, 2.1172955,\n       1.8120893, 1.9817117, 2.0704176, 1.9625106, 2.0174587, 2.1149802,\n       1.9132996, 1.8705112, 1.852652 , 2.09443  , 1.979127 , 2.0383084,\n       2.0242674, 1.9778641, 1.960145 , 1.9589088, 1.9136   , 2.085983 ,\n       2.011373 , 1.8783301, 2.2002337, 1.8190526, 2.114614 , 1.8489418,\n       1.8761176, 2.058416 , 2.0983326, 2.0341997, 2.1334162, 2.0932326,\n       1.8012915, 2.079991 , 2.0200324, 1.9971498, 2.069171 , 2.0264785,\n       1.9648093, 2.0505295, 2.0079937, 1.7439127, 2.0844994, 2.091299 ,\n       2.034783 , 2.0117843, 1.8692949, 2.0899892, 2.0339525, 1.9612634,\n       2.1642358, 1.8460659, 1.9148293, 2.0279918, 2.0046644, 2.1203682,\n       2.0319295, 1.9511082, 2.162214 , 2.06977  , 1.9911845, 2.0818896,\n       1.9643215, 2.0143147, 2.0516417, 2.051511 , 1.910132 , 2.1572645,\n       2.1489115, 2.0146992, 1.9491345, 2.0219643, 2.204611 , 1.9940805,\n       1.9393895, 1.9979424, 1.9813461, 1.8555312, 1.8292487, 2.0699575,\n       2.0519702, 1.8362075, 1.8792703, 2.2929866, 2.1572473, 2.2402775,\n       2.013396 , 1.8781621, 2.0179877, 2.0973992, 2.1572955, 1.9576926,\n       1.9399191, 1.9905062, 1.9435359, 1.9334903, 1.9127337, 1.9574097,\n       1.9561778, 2.0532603, 1.8417983, 2.0702806, 2.022363 , 2.0557802,\n       1.9263593, 1.7554201], dtype=float32) has invalid type <class 'numpy.ndarray'>, must be a string or Tensor. (Can not convert a ndarray into a Tensor or Operation.)",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mTypeError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m/disk_c/akash/anaconda/envs/iclr/lib/python3.7/site-packages/tensorflow_core/python/client/session.py\u001b[0m in \u001b[0;36m__init__\u001b[0;34m(self, fetches, contraction_fn)\u001b[0m\n\u001b[1;32m    304\u001b[0m         self._unique_fetches.append(ops.get_default_graph().as_graph_element(\n\u001b[0;32m--> 305\u001b[0;31m             fetch, allow_tensor=True, allow_operation=True))\n\u001b[0m\u001b[1;32m    306\u001b[0m       \u001b[0;32mexcept\u001b[0m \u001b[0mTypeError\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0me\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/akash/anaconda/envs/iclr/lib/python3.7/site-packages/tensorflow_core/python/framework/ops.py\u001b[0m in \u001b[0;36mas_graph_element\u001b[0;34m(self, obj, allow_tensor, allow_operation)\u001b[0m\n\u001b[1;32m   3606\u001b[0m     \u001b[0;32mwith\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_lock\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 3607\u001b[0;31m       \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_as_graph_element_locked\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mobj\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mallow_tensor\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mallow_operation\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   3608\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/akash/anaconda/envs/iclr/lib/python3.7/site-packages/tensorflow_core/python/framework/ops.py\u001b[0m in \u001b[0;36m_as_graph_element_locked\u001b[0;34m(self, obj, allow_tensor, allow_operation)\u001b[0m\n\u001b[1;32m   3695\u001b[0m       raise TypeError(\"Can not convert a %s into a %s.\" %\n\u001b[0;32m-> 3696\u001b[0;31m                       (type(obj).__name__, types_str))\n\u001b[0m\u001b[1;32m   3697\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mTypeError\u001b[0m: Can not convert a ndarray into a Tensor or Operation.",
      "\nDuring handling of the above exception, another exception occurred:\n",
      "\u001b[0;31mTypeError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-5-98aeb9bf351c>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      3\u001b[0m \u001b[0mms\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mm_list_test\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrandom\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mchoice\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mm_list_test\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mbs\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      4\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 5\u001b[0;31m \u001b[0msample_and_plot\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msess\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkl_from_pq\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkl_from_cob\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkld\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mps\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mqs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mms\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlog_ratio_p_q\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlog_ratio_p_m\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmu_1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmu_2\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mscale_p\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mscale_q\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmu_3\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mscale_m\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m/disk_c/akash/CoB/models/kl_utils.py\u001b[0m in \u001b[0;36msample_and_plot\u001b[0;34m(sess, kl_p_q, kl_cob, kld, p_samples, q_samples, m_samples, log_ratio_p_q, log_ratio_p_m, mu_1, mu_2, scale_p, scale_q, mu_3, scale_m, training)\u001b[0m\n\u001b[1;32m    170\u001b[0m                                                                             \u001b[0mp_samples\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mq_samples\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mm_samples\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mencoder_m\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mencoder_p\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    171\u001b[0m                                                                             log_ratio_p_q,  log_ratio_p_m],\n\u001b[0;32m--> 172\u001b[0;31m                                                                           feed_dict=feed_dict)\n\u001b[0m\u001b[1;32m    173\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    174\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/akash/anaconda/envs/iclr/lib/python3.7/site-packages/tensorflow_core/python/client/session.py\u001b[0m in \u001b[0;36mrun\u001b[0;34m(self, fetches, feed_dict, options, run_metadata)\u001b[0m\n\u001b[1;32m    954\u001b[0m     \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    955\u001b[0m       result = self._run(None, fetches, feed_dict, options_ptr,\n\u001b[0;32m--> 956\u001b[0;31m                          run_metadata_ptr)\n\u001b[0m\u001b[1;32m    957\u001b[0m       \u001b[0;32mif\u001b[0m \u001b[0mrun_metadata\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    958\u001b[0m         \u001b[0mproto_data\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtf_session\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mTF_GetBuffer\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrun_metadata_ptr\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/akash/anaconda/envs/iclr/lib/python3.7/site-packages/tensorflow_core/python/client/session.py\u001b[0m in \u001b[0;36m_run\u001b[0;34m(self, handle, fetches, feed_dict, options, run_metadata)\u001b[0m\n\u001b[1;32m   1163\u001b[0m     \u001b[0;31m# Create a fetch handler to take care of the structure of fetches.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1164\u001b[0m     fetch_handler = _FetchHandler(\n\u001b[0;32m-> 1165\u001b[0;31m         self._graph, fetches, feed_dict_tensor, feed_handles=feed_handles)\n\u001b[0m\u001b[1;32m   1166\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1167\u001b[0m     \u001b[0;31m# Run request and get response.\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/akash/anaconda/envs/iclr/lib/python3.7/site-packages/tensorflow_core/python/client/session.py\u001b[0m in \u001b[0;36m__init__\u001b[0;34m(self, graph, fetches, feeds, feed_handles)\u001b[0m\n\u001b[1;32m    472\u001b[0m     \"\"\"\n\u001b[1;32m    473\u001b[0m     \u001b[0;32mwith\u001b[0m \u001b[0mgraph\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mas_default\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[0;32m--> 474\u001b[0;31m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_fetch_mapper\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0m_FetchMapper\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfor_fetch\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfetches\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    475\u001b[0m     \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_fetches\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    476\u001b[0m     \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_targets\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[0;32m/disk_c/akash/anaconda/envs/iclr/lib/python3.7/site-packages/tensorflow_core/python/client/session.py\u001b[0m in \u001b[0;36mfor_fetch\u001b[0;34m(fetch)\u001b[0m\n\u001b[1;32m    264\u001b[0m     \u001b[0;32melif\u001b[0m \u001b[0misinstance\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfetch\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mlist\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtuple\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    265\u001b[0m       \u001b[0;31m# NOTE(touts): This is also the code path for namedtuples.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 266\u001b[0;31m       \u001b[0;32mreturn\u001b[0m \u001b[0m_ListFetchMapper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfetch\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    267\u001b[0m     \u001b[0;32melif\u001b[0m \u001b[0misinstance\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfetch\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcollections_abc\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mMapping\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    268\u001b[0m       \u001b[0;32mreturn\u001b[0m \u001b[0m_DictFetchMapper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfetch\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/akash/anaconda/envs/iclr/lib/python3.7/site-packages/tensorflow_core/python/client/session.py\u001b[0m in \u001b[0;36m__init__\u001b[0;34m(self, fetches)\u001b[0m\n\u001b[1;32m    373\u001b[0m     \"\"\"\n\u001b[1;32m    374\u001b[0m     \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_fetch_type\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfetches\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 375\u001b[0;31m     \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_mappers\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0m_FetchMapper\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfor_fetch\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfetch\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mfetch\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mfetches\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    376\u001b[0m     \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_unique_fetches\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_value_indices\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0m_uniquify_fetches\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_mappers\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    377\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/akash/anaconda/envs/iclr/lib/python3.7/site-packages/tensorflow_core/python/client/session.py\u001b[0m in \u001b[0;36m<listcomp>\u001b[0;34m(.0)\u001b[0m\n\u001b[1;32m    373\u001b[0m     \"\"\"\n\u001b[1;32m    374\u001b[0m     \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_fetch_type\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfetches\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 375\u001b[0;31m     \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_mappers\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0m_FetchMapper\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfor_fetch\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfetch\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mfetch\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mfetches\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    376\u001b[0m     \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_unique_fetches\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_value_indices\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0m_uniquify_fetches\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_mappers\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    377\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/akash/anaconda/envs/iclr/lib/python3.7/site-packages/tensorflow_core/python/client/session.py\u001b[0m in \u001b[0;36mfor_fetch\u001b[0;34m(fetch)\u001b[0m\n\u001b[1;32m    274\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0misinstance\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfetch\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtensor_type\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    275\u001b[0m           \u001b[0mfetches\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcontraction_fn\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mfetch_fn\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfetch\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 276\u001b[0;31m           \u001b[0;32mreturn\u001b[0m \u001b[0m_ElementFetchMapper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfetches\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcontraction_fn\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    277\u001b[0m     \u001b[0;31m# Did not find anything.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    278\u001b[0m     raise TypeError('Fetch argument %r has invalid type %r' %\n",
      "\u001b[0;32m/disk_c/akash/anaconda/envs/iclr/lib/python3.7/site-packages/tensorflow_core/python/client/session.py\u001b[0m in \u001b[0;36m__init__\u001b[0;34m(self, fetches, contraction_fn)\u001b[0m\n\u001b[1;32m    307\u001b[0m         raise TypeError('Fetch argument %r has invalid type %r, '\n\u001b[1;32m    308\u001b[0m                         \u001b[0;34m'must be a string or Tensor. (%s)'\u001b[0m \u001b[0;34m%\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 309\u001b[0;31m                         (fetch, type(fetch), str(e)))\n\u001b[0m\u001b[1;32m    310\u001b[0m       \u001b[0;32mexcept\u001b[0m \u001b[0mValueError\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0me\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    311\u001b[0m         raise ValueError('Fetch argument %r cannot be interpreted as a '\n",
      "\u001b[0;31mTypeError\u001b[0m: Fetch argument array([1.8654219, 2.1975555, 2.1357305, 2.1089392, 2.1027296, 2.0635662,\n       1.907367 , 1.9077305, 1.877833 , 1.9443195, 1.9277153, 1.9847392,\n       1.695134 , 2.0427012, 2.0365894, 2.0145977, 2.0559826, 2.061621 ,\n       1.9518727, 2.0327802, 1.9607908, 1.8187155, 2.0307326, 1.8606565,\n       2.0107002, 1.8520222, 2.0490835, 1.9950736, 2.1242375, 1.982958 ,\n       2.0654273, 1.9501238, 1.926147 , 2.0260305, 1.8210969, 1.9984273,\n       1.9693581, 1.8334082, 1.9736323, 1.9516562, 2.2349524, 2.1637359,\n       2.0270193, 1.9426658, 2.0611258, 2.0239685, 1.9912816, 2.0517278,\n       2.061085 , 2.0644238, 2.086155 , 1.8636572, 2.0411284, 1.95912  ,\n       2.0037704, 2.1434016, 2.0090034, 2.0473154, 2.1342425, 2.064986 ,\n       1.9921297, 2.0547917, 2.152583 , 2.046934 , 1.996203 , 2.0835843,\n       1.8884397, 1.9606011, 1.9918784, 2.0657508, 2.0075796, 2.005409 ,\n       1.9443059, 1.9443344, 2.0553267, 1.8889552, 2.0779145, 2.051426 ,\n       1.8928688, 2.0715137, 2.067317 , 1.8936456, 1.8910722, 1.8821617,\n       1.9889914, 2.1538377, 2.0061557, 1.9214827, 2.0490816, 1.8098432,\n       2.0236814, 2.0515528, 1.9275724, 2.1627371, 2.069758 , 1.9032412,\n       2.1513648, 2.115444 , 1.939657 , 2.1086462, 2.2552412, 1.997185 ,\n       2.0472507, 2.122509 , 1.8883821, 1.9259651, 2.114003 , 1.9869269,\n       2.1457665, 2.1002564, 1.9755713, 2.0982928, 1.8837267, 1.8981224,\n       2.2530193, 2.040568 , 1.8232497, 1.8566784, 2.045957 , 2.0139537,\n       2.0902581, 2.1062567, 1.9434052, 2.005993 , 2.1142495, 2.1082187,\n       1.9820727, 2.0328465, 2.1560805, 2.044188 , 2.056334 , 1.9514188,\n       2.1592255, 1.8069599, 1.9810692, 1.856318 , 2.0031083, 1.9765884,\n       1.9846089, 1.956072 , 1.9547894, 1.8648735, 2.0552926, 2.061795 ,\n       1.9207226, 2.1019614, 2.01901  , 2.1097004, 2.02407  , 1.9638929,\n       1.8960495, 1.833455 , 1.9594959, 1.8857876, 2.1538563, 1.915187 ,\n       1.7499614, 1.9775933, 1.981234 , 2.0710661, 1.9098037, 1.9591907,\n       2.234987 , 2.0355632, 2.0121872, 2.076396 , 1.993393 , 2.0258393,\n       1.9940641, 1.9444991, 1.8870697, 2.0379155, 2.055931 , 1.8500917,\n       2.1103852, 1.955085 , 2.1665769, 2.0424566, 1.9676801, 1.9667585,\n       1.9633492, 2.1004963, 1.8827578, 2.1074054, 1.9704323, 2.0019019,\n       1.9785689, 1.8793744, 2.020839 , 2.0509796, 2.2229924, 1.8605093,\n       2.0129516, 2.134486 , 1.9344414, 1.8711281, 1.9017636, 1.970962 ,\n       1.9861463, 1.9895744, 2.0596597, 2.0852468, 1.9237735, 1.8630253,\n       1.9364474, 2.130681 , 2.0531013, 2.1431575, 1.8233039, 2.2414165,\n       2.2043417, 2.178008 , 2.051153 , 2.055254 , 1.9888495, 2.102437 ,\n       1.9199178, 2.0362227, 2.0276155, 2.088104 , 2.1543233, 2.063622 ,\n       2.0445862, 1.936782 , 2.1531613, 2.1325927, 1.8979104, 1.9802256,\n       2.1945407, 1.8801751, 1.9011354, 1.9487367, 1.819632 , 1.8786093,\n       2.0930326, 2.116372 , 1.9911766, 2.167138 , 1.8233294, 2.203879 ,\n       2.1312385, 1.8231099, 2.004325 , 1.8994882, 2.136447 , 2.0711067,\n       2.0160353, 2.1270764, 2.0682387, 2.018396 , 2.1432033, 2.2229648,\n       1.9980628, 1.8978634, 1.9811496, 2.0008698, 1.9657242, 2.0780127,\n       2.0396905, 1.8636926, 1.9185805, 2.0100255, 1.8998545, 1.9616259,\n       1.9651117, 2.0383964, 2.0354385, 1.8929874, 2.010974 , 2.017306 ,\n       1.9820234, 1.9195893, 1.9523463, 2.0609121, 1.9765694, 2.0042036,\n       2.0407956, 2.0348895, 2.1534877, 1.9699079, 2.0594506, 2.0498903,\n       1.9513882, 1.9391098, 1.9944174, 1.9175103, 2.1055787, 1.9017264,\n       2.0907521, 2.123268 , 1.9229623, 1.9170046, 2.0510504, 2.116082 ,\n       1.992574 , 1.9228145, 1.919255 , 2.02248  , 2.0705802, 1.9956083,\n       1.9475284, 2.0788639, 2.1250849, 2.1573894, 1.9858968, 2.028444 ,\n       1.9661502, 1.9807788, 2.0154326, 2.0725136, 1.9764662, 1.9204234,\n       2.1491048, 2.0733685, 1.8769157, 2.0352657, 2.0713487, 2.0879612,\n       1.9941818, 1.932777 , 1.9634038, 2.125091 , 2.112381 , 2.0335734,\n       2.2488925, 1.9741459, 2.036112 , 2.1199534, 2.1347682, 1.9538622,\n       1.9836658, 2.003674 , 1.9120182, 2.0605888, 2.1037703, 1.9808952,\n       2.0251787, 2.0503619, 2.065582 , 1.9361473, 2.0327473, 2.0685308,\n       2.1823924, 1.9449438, 2.030153 , 2.099775 , 2.0529494, 1.8566617,\n       1.864986 , 1.9152492, 2.048271 , 2.2010207, 2.0380244, 2.3100526,\n       2.0252216, 2.0906951, 1.985851 , 2.039298 , 2.0164382, 2.1220517,\n       1.9187176, 2.081197 , 1.8847811, 1.9722269, 2.0432982, 1.8686901,\n       1.9049264, 1.8077533, 1.9486483, 2.0921345, 2.0930164, 2.0297136,\n       1.8569776, 2.125936 , 1.865938 , 1.9699055, 2.075267 , 2.0538425,\n       1.8922474, 2.071622 , 2.0390954, 1.8950214, 2.1154833, 2.032021 ,\n       2.0816734, 1.9577699, 1.962571 , 1.889414 , 1.9421288, 1.9345027,\n       2.0178564, 1.9972911, 1.8666799, 2.1506166, 1.7556301, 2.1172955,\n       1.8120893, 1.9817117, 2.0704176, 1.9625106, 2.0174587, 2.1149802,\n       1.9132996, 1.8705112, 1.852652 , 2.09443  , 1.979127 , 2.0383084,\n       2.0242674, 1.9778641, 1.960145 , 1.9589088, 1.9136   , 2.085983 ,\n       2.011373 , 1.8783301, 2.2002337, 1.8190526, 2.114614 , 1.8489418,\n       1.8761176, 2.058416 , 2.0983326, 2.0341997, 2.1334162, 2.0932326,\n       1.8012915, 2.079991 , 2.0200324, 1.9971498, 2.069171 , 2.0264785,\n       1.9648093, 2.0505295, 2.0079937, 1.7439127, 2.0844994, 2.091299 ,\n       2.034783 , 2.0117843, 1.8692949, 2.0899892, 2.0339525, 1.9612634,\n       2.1642358, 1.8460659, 1.9148293, 2.0279918, 2.0046644, 2.1203682,\n       2.0319295, 1.9511082, 2.162214 , 2.06977  , 1.9911845, 2.0818896,\n       1.9643215, 2.0143147, 2.0516417, 2.051511 , 1.910132 , 2.1572645,\n       2.1489115, 2.0146992, 1.9491345, 2.0219643, 2.204611 , 1.9940805,\n       1.9393895, 1.9979424, 1.9813461, 1.8555312, 1.8292487, 2.0699575,\n       2.0519702, 1.8362075, 1.8792703, 2.2929866, 2.1572473, 2.2402775,\n       2.013396 , 1.8781621, 2.0179877, 2.0973992, 2.1572955, 1.9576926,\n       1.9399191, 1.9905062, 1.9435359, 1.9334903, 1.9127337, 1.9574097,\n       1.9561778, 2.0532603, 1.8417983, 2.0702806, 2.022363 , 2.0557802,\n       1.9263593, 1.7554201], dtype=float32) has invalid type <class 'numpy.ndarray'>, must be a string or Tensor. (Can not convert a ndarray into a Tensor or Operation.)"
     ]
    }
   ],
   "source": [
    "ps = p_list_test[np.random.choice(range(len(p_list_test)),bs)]\n",
    "qs = q_list[np.random.choice(range(len(q_list)),bs)]\n",
    "ms = m_list_test[np.random.choice(range(len(m_list_test)),bs)]\n",
    "        \n",
    "sample_and_plot(sess, kl_from_pq, kl_from_cob, kld, ps, qs, ms, log_ratio_p_q, log_ratio_p_m, mu_1, mu_2, scale_p, scale_q, mu_3, scale_m)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"../models/kl_utils.py\", \"a\") as f:\n",
    "    f.write(\" \")\n",
    "    f.close()\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "collapsed_sections": [],
   "name": "Experiment_CoB_Simple.ipynb",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "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.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
