{
 "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 tensorflow.keras.initializers as initializers\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",
    "from scipy.special import softmax\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",
    "from scipy.linalg import block_diag\n",
    "sys.path.append('../models/')\n",
    "sys.path.append('../')\n",
    "from ratio_utils_highdim import *\n",
    "tf.keras.backend.set_floatx('float32')\n",
    "print(tf.__version__)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f9c79b6b190>"
      ]
     },
     "execution_count": 76,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 936x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "p_s = np.random.normal(0.,.01,1000)\n",
    "q_s = np.random.normal(0,.2,1000)\n",
    "\n",
    "m_s = np.concatenate([np.random.normal(0.,.01,900),np.random.normal(0.,.1,100)],0)\n",
    "\n",
    "# alphas = np.random.uniform(0.9,1,size=1000)\n",
    "# m_s = [alpha*p + (1-alpha)*q for (alpha,p,q) in zip(alphas,p_s,q_s)] + p_s_h\n",
    "# m_s = [np.sqrt(1-alpha**2)*p + (alpha)*q for (alpha,p,q) in zip(alphas,p_s,q_s)]\n",
    "# m_s = np.sqrt(1-(.5)**2)*p_s + q_s*(.5)\n",
    "fig, ax = plt.subplots(1, 1,figsize=(13,4))\n",
    "ax.hist(p_s, density=True, histtype='stepfilled', alpha=0.8, label='P')\n",
    "ax.hist(q_s, density=True, histtype='stepfilled', alpha=0.8, label='Q')\n",
    "ax.hist(m_s, density=True, histtype='stepfilled', alpha=0.8, label='M')\n",
    "ax.legend(loc='best', frameon=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.7950600976206501\n",
      "(100000, 320)\n"
     ]
    }
   ],
   "source": [
    "n_dims = 320\n",
    "num_samples=100000\n",
    "mi = 80\n",
    "bs=1000\n",
    "N=400\n",
    "deep=False\n",
    "reset(4)\n",
    "\n",
    "def get_rho_from_mi(mi, n_dims):\n",
    "    \"\"\"Get correlation coefficient from true mutual information\"\"\"\n",
    "    x = (4 * mi) / n_dims\n",
    "    return (1 - np.exp(-x)) ** 0.5  # correlation coefficient\n",
    "        \n",
    "def get_data(mu_1=0.,mu_2=2.,mu_3=2.,scale_p=0.1,scale_q=0.1,scale_m=1.):\n",
    "    \n",
    "    p = tfd.MultivariateNormalFullCovariance(\n",
    "        loc=mu_1,\n",
    "        covariance_matrix=scale_p)\n",
    "    \n",
    "    q = tfd.MultivariateNormalDiag(\n",
    "        loc=mu_2,\n",
    "        scale_diag=scale_q)\n",
    "      \n",
    "    m = tfp.distributions.Mixture(\n",
    "          cat=tfp.distributions.Categorical(probs=[.5,.5]),\n",
    "          components=[\n",
    "            p,\n",
    "            q, \n",
    "        ])\n",
    "    \n",
    "#     m = tfp.distributions.MultivariateStudentTLinearOperator(\n",
    "#     df=1.,\n",
    "#     loc=mu_2,\n",
    "#     scale=tf.linalg.LinearOperatorLowerTriangular(scale_m))\n",
    "    \n",
    "    p_samples_ = p.sample([num_samples]) \n",
    "    q_samples_ = q.sample([num_samples])\n",
    "    alpha = tf.expand_dims(tfd.Uniform (0.15,0.83).sample([num_samples]),1) #).15, 0.83\n",
    "    \n",
    "    \n",
    "    alpha = tf.expand_dims(tf.reshape(tf.repeat([0.,0.25,0.5,.75,1.],num_samples//5),[num_samples]),1)\n",
    "# #     alpha = tf.expand_dims(tf.reshape(tf.repeat([0.0,.15,.25,.35,.45,.55,.55,.75,.85,1.],num_samples//10),[num_samples]),1)\n",
    "#     m_samples_ = p_samples_ + q_samples_ # \n",
    "    m_samples_ = (1-alpha)*p_samples_ + alpha*q_samples_ \n",
    "    \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",
    "# Define data param\n",
    "rho = get_rho_from_mi(mi, n_dims)  # correlation coefficient\n",
    "print(rho)\n",
    "rhos = np.ones(n_dims // 2, dtype=\"float32\") * rho\n",
    "\n",
    "mu_1=0.+np.zeros((n_dims), dtype=\"float32\")\n",
    "mu_2=0.+np.zeros((n_dims), dtype=\"float32\")\n",
    "mu_3=np.zeros((n_dims), dtype=\"float32\")\n",
    "\n",
    "scale_p = block_diag(*[[[1, rho], [rho, 1]] for _ in range(n_dims // 2)])\n",
    "scale_p = np.float32(scale_p)\n",
    "scale_q = np.ones(n_dims, dtype=\"float32\")\n",
    "scale_m = 1*np.eye(n_dims, dtype=\"float32\")\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": 97,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-1.3692386\n"
     ]
    },
    {
     "data": {
      "image/png": "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LTomjMOAVKACr+2xr9s+5nqV9oD8XWocN7irM+Z6bMvbg8c2joPjr45JkkcJHhGRBOXunHrqqZxzzjn861//AmDp0qW88MIL3HvvvQAsWbKEE088kc8//7xJ++7QoUPlNueccw733nsv1113Xcxiv+GGG1i1ahVz5swhMzOTNWvW8M477zS43dtvv03Pnj2ZP38+EydOVIJHkkIsz9WSkhK+//3vM3bsWG688cZ6173yyisrk7dPPvkkRx55JF999VXll8/a3HvvvQwfPpwXX3yRdevWsfvuu/PjH/+Y1NRULrnkEt544w0GDBjAvvvuy8knn7xdwujVV19lwYIFLFiwgI8++oif/vSnfPTRRw09RSJJq0ePHpXnbV0/mtRnxowZdOrUqdYEj7Sq/sDyqOnccN52CR4zuwi4CGDQoEG17uz179KgpCNBsqCuZEDDSZDG8UhkzdiuMdtE0ksWblNfYsNr3NfcvzcwXR+HsjSClETN2GPxXEZSHZHUWF37bUrMjdGM168sgxlL+sXk6KrBIyKSoN566y0yMjK4+OKLK+ftvPPO/OxnP4vpcQ488EBWrFix3fxrrrmGv/71r5XTN910E3/6059YtWoVhx12GKNHj2bEiBG899571bYrLCzk73//O3/5y1/IzMwEoE+fPpx++ukAPP744+y9996MGDGCa665ptaY8vLy6NatW6weokiritW5WlZWxqRJkxg2bBi33XZbk7b94Q9/yMSJEysTTHUxM/Lz83F3tm7dSvfu3UlLS+Pjjz9m1113ZejQoWRkZDBp0iSef/757bZ//vnnOfvsszEzDjjgADZv3syqVc36QVwkac2ePZvDDz+csWPHcswxx1SeA3fffTfDhw9n5MiRTJo0iSVLlnDfffdxxx13MHr06O0+L+vy5z//mREjRjBixAjuvPNOAAoKCjjhhBMYNWoUI0aM4MknnwRg8uTJlcdsSuJpB1Dbt+tav8m7+/3uPs7dx9WVID9mlzLIKKT+hEis6htZM/fV2G1SqGrZ0lA6wGrcGlrelPSCQVoZQZOcmvuOxXNZRpDYiY6rrscQS814/dJKGD94ZUyOrhY8IiKxNG0azJgB48fDxIkt2tXcuXNbvetDeXk506dP54ILLthu2aRJk7jiiiv43//9XwCeeuopXnvtNf71r39xzDHHcN1111FeXk5hYWG17RYuXMigQYPo3LnzdvtcuXIl11xzDbNnz6Zbt25MnDiR5557jlNPPRWAI444Andn0aJFPPXUU7F/wNLu/frFuXy9Mi+m+xzerzM3nrRXnctjda7+/ve/56ijjqr8QtdU++yzD/PmzQPgV7/6FePGjePkk0+uts6ll17KySefTL9+/cjPz+fJJ58kJSWFFStWMHDgwMr1BgwYUGvLnNrWW7FiBX379m1WzCJNEY/zuyZ352c/+xnPP/88vXr14sknn+S6667jwQcf5LbbbmPx4sVkZmayefNmunbtysUXX9ykVj+zZ89m6tSpfPTRR7g7+++/P4cffjiLFi2iX79+vPzyy0DQ3XLjxo08++yzzJs3DzNj8+bNzXkK2qtcYGDU9ACg2d+gb/jPPaAaPKrBoxo8IiI7kGnT4MwzobgYHngAHnusxUmeaJdccgnvv/8+GRkZfPLJJy3a17Zt2xg9ejRLlixh7NixHH300dutM2bMGNauXcvKlStZt24d3bp1Y9CgQey7776cf/75lJaWcuqppzJ69OhGH/eTTz5h/PjxlV1IfvzjH/Puu+9WJngiXbS+++47JkyYwPjx4+nUqVOLHqtIW2vuuXrIIYfw4Ycf8u2337Lbbrs1+bhBqYnAzTffXOs6r7/+OqNHj+att97iu+++4+ijj+bQQw+ttm1EbaPtNHY9kfaquLiYOXPmVH5ulpeXVyY4R44cyY9//GNOPfXUys+1pnr//ff5n//5H7KzswH43ve+x3vvvcexxx7LVVddxTXXXMOJJ57IoYceSllZGVlZWVx44YWccMIJnHjiiTF5jO3EC8ClZvYEQXHlLc2tvxNxw3/u4YZal4xu5B4GNrB8SFPCaYSa++sDHB7jYzRXPxr/vDVF9HPcWt38exHU7o6VvYDYfV9QgkdEJFZmzAiSO9nZUFAQTLcgwbPXXnvxzDPPVE7fe++9rF+/nnHjxrU41EgNni1btnDiiSdy7733ctlll2233mmnncbTTz/N6tWrmTRpEgCHHXYY7777Li+//DJnnXUWV199NWeffXblNrvuuivLli0jPz+fnJycavur7cthbXbZZRf69OnD119/zX777deCR5q4zOxB4ERgrbuPCOf9ATgJKAG+A85z983hsinABQQ1/C5z99fjEXeia8ov8bESq3P1sMMO45xzzuG4447jvffeo1+/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u63Jm3377be8+eabpKamkpeXx7vvvktaWhpvvvkm1157Lc8888x228ybN4+3336b/Px8dt99d37605+Snp7e4LEuvfRSzj77bM455xwefPBBLrvsMp577jluvvlmXn/9dfr378/mzZsBuO+++7j88sv58Y9/TElJCeXlGnBRZEcStxY8ZtYfuAwY5+4jgFRgUrziEdlBOTDNzGab2UXhvD7uvgogvO9d24ZmdpGZzTKzWRq5RkREdmS6rt3x/OAHPyA1NRWALVu28IMf/IARI0Zw5ZVXMnfu3Fq3OeGEE8jMzKRnz5707t2bNWvWNOpYH374IT/60Y8AOOuss3j//fcBOPjggzn33HP5+9//XpnIOfDAA/ntb3/L7bffztKlS+nQoUNLH6qIJJF41+BJAzqYWSnQEVgZ53hEdjQHu/tKM+sNvGFm8xq7obvfD9wPMG7cOG+tAEVERJKErmtbWzNa2rSW7Ozsyr9vuOEGjjjiCJ599lmWLFnC+PHja90mMzOz8u/U1FTKysqadWwzA4LWOh999BEvv/wyo0eP5vPPP+dHP/oR+++/Py+//DLHHHMMDzzwAEceeWSzjiMiySduLXjcfQXwR2AZsArY4u7Taq6nVgIircfdV4b3a4Fngf2ANWbWFyC8Xxu/CEVERBJfY65rdU3bfm3ZsoX+/fsD8NBDD8V8/wcddBBPPPEEAP/85z855JBDAPjuu+/Yf//9ufnmm+nZsyfLly9n0aJFDB06lMsuu4yTTz6ZL7/8MubxiEjiimcXrW4EtT6GAP2AbDM7s+Z67n6/u49z93G9evVq6zBF2i0zyzaznMjfwERgDvACcE642jnA8/GJUEREJDk05rpW17Tt1y9/+UumTJnCwQcfHJOaNyNHjmTAgAEMGDCAn//859x9991MnTqVkSNH8uijj3LXXXcBcPXVV7P33nszYsQIDjvsMEaNGsWTTz7JiBEjGD16NPPmzePss89ucTwikjzMPT49K8zsB8Cx7n5BOH02cIC7/29d24wbN85nzZrVViGK1MvMZkeNPJV0zGwoQasdCJqV/8vdf2NmPYCngEEEv0T+wN031rcvnZuSSJL93IwlnZuSSNrzudnU61qdm433zTffsOeee8Y7jHaltue0PZ+fTaFzUxJNU8/NeNbgWQYcYGYdgW3ABEBnk0gbcfdFwKha5m8gOB9F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iIiIJBozGwCcAPwG+Hk4+xRgfPj3w8AM4Jq2jk1Eatfk61oleEREJMbi2UVLREREancn8Esgug9HH3dfBRDe945DXCISM0rwiIhIbCVVgsf1QSgiIu2cmZ0IrHX32c3cvnKknnXr1sU4OhGJFY2iJSIisZZUCR4REZEdwMHAyWa2BHgCONLMHgPWmFlfgPB+bW0bR4/U06tXr7aKWUSaSgkeERGJMSV4REREEoi7T3H3Ae4+mGAknrfc/UyCEXnOCVc7B3g+TiGKSEwowSMiIrGlBI+IiEhyuA042swWAEeH0yKSpNRFS0REYi2uo2iJiIhI3dx9BsFoWbj7BmBCPOMRkVhSgkdERGJLLXhERERERNqYqQWPiIjEmBI8IiIiIiJtTF20REQk1pTgERERERFpc0rwiIhIbCnBIyIiIiLS1tSCR0REYkwJHhERERGRNqYuWiIiEmtK8IiIiIiItDkleEREJLaU4BERERERaWNqwSMiIrGWVAkefQyKiIiISHtgXhHvEEREpJ1JqgRPaZk+CEVERESkPdBPlyIiEltJleAxs3iHICIiIiLScuqiJSIiMZYW7wCaosKdwZNf5tBhPTl+777s2rsTQ3pm07NTZrxDExERERFptA6L3+DjV/uT3m0AHXoMpHvv/vTM6UBKin7QFGkMMzsWuAtIBR5w99tqLP8xcE04uRX4qbt/0bZRirStpErwRLy3YD3vLVi/3fwlt50Qh2hERERERBqvMK0rI4o+JeWj2ZXzSj2V1XRjzc4nMua8O0Et10XqZGapwL3A0UAu8ImZveDuX0etthg43N03mdlxwP3A/m0frUjbSaoEz979u/D3/z2I1+euYXCPjny9Ko9HPlxauXzh2q3s2rtTHCMUEREREalfx95DKPz562xcPo+iDcsp3byCii0rSV05mzHLHuKr949i70NPineYIolsP2Chuy8CMLMngFOAygSPu/83av2ZwIA2jVAkDpIqwQMwZlA3xgzqVjl98ykj+NHfZ/Lf7zbwg/v+y2e/mhjH6EREREREGtapSw86dTm42rySokLybxtKwewnQAkekfr0B5ZHTedSf+ucC4BXa1tgZhcBFwEMGjQoVvGJxEVSFVmuy2MXBOfypsLSOEciIiIiItI8GVkdWdhpX3be/FG8QxFJdLX1Yay1crmZHUGQ4LmmtuXufr+7j3P3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\n",
      "text/plain": [
       "<Figure size 1152x288 with 5 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-97-ccc841c8644e>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m    130\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    131\u001b[0m             \u001b[0mdisplay\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfig\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 132\u001b[0;31m         \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[0m\u001b[1;32m    133\u001b[0m         \u001b[0mloss_store\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0ml\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    134\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   1178\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mfinal_fetches\u001b[0m \u001b[0;32mor\u001b[0m \u001b[0mfinal_targets\u001b[0m \u001b[0;32mor\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mhandle\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0mfeed_dict_tensor\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   1179\u001b[0m       results = self._do_run(handle, final_targets, final_fetches,\n\u001b[0;32m-> 1180\u001b[0;31m                              feed_dict_tensor, options, run_metadata)\n\u001b[0m\u001b[1;32m   1181\u001b[0m     \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1182\u001b[0m       \u001b[0mresults\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;36m_do_run\u001b[0;34m(self, handle, target_list, fetch_list, feed_dict, options, run_metadata)\u001b[0m\n\u001b[1;32m   1357\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mhandle\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1358\u001b[0m       return self._do_call(_run_fn, feeds, fetches, targets, options,\n\u001b[0;32m-> 1359\u001b[0;31m                            run_metadata)\n\u001b[0m\u001b[1;32m   1360\u001b[0m     \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1361\u001b[0m       \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_do_call\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0m_prun_fn\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mhandle\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfeeds\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/disk_c/akash/anaconda/envs/iclr/lib/python3.7/site-packages/tensorflow_core/python/client/session.py\u001b[0m in \u001b[0;36m_do_call\u001b[0;34m(self, fn, *args)\u001b[0m\n\u001b[1;32m   1363\u001b[0m   \u001b[0;32mdef\u001b[0m \u001b[0m_do_call\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfn\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\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   1364\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[0;32m-> 1365\u001b[0;31m       \u001b[0;32mreturn\u001b[0m \u001b[0mfn\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\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   1366\u001b[0m     \u001b[0;32mexcept\u001b[0m \u001b[0merrors\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mOpError\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   1367\u001b[0m       \u001b[0mmessage\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mcompat\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mas_text\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0me\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmessage\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_fn\u001b[0;34m(feed_dict, fetch_list, target_list, options, run_metadata)\u001b[0m\n\u001b[1;32m   1348\u001b[0m       \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_extend_graph\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   1349\u001b[0m       return self._call_tf_sessionrun(options, feed_dict, fetch_list,\n\u001b[0;32m-> 1350\u001b[0;31m                                       target_list, run_metadata)\n\u001b[0m\u001b[1;32m   1351\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1352\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_prun_fn\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mhandle\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfeed_dict\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfetch_list\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;36m_call_tf_sessionrun\u001b[0;34m(self, options, feed_dict, fetch_list, target_list, run_metadata)\u001b[0m\n\u001b[1;32m   1441\u001b[0m     return tf_session.TF_SessionRun_wrapper(self._session, options, feed_dict,\n\u001b[1;32m   1442\u001b[0m                                             \u001b[0mfetch_list\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtarget_list\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1443\u001b[0;31m                                             run_metadata)\n\u001b[0m\u001b[1;32m   1444\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1445\u001b[0m   \u001b[0;32mdef\u001b[0m \u001b[0m_call_tf_sessionprun\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mhandle\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfeed_dict\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfetch_list\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    },
    {
     "data": {
      "image/png": "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LTomjMOAVKACr+2xr9s+5nqV9oD8XWocN7irM+Z6bMvbg8c2joPjr45JkkcJHhGRBOXunHrqqZxzzjn861//AmDp0qW88MIL3HvvvQAsWbKEE088kc8//7xJ++7QoUPlNueccw733nsv1113Xcxiv+GGG1i1ahVz5swhMzOTNWvW8M477zS43dtvv03Pnj2ZP38+EydOVIJHkkIsz9WSkhK+//3vM3bsWG688cZ6173yyisrk7dPPvkkRx55JF999VXll8/a3HvvvQwfPpwXX3yRdevWsfvuu/PjH/+Y1NRULrnkEt544w0GDBjAvvvuy8knn7xdwujVV19lwYIFLFiwgI8++oif/vSnfPTRRw09RSJJq0ePHpXnbV0/mtRnxowZdOrUqdYEj7Sq/sDyqOnccN52CR4zuwi4CGDQoEG17uz179KgpCNBsqCuZEDDSZDG8UhkzdiuMdtE0ksWblNfYsNr3NfcvzcwXR+HsjSClETN2GPxXEZSHZHUWF37bUrMjdGM168sgxlL+sXk6KrBIyKSoN566y0yMjK4+OKLK+ftvPPO/OxnP4vpcQ488EBWrFix3fxrrrmGv/71r5XTN910E3/6059YtWoVhx12GKNHj2bEiBG899571bYrLCzk73//O3/5y1/IzMwEoE+fPpx++ukAPP744+y9996MGDGCa665ptaY8vLy6NatW6weokiritW5WlZWxqRJkxg2bBi33XZbk7b94Q9/yMSJEysTTHUxM/Lz83F3tm7dSvfu3UlLS+Pjjz9m1113ZejQoWRkZDBp0iSef/757bZ//vnnOfvsszEzDjjgADZv3syqVc36QVwkac2ePZvDDz+csWPHcswxx1SeA3fffTfDhw9n5MiRTJo0iSVLlnDfffdxxx13MHr06O0+L+vy5z//mREjRjBixAjuvPNOAAoKCjjhhBMYNWoUI0aM4MknnwRg8uTJlcdsSuJpB1Dbt+tav8m7+/3uPs7dx9WVID9mlzLIKKT+hEis6htZM/fV2G1SqGrZ0lA6wGrcGlrelPSCQVoZQZOcmvuOxXNZRpDYiY6rrscQS814/dJKGD94ZUyOrhY8IiKxNG0azJgB48fDxIkt2tXcuXNbvetDeXk506dP54ILLthu2aRJk7jiiiv43//9XwCeeuopXnvtNf71r39xzDHHcN1111FeXk5hYWG17RYuXMigQYPo3LnzdvtcuXIl11xzDbNnz6Zbt25MnDiR5557jlNPPRWAI444Andn0aJFPPXUU7F/wNLu/frFuXy9Mi+m+xzerzM3nrRXnctjda7+/ve/56ijjqr8QtdU++yzD/PmzQPgV7/6FePGjePkk0+uts6ll17KySefTL9+/cjPz+fJJ58kJSWFFStWMHDgwMr1BgwYUGvLnNrWW7FiBX379m1WzCJNEY/zuyZ352c/+xnPP/88vXr14sknn+S6667jwQcf5LbbbmPx4sVkZmayefNmunbtysUXX9ykVj+zZ89m6tSpfPTRR7g7+++/P4cffjiLFi2iX79+vPzyy0DQ3XLjxo08++yzzJs3DzNj8+bNzXkK2qtcYGDU9ACg2d+gb/jPPaAaPKrBoxo8IiI7kGnT4MwzobgYHngAHnusxUmeaJdccgnvv/8+GRkZfPLJJy3a17Zt2xg9ejRLlixh7NixHH300dutM2bMGNauXcvKlStZt24d3bp1Y9CgQey7776cf/75lJaWcuqppzJ69OhGH/eTTz5h/PjxlV1IfvzjH/Puu+9WJngiXbS+++47JkyYwPjx4+nUqVOLHqtIW2vuuXrIIYfw4Ycf8u2337Lbbrs1+bhBqYnAzTffXOs6r7/+OqNHj+att97iu+++4+ijj+bQQw+ttm1EbaPtNHY9kfaquLiYOXPmVH5ulpeXVyY4R44cyY9//GNOPfXUys+1pnr//ff5n//5H7KzswH43ve+x3vvvcexxx7LVVddxTXXXMOJJ57IoYceSllZGVlZWVx44YWccMIJnHjiiTF5jO3EC8ClZvYEQXHlLc2tvxNxw3/u4YZal4xu5B4GNrB8SFPCaYSa++sDHB7jYzRXPxr/vDVF9HPcWt38exHU7o6VvYDYfV9QgkdEJFZmzAiSO9nZUFAQTLcgwbPXXnvxzDPPVE7fe++9rF+/nnHjxrU41EgNni1btnDiiSdy7733ctlll2233mmnncbTTz/N6tWrmTRpEgCHHXYY7777Li+//DJnnXUWV199NWeffXblNrvuuivLli0jPz+fnJycavur7cthbXbZZRf69OnD119/zX777deCR5q4zOxB4ERgrbuPCOf9ATgJKAG+A85z983hsinABQQ1/C5z99fjEXeia8ov8bESq3P1sMMO45xzzuG4447jvffeo1+/pvXH/+yzzxo85tSpU5k8eTJmxq677sqQIUOYN28eAwYMYPnyqnIVubm5tR6/seuJtIZ4nN81uTt77bUXH3744XbLXn75Zd59911eeOEFbrnlFubOndus/ddmt912Y/bs2bzyyitMmTKFiRMn8qtf/YqPP/6Y6dOn88QTT3DPPffw1ltvNfmYycjMHgfGAz3NLBe4EUgHcPf7gFeA44GFQCFwXnwiFWlbqsEjIhIr48dDZmaQ3MnMDKZb4Mgjj6SoqIi//e1vlfNqdodqqS5dunD33Xfzxz/+kdLS7cdlmDRpEk888QRPP/105Yg/S5cupXfv3vy///f/uOCCC/j000+rbdOxY0cuuOACLrvsMkpKSgBYtWoVjz32GPvvvz/vvPMO69evp7y8nMcff5zDD9/+16S1a9eyePFidt555+2WtSMPAcfWmPcGMMLdRwLfAlMAzGw4MIngZ55jgb+aWWrbhSr1ieW5+v3vf5+rr76aY489tkndLZ555hmmTZvGGWecUe96gwYNYvr06UAw8tf8+fMZOnQo++67LwsWLGDx4sWUlJTwxBNPbNe9C+Dkk0/mkUcewd2ZOXMmXbp0Ufcs2aFkZmaybt26ygRPaWkpc+fOpaKiguXLl3PEEUfw+9//ns2bN7N161ZycnLIz89v9P4PO+wwnnvuOQoLCykoKODZZ5/l0EMPZeXKlXTs2JEzzzyTq666ik8//ZStW7eyZcsWjj/+eO68884mD7iQzNz9DHfv6+7p7j7A3f/h7veFyR08cIm77+Lue7v7rHjHLNIW1IJHRCRWJk4MumXFqAaPmfHcc89x5ZVX8vvf/55evXqRnZ3N7bff3qT93HrrrdVqeuTm5lZbPmbMGEaNGsUTTzzBWWedVW3ZXnvtRX5+Pv3796/8Ejdjxgz+8Ic/kJ6eTqdOnXjkkUdqPeb111/P8OHDycrKIjs7m5tvvpm+ffvyu9/9rrLWzvHHH19tpKwjjjiC1NRUSktLue222+jTp0+THmsyqW2IV3efFjU5E4iMo30K8IS7FwOLzWwhsB+w/U/I0uZida5GXHzxxaxevZqTTz6ZadOmUVhYyIABAyqX//znPwfgjjvu4LHHHqOgoIARI0bw1ltvVXZ/rKsGzw033MC5557L3nvvjbtz++2307NnTwDuuecejjnmGMrLyzn//PPZa6+gtcR9991XGdfxxx/PK6+8wq677krHjh2ZOnVqsx6jSLJKSUnh6aef5rLLLmPLli2UlZVxxRVXsNtuu3HmmWeyZcsW3J0rr7ySrl27ctJJJ3Haaafx/PPP85e//IVDDz202v4eeughnnvuucrpmTNncu6551a2Xr3wwgsZM2YMr7/+OldffTUpKSmkp6fzt7/9jfz8fE455RSKiopwd+644462fCpEJAFZY5vLJ4Jx48b5rFlKvkpiMLPZ7t7yvjLtQHs9N7/55hv23HPPeIch9ajtNUqmczNM8LwU6aJVY9mLwJPu/piZ3QPMdPfHwmX/AF5196dr2S56uNexS5cubc2HkBB0riaeZD83W1t7/dxsDTq/Y0/nZ910bkqiaeq5qS5aIiIiCcbMriMY3/OfkVm1rNbs4V5FREREpP1RFy0REZEEYmbnEBRfnuBVzWxjOtyriIiIiLQ/asEjIlKPZOrGuqNpj6+NmR0LXAOc7O7RVXpfACaZWaaZDSEYn/PjeMSYqNrj+yFZ6bUQERGJDyV4RETqkJWVxYYNG/RlJQG5Oxs2bCArKyveoTRbOMTrh8DuZpZrZhcA9wA5wBtm9rmZRUYDmQs8BXwNvAZc4u7lcQo94ehcTRzt4dwUERFJVuqiJSJShwEDBpCbm8u6deviHYrUIisrq9rIQsnG3Wsbz/of9az/G+A3rRdR8tK5mliS/dwUERFJVkrwiIjUIT09nSFDhsQ7DBFpgM5VEREREXXREhERERERqdWGDRsYPXo0o0ePZqeddqJ///6V0yUlJfVuO2vWLC677LImHW/w4MGsX7++JSGLyA5MLXhEdmBmtgTIB8qBMncfZ2bdgSeBwcAS4HR33xSvGEVERETipUePHnz++ecA3HTTTXTq1ImrrrqqcnlZWRlpabV/pRo3bhzjxo1rizBFRAC14BEROMLdR7t75ApkMjDd3YcB08NpEREREQHOPfdcfv7zn3PEEUdwzTXX8PHHH3PQQQcxZswYDjroIObPnw/AjBkzOPHEE4EgOXT++eczfvx4hg4dyt13393o4y1dupQJEyYwcuRIJkyYwLJlywD497//zYgRIxg1ahSHHXYYAHPnzmW//fZj9OjRjBw5kgULFsT40YtIIotrCx4zuxK4EHDgK+A8dy+KZ0wiwinA+PDvh4EZBMM2i4iISB10XdsGXp0Mq7+K7T532huOu63Jm3377be8+eabpKamkpeXx7vvvktaWhpvvvkm1157Lc8888x228ybN4+3336b/Px8dt99d37605+Snp7e4LEuvfRSzj77bM455xwefPBBLrvsMp577jluvvlmXn/9dfr378/mzZsBuO+++7j88sv58Y9/TElJCeXlGnBRZEcStxY8ZtYfuAwY5+4jgFRgUrziEdlBOTDNzGab2UXhvD7uvgogvO9d24ZmdpGZzTKzWRq5RkREdmS6rt3x/OAHPyA1NRWALVu28IMf/IARI0Zw5ZVXMnfu3Fq3OeGEE8jMzKRnz5707t2bNWvWNOpYH374IT/60Y8AOOuss3j//fcBOPjggzn33HP5+9//XpnIOfDAA/ntb3/L7bffztKlS+nQoUNLH6qIJJF41+BJAzqYWSnQEVgZ53hEdjQHu/tKM+sNvGFm8xq7obvfD9wPMG7cOG+tAEVERJKErmtbWzNa2rSW7Ozsyr9vuOEGjjjiCJ599lmWLFnC+PHja90mMzOz8u/U1FTKysqadWwzA4LWOh999BEvv/wyo0eP5vPPP+dHP/oR+++/Py+//DLHHHMMDzzwAEceeWSzjiMiySduLXjcfQXwR2AZsArY4u7Taq6nVgIircfdV4b3a4Fngf2ANWbWFyC8Xxu/CEVERBJfY65rdU3bfm3ZsoX+/fsD8NBDD8V8/wcddBBPPPEEAP/85z855JBDAPjuu+/Yf//9ufnmm+nZsyfLly9n0aJFDB06lMsuu4yTTz6ZL7/8MubxiEjiimcXrW4EtT6GAP2AbDM7s+Z67n6/u49z93G9evVq6zBF2i0zyzaznMjfwERgDvACcE642jnA8/GJUEREJDk05rpW17Tt1y9/+UumTJnCwQcfHJOaNyNHjmTAgAEMGDCAn//859x9991MnTqVkSNH8uijj3LXXXcBcPXVV7P33nszYsQIDjvsMEaNGsWTTz7JiBEjGD16NPPmzePss89ucTwikjzMPT49K8zsB8Cx7n5BOH02cIC7/29d24wbN85nzZrVViGK1MvMZkeNPJV0zGwoQasdCJqV/8vdf2NmPYCngEEEv0T+wN031rcvnZuSSJL93IwlnZuSSNrzudnU61qdm433zTffsOeee8Y7jHaltue0PZ+fTaFzUxJNU8/NeNbgWQYcYGYdgW3ABEBnk0gbcfdFwKha5m8gOB9F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iIiIJBozGwCcAPwG+Hk4+xRgfPj3w8AM4Jq2jk1Eatfk61oleEREJMbi2UVLREREancn8Esgug9HH3dfBRDe945DXCISM0rwiIhIbCVVgsf1QSgiIu2cmZ0IrHX32c3cvnKknnXr1sU4OhGJFY2iJSIisZZUCR4REZEdwMHAyWa2BHgCONLMHgPWmFlfgPB+bW0bR4/U06tXr7aKWUSaSgkeERGJMSV4REREEoi7T3H3Ae4+mGAknrfc/UyCEXnOCVc7B3g+TiGKSEwowSMiIrGlBI+IiEhyuA042swWAEeH0yKSpNRFS0REYi2uo2iJiIhI3dx9BsFoWbj7BmBCPOMRkVhSgkdERGJLLXhERERERNqYqQWPiIjEmBI8IiIiIiJtTF20REQk1pTgERERERFpc0rwiIhIbCnBIyIiIiLS1tSCR0REYkwJHhERERGRNqYuWiIiEmtK8IiIiIiItDkleEREJLaU4BERERERaWNqwSMiIrGWVAkefQyKiIiISHtgXhHvEEREpJ1JqgRPaZk+CEVERESkPdBPlyIiEltJleAxs3iHICIiIiLScuqiJSIiMZYW7wCaosKdwZNf5tBhPTl+777s2rsTQ3pm07NTZrxDExERERFptA6L3+DjV/uT3m0AHXoMpHvv/vTM6UBKin7QFGkMMzsWuAtIBR5w99tqLP8xcE04uRX4qbt/0bZRirStpErwRLy3YD3vLVi/3fwlt50Qh2hERERERBqvMK0rI4o+JeWj2ZXzSj2V1XRjzc4nMua8O0Et10XqZGapwL3A0UAu8ImZveDuX0etthg43N03mdlxwP3A/m0frUjbSaoEz979u/D3/z2I1+euYXCPjny9Ko9HPlxauXzh2q3s2rtTHCMUEREREalfx95DKPz562xcPo+iDcsp3byCii0rSV05mzHLHuKr949i70NPineYIolsP2Chuy8CMLMngFOAygSPu/83av2ZwIA2jVAkDpIqwQMwZlA3xgzqVjl98ykj+NHfZ/Lf7zbwg/v+y2e/mhjH6EREREREGtapSw86dTm42rySokLybxtKwewnQAkekfr0B5ZHTedSf+ucC4BXa1tgZhcBFwEMGjQoVvGJxEVSFVmuy2MXBOfypsLSOEciIiIiItI8GVkdWdhpX3be/FG8QxFJdLX1Yay1crmZHUGQ4LmmtuXufr+7j3P3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\n",
      "text/plain": [
       "<Figure size 1152x288 with 5 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "p_samples = tf.placeholder(tf.float32, shape=[None,n_dims])\n",
    "q_samples = tf.placeholder(tf.float32, shape=[None,n_dims])\n",
    "m_samples = tf.placeholder(tf.float32, shape=[None,n_dims])\n",
    "\n",
    "dloss = get_loss(p_samples, q_samples, m_samples, None, deep=deep)\n",
    "optim = get_optim(dloss,lr=1e-4)#,lr=5e-3,b1=.99\n",
    "\n",
    "log_ratio_p_q, _ = get_gt_ratio_kl(p,q,p_samples)\n",
    "_, kl_from_pq = get_gt_ratio_kl(p,q,p_samples)\n",
    "kl_from_cob = get_kl_from_cob(p_samples, q_samples)\n",
    "\n",
    "log_ratio_p_m = get_log_ratio(p_samples) #tf.nn.softmax(get_logits(p_samples,deep=deep, training=False))\n",
    "# logit_q = get_logits(q_samples,deep=deep, training=False)\n",
    "# logit_m = get_logits(m_samples,deep=deep, training=False)\n",
    "\n",
    "init = tf.global_variables_initializer()\n",
    "sess = tf.Session()\n",
    "sess.run(init)\n",
    "[kl_gt] = sess.run([p.kl_divergence(q)],feed_dict={})\n",
    "\n",
    "fig, [ax1,ax2,ax3,ax4,ax5] = plt.subplots(1, 5,figsize=(16,4))\n",
    "\n",
    "line, = ax1.plot([0,1],[0,1])\n",
    "test_line, = ax4.plot([0,1],[0,1],label='Test Loss')\n",
    "test_line1, = ax4.plot([0,1],[0,1],label='Train Loss')\n",
    "kld_line, = ax3.plot([0],[0],label='GT KLD: '+str(kl_gt))\n",
    "x, y = np.random.random((2, 500))\n",
    "np.random.randint\n",
    "scat = ax2.scatter(x,y,label='GT LR vs CoB ',alpha=0.9,s=10.,c='r')\n",
    "\n",
    "scat_p = ax5.scatter(range(bs),np.random.randint(0,2,bs),label='P',alpha=0.9,s=10.,c='r')\n",
    "scat_q = ax5.scatter(range(bs),np.random.randint(0,2,bs),label='Q',alpha=0.6,s=10.,c='g')\n",
    "scat_m = ax5.scatter(range(bs),np.random.randint(0,2,bs),label='M',alpha=0.4,s=10.,c='b')\n",
    "\n",
    "ax1.set_xlabel(\"Iteration\")\n",
    "ax1.set_ylabel(\"Train Loss\")\n",
    "ax1.set_xlim([0,N*(num_samples//bs)])\n",
    "ax1.set_ylim([-5,10])\n",
    "\n",
    "ax2.set_xlabel(\"Log Ratio\")\n",
    "ax2.set_ylabel(\"Log Ratio CoB\")\n",
    "ax2.legend(loc='best')\n",
    "\n",
    "ax3.set_ylabel(\"KLD\")\n",
    "ax3.legend(loc='best')\n",
    "\n",
    "ax4.set_xlabel(\"Iteration\")\n",
    "ax4.set_ylabel(\"Test Loss\")\n",
    "ax4.set_xlim([0,N//50])\n",
    "ax4.set_ylim([-5,10])\n",
    "ax4.legend(loc='best')\n",
    "\n",
    "ax5.set_xlabel(\"Class\")\n",
    "ax5.set_ylabel(\"Samples\")\n",
    "ax5.legend(loc='best')\n",
    "\n",
    "\n",
    "plt.tight_layout()\n",
    "loss_store=[]\n",
    "test_loss_store=[]\n",
    "test_loss_store1=[]\n",
    "kld_store=[]\n",
    "pbar = range(0,N)\n",
    "for j in pbar:\n",
    "    for i in range(num_samples//bs):\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",
    "        \n",
    "        [l] = sess.run([dloss],feed_dict=feed_dict)\n",
    "        loss_store.append(l)\n",
    "        \n",
    "        if i%100==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, lpq, lpqm, kl_cob = sess.run([dloss, log_ratio_p_q, log_ratio_p_m, kl_from_cob],feed_dict=feed_dict)\n",
    "            kld_store.append(kl_cob)\n",
    "            test_loss_store.append(testl)\n",
    "            test_loss_store1.append(l)\n",
    "#             cob = np.log([max(1e-10,n_[0]/n_[1]) for n_ in lpqm])\n",
    "        \n",
    "            cob=np.squeeze(lpqm)\n",
    "            scat.set_offsets(np.asarray([lpq,cob]).T)\n",
    "            ax2.set_xlim( lpq.min(), lpq.max() )\n",
    "#             ax2.set_ylim( lpq.min()-30, lpq.max()+10 )\n",
    "            ax2.set_ylim( cob.min(), cob.max()+10 )\n",
    "\n",
    "            kld_line.set_data(range(len(kld_store)),kld_store)\n",
    "            ax3.set_xlim( 0, len(kld_store) )\n",
    "            ax3.set_ylim( 0, kl_gt+50 )\n",
    "#             ax3.set_ylim( 0, min(max(kld_store),500) )\n",
    "            \n",
    "            test_line1.set_data(range(len(test_loss_store1)), test_loss_store1)\n",
    "            test_line.set_data(range(len(test_loss_store)), test_loss_store)\n",
    "            ax4.set_xlim( 0, len(test_loss_store) )\n",
    "            \n",
    "            \n",
    "            \n",
    "#             scat_p.set_offsets(np.asarray([range(bs),lpqm[:,0]]).T)\n",
    "#             scat_q.set_offsets(np.asarray([range(bs),softmax(l_q, axis=1)[:,1]]).T)\n",
    "#             scat_m.set_offsets(np.asarray([range(bs),softmax(l_m, axis=1)[:,2]]).T)\n",
    "            \n",
    "             \n",
    "            \n",
    "            clear_output(wait=True)\n",
    "            \n",
    "            print(cob.min())\n",
    "            \n",
    "#             sp = np.mean(lpqm[:,0])\n",
    "#             sq = np.mean(softmax(l_q, axis=1)[:,1])\n",
    "#             sm = np.mean(softmax(l_m, axis=1)[:,2])\n",
    "#             print(sp)\n",
    "#             print(sq)\n",
    "#             print(sm)\n",
    "            \n",
    "#             print(np.mean(np.exp(lpqm[:,0])))\n",
    "#             print(np.mean(np.exp(l_q[:,1])))\n",
    "#             print(np.mean(np.exp(l_m[:,2])))\n",
    "            \n",
    "#             if ( sp>0.99 and sq > 0.99 and sm>0.99 ):\n",
    "#                 sys.exit(0)\n",
    "                                                                                \n",
    "            \n",
    "            display(fig)\n",
    "        l,_ = sess.run([dloss, optim],feed_dict=feed_dict)\n",
    "        loss_store.append(l)\n",
    "\n",
    "\n",
    "# sample_and_plot(sess, kld, kl_from_pq, kl_from_cob, 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)\n",
    "\n",
    "\n",
    "\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.mean(kld_store[:])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "7.0587945"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.std(kld_store[-5:])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "def kl(m1, s1, m2, s2):\n",
    "    return np.log(s2)-np.log(s1)+(s1**2 + (m1-m2)**2)/(2*s2**2)-1/2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 122,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[-2.4978073,\n",
       " -2.4948757,\n",
       " -2.4917202,\n",
       " -2.498714,\n",
       " -2.4976697,\n",
       " -2.4987798,\n",
       " -2.4978113,\n",
       " -2.4975638,\n",
       " -2.4982789,\n",
       " -2.498995]"
      ]
     },
     "execution_count": 122,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_loss_store1[-10:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 119,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[1.6952966,\n",
       " 1.7798133,\n",
       " 6.550874,\n",
       " 10.017588,\n",
       " 12.17298,\n",
       " 14.352085,\n",
       " 16.17169,\n",
       " 18.041306,\n",
       " 17.702417,\n",
       " 19.946114,\n",
       " 20.63465,\n",
       " 20.95625,\n",
       " 20.54527,\n",
       " 21.880987,\n",
       " 24.040455,\n",
       " 24.780142,\n",
       " 24.890266,\n",
       " 25.527515,\n",
       " 26.07804,\n",
       " 27.07059,\n",
       " 26.679907,\n",
       " 27.299023,\n",
       " 26.557703,\n",
       " 27.433714,\n",
       " 28.051172,\n",
       " 28.561237,\n",
       " 28.262453,\n",
       " 30.629555,\n",
       " 29.070976,\n",
       " 31.974966,\n",
       " 29.31949,\n",
       " 32.383125,\n",
       " 31.212034,\n",
       " 33.517124,\n",
       " 33.771133,\n",
       " 33.55163,\n",
       " 33.708916,\n",
       " 35.198025,\n",
       " 34.98715,\n",
       " 34.456306,\n",
       " 36.69805,\n",
       " 36.828804,\n",
       " 36.502346,\n",
       " 35.674973,\n",
       " 35.432655,\n",
       " 36.853493,\n",
       " 39.247417,\n",
       " 35.482506,\n",
       " 42.147312,\n",
       " 39.38999,\n",
       " 37.164726,\n",
       " 38.53191,\n",
       " 41.551212,\n",
       " 37.21286,\n",
       " 39.971954,\n",
       " 40.222137,\n",
       " 44.02921,\n",
       " 41.79677,\n",
       " 38.419277,\n",
       " 40.47752,\n",
       " 46.408363,\n",
       " 45.1106,\n",
       " 45.12582,\n",
       " 41.578804,\n",
       " 46.832912,\n",
       " 42.55866,\n",
       " 45.49365,\n",
       " 45.438564,\n",
       " 45.075054,\n",
       " 45.43744,\n",
       " 48.52367,\n",
       " 45.402897,\n",
       " 44.995495,\n",
       " 45.400127,\n",
       " 44.754967,\n",
       " 47.406265,\n",
       " 45.208843,\n",
       " 47.779858,\n",
       " 44.411766,\n",
       " 49.34396,\n",
       " inf,\n",
       " 46.994503,\n",
       " 45.40825,\n",
       " 49.55635,\n",
       " 48.201313,\n",
       " 50.285374,\n",
       " 48.02398,\n",
       " 45.142174,\n",
       " 52.264683,\n",
       " inf,\n",
       " 51.5625,\n",
       " 49.45244,\n",
       " 52.03036,\n",
       " 48.161186,\n",
       " inf,\n",
       " inf,\n",
       " 51.61807,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " 55.353546,\n",
       " 52.513733,\n",
       " inf,\n",
       " 55.52051,\n",
       " inf,\n",
       " inf,\n",
       " 51.79153,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf,\n",
       " inf]"
      ]
     },
     "execution_count": 119,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(kld_store)"
   ]
  },
  {
   "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
}
