{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "zdgemk5nHdbL",
    "outputId": "a65eddf1-049b-416f-ce9e-296383a25c46"
   },
   "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\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",
    "tfk = tf.keras\n",
    "\n",
    "print(tf.__version__)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "id": "boCNTMt4BEiY"
   },
   "outputs": [],
   "source": [
    "tol = 1e-35\n",
    "bs = 500\n",
    "K = 3\n",
    "do = .8\n",
    "n_posterior_samples = 500\n",
    "\n",
    "def ratios_critic(x, prob = 1, reuse=False, training = True):\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, 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 h #tf.squeeze(log_d)\n",
    "\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "id": "lt5Ozzo0HrUj"
   },
   "outputs": [],
   "source": [
    "tf.reset_default_graph()\n",
    "tf.random.set_random_seed(40)\n",
    "\n",
    "# layer = tfk.layers.Dense(K, activation=None)\n",
    "\n",
    "layer = tfp.layers.DenseFlipout(K, activation=None)\n",
    "\n",
    "mu_1 = 0.\n",
    "mu_2 = 4.\n",
    "mu_3 = 4.\n",
    "scale_pq = .1\n",
    "scale_m = 2.\n",
    "lam = tf.placeholder('float',1)\n",
    "p = tfd.Normal(loc=mu_1, scale=scale_pq)\n",
    "q = tfd.Normal(loc=mu_2, scale=scale_pq)\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 samples\n",
    "kld_from_samples = tf.reduce_mean(p.log_prob(p_samples) - q.log_prob(p_samples)) \n",
    "#KL from samples\n",
    "kld = p.kl_divergence(q)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "id": "QH5eP5NclBEf"
   },
   "outputs": [],
   "source": [
    "# Build 2 Discriminator Networks (one from noise input, one from generated samples)\n",
    "\n",
    "disc_real = layer(ratios_critic(p_samples, do))\n",
    "disc_fake = layer(ratios_critic(q_samples, do,reuse=True))\n",
    "disc_m = layer(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",
    "dloss += sum(layer.losses)/1e+5\n",
    "# Define CoB DRE\n",
    "\n",
    "log_r_p_m = layer(ratios_critic(m_samples, reuse=True, training=False))\n",
    "log_r_p_from_m_direct = log_r_p_m \n",
    "\n",
    "#KL from samples\n",
    "ratio_logits = layer(ratios_critic(p_samples, reuse=True, training=False))\n",
    "kld_from_cob = tf.reduce_mean(ratio_logits[:,0] - ratio_logits[:,1]) \n",
    "\n",
    "enc_m = ratios_critic(m_samples, reuse=True, training=False)\n",
    "enc_p = ratios_critic(p_samples, reuse=True, training=False)\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": 12,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 297
    },
    "id": "c8oVgSoXEAv_",
    "outputId": "894251db-44ea-4d85-c35a-6ebb90642d4e"
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "0c98be3d5fc246569dc366647dbcdfba",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(FloatProgress(value=0.0, max=26000.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f5f0c164110>"
      ]
     },
     "execution_count": 12,
     "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,26000))\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": 13,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 337
    },
    "id": "08mK99A8IL2n",
    "outputId": "68f04d14-5cbb-4a37-fdff-ad5128d942d8"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "KL :  799.99994\n",
      "KL from samples :  803.2071\n",
      "KL from CoB:  829.72485\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(-5.0, 5.0)"
      ]
     },
     "execution_count": 13,
     "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, kl_cob, kl_ture, p_s, q_s, d_s, m_s, lpq, lpq_from_cob_dre_direct= sess.run([kld_from_samples, kld_from_cob, kld,\n",
    "                                                                            p_samples, q_samples, enc_m, m_samples,\n",
    "                                                                            log_ratio_p_q,  log_r_p_from_m_direct],\n",
    "                                                                          feed_dict=feed_dict)\n",
    "print('KL : ',kl_ture)\n",
    "print('KL from samples : ',kl_ratio)\n",
    "print('KL from CoB: ', kl_cob)\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": 14,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 301
    },
    "id": "ja9hDBCPlg12",
    "outputId": "2830325e-dc2d-441d-875c-9e1b904a6200"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-400.0, 1000.0)"
      ]
     },
     "execution_count": 14,
     "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": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-400.0, 1000.0)"
      ]
     },
     "execution_count": 15,
     "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(-400,1000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 297
    },
    "id": "gHtEC7YB-jah",
    "outputId": "a8388170-5916-46cf-be3d-9ebcc99368d7"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-4000.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,scale_pq)) for x in xs]\n",
    "b = [np.squeeze(norm.logpdf(x,mu_1,scale_pq)) 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",
    "x_sorted = []\n",
    "r_sorted = []\n",
    "[(x_sorted.append(a),r_sorted.append(b)) for a,b in sorted(zip(xs,rat+d))]\n",
    "plt.plot(x_sorted, r_sorted, '-r.', label='line P',alpha=0.9)\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(-4000,400)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "id": "sUI_JiMBXE64"
   },
   "outputs": [],
   "source": [
    "# helper function, mostly for plotting\n",
    "def log_ratio(w, b):\n",
    "  [x_] = sess.run([enc_m],feed_dict={})\n",
    "  return x_@w + b\n",
    "\n",
    "def log_ratio_predictive(w, b):\n",
    "  x_ = d_s\n",
    "  print(x_.shape)\n",
    "  print(w.shape)\n",
    "  pred = x_@w \n",
    "  # pred = np.transpose(pred,(1,0,2))+ b\n",
    "  pred = pred[0,:,:] - pred[1,:,:]\n",
    "  print(pred.shape)\n",
    "  return pred.mean(1), (pred).std(1)\n",
    "\n",
    "def log_ratio_predictive_p(w, b):\n",
    "  [x_] = sess.run([enc_p],feed_dict={})\n",
    "  print(x_.shape)\n",
    "  print(w.shape)\n",
    "  pred = x_@w \n",
    "  # pred = np.transpose(pred,(1,0,2))+ b\n",
    "  pred = pred[0,:,:] - pred[1,:,:]\n",
    "  print(pred.shape)\n",
    "  return pred.mean(1), (pred).std(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 483
    },
    "id": "CBGq-0XIXFvv",
    "outputId": "bfb8b33d-2870-48bd-cd83-13adb9651f6a"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Taking 500 samples from posterior distributions on weights\n",
      "\n",
      "Sampling complete. Samples are stored in numpy arrays:\n",
      "  weight: candidate_ws\n",
      "    bias: candidate_bs\n",
      "(500, 100)\n",
      "(3, 100, 500)\n",
      "(500, 500)\n",
      "(500,)\n",
      "Done\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(-400.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": [
    "candidate_ws = []\n",
    "candidate_bs = []\n",
    "\n",
    "print(f\"Taking {n_posterior_samples} samples from posterior distributions on weights\\n\")\n",
    "\n",
    "w_draw = layer.kernel_posterior.sample()\n",
    "b_draw = layer.bias_posterior.sample()\n",
    "\n",
    "for mc in range(n_posterior_samples):\n",
    "    w_, b_ = sess.run([w_draw, b_draw])\n",
    "    candidate_ws.append(w_)\n",
    "    candidate_bs.append(b_)\n",
    "    \n",
    "print(\"Sampling complete. Samples are stored in numpy arrays:\")\n",
    "print(f\"  weight: candidate_ws\")\n",
    "print(f\"    bias: candidate_bs\")\n",
    "        \n",
    "candidate_ws = np.array(candidate_ws).astype(np.float32)\n",
    "candidate_bs = np.array(candidate_bs).astype(np.float32)\n",
    "# print(candidate_ws.shape)\n",
    "# candidate_ws = np.transpose(candidate_ws, (1,2,0))\n",
    "post_pred,post_std = log_ratio_predictive(candidate_ws.T, candidate_bs.T)\n",
    "print(post_pred.shape)\n",
    "# plt.plot(xs,post_pred,label='BC_Bayes_e',alpha=0.7)\n",
    "x_sorted = []\n",
    "m_sorted = []\n",
    "s_sorted = []\n",
    "[(x_sorted.append(a),m_sorted.append(b), s_sorted.append(c)) for a,b,c in sorted(zip(xs,post_pred, post_std))]\n",
    "print('Done')\n",
    "plt.plot(x_sorted, m_sorted,label='BC_Bayes_e',alpha=0.7)\n",
    "# plt.scatter(xs,post_pred,label='BC_Bayes_e',alpha=0.7,s=5.)\n",
    "plt.fill_between(x_sorted, np.asarray(m_sorted)-10*np.asarray(s_sorted), np.asarray(m_sorted)+10*np.asarray(s_sorted))\n",
    "\n",
    "plt.scatter(xs,norm.logpdf(xs,mu_1,scale_pq)-norm.logpdf(xs,mu_2,scale_pq),label='True log_prob',alpha=0.99,s=5.)\n",
    "\n",
    "plt.xlabel(\"Samples\")\n",
    "plt.ylabel(\"Log Ratio\")\n",
    "plt.legend(loc='upper right')\n",
    "plt.xlim(-4,4)\n",
    "plt.ylim(-400,1000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "TKRJIoITkBi0",
    "outputId": "1afd3a59-a067-4de3-d1c4-900ecb57a109"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "KL :  199.99998\n",
      "(500, 100)\n",
      "(3, 100, 500)\n",
      "(500, 500)\n",
      "KL Post Pred:  202.23706\n"
     ]
    }
   ],
   "source": [
    "[true_kl] = sess.run([kld],feed_dict={})\n",
    "print('KL : ',true_kl)\n",
    "post_pred,post_std = log_ratio_predictive_p(candidate_ws.T, candidate_bs.T)\n",
    "spp = [x for _,x in sorted(zip(post_std,post_pred))]\n",
    "print('KL Post Pred: ', np.mean(spp[:500]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "qjhbHCqE9nyi"
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "collapsed_sections": [],
   "name": "KLD_on_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
}
