{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "zdgemk5nHdbL",
    "outputId": "332d9159-5b7e-488d-cdf1-803b67f11603"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n",
      "1.15.0\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "\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",
    "\n",
    "print(tf.__version__)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "sys.path.append('../models/')\n",
    "sys.path.append('../')\n",
    "from critics import RatioCritic"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {
    "id": "boCNTMt4BEiY"
   },
   "outputs": [],
   "source": [
    "tol = 1e-35\n",
    "bs = 500\n",
    "K = 3\n",
    "do = 0.8\n",
    "\n",
    "mu_1 = 0.\n",
    "mu_2 = 2.\n",
    "mu_3 = 3."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {
    "id": "lt5Ozzo0HrUj"
   },
   "outputs": [],
   "source": [
    "tf.reset_default_graph()\n",
    "tf.random.set_random_seed(40)\n",
    "\n",
    "ratio_critic = RatioCritic(K)\n",
    "\n",
    "lam = tf.placeholder('float',1)\n",
    "p = tfd.Normal(loc=mu_1, scale=.1)\n",
    "q = tfd.Normal(loc=mu_2, scale=.1)\n",
    "base = tfp.distributions.Cauchy(loc=mu_3, scale=2.)\n",
    "\n",
    "\n",
    "samples = base.sample([bs]) \n",
    "p_samples = p.sample([bs]) \n",
    "q_samples = q.sample([bs])\n",
    "m_samples = samples\n",
    "# m_samples = samples + (p_samples+q_samples)/2.\n",
    "m_samples2 = m_samples# samples[bs:]\n",
    "\n",
    "#Ratio by log of prob evaluated at samples from base\n",
    "log_ratio_p_q = p.log_prob(m_samples) - q.log_prob(m_samples)\n",
    "#KL from CoB\n",
    "kld = tf.reduce_mean(log_ratio_p_q) \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "QH5eP5NclBEf",
    "outputId": "1c6f6465-8bb3-4583-c235-2c914da988fb"
   },
   "outputs": [],
   "source": [
    "# Build 2 Discriminator Networks (one from noise input, one from generated samples)\n",
    "\n",
    "disc_real = ratio_critic(p_samples)\n",
    "disc_fake = ratio_critic(q_samples)\n",
    "disc_m = ratio_critic(m_samples)\n",
    "# disc_m_gen = ratios_critic(m_samples2, do,reuse=True)\n",
    "\n",
    "# Build Loss\n",
    "# lab = np.eye(K)\n",
    "# a = np.tile(lab[0],bs)\n",
    "# b = np.tile(lab[1],bs)\n",
    "# c = np.tile(lab[2],bs)\n",
    "\n",
    "a = np.tile([1,0,0],bs)\n",
    "b = np.tile([0,1,0],bs)\n",
    "c = np.tile([0,0,1],bs)\n",
    "\n",
    "label_a = tf.reshape(a,[bs,K])\n",
    "label_b = tf.reshape(b,[bs,K])\n",
    "label_c = tf.reshape(c,[bs,K])\n",
    "\n",
    "\n",
    "disc_loss_1 = tf.reduce_mean(tf.nn.softmax_cross_entropy_with_logits(logits=disc_real, labels=label_a))\n",
    "disc_loss_2 = tf.reduce_mean(tf.nn.softmax_cross_entropy_with_logits(logits=disc_fake, labels=label_b))\n",
    "disc_loss_3 = tf.reduce_mean(tf.nn.softmax_cross_entropy_with_logits(logits=disc_m, labels=label_c))\n",
    "# disc_loss_4 = tf.reduce_mean(tf.nn.softmax_cross_entropy_with_logits(logits=disc_m_gen, labels=label_c))\n",
    "\n",
    "dloss = disc_loss_1 + disc_loss_2 + 1*disc_loss_3 #+ 0.5*disc_loss_4 \n",
    "\n",
    "# Define CoB DRE\n",
    "\n",
    "log_r_p_m = ratio_critic(m_samples, training=False) \n",
    "log_r_p_from_m_direct = log_r_p_m \n",
    "\n",
    "t_vars = tf.trainable_variables()\n",
    "c_vars = [var for var in t_vars if 'critic' in var.name]\n",
    "\n",
    "c_optim = tf.train.AdamOptimizer(learning_rate=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": 46,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 297
    },
    "id": "c8oVgSoXEAv_",
    "outputId": "045f2573-6d7f-4e89-94a7-286b08dcf27f"
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7fc9e9b8d61743c6bb6b089e21c4884a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(FloatProgress(value=0.0, max=10000.0), HTML(value='')))"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7ff556c32d50>"
      ]
     },
     "execution_count": 46,
     "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,10000))\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": 47,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 283
    },
    "id": "08mK99A8IL2n",
    "outputId": "5d1e8b4f-82d7-4dde-a5ee-9687986d3f90"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-5.0, 5.0)"
      ]
     },
     "execution_count": 47,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Sampling\n",
    "kl_ratio_store=[]\n",
    "log_ratio_store=[]\n",
    "log_r_p_from_m_direct_store=[]\n",
    "\n",
    "\n",
    "feed_dict = feed_dict\n",
    "kl_ratio, p_s, q_s, d_s, m_s, lpq, lpq_from_cob_dre_direct= sess.run([kld,\n",
    "                                                                            p_samples, q_samples, samples, m_samples,\n",
    "                                                                            log_ratio_p_q,  log_r_p_from_m_direct],\n",
    "                                                                          feed_dict=feed_dict)\n",
    "kl_ratio_store.append(kl_ratio)\n",
    "log_ratio_store.append(lpq)\n",
    "log_r_p_from_m_direct_store.append(lpq_from_cob_dre_direct)\n",
    "    \n",
    "fig, ax = plt.subplots(1, 1)\n",
    "ax.hist(p_s, density=True, histtype='stepfilled', alpha=0.8, label='P')\n",
    "ax.hist(q_s, density=True, histtype='stepfilled', alpha=0.8, label='Q')\n",
    "# ax.hist(d_s, density=True, histtype='stepfilled', alpha=0.8, label='M')\n",
    "ax.hist(m_s, density=True, histtype='stepfilled', alpha=0.8, label='M')\n",
    "ax.legend(loc='best', frameon=False)\n",
    "plt.xlim(-5,5)\n",
    "# plt.ylim(-400,800)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 301
    },
    "id": "ja9hDBCPlg12",
    "outputId": "16acdcbe-1f62-4f6c-ea71-dddc8ce642d1"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-400.0, 1000.0)"
      ]
     },
     "execution_count": 48,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZAAAAEKCAYAAAA8QgPpAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAAA4DElEQVR4nO3deXiU5bn48e+dhSRAoBJjREAWQ5AlEDEiVI1GVDjHBfWIdQUVSz2mtrbVqscu2p8eacXWqlhLVRZBRa1WraeiIBqxIIRdthABIRIhBoFAyDa5f3+87ySTZJIMQ5KZJPfnunLNzLveM0nee57lfR5RVYwxxphjFRHqAIwxxrRNlkCMMcYExRKIMcaYoFgCMcYYExRLIMYYY4JiCcQYY0xQWjyBiMiLIrJPRL7wWdZDRD4UkW3u4wk+6x4QkTwR2Soi43yWnykiG9x1T4mItHTsxhhjGtYaJZDZwPg6y+4HFqvqQGCx+xoRGQJcBwx193lWRCLdff4CTAUGuj91j2mMMaYVtXgCUdVsYH+dxROAOe7zOcCVPstfVdUyVd0B5AGjRKQn0E1Vl6lz5+Ncn32MMcaEQFSIzpukqgUAqlogIie5y3sBy322y3eXVbjP6y73S0Sm4pRWiO3c+cy+/QdyuLySrp2i6BobqrdsjDFtx6pVq75V1cTGtgm3q6m/dg1tZLlfqjoTmAlw+rA07fyDx5HyShS49cKBZGUmN0uwxhjTXonIV01tE6peWHvdaincx33u8nygj892vYE97vLefpY36XB5JUfLKymtrKK0ooqnF28jO7fwuN+AMcZ0dKFKIO8Ak93nk4G3fZZfJyIxItIfp7F8hVvdVSwio93eV5N89mlU105RKKAKIuBR5XfvbuSul1dbIjHGmOPQGt14XwGWAYNEJF9EpgDTgItFZBtwsfsaVd0IvAZsAt4HslTV4x7qv4HncRrWvwT+Fcj5u8ZGcdeFA4mNiiAqQqjwKHmFR3h3fQG3z8lhxpK8Zny3xhjTcUh7H849PT1dc3JyyM4t5MlFuazbfQCPz1uOFPj5JYOsXcS0KxUVFeTn51NaWhrqUEyYi42NpXfv3kRHR9daLiKrVDW9sX3DrRG9xWSkOJ0Jsuavprissnq5R+FPH+Y66yyJmHYiPz+f+Ph4+vXrh91zaxqiqhQVFZGfn0///v2Pef8ONZRJRkoiM24cydn9e9Tq1lVZpda4btqV0tJSEhISLHmYRokICQkJQZdUO1QCASeJLPjRGO4ZN4ioCOefSwQQWL69KLTBGdOMLHmYQBzP30mHqcKqy1td9fTibSDQuVMUowckhDgqY4xpOzpsAgEniaT26s7y7UWMHpBQ3U6SnVtYb5kxxpjaOlwVVl0ZKYn8cvzptZLH3QvWMnfZV9y9YK21ixgThKKiItLS0khLS+Pkk0+mV69e1a/Ly8ub5RyffvopQ4cOJS0tjaNHjzbLMf156KGHmD59eosd/1h9/PHHXHbZZaEOA+jgJRB/lm8voryyis6dIikp97B8e5GVQow5RgkJCaxduxZwLsBdu3blnnvuqV5fWVlJVNTxXX7mz5/PPffcw6233lprucfjITIysoG92gZVRVWJiAjv7/jhHV0IjB6QQKeoCErKPXSKirB2EdNhZOcW8of3t7RYqfuWW27h5z//OZmZmdx33331vtkPGzaMnTt3AjBv3jxGjRpFWloaP/rRj/B4PLWO9fzzz/Paa6/xu9/9jhtvvJGPP/6YzMxMbrjhBlJTUyktLeXWW28lNTWVM844gyVLlgAwe/ZsrrzySi6//HL69+/PM888wx//+EfOOOMMRo8ezf79dQcOr23t2rWMHj2a4cOHc9VVV/Hdd98BsHLlSoYPH86YMWO49957GTZsWIPHmD17NhMmTGD8+PEMGjSIhx9+GICdO3cyePBg7rzzTkaOHMnu3burj5WamsqCBQuqj3Ho0CGuuuoqhgwZwh133EFVVVXgv4hmZAmkjoyURJ78QRqTxvTlyR+kWenDdAitVXWbm5vLokWLeOKJJxrcZvPmzSxYsIDPPvuMtWvXEhkZyfz582ttc/vtt3PFFVfw+OOPV69bsWIFjz76KJs2bWLGjBkAbNiwgVdeeYXJkydXd1X94osvePnll1mxYgUPPvggnTt3Zs2aNYwZM4a5c+c2Gv+kSZP4/e9/z/r160lNTa2++N96660899xzLFu2LKDSz4oVK5g/fz5r167l9ddfJycnB4CtW7cyadIk1qxZQ05ODmvXrmXdunUsWrSIe++9l4KCgur9n3jiCTZs2MCXX37Jm2++2eQ5W4IlED/qtosY0975Vt2WV1a1WJf2iRMnNnmBXbx4MatWreKss84iLS2NxYsXs3379iaPPWrUqOqb4ZYuXcrNN98MwOmnn07fvn3JzXVuGM7MzCQ+Pp7ExES6d+/O5ZdfDkBqamp1CcifgwcPcuDAAc4//3wAJk+eTHZ2NgcOHKC4uJjvf//7ANxwww1NxnrxxReTkJBAXFwcV199NUuXLgWgb9++jB49uvo9XH/99URGRpKUlMT555/PypUrq9/rgAEDiIyM5Prrr6/ev7VZG4gxhtEDEnh15e4Wr7rt0qVL9fOoqKhaVS/eEoKqMnnyZB577LGgj93YEE0xMTHVzyMiIqpfR0REUFlZ2dBuDQpmOKi69154Xwf6Hhrav7VZCSQILV1XbExrC0XVbb9+/Vi9ejUAq1evZseOHQCMHTuWN954g337nFke9u/fz1dfNTk1RS0ZGRnVVVu5ubns2rWLQYMGHVe83bt354QTTuDTTz8F4KWXXuL888/nhBNOID4+nuXLnbnwXn311SaP9eGHH7J//36OHj3KP/7xD8455xy/72HBggV4PB4KCwvJzs5m1KhRgFOFtWPHDqqqqliwYAHnnnvucb23YFkJ5Bh564rLK6t4deVuaycx7UZGSmKr/i3/13/9F3PnziUtLY2zzjqLlJQUAIYMGcIjjzzCJZdcQlVVFdHR0cyYMYO+ffsGfOw777yTO+64g9TUVKKiopg9e3atkkew5syZwx133EFJSQkDBgxg1qxZALzwwgv88Ic/pEuXLlxwwQV079690eOce+653HzzzeTl5XHDDTeQnp5er/rsqquuYtmyZYwYMQIR4Q9/+AMnn3wyW7ZsYcyYMdx///1s2LCBjIwMrrrqquN+b8HoMKPxNpc/vL+Fucu+qu7mO2lMX345/vRmO74xzWHz5s0MHjw41GF0GIcPH6Zr164ATJs2jYKCAv785z/73Xb27Nnk5OTwzDPPtGaIjfL39xLIaLxWhXWMrJuvMaau9957j7S0NIYNG8ann37Kr371q1CH1CqsBBKEukOd2NAnJtxYCST0Fi5cyH333VdrWf/+/XnrrbdCFFHDgi2BWBtIEHzrin3bRF5a9hUXDEpkYnofSyTGdHDjxo1j3LhxoQ6jRVkV1nHy9p+PjBCKyyp5f+M3NoaWMaZDsARynKrbRNxZDrt0iuJoeSVPLsq1JGKMadcsgRwnb//5ccNOJj42irJKD6UVVWwqOGQlEWNMu2YJpBlkpCTyzA0jmXHDSAb37EZMdATdYqNbdEgIY8LdU089xeDBg7nxxhtb9DwVFRXcf//9DBw4kGHDhjFq1Cj+9a9/NbpPv379SE1NJS0tjdTUVN5+++1Gt0tNTWXIkCH86le/oqysDHAGP4yLiyMtLY0hQ4YwadIkKioqAGfI9e7du1cPYZ+WlsaiRYuO6fh79uzhmmuuOZ6PptqTTz5JSUlJsxyrFu+wwe3158wzz9TW9MnWfXrG7z7Qob95X8/43Qf6ydZ9rXp+Y1RVN23aFOoQdNCgQbp9+/Z6yysqKpr1PPfdd59OmjRJS0tLVVX1m2++0QULFjS6T9++fbWwsFBVVbds2aKnnnpqk9sVFxfr9ddfr5MmTVJV1R07dujQoUNVVbWyslIzMzN13rx5qqq6ZMkSvfTSS5uMvbHjNySYz8/3PP74+3sBcrSJ62tIe2GJyM+A2wEFNgC3Ap2BBUA/YCdwrap+527/ADAF8AA/UdWFrR9147xVWtat13Rkd9xxB9u3b+eKK67gtttu4+DBg+zZs4edO3dy4okn8thjj3HbbbdRWFhIYmIis2bN4tRTT+WWW24hLi6OLVu28NVXXzFr1izmzJnDsmXLOPvss5k9e3at85SUlPC3v/2NHTt2VN9pnpSUxLXXXgvAK6+8wv/+7/+iqlx66aX8/ve/rxfroUOHOOGEE5p8T127duW5556jT58+9YZ9j4yMZNSoUXz99ddBfmL1j3/o0CEuu+wyvvjiC2bPns17771HaWkpR44c4d133+Wuu+5iw4YNVFZW8tBDDzFhwgQ8Hg/33XcfCxcuRET44Q9/iKqyZ88eMjMzOfHEE6uHtm8WTWWYlvoBegE7gDj39WvALcAfgPvdZfcDv3efDwHWATFAf+BLILKp87R2CcSYcBBUCWTbItUPH3Iem4Hvt97f/va3OnLkSC0pKVFV1csuu0xnz56tqqovvPCCTpgwQVVVJ0+erD/4wQ+0qqpK//GPf2h8fLyuX79ePR6Pjhw5UtesWVPrHOvWrdO0tDS/5//666+1T58+um/fPq2oqNDMzEx96623qmMbNmyYDh06VOPi4vTdd99t8j14jRgxQpcvX16rBHL06FG94IILdN26darqlEC6deumI0aMqP7Jy8sL+vizZs3SXr16aVFRkaqqPvDAA/rSSy+pqup3332nAwcO1MOHD+uzzz6rV199dXUpxbt9S5VAQt0GEgXEiUgUTsljDzABmOOunwNc6T6fALyqqmWqugPIA0a1brjGtFN5i+HNqbDyeecxb3Gzn+KKK64gLi4OgGXLllUPe37zzTfXGo788ssvR0RITU0lKSmJ1NRUIiIiGDp0aKPDrde1cuVKLrjgAhITE4mKiuLGG28kOzu7ev2SJUv44osv2LBhAz/+8Y85fPhwQMdVn5uvv/zyS9LS0khISODUU09l+PDh1evOO+881q5dW/1z2mmnHfPxfV188cX06NEDgA8++IBp06aRlpbGBRdcQGlpKbt27WLRokXccccd1bM9erdvKSFLIKr6NTAd2AUUAAdV9QMgSVUL3G0KgJPcXXoBu30Oke8uq0dEpopIjojkFBZaLyhjmrRzKXjKIbqz87iz+eeX8B2qvC7f4ch9h1evO/R63eHWk5OT2bVrF8XFxfWO2dCFuK7TTjuNpKQkNm3a1OS2xcXF7Ny5s3rgx9NOO421a9eSl5fH8uXLeeeddwI6Z6DH91V3qPe///3v1clp165dDB48GFVt1aHdQ5ZAROQEnFJFf+AUoIuI3NTYLn6W+f0LUdWZqpququmJieHbBmHDwpuw0e9ciOwEFSXOY7+WHR78+9//fvWw5/Pnzw96OPLOnTszZcoUfvKTn1BeXg5AQUEB8+bN4+yzz+aTTz7h22+/xePx8Morr1RPBuVr37597Nixo8nRfg8fPsydd97JlVdeWa/NpGfPnkybNu2Y5zAJ9Ph1jRs3jqeffro6Sa5ZswaASy65hOeee6460XrbauLj4/0m2eMVyiqsi4AdqlqoqhXAm8D3gb0i0hPAfdznbp8P9PHZvzdOlVeb5DuFaNbLq/nxy6stkZjQSR4LV8+Es253HpPHtujpnnrqKWbNmsXw4cN56aWXGhy5NhCPPPIIiYmJDBkyhGHDhnHllVeSmJhIz549eeyxx8jMzGTEiBGMHDmSCRMmVO+XmZlJWloamZmZTJs2jaSkJL/Hz8zMrO4efOqpp/LXv/7V73ZXXnklJSUl1fOFfPrpp7W68b7xxhvHdXxfv/71r6moqGD48OEMGzaMX//614Az1a+3Km3EiBG8/PLLAEydOpX/+I//IDMzs8ljH4uQDaYoImcDLwJnAUeB2UAOcCpQpKrTROR+oIeq/lJEhgIv47R7nAIsBgaqqqex87TEYIrNwTssfFSEcOBoBQJ0jYlixo0jreeWOW42mKI5Fm1uOHdV/Rx4A1iN04U3ApgJTAMuFpFtwMXua1R1I05PrU3A+0BWU8kjnHmHQCkuc248UqC4rJLXcnY3vqMxxoSJkPbCUtXfqurpqjpMVW92e1gVqepYVR3oPu732f5RVT1NVQepauO3moY57/0i/ROchjFvA09oZjY2xphjF+puvB1aRkoiv7l8KPGxUURFCvGxUUxM79P0jsYEIFTV06ZtOZ6/E5sPJMQyUhKZccNIu3PdNKvY2FiKiopISEho1W6dpm1RVYqKioiNjQ1qf0sgYcB3gqq6bLZDE4zevXuTn5+P3QdlmhIbG0vv3r2D2tcSSBjzne3w1ZW7efIHaZZETECio6Pp379/qMMw7Zy1gYQx72yHnTtF2tDwxpiwYwkkjFXPdljuoVNUBKMHJIQ6JGOMqWZVWGHMhoY3xoQzSyBhrrEGdmOMCSWrwjLGGBMUSyDGGGOCYgnEGGNMUCyBGGOMCYolEGOMMUGxBGKMMSYolkCMMcYExRKIMcaYoNiNhO2cjeZrjGkplkDaMe9oviXllby4dAd3jR1IVmZyqMMyxrQTlkDaseXbiygpr6SssgpV+POibWwuOMS16X2sNGKMOW7WBtKOjR6QAAqqzlzr5Z4qFn7xDXcvWEt2rk00ZIw5PpZA2rGMlETuGjuQ2OgIIiOcaU07x0TZ3CLGmGZhVVjtXFZmMqm9uvN6zm4+3lqIp0ptbhFjTLMIaQIRke8BzwPDAAVuA7YCC4B+wE7gWlX9zt3+AWAK4AF+oqoLWz3oNsg7JLy/HlnWS8sYEyxR1dCdXGQO8KmqPi8inYDOwP8A+1V1mojcD5ygqveJyBDgFWAUcAqwCEhRVU9j50hPT9ecnJyWfSNtlO+c652iImzOdWNMNRFZparpjW0TsjYQEekGZAAvAKhquaoeACYAc9zN5gBXus8nAK+qapmq7gDycJKJCZLNuW6MOR6hbEQfABQCs0RkjYg8LyJdgCRVLQBwH09yt+8F7PbZP99dVo+ITBWRHBHJKSy03kYNqTvnepeYKP7w/hbroWWMCUgo20CigJHAXar6uYj8Gbi/ke3FzzK/9W+qOhOYCU4V1vEG2l75zrneJSaKF5buoLyyildX7rbqLGNMk0JZAskH8lX1c/f1GzgJZa+I9ARwH/f5bN/HZ//ewJ5WirXdykhJ5JfjT+dIWaVVZxljjknIEoiqfgPsFpFB7qKxwCbgHWCyu2wy8Lb7/B3gOhGJEZH+wEBgRSuG3K7Vrc6ybr7GmKaE+j6Qu4D5bg+s7cCtOEntNRGZAuwCJgKo6kYReQ0nyVQCWU31wDKB863Osi69xphAhLQbb2uwbrzGGHPswrobrzHGmLYt1FVYpg2xu9aNMb6sBGIC4r1rfe6yr2w0X2MMYAnEBMjuWjfG1GUJxATEuvkaY+qyNhATEOvma4ypyxKICZh3WHhjjAGrwjLGGBMkK4GYZmVdfY3pOKwEYpqNdfU1pmOxBGKajW9X36PllTy5KNeSiDHtmCUQ02y8XX2LSysorahiU8EhK4kY045ZAjHNxtvVd3DPbsRER9AtNtpuOjSmHbMEYppVRkoid1+UQudOUTZVrjHtnPXCMs3Opso1pmOwEohpETZVrjHtnyUQ06L8jaE1Y0keVz/7GTOW5IU6PGPMcbAqLNOi6o6hteHrg0xfuBUF1uw6AEBWZnJIYzTGBMcSiGlxvmNoPbkoFwUiBKoU3lydz5GySrtz3Zg2yKqwTKsaOzgJwUkeAuw5cJQXP9vB1Lk5VqVlTBvTZAlERLoDDwHnuYs+AX6nqgdbMC7TTnmrqxZv3kt0ZATr8g9QVlmFKjz90TZSe3W3kogxbUQgJZAXgUPAte7PIWBWSwZl2reszGTevPMcJ5koqIKIUyKxXlrGtB2BJJDTVPW3qrrd/XkYGNBcAYhIpIisEZF/uq97iMiHIrLNfTzBZ9sHRCRPRLaKyLjmisGERkZKIneNHUhsdASxURHEdYpi9IAEsnML7cZDY9qAQBrRj4rIuaq6FEBEzgGONmMMPwU2A93c1/cDi1V1mojc776+T0SGANcBQ4FTgEUikqKqnmaMxbSyrMxkUnt1r+6lBXD3grV246ExbUAgJZD/BmaIyE4R+Qp4BrijOU4uIr2BS4HnfRZPAOa4z+cAV/osf1VVy1R1B5AHjGqOOExoeW86zEhJrDWir914aEx4azKBqOpaVR0BDAdSVfUMVV3XTOd/EvglUOWzLElVC9xzFwAnuct7Abt9tst3l5l2xN+Nh8aY8NRgFZaI3KSq80Tk53WWA6CqfzyeE4vIZcA+VV0lIhcEsoufZdrAsacCUwFOPfXUYEM0IVD3xkOrvjImfDXWBtLFfYz3s87vhfsYnQNcISL/CcQC3URkHrBXRHqqaoGI9AT2udvnA3189u8N7PF3YFWdCcwESE9Pb45YTSvyvfHQy6bKNSb8iGrj11cROUdVP2tq2XEF4ZRA7lHVy0TkcaDIpxG9h6r+UkSGAi/jtHucAiwGBjbViJ6enq45OTnNFaoJAe9UuSXllaBw19iBNvyJMS1MRFapanpj2wTSiP50gMuayzTgYhHZBlzsvkZVNwKvAZuA94Es64HVMSzfXkRJeSVllVWUVlbx9EfbrIuvMWGgsTaQMcD3gcQ67SDdgMjmDEJVPwY+dp8XAWMb2O5R4NHmPLcJf6MHJPDi0h31bji0qixjQquxEkgnoCtOkon3+TkEXNPyoRnjaOiGQxsW3pjQarAEoqqfAJ+IyGxV/aoVYzKmnro3HNqw8MaEXiB3ope4DdtDcXpLAaCqF7ZYVMb40diw8Is377UEYkwrC6QRfT6wBegPPAzsBFa2YEzGNKnusPBjBydZlZYxrSyQEkiCqr4gIj/1qdb6pKUDM6YxvsPCjx2cBFBdpbV61wGycwvJyky2hnZjWlAgCaTCfSwQkUtxbt7r3XIhGROYrMzk6kRy9bOfoTilEQVW7NjPpoLVzLhhpCURY1pIIFVYj7iTSv0CuAdn4MO7WzIoY46Vt0rLe1usAsWllbyes7uRvYwxx6PJEoiq/tN9ehDIhOoh3Y0JG96SyN+yt3PgaEV1MrFxbIxpOQ2WQNyJnq4XkXtEZJi77DIR+TfOkO7GhJWszGSeuv4M4mOiiIoQ4mOiuDa9T9M7GmOC0lgJ5AWcwQtXAE+5c4GMAe5X1X+0QmzGHLOMlERm3DjSBl40phU0lkDSgeGqWiUiscC3QLKqftM6oRkTHH+j+Rpjml9jjejlqloFoKqlQK4lD2OMMV6NlUBOF5H17nMBTnNfC6CqOrzFozOmhdj8IsYcv8YSyOBWi8KYVuQ7v8iLS3fY/CLGBKmxwRRtAEXTLvnOL6IKf/owF7DBGI05VoHcSGhMuzJ6QAIoeCfjrKxSnvwwl7teXm0TVRlzDCyBmA7HO79IVIQATqNeRZXyf18UMHVujg3GaEyALIGYDikrM5mfXZxCbFQEbh6hqgqbMteYY9DkUCYisoH6I0IcBHKAR9wpaI1pc7yTVL2Ws5uFG7+hwqM2Za4xxyCQ0Xj/BXiAl93X17mPh4DZwOXNH5YxrcN70+GMJXk8/dE2BKqnzDXGNC6QBHKOqvoOnrhBRD5T1XNE5KaWCsyY1lR3ylwrfRjTtEASSFcROVtVPwcQkVFAV3ddZYtFZkwrsyFQjDk2gSSQ24EXRaQrTvXwIWCKiHQBHgv2xCLSB5gLnAxUATNV9c8i0gNYAPTDmT73WlX9zt3nAWAKTpXaT1R1YbDnNyZQ2bmFvJ6zGwWuTe9jScYYl6gGNmOCO6mUqOqBZjmxSE+gp6quFpF4YBVwJXALsF9Vp4nI/cAJqnqfiAwBXgFGAacAi4AUVfU0dp709HTNyclpjpBNB5SdW0jWy6spLnUK23HREfz15nRLIqbdE5FVqpre2DZNduMVke4i8kdgMbBIRJ5wk8lxUdUCVV3tPi8GNgO9gAnAHHezOThJBXf5q6papqo7gDycZGJMi1m+vYij5TXfUY5WVPGazXJoDBDYfSAvAsXAte7PIWBWcwYhIv2AM4DPgSRVLQAnyQAnuZv1Anz/c/PdZca0mNEDEogQqbVMGtjWmI4mkARymqr+VlW3uz8PAwOaKwC3beXvwN2qeqixTf0s81v/JiJTRSRHRHIKC+2GMBO8jJREfnrRQKIjhcgIiI+NYqI7y2F2biF/eH+L3XRoOqxAGtGPisi5qroUqudDP9ocJxeRaJzkMV9V33QX7xWRnqpa4LaT7HOX5+PMkOjVG9jj77iqOhOYCU4bSHPEajouf118vW0jR8s9PP/pDn56kY3oazqeQBLIHcBcn3aP74DJx3tiERGcaXM3q+offVa94x5/mvv4ts/yl932mFOAgTjT7RrT4up28X09Z3d1wzooTyzcCtiIvqZjaTKBqOo6YISIdHNfHxKRu4H1je7YtHOAm3FuTFzrLvsfnMTxmohMAXYBE93zbhSR14BNOPefZDXVA8uYllK3WFsFPL14G6m9ulsPLdNhBFICAZzE4fPy58CTx3Nit0qsofbIsQ3s8yjw6PGc15jmcG16HxZv3svRiirA/UMWG0PLdCzBjsZrHVFMh5aRkshfb07n7P49iI4QYqIj6Nwpin3FZVz97Gc2JLzpEAIugdRhDdOmw/O2i3jnV99XXMbfV+WjwJpdBwBrEzHtW4MlEBEpFpFDfn6KcRqxjTE4ieSX409ne+FhFIgQ5xvWs0vyuOiJj600YtqtxuZEj2/NQIxp68YOTmLNrgNUueXzI+Ue8gqP8Lj10DLtlM1IaEwzycpM5p5xg0iKj6nXSDj33zvthkPT7lgCMaYZZWUm8/jEEcRGR9ZaXnSkzOZbN+2OJRBjmpnTQ+tMzu7fg+/FRRMVAR515lv/04e51i5i2o2Ah3Nvq2w4dxNK2bmFTJ2bQ2llVb115w48kXlTzg5BVMY0rVmGczfGBC8jJZG7xg4kNjqCOoP6snTbt9zz+rrQBGZMM7AEYkwLy8pMZubN6Yzq16PeurdW51vjummzLIEY0woyUhJZ8KMxnDvwxFrLIyOE13N227Dwpk2yNhBjWtk9r6/jrdX5REYIMdGRoHCkvJIqhaGndOO9n5wX6hCNsTYQY8LR9IkjmHXrKG4/bwDnpyRWJw+AjXsOcdMLn4c2QGMCFOxYWMaY4+A7jtY/1xfUWrd65/4QRWXMsbESiDEhlJGSyNBTutVaNtJPY7sx4chKIMYEK/sJWP8qRERB4ulwxk2wZy3kvg8JA+HATjjyLQz/AWT8osHDvPeT87jphc9ZvXM/I/v1YN6Us8nOLeS1nN0IMDG9j80xYsKSNaIb05S8xfDpE7WTQfYT8NH/o9bMBpEx4Cnzf4yThjhJJioOdnwMlaXO6/N+Acm150/Lzi0ka/5qisucKXM7RUbYnOum1QXSiG4lEGMak7cYFtwEFSXO649+5zzmvk+9aXEaSh4A+zY5P76++gz2rIHz7oFVc+DwXuj7fZaf9BilFTWzNZd7qvjjBzairwk/lkBMx5a3GHYuhU5dYe8XzrIzbqopFexc6pQWfOW+DynjIX8lAZdAGlJxtHZJZvtH3F7yC/Kiz+fSqsWcxEEU5Vu+x9sfZZLda4pVZ5mwYQnEdEzeaqndK0HE58IvkLcIJs52kki/c+Hz52pKIOAkD2+bRlNtIN99BUcKwVOO34k8IyKhqrLWoh6FOczotI6oiuLqXRS4iDV8+fq77OvZl5MyptSr+jKmtVkbiOl48hbD67dA2SE/KwUio2HMj+Gi39ZsX7cN5FjPt2ae87xuG8hpY+Hjx6Cqomb77n2huACqyp384ZNExH2siOpKzLAJNcfqmgRxJziPviUoY4JkbSCmY8p+oqaayd/FfudSqCitv9wrKtYpeXgljz2+C3JT+5+SBu/+rLoNhO//2E1w5U7CcAdhFK0pw0RWHkHXza+ZuKqkqOZ4ue/DkKugaBtUlsHhfXDahXDVs8G/B2P8sBKIabu87Rf9znUu0NlPQM4LcOhrdwOBC39dP4lUl0CKAYXITjBsIlQeddaHwzd4b6nl8F4ADpRUEL1vHXE4VW1VCJFS879bdwZEvyKiISYeYr8Hpd9BfE+45JHQv1cTlgIpgbS5BCIi44E/A5HA86o6rbHtwzqBeC+AxXudb4v+vjHXvUgGcw5v9UnSMCg/XPtYvseHxs91vLEcD9/3ccZNzuPrtzjVN1GxcPrlsO5lar6ju5U9vUfB7R82fbw2cBF95+8vEbFuPgBl2omrIj6pSRwSYBLxJyIaqjxwQj/o1tNpsxl+3bFX1Znm4/1fy1vs9N6LjILoeCg/BFUKEQI9BsCwa5zOH4f31lRf+rbDxSc5HUTKD9dcZxIGwrYPoKTQab/rmgT9L4CCNU7Vac8zwFPGiAcWlq/7xhPTWJhtKoGISCSQC1wM5AMrgetVdVND+6Snp2vOq7+vfRH1fuBedeuNm7pQ1l3v25On/HDNY2MX2rzF8OZUpx7eU+59h7W/MXu38ZQ735KvnnlsF7q637QRiI6D6M7OsaDm+L78nSvQWOp+Fv4Sk28V0ylp9S/k/j7f6veB8y365FT46t815437Hhz9rk4wDZRA2rDs3EKWby9i4cZvuGT/y9wY+SExVHBEY+kduZ8owbkoNNRofyw6J8DA8bUvQqH48tBcvF8aCrfU/P9Hd4GjB5zSZ1QsSITbNub+v0TFQif3wu2pBK0EiYK4HlBe7JZaher0HdUJ4k9xjqke50ciax4ry53xP6o8zk9cAnRJhLIDNdvFdoeD+c7nrfUnImtUZEzt331EtNNJIyKqdjtbANJnHiZnj6fR7yVtrQ1kFJCnqtsBRORVYALQYALh8N7aF9GNb/rfztvzBmoulKvnNn4hXT0XRt8Jy591eulUHHUurp5y50Ltb3+vnUud7ar/QNxvzLnv11zwvNtEd3aOv3Ppsf3z1qvrd/+oPOXOOu/z6M5wdL+zunMP/+cKJBbvZ1NxxDlvdBysfL5m/eq5MHBcTUkhf2XN5wXO7+Ccu53P0/fzr/s+KkudBm1f8T2df1rve+zWC9KntKvkATVjaHWJieLxhRP4i2dC9brzPOv56Wl7ST//8ppvod9uc6qrglFSBOvm11yEIqPh3085F7iuSTU9z7x/B9lPQM6LzkXV20Hgy8XOBdtT7lyAIyKdUuEpac434q9Xun8rsdCtt3PRTBjoHKNwCxTmOhdtIqHbyXDiIPh2q/P3WlnuXPCjO0NEBHQ/1dmvotT5Gzx60N0XiD0BSg9QP6n6tB2V173AqnM8b9Vm9eJKKNlXezvvcStL4bvtjX+uHp/nJfvqHAufKtgg+PYmRN0eflqvp19zaWsJpBew2+d1PlBvTlARmQpMBTi1RyxUdm36yBWl9S+qgVxIc9/3+QavbkKoc6H2d9Hvd65zgay+x8D9xpMyvv42FSXOhda3YTcQ/c51LuBl3n8M98uE77G8x4+KdT+HBs4VSCzez0Yiaj6DilLntHFuYvryI2edRDiflaesJq7K0prP0/fzr/s+omKd3lCfPVlz8bnkkZqLZkON5+1IVmYyy7YXsXRbTSL9tGo4n26Da7qdyPSJv6j5DN66E7b+y/l2GxHp/P4OfxP4ydQDaM3feUmR87NvU80Xrz1ra26yBOcmya8+83+87R85vcfqfrv+Ntd5zF/hZyePc2Gte3FVD5QddJ7XK4H6CDaJtjX1SiBRQZdAAtHWEoi/4lS9crqqzgRmAqSf3keJAjxNfHjRsfUvqoFcSFPGw/7tboYX9+Lp50JdV/LYmm/XDbWB+G4TTNVB8ljnn7uxNhDf40PD5woklurP5kjNZxBdJzGddqFTAtEqZxvfEkhUbM3n6fv5130f3m+9p6TVjid5bLtPHL7mTTmbe15fxxur8mstf2NVPv1P7FJz17q/3ld5i+GDX8GBXc7/hqcCup4ER/bVv7BLZMNVKZXuFy/vl69AHWvVTEcTGQOnXwpFX4asDaSiamF5E1G2uTaQMcBDqjrOff0AgKo+1tA+YdsG0l61RBuIadSMJXk8vnBrrWWndI/h5O5xjB2cdGzDn/i2E1RVQq+znItQ8V5Yv6CmSsgrppv/EkhTvCXQUInoBLHx4dkGckI/v2OktbZ21wtLRKJwGtHHAl/jNKLfoKobG9onrHthGdNM/JVEvHp2j+Wm0X2Pfxwt7w2V3+102kHaUhtI15Od9r3iAkj5T7snJgDtLoEAiMh/Ak/idON9UVUfbWx7SyCmo5ixJI/Fm/dScLCUgoP1b5S85szeTJ84IgSRmbaoXU5pq6r/p6opqnpaU8nDmI4kKzOZN+88h5tG9/XbWPjGqnyycwtbPS7TfrW5BGKMaVxWZjL3jBtEl071/71vmbWCe15fF4KoTHtkCcSYdigrM5m/3FS/9qFKnZKIJRHTHCyBGNNOZaQkcs2Zvf2u+7slEdMMLIEY045NnziCa87sXa9NRHFKIoN//S9mLMkLRWimHbAEYkw7N33iCObcNopBSfH11h2tqOLxhVstiZigWAIxpgPISElk4c8yGqzSmr5wq1VpmWNmCcSYDmT6xBEMPaVbveXeKi1LIuZYWAIxpoN57yfnNVgSeWt1Pne9vNruFzEBsQRiTAc0feII7h03qN5yj8K76wv44dwcSyKmSZZAjOmgsjKTGyyJlFVWcferayyJmEZZAjGmA/OWRJITu9Rbt7+kgh+9ZCUR0zBLIMZ0cFmZySz6xQV+SyNHK6p4+N2NlkSMX5ZAjDFAzU2HdX1VVMLdC9ZaEjH1WAIxxlTzVml1ioyovnu9a0wUR8sreXJRriURU4slEGNMLVmZyTw/OZ1Lh/ckPjaKskoPpRVVfPH1Qaa+lGN3rZtqbW5CqWNlE0oZE7zs3EKeXJTLF18fpKJK8V4uBiXF8+Clg8lISQxtgKbFtMsJpYwxrScjJZG7L0ohIkLw/a65dW8xt85aYaWRDs4SiDGmURkpidx14cB6yz0KT3+0zdpFOjBLIMaYJjV006EAy7cXtX5AJixEhToAY0zbMH3iCPqf2IX5y3eyr7ic6EghrlMUowckhDo0EyKWQIwxAcvKTCYrM5ns3EKWby9i9ICE6oZ0f8tM+2a9sIwxxy07t5Cs+as5UlaJAv91Zm+mTxwR6rDMcQjbXlgi8riIbBGR9SLyloh8z2fdAyKSJyJbRWScz/IzRWSDu+4pEak7S6cxJkRey9lNcVklVdjcIh1JqBrRPwSGqepwIBd4AEBEhgDXAUOB8cCzIhLp7vMXYCow0P0Z39pBG2P88/dt7q3V+dZDq50LSQJR1Q9UtdJ9uRzwdu+YALyqqmWqugPIA0aJSE+gm6ouU6fObS5wZWvHbYzxb2J6HzpF1k4jIvDwuxttgqp2LBy68d4G/Mt93gvY7bMu313Wy31ed7lfIjJVRHJEJKew0P5wjWlpGSmJPD/5LAYlxRMBREWApwq+LDzCu+sLuHW23XTYHrVYLywRWQSc7GfVg6r6trvNg0AlMN+7m5/ttZHlfqnqTGAmOI3oxxC2MSZIGSmJZKQkVg9/snbXgep/Uk8VTF+4FXB6cpn2ocUSiKpe1Nh6EZkMXAaM1ZquYPlAH5/NegN73OW9/Sw3xoQZbxfeKbNXUlVV8/1NgccXbmXZ9iLmTTk7RNGZ5hSqXljjgfuAK1S1xGfVO8B1IhIjIv1xGstXqGoBUCwio93eV5OAt1s9cGNMQDJSErn74hQi/NQdLN32rfXQaidC1QbyDBAPfCgia0XkOQBV3Qi8BmwC3geyVNXj7vPfwPM4DetfUtNuYowJQ1mZyfzikkF+1/3f+j3WsN4O2I2ExpgWNWNJHk98sBWf2iyiIoS4TpGcn5LItel97M71MBS2NxIaYzqOrMxkZt86ikFJXYmJFKIihK4xURSXVvLP9QVMmb3Semi1UZZAjDEtLiMlkYU/O5+/TT6LbnHRHC6rrF5XUaU8vnCrtYu0QZZAjDGtJiMlkSd/kEa/hM711r2xKt9KIm2MJRBjTKvKSEnkN5cPJS46st66GR9tsyTShlgCMca0uoyURP5685kMSoqvtbykoorpC7daEmkjLIEYY0LCaRfJ4N5xg+gc7VyKIsS54fBv2V/aGFptgE0oZYwJKe/QJtMX1nT1PXC0knfXF/Du+gIGJcXz4KWDratvGLISiDEm5LIyk7ln3CCS4mPqXZS27i1m0os2GGM4sgRijAkLWZnJPD5xBF1i/FeMPL5wq1VphRlLIMaYsJGRksiMG0fWa1z3evS9za0ckWmMJRBjTFjxNq6fFB9Tb93WvcWMeWyxVWeFCUsgxpiwtOLBi+jbo/4NhwUHS3l84VbOnbbYqrRCzBKIMSZsffLLTK45s7ffdfkHSrllljWuh5IlEGNMWJs+cQT3jhvEKd3rV2lVqdO4bkkkNCyBGGPCXlZmMv9+4CLOHXii3/U2GGNoWAIxxrQZ86ac3WASscEYW58lEGNMm9JYEnlqUa4lkVZkCcQY0+bMm3I2944bRExU7UnXyzzO3CLj/pRtPbRagSUQY0yblJWZzN8mnUVcdP3L2Na9xdxqPbRanCUQY0yb5QwLn87Z/XvUW+dxe2hd+tSnIYisY7AEYoxp0zJSElnwozEN3i+ycc8hhvzm/VaOqmOwBGKMaRe894uIn3Ul5R4ribSAkCYQEblHRFRETvRZ9oCI5InIVhEZ57P8TBHZ4K57SkT8/Z0YYzow77Dw/mzcc4i0hxfa/SLNKGQJRET6ABcDu3yWDQGuA4YC44FnRcQ7cfJfgKnAQPdnfKsGbIxpE7Iyk7m3gSRy4Gglb6zKtyTSTEJZAvkT8EucGSy9JgCvqmqZqu4A8oBRItIT6Kaqy1RVgbnAla0dsDGmbfAmkYaqKf6xJt+6+TaDkExpKyJXAF+r6ro6NVG9gOU+r/PdZRXu87rLGzr+VJzSCkCZiHzRHHE3oxOBb0MdRB0WU+DCMS6LyY+ImC7dIuK6JUTEdOmBgKfkIJGduwNw8YuqniMH9ngOF30TyhgJg8+pAf6LcT5aLIGIyCLgZD+rHgT+B7jE325+lmkjy/1S1ZnATDeOHFVNbzLgVmQxBSYcY4LwjMtiCoyI5FQe3Bd2MYXb5wROXE1t02IJRFUv8rdcRFKB/oC39NEbWC0io3BKFn18Nu8N7HGX9/az3BhjTIi0ehuIqm5Q1ZNUtZ+q9sNJDiNV9RvgHeA6EYkRkf44jeUrVLUAKBaR0W7vq0nA260duzHGmBohaQNpiKpuFJHXgE1AJZClqh539X8Ds4E44F/uTyBmNneczcBiCkw4xgThGZfFFBiLKXBNxiVOpyZjjDHm2Nid6MYYY4JiCcQYY0xQOkwC8TdsSiiJyP8TkfUislZEPhCRU8IgpsdFZIsb11si8r0wiGmiiGwUkSoRCWlXRxEZ7w6xkyci94cyFi8ReVFE9oXLvU4i0kdElojIZvf39tNQxwQgIrEiskJE1rlxPRzqmLxEJFJE1ojIP0MdC4CI7HSHjVrbVFfeDpFA/A2bEgYeV9XhqpoG/BP4TYjjAfgQGKaqw4Fc4IEQxwPwBXA1kB3KINwhdWYA/wEMAa53h94JtdmE17A+lcAvVHUwMBrICpPPqQy4UFVHAGnAeBEZHdqQqv0U2BzqIOrIVNW0pu5P6RAJBP/DpoSUqh7yedmFMIhNVT9Q1Ur35XJq33sTEqq6WVW3hjoOYBSQp6rbVbUceBVn6J2QUtVsYH+o4/BS1QJVXe0+L8a5MDY4akRrUcdh92W0+xPy/zkR6Q1cCjwf6liC0e4TiO+wKaGOpS4ReVREdgM3Eh4lEF+3EXhX6Y6gF7Db53Wjw+kYEJF+wBnA5yEOBaiuKloL7AM+VNVwiOtJnC+3VSGOw5cCH4jIKndYqAaF1X0gwQpy2JQW11hcqvq2qj4IPCgiDwA/Bn4b6pjcbR7EqYqY39LxBBpTGDim4XQ6OhHpCvwduLtOaTtk3HvK0ty2vbdEZJiqhqztSEQuA/ap6ioRuSBUcfhxjqruEZGTgA9FZItb0q2nXSSQYIZNce98D0lcfrwMvEcrJJCmYhKRycBlwFhtpZuEjuFzCqWGhtkxdYhINE7ymK+qb4Y6nrpU9YCIfIzTdhTKzgfnAFeIyH8CsUA3EZmnqjeFMCZUdY/7uE9E3sKpvvWbQNp1FVYTw6aElIgM9Hl5BbAlVLF4ich44D7gClUtCXU8YWYlMFBE+otIJ5x5a94JcUxhxx1q6AVgs6r+MdTxeIlIordXoYjEARcR4v85VX1AVXu716brgI9CnTxEpIuIxHuf49TeNJhk23UCCXPTROQLEVmP80sKh+6OzwDxOMXWtSLyXKgDEpGrRCQfGAO8JyILQxGH27ngx8BCnIbh11R1Yyhi8SUirwDLgEEiki8iU0Ic0jnAzcCF7t/QWvcbdqj1BJa4/28rcdpAwqLbbJhJApaKyDpgBfCeqjY4obwNZWKMMSYoVgIxxhgTFEsgxhhjgmIJxBhjTFAsgRhjjAmKJRBjjDFBsQRiTIBE5EF3JFfvKMpnt+C5Pg716MPGNKVd3IluTEsTkTE4d+iPVNUyd1qATiEOy5iQshKIMYHpCXyrqmUAqvqtO17Qb0RkpXtT6Ez3TmxvCeJPIpLtzo1xloi8KSLbROQRd5t+7vwrc9xSzRsi0rnuiUXkEhFZJiKrReR1d5wpRGSaiGxy953eip+FMYAlEGMC9QHQR0RyReRZETnfXf6Mqp6lqsOAOJxSile5qmYAzwFvA1nAMOAWEUlwtxkEzHTnYDkE3Ol7Urek8yvgIlUdCeQAPxeRHsBVwFB330da4D0b0yhLIMYEwJ1L4kxgKlAILBCRW4BMEflcRDYAFwJDfXbzjpW1AdjozpVRBmynZmDG3ar6mft8HnBunVOPxpnA6jN3KPLJQF+cZFMKPC8iVwM2dplpddYGYkyA3OHAPwY+dhPGj4DhQLqq7haRh3BGVfUqcx+rfJ57X3v/9+qOJVT3teCM23R93XhEZBQwFmcgvh/jJDBjWo2VQIwJgIgMqjOCchrgnSnxW7dd4pogDn2q20APcD2wtM765cA5IpLsxtFZRFLc83VX1f8D7nbjMaZVWQnEmMB0BZ52hwSvBPJwqrMO4FRR7cQZ5fVYbQYmi8hfgW3AX3xXqmqhW1X2iojEuIt/BRQDb4tILE4p5WdBnNuY42Kj8RoTIu6Ur/90G+CNaXOsCssYY0xQrARijDEmKFYCMcYYExRLIMYYY4JiCcQYY0xQLIEYY4wJiiUQY4wxQfn/m+LuikZTizQAAAAASUVORK5CYII=\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": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-1000.0, 1000.0)"
      ]
     },
     "execution_count": 36,
     "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(-1000,1000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 301
    },
    "id": "gHtEC7YB-jah",
    "outputId": "5ce554de-d77e-48b8-eea8-48f42af7e327"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-600.0, 400.0)"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "rat = log_r_p_from_m_direct_store[-1][:,0]-log_r_p_from_m_direct_store[-1][:,1]\n",
    "d = [np.squeeze(norm.logpdf(x,mu_2,0.1)) for x in xs]\n",
    "b = [np.squeeze(norm.logpdf(x,mu_1,0.1)) for x in xs]\n",
    "\n",
    "plt.scatter(xs,b,label='True P',alpha=0.9,s=5.)\n",
    "plt.scatter(xs,rat+d,label='P',alpha=0.9,s=5.)\n",
    "\n",
    "plt.xlabel(\"Samples\")\n",
    "plt.ylabel(\"Log P(x)\")\n",
    "plt.legend(loc='upper right')\n",
    "plt.xlim(-4.,4)\n",
    "plt.ylim(-600,400)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "V03YVAWPlSSH"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "collapsed_sections": [],
   "name": "Experiment_CoB_Simple.ipynb",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
