{
 "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": 2,
   "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": 20,
   "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": 21,
   "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",
    "kl_loss = sum(layer.losses)/1e+5\n",
    "dloss = dloss_ + kl_loss\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": 22,
   "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": "65b32313b22e46edba933081286b2b83",
       "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 0x7fe588314b50>"
      ]
     },
     "execution_count": 22,
     "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",
    "loss1 = []\n",
    "loss2 = []\n",
    "pbar = (range(0,26000))\n",
    "for i in tqdm(pbar):\n",
    "    # Train\n",
    "    feed_dict = {}\n",
    "    l1, l2, _ = sess.run([dloss_, kl_loss, c_optim],feed_dict=feed_dict)\n",
    "    loss1.append(l1)\n",
    "    loss2.append(l2)\n",
    "\n",
    "fig = plt.figure()\n",
    "ax = plt.axes()\n",
    "plt.plot(loss1, label='dloss')\n",
    "plt.plot(loss2, label='kl')\n",
    "ax.set_xlabel('Iterations' )\n",
    "ax.set_ylabel('Loss')\n",
    "plt.legend(loc='upper right')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "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:  796.9083\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(-5.0, 5.0)"
      ]
     },
     "execution_count": 23,
     "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": 24,
   "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": 24,
     "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": "iVBORw0KGgoAAAANSUhEUgAAAZAAAAEKCAYAAAA8QgPpAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAABFrklEQVR4nO3de3yU5Zn4/8+VAyEEAoIoKipIsRhAKAE8FsbTgCgqrUXsF0WyLupPt61d+tWgbnGrRLdW7W7RrWWDVlrFWvwpboVH0YhaFYHiCYqCoKKgCBUwhByv7x/3TDJJJuc5z/V+vaYzc8/zzNwz0ufKfbpuUVWMMcaYjsqIdwWMMcYkJwsgxhhjOsUCiDHGmE6xAGKMMaZTLIAYY4zpFAsgxhhjOiXqAURESkXkSxF5L6Ssr4g8LyIfBu4PC3mtWES2iMhmEZkUUl4oIu8GXvtPEZFo190YY0zLYtECeRiY3KTsZmCVqg4FVgWeIyIFwAxgeOCcB0QkM3DOg8AcYGjg1vQ9jTHGxFDUA4iqrgb2Nim+GHgk8PgR4JKQ8sdVtVJVtwFbgPEichSQr6qvq1v5+PuQc4wxxsRBVpw+90hV3QmgqjtF5IhA+THAGyHH7QiUVQceNy0PS0Tm4For5OXlFQ4bNiyCVTcJY/9+2LYN6uogIwMGD4b8/HjXyqSht9+GmprGZf36waBBcalORKxbt+4rVe3f2jHxCiAtCTeuoa2Uh6WqDwEPAYwdO1bXrl0bmdqZxDJvHixcCHl5UF4Ol14KCxbEu1YmzXgeTJrUuCw7G776Kj71iRQR+bitY+I1C+uLQLcUgfsvA+U7gGNDjhsIfB4oHxim3KQznw9yclzwyMlxz42Jsblzm5eddVbs6xEP8QogzwCzAo9nAU+HlM8QkRwRGYwbLF8T6O46ICKnBmZfXRlyjklXfj8sWQLXX+/u/f5418ikoc2bGz8XgZUr41OXWIt6F5aIPAb4gMNFZAfwc+Au4AkR+SfgE+AHAKr6vog8AWwEaoDrVbU28FbX4WZ05QLPBW4m3fn9FjhM3EyaBFVVjcsOPzw+dYmHqAcQVb28hZfOaeH4O4E7w5SvBUZEsGrGGNNpkya58Y+mbrwx9nWJF1uJbpKa57mx9HD/RzYmWjwv/L+52bOhuDj29YkXSfUNpWwWVuryPJg5Eyor3Ri6DYOYWBk8GLZvb1zWuzd8/XU8ahMdIrJOVce2doy1QEzSKitzwSMvz92XlcW7RiZdfBxmgutNN8W+HvFmAcQkLZvFa+KhpASadtxkZKRX11VQoi0kNKbdgrN4y8pc8LDuKxNtwTG3pmbNal6WDmwMxKQuz7PoYiJqwAD44ovGZYMGuYw6qcbGQEz6Co6wL1zo7m2alomApsED4Le/jX09EoUFEJOabITdRFhhYfOyPn3Su3FrAcSkJhthNxFUUgLr1zcvX7o09nVJJDaIblKT3++WBC9fDlOnpvefiabLHnyweZll0bEAYlKV58F997nuqy1bXP9Duv+/3XSK58FnnzUu69MnfRImtsa6sExqsjEQEyHXXOP2LAs12TbUBiyAmFTl81ElOVTsLadKbAzEdE5hYfOUJXl5LueVsS4sk6I8/CxiCeO1jDX4uBo/1oFlOsLzwg+cL1tmvaFBFkBMSiorg/+t9vOXbD9aDZNLbVGh6ZhwuyPn59s/n1DWhWVSUq9eUFHhZvGeedDjsmdnwq9/DZdc4uZkGtMKz4PVq5uX33xz7OuSyCyAmJR04ADk5kLPnnBOVhlZVeVw6JCLKnfcYSvTTauuuaZ5wsSRI9MzYWJrLICYlOTzucHOjAxYm+cjS9RNpckI/JO3WVmmBSUlzQfOAe65J+ZVSXg2BmJSUuNMvX4y193mWh7gIovNyjItuO++5mW5uTb2EY4FEJOyQlcKexSzY2oh5+9azFEDUjsDtek8z4Pdu5uXz5gR+7okAwsgJuUFE/OeUQ4XVayiOreS7BdftD1wTTOXXda8rEcPKC2NfV2SgY2BmJQXXJT+3boysrSSA3W2Ot00V1ISfk/zW2+NeVWSRlwDiIjcKCLvi8h7IvKYiHQXkb4i8ryIfBi4Pyzk+GIR2SIim0VkUjzrbpKHzwcisPKQjypyyDhUTnmtrU43jd12W/Oyb33LZl61Jm4BRESOAX4EjFXVEUAmMAO4GVilqkOBVYHniEhB4PXhwGTgARHJjEfdTXLx++H88+HFLD9XsISFXM+M6iV4tjbdBBQWQm1t47KMDPjww/jUJ1nEuwsrC8gVkSygB/A5cDHwSOD1R4BLAo8vBh5X1UpV3QZsAcbHtromWc2eDd26uRQn/5axgBez/NaDZept2NC8LF33Oe+IuAUQVf0MuAf4BNgJ7FNVDzhSVXcGjtkJHBE45Rjg05C32BEoa0ZE5ojIWhFZuzvclAqTdvx+15edmwvduzeZyet5MG+eLS5MY9nZjZ/n5NjAeXvEbRZWYGzjYmAw8DXwJxGZ2dopYcrCzsdU1YeAhwDGjh1rczYN4PqyCwubpMQKTtGqrIRFi2xmVhoaOtT95w8SgWeeiV99kkk8p/GeC2xT1d0AIrIMOB34QkSOUtWdInIU8GXg+B3AsSHnD8R1eRnTbs12kQvdN6S83D23AJI2CgvdfmOhDjvM/gm0VzzHQD4BThWRHiIiwDnAJuAZINj7OAt4OvD4GWCGiOSIyGBgKLAmxnU2qcb2Tk9bLe1zfvHFsa9LsopbC0RV3xSRJ4H1QA3wN1y3U0/gCRH5J1yQ+UHg+PdF5AlgY+D461W1NuybG9NeoTlPevVqWBtif4KmvEcfbV72rW/Z2EdHiDZNOZlixo4dq2vXro13NUwi8zx31VixwqVgzcmxsZA0MGAAfPFFw/M+feAf/4hbdRKOiKxT1bGtHRPvabzGxJfnUf69mVQufYq6ffshK8tWqaeBoqLGwQNgki1N7jALICat/XVBGdXllXxDTwBq9tlYSKrzPHjkkcZlGRkuqJiOsQBi0toTX7r0JpnUsJ98XuozzbqvUtzFF7utYULNmmX/yTvDsvGatHbkFX6umLeECZTxMj6qRvhRsCQnKWroULcxZajevW3gvLMsgJi05hLl+Xn0UT+ffAKZf3PrCq0RkpqarvkAGD065tVIGdaFZdJecTFccglkZrr1hDaGnrr69GleNm9ezKuRMiyAGIOtJ0wHxxzTfL+PBQuspdkV1oVlDE33UAc/HswrC0maZZLZMcfA5yGJj/LyYNky+0/bVbaQ0JimQhMs2qLClCBhUrGm+KWvy2whoTGdEZpg0QZEkl64LP15ebGvRyqyAGJMUz4fVZJDxd5yqsQGRJLdNdc0L1u2LPb1SEU2BmJMEx5+FrGE8VrGGnxcjd/WhSSpoiLYvr1xWa9e1iMZKRZAjGmirAxWqp9X+/kpL4dvldkFJxmVlMDixc3LL7009nVJVdaFZUwTNqU3Ndx3X/OyQYNs1XkkWQvEmCaaTekNbn3bqMAkMs+D3bubl//2t7GvSyqzabzGtMWm9Sadww5rvmhw9mxrfXSETeM1JhKC03pVYc8et3zZJKyioubBIzfXgkc0WAAxpi0+HzWVNeiBA2hdHaxe7UZoTUIKt1XtjBmxr0c6sABiTBs8/GypPh4ARVBVWL48zrUy4ZSUQE1N47KMDGt9RIsFEGPaUFYGf8y8AkUAN2a4o9ewuNbJhHfXXc3LZs2KfT3ShQUQY9rg88HdUszDXEUtWRwih14vPxs+R4aJG8+D/fsbl2VlWesjmiyAGNMGvx9OOw12MoByevAP+pJZYzmyEk24uQ1XXBH7eqSTuAYQEekjIk+KyN9FZJOInCYifUXkeRH5MHB/WMjxxSKyRUQ2i8ikeNbdpJd58+DNHLd/eg/KqajLYV0vX7yrZQI8D159tXGZLRqMvni3QH4NrFDVYcAoYBNwM7BKVYcCqwLPEZECYAYwHJgMPCAimXGptUk7fj/kTfNTlL2E0u7XMyd3CX8+YGtBEsXcuVBb2/A8M9MWDcZC3Faii0g+MAG4CkBVq4AqEbkY8AUOewQoA24CLgYeV9VKYJuIbAHGA6/HtOImbc2eDTNX+Xml0k9ODlzni3eNDLjWx3vvNS47+mhb69kpoRkX2iGeqUxOAHYDi0VkFLAO+DFwpKruBFDVnSJyROD4Y4A3Qs7fEShrRkTmAHMAjjvuuOjU3qSdsClOTNxdeWXzzaGuuy4+dUlqoRkXFi2iD+S3dUo8A0gWMAb4F1V9U0R+TaC7qgVh9hQjbB4WVX0IeAhcKpOuVtSYIL/fAkciKSqCL75oXNa/PxQXx6c+Sa2szGUQFYHycnpBr7ZOiecYyA5gh6q+GXj+JC6gfCEiRwEE7r8MOf7YkPMHAiG7HBsTB57nRthtSm9cPPlk87Ibb4x9PVJCr15QUeGCSEUFdVDb1ilxCyCqugv4VES+HSg6B9gIPAMEl/7MAp4OPH4GmCEiOSIyGBgKrIlhlY1pzPOomj6TinsXUjV9pgWRGCspgQMHGpcdeaS1PjrtwAGXNKxnT8jNJQPanKQU71lY/wL8QUTeAUYDC4C7gPNE5EPgvMBzVPV94AlckFkBXK+qbUZIY6Llo8VlVOyv5OuqPCr2V/LR4rJ4VylteB7cdlvjsowM+P3v41OflODzuc3iMzIgL48DcKCtU+K6H4iqbgDCpQs+p4Xj7wTujGadjGmvMvUxlUX0oJwqcihTHyfEu1Jp4sorG0/bBfjud218qkOa7nHTZJbI15Mm7W/jHWxDKWM6a2CRn+tXLGF8RRlrcn1cXWRXr1gIN3CekeGGokw7BWdclZfDr38Nl10GAwa4YNKB7Qri3YVlTNLy++HqJ/zs/dcFTB+yjm9dVMDHg302FhJl4fY5nzXLWh8dEpxxdegQHDzoftRf/hKmT+/Qv19rgRjTBX4/dPtVCRPWz3PzzLdvovL8N8l57mm7okXB0KHNyyxhYhhNu6eaLhD86CPXB1hX13BOTY3LRrl4cbv/7VoAMaaL+r62vNEipW51h3h/7mKGv2MBJJI8D7ZsaV5uCRObaLIgkBtvhPvuc88feMAdo+ryvXTrBtXVjVdidmCbc+vCMqaL9p4xtVnZN1t2xqEmqS1cK6NvX2t9NBPsnqqtdffLl7vgkZfn1nkcOuQeZ2W5NNPdujWcm5vrBpnayQKIMV3kW1nMpuyR9c8V+KbngPhVKEVt3Nj4eZ8+bov6tNd0MWvogsCDB2HnzvrV5eTmQvfu7nFODhx1lLvv29cFkqlTO9T1al1YxkRAxe33sG/edLpTwSFy6XNj+/+KM20rKWmcMDEnB5YujV99EobnuYHv8nL41a9g/ny3IDAry3VNAWzf7locF14Io0bBO++4bqpgS2PVKtdC6d27Q60PsABiTEQUFvtZxxPsX15G/lQfhcU2/hFJ993XuGv+hBNsjgLg+u/27Wt4fvvt8MMfNgSPoMpK1woJjoXk5Lhg0cUMoRZAjImQwmI/WOCIuEmTYPfuxmVpN3DedFZVkDTJMVtdDX//uwsQlZUN5bW1risrOBZSXu7eL7iAsJPR2MZAjDEJy/OaL0vo1SvN8l0Fu6l+9Su46CIoKHB9euDGNELV1cGwYZCf77qxALKz3XHB8Y7g+Ec79/xojbVAjDEJK9yi6EsvjX094mrBgsbdVJs2wS23uMcvvND8+AEDXLfU4sXw3HOu7y8nx+2INnt2RDe0Ee3AnN9kNHbsWF27dm28q2GM6YTjjoNPP214np/f+Fqa8jwPpkxpnvgL4NhjXbdUTU1DWVYW/O//NgSHlrq+2kFE1qlquFyFDR/XoXc0xnRIF/7/m/aKimDHjsZlN7e25VyqCP1Hs2BB+OAB8PnnLmAEA0hGBvz7vzf+hxblHdAsgBgTJZ4Hi6Z7jK8oY9EDPnjCb0GknUpKmue8GjkyDcY+QleR33tv44HwpkRc0OjRw3VT3XZbzH8gCyDGRMmOUo+F+2fSjUpmVS9ieekSa4a00333NS8rKIh9PWLC81y03LkTvvwS9u5tudURKi8PbrrJrfuIUxPXAogxUeKTMrpRyUHy6EE5PikDLIC0paSk+bTdjIwOr3FLfCUl8OijsG2bSy/SESedBPffH/c/SGwarzFRcsJsH7n5OfTpVk5ufg4nzPbFuUbJIVzr44474n6tjKySEpd+ZNOmjgUPEbdiPAGCB1gLxJjo8fvp9sSSltNqJ8AFINEUFTVvfaTM2Ifnwdy5sHkzVFV17NzMTDjzTLeWY/bshPm3Y9N4jYmRD4pKGPToL8jIFLLy89xc/QS5ECQCz4Pzz2+8RUVGhlvKkPQ/06RJHdtoLDPT/RAibqbV/Pkxj6I2jdeYBLGuxOOkxXeQRQVak0HV19AtmErCAC6tU2jwgBTYabCoCP7wh463OC691J2b4K3VNgOIiPQG5gPfDRS9DPy7qqbTch5jumT/8jLqACUDoY7qauXdXj4K412xBLJrV+PnI0cm4V4fnufWbmzY4Hb3a08PT1aWm3UVPLZHj4ZEhwkaOILa0wIpBd4DpgeeXwEsBr4XrUoZk2ryp/qoeH0RAALcnX0rNQf8FkACPA/eeqvheV4e3HNP/OrTKR3tpsrIcHtz5OW5XQPfftt1WSXQGEdb2hNAhqjq90Oe3y4iGyJVARHJBNYCn6nqhSLSF1gKDAK2A9NV9R+BY4uBfwJqgR+p6spI1cOYaCos9vP4h0v45PdlvJrl4418P0t88a5V4pg71+19FDR2bNJcQ51jjnErw9tr9myYMSPhu6ja0p4AUiEiZ6rqqwAicgZQEcE6/BjYBOQHnt8MrFLVu0Tk5sDzm0SkAJgBDAeOBl4QkRNVtR0rboyJvxmlfrwZfr4ug5/38igsKwN8SXvxiJRJk+DddxuXHXVUfOrSIUVFbh1HaC6qlojAeee5RX9TpzYMiCf7f3tVbfUGjAbexrUGPgb+Boxq67z23ICBwCrgbODZQNlm4KjA46OAzYHHxUBxyLkrgdPa+ozCwkI1JqGsXKmVvfvroeweWtMtV3XBgnjXKG4WLFB1nf8Nt4wM1ZUr412zVvj9qiLNKx7uJqI6cWKCf6HwgLXaxvW1zRaIqm4ARolIfuD5/ohELud+4P8CvULKjlTVnYHP2ikiRwTKjwHeCDluR6DMmKTy0eIyjtxXTncOIdRRe/sdZBYWJv9fo51w993Ny4YPT9CfoqTErWgM7WtrTWYm/OUvCfplIqPFACIiM1V1iYj8tEk5AKp6b1c+WEQuBL5U1XUi4mvPKWHKwk5xEJE5wByA4447rrNVNCYqytTHZdyPUIeSQW11LZnz57sXU/hiE8433zQvS7jB8+ACwKb9bC3p0QPGjXMrzVP8v2drqUzyAve9wtx6RuCzzwAuEpHtwOPA2SKyBPhCRI4CCNx/GTh+B3BsyPkDgbCjVqr6kKqOVdWx/fv3j0BVjYmcgUV+fplzGxX0oJZMsuoqqV6z3mVh7cgsniTneW4iUqgxYxLomltS4jYkCTdI05SIy0+1YEHj7WJTXIstEFX9beDhC6r6WuhrgYH0LlHVYty4BoEWyFxVnSkivwRmAXcF7p8OnPIM8EcRuRc3iD4UWNPVehgTa34/LJ5WzIKl8HO9DYCM2mpq9peTlSYXHnDX2Nxcd+2tqoJBg2DdunjXKqAjU3LHjEmgisdWe5Ip/lc7yyLlLuA8EfkQOC/wHFV9H3gC2AisAK5Xm4FlktTs2dA78wBV5NQvLqytISL7VCcDz3NJaEXcUoj+/eG3v237vJgYOrR9wWPMGDdUnqbBA1ofAzkNOB3o32QcJB/IjGQlVLUMKAs83gOc08JxdwJ3RvKzjYkHvx/2XuGjYnFwcaGyLOMyzlhcxgnBA1JUcCwaIDvb5b8KLryOq/a0OjIz4eij4brrUiTDY9e0NgurG26sI4vGs6T2A+m2rb0xETej1M+Cj5aQ+UoZlTm9+FHF3eQ9UQHPPQBPPJEAV9TI8zz4xS+goqJh/OOEE+L8VT0PLrsMvv669eOOPho++ywmVUoWrY2BvAy8LCIPq+rHMayTMWlj7Dw/M2f6WfiPGeSzH+pA91UjpaUpGUBKS6G62nVdBRMnxrXXrrAQ1q9v+zi/H1Za4oum2jMGclBEfikifxGRF4O3qNfMmDTg97us7n0Pa5ilrsD7G8PNWk9ungfLl7uF26rQrRvcemsc4qTnwcknuyZQW8GjRw83s8qCR1jtCSB/AP4ODAZux61If6u1E4wx7ef3w/LDZ7OffKroxn7y+V3N7HhXK+JKSxuvwTvttDgMI3geTJ7spuW2lik3L88FjfJyG+toRXtyYfVT1f8RkR+HdGu9HO2KGZNOjrzCz2XznmACZXxDL6YfUQYeKdWNtXFjnCvQ3oSHs2cnYR75+GhPC6Q6cL9TRC4Qke/gFvEZYyKkuBh8C/zsPsnHrXn3cfpbv4Zp09yUpRTgeW7771AxSZjoeXD55W72VGvBIzsbJk50rQ4LHu3WnhbIHYFNpf4Vt/4jH/hJNCtlTDoqLgYOlFFzbzlaWQEoMn++G+hN8pbIlVc2Tlqbne3+0I+qkhK45Za2N3WyFkentdkCUdVnVXWfqr6nqmepaiGwNwZ1MybtrOvlo6aylmCat7qqKli8OL6V6qJJk+CLLxqXnX56FGNicJB83rzWg0efPtbi6KLWFhJm4nYhPAZYoarvBRIgzgNyge/EporGpI8/H/DzjZzKBH05EEKEnTuVZNgeoyWvvda8bN68KH2Y58GUKW6L2NasXJn0rbpE0FoL5H+Aq4F+wH+KyGLgHuA/VNWChzFR4PPBL7PmsY/e9TOyFlMU72p1WkmJ2/I7VNQSJnqeGzdqLXhkZLhpuRY8IqK1MZCxwMmqWici3YGvgG+p6q7YVM2Y9OP3w4LT/Ux/+QkmUsZqfPQ9Kjkvdk2HILKz4ayzorSkwvPgwgvdKsVw8vLcToBJtN94MmgtgFSpah2Aqh4SkQ8seBgTffPmwfQNflYf8tO9OzyRpEtCli93wSMjw606Hzs2SsGjpAT+7d9a3lrWUpBETWsBZJiIvBN4LMCQwHMBVFVPjnrtjElDfr9LhVVW5rq0kvEPZs9zK83BBQ8R1wCIuJKS1gdU0jjVeiy0FkBOilktjDGN+P3JGTjABY/p013CxJwclyzxiisivKDb89xYxurV4V8fNMjlh0/WHzFJtJZM0RIoGpMoPC9pmiSlpbB/f8Pzk0+OcPCwVkfCaM9KdGNMPHkeVdNnUnHvQmoumgYFBQm9Ql2k9edd4nkWPBKIBRBjEtxHi8uo2F9JdaWSWXkQ3bTJTW9K0CCSm+sGzjMyID8/wivOr7yy5df8fgseMWYBxJgEV6Y+qsihB+UAKOKmNy1fHueaNVdU5BbO19a62/e+F6Eet+Dq8qZL2oNmz7aU63HQZgARkXdF5J0mt1dE5D4R6ReLShqTzgYW+bk+fwl/zfguiiCo6xfq1q19e3fHiOfB73/fuOzvf4/QG194oUvBHs6CBZaOJE7ak0zxOaAW+GPg+YzA/X7gYSAak/OMMQF+P/CEnxVlfr5cWcKYjY8ysPZjuv3tbzBzptuRKgEG1ufObb4IPCJTd6+8MvwCwR494KmnEuK7p6v2dGGdoarFqvpu4HYL4FPVu4FB0a2eMQbcNbJXL5j+t2IeO3QJB6uzOKB5UFnpZmfFWVFR8wbCyJFdnH1VUuJWkIfrtsrJseCRANoTQHqKyCnBJyIyHugZeNrC0k9jTKQFV3a/Im5MhPJydyGN66birofp0Ucbl2VkwD33dOFNCwvdbKvQLQyDBg2CZ56x4JEA2hNArgYWicg2EdkOLAKuFpE8oNPTQETkWBF5SUQ2icj7IvLjQHlfEXleRD4M3B8Wck6xiGwRkc0iMqmzn21MMpo61Q19rFQ/V7CEp4+5nnU3xr/7qrTUrTYPNWtWF6pVWNjyXuVjxsC2bXH/zsYRbWuzleCBblMpUdWvI/LBIkcBR6nqehHpBawDLgGuAvaq6l0icjNwmKreJCIFwGPAeOBo4AXgRFVtNW/z2LFjde3atZGosjFxV1Li/tr/+GOX5XaSeNx1fhknzPbF5aIaXHW+f39D3qtZs7owpj1pUssTA2yNR0yJyDpVHdvaMe2ZhdVbRO4FVgEviMivAsGkS1R1p6quDzw+AGzC7T1yMfBI4LBHcEGFQPnjqlqpqtuALbhgYkzaKC6GSy5xwWNKlsfC/TMZ+GT8tr8tK3OB47DDXG/a9OldCB4lJS0Hj9mzLXgkoPZ0YZUCB3CbS03Hzb6K6BZpIjIIt0HVm8CRqroTXJABjggcdgzwachpOwJlxqQVn89drAu/KaOHlpNde8iNFdx2W8yDSLAuNTURWDT44IPNy4480nYNTGDtCSBDVPXnqvpR4HY7cEKkKiAiPYE/Az9R1f2tHRqmLGz/m4jMEZG1IrJ29+7dkaimMQnD73czd/tO89EtG9A693+E2lq4446YrQ0Jpue68Ua4/vouzCYOzrb69NPG5X4/7Npl4x0JrD0BpEJEzgw+EZEzgIpIfLiIZOOCxx9UdVmg+IvA+EhwnOTLQPkO4NiQ0wcCn4d7X1V9SFXHqurY/v37R6KqxiQUv98tMLw7+1aqyUQBlcD/nWMwrTc49nHvvXD33V3I8VhUFH621bHH2sryJNCeAHItsFBEtgdmYf0GuKarHywigts2d5Oq3hvy0jPArMDjWcDTIeUzRCRHRAYDQ4E1Xa2HMcmqrAx+mVXMXbm/oIIeVGZ0d3/Jx2Ba7+LFbuC8qsrdL+5Mp7bntXziddd1qX4mNtoMIKr6tqqOAk7GbXH7HeDsCHz2GcAVwNkisiFwmwLcBZwnIh8C5wWeo6rvA08AG4EVwPVtzcAyJpX5fG5a7/xDxXyPp1iY+eOYTettOnmznZM5G3gezJ8f/rUxYyKc/91ES7un8TY6SeQTVT0uCvWJOJvGa1LZjBluQXZOjluUPm0aPF4U3b1DPM+NaS9f7gbPc3PdDort/qiSEjdWU1vrKh3Ktp9NGBGZxtvSe3fyPGNMBBUVuQv4N9+4dFGVy93eISxc6PJkRXhA3fPc2z73HGRnu2y7HQ4et93mxjyqq13k690bund3b2LBI6l0NoB0vNlijIk4vx/OP98l5j3sMDijpozaQ5VuLCQKebLKytzb5uW5bqvBgzsQPDwPfv7zhoyLdXWQmekiUEWFDZonoRYDiIgcEJH9YW4HcCvBjTEJYPZstwajpgbW5PrI7B6dPFmeBx995MZdOvz2wWlboVl1ReDWW22abhJrbU/0XrGsiDGmc4LrQtywh59uLIn4GEjw+l9R4VbBX3SRC1ztenvPgylTmud6HzjQBsuTXHv2AzHGJDi/v+Fi7nl+yvDjA/xeZAbUS0vddF1wjQjVDrxduI1CwKbqpgALIMakkOAgd2UlbHnAw8dMumkl/PrXcPzxcMUVnfqrX6T15y0qKYGNG5uX+/3W+kgBtie6MSkkdJB7fEVgQF3VzXratAluuaVT+bKC4yzdurUz55XnuVbPvHnNWx9jxtiAeYqwAGJMCgkmNywvDxlQ/+abhgNU4b77Ovy+fr+bLPXTn7Zj2m5wwOTll93zYHMlK8uy6qaYTi0kTCa2kNCkm0bDHnhw9dXNExXOnh29DLc+X0PwCBKBO++0bqsk0p6FhBZAjEl1nuc2ampq5crIT6EtKmqe36pfP/jXf7XgkWSiuRLdGJMEPA/mlfmp7pbb/MVIZ+2dNKl58MjOhj/+0YJHirIAYkyKCs7IWrgQ/iQzGqePyM52qwIjleqkqCj8e51+ui0UTGEWQIxJUaEzsq7LKWXtyNmuO2nQIBdA/vxnmDo17KyskhJ37W/XhK2SEnj44eblOTluFpZJWRZAjElRoTOyKivh/M9LKbroKzjlFDett6bGbehx662NIkVJiZvt+/rr7Zj163kus27TsdRBg+CZZ6z1keIsgBiTooIpTo4/3gWQPXvcEMXbK3c1PrCurtFWuI8+6uKBiLtfvryFDwju6VFbCxmBS4mIm+G1bZsFjzRgAcSYFOb3u8AR6v2vB4RPp11WRlGRW28IDY2KqVPDHBscYHn7bdeKyc6GHj3cVN1oTQ82CccCiDEprukM3ocpYj+9G1oN2dkAlKzzN5tENXJkCxOoyspc31hGhluePmaM29nKZlulFQsgxqS40tKGWAHwPH5+wBN8NP0m192UlQW1tSx/PoemW/0UFIR5Q8+Dv/7Vpeb95hvXApk61bqs0pAFEGPSwLnnNn7+YqafRYMXwIABIIJXOZFueggXQFwQyclxs3MbCXZdvf666+Pq3t1tiXjgQCy+hkkwFkCMSQMrV7peJnCbAPbtG9gMyufDqz6L6SzlDU4jh0qOzf2KiRPDTKIKDpqXl0PPng2j7Hl5Ed24yiQPS+duTJpYt65Jniw/gJ8FPfqzb19vQBHgjMrlPPbRXFh3HfgDYxrBBInl5Q3ZdfPz3X667d5ZKjaqq6vZsWMHhw4dindVkkL37t0ZOHAg2YGxsI6wAGJMGgluPFVU5K77I0bAGwdPDrwqKIrW1bjki8FFgMXFjXeUUnVzg++/P6ECR9COHTvo1asXgwYNQtq9cUl6UlX27NnDjh07GDx4cIfPty4sY9JMMN/h55+7hkV1bWZ9xvVuVFHEww0HP/iguw+9EIvAqFEJGTwADh06RL9+/Sx4tIOI0K9fv0631pIugIjIZBHZLCJbROTmeNfHmGTTdC+nujrIyhJ6ZNcwn9vx83zDi59+6paid3hHqfiy4NF+XfmtkiqAiEgmsBA4HygALheRcBMNjTEtCJfZva4Obr09m+IF+fXrQuotX97BHaVMuki2MZDxwBZV/QhARB4HLgbCbLpsjAmntBQ++6xx8tzaWnjnHeCxwKD5Lbc05DMJLkUPDqCYVu3Zs4dzzjkHgF27dpGZmUn//v0BWLNmDd26dYvq5+/cuZNZs2bhRSrTciuSLYAcA4RurbYDOKXpQSIyB5gDcNxxx8WmZsYkEZ8PXnnFrQWEhhm5gBs0LyuD116DM86w1eUd1K9fPzZs2ADA/Pnz6dmzJ3Pnzq1/vaamhqys6F16V6xYwaRwzcwoSKouLCBcZ12ztD6q+pCqjlXVscHIb4xxSkrcBKtg8AC3GH3UqMCTSZNc86S8HJ5/vp053ZOb57nfJFp/tF911VX89Kc/5ayzzuKmm25i/vz53HPPPfWvjxgxgu3btwOwZMkSxo8fz+jRo7nmmmuoDU6bDjFo0CBuuukmxo8fz/jx49myZUv9aytWrOD8889HVbnhhhsoKCjgggsuYMqUKTz55JMR/V7JFkB2AMeGPB8IfB6nuhiTlB59tHlZba1LyLt16KTGV9HQdLwd2iQkeYRuvDVzZvSCyAcffMALL7zAr371qxaP2bRpE0uXLuW1115jw4YNZGZm8oc//CHssfn5+axZs4YbbriBn/zkJwDU1tayefNmCgoKeOqpp9i8eTPvvvsuv/vd7/jrX/8a8e+UbF1YbwFDRWQw8BkwA/hhfKtkTHI54oiGjLtBdXXwo4MlnLDFQ2nS1A9uOhUcF3njDVeeIl1boRtvlZe759EY6vnBD35AZmZmq8esWrWKdevWMW7cOAAqKio44ogjwh57+eWX19/feOONALz55puccorr1V+9ejWXX345mZmZHH300Zx99tmR+ir1kiqAqGqNiNwArAQygVJVfT/O1TImqcybB2vXuj2lgkkWf1ZbQjF3Nj/Y73eB4vTTXfDIyHDR5je/gcLClBhU9/lg0SIXPHJyopeVJS8vr/5xVlYWdXV19c+D6zBUlVmzZlHSjlZe6PTb4OPnnnuOyZMnhz0mGpKtCwtV/YuqnqiqQ1Q1zL94Y0xLgqlMbrkFbr4Z/vIXePrwIhYwj56UNz7Y729YNDJ1qhtpD1709uyJbn9PDAU33rr+encfi5g4aNAg1q9fD8D69evZtm0bAOeccw5PPvkkX375JQB79+7l448/DvseS5curb8/7bTTANeCCc4AmzBhAo8//ji1tbXs3LmTl156KeLfI6laIMaYzguOjWdnQ58+gYslHnVfuUERwc1IOZSZx44rb+HE0pAuqmB31W9+44JH376wb59LrghJ3xKJ9Qzl73//+/z+979n9OjRjBs3jhNPPBGAgoIC7rjjDvx+P3V1dWRnZ7Nw4UKOP/74Zu9RWVnJKaecQl1dHY899hi7d++me/fu5OfnAzBt2jRefPFFRo4cyYknnsjEiRMj/0VUNaVvhYWFaky6mz1b1fVBuVt2tmpxsbr/ycnROqi/zZMFmpnpzmlm5UrV/v1Ve/Rwb5SVpdq7tytPEBs3box3FaLu+OOP1927dzcqe/TRR7WkpKTFc2bNmqV/+tOfwr4W7jcD1mob19ek68IyxnRc04k81dWBvv5evSAjA8nOplayWMxsFmgxtbUuX1azrvjQjdbBTd/av9+2sU0AM2fO5OabY5vdyQKIMSmupMRtGhjqkh4e/tIZcPfdbmwjO5s/jfh3/onGgSCYS7ERv98tGgkO0Kq6ZewpMB6SLLZv387hhx/eoXMefvhhLr300ojWwwKIMSmu6bqP8/BYWj0Nli514xiZmZCVxSnDD5CT0/jYYC7FZoLJFTMzXSD56COYNi3l1oiY1lkAMSbFNV1GcHvOArpVH2woOHAARDhhto9nnnG9WqGC6wgbCSZXHDfOZeitrnbzgm+5Jcw+uCZVWQAxJoV5Hhx1lFvfkJEBPXrAyCO+bH7g5Mng99cv+wj2ToXmUmzG73ezsDIzG6b3qrrBEwsiacGm8RqTooIpOioroXt3uOQS+Nkoj54rj4BPQ5ai5+U1uuAHZ+wuX+6CR6sLzv1+uPXWhlXqQYsXu3sbXE9p1gIxJkWFpuhQhdvfnEThvEnw17+6psixx8LEibBsWbNFEMXF7rB2ZSspLoarrmpeHnYaV3rYtWsXM2bMYMiQIRQUFDBlyhQ++OCDFo/fvn07ubm5jB49mlGjRnH66aezefPmDn9uSUlJi7mzosECiDEpyudzXVfl5fBUxSRO3B6YJVVd7W4zZ0Yu8VNpKYwc2bw87DSu1KaqTJs2DZ/Px9atW9m4cSMLFizgiy++aPW8IUOGsGHDBt5++21mzZrFggULOvzZnufhj+GKSAsgxqSo4JKN+873OKvaa5wgsX4hSATdc4/rKwv16afucxJ9im8E87m/9NJLZGdnc+2119aXjR49mu9+97uoKj/72c8YMWIEI0eOrE9H0tT+/fs57LDDmpWXlZUxYcIEpk2bRkFBAddee219Tq39+/dTVVVF//792bZtG6eddhrjxo3jtttuo2fPnl3+XuHYGIgxKSaY78rnCzQuwv0lm58f+dwdfj88/TRceqmb2RX08suwYUPiboUbOli0aFGXE2K99957FBYWhn1t2bJl9a2Mr776inHjxjFhwgQAtm7dyujRozlw4AAHDx7kzTffDPsea9asYePGjRx//PFMnjyZZcuWcemll/LCCy/U58H68Y9/zHXXXceVV17JwoULO/1d2mItEGNSSNO9LdaVePDee80PjNaK5abTuIL27YMf/jAxx0RCB4sqK93zKHn11VfrU6wfeeSRTJw4kbfeegto6MLaunUr999/P3PmzAn7HuPHj+eEE04gMzOTyy+/nFdffRVo2EgK4LXXXqtP937FFVdE7ftYADEmhYReC88o9/j2HTPhm28aHxS8yHdQu/eTKi6GO++Efv0al+/Z47qJEm2Kb+hgUQTyuQ8fPpx169aFfU212QaqYV100UWsXr067GtNU7QHn69Zs4bx48e3eFw0WAAxJoWEXgsnahk5VLrMuTk5cPTRrjsrmKK9A4L7Sb3+urtvVxD54x+hd+/mryXa7KwI53M/++yzqays5He/+1192VtvvcXLL7/MhAkTWLp0KbW1tezevZvVq1c3uugHvfrqqwwZMiTs+69Zs4Zt27ZRV1fH0qVLOfPMM3n//fcZNmxY/YZVZ5xxBo8//jhAdGdltZVtMdlvlo3XpJuVK12S3bULAplz8/PdfRcy5p52mku+m5Hh7k87rQOV6dWrcSrgYDrgKGXwTYRsvJ999pn+4Ac/0BNOOEELCgp0ypQp+sEHH2hdXZ3OnTtXhw8friNGjNDHH39cVVW3bdum3bt311GjRunJJ5+sY8eO1TfeeKPZ+7700kt61lln6fTp0/Wkk07Sa665Rmtra/WXv/ylLl68uP64jz76SE899VQdO3aslpSUaF5eXqv17Ww23rhf4KN9swBi0k4wgqxc2fhxFyxYoCrirhgi7nmHTm4aQEB14sQu1akliRBAouWll17SCy64oFn5ueeeq59//nmL50UrgNgsLGNSQHDm1fd7eRTe12RGUSfWEzQVujp92DA3ycrz2tnbU1wMH37YsDo9aPVq15WVInurx9Pzzz8fl8+1AGJMkispgTvucI+P0DJOlkqye+e5gZBILRTEXecLCzs547W01GXsffnlhjJVV/EU2Vs9Fnw+H75ODPJ/03QiRYTYILoxSczz4Be/cIlwDx2CF+t8VBK5GUVNdWnG67x5LoVKkIjbkGr+/MRfaGjCsgBiTBIrK3PX4YwMlxB3VaafzbdGbkZRU6GzvERg27YOXPv9fnjqKZd/KyfHpYGvqoI33nAbth92mAWSJGMBxJgk1quX6wnKzobcXJcYt7DY78Y9otAtFJzxev75LhvKsmUwfXoHg0hZGTzzDIwZ48o0sDbi669dIEmkKb6mVXEJICLySxH5u4i8IyJPiUifkNeKRWSLiGwWkUkh5YUi8m7gtf+UWKySMSaBeR7cdx+cW+fx++oZvPWtyykujP5f8MG4VFHhgkintkQP7iWiYRbW3XqrtUSSRLxaIM8DI1T1ZOADoBhARAqAGcBwYDLwgIhkBs55EJgDDA3cJse60sYkkrIyt9r80arpXFr3BCe9u7SDzYHOa/rnW6f+nPP7oU+f5uV1dTB3bmeqlRD27NnD6NGjGT16NAMGDOCYY46pf17VdHP6KKiurm4xF1ekxSWAqKqnqjWBp28AAwOPLwYeV9VKVd0GbAHGi8hRQL6qvh6Yn/x74JJY19uYROF5blLT/6kqJU8PAOou4ocORTWXU1BwS/Ru3dy4uGon49bSpW4Ap6l333XdWUmoX79+bNiwgQ0bNnDttddy44031j/v1q0bNTU1bb9JF7z66qucfvrpUf2MoEQYAykCngs8Pgb4NOS1HYGyYwKPm5aHJSJzRGStiKzdvXt3hKtrTHzVJ49d7nFezQoyqEMAUXXp1COdpj2M4Jbo06ZBVhY895yrU4eDiN/vTg63l4jnweDBMWlRRTCbe1hXXXUVP/3pTznrrLO46aabmD9/Pvfcc0/96yNGjGD79u0ALFmyhPHjxzN69GiuueYaamtrm73fihUrGDZsGGeeeSY/+tGPuPDCCxu9dv7557N9+3aGDRvGrFmzOPnkk7n00ks5ePBgRL9X1AKIiLwgIu+FuV0ccswtQA0QTNYSriGsrZSHpaoPqepYVR3bv3//rnwNYxJOcCqtT8oA5VD3vkh2Npx0UkxTpvv97vqu6oLI/v3N1wq2+43eecc1a5ravt3t1x7FgfWmGYyjFUQ++OADXnjhBX71q1+1eMymTZtYunQpr732Ghs2bCAzM7NZLqtDhw7xz//8zyxfvpxXXnmFXbt2NXr9pZdeql8rsnnzZubMmcM777xDfn4+DzzwQES/U9QCiKqeq6ojwtyeBhCRWcCFwP8JdEuBa1kcG/I2A4HPA+UDw5Qbk1Y8z02dFYEy9VEtOWRn1LixhPvvj/mCPJ/P1eUf/3Azcp97rgsX4NLS8PVXbWcGx86JVTb3H/zgB/XJDluyatUq1q1bx7hx4xg9ejSrVq3io48+anTM3//+dwYPHszQoUMREWbOnFn/2ueff07fvn3pEVhvc+yxx3LGGWcAMHPmzPrU75ESl5XoIjIZuAmYqKqhbapngD+KyL3A0bjB8jWqWisiB0TkVOBN4Ergv2Jdb2PiyfPcGHlFBUwSjytPKGPvqTdy+IADIbtHxZbf7xoITz0FmZkuxUmXZhCvXOmaNYHunHqqro8JIp76xOdzq+qjtPayXl5eXv3jrKys+p0EwbUqwOUmnDVrFiVtBMuWJqE+99xzTAoZO2op9XukxGsM5DdAL+B5EdkgIv8NoKrvA08AG4EVwPWqGuwAvA5YhBtY30rDuIkxaaG01HUT+ao8FlXOxP/hQk589r64BY+goiLXhVVR4SZQvfxyF7f8+O1v3cKWcObNi3hLJMLZ3Ntl0KBBrF+/HoD169ezbds2AM455xyefPJJvvzySwD27t3Lxx9/3OjcYcOGsW3bNrZu3QrAY489Vv9a6KZSAJ988gmvv/56/XFnnnlmRL9HvGZhfUtVj1XV0YHbtSGv3amqQ1T126r6XEj52kAX2BBVvSGk28uYtBD843EiZXSjkqqs6O+g1x5+Pxx/fOOyLm354ffDs8+GH1iHqHRn+aO39jKs73//++zdu5fRo0fz4IMPcuKJJwJQUFDAHXfcgd/v5+STT+a8885j586djc7t3r07Dz30EBdccAFnnnkmxwd+/NraWj788EOGDRtWf+xJJ53EI488wsknn8zevXu57rrrIvtF2krXm+w3S+duUsHKlaqXXaZ6W/YCfZ+T9AA9tKpH1/f5iJRwGduzsiJQtdmzw6eCB/daGKmczj2cYIr3V155Ra+55pr68m3btunw4cPb9R6dTeeeCNN4jTGtCM4SGvb/lzC/+haGsYk8Ksge953Y9bm0obi4eYOhpqaTs7JCtTSwDu7NLX9WvTPPPJP//u//julnWgAxJsEFV5zPqfoNoCAZCOqmPSVA8Ai6557mQxdNel86Z+XK8FN8wfJn4VK8P/vss83KBw0axHvvvRfVz7YAYkyC+34vj99VzKSv7gksGKxzAyJTp8a7ao34/XD77W5APWjt2gg1EEpLW98Y65ZbujhybzrDAogxCa7wQBm9cyup6tmXuuwc5Oij4c47E3Inv+JiCCw7QMTtU9LlbqzQN2+pxaXqPihGOaCMYwHEmETn85Gdl0N+RjmZffLdhTIBg0fQgAGNkytGdL7kypUNaeDDWb8+Qv1mpj0sgBiT6OKxUKELiopcosXsbJds8Z13IjxEsW6dGxNpaVFcVZUFkRixAGJMMoj1QoUuCCZaPO00t0xl06YoLN0oLYUVK1peK/LZZy5y7dsXwQ9tv127djFjxgyGDBlCQUEBU6ZM4YMPPmjx+O3bt5Obm8vo0aMZNWoUp59+Ops3b+7w5z722GPceeedXal6h1gAMSYBlZTA6acn7+Qiv981BMBla1eF5cuj8CHvvOMCa1aYrExVVfDhhzEPIqrKtGnT8Pl8bN26lY0bN7JgwQK++OKLVs8bMmQIGzZs4O2332bWrFksaG3SQAtWrFjB5Mmx2yrJAogxCaakBMrmeVzw+jzK5nlJG0SmTnW9TMGUT2vXRmmLj+Ji+N//bblL68MP2+7SimA+95deeons7GyuvbY+wQajR4/mu9/9LqrKz372M0aMGMHIkSNZunRp2PfYv38/hx12WLNyVeWGG26goKCACy64gClTpvDkk0/Wv7ZhwwbGjBnD/PnzueKKKzj77LMZOnQov/vd77r8vcKJSzJFY0zLtj7osZTpdKeC63mA+Y8+AcWJ33XVVHCc/+67XSOgutpdnydNcmPhEeX3w1VXtTzl67PP3C0/HwJpQ+rVb7BS6bIqdnGc6b333mtxR8Bly5bVtzK++uorxo0bx4QJEwDYunUro0eP5sCBAxw8eJA333yz2flPPfUUmzdv5t133+WLL76goKCAosD05b/97W+MGjWqPmHiO++8wxtvvEF5eTnf+c53uOCCCzj66KM7/b3CsRaIMQnE8+DKHQvozT66UUU++/nnrI5uOJ44iovdivRQL70UpQ8rLW15wWHQ/v1uED5UrPK543YLvPzyy8nMzOTII49k4sSJvPXWW0BDF9bWrVu5//77mTNnTrPzV69eXX/+0Ucfzdlnn13/WtNEihdffDG5ubkcfvjhnHXWWaxZsybi38cCiDEJZEepx3h9AwjuoqYMHx7ZFNyxFlwXElRdHcWxndJSOOKI1jdpV3X9acFBbZ/P5XGPUD734cOHs65pkKr/6PbNab7oootYvXp12NdaSsnueR7+kJZTtFO5gwUQYxKKT8qoJRMNho+sbm3/VZ3gVq6E3r0blz36aBQ/MDfXLSjMyWn9uGBr5JRTIjpN+uyzz6aysrLRuMNbb73Fyy+/zIQJE1i6dCm1tbXs3r2b1atXM378+Gbv8eqrrzJkyJBm5RMmTODxxx+ntraWnTt38lKgObdv3z5qamro169f/bFPP/00hw4dYs+ePZSVlTFu3Lgufa9wbAzEmAThebBDfVyWt4iaSrdBU+bPb02Kqbttuemmhv2gALZscd83ql9t5Eg3eL57d8OUsKZU3SD7gAGukk0jXSeICE899RQ/+clPuOuuu+jevTuDBg3i/vvvZ8KECbz++uv1YxX/8R//wYABA9i+fXv9GIiq0q1bNxYtWtTsvadNm8aLL77IyJEjOfHEE5k4cSIAzz//POeee26jY8ePH88FF1zAJ598wm233Rbx8Q8AaW+TKlmNHTtW165dG+9qGNMqz4MHp3mccqiMQ9m9uHLaAU6Y7UuJ4BHUdKPBiROjM9ywadMmTjrppOYvbNjQfECmqcMPh0GDIl+pKLnqqqu48MILWbFiBVdffTWnnnoqAPPnz6dnz57MnTu3Xe8T7jcTkXWqOra186wFYkwCWLvA47cHZ7qNoipzWLRzCfNSKHiA61kK1WSr7+gbPdpFsK++avmYr76CPXvg6KPhqKNiVbMuC9daiQULIMbEmedBv/fK6EE5SgY9KKfgyzIgtQLIFVc07sbasycG3VhNBVsXe/a0nKRLtWHab24uDBwYka6taHj44YfDls+fPz8mn2+D6MbEUXAJwmf7e9GDCvL4hh5UUHBqr3hXLeKKi123VUaGuy7X1LhJU9HQatf8oEFukP2YY9p+o4qK9i1ETGJdGcawAGJMHO0o9fi/++bxnYy3qSCXCsmjLieXEwcciHfVomLePOjVCw4dctN5V6yI/IaC3bt3Z8+ePW1fGI86CoYObd63Fs5nn8G770amgglEVdmzZw/du3fv1PnWhWVMvHgelz07k5qqShShhmx65CpZeV1fi5Co/H44/3x46im3bq+mxg2kR7Iba+DAgezYsYPdu3e374SMDBfRvvmm7WN37nQD7e0JOkmie/fuDBw4sFPnWgAxJk7+uqCM4eWV1JBFHt+wa9Bp9L78dBc8UmwAPdTs2bBqlVv0LeIG0yM5FpKdnc3gwYM7fmJJSUPelbb07u2m/SbwviyxENcuLBGZKyIqIoeHlBWLyBYR2Swik0LKC0Xk3cBr/ynRWFZpTIx4Hqz4ay9yOMRh7KUb1Ry5c0PKBw9o2N5kyhT3fNkymDw5SokWO6K42O2xvnIlHHlk68fu2+f64/r0Sd6UyREQtwAiIscC5wGfhJQVADOA4cBk4AERyQy8/CAwBxgauMUuZ7ExEbZnbgk3Vd9BJrUI8A09ycrUqOZhSiR+v1sXcvCgGwtRdUE1IbY19/th1y6XJr5//9aPDQaS/Pzkzr/fSfFsgdwH/F8gdKTrYuBxVa1U1W3AFmC8iBwF5Kvq6+pGxn4PXBLrChsTCetKPC569xfkcpBM6lCgR0Yl2Sk89hGOz+eCR6iopjjpqOJi+PJL1yJpa3HhgQPw+usumBQWRiw1fKKLyxiIiFwEfKaqbzfpiToGeCPk+Y5AWXXgcdPylt5/Dq61AlApIu9Fot4p4HCglVVUaSVuv8VAeg3rT2We++tNUWB/XdXer3bv3vP1pEn741ClOP67GDMmNPNhTQ2I7PoMPtsVn/q0/FucAMcf5l5v3fr1sH49dSUlddtg69cQj/+mkfDttg6IWgARkReAAWFeugWYR/hVUuHGNbSV8rBU9SHgoUA91ra1HD9d2G/RwH6LBvZbNLDfooGItJkDKmoBRFXPDVcuIiOBwUCw9TEQWC8i43Eti2NDDh8IfB4oHxim3BhjTJzEfAxEVd9V1SNUdZCqDsIFhzGqugt4BpghIjkiMhg3WL5GVXcCB0Tk1MDsqyuBp2Ndd2OMMQ0Sah2Iqr4vIk8AG4Ea4HpVrQ28fB3wMJALPBe4tcdDka5nErPfooH9Fg3st2hgv0WDNn+LlE/nbowxJjosF5YxxphOsQBijDGmU9ImgIRLm5JuROSXIvJ3EXlHRJ4SkT7xrlOsicjkQJqcLSJyc7zrEy8icqyIvCQim0TkfRH5cbzrFG8ikikifxORZ+Ndl3gSkT4i8mTgWrFJRE5r6di0CCDh0qakqeeBEap6MvABkFaZ4AJpcRYC5wMFwOWB9DnpqAb4V1U9CTgVuD6Nf4ugHwOb4l2JBPBrYIWqDgNG0cpvkhYBhPBpU9KOqnqqGtwU+g0ar61JB+OBLar6kapWAY/j0uekHVXdqarrA48P4C4S7dhhKTWJyEDgAiA+e8MmCBHJByYA/wOgqlWq+nVLx6d8AAlNmxLvuiSYIto/FTpVHAN8GvK81ZQ46UJEBgHfAd6Mc1Xi6X7cH5l1ca5HvJ0A7AYWB7rzFolIXksHJ9Q6kM7qZNqUlNTab6GqTweOuQXXhfGHWNYtAXQoJU46EJGewJ+Bn6hqsuZs6hIRuRD4UlXXiYgvztWJtyxgDPAvqvqmiPwauBm4raWDk15n0qYEVr6nnJZ+iyARmQVcCJyj6bcIqKVUOWlJRLJxweMPqros3vWJozOAi0RkCtAdyBeRJao6M871iocdwA5VDbZGn8QFkLDSaiGhiGwHxqpqWmakFZHJwL3ARFVt536fqUNEsnCTB84BPgPeAn6oqu/HtWJxEEgJ9AiwV1V/EufqJIxAC2Suql4Y56rEjYi8AlytqptFZD6Qp6o/C3dsSrRATLv9BsgBng+0yN5Q1WvjW6XYUdUaEbkBWAlkAqXpGDwCzgCuAN4VkQ2Bsnmq+pf4VckkiH8B/iAi3YCPgNktHZhWLRBjjDGRk/KzsIwxxkSHBRBjjDGdYgHEGGNMp1gAMcYY0ykWQIwxxnSKBRBj2klEbglkrn1HRDaIyClR/KwyERkbrfc3JhJsHYgx7RBIaX0hMEZVKwPbAnSLc7WMiStrgRjTPkcBX6lqJYCqfqWqn4vIv4nIWyLynog8FFjhHWxB3CciqwN7KowTkWUi8qGI3BE4ZlBgz4VHAq2aJ0WkR9MPFhG/iLwuIutF5E+B/FWIyF0isjFw7j0x/C2MASyAGNNeHnCsiHwgIg+IyMRA+W9UdZyqjgByca2UoCpVnQD8N/A0cD0wArhKRPoFjvk28FBgj5b9wP8X+qGBls6twLmqOgZYC/xURPoC04DhgXPviMJ3NqZVFkCMaQdV/QYoBObg0l0vFZGrgLNE5E0ReRc4Gxgectozgft3gfcDe3BU4tJDBJM6fqqqrwUeLwHObPLRp+I2v3otkHJkFnA8LtgcAhaJyPeAg5H6rsa0l42BGNNOqloLlAFlgYBxDXAyLkHnp4HEc91DTqkM3NeFPA4+D/5/r2kuoabPBXheVS9vWh8RGY9LDDkDuAEXwIyJGWuBGNMOIvJtERkaUjQa2Bx4/FVgXOLSTrz1cSF7Tl8OvNrk9TeAM0TkW4F69BCREwOf1zuQ/PAngfoYE1PWAjGmfXoC/yUifXCbcW3BdWd9jeui2o5LD99Rm4BZIvJb4EPgwdAXVXV3oKvsMRHJCRTfChwAnhaR7rhWyo2d+GxjusSy8RoTJ4GtZJ8NDMAbk3SsC8sYY0ynWAvEGGNMp1gLxBhjTKdYADHGGNMpFkCMMcZ0igUQY4wxnWIBxBhjTKf8PyEN9ZyOMOsEAAAAAElFTkSuQmCC\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
}
