{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "zdgemk5nHdbL",
    "outputId": "793bbcbb-96da-4252-a4be-e75389010cd9"
   },
   "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": [
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "\n",
    "import tensorflow as tf\n",
    "# tf.keras.backend.set_floatx(\n",
    "#     'float32'\n",
    "# )\n",
    "import numpy as np\n",
    "import seaborn as sns; \n",
    "tfd = tf.contrib.distributions\n",
    "import imageio\n",
    "import glob\n",
    "import tensorflow_probability as tfp\n",
    "tfd = tfp.distributions\n",
    "from tqdm import tqdm_notebook as tqdm\n",
    "from scipy.stats import norm, uniform, cauchy\n",
    "\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",
    "from IPython.display import display, clear_output\n",
    "\n",
    "print(tf.__version__)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "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') as scope:\n",
    "        if reuse:\n",
    "            scope.reuse_variables()\n",
    "        x = tf.expand_dims(x,1)\n",
    "        \n",
    "        h1 = slim.fully_connected(x, 100, activation_fn=tf.nn.softplus)\n",
    "        h1 = tf.nn.dropout(h1,prob)\n",
    "        h1 = slim.fully_connected(h1, 50, activation_fn=tf.nn.softplus)\n",
    "        h1 = tf.nn.dropout(h1,prob)\n",
    "        \n",
    "        h2 = slim.fully_connected(x, 100, activation_fn=tf.nn.softplus)\n",
    "        h2 = tf.nn.dropout(h2,prob)\n",
    "        h2 = slim.fully_connected(h2, 50, activation_fn=tf.nn.softplus)\n",
    "        h2 = tf.nn.dropout(h2,prob)\n",
    "        \n",
    "        log_d = tf.concat([-h1,-h2],1)\n",
    "        log_d = slim.fully_connected(log_d, 2, activation_fn=None)\n",
    "        \n",
    "    return tf.squeeze(log_d)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {
    "id": "lt5Ozzo0HrUj"
   },
   "outputs": [],
   "source": [
    "tf.reset_default_graph()\n",
    "tf.random.set_random_seed(40)\n",
    "\n",
    "mu_1 = -1.\n",
    "mu_2 = 1.\n",
    "mu_3 = 0.\n",
    "scale_p=0.2\n",
    "scale_q=0.1\n",
    "scale_m=3.\n",
    "\n",
    "p = tfd.Normal(loc=mu_1, scale=scale_p)\n",
    "q = tfd.Normal(loc=mu_2, scale=scale_q)\n",
    "base = tfp.distributions.Cauchy(loc=mu_3, scale=scale_m)\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": 42,
   "metadata": {
    "id": "QH5eP5NclBEf"
   },
   "outputs": [],
   "source": [
    "# Build 2 Discriminator Networks (one from noise input, one from generated samples)\n",
    "\n",
    "ratio_on_p = ratios_critic(p_samples, do)\n",
    "ratio_on_q = ratios_critic(q_samples, do,reuse=True)\n",
    "ratio_on_m = ratios_critic(m_samples, do,reuse=True)\n",
    "# disc_m_gen = ratios_critic(m_samples2, do,reuse=True)\n",
    "\n",
    "logitP = tf.concat([ratio_on_p-tf.expand_dims(base.log_prob(p_samples),1),tf.expand_dims(base.log_prob(p_samples),1)],1)\n",
    "logitQ = tf.concat([ratio_on_q-tf.expand_dims(base.log_prob(q_samples),1),tf.expand_dims(base.log_prob(q_samples),1)],1)\n",
    "logitM = tf.concat([ratio_on_m-tf.expand_dims(base.log_prob(m_samples),1),tf.expand_dims(base.log_prob(m_samples),1)],1)\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=logitP, labels=label_a))\n",
    "disc_loss_2 = tf.reduce_mean(tf.nn.softmax_cross_entropy_with_logits(logits=logitQ, labels=label_b))\n",
    "disc_loss_3 = tf.reduce_mean(tf.nn.softmax_cross_entropy_with_logits(logits=logitM, 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",
    "optim = tf.train.AdamOptimizer(learning_rate=1e-3).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": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 296
    },
    "id": "c8oVgSoXEAv_",
    "outputId": "9a5bbab4-c758-4cbb-a3de-25d9ba2bded6"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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3HHH8Ze//IWsrKxK++vVqxcXXXQR//3vfwH45z//yYEHHggECfKtt96Ku/OjH/2It956i969e+PujBgxggsuuKDxT1BE6kQlFiIikhIKC+HSS+HBB4PnwsKmOc6nn37KG2+8wb333lvjOh9//DHPPvss//vf/5g5cyZZWVk89dRTCddt3749U6dO5Yc//CE//elPASgtLWX+/Pn06dOHF154gfnz5zN79mwefvhh3nvvvaY4LRGpB7Ugi4hISpg4EXbuhDZtYOvWYLopWpG/9a1vVWsJrurNN99k+vTpHHvssQBs376dvffeO+G6l1xySfnzddddB8CUKVM47rjjAHj77be55JJLyMrKYt999+XUU09trFMRkQZSgiwiIilhyBB45JEgOc7NDaabQps2bcpfZ2dnU1ZWVj4d64vY3bn88ssZNWrULvcX30Vb7PWrr77K8OHDE64jItFTiYWIiKSE/HwYMwauvTZ4bo4OIHr16sWMGTMAmDFjBkuWLAFg6NChPPfcc6xevRqA9evX89lnnyXcx7PPPlv+PGjQICBogR46dCgAgwcP5plnnqG0tJSVK1eW1yuLSHTUgiwiIikjP795EuOYb37zmzzxxBP069ePY489loMPPhiAPn36cPvtt5Ofn09ZWRk5OTk8+OCD9OzZs9o+du7cyXHHHUdZWRlPP/00a9asIS8vj/bt2wNw/vnn89Zbb9G3b18OPvhgTj755OY7QRFJSAmyiIhkvJEjRyac36pVKwpruBvwoosu4qKLLtrlvq+99lpuvfXW8ukxY8ZU6v/YzPjzn/9cPv3d7363bkGLSJNRgiwiItKMLr300qhDEJFdUIIsIiLSRJYuXVrvbR577LFGj0NE6kc36YmIiIiIxFGCLCIiIiISRwmyiIiIiEgcJcgiIiIiInGUIIuISMZatWoVF198MQcccAB9+vThzDPP5NNPP61x/aVLl9KqVSv69evHUUcdxde+9jXmz59f7+OOGjWKp556andCF5EmpARZREQykrtz/vnnM2TIEBYtWsS8efO48847+fLLL2vd7oADDmDmzJnMmjWLyy+/nDvvvLPexy4sLKzUF7KIJBclyCIikjoKC+Gmm4Ln3fTf//6XnJwcrr766vJ5/fr146STTsLd+cUvfsERRxxB3759y4eLrmrTpk107Nix2vyJEycyePBgzj//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\n",
      "text/plain": [
       "<Figure size 720x288 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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3HHH8Ze//IWsrKxK++vVqxcXXXQR//3vfwH45z//yYEHHggECfKtt96Ku/OjH/2It956i969e+PujBgxggsuuKDxT1BE6kQlFiIikhIKC+HSS+HBB4PnwsKmOc6nn37KG2+8wb333lvjOh9//DHPPvss//vf/5g5cyZZWVk89dRTCddt3749U6dO5Yc//CE//elPASgtLWX+/Pn06dOHF154gfnz5zN79mwefvhh3nvvvaY4LRGpB7Ugi4hISpg4EXbuhDZtYOvWYLopWpG/9a1vVWsJrurNN99k+vTpHHvssQBs376dvffeO+G6l1xySfnzddddB8CUKVM47rjjAHj77be55JJLyMrKYt999+XUU09trFMRkQZSgiwiIilhyBB45JEgOc7NDaabQps2bcpfZ2dnU1ZWVj4d64vY3bn88ssZNWrULvcX30Vb7PWrr77K8OHDE64jItFTiYWIiKSE/HwYMwauvTZ4bo4OIHr16sWMGTMAmDFjBkuWLAFg6NChPPfcc6xevRqA9evX89lnnyXcx7PPPlv+PGjQICBogR46dCgAgwcP5plnnqG0tJSVK1eW1yuLSHTUgiwiIikjP795EuOYb37zmzzxxBP069ePY489loMPPhiAPn36cPvtt5Ofn09ZWRk5OTk8+OCD9OzZs9o+du7cyXHHHUdZWRlPP/00a9asIS8vj/bt2wNw/vnn89Zbb9G3b18OPvhgTj755OY7QRFJSAmyiIhkvJEjRyac36pVKwpruBvwoosu4qKLLtrlvq+99lpuvfXW8ukxY8ZU6v/YzPjzn/9cPv3d7363bkGLSJNRgiwiItKMLr300qhDEJFdUIIsIiLSRJYuXVrvbR577LFGj0NE6kc36YmIiIiIxFGCLCIiIiISRwmyiIiIiEgcJcgiIiIiInGUIIuISMZatWoVF198MQcccAB9+vThzDPP5NNPP61x/aVLl9KqVSv69evHUUcdxde+9jXmz59f7+OOGjWKp556andCF5EmpARZREQykrtz/vnnM2TIEBYtWsS8efO48847+fLLL2vd7oADDmDmzJnMmjWLyy+/nDvvvLPexy4sLKzUF7KIJBclyCIikjoKC+Gmm4Ln3fTf//6XnJwcrr766vJ5/fr146STTsLd+cUvfsERRxxB3759y4eLrmrTpk107Nix2vyJEycyePBgzj//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\n",
      "text/plain": [
       "<Figure size 720x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "N=50000\n",
    "loss_store=[]\n",
    "fig, [ax1,ax2] = plt.subplots(1, 2,figsize=(10,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",
    "\n",
    "ax1.set_xlabel(\"Iteration\")\n",
    "ax1.set_ylabel(\"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,1500])\n",
    "\n",
    "plt.tight_layout()\n",
    "\n",
    "pbar = range(0,N)\n",
    "for i in pbar:\n",
    "\n",
    "    feed_dict = {}\n",
    "    l,_ = sess.run([dloss, optim],feed_dict=feed_dict)\n",
    "    loss_store.append(l)\n",
    "    if i%500==0:\n",
    "        line.set_data(range(len(loss_store)), loss_store)\n",
    "        xs, lpq, lpqm = sess.run([m_samples, log_ratio_p_q, log_r_p_m],feed_dict={})\n",
    "        scat1.set_offsets(np.asarray([xs, lpq]).T)\n",
    "        scat2.set_offsets(np.asarray([xs,lpqm[:,0]-lpqm[:,1]]).T)\n",
    "        \n",
    "        \n",
    "        \n",
    "        clear_output(wait=True)\n",
    "        display(fig)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 282
    },
    "id": "08mK99A8IL2n",
    "outputId": "35db5c04-7e38-4291-dcc4-b81d576a6b53"
   },
   "outputs": [],
   "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,10)\n",
    "# plt.ylim(-400,800)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 300
    },
    "id": "ja9hDBCPlg12",
    "outputId": "ae16376f-694d-43a5-e7d5-f830b068474f"
   },
   "outputs": [],
   "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,lpq_from_cob_dre_direct[:,0]-lpq_from_cob_dre_direct[:,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(-6,10)\n",
    "plt.ylim(-3000,5000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 300
    },
    "id": "gHtEC7YB-jah",
    "outputId": "fcebaef2-ab26-4892-9f76-626bb3e04810"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-6000.0, 400.0)"
      ]
     },
     "execution_count": 31,
     "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_p = log_r_p_from_m_direct_store[-1][:,0]- cauchy.logpdf(xs,loc=mu_3,scale=scale_m)\n",
    "rat_q = log_r_p_from_m_direct_store[-1][:,1]- cauchy.logpdf(xs,loc=mu_3,scale=scale_m)\n",
    "\n",
    "d = [np.squeeze(norm.logpdf(x,mu_2,scale_q)) for x in xs]\n",
    "b = [np.squeeze(norm.logpdf(x,mu_1,scale_p)) for x in xs]\n",
    "\n",
    "plt.scatter(xs,b,label='True P',alpha=0.9,s=5.)\n",
    "plt.scatter(xs,rat_p,label='P',alpha=0.9,s=5.)\n",
    "plt.scatter(xs,d,label='True q',alpha=0.9,s=5.)\n",
    "plt.scatter(xs,rat_q,label='q',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.,10)\n",
    "plt.ylim(-6000,400)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "# Training\n",
    "loss2 = []\n",
    "pbar = (range(0,100000))\n",
    "for i in 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')"
   ]
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "collapsed_sections": [],
   "name": "ratio_output_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
}
