{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "zdgemk5nHdbL",
    "outputId": "332d9159-5b7e-488d-cdf1-803b67f11603"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "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\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",
    "\n",
    "print(tf.__version__)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "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",
    "      h = slim.fully_connected(x, 20, activation_fn=tf.nn.softplus)\n",
    "      h = tf.nn.dropout(h,prob)\n",
    "      h = slim.fully_connected(h, 10, 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)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "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": 90,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "QH5eP5NclBEf",
    "outputId": "1c6f6465-8bb3-4583-c235-2c914da988fb"
   },
   "outputs": [],
   "source": [
    "# Build 2 Discriminator Networks (one from noise input, one from generated samples)\n",
    "\n",
    "disc_real = ratios_critic(p_samples, do)\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=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": 91,
   "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": "1bc56901d4e64340ad7422ebd181392a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(FloatProgress(value=0.0, max=31000.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f7e1c42d4d0>"
      ]
     },
     "execution_count": 91,
     "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": [
    "# Training\n",
    "loss2 = []\n",
    "pbar = (range(0,31000))\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": 92,
   "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": 92,
     "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": 93,
   "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": 93,
     "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": 94,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-1000.0, 1000.0)"
      ]
     },
     "execution_count": 94,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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3hhWxPmby+jBQbKoo7vu54DkkH1LYaKr1u6Ki53pyNnZweVPPuk2Wiorj2kMxgJLdI71e7LgYkwSGLIluDunliw+nb8gpVotgTweOO644DJVmD3bPSgvd/rLIikrs22Tk4AFF2MSrNLroyqrd1DZ2qHXpGxg8bvllvCydesC4kZpafMBJkm3Td6zZw+5ubnk5uZyyimn0L9//6bj2trauL//zp078bRTagcLLsYkUEWBlzPnTGNAzRaq6cIeerNyaCEXbLK1G8XFzlTk0BX8Pl9AirGWAkwSpuzv3bs3a9euZe3atdx8883cfvvtTcdZWVnU19fH9f2XL19OQTu16iy4GJMglV4f43z3kc0hulJNA+msO3eWBZYAxcVwww3h5U0D/NBygInBOph4b/x54403cscdd3DhhRdy1113MW/ePB544IGm50eOHMl2d372ggULGD9+PLm5udx00000NDSEvd6gQYO46667GD9+POPHj2fz5s1Nzy1fvpxLL70UVeW2225jxIgRXH755Vx22WU8++yzMf1cFlyMSZCqpRWANCWkTIOUmnYcrdJSGDQovLysLKQFU14OJ58c+cSj7CLz+WDGDHj4Yec+XgHmk08+4ZVXXuHBBx9s9pwNGzawaNEi3nzzTdauXUt6ejp//vOfI56bk5PDu+++y2233cZPfvITABoaGti4cSMjRoxgyZIlbNy4kXXr1vH444/z1ltvxfwzWXAxJkFypuRzWLpTTTaH6cq7nntSfpylOY8+6qx7CXX//QEHHg98+SWMGhV+on8dTBtVVDhrbrp3d+4rKtr8ElH54Q9/SHpo/1+IV199lcrKSsaNG0dubi6vvvoqW7dujXjudddd13S/atUqAN555x2+973vAfD6669z3XXXkZ6eTr9+/bgoUpLQY5R0wUVE5onI5yKy1r1dFvBcsYhsFpGNIlIQUJ4nIuvc5/5DbK6hSWL+bpY9eU5CynfP/TEfl/ylUyWkjDWPB268Mbz80CEYNiyk8IEHwnciA+eL37OnTe+bn++81MGDzn1+fpsuj1r37t2bHmdkZNDY2Nh07F9roqrMnDmzaYxm48aNzJs3L+LrBf4K9D9etmwZkydPjnhOPCRdcHE9pKq57u0lABEZAUwHzgImA38QEX+ofwSYBQxzb5MjvKYxCbewyMe3l04n91fX8cQ1Pvbkebjw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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": 95,
   "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": 95,
     "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": []
  }
 ],
 "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
}
