{
 "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",
    "%matplotlib inline\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "from IPython.display import display, clear_output\n",
    "from time import sleep\n",
    "from livelossplot import PlotLosses\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",
    "import sys\n",
    "sys.path.append('../models/')\n",
    "sys.path.append('../')\n",
    "from ratio_utils import *\n",
    "\n",
    "print(tf.__version__)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:From ../models/ratio_utils.py:31: The name tf.reset_default_graph is deprecated. Please use tf.compat.v1.reset_default_graph instead.\n",
      "\n",
      "WARNING:tensorflow:From ../models/ratio_utils.py:32: The name tf.random.set_random_seed is deprecated. Please use tf.compat.v1.random.set_random_seed instead.\n",
      "\n",
      "(100000,)\n"
     ]
    }
   ],
   "source": [
    "num_samples = 100000\n",
    "N=500\n",
    "bs=100000\n",
    "deep=False\n",
    "reset(4)\n",
    "\n",
    "def get_data(mu_1=0.,mu_2=2.,mu_3=0.,scale_p=0.1,scale_q=0.1,scale_m=1.,mtype=\"mix\"):\n",
    "    \n",
    "    p = tfd.Normal(loc=mu_1, scale=scale_p)\n",
    "    q = tfd.Normal(loc=mu_2, scale=scale_q) \n",
    "   \n",
    "    m = tfp.distributions.Cauchy(loc=mu_3, scale=scale_m)\n",
    "    \n",
    "        \n",
    "    p_samples_ = p.sample([num_samples]) \n",
    "    q_samples_ = q.sample([num_samples])\n",
    "    m_samples_ = m.sample([num_samples])\n",
    "    \n",
    "    with tf.Session() as sess:\n",
    "        p_,q_,m_ = sess.run([p_samples_, q_samples_, m_samples_],feed_dict={})\n",
    "        sess.close() \n",
    "    \n",
    "    return p, q, m, p_,q_,m_\n",
    "\n",
    "mu_1=-2.\n",
    "mu_2=2.\n",
    "mu_3=0.\n",
    "\n",
    "scale_p=0.1\n",
    "scale_q=0.2\n",
    "scale_m=2.\n",
    "\n",
    "# Generate dataset\n",
    "p, q, m, p_list, q_list, m_list = get_data(mu_1,mu_2,mu_3,scale_p,scale_q,scale_m)\n",
    "_, _, _, p_list_test, _, m_list_test = get_data(mu_1,mu_2,mu_3,scale_p,scale_q,scale_m)\n",
    "\n",
    "print(p_list.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:From ../models/ratio_utils.py:71: The name tf.variable_scope is deprecated. Please use tf.compat.v1.variable_scope instead.\n",
      "\n",
      "WARNING:tensorflow:From ../models/ratio_utils.py:71: The name tf.AUTO_REUSE is deprecated. Please use tf.compat.v1.AUTO_REUSE instead.\n",
      "\n",
      "WARNING:tensorflow:From ../models/ratio_utils.py:104: 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",
      "[-2.1355526, [array([-0.74844486], dtype=float32), array([0.04896176], dtype=float32), array([-1.5364704], dtype=float32), array([-0.7165909], dtype=float32), array([-0.1574322], dtype=float32), array([-0.41553283], dtype=float32), array([-0.14673996], dtype=float32), array([0.02216816], dtype=float32), array([0.8122548], dtype=float32), array([0.45707667], dtype=float32), array([1.7037987], dtype=float32), array([1.5918928], dtype=float32), array([1.3993071], dtype=float32)]]\n"
     ]
    }
   ],
   "source": [
    "p_samples = tf.placeholder(tf.float32, shape=[None])\n",
    "q_samples = tf.placeholder(tf.float32, shape=[None])\n",
    "m_samples = tf.placeholder(tf.float32, shape=[None])\n",
    "\n",
    "weights = [tf.get_variable('q1',1.),tf.get_variable('q2',1.),tf.get_variable('q4',1.),tf.get_variable('q5',1.),tf.get_variable('q6',1.),tf.get_variable('s1',1.),tf.get_variable('s2',1.),\n",
    "           tf.get_variable('t1',1.),tf.get_variable('t2',1.),tf.get_variable('t3',1.),tf.get_variable('b1',1.),tf.get_variable('b2',1.),tf.get_variable('b3',1.)]\n",
    "prior = tfd.MultivariateNormalDiag(\n",
    "        loc=len(weights)*[0.],\n",
    "        scale_diag=len(weights)*[1.])\n",
    "\n",
    "dloss_func = get_loss(p_samples, q_samples, m_samples, prior)\n",
    "dloss = dloss_func(*weights)\n",
    "t_vars = tf.trainable_variables()\n",
    "\n",
    "init = tf.global_variables_initializer()\n",
    "sess = tf.Session()\n",
    "sess.run(init)\n",
    "\n",
    "ps = p_list[np.random.choice(range(len(p_list)),bs)]\n",
    "qs = q_list[np.random.choice(range(len(q_list)),bs)]\n",
    "ms = m_list[np.random.choice(range(len(m_list)),bs)]\n",
    "feed_dict = {p_samples:ps, q_samples:qs, m_samples:ms}\n",
    "l = sess.run([dloss,t_vars],feed_dict=feed_dict)\n",
    "print(l)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Initialize the HMC transition kernel. Change to NUTS\n",
    "num_results = int(10000) # 10K\n",
    "num_burnin_steps = int(2000)\n",
    "\n",
    "adaptive_hmc = tfp.mcmc.SimpleStepSizeAdaptation(\n",
    "    tfp.mcmc.HamiltonianMonteCarlo(\n",
    "        target_log_prob_fn=dloss_func,\n",
    "        num_leapfrog_steps=3,\n",
    "        step_size=1.), #just small enough to have an acc_rate >.6\n",
    "    num_adaptation_steps=int(num_burnin_steps * 0.8))\n",
    "\n",
    "# NUTS = tfp.mcmc.NoUTurnSampler(\n",
    "#         target_log_prob_fn=dloss_func,\n",
    "#         step_size=1.)\n",
    "\n",
    "NUTS = tfp.mcmc.NoUTurnSampler(\n",
    "    target_log_prob_fn=dloss_func, step_size=1., max_tree_depth=5, max_energy_diff=1000.0, unrolled_leapfrog_steps=1\n",
    ")\n",
    "\n",
    "# adaptive_kernel = tfp.mcmc.SimpleStepSizeAdaptation(\n",
    "#     NUTS, 1,\n",
    "#     step_size_setter_fn=lambda pkr, new_step_size: pkr._replace(step_size=new_step_size),\n",
    "#     step_size_getter_fn=lambda pkr: pkr.step_size,\n",
    "#     log_accept_prob_getter_fn=lambda pkr: pkr.log_accept_ratio\n",
    "# )\n",
    "\n",
    "adaptive_kernel = tfp.mcmc.DualAveragingStepSizeAdaptation(\n",
    "    NUTS, 1000,\n",
    "    target_accept_prob=0.5,\n",
    "    step_size_setter_fn=lambda pkr, new_step_size: pkr._replace(step_size=new_step_size),\n",
    "    step_size_getter_fn=lambda pkr: pkr.step_size,\n",
    "    log_accept_prob_getter_fn=lambda pkr: pkr.log_accept_ratio,\n",
    ")\n",
    "\n",
    "# Run the chain (with burn-in).\n",
    "@tf.function\n",
    "def run_chain():\n",
    "  # Run the chain (with burn-in).\n",
    "  samples, target_lp = tfp.mcmc.sample_chain(\n",
    "      num_results=num_results,\n",
    "      num_burnin_steps=num_burnin_steps,\n",
    "      current_state=weights,\n",
    "      kernel=adaptive_kernel,\n",
    "      trace_fn=lambda _, pkr: pkr.inner_results.target_log_prob)\n",
    "# trace_fn=lambda _, pkr: pkr.inner_results.target_log_prob)\n",
    "    \n",
    "    \n",
    "  sample_mean = tf.reduce_mean(samples)\n",
    "  sample_stddev = tf.math.reduce_std(samples)\n",
    "#   is_accepted = tf.reduce_mean(tf.cast(is_accepted, dtype=tf.float32))\n",
    "  return samples, sample_mean, sample_stddev, target_lp\n",
    "\n",
    "sample_weights, sample_mean, sample_stddev, target_lp = run_chain()\n",
    "\n",
    "ps = p_list[np.random.choice(range(len(p_list)),bs)]\n",
    "qs = q_list[np.random.choice(range(len(q_list)),bs)]\n",
    "ms = m_list[np.random.choice(range(len(m_list)),bs)]\n",
    "feed_dict = {p_samples:ps, q_samples:qs, m_samples:ms}\n",
    "[sw,sm,sstd,tlp] = sess.run([sample_weights, sample_mean, sample_stddev, target_lp],feed_dict=feed_dict)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f2205588d90>]"
      ]
     },
     "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": [
    "plt.plot(tlp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def log_ratio_predictive(x,weights):\n",
    "    posterior_prediction=[]\n",
    "    for i,weight in enumerate(weights):\n",
    "        if i%5==0:\n",
    "            [q1,q2,q4,q5,q6,s1,s2,t1,t2,t3,b1,b2,b3]=weight\n",
    "            h1 = (x-q1)*(x-q1)*s1 + (x-q4)*t1 + b1 \n",
    "            h2 = (x-q2)*(x-q2)*s2 + (x-q5)*t2 + b2\n",
    "            h3 = t3*(x-q6) + b3\n",
    "            pred = h1 - h2\n",
    "            posterior_prediction.append(pred)\n",
    "    posterior_prediction=np.array([xi for xi in posterior_prediction])\n",
    "    return posterior_prediction.T.tolist(), posterior_prediction.T, posterior_prediction.mean(0), posterior_prediction.std(0) # 100 weights x 1000 samplesposterior_prediction"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZAAAAEKCAYAAAA8QgPpAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAAAi50lEQVR4nO3deZRU5Z3/8feHZmlWFUREGgMmiAEFVEQdHNwSJUFFjSg5MeI2TBJ01IwnQpz8gmd01JhxjCNqOC7gkVFQM+okk4xbxJiICIgi4oJLsBUBMRFlb/r7+6Nud0rsbppLdd2u7s/rnDpV9dRdvoV2f/q5y/MoIjAzM9tZbbIuwMzMSpMDxMzMUnGAmJlZKg4QMzNLxQFiZmapOEDMzCyVJg8QSXdJWi3plby27pIel/Rm8rxH3mdTJC2X9LqkE/PaD5W0JPnsZklq6trNzKx+xeiBzABGb9c2GXgyIgYATybvkTQIGA8MTta5VVJZss5twERgQPLYfptmZlZETR4gEfEM8PF2zWOBmcnrmcCpee33R8TmiHgHWA6MkNQb6BYRz0Xuzsd78tYxM7MMtM1ov70iYiVARKyUtFfS3geYl7dcZdK2NXm9fXudJE0k11uhc+fOhx5wwAEFLN3MrOVbuHDhRxHRs6FlsgqQ+tR1XiMaaK9TREwHpgMMHz48FixYUJjqzMxaCUl/3tEyWV2FtSo5LEXyvDpprwT65i1XAXyQtFfU0W5mZhnJKkAeBSYkrycAj+S1j5fUQVJ/cifL5yeHuz6VdERy9dU5eeuYmVkGmvwQlqT7gGOAPSVVAj8FrgPmSLoAWAGMA4iIpZLmAK8CVcCkiNiWbOr75K7o6gj8NnmYmVlG1NKHc/c5ELPmYevWrVRWVrJp06asS7E85eXlVFRU0K5du8+1S1oYEcMbWre5nUQ3sxaqsrKSrl270q9fP3wfcPMQEaxdu5bKykr69++/0+t7KBMzK4pNmzbRo0cPh0czIokePXqk7hU6QMysaBwezc+u/DdxgJiZWSoOEDMzS8UBYmatwtq1axk2bBjDhg1j7733pk+fPrXvt2zZUpB9HHPMMTSnqz6nTp3Kz3/+8ybbvq/CMrNWoUePHixevBjI/WLt0qULl19+ee3nVVVVtG1ber8Ss6y79P61zKz0XXopJL/MC2bYMLjppp1a5dxzz6V79+68+OKLHHLIIXTt2vVzwXLggQfy61//mn79+nHvvfdy8803s2XLFg4//HBuvfVWysrK6t32fffdx7/9278REYwZM4brr78egDvvvJPrr7+effbZhwEDBtChQwduueWWeusrLy9n6dKlrFq1ihtvvJGTTjqJGTNm8Jvf/IZNmzaxfv16HnzwQc4//3zefvttOnXqxPTp0xkyZAgAL730EscddxzvvfceP/rRj/iHf/iHnfo3aogDxMxatTfeeIMnnniCsrIypk6dWucyy5YtY/bs2fzxj3+kXbt2/OAHP2DWrFmcc845dS7/wQcfcMUVV7Bw4UL22GMPTjjhBB5++GFGjBjBv/7rv7Jo0SK6du3Kcccdx9ChQxus791332Xu3Lm89dZbHHvssSxfvhyA5557jpdffpnu3btz8cUXc/DBB/Pwww/z1FNPcc4559T2tl5++WXmzZvH+vXrOfjggxkzZgz77LNP6n+vfA4QMyu+newpNKVx48Y12JMAePLJJ1m4cCGHHXYYABs3bmSvvfaqd/kXXniBY445hp49c6Ohf+c73+GZZ54B4Oijj6Z79+61+37jjTca3PeZZ55JmzZtGDBgAPvttx+vvfYaAF//+tdrt/Pss8/y0EMPAXDcccexdu1aPvnkEwDGjh1Lx44d6dixI8ceeyzz58/n1FNPbXCfjeUAMbNWrXPnzrWv27ZtS3V1de37mhvsIoIJEyZw7bXXNmqb9Q0RlWboqO3v06h5n193XdutWa6+9QvBV2GZmSX69evHokWLAFi0aBHvvPMOAMcffzwPPvggq1fnZp74+OOP+fOf658u4/DDD2fu3Ll89NFHbNu2jfvuu4+jjz6aESNGMHfuXP7yl79QVVVV22toyAMPPEB1dTVvvfUWb7/9NgMHDvzCMqNGjWLWrFkAPP300+y5555069YNgEceeYRNmzaxdu1ann766dpeVCG4B2JmlvjWt77FPffcw7BhwzjssMPYf//9ARg0aBBXX301J5xwAtXV1bRr145p06bxpS99qc7t9O7dm2uvvZZjjz2WiOCb3/wmY8eOBeDHP/4xhx9+OPvssw+DBg1it912a7CmgQMHcvTRR7Nq1Spuv/12ysvLv7DM1KlTOe+88xgyZAidOnVi5syZtZ+NGDGCMWPGsGLFCn7yk58U7PwHeDReMyuSZcuW8dWvfjXrMjL32Wef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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABswAAAE5CAYAAAA0vwWvAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAACFJUlEQVR4nO3dd5gkVd238fu3S845RwFRQOJKEB8UUEFAARUFRTAnzK8BxACmNT2KCgZM4CMq5hxBAQNpkQUkgyAiCIiBIMFlz/vHqWZrejpXz1T3zv25rtmdOV3fqtNVp6pOdYWOlBKSJEmSJEmSJEnSTDWr7gpIkiRJkiRJkiRJdfKEmSRJkiRJkiRJkmY0T5hJkiRJkiRJkiRpRvOEmSRJkiRJkiRJkmY0T5hJkiRJkiRJkiRpRvOEmSRJkiRJkiRJkma0KT9hFhFfjIjbI+KPpbLVIuKXEXFt8f+qpdeOiYjrIuLqiNinVL5TRFxWvPaJiIiprrskSZIkSZIkSZIWf9Nxh9kpwL5NZUcDZ6aUtgDOLP4mIrYCDgW2LjKfiojZRebTwMuALYqf5nFKkiRJkiRJkiRJfZvyE2YppXOAfzQVHwicWvx+KnBQqfzrKaUHUko3ANcBO0fEusBKKaVzU0oJ+HIpI0mSJEmSJEmSJA2sru8wWzuldCtA8f9aRfn6wF9Kw91clK1f/N5cLkmSJEmSJEmSJFWyRN0VaNLqe8lSh/LWI4l4GfnxjSy//PI7PepRjxpO7SRJkiRJkiRJkjQ2Lrroor+nlNbsNlxdJ8xui4h1U0q3Fo9bvL0ovxnYsDTcBsAtRfkGLcpbSimdDJwMMGfOnDRv3rxh1l2SJEmSJEmSJEljICL+3MtwdT2S8QfAkcXvRwLfL5UfGhFLR8SmwBbABcVjG++OiF0jIoAjShlJkiRJkiRJkiRpYFN+h1lEfA14IrBGRNwMvAv4APCNiHgxcBNwCEBK6fKI+AZwBbAAOCql9FAxqlcCpwDLAj8tfiRJkiRJkiRJkqRKIqW2XwW2WPCRjJIkSZIkSZIkSTNTRFyUUprTbbi6vsNMkiRJkiRJkiRp7Pz3v//l5ptv5v7776+7KipZZpll2GCDDVhyySUHynvCTJIkSZIkSZIkqUc333wzK664IptssgkRUXd1BKSUuPPOO7n55pvZdNNNBxrHrCHXSZIkSZIkSZIkabF1//33s/rqq3uybIREBKuvvnqlu/48YSZJkiRJkiRJktQHT5aNnqrLxBNmkiRJkiRJkiRJmtE8YSZJkiRJkiRJkjQm7rzzTrbffnu233571llnHdZff/2H/37wwQeHMo0nPvGJzJs3byjjGobjjjuOj3zkI1M6jSWmdOySJEmSJEmSJEkamtVXX5358+cD+UTSCiuswJve9KaHX1+wYAFLLDF+p3/qrvf4zTFJkiRJkiRJkqQR8J4fXcEVt9w11HFutd5KvOOArfrKvOAFL2C11Vbj4osvZscdd2TFFVeccCJtm2224Uc/+hGbbLIJX/nKV/jEJz7Bgw8+yC677MKnPvUpZs+e3XbcX/va13j/+99PSon999+fD37wgwB84Qtf4IMf/CDrrbceW2yxBUsvvTQnnnhi2/ots8wyXH755dx222189KMf5YADDuCUU07hxz/+Mffffz/33nsv3/rWt3jRi17En/70J5ZbbjlOPvlktt12WwAuueQS9tprL/7yl7/wlre8hZe+9KV9zaNuPGEmSZIkSZIkSZI05q655hrOOOMMZs+ezXHHHddymCuvvJLTTz+d3/3udyy55JK86lWv4rTTTuOII45oOfwtt9zCW9/6Vi666CJWXXVVnvKUp/C9732PnXfemfe85z384Q9/YMUVV2SvvfZiu+2261i/G2+8kbPPPpvrr7+ePffck+uuuw6Ac889l0svvZTVVluN17zmNeywww5873vf41e/+hVHHHHEw3fTXXrppZx33nnce++97LDDDuy///6st956A8+vZp4wkyRJkiRJkiRJGkC/d4JNpUMOOaTjnWIAZ555JhdddBGPfexjAbjvvvtYa6212g5/4YUX8sQnPpE111wTgOc973mcc845ADzhCU9gtdVWe3ja11xzTcdpP/vZz2bWrFlsscUWPOIRj+Cqq64C4MlPfvLD4/ntb3/Lt7/9bQD22msv7rzzTv79738DcOCBB7Lsssuy7LLLsueee3LBBRdw0EEHdZxmPzxhJkmSJEmSJEmSNOaWX375h39fYoklWLhw4cN/33///QCklDjyyCOZO3duT+NMKfVV3klEtPy7XO9W420M1y4/LLOGOjZJkiRJkiRJkiTVapNNNuEPf/gDAH/4wx+44YYbANh777351re+xe233w7AP/7xD/785z+3Hc8uu+zC2Wefzd///nceeughvva1r/GEJzyBnXfembPPPpt//vOfLFiw4OG7wjr55je/ycKFC7n++uv505/+xJZbbjlpmD322IPTTjsNgLPOOos11liDlVZaCYDvf//73H///dx5552cddZZD98lNyzeYSZJkiRJkiRJkrQYeeYzn8mXv/xltt9+ex772MfyyEc+EoCtttqK9773vTzlKU9h4cKFLLnkkpx00klsvPHGLcez7rrrMnfuXPbcc09SSuy3334ceOCBALztbW9jl112Yb311mOrrbZi5ZVX7linLbfckic84QncdtttfOYzn2GZZZaZNMxxxx3HC1/4QrbddluWW245Tj311Idf23nnndl///256aabeMc73jHU7y8DiEFumxsnc+bMSfPmzau7GpIkSZIkSZIkaTFw5ZVX8uhHP7ruatTunnvuYYUVVmDBggUcfPDBvOhFL+Lggw9uOewLXvACDjjgAJ71rGdNaZ1aLZuIuCilNKdb1kcySpIkSZIkSZIkqS/HHXcc22+/Pdtssw2bbropBx10UN1VqsRHMkqSJEmSJEmSJKkvH/nIRyaVve997+Ob3/zmhLJDDjmEU045ZZpqNThPmEmSJEmSJEmSJKmyY489lmOPPbbuagzERzJKkiRJkiRJkiRpRvOEmSRJkiRJkiRJkmY0T5hJkiRJkiRJkiRpRvOEmSRJkiRJkiRJkmY0T5hJkiRJkiRJkiSNkdmzZ7P99tuz3XbbseOOO/L73//+4dcuuOAC9thjD7bcckse9ahH8ZKXvIT//Oc/LcdzyimnsOaaa7L99tuz9dZb86xnPavtsIu7Wk+YRcQbIuLyiPhjRHwtIpaJiNUi4pcRcW3x/6ql4Y+JiOsi4uqI2KfOukuSJEmSJEmSJNVh2WWXZf78+VxyySXMnTuXY445BoDbbruNQw45hA9+8INcffXVXHnlley7777cfffdbcf1nOc8h/nz53P55Zez1FJLcfrpp0/X2xgpS9Q14YhYH3gtsFVK6b6I+AZwKLAVcGZK6QMRcTRwNPDWiNiqeH1rYD3gjIh4ZErpoZregiRJkiRJkiRJmskuOgX+eeNwx7nqJrDTC3oe/K677mLVVfO9RyeddBJHHnkku+22GwARwbOe9ayexrNgwQLuvffeh8f1wx/+kPe+9708+OCDrL766px22mmsueaabLnllvz+979nzTXXZOHChTzykY/kvPPOI6XEK17xCm666SYATjjhBHbffXfOPvtsXve61z1cn3POOYcVV1yxZR0+/OEP841vfIMHHniAgw8+mOOPP77n+VBV3Y9kXAJYNiKWAJYDbgEOBE4tXj8VOKj4/UDg6ymlB1JKNwDXATtPb3UlSZIkSZIkSZLqdd9997H99ts//MjFd7zjHQD88Y9/ZKedduprXKeffjrbb78966+/Pv/4xz942tOeBsDjH/94zjvvPC6++GIOPfRQPvShDzFr1iwOP/xwTjvtNADOOOMMtttuO9ZYYw1e97rX8YY3vIELL7yQb3/727zkJS8B4CMf+QgnnXQS8+fP5ze/+Q3LLrtsy3r84he/4Nprr+WCCy5g/vz5XHTRRZxzzjmDzqK+1XaHWUrprxHxEeAm4D7gFymlX0TE2imlW4thbo2ItYrI+sB5pVHcXJRJkiRJkiRJkiRNvz7uBBumxiMZAc4991yOOOII/vjHPw40ruc85zmceOKJpJQ46qij+PCHP8zRRx/NzTffzHOe8xxuvfVWHnzwQTbddFMAXvSiF3HggQfy+te/ni9+8Yu88IUvBPLJsyuuuOLh8d51113cfffd7L777rzxjW/kec97Hs94xjPYYIMNWtbjF7/4Bb/4xS/YYYcdALjnnnu49tpr2WOPPQZ6X/2q7Q6z4rvJDgQ2JT9icfmIOLxTpEVZajPul0XEvIiYd8cdd1SvrCRJkiRJkiRJ0gjabbfd+Pvf/84dd9zB1ltvzUUXXTTQeCKCpz3taQ/f1fWa17yGV7/61Vx22WV89rOf5f777wdgww03ZO211+ZXv/oV559/Pk996lMBWLhwIeeeey7z589n/vz5/PWvf2XFFVfk6KOP5vOf/zz33Xcfu+66K1dddVXL6aeUOOaYYx7OX3fddbz4xS8e6L0Mos5HMj4JuCGldEdK6b/Ad4DHAbdFxLoAxf+3F8PfDGxYym9AfoTjJCmlk1NKc1JKc9Zcc80pewOSJEmSJEmSJEl1uuqqq3jooYdYffXVefWrX82pp57K+eef//DrX/nKV/jb3/7W07h++9vfstlmmwHw73//m/XXzw/6O/XUUycM95KXvITDDz+cZz/72cyePRuApzzlKZx44okPD9O4A+7666/nMY95DG9961uZM2dO2xNm++yzD1/84he55557APjrX//K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\n",
      "text/plain": [
       "<Figure size 2160x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'KLD')"
      ]
     },
     "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": [
    "x_s = ps\n",
    "sw_=sw[-500:]\n",
    "post,kl_post, post_pred,post_std = log_ratio_predictive(x_s, np.squeeze(np.asarray(sw_).T))\n",
    "\n",
    "x_sorted = []\n",
    "m_sorted = []\n",
    "s_sorted = []\n",
    "p_sorted = []\n",
    "[(x_sorted.append(a),m_sorted.append(b), s_sorted.append(c), p_sorted.append(d)) for a,b,c,d in sorted(zip(x_s,post_pred, post_std, post))]\n",
    "\n",
    "fig1, ax = plt.subplots()\n",
    "plt.plot(x_sorted, norm.logpdf(x_sorted,mu_1,scale_p)-norm.logpdf(x_sorted,mu_2,scale_q),label='True log_prob',c='r')\n",
    "plt.plot(x_sorted, m_sorted,label='BC_Bayes_e',alpha=0.7)\n",
    "quan = [np.abs(np.quantile(p_, .05)-np.quantile(p_, .95)) for p_ in p_sorted]\n",
    "plt.errorbar(x_sorted, m_sorted, yerr = quan,label='BC_Bayes_e')\n",
    "\n",
    "#     plt.scatter(x_sorted,norm.logpdf(x_sorted,mu_1,scale_p)-norm.logpdf(x_sorted,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(-6,6)\n",
    "plt.ylim(-400,1000)\n",
    "plt.show()\n",
    "\n",
    "fig1, ax = plt.subplots(figsize=(30,4))\n",
    "plt.plot(norm.logpdf(x_sorted[100:400],mu_1,scale_p)-norm.logpdf(x_sorted[100:400],mu_2,scale_q),label='True log_prob',alpha=0.99)\n",
    "plt.plot(m_sorted[100:400],label='BC_Bayes_e',alpha=0.7)\n",
    "plt.boxplot(p_sorted[100:400],widths=0.05,notch=True,labels=x_sorted[100:400], showfliers=False, showbox=False, showcaps=False)\n",
    "plt.xlabel(\"Samples\")\n",
    "plt.ylabel(\"Log Ratio\")\n",
    "plt.legend(loc='upper right')\n",
    "plt.xticks(rotation = -65)\n",
    "plt.locator_params(axis='x', nbins=100)\n",
    "plt.ylim(-400,1000)\n",
    "\n",
    "plt.show()\n",
    "\n",
    "fig1, ax = plt.subplots()\n",
    "plt.boxplot(kl_post.mean(0),widths=0.5,notch=True, showfliers=False)\n",
    "plt.ylabel(\"KLD\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "200.31814718055992\n"
     ]
    }
   ],
   "source": [
    "true_KL = np.log(scale_q/scale_p) + ((scale_p**2 + (mu_1-mu_2)**2)/(2*scale_q**2)) - 0.5\n",
    "print(true_KL)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# pip install -U tensorflow-probability==0.6.0"
   ]
  }
 ],
 "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
}
