{
 "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",
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "\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",
    "\n",
    "print(tf.__version__)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "id": "boCNTMt4BEiY"
   },
   "outputs": [],
   "source": [
    "tol = 1e-35\n",
    "bs = 500\n",
    "K = 3\n",
    "do = 0.8\n",
    "\n",
    "def ratios_critic(x, prob = 1, reuse=False):\n",
    "    with tf.variable_scope('critic', reuse=tf.AUTO_REUSE) as scope:\n",
    "#       if reuse:\n",
    "#         scope.reuse_variables()\n",
    "      x = tf.expand_dims(x,1)\n",
    "      h = slim.fully_connected(x, 100, activation_fn=tf.nn.softplus)\n",
    "      h = tf.nn.dropout(h,prob)\n",
    "      h = slim.fully_connected(h, 50, activation_fn=tf.nn.softplus)\n",
    "      h = tf.nn.dropout(h,prob)\n",
    "      log_d = slim.fully_connected(h, K, activation_fn=None)\n",
    "    return tf.squeeze(log_d)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "id": "lt5Ozzo0HrUj"
   },
   "outputs": [],
   "source": [
    "tf.reset_default_graph()\n",
    "tf.random.set_random_seed(40)\n",
    "\n",
    "mu_1 = 0.\n",
    "mu_2 = 4.\n",
    "mu_3 = 4.\n",
    "lam = tf.placeholder('float',1)\n",
    "p = tfd.Normal(loc=mu_1, scale=.1)\n",
    "q = tfd.Normal(loc=mu_2, scale=.1)\n",
    "base = tfp.distributions.Cauchy(loc=mu_3, scale=2.)\n",
    "\n",
    "\n",
    "samples = base.sample([bs]) \n",
    "p_samples = p.sample([bs]) \n",
    "q_samples = q.sample([bs])\n",
    "m_samples = samples\n",
    "# m_samples = samples + (p_samples+q_samples)/2.\n",
    "m_samples2 = m_samples# samples[bs:]\n",
    "\n",
    "#Ratio by log of prob evaluated at samples from base\n",
    "log_ratio_p_q = p.log_prob(m_samples) - q.log_prob(m_samples)\n",
    "#KL from CoB\n",
    "kld = tf.reduce_mean(log_ratio_p_q) \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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 <ipython-input-5-6cde502d42a9>:12: calling dropout (from tensorflow.python.ops.nn_ops) with keep_prob is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "Please use `rate` instead of `keep_prob`. Rate should be set to `rate = 1 - keep_prob`.\n",
      "WARNING:tensorflow:From <ipython-input-7-cf3d2f4d781a>:23: 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"
     ]
    }
   ],
   "source": [
    "# Build 2 Discriminator Networks (one from noise input, one from generated samples)\n",
    "\n",
    "disc_real = ratios_critic(p_samples,do, reuse=True)\n",
    "disc_fake = ratios_critic(q_samples, do,reuse=True)\n",
    "disc_m = ratios_critic(m_samples, do,reuse=True)\n",
    "# disc_m_gen = ratios_critic(m_samples2, do,reuse=True)\n",
    "\n",
    "# Build Loss\n",
    "# lab = np.eye(K)\n",
    "# a = np.tile(lab[0],bs)\n",
    "# b = np.tile(lab[1],bs)\n",
    "# c = np.tile(lab[2],bs)\n",
    "\n",
    "a = np.tile([1,0,0],bs)\n",
    "b = np.tile([0,1,0],bs)\n",
    "c = np.tile([0,0,1],bs)\n",
    "\n",
    "label_a = tf.reshape(a,[bs,K])\n",
    "label_b = tf.reshape(b,[bs,K])\n",
    "label_c = tf.reshape(c,[bs,K])\n",
    "\n",
    "\n",
    "disc_loss_1 = tf.reduce_mean(tf.nn.softmax_cross_entropy_with_logits(logits=disc_real, labels=label_a))\n",
    "disc_loss_2 = tf.reduce_mean(tf.nn.softmax_cross_entropy_with_logits(logits=disc_fake, labels=label_b))\n",
    "disc_loss_3 = tf.reduce_mean(tf.nn.softmax_cross_entropy_with_logits(logits=disc_m, labels=label_c))\n",
    "# disc_loss_4 = tf.reduce_mean(tf.nn.softmax_cross_entropy_with_logits(logits=disc_m_gen, labels=label_c))\n",
    "\n",
    "dloss = disc_loss_1 + disc_loss_2 + 1*disc_loss_3 #+ 0.5*disc_loss_4 \n",
    "\n",
    "# Define CoB DRE\n",
    "\n",
    "log_r_p_m = ratios_critic(m_samples, reuse=True) \n",
    "log_r_p_from_m_direct = log_r_p_m \n",
    "\n",
    "t_vars = tf.trainable_variables()\n",
    "c_vars = [var for var in t_vars if 'critic' in var.name]\n",
    "\n",
    "c_optim = tf.train.AdamOptimizer(learning_rate=0.001, beta1=0.001, beta2=0.999).minimize(dloss, var_list=t_vars)\n",
    "\n",
    "init = tf.global_variables_initializer()\n",
    "# Start a new TF session\n",
    "sess = tf.Session()\n",
    "\n",
    "# Run the initializer\n",
    "sess.run(init)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 297
    },
    "id": "c8oVgSoXEAv_",
    "outputId": "045f2573-6d7f-4e89-94a7-286b08dcf27f"
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "031242018ef342a2b0af27542f2c72a6",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(FloatProgress(value=0.0, max=30000.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7ffa5c0aa410>"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAX8AAAEGCAYAAACNaZVuAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAAAe60lEQVR4nO3deZxU5Z3v8c+vuhu6wZa1BRRIIy4ZRGkVSVyiRieJcRKNZhnJjGE08yLOjUnI3Js7mMxEzeQart44apJJgkvUjDE4xjUaFQ2R4AI0CghERLTBZm22Xui1qp77R50uGqhuqpdTp06d7/v16ldXn6o65/fU8u1Tz3nqOeacQ0REoiUWdAEiIpJ7Cn8RkQhS+IuIRJDCX0QkghT+IiIRVBx0AdkYPXq0q6ysDLoMEZFQWbFixS7nXEWm60IR/pWVlVRXVwddhohIqJjZpu6uU7ePiEgEKfxFRCJI4S8iEkGh6PMXEemvjo4OamtraW1tDbqUAVdaWsr48eMpKSnJ+j4KfxGJhNraWsrLy6msrMTMgi5nwDjn2L17N7W1tUyaNCnr+6nbR0QiobW1lVGjRhVU8AOYGaNGjer1JxqFv4hERqEFf6e+tEvhL5KHFr9Tx+bdzUGXIQVM4S+Sh75y3zLOv21R0GWID7Zv385VV13F5MmTmTJlCpdeeinvvPNOxtvW1NRQVlZGVVUV06ZN45xzzmH9+vUDUofCX0QkR5xzXHHFFVx44YVs3LiRdevWccstt7Bjx45u7zN58mRWrlzJqlWrmDVrFrfccsuA1KLwFxHJkUWLFlFSUsJ1112XXlZVVcV5553Hd77zHaZOncqpp57KggULMt6/oaGBESNGDEgtGuopIpFz89NrWbe1YUDXOeXYo7nxs6f0eJs1a9Zw5plnHrb8scceS+/d79q1i7POOovzzz8fgI0bN1JVVUVjYyPNzc0sXbp0QOrVnr+ISMCWLFnCzJkzKSoqYsyYMVxwwQUsX74cONDts3HjRu644w5mz549INvUnr+IRM6R9tD9csopp/Doo48ettw5l9X9L7vsMq655poBqUV7/iIiOXLRRRfR1tbG3XffnV62fPlyRowYwYIFC0gkEtTV1bF48WJmzJhx2P2XLFnC5MmTB6QW7fmLiOSImfH4448zZ84c5s2bR2lpKZWVldxxxx00NTUxbdo0zIxbb72VsWPHUlNTk+7zd84xaNAg7rnnngGpReEvIpJDxx57LI888shhy2+77TZuu+22g5ZVVlbS0tLiSx3q9hERiSCFv4hIBCn8RSQysh1VEzZ9aZfCX0QiobS0lN27dxfcP4DO+fxLS0t7dT/fDvia2QTgQWAskATmO+fuNLORwAKgEqgBvuSc2+tXHSIiAOPHj6e2tpa6urqgSxlwnWfy6g0/R/vEgf/pnHvDzMqBFWa2EPgH4CXn3DwzmwvMBf7FxzpERCgpKenVma4KnW/dPs65bc65N7zLjcBfgOOAy4EHvJs9AHzOrxpERCSznPT5m1klcDqwFBjjnNsGqX8QwDG5qEFERA7wPfzN7Cjgd8Ac51zW0+iZ2Wwzqzaz6kLsoxMRCZKv4W9mJaSC/yHn3GPe4h1mNs67fhywM9N9nXPznXPTnXPTKyoq/CxTRCRyfAt/S51R+F7gL86527tc9RQwy7s8C3jSrxpERCQzP0f7nAtcDbxlZiu9Zd8F5gGPmNlXgc3AF32sQUREMvAt/J1zSwDr5uqL/dquiIgcmb7hKyISQQp/EZEIUviLiESQwl9EIqGxtYP36pqCLiNvKPxFJBK+fPdSLvrxy0GXkTcU/iISCW9tqQ+6hLyi8BcRiSCFv4hIBCn8RUQiSOEvIhJBCn8RkQhS+IuIRJDCX0QkghT+IiIRpPAXEYkghb+ISAQp/EVEIkjhLyISQQp/EZEIUviLiESQwl9EJIIU/iIiEaTwFxGJIIW/iEgEKfxFRCJI4S8iEkEKfxGRCFL4i4hEkMJfRCSCFP4iIhGk8BcRiSCFv4hIBCn8RUQiSOEvIhJBCn8RkQhS+IuIr773+FtUzn0m6DLkEAp/EfHVQ0s3B12CZOBb+JvZfWa208zWdFl2k5ltMbOV3s+lfm1fRES65+ee//3AJRmW/4dzrsr7edbH7YuISDd8C3/n3GJgj1/rFxGRvguiz/96M1vtdQuNCGD7IiKRl+vw/zkwGagCtgE/7u6GZjbbzKrNrLquri5H5UlvLK/ZQzLpgi5DRPogp+HvnNvhnEs455LA3cCMHm473zk33Tk3vaKiIndFSlaWbNjFF3/xGr9c/F7QpYhIH+Q0/M1sXJc/rwDWdHdbyW9b61sA2FjXFHAlItIXxX6t2MweBi4ERptZLXAjcKGZVQEOqAG+5tf2RUSke76Fv3NuZobF9/q1PRERyZ6+4SsiEkEKfxGRCFL4S784jfQUCSWFv/SJBV2AiPSLwl9EJIIU/iIiEaTwFxGJIIW/iEgEKfylXxwa7iMSRgp/6RMzjfcRCTOFv4hIBCn8RUQiSOEvIhJBCn8RkQhS+Ev/aLCPSCgp/KVPNNZHJNwU/iIiEaTwFxGJIIW/iEgEKfxFRCJI4S8iEkEKf+kXjfQUCSeFv4hIBGUV/mY21Mxi3uWTzOwyMyvxtzQJA433FwmnbPf8FwOlZnYc8BJwDXC/X0WJiIi/sg1/c841A1cCP3HOXQFM8a8sERHxU9bhb2ZnA38HPOMtK/anJBER8Vu24T8HuAF43Dm31syOBxb5VpWEhkb7iIRTVnvvzrmXgZcBvAO/u5xz3/SzMMlvOoujSLhlO9rnN2Z2tJkNBdYB683sO/6WJiIifsm222eKc64B+BzwLDARuNqvokRExF/Zhn+JN67/c8CTzrkO1N0rIhJa2Yb/L4EaYCiw2Mw+BDT4VZSIiPgr2wO+dwF3dVm0ycw+7k9JEibO6QOgSBhle8B3mJndbmbV3s+PSX0KkIjSaB+RcMu22+c+oBH4kvfTAPzKr6JERMRf2X5Ld7Jz7vNd/r7ZzFb6UI+IiORAtnv+LWZ2XucfZnYu0NLTHczsPjPbaWZruiwbaWYLzWyD93tE38oWEZH+yDb8rwN+ZmY1ZlYD/BT42hHucz9wySHL5gIvOedOJDU76NzsSxURkYGSVfg751Y556YBpwGnOedOBy46wn0WA3sOWXw58IB3+QFS3xuQENNYHwkbjVBL6dWZvJxzDd43fQH+uQ/bG+Oc2+ataxtwTB/WIXnAdBoXkVDrz2kcfX33m9nszqGldXV1fm5K5DDxRJJkUnuIUrj6E/59eWfsMLNxAN7vnd2u3Ln5zrnpzrnpFRUVfa1RpE9O+N4fuPq+pUGXIeKbHsPfzBrNrCHDTyNwbB+29xQwy7s8C3iyD+sQyYlX3t0ddAkivulxnL9zrryvKzazh4ELgdFmVgvcCMwDHjGzrwKbgS/2df0iItJ3vp2K0Tk3s5urLvZrm5J7GjghEk796fOXCNPcPv7Zu7896BIkAhT+InlmR2Nr0CUUNH1aTVH4i4hEkMJf+kR7TyLhpvCXflHf/8DTt6clFxT+0i/6BCASTgp/6RPt8YuEm8JfRCSCFP4ieUafqiQXFP4iEik6TJWi8BcRiSCFv0ieUa+P5ILCX/pFH6FFwknhLyISQQp/kTyj0T6SCwp/EZEIUviL5BlNmSG5oPAXkUhx+u8KKPyln/RGGnjq85dcUPhLn5gSSiTUFP4iIhGk8BfJO/pUJf5T+IuIRJDCX0QkghT+0i8a6zPwdCxdckHhL32ifPLPy+vrgi5BIkDhL5JHVmzayw9+vy7oMgqaPq2mKPxF8sje/e1BlyARofAXEYkghb/0iT46+0MHeyVXFP4iIhFU0OG/rb6Ft7c3BF1GQdIOqj+05y+5UtDh/7NF7/Llu5cGXYaISN4p6PCPmWnKYRGRDAo6/A1IKvslREwdar7T/mBKYYe/9vxFRDIq8PDXf3nf6fEVCaXiIDZqZjVAI5AA4s656X5sJ2ambPKJRqWIhFsg4e/5uHNul58bSPX5K/4lRPRPVXKkoLt9YjFTt4+ISAZBhb8DXjCzFWY226+NaM9fRCSzoLp9znXObTWzY4CFZva2c25x1xt4/xRmA0ycOLFvWzEdj5RwUa+P5Eoge/7Oua3e753A48CMDLeZ75yb7pybXlFR0aftxEzp7zenB1hCRq/ZlJyHv5kNNbPyzsvAJ4E1vmwLdfv4RV9G8odpGJXkSBDdPmOAx70XeTHwG+fcc35sSEM9RUQyy3n4O+feA6blYltm2vMXEcmkoId6pqZ3CLoKEZH8U9jh7/3W/D4iIgcr6PCPeQfPwpb9V9+7lAderQm6jKyE7bHNdzrcK7lS0OHfOXAibP3+f96wixufWht0GSJSwAo6/GNe+Icr+sNBIxL9ocfVfyHbF/RNQYd/55jpsO35i4j4rcDDP/Vb2S9hoS/PSa4UdvgTzgO+IiJ+K+jwP9Dnr/QXEemqoMP/oaWbAdjX3BFwJYVLn6pEwqmgw3/znmYAttW3BFyJiEh+KejwP238MADKSvybwqi5Pc73n1xDU1vct23kMw1NHFh6PCVXIhH+ze2HB/OupjYq5z7Doytq+7WN+1+t4cHXNvHLlzf2az0iEoy2eCKSvQMFHf4Xf3gMAEWxw3enanbtB+DhZZv7tY1kMtXpnUiq81v6Tzv+uTfntys5+0d/jNx7uKDDv2xQEQAt7Ylub9PfSd86v0gWrZeNSPc27GjkgtsWsXd/e9ClZGXhuh1A9HbgCjr8O5/MF7wntysb4KkfojrqJartlu795582sml3M398e2fQpWQlqsdZCjr8WztSe/z3Z5whc2Ce8ai+cDqb/dza7ZoyeyAVwOspPZV6oFX0XtS+D1TQ4X/6xBFHvM1A5VbUXjhdvbF5X9AlSD5JT6sSjvdEVGcCKOjwH15W0u11A9Xtk56LJWIvnK6i1lcqPUuHacB1ZK0APm31RUGHfyzDKJ+BNtDHDsIoLHt4khsWsn6fiGZ/YYd/LuhUkaF5j4dCIczqeSD7c/fK2NfcTn2W07hE+K16EP+++prn0m8xvRL6TQ+hdBXEIIiqHywEoGbe3/R5HVF7HUdmz39XU9tBf1seDtNpaouHZmx014cvyge7pXthCVOL6Oy/kQn/v7795YzL+33AdwBPGHPBrYs4/d8X9n9FuRat94yv8nCfpNdiIfviYyF0tfVFwYf/9R8/ATh8WucDffX9W/9AjmzYHZK9/kOF5U3enWTS8fXfvMGKTXuCLqUgdP4DC9vpU49U7hd+/ipX37s0N8XkQMGH/zcuPiF9uXNI4uvv7aahteeDQ8+t2cYldyxOz93TnULYU+uvkL3HD7OnuZ1nVm9j9oMrgi6lQPZBwzVuPtsRe9Wb9vLnDbt8rydXCv6A7+DiovTlyd99lrf//RKumv86g4p6/r/3z4+sork9QUtHgqGDj/wwheWF7oew95WGbGRi3gvb8Oeojtgr+D3/Q33j4TcBaE8kge6Dq7PfMtuPrmEPwP4I+3smPTlf2BuSJ8I2ki6qkzNGIvzf/9Gl6csLM0zylknnC/hIX149EBx9qSzMDnRQhL3psXQfdbB1FIp87wr1e0ftiTe3cNdLG47YtRy0SIS/mbHm5k9lvK670D4wiucIff6H/P3C2u3pcwVERdj3mA/M7RLuduSbqD6acxas5PaF73DaTS/k9T+ASIQ/wFGDi/n+Z6Yctnzt1obDvgMAB6aGqPrBQh57o/uzfR26lzP71yv45H8sznjbu17awGsbd/ei6nDw403e2pE44sH2bPx22Wbe2Ly35xvlUR/1od8/+cA7D3WYhG2itIEa+ZdJtt86DkJkwh/g2vMmZVw+/YcvUjn3GSrnPsNPXtoAHLxH//M/HX6Kxj++vYNVH+zLuL7O4wmHun3hO8y8+/Ve1RwKPrxpPvxvz3HDY2/1ez1zH3uLK//z1exunIdh9bFbFwVdQq9l+6m5r5ra4gM7maCPR/zzebhrpMIfUl//njljYrfX/3jhO1TOfYa9Xf5jb9jZxAtrt/PG5r3sa25nzZZ6rr2/mst/9gq7m1Jj86PUZTDrvmVc91/+D4tcUP2B79uAA33++fAM5nt/eU86Ekl+/VpNOvD8eDydc0y98Xlmzj/yTtTL79Txq1feZ2U3O2md/HzI8/k4UsEP9czkR1eeyr995q+Y8v3ns77P7F9nDrufLnoXgAde28QDr21KL7/mV8s4dngZDy1NnSP4hGOOSl+3u6mN+Yvf492dTVx5xnhOGz+Me5e8f9i66xrbqGts4926Jpa+t5vPTjsWA6omDj9oCKtzjvtfreHmp9fx4LUzOP+kiqza5Jxjw84mSopiTBo9NKv7QOpNlS/2NbfT2Bpnwsghvb7vkg27OHlsOR3eJ7Wmtjht8cRBj21vPb92O+dMHkV5affTiffWpXf+mSe+fi6DirPbV4snkhQfYSizH2Y/WM2i9XXpYdR+BF+Ld4KmZTU9fyGvtSPBrPuWpf/OZs6f/hwIvn3hOxjw7U+cdNDyfN7zj2T4AwwZVJx+Qcz57Zs8sXLrgK5/0fqDA/LdnU3py2f+8MX05Zd6ONXdWf/nxYP+7vxH0pOvdHnB58o19y/v8fqrzprAb5cf2IsfMqiI0ycOZ+pxw9hR38q7dU2s2dIAQEmRMWHEgSC/av5rfGjk0PT5mO9/tYZvXXwiR5eV8N/VH/D29kYAnpvzMTbtbubpVVs5vuIoPnbi6IO6Br74i1dZXrOXz58xnqIYPFKd+TjOyf/6HE9ff17678q5z6Qv/+ofzqKxLU4imeSY8lI+NGoITW1x/uXR1fzThZP50KihfM3bSThueBnXnFvJJVPH8uTKrXx66th0G+IJx4LlH3B51bH8fvU2Nuxs5Lk12zn1uGFcXnXcYTWt29bASf/6h/TfxTHjk6eM4bTxw1n1wT5uvuwU4knH71bUsrW+lYeXbWZG5Ui21rcwceQQPjJpFN+8+AQaWuPsb4szZFAR9y55n5PHlvNX445mUFGM59du54fP/IWPn1zBT758BlNvfJ5pE4ZzwUkVfPHM8ayq3cfHTqxgWFkJd764geb2ONeeN4n2eJJ12xp4Ye2O9Gu+s9vziTe3ULv3wDGLjkSSxtY48USSWMxoaU8wYeQQWjsSNLXFGTlkELGYsbxmD+/v2s/lVcdS19jGi+t28KWzJtDWkaQjeaBLdeu+FlbX1jNtwrD0svfqmigtKWLEkEEHPYb72+Lpy5/9yRI+MWUsXzhzPE+t3EJDa+q6RNKxZ387+9viPLVqK9eeO4navc00tyc4eWx5+v5b9rUwcsggBhfHeP393ZSWFHGX1138rYtPPGi7nT0CP/z9Ou5Z8n46c9riCXbUtzF0cBHbG1r58NijWbD8A8YOG8z5J1YQTzqcg0dXfMDMGRN9+WduYeiumD59uquurvZ9O845HnxtE0nnuPnpdb5vT0TkSD49dSw///sz+3RfM1vhnJue6brI7vlnYmbMOqcSgGvOzXxwuMX71m9HIslHbnkph9WJSBTV7m3xZb2BhL+ZXQLcCRQB9zjn5gVRR1+UDSpKf3zvz9zhiaTj+bXbueSUsWytb6E4FqMoZpQUGbGY0eR9FN2yr4XBxTHGHF3KUYOL+ccHqvmb08ZR39LBw8s285nTjgXgFy8fPCKpvLSYxtYDH3UnjhzC5hAOG4yq8sHFvPn9T7CnuZ07X9yQVZefFKb/+upHfFlvzrt9zKwIeAf4BFALLAdmOue67WfJVbePhFtrR4LimPW6f9Q5d9D4+s6hhEeXFmNmJJKO/e1xji4toT2ePOjAa31LB2UlqZ2BophRdIRThzrnSLrUCJNYzEgmHbv2t3FMeWmvaq5v6aC0JJY+ON21Dfua22mPJ3HAsLISSks6jzUk2bqvlYmjhrC9vpURQ0vY2dCGWeoYRXsiyeDiovS6EknH+7v2U3HUYGIxKC8toaU9QUlR6jFOJB3t8SS7mto4bngZsZjx3JrtjDpqEKOPGsz4EWVs2r2fo8tKum1fa0eCophRHDOcO/jUq9vqWxhTXsrarQ2UDSpiX3M7FeWDKYoZx5SX0hpPEDMjkXBsb2hlf3uc4WUl7G1u54yJIzAzVtfuY0dDG+dMHsXQwcXsbmrjoaWb+cZFqQkf2+JJ9jV3EDM45ujSdB99R8JhBu3xJNvqW4iZMWHkEPa3xdmzv51t9a2cM3kUze2pA9Axs/Sxi2FDStjZ0Mr2+jZOHlvOzsZWykqKqCgfTGlJETFL7dwtr9lD1cThvLhuB58/czxt8SRPvLmF4UNK+Ojxo2iPJxlWVpLV3GLd6anbJ4jwPxu4yTn3Ke/vGwCccz/q7j4KfxGR3usp/IMY538c0HUAd623TEREciSI8M/0ufiwjx9mNtvMqs2suq4uf8aVi4gUgiDCvxaY0OXv8cBhg+ydc/Odc9Odc9MrKrL70pKIiGQniPBfDpxoZpPMbBBwFfBUAHWIiERWzod6OufiZnY98DypoZ73OefW5roOEZEoC2Scv3PuWeDZILYtIiIRnNVTREQU/iIikRSKid3MrA7YdMQbZjYa2DWA5QRJbck/hdIOUFvyVX/a8iHnXMbhkqEI//4ws+ruvuEWNmpL/imUdoDakq/8aou6fUREIkjhLyISQVEI//lBFzCA1Jb8UyjtALUlX/nSloLv8xcRkcNFYc9fREQOofAXEYmggg5/M7vEzNab2btmNjfoejIxsxoze8vMVppZtbdspJktNLMN3u8RXW5/g9ee9Wb2qS7Lz/TW866Z3WVdT03lX+33mdlOM1vTZdmA1W5mg81sgbd8qZlV5rgtN5nZFu+5WWlml+Z7W8xsgpktMrO/mNlaM/uWtzx0z0sPbQnV82JmpWa2zMxWee242Vse7HPinCvIH1KTxm0EjgcGAauAKUHXlaHOGmD0IctuBeZ6l+cC/9e7PMVrx2Bgkte+Iu+6ZcDZpM6X8Afg0zmo/XzgDGCNH7UD/wP4hXf5KmBBjttyE/C/Mtw2b9sCjAPO8C6Xkzpl6pQwPi89tCVUz4u3zaO8yyXAUuCjQT8nvoZDkD/eA/R8l79vAG4Iuq4MddZwePivB8Z5l8cB6zO1gdTMqGd7t3m7y/KZwC9zVH8lBwfmgNXeeRvvcjGpbzlaDtvSXcjkfVu61PAkqfNlh/Z5ydCW0D4vwBDgDeAjQT8nhdztE5bTRTrgBTNbYWazvWVjnHPbALzfx3jLu2vTcd7lQ5cHYSBrT9/HORcH6oFRvlWe2fVmttrrFur8WB6Ktngf/U8ntacZ6uflkLZAyJ4XMysys5XATmChcy7w56SQwz+r00XmgXOdc2cAnwa+bmbn93Db7toUhrb2pfag2/VzYDJQBWwDfuwtz/u2mNlRwO+AOc65hp5ummFZvrcldM+Lcy7hnKsidebCGWY2tYeb56QdhRz+WZ0uMmjOua3e753A48AMYIeZjQPwfu/0bt5dm2q9y4cuD8JA1p6+j5kVA8OAPb5Vfgjn3A7vTZsE7ib13BxUlyev2mJmJaTC8iHn3GPe4lA+L5naEtbnxat9H/An4BICfk4KOfzz/nSRZjbUzMo7LwOfBNaQqnOWd7NZpPo68ZZf5R3ZnwScCCzzPjI2mtlHvaP/X+lyn1wbyNq7rusLwB+d16mZC51vTM8VpJ6bzrrysi3edu8F/uKcu73LVaF7XrprS9ieFzOrMLPh3uUy4K+Btwn6OfH7IE2QP8ClpEYIbAS+F3Q9Geo7ntRR/VXA2s4aSfXVvQRs8H6P7HKf73ntWU+XET3AdFJvgo3AT8nNAbiHSX3s7iC15/HVgawdKAX+G3iX1CiH43Pcll8DbwGrvTfXuHxvC3AeqY/7q4GV3s+lYXxeemhLqJ4X4DTgTa/eNcD3veWBPiea3kFEJIIKudtHRES6ofAXEYkghb+ISAQp/EVEIkjhLyISQQp/iQQza/J+V5rZlwd43d895O9XB3L9In5Q+EvUVAK9Cn8zKzrCTQ4Kf+fcOb2sSSTnFP4SNfOAj3nzwH/bm3DrNjNb7k0U9jUAM7vQUnPJ/4bUF4owsye8CfjWdk7CZ2bzgDJvfQ95yzo/ZZi37jXeHOx/22XdfzKzR83sbTN7qMu87PPMbJ1Xy//L+aMjkVEcdAEiOTaX1HTAnwHwQrzeOXeWmQ0GXjGzF7zbzgCmOufe9/6+1jm3x/uK/nIz+51zbq6ZXe9Sk3Yd6kpSk49NA0Z791nsXXc6cAqpuVleAc41s3Wkpiv4sHPOdU4JIOIH7flL1H0S+Io33e5SUl+5P9G7blmX4Af4ppmtAl4nNYnWifTsPOBhl5qEbAfwMnBWl3XXutTkZCtJdUc1AK3APWZ2JdDcz7aJdEvhL1FnwDecc1XezyTnXOee//70jcwuJDUh19nOuWmk5mopzWLd3WnrcjkBFLvUPOwzSM1i+TnguV60Q6RXFP4SNY2kTgnY6Xngn7ypgzGzk7wZVg81DNjrnGs2sw+TOg1fp47O+x9iMfC33nGFClKnilzWXWHevPXDnHPPAnNIdRmJ+EJ9/hI1q4G4131zP3AnqS6XN7yDrnWk9roP9RxwnZmtJjXT4utdrpsPrDazN5xzf9dl+eOkTr+3itTslP/bObfd++eRSTnwpJmVkvrU8O0+tVAkC5rVU0QkgtTtIyISQQp/EZEIUviLiESQwl9EJIIU/iIiEaTwFxGJIIW/iEgE/X/JA+5grH70TgAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Training\n",
    "loss2 = []\n",
    "pbar = (range(0,30000))\n",
    "for i in tqdm(pbar):\n",
    "    # Train\n",
    "    feed_dict = {}\n",
    "    l2,_ = sess.run([dloss, c_optim],feed_dict=feed_dict)\n",
    "    loss2.append(l2)\n",
    "\n",
    "fig = plt.figure()\n",
    "ax = plt.axes()\n",
    "plt.plot(loss2, label='CoB')\n",
    "ax.set_xlabel('Iterations' )\n",
    "ax.set_ylabel('Loss')\n",
    "plt.legend(loc='upper right')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 283
    },
    "id": "08mK99A8IL2n",
    "outputId": "5d1e8b4f-82d7-4dde-a5ee-9687986d3f90"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-5.0, 5.0)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Sampling\n",
    "kl_ratio_store=[]\n",
    "log_ratio_store=[]\n",
    "log_r_p_from_m_direct_store=[]\n",
    "\n",
    "\n",
    "feed_dict = feed_dict\n",
    "kl_ratio, p_s, q_s, d_s, m_s, lpq, lpq_from_cob_dre_direct= sess.run([kld,\n",
    "                                                                            p_samples, q_samples, samples, m_samples,\n",
    "                                                                            log_ratio_p_q,  log_r_p_from_m_direct],\n",
    "                                                                          feed_dict=feed_dict)\n",
    "kl_ratio_store.append(kl_ratio)\n",
    "log_ratio_store.append(lpq)\n",
    "log_r_p_from_m_direct_store.append(lpq_from_cob_dre_direct)\n",
    "    \n",
    "fig, ax = plt.subplots(1, 1)\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(d_s, density=True, histtype='stepfilled', alpha=0.8, label='M')\n",
    "ax.hist(m_s, density=True, histtype='stepfilled', alpha=0.8, label='M')\n",
    "ax.legend(loc='best', frameon=False)\n",
    "plt.xlim(-5,5)\n",
    "# plt.ylim(-400,800)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 301
    },
    "id": "ja9hDBCPlg12",
    "outputId": "16acdcbe-1f62-4f6c-ea71-dddc8ce642d1"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-400.0, 1000.0)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "xs = m_s\n",
    "plt.scatter(xs,log_ratio_store[0],label='True from log_prob',alpha=0.9,s=10.)\n",
    "plt.scatter(xs,log_r_p_from_m_direct_store[-1][:,0]-log_r_p_from_m_direct_store[-1][:,1],label='from CoB DRE Direct',alpha=0.9,s=10.)\n",
    "\n",
    "plt.xlabel(\"Samples\")\n",
    "plt.ylabel(\"Log Ratio\")\n",
    "plt.legend(loc='upper right')\n",
    "plt.xlim(-4,5)\n",
    "plt.ylim(-400,1000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-1000.0, 1000.0)"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(xs,log_ratio_store[0],label='True p/q',alpha=0.9,s=10.,c='b')\n",
    "plt.scatter(xs,log_r_p_from_m_direct_store[-1][:,0]-log_r_p_from_m_direct_store[-1][:,1],label='CoB p/q',alpha=0.9,s=10.,c='r')\n",
    "plt.scatter(xs,-log_ratio_store[0],label='True q/p',alpha=0.9,s=10.,c='b')\n",
    "plt.scatter(xs,log_r_p_from_m_direct_store[-1][:,1]-log_r_p_from_m_direct_store[-1][:,0],label='CoB q/p',alpha=0.9,s=10.,c='r')\n",
    "\n",
    "plt.xlabel(\"Samples\")\n",
    "plt.ylabel(\"Log Ratio\")\n",
    "plt.legend(loc='lower right')\n",
    "plt.xlim(-4,6)\n",
    "plt.ylim(-1000,1000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 301
    },
    "id": "gHtEC7YB-jah",
    "outputId": "5ce554de-d77e-48b8-eea8-48f42af7e327"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-600.0, 400.0)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "rat = log_r_p_from_m_direct_store[-1][:,0]-log_r_p_from_m_direct_store[-1][:,1]\n",
    "d = [np.squeeze(norm.logpdf(x,mu_2,0.1)) for x in xs]\n",
    "b = [np.squeeze(norm.logpdf(x,mu_1,0.1)) for x in xs]\n",
    "\n",
    "plt.scatter(xs,b,label='True P',alpha=0.9,s=5.)\n",
    "plt.scatter(xs,rat+d,label='P',alpha=0.9,s=5.)\n",
    "\n",
    "plt.xlabel(\"Samples\")\n",
    "plt.ylabel(\"Log P(x)\")\n",
    "plt.legend(loc='upper right')\n",
    "plt.xlim(-4.,4)\n",
    "plt.ylim(-600,400)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "V03YVAWPlSSH"
   },
   "outputs": [],
   "source": []
  },
  {
   "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
}
