{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "zdgemk5nHdbL",
    "outputId": "c655599a-acd9-4510-bfd3-7a0d81e817c5"
   },
   "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",
    "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",
    "print(tf.__version__)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 129,
   "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, 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": 119,
   "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, kernel_initializer='glorot_normal')\n",
    "layer = tfk.layers.Lambda(lambda x: x)\n",
    "\n",
    "# layer = tfp.layers.DenseFlipout(K, activation=None)\n",
    "\n",
    "alpha_dist = tfd.Uniform()\n",
    "mu_1 = 0.\n",
    "mu_2 = 2.\n",
    "mu_3 = 3.\n",
    "scale_p = .1\n",
    "scale_q = .1\n",
    "scale_m = 1.\n",
    "lam = tf.placeholder('float',1)\n",
    "p = tfd.Normal(loc=mu_1, scale=scale_p)\n",
    "q = tfd.Normal(loc=mu_2, scale=scale_q)\n",
    "eps_dist = tfd.Normal(loc=0, scale=1.)\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",
    "alpha = alpha_dist.sample([bs])\n",
    "eps = eps_dist.sample([bs])\n",
    "# m_samples = tf.sqrt(1-alpha*alpha)*p_samples + alpha*q_samples\n",
    "m_samples=samples\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": 120,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 350
    },
    "id": "QH5eP5NclBEf",
    "outputId": "1528f37f-1766-4013-a7aa-9575528d532f"
   },
   "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+8\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": 125,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 296
    },
    "id": "c8oVgSoXEAv_",
    "outputId": "b96b4a62-f99a-4209-bd09-c9019986cbe3"
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "a2e950e1390a477a9f17bf1a544d3c26",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(FloatProgress(value=0.0, max=6000.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f52786dafd0>"
      ]
     },
     "execution_count": 125,
     "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,12000))\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='TRE')\n",
    "ax.set_xlabel('Iterations' )\n",
    "ax.set_ylabel('Loss')\n",
    "plt.legend(loc='upper right')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 126,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 342
    },
    "id": "08mK99A8IL2n",
    "outputId": "f84294b1-01bf-4224-d854-eb065edb1b59"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "KL :  199.99998\n",
      "KL from samples :  201.08546\n",
      "KL from CoB:  146.80557\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(0.0, 5.0)"
      ]
     },
     "execution_count": 126,
     "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(0,5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 127,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 301
    },
    "id": "ja9hDBCPlg12",
    "outputId": "59dbb3c9-787f-4aa8-9e12-08dc1f4d2778"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-400.0, 1000.0)"
      ]
     },
     "execution_count": 127,
     "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.99,s=5.)\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.59,s=5.)\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": 128,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 301
    },
    "id": "gHtEC7YB-jah",
    "outputId": "54db48a6-66e4-4c56-ce94-a01ad0ca2991"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-400.0, 400.0)"
      ]
     },
     "execution_count": 128,
     "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_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+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(-400,400)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "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": 61,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 483
    },
    "id": "CBGq-0XIXFvv",
    "outputId": "8b307a0b-fd51-4d0a-c39f-4105d1b2d45c"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Taking 500 samples from posterior distributions on weights\n",
      "\n"
     ]
    },
    {
     "ename": "AttributeError",
     "evalue": "'Dense' object has no attribute 'kernel_posterior'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mAttributeError\u001b[0m                            Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-61-e1b9ed628d56>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      4\u001b[0m \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34mf\"Taking {n_posterior_samples} samples from posterior distributions on weights\\n\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 6\u001b[0;31m \u001b[0mw_draw\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlayer\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mkernel_posterior\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msample\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[0m\u001b[1;32m      7\u001b[0m \u001b[0mb_draw\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlayer\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbias_posterior\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msample\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      8\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mAttributeError\u001b[0m: 'Dense' object has no attribute 'kernel_posterior'"
     ]
    }
   ],
   "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_p)-norm.logpdf(xs,mu_2,scale_q),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": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "TKRJIoITkBi0",
    "outputId": "5c16db14-4d30-4fed-d9e0-9e9887a236a4"
   },
   "outputs": [],
   "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[:]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "qjhbHCqE9nyi"
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "collapsed_sections": [],
   "name": "KLD_on_Experiment_TRE_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
}
