{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "CrSZiwbewKr_"
   },
   "source": [
    "# Week 12 - Gaussian processes\n",
    "\n",
    "Hello again. Welcome to week 13! In this week, you will learn about Gaussian processes.\n",
    "\n",
    "The usual imports..."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "id": "YdanpIGryqUE"
   },
   "outputs": [],
   "source": [
    "# Install Pyro, if necessary\n",
    "#!pip install pyro-ppl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "id": "zcepTRVUwKsA"
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "from torch.distributions import constraints\n",
    "from torch.nn import Parameter\n",
    "\n",
    "import pyro \n",
    "import pyro.contrib.gp as gp\n",
    "import pyro.distributions as dist\n",
    "from pyro.contrib.gp.models.model import GPModel\n",
    "from pyro.contrib.gp.util import conditional\n",
    "from pyro.distributions.util import eye_like\n",
    "from pyro.nn.module import PyroParam, pyro_method\n",
    "\n",
    "import numpy as np\n",
    "from scipy.stats import norm, multivariate_normal\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "# fix random generator seed (for reproducibility of results)\n",
    "np.random.seed(42)\n",
    "\n",
    "# matplotlib options\n",
    "%matplotlib inline\n",
    "plt.style.use('ggplot')\n",
    "plt.rcParams['figure.figsize'] = (12, 8)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "id": "479btlWHwKsD"
   },
   "outputs": [],
   "source": [
    "# matplotlib options (for some reason, in many computers, needs to be run twice to take effect...)\n",
    "%matplotlib inline\n",
    "plt.style.use('ggplot')\n",
    "plt.rcParams['figure.figsize'] = (12, 8)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "hly4mrkewKth"
   },
   "source": [
    "## Part 3: Inference and maximum marginal likelihood optimization\n",
    "\n",
    "Let us start by generating some artificial data that follows more or less a sinusoid function (but with some missing values in the middle) plus Gaussian noise."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "id": "ZHt9E6JDwKth"
   },
   "outputs": [],
   "source": [
    "# generate some training data\n",
    "X_train = np.hstack([-0.75 + np.random.rand(1,150), 0.75 + np.random.rand(1,150)]).T\n",
    "y_train = np.sin(4.0*X_train) + 0.1*X_train**3 * np.random.randn(len(X_train), 1)\n",
    "N_train = len(y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "id": "wIOV7sXtwKtj",
    "outputId": "993da1df-f77c-4967-d179-fe247c4e0d62"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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e+7vz+nll99wYUS1i8fjxvvILANom5XZh8nJiLq6bNrFAYCPTU46V/WabvebYPwrAPhCKtVXUnYhSQsLlg4fpl0cAMCbCJYBtEUmE9XcnOV4X1CyDwAQRrGY88Js0+1+wzcUgLYoZI+dg2UAgH8dOTKjrq7SwLirK68jR4KxYJtgGUDLZTLRitnjoGQfACCMksl5HTtW2lLu2LHpwKxFYYEfgJYrbKVqyirbgck+AEBYObWUC4qmBMsvvfSSnnzySeXzee3YsUO7du0quf+5557TiRMnNDAwIEn6+Mc/rh07djTjpQH4gHkrVVv33DMX2AMsAHjZ8laetO80azhYzufzeuKJJ/SVr3xFg4ODGhsb0/bt2zU8PFzyuFtvvVWf+9znGn05AD4Uj+eUzZYfbmKxvB58kKwyALRbJhPV6Gif5ucLJXLZbKdGR/skBWMjkWZquGb5tdde080336yNGzeqs7NTt956q86ePduMsQEICNMWq5RfAIA70umepUC5aH6+43rZHJZrOLN85coVDQ4OLv08ODioV199texxP/vZz/SLX/xCmzZt0mc+8xkNDQ01+tIAfKIZW6wCAJrHVB5nLpsLr7Ys8Lvlllv0gQ98QF1dXfr+97+vxx57TF/96lfLHnf69GmdPn1akpROpwmo26Szs5PfdQi4Pc979kh79uQlFTPM3df/oNncnmu0B/McHq2Y682bpddfd769Ve+rU6c6dPhwRL/7XeF1xsdzuusu73dDajhYHhgY0OXLl5d+vnz58tJCvqKenhsp/R07dui73/2u43Pt3LlTO3fuXPrZy/ugB4nX95xHczDP4cFchwPzHB6tmOv77iutWZYK5XH33TetS5eaf9XvRo10oTPS669L/+f/dGh21htXGePxuPG+hmuWt27dqgsXLujixYtaXFzU888/r+3bt5c8ZnJycun/z507V7b4D0DwZDJRjYxs0PDwJo2MbFAmE3V7SACA65LJeR09Wtob+ejR1vVG9nONdMOZ5Ugkos9+9rN64IEHlM/n9eEPf1ibN2/W008/ra1bt2r79u36t3/7N507d06RSETr16/X3r17mzF2AB7FKmsA8L529kb2c420Zdu27fYgTCYmJtweQihwKS8c2jnPIyMbHFvFJRKLOnPmYlvGEGZ8psOBeQ6PIMy1178XWlqGAQArZbP+zSAAAJrP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\n",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(X_train, y_train, \"bo\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "N3I_eOr5wKtl"
   },
   "source": [
    "We will now perform exact inference on the GP to compute the posterior:\n",
    "\n",
    "\\begin{align}\n",
    "\tp(\\textbf{f}|\\textbf{y},\\textbf{X}) = \\frac{p(\\textbf{y}|\\textbf{f}) \\, p(\\textbf{f})}{ p(\\textbf{y}|\\textbf{X}) } \n",
    "\\end{align}\n",
    "\n",
    "We assume a Gaussian likelihood of the form:\n",
    "\n",
    "\\begin{align}\n",
    "\tp(y_n|f_n) = \\mathcal{N}(y_n|f_n,\\sigma^2)\n",
    "\\end{align}\n",
    "\n",
    "The **posterior distribution** therefore becomes:\n",
    "\n",
    "\\begin{align}\n",
    "\tp(\\textbf{f}|\\textbf{y},\\textbf{X}) \\propto \\mathcal{N}(\\textbf{y} | \\textbf{f}, \\sigma^2 \\textbf{I}) \\, \\mathcal{N}(\\textbf{f}|\\textbf{0},\\textbf{K}) \n",
    "\\end{align}\n",
    "\n",
    "Since both prior and likelihood are Gaussian, we can compute the exact posterior analytically using the stardard results shown in slides 4 and 5 of Lecture 9. \n",
    "\n",
    "Similarly, we can also determine the **marginal likelihood** of the data analytically (again using the stardard results shown in slides 4 and 5 of Lecture 9):\n",
    "\n",
    "\\begin{align}\n",
    "\tp(\\textbf{y}|\\textbf{X}) = \\int \\mathcal{N}(\\textbf{y} | \\textbf{f}, \\sigma^2 \\textbf{I}) \\, \\mathcal{N}(\\textbf{f}|\\textbf{0},\\textbf{K}) \\, d\\textbf{f} = \\mathcal{N}(\\textbf{y}|\\textbf{0},\\sigma^2\\textbf{I} + \\textbf{K})\n",
    "\\end{align}\n",
    "\n",
    "However, our main interest is to make predictions for new test points $\\textbf{x}_*$ and that requires computing $p(\\textbf{y}_*|\\textbf{y},\\textbf{x}_*,\\textbf{X})$. This can be done by starting from the joint distribution $p(y_*,\\textbf{y}|\\textbf{x}_*,\\textbf{X})$ given by\n",
    "\n",
    "\\begin{align}\n",
    "p(y_*,\\textbf{y}|\\textbf{x}_*,\\textbf{X}) = \\mathcal{N}(y_*,\\textbf{y}|\\textbf{0}, \\textbf{V}) \\nonumber\n",
    "\\end{align}\n",
    "\n",
    "with\n",
    "\\begin{align}\n",
    "\\textbf{V} = \\left(\\begin{array}{cc} \\sigma^2\\textbf{I} + \\textbf{K} & \\textbf{k}_* \\\\\\textbf{k}_*^T & \\sigma^2 + k_{**}\\end{array}\\right) \\nonumber\n",
    "\\end{align}\n",
    "\n",
    "where $\\textbf{k}_* = k(\\textbf{x},x_*)$ and $k_{**} = k(x_*,x_*)$.\n",
    "\n",
    "By making use of the stardard results shown in slides 4 and 5 of Lecture 9, we can now compute the **conditional (predictive) distribution**:\n",
    "\n",
    "\\begin{align}\n",
    "\tp(y_*|\\textbf{y},\\textbf{x}_*,\\textbf{X}) &= \\mathcal{N}(y_*|\\textbf{k}_*^T (\\sigma^2\\textbf{I} + \\textbf{K})^{-1} \\, \\textbf{y}, \\, k_{**} + \\sigma^2 - \\textbf{k}_*^T (\\sigma^2\\textbf{I} + \\textbf{K})^{-1} \\textbf{k}_*) \\nonumber\n",
    "\\end{align}\n",
    "\n",
    "Can you write a Python function that computes this predictive posterior distribution?"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "8bnJcoggg-fi"
   },
   "source": [
    "## Part 3: Gaussian processes in Pyro\n",
    "\n",
    "Pyro implementation of the same Gaussian process in Pyro (adapted from Pyro's Documentation):"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 136
    },
    "executionInfo": {
     "elapsed": 3881,
     "status": "ok",
     "timestamp": 1589213379726,
     "user": {
      "displayName": "Daniele Gammelli",
      "photoUrl": "",
      "userId": "02727525050247971435"
     },
     "user_tz": -120
    },
    "id": "Ybkm_J6nlWTL",
    "outputId": "cd522ad4-f7ed-4701-e7f2-2d35703dda8b"
   },
   "outputs": [],
   "source": [
    "#!pip install pyro-ppl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 430,
   "metadata": {
    "id": "ssvNoGXadvSO"
   },
   "outputs": [],
   "source": [
    "def plot(plot_observed_data=False, plot_predictions=False, n_prior_samples=0,\n",
    "         model=None, kernel=None, n_test=500):\n",
    "\n",
    "    plt.figure(figsize=(12, 6))\n",
    "    if plot_observed_data:\n",
    "        plt.plot(X_train_tensor.view(-1,).numpy(), y_train_tensor.view(-1,).numpy(), 'kx')\n",
    "    if plot_predictions:\n",
    "        Xtest = torch.linspace(-4, 4, n_test)  # test inputs\n",
    "        # compute predictive mean and variance\n",
    "        with torch.no_grad():\n",
    "            if type(model) == gp.models.VariationalSparseGP:\n",
    "                mean, cov = model(Xtest, full_cov=True)\n",
    "            else:\n",
    "                mean, cov = model(Xtest.double(), full_cov=True)\n",
    "                #noise = model.likelihood.variance\n",
    "        sd = cov.diag().sqrt()  # standard deviation at each input point x\n",
    "        plt.plot(Xtest.numpy(), mean.numpy(), 'r', lw=2, label=\"Data\")  # plot the mean\n",
    "        #plt.fill_between(Xtest.numpy(),\n",
    "        #                 (mean - 2.0 * noise).numpy(),\n",
    "        #                 (mean + 2.0 * noise).numpy(),\n",
    "        #                 color='b', alpha=0.3, label=\"Likelihood noise\"\n",
    "        #                )\n",
    "        plt.fill_between(Xtest.numpy(),  # plot the two-sigma uncertainty about the mean\n",
    "                         (mean - 2.0 * sd).numpy(),\n",
    "                         (mean + 2.0 * sd).numpy(),\n",
    "                         color='C0', alpha=0.3, label=\"GP Posterior Mean\")\n",
    "        plt.legend()\n",
    "    if n_prior_samples > 0:  # plot samples from the GP prior\n",
    "        Xtest = torch.linspace(-0.5, 5.5, n_test)  # test inputs\n",
    "        noise = (model.noise if type(model) != gp.models.VariationalSparseGP\n",
    "                 else model.likelihood.variance)\n",
    "        cov = kernel.forward(Xtest) + noise.expand(n_test).diag()\n",
    "        samples = dist.MultivariateNormal(torch.zeros(n_test), covariance_matrix=cov)\\\n",
    "                      .sample(sample_shape=(n_prior_samples,))\n",
    "        plt.plot(Xtest.numpy(), samples.numpy().T, lw=2, alpha=0.4)\n",
    "\n",
    "    plt.xlim(-4, 4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 431,
   "metadata": {
    "id": "MJjSv8GWgHmX"
   },
   "outputs": [],
   "source": [
    "# Build torch.tensors\n",
    "X_train_tensor = torch.from_numpy(X_train).view(-1,)\n",
    "y_train_tensor = torch.from_numpy(y_train).view(-1,)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## GP Regression"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 432,
   "metadata": {},
   "outputs": [],
   "source": [
    "from pyro.contrib.gp.models.gpr import GPRegression"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 433,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Y4a2bt0qY4wyMzM1cOBA5uLYnj17dMcdd6i0tFRlZWXq2bOnhg8frpycHE2dOlXbt29X69atNXr0aMXGxqqkpETTp0/X119/rQYNGmjs2LFq1KiR67cRkXzf10033aS0tDTddNNNzCQArrrqKtWtW1ee5ykmJkYTJkzge1gAFBcXa+bMmfr2229ljNGVV16ppk2bBnMuNoqVlZXZq6++2m7evNmWlJTY66+/3n777beuY0WNFStW2DVr1thrr722Ytujjz5q582bZ621dt68efbRRx+11lr74Ycf2vHjx1vf9+3KlSvtzTff7CJyxMvPz7dr1qyx1lq7Y8cOO2bMGPvtt98yF8d837c7d+601lpbUlJib775Zrty5Uo7efJk+/bbb1trrb3//vvtwoULrbXWvvrqq/b++++31lr79ttv27vvvttN8Cjw0ksv2alTp9q///3v1lrLTAJg1KhRtrCwcK9tfA9z795777VZWVnW2tD3saKiosDOJaqXVaxevVpNmjRR48aNFRsbq169eik7O9t1rKjRoUMHJSYm7rUtOztbffr0kST16dOnYh4ffPCBjj/+eBlj1L59exUXF6ugoKDWM0e61NTUin+d16tXT82aNVN+fj5zccwYo7p160qSysrKVFZWJmOMVqxYoZ49e0qS+vbtu9dc+vbtK0nq2bOnPvvsM1l+vaTa5eXladmyZerXr58kyVrLTAKK72Fu7dixQ1988YVOPPFESVJsbKzq168f2LlE9bKK/Px8paenVzxOT0/XV1995TARCgsLlZqaKklKSUlRYWGhpNCsMjIyKvZLT09Xfn5+xb6ofjk5OVq7dq3atm3LXALA933deOON2rx5s04++WQ1btxYCQkJiomJkSSlpaUpPz9f0t7f22JiYpSQkKDt27crKSnJWf5INHv2bF1wwQXauXOnJGn79u3MJCDGjx8vSTrppJOUmZnJ9zDHcnJylJSUpPvuu0/r169X69atddFFFwV2LlFdjhFsxhgZY1zHiEq7du3S5MmTddFFFykhIWGv55iLG57naeLEiSouLtakSZO0ceNG15Gi2ocffqjk5GS1bt1aK1ascB0HPzJu3DilpaWpsLBQd955p5o2bbrX83wPq31lZWVau3atLrnkErVr106zZs3S/Pnz99onSHOJ6nKclpamvLy8isd5eXlKS0tzmAjJyckqKChQamqqCgoKKs6qpKWlKTc3t2I/ZlVzSktLNXnyZPXu3Vs9evSQxFyCpH79+urYsaNWrVqlHTt2qKysTDExMcrPz6/4s//f97b09HSVlZVpx44datCggePkkWXlypX64IMPtHz5cu3Zs0c7d+7U7NmzmUkA/O/PPDk5Wd27d9fq1av5HuZYenq60tPT1a5dO0mhpUXz588P7Fyies1xmzZttGnTJuXk5Ki0tFRLly5Vt27dXMeKat26ddPixYslSYsXL1b37t0rti9ZskTWWq1atUoJCQn82KsGWGs1c+ZMNWvWTIMGDarYzlzc2rZtm4qLiyWFrlzxySefqFmzZurYsaPeffddSdKbb75Z8f2ra9euevPNNyVJ7777rjp27BiYMzKR4rzzztPMmTM1Y8YMjR07VocffrjGjBnDTBzbtWtXxTKXXbt26ZNPPlHLli35HuZYSkqK0tPTK37i9emnn6p58+aBnUvU3wRk2bJl+te//iXf93XCCSdoyJAhriNFjalTp+rzzz/X9u3blZycrOHDh6t79+6aMmWKcnNzf3ZZl4cfflgff/yx6tSpo1GjRqlNmzau30LE+fLLL3X77berZcuWFf/Hfe6556pdu3bMxaH169drxowZ8n1f1lodc8wxGjZsmL7//ntNnTpVRUVFatWqlUaPHq24uDjt2bNH06dP19q1a5WYmKixY8eqcePGrt9GxFqxYoVeeukl3XTTTczEse+//16TJk2SFPpR/nHHHachQ4Zo+/btfA9zbN26dZo5c6ZKS0vVqFEjjRo1StbaQM4l6ssxAAAA8D9RvawCAAAA+DHKMQAAAFCOcgwAAACUoxwDAAAA5SjHAAAAQDnKMQAAAFCOcgwAAACUoxwDAAAA5f4fYF2DR3ZF9LQAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# initialize the kernel, likelihood, and model\n",
    "pyro.clear_param_store()\n",
    "kernel = gp.kernels.RBF(input_dim=1)\n",
    "\n",
    "# turn on \"whiten\" flag for more stable optimization\n",
    "gpr = GPRegression(X_train_tensor.view(-1,), y_train_tensor.view(-1,), kernel)\n",
    "\n",
    "# instead of defining our own training loop, we will\n",
    "# use the built-in support provided by the GP module\n",
    "num_steps = 600\n",
    "losses = gp.util.train(gpr, num_steps=num_steps)  # default: loss_fn=TraceMeanField_ELBO().differentiable_loss\n",
    "plt.plot(losses);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 434,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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G5C9B/Xzt5gb/0RJs3YhRC2mtvwNhXnlLy8ryEczvX77Ollynfntt1itVkbdcH3Zbc2aNuXfo0eX/FSySIjHQxgmXTt3ZtOmTcc9nsVi4fzzz2fz5s1s27aNa6+9ln79+nHdddexY8cOAD766CP69OlDv379GDp0KC6Xi2nTpvHhhx9y6aWXsnDhQoqKirjzzjsZOHAgl112GZ9//jkA77zzDjfddBPXXnstw4cPZ9u2bfTp0wfwrbh3xx130LdvXy677DIyMzOPuc+x9OnThy+//BKADz74gCFDhpTdd7xYtm3bxtVXX83ll1/O5Zdfzo8//gjAypUrueaaa/jPf/5Dr169GD9+PP5eV05GiIU4TcrjQe3bDft2QXHRP6PAlTDLWTMsYFhQB/aj9u9DtWiN3rCp3x9HCCGCmbl7J+zdhVaeK20B8uf6v+nSqdPJN9Q0cnMP8PMvv/DfcYkot8s3j+SIlnHFxcWsWLGCu+++mwcffJBrr72W6667jrfffpvk5GT+97//MX36dN544w0aN27MwYMHsdls3H333fz222888cQTADz11FPEx8fz7LPPcvDgQQYOHEjPnj0B+P3331myZAn16tVj27ZtZY89a9YsNE3jyy+/5O+//+b6669n+fLlR+1zLIMHD+a5556jX79+/PHHH4wYMYLvv/8egOeff/6YscTGxvLWW28REhLCxo0bue222/j0008BXwnIV199RaNGjRg8eDA//vgj3bp1O7VfzglIQizEKTLzcmHndsg7ALqGZrVVShJ8LL7EGNTWjZj796G164RmlTIKIUTNZxbkwZa/0UKCNxk+lgceeYQfVq3CZrWyaMECAH746Scuv2owuq5z2623cmb79r75JW4XympHKcWWLVu49NJL0TSNyy+/nD59+nD77bfz2muvATBs2DAef/xxAM4//3zuuOMOBg0aRP/+/Y8Zx7Jly1i8eDFpaWkAOJ3OshHmXr16HTOx/fHHH7n55psBOOOMM2jWrBkbN2484T6lOnbsyPbt21m4cGHZiPPJYmnYsCEPPPAAa9euRdf1sscCOPvss8uWYO7UqRPbtm0LroTY5XLx8MMP4/F48Hq9XHTRRVx33XX+iE2IoKE8btSu7ZC9G1wusIeg2QPX4kez2VFOByrre1SHrugRUQGLRQghKpvyeHyLblSDZPjMdmfwSUkJ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\n",
      "text/plain": [
       "<Figure size 864x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot(model=gpr, plot_observed_data=True, plot_predictions=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Parameter containing:\n",
      "tensor(-0.5905, requires_grad=True)\n",
      "Parameter containing:\n",
      "tensor(0.6595, requires_grad=True)\n"
     ]
    }
   ],
   "source": [
    "#print(torch.exp(gpr.kernel.lengthscale_unconstrained))\n",
    "print(gpr.kernel.lengthscale_unconstrained)\n",
    "print(gpr.kernel.variance_unconstrained)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Try to add hyperparameters with posterior distributions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "? GPRegression"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 357,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Copyright (c) 2017-2019 Uber Technologies, Inc.\n",
    "# SPDX-License-Identifier: Apache-2.0\n",
    "\n",
    "import torch\n",
    "import torch.distributions as torchdist\n",
    "from torch.distributions import constraints\n",
    "\n",
    "import pyro\n",
    "import pyro.distributions as dist\n",
    "from pyro.contrib.gp.models.model import GPModel\n",
    "from pyro.contrib.gp.util import conditional\n",
    "from pyro.nn.module import PyroParam, pyro_method, PyroSample\n",
    "from pyro.util import warn_if_nan\n",
    "\n",
    "\n",
    "class GPRegression2(GPModel):\n",
    "    r\"\"\"\n",
    "    Gaussian Process Regression model.\n",
    "\n",
    "    The core of a Gaussian Process is a covariance function :math:`k` which governs\n",
    "    the similarity between input points. Given :math:`k`, we can establish a\n",
    "    distribution over functions :math:`f` by a multivarite normal distribution\n",
    "\n",
    "    .. math:: p(f(X)) = \\mathcal{N}(0, k(X, X)),\n",
    "\n",
    "    where :math:`X` is any set of input points and :math:`k(X, X)` is a covariance\n",
    "    matrix whose entries are outputs :math:`k(x, z)` of :math:`k` over input pairs\n",
    "    :math:`(x, z)`. This distribution is usually denoted by\n",
    "\n",
    "    .. math:: f \\sim \\mathcal{GP}(0, k).\n",
    "\n",
    "    .. note:: Generally, beside a covariance matrix :math:`k`, a Gaussian Process can\n",
    "        also be specified by a mean function :math:`m` (which is a zero-value function\n",
    "        by default). In that case, its distribution will be\n",
    "\n",
    "        .. math:: p(f(X)) = \\mathcal{N}(m(X), k(X, X)).\n",
    "\n",
    "    Given inputs :math:`X` and their noisy observations :math:`y`, the Gaussian Process\n",
    "    Regression model takes the form\n",
    "\n",
    "    .. math::\n",
    "        f &\\sim \\mathcal{GP}(0, k(X, X)),\\\\\n",
    "        y & \\sim f + \\epsilon,\n",
    "\n",
    "    where :math:`\\epsilon` is Gaussian noise.\n",
    "\n",
    "    .. note:: This model has :math:`\\mathcal{O}(N^3)` complexity for training,\n",
    "        :math:`\\mathcal{O}(N^3)` complexity for testing. Here, :math:`N` is the number\n",
    "        of train inputs.\n",
    "\n",
    "    Reference:\n",
    "\n",
    "    [1] `Gaussian Processes for Machine Learning`,\n",
    "    Carl E. Rasmussen, Christopher K. I. Williams\n",
    "\n",
    "    :param torch.Tensor X: A input data for training. Its first dimension is the number\n",
    "        of data points.\n",
    "    :param torch.Tensor y: An output data for training. Its last dimension is the\n",
    "        number of data points.\n",
    "    :param ~pyro.contrib.gp.kernels.kernel.Kernel kernel: A Pyro kernel object, which\n",
    "        is the covariance function :math:`k`.\n",
    "    :param torch.Tensor noise: Variance of Gaussian noise of this model.\n",
    "    :param callable mean_function: An optional mean function :math:`m` of this Gaussian\n",
    "        process. By default, we use zero mean.\n",
    "    :param float jitter: A small positive term which is added into the diagonal part of\n",
    "        a covariance matrix to help stablize its Cholesky decomposition.\n",
    "    \"\"\"\n",
    "    def __init__(self, X, y, kernel, noise=None, mean_function=None, jitter=1e-6):\n",
    "        super().__init__(X, y, kernel, mean_function, jitter)\n",
    "\n",
    "        noise = self.X.new_tensor(1.) if noise is None else noise\n",
    "        self.noise = PyroParam(noise, constraints.positive)\n",
    "        \n",
    "        ### Extend ###\n",
    "        #self.alpha = torch.tensor(3.)\n",
    "        #self.beta = torch.tensor(6.)\n",
    "        #self.alpha = torch.nn.Parameter(torch.tensor(3.))\n",
    "        #self.beta = torch.nn.Parameter(torch.tensor(6.))\n",
    "        self.alpha = PyroParam(torch.tensor(3.), constraints.positive)\n",
    "        self.beta = PyroParam(torch.tensor(6.), constraints.positive)\n",
    "        \n",
    "        ###\n",
    "\n",
    "    @pyro_method\n",
    "    def model(self):\n",
    "        self.set_mode(\"model\")\n",
    "        \n",
    "        ### Extend ###\n",
    "        #alpha0 = torch.tensor(3.)\n",
    "        #beta0 = torch.tensor(6.)\n",
    "        #alpha0 = pyro.param(\"alpha\", 3.)\n",
    "        #beta0 = pyro.param(\"beta\", 6.)\n",
    "        #alpha0 = pyro.sample(\"alpha\", dist.HalfNormal(1.))\n",
    "        #beta0 = pyro.sample(\"beta\", dist.HalfNormal(1.))\n",
    "        #self.kernel.lengthscale = pyro.sample(\"lengthscale\", dist.Gamma(3., 6.))\n",
    "        #lengthscale = pyro.sample(\"lengthscale\", dist.Gamma(alpha0, beta0))\n",
    "        #self.kernel.lengthscale = torch.nn.Parameter(lengthscale)\n",
    "        # Deprecated: self.kernel.set_prior(\"lengthscale\", dist.Gamma(alpha0, beta0))\n",
    "        #self.kernel.lengthscale = PyroSample(dist.Gamma(alpha0, beta0))\n",
    "        \n",
    "        self.kernel.lengthscale = pyro.sample(\"lengthscale\", dist.Gamma(self.alpha, self.beta))\n",
    "        #self.kernel.lengthscale = PyroSample(dist.Gamma(self.alpha, self.beta))\n",
    "        #lengthscale = PyroSample(dist.Gamma(self.alpha, self.beta))\n",
    "        #self.kernel.lengthscale = lengthscale\n",
    "        #lengthscale = pyro.sample(\"lengthscale\", dist.Gamma(self.alpha, self.beta))\n",
    "        #self.kernel.lengthscale = torch.nn.Parameter(lengthscale)\n",
    "        #self.kernel = gp.kernels.RBF(input_dim=1, lengthscale=lengthscale)\n",
    "        ###\n",
    "\n",
    "        N = self.X.size(0)\n",
    "        Kff = self.kernel(self.X)\n",
    "        Kff.view(-1)[::N + 1] += self.jitter + self.noise  # add noise to diagonal\n",
    "        Lff = Kff.cholesky()\n",
    "\n",
    "        zero_loc = self.X.new_zeros(self.X.size(0))\n",
    "        f_loc = zero_loc + self.mean_function(self.X)\n",
    "\n",
    "        \n",
    "        if self.y is None:\n",
    "            f_var = Lff.pow(2).sum(dim=-1)\n",
    "            return f_loc, f_var\n",
    "        else:\n",
    "            return pyro.sample(self._pyro_get_fullname(\"y\"),\n",
    "                               dist.MultivariateNormal(f_loc, scale_tril=Lff)\n",
    "                                   .expand_by(self.y.shape[:-1])\n",
    "                                   .to_event(self.y.dim() - 1),\n",
    "                               obs=self.y)\n",
    "\n",
    "    @pyro_method\n",
    "    def guide(self):\n",
    "        self.set_mode(\"guide\")\n",
    "        #self._load_pyro_samples()\n",
    "        \n",
    "        ### Extend ###      \n",
    "        print(\"guide\")\n",
    "        #alpha = pyro.sample(\"alpha\", dist.HalfNormal(1.))\n",
    "        #beta = pyro.sample(\"beta\", dist.HalfNormal(1.))\n",
    "        alpha = pyro.param(\"alpha\", torch.tensor(3.), constraint=constraints.positive)\n",
    "        beta = pyro.param(\"beta\", torch.tensor(6.), constraint=constraints.positive)\n",
    "        #alpha = PyroParam(torch.tensor(3.), constraint=constraints.positive)\n",
    "        #beta = PyroParam(torch.tensor(6.), constraint=constraints.positive)\n",
    "        #lengthscale = pyro.sample(\"kernel.lengthscale\", dist.Gamma(alpha, beta))\n",
    "        #return lengthscale\n",
    "        pyro.sample(\"lengthscale\", dist.Gamma(alpha, beta))\n",
    "        #self.kernel.lengthscale = pyro.sample(\"lengthscale\", dist.Gamma(alpha, beta))\n",
    "\n",
    "        \n",
    "        N = self.X.size(0)\n",
    "        Kff = self.kernel(self.X)\n",
    "        Kff.view(-1)[::N + 1] += self.jitter + self.noise  # add noise to diagonal\n",
    "        Lff = Kff.cholesky()\n",
    "\n",
    "        zero_loc = self.X.new_zeros(self.X.size(0))\n",
    "        f_loc = zero_loc + self.mean_function(self.X)\n",
    "        \n",
    "        pyro.sample(self._pyro_get_fullname(\"y\"),\n",
    "                               dist.MultivariateNormal(f_loc, scale_tril=Lff)\n",
    "                                   .expand_by(self.y.shape[:-1])\n",
    "                                   .to_event(self.y.dim() - 1))\n",
    "        \n",
    "        ###\n",
    "        self._load_pyro_samples()\n",
    "\n",
    "    def forward(self, Xnew, full_cov=False, noiseless=True):\n",
    "        r\"\"\"\n",
    "        Computes the mean and covariance matrix (or variance) of Gaussian Process\n",
    "        posterior on a test input data :math:`X_{new}`:\n",
    "\n",
    "        .. math:: p(f^* \\mid X_{new}, X, y, k, \\epsilon) = \\mathcal{N}(loc, cov).\n",
    "\n",
    "        .. note:: The noise parameter ``noise`` (:math:`\\epsilon`) together with\n",
    "            kernel's parameters have been learned from a training procedure (MCMC or\n",
    "            SVI).\n",
    "\n",
    "        :param torch.Tensor Xnew: A input data for testing. Note that\n",
    "            ``Xnew.shape[1:]`` must be the same as ``self.X.shape[1:]``.\n",
    "        :param bool full_cov: A flag to decide if we want to predict full covariance\n",
    "            matrix or just variance.\n",
    "        :param bool noiseless: A flag to decide if we want to include noise in the\n",
    "            prediction output or not.\n",
    "        :returns: loc and covariance matrix (or variance) of :math:`p(f^*(X_{new}))`\n",
    "        :rtype: tuple(torch.Tensor, torch.Tensor)\n",
    "        \"\"\"\n",
    "        self._check_Xnew_shape(Xnew)\n",
    "        self.set_mode(\"guide\")\n",
    "        \n",
    "        ### Extend ###\n",
    "        #lengthscale = self.guide()\n",
    "        #self.kernel.lengthscale = torch.nn.Parameter(lengthscale)\n",
    "        print(\"forward\")\n",
    "        ###\n",
    "\n",
    "        N = self.X.size(0)\n",
    "        Kff = self.kernel(self.X).contiguous()\n",
    "        Kff.view(-1)[::N + 1] += self.jitter + self.noise  # add noise to the diagonal\n",
    "        Lff = Kff.cholesky()\n",
    "\n",
    "        y_residual = self.y - self.mean_function(self.X)\n",
    "        loc, cov = conditional(Xnew, self.X, self.kernel, y_residual, None, Lff,\n",
    "                               full_cov, jitter=self.jitter)\n",
    "\n",
    "        if full_cov and not noiseless:\n",
    "            M = Xnew.size(0)\n",
    "            cov = cov.contiguous()\n",
    "            cov.view(-1, M * M)[:, ::M + 1] += self.noise  # add noise to the diagonal\n",
    "        if not full_cov and not noiseless:\n",
    "            cov = cov + self.noise\n",
    "\n",
    "        return loc + self.mean_function(Xnew), cov\n",
    "\n",
    "    def iter_sample(self, noiseless=True):\n",
    "        r\"\"\"\n",
    "        Iteratively constructs a sample from the Gaussian Process posterior.\n",
    "\n",
    "        Recall that at test input points :math:`X_{new}`, the posterior is\n",
    "        multivariate Gaussian distributed with mean and covariance matrix\n",
    "        given by :func:`forward`.\n",
    "\n",
    "        This method samples lazily from this multivariate Gaussian. The advantage\n",
    "        of this approach is that later query points can depend upon earlier ones.\n",
    "        Particularly useful when the querying is to be done by an optimisation\n",
    "        routine.\n",
    "\n",
    "        .. note:: The noise parameter ``noise`` (:math:`\\epsilon`) together with\n",
    "            kernel's parameters have been learned from a training procedure (MCMC or\n",
    "            SVI).\n",
    "\n",
    "        :param bool noiseless: A flag to decide if we want to add sampling noise\n",
    "            to the samples beyond the noise inherent in the GP posterior.\n",
    "        :returns: sampler\n",
    "        :rtype: function\n",
    "        \"\"\"\n",
    "        noise = self.noise.detach()\n",
    "        X = self.X.clone().detach()\n",
    "        y = self.y.clone().detach()\n",
    "        N = X.size(0)\n",
    "        Kff = self.kernel(X).contiguous()\n",
    "        Kff.view(-1)[::N + 1] += noise  # add noise to the diagonal\n",
    "\n",
    "        outside_vars = {\"X\": X, \"y\": y, \"N\": N, \"Kff\": Kff}\n",
    "\n",
    "        def sample_next(xnew, outside_vars):\n",
    "            \"\"\"Repeatedly samples from the Gaussian process posterior,\n",
    "            conditioning on previously sampled values.\n",
    "            \"\"\"\n",
    "            warn_if_nan(xnew)\n",
    "\n",
    "            # Variables from outer scope\n",
    "            X, y, Kff = outside_vars[\"X\"], outside_vars[\"y\"], outside_vars[\"Kff\"]\n",
    "\n",
    "            # Compute Cholesky decomposition of kernel matrix\n",
    "            Lff = Kff.cholesky()\n",
    "            y_residual = y - self.mean_function(X)\n",
    "\n",
    "            # Compute conditional mean and variance\n",
    "            loc, cov = conditional(xnew, X, self.kernel, y_residual, None, Lff,\n",
    "                                   False, jitter=self.jitter)\n",
    "            if not noiseless:\n",
    "                cov = cov + noise\n",
    "\n",
    "            ynew = torchdist.Normal(loc + self.mean_function(xnew), cov.sqrt()).rsample()\n",
    "\n",
    "            # Update kernel matrix\n",
    "            N = outside_vars[\"N\"]\n",
    "            Kffnew = Kff.new_empty(N+1, N+1)\n",
    "            Kffnew[:N, :N] = Kff\n",
    "            cross = self.kernel(X, xnew).squeeze()\n",
    "            end = self.kernel(xnew, xnew).squeeze()\n",
    "            Kffnew[N, :N] = cross\n",
    "            Kffnew[:N, N] = cross\n",
    "            # No noise, just jitter for numerical stability\n",
    "            Kffnew[N, N] = end + self.jitter\n",
    "            # Heuristic to avoid adding degenerate points\n",
    "            if Kffnew.logdet() > -15.:\n",
    "                outside_vars[\"Kff\"] = Kffnew\n",
    "                outside_vars[\"N\"] += 1\n",
    "                outside_vars[\"X\"] = torch.cat((X, xnew))\n",
    "                outside_vars[\"y\"] = torch.cat((y, ynew))\n",
    "\n",
    "            return ynew\n",
    "\n",
    "        return lambda xnew: sample_next(xnew, outside_vars)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 358,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/christofferriis/envs/nostromo/lib/python3.9/site-packages/pyro/util.py:240: UserWarning: Found non-auxiliary vars in guide but not model, consider marking these infer={'is_auxiliary': True}:\n",
      "{'y'}\n",
      "  warnings.warn(\"Found non-auxiliary vars in guide but not model, \"\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n",
      "guide\n"
     ]
    },
    {
     "data": {
      "image/png": "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FEFO7pCMsT16ECpmu4H3KHxXXI25+O2hN+hNUf5EL0BERERE4sOcfxF272swe5Syh9FebwxUDRsNffQgZvGZkV971nmYs84b13UTZfqE8CIiIiIyJqaolJRbPo/Jzhn/OWbPg+OHsY6DbWuBxnqoHl+gPdUpYywiIiIi4c2eBz3dbjeK06eACBvvpjEFxiIiIiISlpk9Dwtw7BC2vs59cJylGVOdAmMRERERCW9WNRifW2dcXwv5RZi8gkSvKi4UGIuIiIhIWCY9HcpnuYHxqZOjDvaY7rT5TkRERERGZarmweH9cOIoZs68RC8nbhQYi4iIiMjoZs+Dhnp3xPScBYleTdwoMBYRERGRUQ3uQjFTO1KAAmMRERERiSQwGpq0dCibldClxJM234mIiIjI6IpK3bHSFbMxvpREryZuFBiLiIiIyKiMMZi3/Q0UlSR6KXGlwFhEREREIvJd+Z5ELyHuVGMsIiIiIoICYxERERERQIGxiIiIiAigwFhEREREBFBgLCIiIiICKDAWEREREQEUGIuIiIiIAAqMRUREREQABcYiIiIiIoACYxERERERQIGxiIiIiAigwFhEREREBFBgLCIiIiICKDAWEREREQEUGIuIiIiIAAqMRUREREQABcYiIiIiIoACYxERERERAIy11iZ6ESIiIiIiiZb0GePbb7890UuQSaJ7nTx0r5OH7nXy0L1OHom810kfGIuIiIiIgAJjERERERFAgTEbNmxI9BJkkuheJw/d6+She508dK+TRyLvtTbfiYiIiIigjLGIiIiICAD+RC8gUXbu3MlDDz2E4zhcfvnlXH311YleksRIfX09999/P01NTRhj2LBhA1deeSVtbW3cfffdnDp1itLSUj75yU+Sk5OT6OVKDDiOw+23305RURG33347dXV13HPPPbS2trJgwQJuvvlm/P6k/c/djNHe3s7mzZs5evQoxhg+9rGPUVlZqZ/rGeg3v/kNTz75JMYY5syZw8aNG2lqatLP9Qzw7W9/m5deeon8/Hw2bdoEEPb/n621PPTQQ+zYsYP09HQ2btzIggUL4rq+pMwYO47Dgw8+yGc+8xnuvvtunn32WY4dO5boZUmMpKSkcP3113P33Xdzxx138Pjjj3Ps2DEee+wxVqxYwb333suKFSt47LHHEr1UiZHf/va3VFVVBb9++OGHecc73sG3vvUtsrOzefLJJxO4OomVhx56iFWrVnHPPfdw1113UVVVpZ/rGaihoYHf/e533HnnnWzatAnHcXjuuef0cz1DXHLJJXzmM58Z8li4n+MdO3Zw8uRJ7r33Xj784Q/zwAMPxH19SRkY79+/n4qKCsrLy/H7/Vx44YVs27Yt0cuSGCksLAz+RpmZmUlVVRUNDQ1s27aNiy++GICLL75Y93yGOH36NC+99BKXX345ANZaXnvtNdatWwe4/xHWvZ7+Ojo62L17N5dddhkAfr+f7Oxs/VzPUI7j0NPTQ39/Pz09PRQUFOjneoZYvnz5iL/qhPs53r59OxdddBHGGJYsWUJ7ezuNjY1xXV9S/g2ioaGB4uLi4NfFxcXs27cvgSuSeKmrq+PgwYMsWrSI5uZmCgsLASgoKKC5uTnBq5NY+P73v8/73/9+Ojs7AWhtbSUrK4uUlBQAioqKaGhoSOQSJQbq6urIy8vj29/+NocPH2bBggXceOON+rmegYqKinjnO9/Jxz72MdLS0jj77LNZsGCBfq5nsHA/xw0NDZSUlASPKy4upqGhIXhsPCRlxliSQ1dXF5s2beLGG28kKytryHPGGIwxCVqZxMqLL75Ifn5+3GvOJPH6+/s5ePAgV1xxBV//+tdJT08fUTahn+uZoa2tjW3btnH//ffz3e9+l66uLnbu3JnoZckkSfTPcVJmjIuKijh9+nTw69OnT1NUVJTAFUms9fX1sWnTJtavX8/atWsByM/Pp7GxkcLCQhobG8nLy0vwKmWi9uzZw/bt29mxYwc9PT10dnby/e9/n46ODvr7+0lJSaGhoUE/3zNAcXExxcXFLF68GIB169bx2GOP6ed6BvrLX/5CWVlZ8F6uXbuWPXv26Od6Bgv3c1xUVER9fX3wuMmI15IyY7xw4UJOnDhBXV0dfX19PPfcc6xevTrRy5IYsdayefNmqqqquOqqq4KPr169mqeffhqAp59+mjVr1iRqiRIjf/d3f8fmzZu5//77+cQnPsFZZ53FLbfcwplnnsnzzz8PwFNPPaWf7xmgoKCA4uJiampqADd4mj17tn6uZ6CSkhL27dtHd3c31trgvdbP9cwV7ud49erVbN26FWste/fuJSsrK65lFJDEAz5eeuklfvCDH+A4DpdeeinXXHNNopckMfL666/z+c9/nurq6uCfY6677joWL17M3XffTX19vdo6zUCvvfYav/71r7n99tupra3lnnvuoa2tjfnz53PzzTeTmpqa6CXKBB06dIjNmzfT19dHWVkZGzduxFqrn+sZ6JFHHuG5554jJSWFefPm8dGPfpSGhgb9XM8A99xzD7t27aK1tZX8/HyuvfZa1qxZE/Ln2FrLgw8+yMsvv0xaWhobN25k4cKFcV1f0gbGIiIiIiKDJWUphYiIiIjIcAqMRURERERQYCwiIiIiAigwFhEREREBFBiLiIiIiAAKjEVEREREAAXGIiIiIiKAAmMREREREQD+f6lmPZ5fZPEhAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# initialize the kernel, likelihood, and model\n",
    "pyro.clear_param_store()\n",
    "kernel = gp.kernels.RBF(input_dim=1)\n",
    "\n",
    "# turn on \"whiten\" flag for more stable optimization\n",
    "gpr = GPRegression2(X_train_tensor.view(-1,), y_train_tensor.view(-1,), kernel)\n",
    "\n",
    "# instead of defining our own training loop, we will\n",
    "# use the built-in support provided by the GP module\n",
    "num_steps = 100\n",
    "losses = gp.util.train(gpr, num_steps=num_steps)  # default: loss_fn=TraceMeanField_ELBO().differentiable_loss\n",
    "plt.plot(losses);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 359,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "alpha:\n",
      "3.0\n",
      "\n",
      "beta:\n",
      "6.0\n",
      "\n",
      "kernel.lengthscale:\n",
      "1.01962149143219\n",
      "\n",
      "kernel.variance:\n",
      "1.0720324516296387\n",
      "\n",
      "noise:\n",
      "0.3747535746863864\n",
      "\n"
     ]
    }
   ],
   "source": [
    "for key, value in pyro.get_param_store().items():    \n",
    "    print(f\"{key}:\\n{value}\\n\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 360,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(1.0196, grad_fn=<AddBackward0>)\n",
      "Parameter containing:\n",
      "tensor(0.0696, requires_grad=True)\n"
     ]
    }
   ],
   "source": [
    "print(gpr.kernel.lengthscale)\n",
    "print(gpr.kernel.variance_unconstrained)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 361,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "forward\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot(model=gpr, plot_observed_data=True, plot_predictions=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Manually VI"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 362,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "\n",
    "from pyro.infer import TraceMeanField_ELBO\n",
    "from pyro.infer.util import torch_backward, torch_item\n",
    "\n",
    "def train(gpmodule, optimizer=None, loss_fn=None, retain_graph=None, num_steps=1000):\n",
    "    \"\"\"\n",
    "    A helper to optimize parameters for a GP module.\n",
    "\n",
    "    :param ~pyro.contrib.gp.models.GPModel gpmodule: A GP module.\n",
    "    :param ~torch.optim.Optimizer optimizer: A PyTorch optimizer instance.\n",
    "        By default, we use Adam with ``lr=0.01``.\n",
    "    :param callable loss_fn: A loss function which takes inputs are\n",
    "        ``gpmodule.model``, ``gpmodule.guide``, and returns ELBO loss.\n",
    "        By default, ``loss_fn=TraceMeanField_ELBO().differentiable_loss``.\n",
    "    :param bool retain_graph: An optional flag of ``torch.autograd.backward``.\n",
    "    :param int num_steps: Number of steps to run SVI.\n",
    "    :returns: a list of losses during the training procedure\n",
    "    :rtype: list\n",
    "    \"\"\"\n",
    "    optimizer = (torch.optim.Adam(gpmodule.parameters(), lr=0.01)\n",
    "                 if optimizer is None else optimizer)\n",
    "    # TODO: add support for JIT loss\n",
    "    loss_fn = TraceMeanField_ELBO().differentiable_loss if loss_fn is None else loss_fn\n",
    "\n",
    "    def closure():\n",
    "        optimizer.zero_grad()\n",
    "        loss = loss_fn(gpmodule.model, gpmodule.guide)\n",
    "        torch_backward(loss, retain_graph)\n",
    "        return loss\n",
    "\n",
    "    losses = []\n",
    "    for i in range(num_steps):\n",
    "        loss = optimizer.step(closure)\n",
    "        losses.append(torch_item(loss))\n",
    "    return losses"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 363,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "ename": "RuntimeError",
     "evalue": "AutoDiagonalNormal found no latent variables; Use an empty guide instead\nTrace Shapes:\n Param Sites:\nSample Sites:",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mRuntimeError\u001b[0m                              Traceback (most recent call last)",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/poutine/trace_messenger.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    164\u001b[0m             \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 165\u001b[0;31m                 \u001b[0mret\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfn\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    166\u001b[0m             \u001b[0;32mexcept\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mValueError\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mRuntimeError\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0me\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/nn/module.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    412\u001b[0m         \u001b[0;32mwith\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_pyro_context\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 413\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0msuper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__call__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    414\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/torch/nn/modules/module.py\u001b[0m in \u001b[0;36m_call_impl\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m    888\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 889\u001b[0;31m             \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    890\u001b[0m         for hook in itertools.chain(\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/autoguide/guides.py\u001b[0m in \u001b[0;36mforward\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    723\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mprototype_trace\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 724\u001b[0;31m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_setup_prototype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    725\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/autoguide/guides.py\u001b[0m in \u001b[0;36m_setup_prototype\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    887\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_setup_prototype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 888\u001b[0;31m         \u001b[0msuper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_setup_prototype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    889\u001b[0m         \u001b[0;31m# Initialize guide params\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/autoguide/guides.py\u001b[0m in \u001b[0;36m_setup_prototype\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    631\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlatent_dim\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 632\u001b[0;31m             \u001b[0;32mraise\u001b[0m \u001b[0mRuntimeError\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'{} found no latent variables; Use an empty guide instead'\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mformat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__name__\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    633\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mRuntimeError\u001b[0m: AutoDiagonalNormal found no latent variables; Use an empty guide instead",
      "\nThe above exception was the direct cause of the following exception:\n",
      "\u001b[0;31mRuntimeError\u001b[0m                              Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-363-0eb8701a6a2f>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     20\u001b[0m \u001b[0madvi_loss\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     21\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mstep\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1000\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 22\u001b[0;31m     \u001b[0madvi_loss\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msvi\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstep\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mX_train_tensor\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mview\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my_train_tensor\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mview\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkernel\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     23\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     24\u001b[0m \u001b[0;31m# Bijector for advi samples.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/svi.py\u001b[0m in \u001b[0;36mstep\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    126\u001b[0m         \u001b[0;31m# get loss and compute gradients\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    127\u001b[0m         \u001b[0;32mwith\u001b[0m \u001b[0mpoutine\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtrace\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mparam_only\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0mparam_capture\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 128\u001b[0;31m             \u001b[0mloss\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mloss_and_grads\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmodel\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mguide\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    129\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    130\u001b[0m         params = set(site[\"value\"].unconstrained()\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/trace_elbo.py\u001b[0m in \u001b[0;36mloss_and_grads\u001b[0;34m(self, model, guide, *args, **kwargs)\u001b[0m\n\u001b[1;32m    129\u001b[0m         \u001b[0mloss\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m0.0\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    130\u001b[0m         \u001b[0;31m# grab a trace from the generator\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 131\u001b[0;31m         \u001b[0;32mfor\u001b[0m \u001b[0mmodel_trace\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mguide_trace\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_get_traces\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmodel\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mguide\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    132\u001b[0m             \u001b[0mloss_particle\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0msurrogate_loss_particle\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_differentiable_loss_particle\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmodel_trace\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mguide_trace\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    133\u001b[0m             \u001b[0mloss\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0mloss_particle\u001b[0m \u001b[0;34m/\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnum_particles\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/elbo.py\u001b[0m in \u001b[0;36m_get_traces\u001b[0;34m(self, model, guide, args, kwargs)\u001b[0m\n\u001b[1;32m    168\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    169\u001b[0m             \u001b[0;32mfor\u001b[0m \u001b[0mi\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnum_particles\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 170\u001b[0;31m                 \u001b[0;32myield\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_get_trace\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmodel\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mguide\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/trace_elbo.py\u001b[0m in \u001b[0;36m_get_trace\u001b[0;34m(self, model, guide, args, kwargs)\u001b[0m\n\u001b[1;32m     55\u001b[0m         \u001b[0magainst\u001b[0m \u001b[0mit\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     56\u001b[0m         \"\"\"\n\u001b[0;32m---> 57\u001b[0;31m         model_trace, guide_trace = get_importance_trace(\n\u001b[0m\u001b[1;32m     58\u001b[0m             \"flat\", self.max_plate_nesting, model, guide, args, kwargs)\n\u001b[1;32m     59\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mis_validation_enabled\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/enum.py\u001b[0m in \u001b[0;36mget_importance_trace\u001b[0;34m(graph_type, max_plate_nesting, model, guide, args, kwargs, detach)\u001b[0m\n\u001b[1;32m     42\u001b[0m     \u001b[0;32mand\u001b[0m \u001b[0mthe\u001b[0m \u001b[0mmodel\u001b[0m \u001b[0mthat\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0mrun\u001b[0m \u001b[0magainst\u001b[0m \u001b[0mit\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     43\u001b[0m     \"\"\"\n\u001b[0;32m---> 44\u001b[0;31m     \u001b[0mguide_trace\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mpoutine\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtrace\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mguide\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mgraph_type\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mgraph_type\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget_trace\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     45\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mdetach\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     46\u001b[0m         \u001b[0mguide_trace\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdetach_\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/poutine/trace_messenger.py\u001b[0m in \u001b[0;36mget_trace\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    185\u001b[0m         \u001b[0mCalls\u001b[0m \u001b[0mthis\u001b[0m \u001b[0mpoutine\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0mreturns\u001b[0m \u001b[0mits\u001b[0m \u001b[0mtrace\u001b[0m \u001b[0minstead\u001b[0m \u001b[0mof\u001b[0m \u001b[0mthe\u001b[0m \u001b[0mfunction\u001b[0m\u001b[0;31m'\u001b[0m\u001b[0ms\u001b[0m \u001b[0;32mreturn\u001b[0m \u001b[0mvalue\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    186\u001b[0m         \"\"\"\n\u001b[0;32m--> 187\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    188\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmsngr\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget_trace\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/poutine/trace_messenger.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    169\u001b[0m                 \u001b[0mexc\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mexc_type\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34mu\"{}\\n{}\"\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mformat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mexc_value\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mshapes\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    170\u001b[0m                 \u001b[0mexc\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mexc\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mwith_traceback\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtraceback\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 171\u001b[0;31m                 \u001b[0;32mraise\u001b[0m \u001b[0mexc\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0me\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    172\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmsngr\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtrace\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0madd_node\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"_RETURN\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mname\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"_RETURN\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtype\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"return\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mvalue\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mret\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    173\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mret\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/poutine/trace_messenger.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    163\u001b[0m                                       args=args, kwargs=kwargs)\n\u001b[1;32m    164\u001b[0m             \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 165\u001b[0;31m                 \u001b[0mret\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfn\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    166\u001b[0m             \u001b[0;32mexcept\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mValueError\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mRuntimeError\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0me\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    167\u001b[0m                 \u001b[0mexc_type\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mexc_value\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtraceback\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msys\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mexc_info\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/nn/module.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    411\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__call__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    412\u001b[0m         \u001b[0;32mwith\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_pyro_context\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 413\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0msuper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__call__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    414\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    415\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__getattr__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mname\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/torch/nn/modules/module.py\u001b[0m in \u001b[0;36m_call_impl\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m    887\u001b[0m             \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_slow_forward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    888\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 889\u001b[0;31m             \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    890\u001b[0m         for hook in itertools.chain(\n\u001b[1;32m    891\u001b[0m                 \u001b[0m_global_forward_hooks\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mvalues\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/autoguide/guides.py\u001b[0m in \u001b[0;36mforward\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    722\u001b[0m         \u001b[0;31m# if we've never run the model before, do so now so we can inspect the model structure\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    723\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mprototype_trace\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 724\u001b[0;31m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_setup_prototype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    725\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    726\u001b[0m         \u001b[0mlatent\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msample_latent\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/autoguide/guides.py\u001b[0m in \u001b[0;36m_setup_prototype\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    886\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    887\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_setup_prototype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 888\u001b[0;31m         \u001b[0msuper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_setup_prototype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    889\u001b[0m         \u001b[0;31m# Initialize guide params\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    890\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mloc\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mParameter\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_init_loc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/autoguide/guides.py\u001b[0m in \u001b[0;36m_setup_prototype\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    630\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlatent_dim\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0m_product\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mshape\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mshape\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_unconstrained_shapes\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mvalues\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    631\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlatent_dim\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 632\u001b[0;31m             \u001b[0;32mraise\u001b[0m \u001b[0mRuntimeError\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'{} found no latent variables; Use an empty guide instead'\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mformat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__name__\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    633\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    634\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_init_loc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mRuntimeError\u001b[0m: AutoDiagonalNormal found no latent variables; Use an empty guide instead\nTrace Shapes:\n Param Sites:\nSample Sites:"
     ]
    }
   ],
   "source": [
    "### ADVI ###\n",
    "# For ADVI\n",
    "from pyro.infer import SVI, Trace_ELBO, TraceEnum_ELBO, JitTrace_ELBO\n",
    "from pyro.contrib.autoguide import AutoDiagonalNormal, AutoGuide\n",
    "from pyro.optim import Adam\n",
    "\n",
    "pyro.clear_param_store()  # clear global parameter cache\n",
    "pyro.set_rng_seed(1)  # set random seed\n",
    "\n",
    "#gpr = GPRegression(X_train_tensor.view(-1,), y_train_tensor.view(-1,), kernel)\n",
    "\n",
    "# Automatically define variational distribution (a mean field guide).\n",
    "guide = AutoDiagonalNormal(GPRegression)\n",
    "\n",
    "\n",
    "# Create SVI object for optimization.\n",
    "svi = SVI(GPRegression, guide, Adam({'lr': 1e-2}), Trace_ELBO())\n",
    "\n",
    "# Do 1000 gradient steps.\n",
    "advi_loss = []\n",
    "for step in range(1000):\n",
    "    advi_loss.append(svi.step(X_train_tensor.view(-1,), y_train_tensor.view(-1,), kernel))\n",
    "    \n",
    "# Bijector for advi samples.\n",
    "def biject(samples):\n",
    "    return dict(alpha=samples[:, 0].exp().numpy(),\n",
    "                rho=samples[:, 1].exp().numpy(),\n",
    "                sigma=samples[:, 2].exp().numpy())\n",
    "\n",
    "# Get ADVI samples in constrained space.\n",
    "advi_posterior_samples = biject(guide.get_posterior().sample((1000, )))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Attempt 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 419,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define GP Model\n",
    "def make_gp_model(X, y,\n",
    "                  length_prior=dist.LogNormal(0.0, 1.0),\n",
    "                  variance_prior=dist.LogNormal(0.0, 0.1),\n",
    "                  noise_prior=dist.LogNormal(0.0, 1.0)):\n",
    "    \n",
    "    # Define squared exponential covariance function.\n",
    "    cov_fn = gp.kernels.RBF(input_dim=1)\n",
    "\n",
    "    # Define GP regression model.\n",
    "    gpr = gp.models.GPRegression(X, y, cov_fn)\n",
    "\n",
    "    # Place priors on GP covariance function parameters.\n",
    "    gpr.kernel.lengthscale = pyro.nn.PyroSample(length_prior)\n",
    "    gpr.kernel.variance = pyro.nn.PyroSample(variance_prior)\n",
    "    gpr.noise = pyro.nn.PyroSample(noise_prior)\n",
    "    \n",
    "    \n",
    "    # Priors for kernel parameters.\n",
    "    #length_prior = PyroSample(dist.LogNormal(0., 1.))\n",
    "    #variance_prior = PyroSample(dist.LogNormal(0., 0.1))\n",
    "    #noise_prior = PyroSample(dist.LogNormal(0., 1.))\n",
    "    \n",
    "    # Place priors on GP covariance function parameters.\n",
    "    #gpr.kernel.lengthscale = PyroSample(dist.LogNormal(0., 1.))\n",
    "    #gpr.kernel.variance = PyroSample(dist.LogNormal(0., 0.1))\n",
    "    #gpr.noise = PyroSample(dist.LogNormal(0., 1.))\n",
    "    \n",
    "    \"\"\"\n",
    "    N = X.shape[0]\n",
    "    \n",
    "    # Priors for kernel parameters.\n",
    "    variance = pyro.sample(\"alpha\", dist.LogNormal(0., 0.1))\n",
    "    lengthscale = pyro.sample(\"rho\", dist.LogNormal(0., 1.))\n",
    "    noise = pyro.sample(\"sigma\", dist.LogNormal(0., 1.))\n",
    "    \n",
    "    gpr.kernel.lengthscale = PyroSample(dist.LogNormal(0., 1.))\n",
    "    gpr.kernel.variance = PyroSample(dist.LogNormal(0., 0.1))\n",
    "    gpr.noise = PyroSample(dist.LogNormal(0., 1.))\n",
    "    \n",
    "    # Covariance matrix. \n",
    "    K = gpr.kernel(X).contiguous()\n",
    "    K.view(-1)[::N + 1] += 1e-6 + gpr.noise * gpr.noise # add noise to the diagonal\n",
    "    L = torch.cholesky(K)\n",
    "    \n",
    "    # Marginal likelihood.\n",
    "    pyro.sample('obs',\n",
    "                dist.MultivariateNormal(torch.zeros(N), scale_tril=L),\n",
    "                obs=y)\n",
    "    \"\"\"\n",
    "    return gpr"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 420,
   "metadata": {},
   "outputs": [],
   "source": [
    "X = X_train_tensor.view(-1,)\n",
    "y = y_train_tensor.view(-1,)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 421,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Sample: 100%|██████████| 150/150 [00:07, 19.52it/s, step size=8.18e-01, acc. prob=0.899]\n"
     ]
    }
   ],
   "source": [
    "### NUTS ###\n",
    "from pyro.infer.mcmc.api import MCMC\n",
    "from pyro.infer.mcmc import NUTS\n",
    "\n",
    "pyro.clear_param_store() \n",
    "pyro.set_rng_seed(1)\n",
    "nuts_gpr = make_gp_model(X, y)\n",
    "kernel = NUTS(nuts_gpr.model, target_accept_prob=0.8)\n",
    "nuts = MCMC(kernel, num_samples=100, warmup_steps=50)\n",
    "nuts.run()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 422,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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0aMQ/9nHunXr4mc/+1lce+21MW/evNiyZUujx0rrySefjPHjx8fcuXPjhhtuiF/96lfR2dnZ6LGgaTz//PPx17/+NS6++OJGj9InmiZ+u/NxyR88ZteuXbF169Y44ogj+nTOLLr78dXPPfdcLFiwIKZNm+av2uuoq31s27Yt1qxZE7/4xS/iqquuipdffjn+93//N1599dVGjHtQ6+7vVePGjYtCoRBDhw6No48+OtatW9fXo6bQnX0sWrQovvjFL0ZExOjRo2PHjh3+1rBBBg8eHB0dHbu/3tefLfSd119/PebNmxdTp05N01RNE7/d+bjkz33uc/Hoo49GxH/+RfsJJ5wQLS0tDZj24NedfaxevTruuuuumDZtmvc01llX++jXr1/cfffdMXv27Jg9e3aMGjUqpk2b5qc91EF3ro0vfOELsXLlyoiIeOedd2LdunUxbNiwRox70OvOPorFYjz//PMREfHGG2/Ejh07YsCAAY0YN71x48bF4sWLo1KpxEsvvRT9+vXzHuwG6ujoiFtvvTWuvvrqaGtra/Q4faapPuRi2bJlcc899+z+uOQLL7ww7r///jjuuONi3LhxsX379rjzzjtj9erV0b9//5gyZYo/UOqoq33cdNNN8c9//jOOPPLIiPjPHzDTp09v7NAHsa728UE///nP49JLLxW/ddLVLiqVStx7772xfPny+MhHPhIXXnhhnHHGGY0e+6DV1T7eeOONmDdvXmzbti0iIi655JIYO3Zsg6c+OM2aNStWrVoVmzdvjoEDB8aECRNi586dERHxla98JSqVStx9993x97//PQ455JCYPHmy36fqqKt9zJ07N/72t7/tfh92a2trtLe3N3LkPtFU8QsAAPXUNG97AACAehO/AACkIX4BAEhD/AIAkIb4BQAgDfELAEAa4hcAgDTELwAAafwf+iEMMJeVSosAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Get posterior samples\n",
    "nuts_posterior_samples = nuts.get_samples()\n",
    "nuts_posterior_samples = {k: nuts_posterior_samples[k].numpy()\n",
    "                          for k in nuts_posterior_samples}\n",
    "for k in nuts_posterior_samples.keys():\n",
    "    plt.hist(nuts_posterior_samples[k], bins=20)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Make predictions with MCMC"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### VI?"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 299,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Model definition.\n",
    "def sq_exp_kernel(d, alpha, rho):\n",
    "    return alpha * alpha * torch.exp(-0.5 * torch.pow(d / rho, 2))\n",
    "\n",
    "def sq_exp_kernel_matrix(X, alpha, rho):\n",
    "    D = torch.cdist(X, X)\n",
    "    return sq_exp_kernel(D, alpha, rho)\n",
    "\n",
    "def gp_model(X, y):\n",
    "    N = X.shape[0]\n",
    "    \n",
    "    # Priors for kernel parameters.\n",
    "    lengthscale = pyro.sample(\"lengthscale\", dist.LogNormal(0., 1.))\n",
    "    outputscale = pyro.sample(\"outputscale\", dist.LogNormal(0., 0.1))\n",
    "    noise = pyro.sample(\"noise\", dist.LogNormal(0., 1.))\n",
    "    \n",
    "    # Covariance matrix. \n",
    "    K = sq_exp_kernel_matrix(X, outputscale, lengthscale) + torch.eye(N) * noise * noise\n",
    "    L = torch.cholesky(K)\n",
    "    \n",
    "    # Marginal likelihood.\n",
    "    pyro.sample('obs',\n",
    "                dist.MultivariateNormal(torch.zeros(N), scale_tril=L),\n",
    "                obs=y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 321,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define GP Model\n",
    "def make_gp_model(X, y,\n",
    "                  length_prior=dist.LogNormal(0.0, 1.0),\n",
    "                  variance_prior=dist.LogNormal(0.0, 0.1),\n",
    "                  noise_prior=dist.LogNormal(0.0, 1.0)):\n",
    "\n",
    "    \n",
    "    #length_prior=dist.Gamma(3.,6.)\n",
    "    #variance_prior=dist.Gamma(2., 0.15)\n",
    "    #noise_prior=dist.LogNormal(0,1.)\n",
    "    \n",
    "    # Define squared exponential covariance function.\n",
    "    cov_fn = gp.kernels.RBF(input_dim=1)\n",
    "\n",
    "    # Define GP regression model.\n",
    "    gpr = gp.models.GPRegression(X, y, cov_fn)\n",
    "\n",
    "    # Place priors on GP covariance function parameters.\n",
    "    #gpr.kernel.lengthscale = PyroSample(length_prior)\n",
    "    #gpr.kernel.variance = PyroSample(variance_prior)\n",
    "    #gpr.noise = PyroSample(noise_prior)\n",
    "    \n",
    "    \n",
    "    # Priors for kernel parameters.\n",
    "    #length_prior = PyroSample(dist.LogNormal(0., 1.))\n",
    "    #variance_prior = PyroSample(dist.LogNormal(0., 0.1))\n",
    "    #noise_prior = PyroSample(dist.LogNormal(0., 1.))\n",
    "    \n",
    "    # Place priors on GP covariance function parameters.\n",
    "    #gpr.kernel.lengthscale = PyroSample(dist.LogNormal(0., 1.))\n",
    "    #gpr.kernel.variance = PyroSample(dist.LogNormal(0., 0.1))\n",
    "    #gpr.noise = PyroSample(dist.LogNormal(0., 1.))\n",
    "    \n",
    "    gpr.kernel.lengthscale = pyro.sample(\"lengthscale\", length_prior)\n",
    "    #gpr.kernel.variance = torch.pow(pyro.sample(\"variance\", variance_prior), 2)\n",
    "    #gpr.noise = torch.pow(pyro.sample(\"noise\", noise_prior), 2)\n",
    "    gpr.kernel.variance = pyro.sample(\"variance\", variance_prior)\n",
    "    gpr.noise = pyro.sample(\"noise\", noise_prior)\n",
    "    \n",
    "    \"\"\"\n",
    "    N = gpr.X.size(0)\n",
    "    Kff = gpr.kernel(X)\n",
    "    Kff.view(-1)[::N + 1] += gpr.jitter + gpr.noise  # add noise to diagonal\n",
    "    Lff = Kff.cholesky()\n",
    "\n",
    "    zero_loc = gpr.X.new_zeros(gpr.X.size(0))\n",
    "    f_loc = zero_loc + gpr.mean_function(gpr.X)\n",
    "\n",
    "    pyro.sample(gpr._pyro_get_fullname(\"y\"),\n",
    "                           dist.MultivariateNormal(f_loc, scale_tril=Lff)\n",
    "                               .expand_by(gpr.y.shape[:-1])\n",
    "                               .to_event(gpr.y.dim() - 1))\n",
    "    \"\"\"\n",
    "    #N = X.shape[0]\n",
    "    \n",
    "    \n",
    "    # Priors for kernel parameters.\n",
    "    #variance = pyro.sample(\"alpha\", dist.LogNormal(0., 0.1))\n",
    "    #lengthscale = pyro.sample(\"rho\", dist.LogNormal(0., 1.))\n",
    "    #noise = pyro.sample(\"sigma\", dist.LogNormal(0., 1.))\n",
    "    \n",
    "    \n",
    "    #l_alpha = PyroParam(6., constraint=constraints.positive)\n",
    "    #l_beta = PyroParam(3., constraint=constraints.positive)\n",
    "    #l_alpha = pyro.param('l_alpha', torch.tensor(6.), constraint=constraints.positive)\n",
    "    #l_beta = pyro.param('l_beta', torch.tensor(10.), constraint=constraints.positive) \n",
    "    #v_alpha = pyro.param('v_alpha', torch.tensor(6.), constraint=constraints.positive)\n",
    "    #v_beta = pyro.param('v_beta', torch.tensor(10.), constraint=constraints.positive) \n",
    "    #n_alpha = pyro.param('n_alpha', torch.tensor(6.), constraint=constraints.positive)\n",
    "    #n_beta = pyro.param('n_beta', torch.tensor(10.), constraint=constraints.positive)\n",
    "    \"\"\"\n",
    "    l_alpha = torch.tensor(6.)\n",
    "    l_beta = torch.tensor(3.) \n",
    "    #v_alpha = torch.tensor(2.)\n",
    "    #v_beta = torch.tensor(0.15) \n",
    "    n_alpha = torch.tensor(0.)\n",
    "    n_beta = torch.tensor(.1) \n",
    "    \n",
    "    # Priors for kernel parameters.\n",
    "    #gpr.kernel.variance = pyro.sample(\"variance\", dist.LogNormal(v_alpha, v_beta))\n",
    "    gpr.kernel.lengthscale = pyro.sample(\"lengthscale\", dist.Gamma(l_alpha, l_beta))\n",
    "    #gpr.kernel.lengthscale = PyroSample(dist.LogNormal(l_alpha, l_beta))\n",
    "    gpr.noise = pyro.sample(\"noise\", dist.LogNormal(n_alpha, n_beta))\n",
    "    \"\"\"\n",
    "    \n",
    "    #gpr.kernel.lengthscale = PyroSample(dist.LogNormal(0., 1.))\n",
    "    #gpr.kernel.variance = variance # PyroSample(dist.LogNormal(0., 0.1))\n",
    "    #gpr.noise = noise #PyroSample(dist.LogNormal(0., 1.))\n",
    "    \n",
    "    return gpr"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 322,
   "metadata": {},
   "outputs": [],
   "source": [
    "def my_guide():\n",
    "    #model.gpr.set_mode(\"guide\")\n",
    "    #l_alpha = pyro.param('l_alpha', torch.tensor(6.), constraint=constraints.positive)\n",
    "    #l_beta = pyro.param('l_beta', torch.tensor(10.), constraint=constraints.positive) \n",
    "    #pyro.sample(\"lengthscale\", dist.Gamma(l_alpha, l_beta))\n",
    "    \n",
    "    length_prior=dist.LogNormal(0.0, 1.0)\n",
    "    variance_prior=dist.LogNormal(0.0, 0.1)\n",
    "    noise_prior=dist.LogNormal(0.0, 1.0)\n",
    "    pyro.sample(\"lengthscale\", length_prior)\n",
    "    pyro.sample(\"variance\", variance_prior)\n",
    "    pyro.sample(\"noise\", noise_prior)\n",
    "    \n",
    "    \n",
    "    \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 324,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "ename": "RuntimeError",
     "evalue": "AutoMultivariateNormal found no latent variables; Use an empty guide instead\nTrace Shapes:\n Param Sites:\nSample Sites:",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mRuntimeError\u001b[0m                              Traceback (most recent call last)",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/poutine/trace_messenger.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    164\u001b[0m             \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 165\u001b[0;31m                 \u001b[0mret\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfn\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    166\u001b[0m             \u001b[0;32mexcept\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mValueError\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mRuntimeError\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0me\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/nn/module.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    412\u001b[0m         \u001b[0;32mwith\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_pyro_context\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 413\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0msuper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__call__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    414\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/torch/nn/modules/module.py\u001b[0m in \u001b[0;36m_call_impl\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m    888\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 889\u001b[0;31m             \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    890\u001b[0m         for hook in itertools.chain(\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/autoguide/guides.py\u001b[0m in \u001b[0;36mforward\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    723\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mprototype_trace\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 724\u001b[0;31m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_setup_prototype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    725\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/autoguide/guides.py\u001b[0m in \u001b[0;36m_setup_prototype\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    833\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_setup_prototype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 834\u001b[0;31m         \u001b[0msuper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_setup_prototype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    835\u001b[0m         \u001b[0;31m# Initialize guide params\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/autoguide/guides.py\u001b[0m in \u001b[0;36m_setup_prototype\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    631\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlatent_dim\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 632\u001b[0;31m             \u001b[0;32mraise\u001b[0m \u001b[0mRuntimeError\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'{} found no latent variables; Use an empty guide instead'\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mformat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__name__\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    633\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mRuntimeError\u001b[0m: AutoMultivariateNormal found no latent variables; Use an empty guide instead",
      "\nThe above exception was the direct cause of the following exception:\n",
      "\u001b[0;31mRuntimeError\u001b[0m                              Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-324-52c2c3a53586>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     22\u001b[0m \u001b[0madvi_loss\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     23\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mstep\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m400\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 24\u001b[0;31m     \u001b[0madvi_loss\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msvi\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstep\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mX_train_tensor\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mview\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my_train_tensor\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mview\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     25\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     26\u001b[0m \u001b[0;31m# Bijector for advi samples.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/svi.py\u001b[0m in \u001b[0;36mstep\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    126\u001b[0m         \u001b[0;31m# get loss and compute gradients\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    127\u001b[0m         \u001b[0;32mwith\u001b[0m \u001b[0mpoutine\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtrace\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mparam_only\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0mparam_capture\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 128\u001b[0;31m             \u001b[0mloss\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mloss_and_grads\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmodel\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mguide\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    129\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    130\u001b[0m         params = set(site[\"value\"].unconstrained()\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/trace_elbo.py\u001b[0m in \u001b[0;36mloss_and_grads\u001b[0;34m(self, model, guide, *args, **kwargs)\u001b[0m\n\u001b[1;32m    129\u001b[0m         \u001b[0mloss\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m0.0\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    130\u001b[0m         \u001b[0;31m# grab a trace from the generator\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 131\u001b[0;31m         \u001b[0;32mfor\u001b[0m \u001b[0mmodel_trace\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mguide_trace\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_get_traces\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmodel\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mguide\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    132\u001b[0m             \u001b[0mloss_particle\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0msurrogate_loss_particle\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_differentiable_loss_particle\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmodel_trace\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mguide_trace\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    133\u001b[0m             \u001b[0mloss\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0mloss_particle\u001b[0m \u001b[0;34m/\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnum_particles\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/elbo.py\u001b[0m in \u001b[0;36m_get_traces\u001b[0;34m(self, model, guide, args, kwargs)\u001b[0m\n\u001b[1;32m    168\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    169\u001b[0m             \u001b[0;32mfor\u001b[0m \u001b[0mi\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnum_particles\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 170\u001b[0;31m                 \u001b[0;32myield\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_get_trace\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmodel\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mguide\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/trace_mean_field_elbo.py\u001b[0m in \u001b[0;36m_get_trace\u001b[0;34m(self, model, guide, args, kwargs)\u001b[0m\n\u001b[1;32m     69\u001b[0m     \"\"\"\n\u001b[1;32m     70\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_get_trace\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmodel\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mguide\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 71\u001b[0;31m         model_trace, guide_trace = super()._get_trace(\n\u001b[0m\u001b[1;32m     72\u001b[0m             model, guide, args, kwargs)\n\u001b[1;32m     73\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mis_validation_enabled\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/trace_elbo.py\u001b[0m in \u001b[0;36m_get_trace\u001b[0;34m(self, model, guide, args, kwargs)\u001b[0m\n\u001b[1;32m     55\u001b[0m         \u001b[0magainst\u001b[0m \u001b[0mit\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     56\u001b[0m         \"\"\"\n\u001b[0;32m---> 57\u001b[0;31m         model_trace, guide_trace = get_importance_trace(\n\u001b[0m\u001b[1;32m     58\u001b[0m             \"flat\", self.max_plate_nesting, model, guide, args, kwargs)\n\u001b[1;32m     59\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mis_validation_enabled\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/enum.py\u001b[0m in \u001b[0;36mget_importance_trace\u001b[0;34m(graph_type, max_plate_nesting, model, guide, args, kwargs, detach)\u001b[0m\n\u001b[1;32m     42\u001b[0m     \u001b[0;32mand\u001b[0m \u001b[0mthe\u001b[0m \u001b[0mmodel\u001b[0m \u001b[0mthat\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0mrun\u001b[0m \u001b[0magainst\u001b[0m \u001b[0mit\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     43\u001b[0m     \"\"\"\n\u001b[0;32m---> 44\u001b[0;31m     \u001b[0mguide_trace\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mpoutine\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtrace\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mguide\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mgraph_type\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mgraph_type\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget_trace\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     45\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mdetach\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     46\u001b[0m         \u001b[0mguide_trace\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdetach_\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/poutine/trace_messenger.py\u001b[0m in \u001b[0;36mget_trace\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    185\u001b[0m         \u001b[0mCalls\u001b[0m \u001b[0mthis\u001b[0m \u001b[0mpoutine\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0mreturns\u001b[0m \u001b[0mits\u001b[0m \u001b[0mtrace\u001b[0m \u001b[0minstead\u001b[0m \u001b[0mof\u001b[0m \u001b[0mthe\u001b[0m \u001b[0mfunction\u001b[0m\u001b[0;31m'\u001b[0m\u001b[0ms\u001b[0m \u001b[0;32mreturn\u001b[0m \u001b[0mvalue\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    186\u001b[0m         \"\"\"\n\u001b[0;32m--> 187\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    188\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmsngr\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget_trace\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/poutine/trace_messenger.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    169\u001b[0m                 \u001b[0mexc\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mexc_type\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34mu\"{}\\n{}\"\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mformat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mexc_value\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mshapes\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    170\u001b[0m                 \u001b[0mexc\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mexc\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mwith_traceback\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtraceback\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 171\u001b[0;31m                 \u001b[0;32mraise\u001b[0m \u001b[0mexc\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0me\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    172\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmsngr\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtrace\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0madd_node\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"_RETURN\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mname\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"_RETURN\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtype\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"return\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mvalue\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mret\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    173\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mret\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/poutine/trace_messenger.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    163\u001b[0m                                       args=args, kwargs=kwargs)\n\u001b[1;32m    164\u001b[0m             \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 165\u001b[0;31m                 \u001b[0mret\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfn\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    166\u001b[0m             \u001b[0;32mexcept\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mValueError\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mRuntimeError\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0me\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    167\u001b[0m                 \u001b[0mexc_type\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mexc_value\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtraceback\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msys\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mexc_info\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/nn/module.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    411\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__call__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    412\u001b[0m         \u001b[0;32mwith\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_pyro_context\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 413\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0msuper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__call__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    414\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    415\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__getattr__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mname\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/torch/nn/modules/module.py\u001b[0m in \u001b[0;36m_call_impl\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m    887\u001b[0m             \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_slow_forward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    888\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 889\u001b[0;31m             \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    890\u001b[0m         for hook in itertools.chain(\n\u001b[1;32m    891\u001b[0m                 \u001b[0m_global_forward_hooks\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mvalues\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/autoguide/guides.py\u001b[0m in \u001b[0;36mforward\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    722\u001b[0m         \u001b[0;31m# if we've never run the model before, do so now so we can inspect the model structure\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    723\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mprototype_trace\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 724\u001b[0;31m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_setup_prototype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    725\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    726\u001b[0m         \u001b[0mlatent\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msample_latent\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/autoguide/guides.py\u001b[0m in \u001b[0;36m_setup_prototype\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    832\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    833\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_setup_prototype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 834\u001b[0;31m         \u001b[0msuper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_setup_prototype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    835\u001b[0m         \u001b[0;31m# Initialize guide params\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    836\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mloc\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mParameter\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_init_loc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/autoguide/guides.py\u001b[0m in \u001b[0;36m_setup_prototype\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    630\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlatent_dim\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0m_product\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mshape\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mshape\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_unconstrained_shapes\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mvalues\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    631\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlatent_dim\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 632\u001b[0;31m             \u001b[0;32mraise\u001b[0m \u001b[0mRuntimeError\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'{} found no latent variables; Use an empty guide instead'\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mformat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__name__\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    633\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    634\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_init_loc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mRuntimeError\u001b[0m: AutoMultivariateNormal found no latent variables; Use an empty guide instead\nTrace Shapes:\n Param Sites:\nSample Sites:"
     ]
    }
   ],
   "source": [
    "### ADVI ###\n",
    "# For ADVI\n",
    "from pyro.infer import SVI, Trace_ELBO, TraceEnum_ELBO, JitTrace_ELBO, TraceMeanField_ELBO\n",
    "from pyro.contrib.autoguide import AutoDiagonalNormal, AutoMultivariateNormal\n",
    "from pyro.optim import Adam, AdamW\n",
    "\n",
    "pyro.clear_param_store()  # clear global parameter cache\n",
    "pyro.set_rng_seed(1)  # set random seed\n",
    "\n",
    "# Automatically define variational distribution (a mean field guide).\n",
    "#guide = my_guide()\n",
    "#guide = AutoMultivariateNormal(gp_model)\n",
    "guide = AutoMultivariateNormal(make_gp_model)\n",
    "#guide = AutoDiagonalNormal(make_gp_model)\n",
    "\n",
    "# Create SVI object for optimization.\n",
    "#svi = SVI(gp_model, guide, Adam({'lr': 1e-2}), TraceMeanField_ELBO(num_particles=5))\n",
    "#svi = SVI(gp_model, guide, AdamW({'lr': 1e-2}), TraceMeanField_ELBO(num_particles=5))\n",
    "svi = SVI(make_gp_model, guide, Adam({'lr': 1e-2}), TraceMeanField_ELBO(num_particles=3))\n",
    "#svi = SVI(make_gp_model, guide, Adam({'lr': 1e-2}), JitTrace_ELBO(num_particles=3))\n",
    "\n",
    "advi_loss = []\n",
    "for step in range(400):\n",
    "    advi_loss.append(svi.step(X_train_tensor.view(-1,1), y_train_tensor.view(-1,)))\n",
    "    \n",
    "# Bijector for advi samples.\n",
    "def biject(samples):\n",
    "    return dict(outputscale=samples[:, 0].exp().numpy(),\n",
    "                lengthscale=samples[:, 1].exp().numpy(),\n",
    "                noise=samples[:, 2].exp().numpy())\n",
    "\n",
    "# Get ADVI samples in constrained space.\n",
    "#advi_posterior_samples = biject(guide.get_posterior().sample((1000, )))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 325,
   "metadata": {},
   "outputs": [
    {
     "ename": "AttributeError",
     "evalue": "'AutoMultivariateNormal' object has no attribute 'loc'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mAttributeError\u001b[0m                            Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-325-e847c9efa939>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0madvi_posterior_samples\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mbiject\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mguide\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget_posterior\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msample\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1000\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/infer/autoguide/guides.py\u001b[0m in \u001b[0;36mget_posterior\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m    848\u001b[0m         \u001b[0mReturns\u001b[0m \u001b[0ma\u001b[0m \u001b[0mMultivariateNormal\u001b[0m \u001b[0mposterior\u001b[0m \u001b[0mdistribution\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    849\u001b[0m         \"\"\"\n\u001b[0;32m--> 850\u001b[0;31m         \u001b[0;32mreturn\u001b[0m \u001b[0mdist\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mMultivariateNormal\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mloc\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mscale_tril\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mscale_tril\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    851\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    852\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_loc_scale\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/pyro/nn/module.py\u001b[0m in \u001b[0;36m__getattr__\u001b[0;34m(self, name)\u001b[0m\n\u001b[1;32m    461\u001b[0m                     \u001b[0;32mreturn\u001b[0m \u001b[0mprior\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    462\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 463\u001b[0;31m         \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msuper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__getattr__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mname\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    464\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    465\u001b[0m         \u001b[0;31m# Regular nn.Parameters trigger pyro.param statements.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/nostromo/lib/python3.9/site-packages/torch/nn/modules/module.py\u001b[0m in \u001b[0;36m__getattr__\u001b[0;34m(self, name)\u001b[0m\n\u001b[1;32m    945\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0mname\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mmodules\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    946\u001b[0m                 \u001b[0;32mreturn\u001b[0m \u001b[0mmodules\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mname\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 947\u001b[0;31m         raise AttributeError(\"'{}' object has no attribute '{}'\".format(\n\u001b[0m\u001b[1;32m    948\u001b[0m             type(self).__name__, name))\n\u001b[1;32m    949\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mAttributeError\u001b[0m: 'AutoMultivariateNormal' object has no attribute 'loc'"
     ]
    }
   ],
   "source": [
    "advi_posterior_samples = biject(guide.get_posterior().sample((1000, )))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 317,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AutoMultivariateNormal.loc:\n",
      "Parameter containing:\n",
      "tensor([-1.3408,  1.4383, -0.8582], requires_grad=True)\n",
      "\n",
      "AutoMultivariateNormal.scale_tril:\n",
      "tensor([[ 0.7230,  0.0000,  0.0000],\n",
      "        [-0.0737,  1.0234,  0.0000],\n",
      "        [-0.1168,  0.0544,  0.9962]], grad_fn=<AddBackward0>)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "for key, value in pyro.get_param_store().items():    \n",
    "    print(f\"{key}:\\n{value}\\n\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 318,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1000, 3])"
      ]
     },
     "execution_count": 318,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "guide.get_posterior().sample((1000, )).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 319,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x138bb0070>]"
      ]
     },
     "execution_count": 319,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(np.arange(len(advi_loss)), advi_loss)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 320,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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a2se6O/vT39/fz796U8nSdasWZN9+/a5puaZf/mXf8n1118/PQ+33357XnzxRdfUPPZe11BfX1/Gxsam36czukPJlWKPop7f2u129uzZkxUrVuRLX/rS9PbVq1fn4MGDSZKDBw/mtttum6shkuRrX/ta9uzZk927d2fLli357Gc/mwceeCArV67M4cOHkyQHDhxwbc0DS5cuTX9/f1599dUkb8XXTTfd5JqaZwYGBvLSSy/lv/7rv9Jut6fnyTU1f73XNbR69eocOnQo7XY7J06cSG9vr1snukDZh3ccPXo0f/d3fzf9KOqvfOUrcz0k/tsLL7yQhx9+OB//+Men/ynqq1/9aj796U9neHg4Y2Njvj5qnjl+/Hh+8IMfZOvWrfnVr36VHTt25OzZs/nEJz6RzZs358Mf/vBcD7G8f/u3f8uePXty8eLFXH/99dm0aVPa7bZrap753ve+l+eeey49PT353d/93dx///1ptVquqXlgx44d+dnPfpaJiYksWbIkd999d2677bZ3vYba7Xa++93v5ic/+UkWLFiQTZs25ZOf/ORcHwIzKBvFAADwGyVvnwAAgN8migEAKE8UAwBQnigGAKA8UQwAQHmiGACA8kQxAADliWIAAMr7vy41HlqUw2NXAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for k in advi_posterior_samples.keys():\n",
    "    #plt.hist(advi_posterior_samples[k], bins=30, label=k, range=(0,1.3))\n",
    "    plt.hist(advi_posterior_samples[k], bins=30, label=k)\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## ExactGP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 365,
   "metadata": {},
   "outputs": [],
   "source": [
    "import gpytorch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 438,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:14<00:00, 67.27it/s]\n"
     ]
    }
   ],
   "source": [
    "### ADVI ###\n",
    "# For ADVI\n",
    "from tqdm import tqdm\n",
    "from pyro.infer import SVI, Trace_ELBO, TraceEnum_ELBO, JitTrace_ELBO\n",
    "from pyro.contrib.autoguide import AutoDiagonalNormal, AutoGuide\n",
    "from pyro.optim import Adam\n",
    "\n",
    "pyro.clear_param_store()  # clear global parameter cache\n",
    "pyro.set_rng_seed(1)  # set random seed\n",
    "\n",
    "\n",
    "from gpytorch.priors import LogNormalPrior, NormalPrior, UniformPrior, GammaPrior\n",
    "class ExactGPModel(gpytorch.models.ExactGP):\n",
    "    def __init__(self, train_x, train_y, likelihood):\n",
    "        super(ExactGPModel, self).__init__(train_x, train_y, likelihood)\n",
    "        self.likelihood = likelihood\n",
    "        self.mean_module = gpytorch.means.ConstantMean()\n",
    "        self.covar_module = gpytorch.kernels.ScaleKernel(gpytorch.kernels.RBFKernel())\n",
    "        \n",
    "        length_scale_prior = GammaPrior(3, 6)\n",
    "        noise_prior = LogNormalPrior(loc=0, scale=2)\n",
    "\n",
    "        #self.covar_module.base_kernel.register_prior(\"lengthscale_prior\", length_scale_prior, \"lengthscale\")\n",
    "        #self.likelihood.register_prior(\"noise_prior\", noise_prior, \"noise\")\n",
    "        self.covar_module.base_kernel.lengthscale = pyro.sample(\"lengthscale\", length_scale_prior)\n",
    "        self.likelihood.noise_covar.noise = pyro.sample(\"noise\", noise_prior)\n",
    "\n",
    "        \n",
    "    def forward(self, x):\n",
    "        mean_x = self.mean_module(x)\n",
    "        covar_x = self.covar_module(x)\n",
    "        return gpytorch.distributions.MultivariateNormal(mean_x, covar_x)\n",
    "\n",
    "\n",
    "likelihood = gpytorch.likelihoods.GaussianLikelihood(noise_constraint=gpytorch.constraints.Positive())\n",
    "\n",
    "# Automatically define variational distribution (a mean field guide).\n",
    "guide = AutoDiagonalNormal(ExactGPModel)\n",
    "\n",
    "\n",
    "# Create SVI object for optimization.\n",
    "svi = SVI(ExactGPModel, guide, Adam({'lr': 1e-2}), Trace_ELBO(num_particles=5))\n",
    "\n",
    "# Do 1000 gradient steps.\n",
    "advi_loss = []\n",
    "for step in tqdm(range(1000)):\n",
    "    advi_loss.append(svi.step(X_train_tensor.view(-1,1), y_train_tensor.view(-1,), likelihood))\n",
    "    \n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 439,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Bijector for advi samples.\n",
    "def biject(samples):\n",
    "    return dict(alpha=samples[:, 0].exp().numpy(),\n",
    "                rho=samples[:, 1].exp().numpy())\n",
    "                #sigma=samples[:, 2].exp().numpy())\n",
    "    \n",
    "# Get ADVI samples in constrained space.\n",
    "advi_posterior_samples = biject(guide.get_posterior().sample((1000, )))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 440,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AutoDiagonalNormal.loc:\n",
      "Parameter containing:\n",
      "tensor([-0.8461, -0.1496], requires_grad=True)\n",
      "\n",
      "AutoDiagonalNormal.scale:\n",
      "tensor([0.5936, 1.9893], grad_fn=<AddBackward0>)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "for key, value in pyro.get_param_store().items():    \n",
    "    print(f\"{key}:\\n{value}\\n\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 441,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x140121190>]"
      ]
     },
     "execution_count": 441,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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v8+T38DAAB555BFcccUV+OlPf4qRkZEJy9RRddX69zcRmdzOzk6sW7fOub1u3Tp0dnZWcYtoLHK5HC699FLst99+2GuvvQAA06ZNw/r16zF9+nSsX7/eOePv7OxET0+P81y+95PDiy++iEcffRRPPPEEMpkMhoeHcf3112NoaAj5fB6pVAq9vb3Oe6m+411dXcjn8xgaGsKUKVOq/FtQMV1dXejq6sLWW28NwLo0ffPNN/P7nDBPP/00Zs6c6byPe+21F1588UV+nxOq1O9vZ2cnnnvuOef+3t5eLFy4cEK2NRGZ3C233BLvvPMO1qxZg1wuhwcffBB77LFHtTeLyiClxFVXXYW5c+fi0EMPde7fY489cO+99wIA7r33Xuy5557O/ffddx+klHjppZfQ2trKS5uTwFFHHYWrrroKV1xxBU4//XTssMMOOPXUU7H99tvjoYceAmCNxlXf49133x333HMPAOChhx7C9ttvX9PZA7J0dHSgq6sLq1atAmAFQ/PmzeP3OWG6u7vx8ssvY3R0FFJK533m9zmZSv3+7rLLLnjqqacwMDCAgYEBPPXUU9hll10mZFsTMxnE448/jp///OcwTRMHHnggDj/88GpvEpXhhRdewLnnnov58+c7O73Pfvaz2HrrrbF06VL09PQEWpZce+21eOqpp9DY2IiTTjoJW265ZZV/CyrFs88+i7/85S84++yz8e6772LZsmUYGBjAFltsgVNOOQUNDQ3IZDK4/PLLsWLFCrS3t+P000/HrFmzqr3pFMPrr7+Oq666CrlcDjNnzsRJJ50EKSW/zwnz+9//Hg8++CBSqRQ233xznHDCCejt7eX3eZJbtmwZnnvuOfT392PatGn49Kc/jT333LPk7+9dd92Fm266CYDVQuzAAw+ckO1PTJBLRERERKQkolyBiIiIiEjHIJeIiIiIEodBLhERERElDoNcIiIiIkocBrlERERElDgMcomIiIgocRjkEhEREVHiMMglIiIiosT5/+imCCPbVcnTAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(np.arange(len(advi_loss)), advi_loss)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 442,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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cu655+Ztb3tbC6acf+pZ9+9+97v5+Mc/noULFyZJOjo6WjHqvFLPulcqlezbty9Jsm/fvixZsqQVo84rH/jABw7+OT6Uhx56KL/7u7+bSqWS973vfdm7d2/GxsZmccL5Z6o1/7Vf+7WDz69YseJNey1wZOZN/Naz3fIbv6etrS0LFizInj17ZnXO+eZIt7keGhrK6aefPguTzV/1rPkzzzyTkZER//TbQPWs+86dO/PCCy/kb/7mb/LXf/3Xeeyxx2Z5yvmnnnX/4z/+43zve9/Lpz71qVx//fW58MILZ3vM4oyOjqarq+vg46ne+2msoaGh/OZv/marxzhqzZv4Ze6777778swzz2TdunWtHmVem5yczFe+8pX86Z/+aatHKc7k5GReeOGFXHvttfnc5z6XO+64I3v37m31WPPe/fffn7Vr1+b222/P5z//+dx6662ZnJxs9VjQFE888UT+8z//MxdccEGrRzlqzZv4rWe75Td+z8TERPbt25fjjz9+Vuecb+rd5vrxxx/Pt771rVx55ZX+GX6Gplrz/fv357nnnsvf/d3f5dOf/nR+9KMf5YYbbsiPf/zjVow7b9T7HtPT05P29vaceOKJ+ZVf+ZW88MILsz3qvFLPug8NDeUjH/lIkuR973tfXn/9df+q12SdnZ0ZGRk5+Phw7/001k9+8pPccccdueKKK/TLDMyb+K1nu+UPfehD2bp1a5Jf3AW/cuXKVCqVFkw7f9Sz7s8++2zuvPPOXHnlla6BbICp1nzBggW56667smXLlmzZsiUrVqzIlVde6dMeZqieP+sf/vCHs2PHjiTJz372s7zwwgtZtmxZK8adN+pZ966urjzxxBNJkueffz6vv/56Fi1a1Ipxi9HT05P77rsvtVotP/zhD7NgwQLXWjfZyMhIbrrppnzmM59Jd3d3q8c5qs2rTS4eeeSR/NM//dPB7ZbPO++8fOMb38hpp52Wnp6evPbaa/nSl76UZ599NgsXLsxll13mF1MDTLXuX/jCF/K///u/Wbx4cZJf/KK66qqrWjv0UW6qNX+jv/3bv80nPvEJ8dsAU617rVbLV77ylTz22GM55phjct555+Wss85q9dhHvanW/fnnn88dd9yR/fv3J0k2btyYD37wgy2e+ui2efPm/OAHP8iePXvS0dGRDRs25MCBA0mSj33sY6nVarnrrrvy3//933n729+eSy65xHvMDE215rfffnv+67/+6+C11m1tbenr62vlyEeteRW/AADw/zNvLnsAAICpiF8AAIohfgEAKIb4BQCgGOIXAIBiiF8AAIohfgEAKIb4BQCgGP8XZFJJCkZrbfMAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for k in advi_posterior_samples.keys():\n",
    "    plt.hist(advi_posterior_samples[k], bins=30, label=k, range=(0,1.3))\n",
    "    #plt.hist(advi_posterior_samples[k], bins=30, label=k)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 443,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'alpha': array([0.20579001, 0.7284505 , 0.7146652 , 0.31272104, 0.33473256,\n",
       "        0.2873278 , 0.36623088, 0.17215331, 0.16113341, 0.6970694 ,\n",
       "        0.65997565, 0.40600938, 0.40064257, 0.4796764 , 1.1719289 ,\n",
       "        0.56113124, 0.19267836, 0.31420308, 0.70116675, 0.17424007,\n",
       "        0.343257  , 0.89174265, 0.537149  , 0.46275556, 1.4048538 ,\n",
       "        0.63204664, 0.1465502 , 0.17042492, 0.38532716, 0.67291933,\n",
       "        0.5625397 , 0.33672804, 0.24042334, 0.18715057, 1.2446264 ,\n",
       "        0.38556737, 0.3796162 , 0.2541481 , 0.45721132, 0.57756245,\n",
       "        0.53075325, 1.2287427 , 0.51997906, 0.89590746, 0.1701414 ,\n",
       "        2.6146553 , 0.99437004, 1.0643739 , 0.4250566 , 0.12106926,\n",
       "        0.4913514 , 0.489503  , 0.57663286, 0.85828614, 0.6219692 ,\n",
       "        1.182524  , 0.23475704, 0.47934613, 0.16526781, 0.17808554,\n",
       "        0.8498727 , 0.47289136, 0.5268675 , 0.8925725 , 0.5713984 ,\n",
       "        0.3042517 , 0.32734215, 0.69448334, 0.21781896, 0.41277662,\n",
       "        0.62824845, 0.47286394, 0.4034502 , 0.6645993 , 0.5012301 ,\n",
       "        0.38239872, 0.31379488, 0.8316183 , 0.1769996 , 0.37839222,\n",
       "        0.44751248, 0.34006897, 0.9843315 , 0.26770824, 0.7245512 ,\n",
       "        0.4663164 , 0.44664958, 0.33858228, 0.45326632, 0.25559393,\n",
       "        0.72787225, 0.16302887, 0.73223686, 0.5047092 , 0.76556706,\n",
       "        0.998549  , 0.40656447, 0.4029255 , 0.49709353, 0.251198  ,\n",
       "        0.17746638, 0.12874743, 0.9954065 , 0.6418456 , 1.2134815 ,\n",
       "        0.1764439 , 0.88621986, 0.41732317, 0.18792064, 0.10011216,\n",
       "        0.79625225, 0.20438787, 0.4962653 , 0.5225572 , 0.9013827 ,\n",
       "        0.38204247, 0.22582045, 0.3116479 , 0.56342244, 1.0312315 ,\n",
       "        0.21851821, 0.16667886, 0.13641803, 0.45224115, 0.49087542,\n",
       "        0.17348975, 0.40553525, 0.3714366 , 0.34376687, 0.1883885 ,\n",
       "        0.33621517, 1.8256764 , 0.53118837, 0.6177314 , 0.29112214,\n",
       "        0.19595003, 0.41899693, 0.6661843 , 0.7984669 , 0.7078525 ,\n",
       "        0.38701844, 0.33409348, 1.4874456 , 0.62982976, 0.3122739 ,\n",
       "        0.38742244, 1.054914  , 2.362767  , 0.1590498 , 0.3342812 ,\n",
       "        0.810678  , 0.4617416 , 0.599088  , 0.40121916, 0.5782745 ,\n",
       "        0.38743111, 0.34076226, 0.32392347, 0.1934535 , 0.42206472,\n",
       "        0.26887143, 0.20760022, 0.36011058, 0.68102676, 0.7151789 ,\n",
       "        0.78067   , 1.2484616 , 0.9165951 , 0.37665105, 0.09881911,\n",
       "        0.59872156, 2.077441  , 0.5205569 , 0.49473178, 0.8014829 ,\n",
       "        0.8985105 , 0.70447415, 0.3606919 , 0.8833984 , 1.078704  ,\n",
       "        0.3542269 , 0.29071864, 0.44984174, 0.36640993, 0.30363297,\n",
       "        0.18580663, 0.79235303, 0.27021918, 0.57533526, 0.29374373,\n",
       "        0.38525325, 0.2356714 , 0.10096531, 0.37581623, 0.49107945,\n",
       "        0.45811325, 0.42331535, 0.57630193, 0.84609497, 0.40623873,\n",
       "        0.62506205, 0.2760922 , 0.82396674, 0.38483423, 0.5125841 ,\n",
       "        0.5214424 , 0.5467962 , 0.15848061, 0.7253957 , 0.40564156,\n",
       "        0.2706508 , 0.24247527, 0.41878012, 0.24142617, 0.42407814,\n",
       "        0.33586586, 1.0507104 , 0.511989  , 0.46145618, 0.22470911,\n",
       "        0.46608317, 0.5284271 , 0.34557346, 0.40629464, 0.26319697,\n",
       "        0.33192527, 0.4948707 , 0.4192608 , 0.33960268, 3.3016143 ,\n",
       "        0.23191266, 0.91114026, 0.11325806, 0.24254563, 0.3573221 ,\n",
       "        0.38861755, 0.72624856, 0.597568  , 0.39411896, 0.50882226,\n",
       "        0.38362604, 0.37407064, 0.36885872, 0.5160016 , 0.1900117 ,\n",
       "        0.27104348, 0.6028672 , 0.53536254, 0.91159517, 0.35751444,\n",
       "        1.4534132 , 0.3534524 , 0.8090082 , 0.8669883 , 1.0208772 ,\n",
       "        0.31931686, 0.42597806, 0.30980843, 0.5042038 , 0.57294345,\n",
       "        0.47377944, 0.6320923 , 0.28222755, 0.30784407, 0.6505555 ,\n",
       "        0.15905172, 1.7401756 , 0.20016925, 0.18009087, 0.19362724,\n",
       "        0.14322747, 0.19864708, 0.5583492 , 0.3399374 , 0.24339852,\n",
       "        0.15056863, 0.28131536, 0.16087803, 0.60025847, 0.8182169 ,\n",
       "        0.7202952 , 0.7808255 , 0.27583197, 0.18679743, 0.2571395 ,\n",
       "        1.2050824 , 0.37935767, 0.8865416 , 0.80078983, 0.17492975,\n",
       "        0.81607646, 0.5597336 , 0.23295371, 0.21764804, 0.26784104,\n",
       "        0.27734455, 0.32355982, 0.67278963, 0.5929704 , 0.21079066,\n",
       "        0.6032983 , 0.29524684, 0.55596954, 0.43688422, 0.53694886,\n",
       "        0.20751435, 0.26898143, 0.53432894, 0.19038495, 0.7604687 ,\n",
       "        0.78869724, 0.412796  , 0.25100797, 0.33337516, 0.55279154,\n",
       "        0.67795265, 0.3522057 , 0.3830105 , 0.69681644, 0.47404444,\n",
       "        0.49610767, 0.2661296 , 0.38065   , 0.18175888, 0.81064385,\n",
       "        0.68283844, 0.35490727, 2.68023   , 0.5212522 , 0.6928707 ,\n",
       "        0.59822565, 0.36806542, 0.5219212 , 0.27217498, 0.56487024,\n",
       "        0.36171246, 0.6393056 , 0.23730776, 0.40771258, 0.38089144,\n",
       "        0.3008591 , 0.2081408 , 0.7801664 , 0.11633891, 0.7116883 ,\n",
       "        0.29896343, 0.89161354, 0.5882261 , 0.43119708, 0.37390542,\n",
       "        0.7001221 , 0.2342153 , 0.26214707, 0.21192902, 0.5455946 ,\n",
       "        0.51096964, 0.5277818 , 0.5897639 , 0.3953524 , 0.16247563,\n",
       "        0.31196338, 0.8082193 , 0.43482512, 0.28990322, 0.5416989 ,\n",
       "        0.7093907 , 0.42362598, 0.2665267 , 0.2555833 , 0.36257833,\n",
       "        0.7196187 , 0.46174482, 0.26696238, 0.69369715, 0.38235652,\n",
       "        1.0665236 , 0.43333718, 0.69468856, 0.71536404, 0.6759404 ,\n",
       "        0.22347707, 0.3077787 , 0.1951714 , 0.5867062 , 1.1159726 ,\n",
       "        0.2955644 , 0.33367658, 0.57890666, 0.41931498, 0.8682109 ,\n",
       "        0.38305095, 0.15046215, 0.51266074, 0.83602136, 0.39850235,\n",
       "        0.5515633 , 0.23589334, 0.23525323, 0.25272265, 0.25091335,\n",
       "        0.37825447, 0.19960713, 0.559796  , 0.5034891 , 0.579118  ,\n",
       "        1.0532076 , 0.39663044, 0.82609904, 0.795748  , 0.42907298,\n",
       "        0.2671838 , 0.28937057, 2.533658  , 0.31814796, 1.00663   ,\n",
       "        0.52469623, 0.7970091 , 0.56038934, 0.25907066, 0.21926554,\n",
       "        0.14319165, 0.3796953 , 0.21259254, 0.9731734 , 0.43799844,\n",
       "        0.4327762 , 0.3886488 , 0.28502458, 0.36086816, 0.6409848 ,\n",
       "        0.5821221 , 0.34334946, 0.2729185 , 0.32485405, 0.36385527,\n",
       "        0.15783964, 0.52962357, 0.29626992, 0.31395835, 1.0401702 ,\n",
       "        0.49694604, 0.55168056, 0.85515   , 0.40746236, 0.49058983,\n",
       "        0.20628628, 0.42085174, 0.614078  , 0.442286  , 0.72308743,\n",
       "        1.083569  , 1.3211467 , 0.5358263 , 0.19826289, 0.94638944,\n",
       "        0.27437702, 0.6905837 , 0.31695154, 0.3815279 , 0.5585473 ,\n",
       "        0.2604477 , 0.74899226, 0.66189003, 0.35157788, 0.40059537,\n",
       "        0.4203895 , 0.841766  , 1.538303  , 2.58428   , 0.31443846,\n",
       "        0.55221695, 0.19230221, 0.79507464, 0.29111424, 0.63968146,\n",
       "        0.15655537, 0.4013868 , 0.5141272 , 0.38594943, 0.1460334 ,\n",
       "        0.90170527, 1.5214024 , 0.28967732, 0.27285728, 0.55931044,\n",
       "        0.51185757, 0.88284785, 0.524759  , 0.8275031 , 1.5551951 ,\n",
       "        0.3358899 , 0.24370773, 0.5473293 , 0.30826738, 0.2899526 ,\n",
       "        0.5216468 , 0.47753623, 0.29543263, 0.41415295, 0.52204394,\n",
       "        0.3107822 , 0.58651936, 0.559867  , 0.1510773 , 0.6340766 ,\n",
       "        0.38524923, 0.45905158, 0.5992747 , 0.2600906 , 0.25703263,\n",
       "        0.3291926 , 0.2784321 , 0.2585281 , 0.21606554, 0.81147194,\n",
       "        0.29781234, 0.23588423, 1.2383049 , 1.3443835 , 1.0808293 ,\n",
       "        0.748873  , 0.27083203, 0.895592  , 0.41232356, 0.46008694,\n",
       "        0.23028153, 0.342927  , 0.9542405 , 1.1630689 , 1.0847201 ,\n",
       "        0.4812495 , 0.9871581 , 0.29798102, 0.46884915, 1.0232536 ,\n",
       "        0.78675926, 1.4943111 , 0.26879352, 0.23664491, 1.2802483 ,\n",
       "        0.612794  , 0.8464035 , 0.32543206, 0.7146146 , 0.595361  ,\n",
       "        0.38574743, 0.2962401 , 1.0590904 , 0.72264683, 0.9920725 ,\n",
       "        0.2316423 , 0.94255495, 1.3286918 , 0.33720857, 0.18151659,\n",
       "        0.30317062, 0.12932177, 0.3595301 , 0.4817912 , 0.33298764,\n",
       "        0.3838368 , 2.126577  , 0.3762551 , 0.2551314 , 0.33617544,\n",
       "        0.7576943 , 0.15160339, 0.19030845, 0.7781881 , 0.39065954,\n",
       "        0.60386014, 0.15495667, 0.6911019 , 0.5288842 , 0.59092957,\n",
       "        0.53108317, 0.3325396 , 0.30645224, 0.40119985, 0.46921557,\n",
       "        1.0047555 , 0.51565224, 0.2667447 , 0.4736604 , 0.44321442,\n",
       "        0.67032546, 0.6385623 , 0.26245254, 0.33768585, 0.20288168,\n",
       "        0.69734925, 0.9169776 , 0.34952495, 0.34363943, 0.14502127,\n",
       "        0.11026244, 0.4977127 , 0.287623  , 0.88578737, 0.34486997,\n",
       "        0.8304093 , 0.25103927, 0.31170574, 0.8922541 , 0.25257316,\n",
       "        0.52981037, 0.7420305 , 0.10438261, 2.7036562 , 0.3792266 ,\n",
       "        0.47541174, 0.20743361, 0.6430294 , 0.46012405, 0.2923033 ,\n",
       "        0.47455594, 1.0781827 , 0.28555402, 0.41802567, 0.9962    ,\n",
       "        0.3008379 , 0.41410848, 0.46117115, 1.3893522 , 0.68278015,\n",
       "        0.52127546, 0.2045079 , 0.19731301, 0.28512806, 0.31624448,\n",
       "        0.39859405, 0.8427119 , 0.67390954, 0.5241297 , 0.10922334,\n",
       "        0.3261351 , 0.21948479, 0.6961959 , 0.21639058, 0.5498156 ,\n",
       "        0.6476847 , 0.5071521 , 0.5018937 , 0.6109495 , 0.37743658,\n",
       "        0.1618413 , 0.8900041 , 0.29487643, 0.36150354, 0.39440668,\n",
       "        0.35704175, 0.2605313 , 0.3376339 , 0.23577212, 1.1051577 ,\n",
       "        0.50142   , 0.6958768 , 1.0338379 , 0.4673442 , 0.22813404,\n",
       "        0.19016618, 1.0423404 , 0.3461881 , 0.83969647, 0.9915977 ,\n",
       "        0.49346614, 0.22773282, 0.48940146, 0.5324664 , 0.6708609 ,\n",
       "        0.40705127, 1.2908796 , 0.44633615, 0.12384552, 0.5009956 ,\n",
       "        0.56997246, 0.29678196, 0.886757  , 1.3516953 , 1.1392146 ,\n",
       "        0.5773455 , 0.48504305, 0.39836407, 0.40722772, 0.5054784 ,\n",
       "        0.43094766, 0.58689755, 0.29181844, 0.26196134, 1.3875558 ,\n",
       "        1.1148055 , 0.32772902, 0.46241444, 0.33299458, 0.7766056 ,\n",
       "        0.3346639 , 0.11422218, 0.48381633, 0.7379631 , 0.30843586,\n",
       "        0.4669907 , 0.9323303 , 0.26820034, 0.9977504 , 0.45863456,\n",
       "        0.68731403, 0.6000888 , 0.4341853 , 0.28118095, 0.21224743,\n",
       "        1.3294137 , 0.6319852 , 1.5247759 , 0.1708941 , 0.50214905,\n",
       "        0.6079797 , 0.7460454 , 0.21188547, 0.5760238 , 0.19631368,\n",
       "        0.3219899 , 0.3235203 , 0.6935228 , 0.4148546 , 0.21446416,\n",
       "        0.19627188, 0.2264815 , 0.19041452, 0.43920204, 0.3875337 ,\n",
       "        0.3072016 , 0.09341909, 0.23279612, 0.8013303 , 0.28529704,\n",
       "        0.1697783 , 0.37197196, 0.27039808, 0.53872776, 0.6487605 ,\n",
       "        0.47926474, 0.4494765 , 0.9031788 , 0.94398856, 0.2639127 ,\n",
       "        0.5980706 , 0.6647745 , 0.9758841 , 1.5374653 , 0.27668786,\n",
       "        0.38743764, 0.4655392 , 0.4489992 , 0.39948305, 0.2032522 ,\n",
       "        2.1755457 , 0.5325424 , 0.49604464, 1.5283126 , 0.21774596,\n",
       "        0.5145673 , 0.48196054, 0.71835995, 0.13090509, 0.5506086 ,\n",
       "        0.54989874, 0.38482428, 1.0228221 , 0.12432054, 0.6929336 ,\n",
       "        0.5305419 , 0.8772958 , 0.36146936, 0.8825673 , 0.3619639 ,\n",
       "        0.28992712, 0.30558014, 0.2947408 , 0.48209256, 0.13646832,\n",
       "        0.22883777, 1.2574518 , 0.5080613 , 0.87131953, 1.0601507 ,\n",
       "        1.3799578 , 0.6609641 , 0.7116046 , 0.8170669 , 0.15274264,\n",
       "        0.7631901 , 0.42827684, 0.4909634 , 0.8252262 , 0.29998517,\n",
       "        0.1299949 , 0.20417997, 0.1451248 , 0.19738333, 0.5195191 ,\n",
       "        0.7048875 , 0.15984847, 0.97469074, 0.41592956, 0.1803313 ,\n",
       "        0.34410417, 0.7822524 , 0.7969576 , 0.4404028 , 0.8947557 ,\n",
       "        0.7100282 , 0.7443298 , 0.3595578 , 0.81554204, 0.4937448 ,\n",
       "        0.20324166, 0.30356836, 0.90065235, 0.28996164, 0.25644165,\n",
       "        0.47768557, 0.6792288 , 0.74704015, 1.223123  , 0.19389513,\n",
       "        0.5316589 , 0.61826664, 0.3247484 , 0.3319876 , 0.25989372,\n",
       "        0.22417   , 1.9693836 , 0.6915256 , 0.26901448, 0.5439525 ,\n",
       "        1.2981088 , 1.1629313 , 0.81834877, 0.5102964 , 0.79615957,\n",
       "        0.53057426, 0.5194949 , 0.42644286, 0.35061502, 0.18343276,\n",
       "        0.266581  , 0.4955575 , 0.35519397, 0.14924733, 0.3261914 ,\n",
       "        0.32855058, 0.24966179, 0.44299176, 0.37162814, 0.13753672,\n",
       "        0.59455043, 0.33174136, 0.28537005, 0.5711481 , 0.20628852,\n",
       "        0.22775361, 0.64332527, 0.85083836, 0.73692906, 0.15638156,\n",
       "        0.69602334, 0.35875538, 0.48241043, 0.5332693 , 0.4067527 ,\n",
       "        0.53189397, 0.5891895 , 0.47552967, 0.28797948, 0.5394627 ,\n",
       "        0.67708063, 0.1426462 , 0.2455198 , 0.5298845 , 0.16929394,\n",
       "        0.35310212, 0.3816052 , 0.25715315, 0.39827645, 0.53165793,\n",
       "        0.809551  , 0.29494572, 0.6153401 , 0.28947562, 0.42946163,\n",
       "        0.37539616, 0.42163232, 0.57869685, 0.91520816, 0.39288354,\n",
       "        0.60080725, 0.5016922 , 0.23381598, 0.42896456, 0.16615912,\n",
       "        0.36560875, 0.6104852 , 0.65638465, 0.44995636, 0.37054634,\n",
       "        0.7585318 , 0.30806386, 0.78202367, 0.6691244 , 1.1327872 ,\n",
       "        0.23935844, 0.22243832, 0.39350325, 0.36368036, 0.38777974,\n",
       "        0.6335972 , 0.46280742, 0.23053479, 0.41207218, 0.2545567 ,\n",
       "        0.27121288, 0.11211573, 0.7836318 , 0.9109611 , 0.64914095,\n",
       "        0.7252623 , 0.8005513 , 0.49108022, 0.54466325, 0.19400491,\n",
       "        0.3824883 , 0.6206578 , 0.23473537, 0.61187154, 0.77303505,\n",
       "        0.34220773, 0.41105255, 0.6988627 , 0.14973155, 0.31223518,\n",
       "        0.17172673, 0.43855992, 0.9023621 , 0.30540103, 0.80923474,\n",
       "        0.628103  , 0.23306863, 0.79372394, 0.5947073 , 1.0408065 ,\n",
       "        0.3261432 , 1.138503  , 0.22496541, 0.9456978 , 0.22859621,\n",
       "        0.49492237, 0.6663128 , 0.4208304 , 0.47938663, 0.41827258,\n",
       "        0.37961   , 0.96588606, 0.4665552 , 0.4163819 , 0.12758836,\n",
       "        0.3331414 , 0.6293925 , 0.6717418 , 0.52960306, 0.62231266,\n",
       "        0.73900497, 0.4845052 , 0.24414678, 0.19752549, 0.5989101 ,\n",
       "        0.4177495 , 0.21124275, 0.44394127, 0.3718391 , 1.8888441 ,\n",
       "        0.15812825, 0.74724865, 0.23988967, 0.79133993, 0.27216503,\n",
       "        0.09459446, 0.27203602, 0.6314876 , 0.40965894, 0.4910449 ,\n",
       "        0.3144318 , 2.0374656 , 0.39030153, 0.55805147, 0.13419744,\n",
       "        0.20124434, 0.41881594, 0.36885822, 0.25170088, 1.999811  ],\n",
       "       dtype=float32),\n",
       " 'rho': array([2.83452064e-01, 3.08660984e+01, 9.23900723e-01, 1.26646888e+00,\n",
       "        1.22884028e-01, 8.69243681e-01, 1.13273633e+00, 5.87252304e-02,\n",
       "        2.87964165e-01, 1.15030074e+00, 3.08338666e+00, 2.88336813e-01,\n",
       "        1.04173303e+00, 3.51074874e-01, 2.64797449e+00, 1.04740374e-01,\n",
       "        4.41094220e-01, 1.41812786e-01, 6.54538870e-01, 8.51310194e-01,\n",
       "        1.04940438e+00, 6.90483749e-02, 2.49819660e+01, 8.08248425e+00,\n",
       "        7.26893425e+00, 4.39612418e-02, 3.19388688e-01, 4.54485798e+00,\n",
       "        8.70326757e-01, 1.26727343e+01, 2.84227788e-01, 1.29523492e+00,\n",
       "        4.37032431e-02, 7.91468799e-01, 1.12042880e+00, 5.38315582e+00,\n",
       "        2.12402537e-01, 2.31621757e-01, 1.02153945e+00, 1.81645763e+00,\n",
       "        8.89535713e+00, 3.06205124e-01, 9.09992978e-02, 1.32756025e-01,\n",
       "        2.57565588e-01, 4.90962944e+01, 4.12899494e-01, 3.72618735e-02,\n",
       "        7.48342812e-01, 3.19604969e+00, 2.03233509e+01, 7.85489500e-01,\n",
       "        4.59739089e-01, 2.58772910e-01, 9.51570570e-02, 1.40127015e+00,\n",
       "        8.75714123e-01, 1.16104298e+01, 8.68939781e+00, 2.01095780e-03,\n",
       "        7.95636702e+00, 5.10592163e-01, 3.44630212e-01, 1.42654431e+00,\n",
       "        8.51923287e-01, 8.70578364e-02, 1.44531536e+00, 2.20934219e+01,\n",
       "        2.73220301e-01, 7.31551573e-02, 1.15612113e+00, 2.37013116e-01,\n",
       "        1.31709123e+00, 6.87383032e+00, 1.87105274e+00, 4.60772932e-01,\n",
       "        6.04144573e-01, 4.22089577e+00, 2.99341679e+00, 4.25263643e+00,\n",
       "        4.80392456e+00, 3.04951191e+00, 5.01253271e+00, 8.91065001e-01,\n",
       "        1.71407059e-01, 1.14992231e-01, 1.15013819e+01, 1.52697825e+00,\n",
       "        1.11271597e-01, 2.34941617e-01, 4.78356987e-01, 3.81117654e+00,\n",
       "        2.97188908e-01, 2.63764411e-01, 9.05495739e+00, 8.27335287e-03,\n",
       "        2.41825986e+00, 8.63902867e-01, 6.22267914e+00, 4.78734064e+00,\n",
       "        3.76190805e+00, 5.34842873e+00, 2.09339666e+00, 1.70199618e-01,\n",
       "        1.84715295e+00, 3.56216252e-01, 4.65769619e-01, 1.53094320e+01,\n",
       "        4.66529310e-01, 4.90402794e+00, 9.35550213e-01, 2.61825352e+01,\n",
       "        2.40079069e+00, 1.69661081e+00, 5.96670154e-03, 8.64258194e+00,\n",
       "        1.88180656e+01, 1.16357183e+00, 7.74565840e+00, 2.67966658e-01,\n",
       "        6.97315445e+01, 3.98986483e+00, 4.19404449e+01, 1.54082388e-01,\n",
       "        1.43821859e+01, 8.29785585e-01, 2.57859230e-01, 1.25054255e-01,\n",
       "        6.79835737e-01, 6.77859592e+00, 3.67320395e+00, 1.19297333e-01,\n",
       "        5.91983199e-01, 2.98266321e-01, 6.64974988e-01, 1.52157748e+00,\n",
       "        1.15590811e+01, 2.89145613e+00, 4.28054892e-02, 5.30035421e-02,\n",
       "        2.70499439e+01, 1.79128420e+00, 7.69341707e-01, 7.30147886e+00,\n",
       "        1.94160100e-02, 1.66571915e-01, 1.89163789e-01, 1.27722847e+00,\n",
       "        2.66969800e-01, 3.43080983e-02, 4.52374220e-01, 6.05905914e+00,\n",
       "        7.43297501e+01, 1.40676999e+00, 3.39828163e-01, 6.30934954e-01,\n",
       "        9.22946095e-01, 3.54650378e-01, 3.35911810e-01, 1.96293548e-01,\n",
       "        1.05351746e-01, 1.13950312e-01, 4.07457724e-02, 9.63251650e-01,\n",
       "        2.94580889e+00, 7.72352600e+00, 7.45117888e-02, 6.25379741e-01,\n",
       "        1.13344885e-01, 2.10222282e+01, 4.03460205e-01, 1.78807229e-01,\n",
       "        1.54883787e-01, 1.61411479e-01, 4.98134732e-01, 3.45939666e-01,\n",
       "        1.05595660e+00, 2.18636398e+01, 7.18105376e-01, 3.72025013e+00,\n",
       "        3.86707187e-01, 8.92412543e-01, 5.44170332e+00, 2.12141538e+00,\n",
       "        1.68709564e+00, 1.06944075e+01, 3.04439008e-01, 6.57701552e-01,\n",
       "        3.98439550e+00, 3.23199749e+00, 9.58816409e-01, 1.34341192e+00,\n",
       "        2.71629959e-01, 6.90532923e-01, 1.56520891e+00, 1.74639380e+00,\n",
       "        5.74344993e-01, 1.75445533e+00, 1.76699713e-01, 4.64757860e-01,\n",
       "        2.85382795e+00, 7.72247672e-01, 1.54857755e+00, 2.38830519e+00,\n",
       "        2.17248001e+01, 9.49249191e+01, 7.76088536e-01, 5.96989822e+00,\n",
       "        1.43360734e+00, 8.62823874e-02, 1.15831949e-01, 1.07367218e-01,\n",
       "        4.22274172e-01, 6.76634768e-03, 4.67815666e+01, 2.95404047e-01,\n",
       "        4.89367917e-02, 1.01789653e-01, 1.65829644e-01, 3.50807428e-01,\n",
       "        3.12536359e-02, 4.82255578e-01, 7.69384241e+00, 2.25754237e+00,\n",
       "        1.24695256e-01, 5.59742689e-01, 4.15617377e-01, 3.68812680e+00,\n",
       "        1.31183332e-02, 2.81615997e+02, 4.09274548e-01, 8.95690918e+00,\n",
       "        1.63568115e+02, 1.08991051e+01, 2.50252664e-01, 1.19244778e+00,\n",
       "        9.24216658e-02, 8.53185177e+00, 3.57675600e+00, 1.44717908e+00,\n",
       "        2.67283106e+00, 4.01176119e+00, 1.36139140e-01, 1.35646505e+01,\n",
       "        3.70645702e-01, 1.25805095e-01, 8.13326314e-02, 1.37148333e+00,\n",
       "        1.44619846e+00, 1.98824644e+00, 1.26121368e+01, 2.24997449e+00,\n",
       "        2.36572981e+00, 4.56021689e-02, 3.83118838e-01, 8.18680573e+00,\n",
       "        3.75316516e-02, 1.20188996e-01, 8.28357697e-01, 3.80831409e+00,\n",
       "        9.93661225e-01, 1.64554977e+01, 1.46420736e+01, 5.01224697e-01,\n",
       "        2.86657190e+00, 5.19601440e+00, 4.38507758e-02, 9.26029444e-01,\n",
       "        6.94277227e-01, 7.80624330e-01, 5.97081280e+00, 1.07989624e-01,\n",
       "        4.25445557e-01, 3.42485398e-01, 2.46426630e+00, 1.09807072e+01,\n",
       "        3.39442778e+00, 1.92682660e+00, 1.99583817e+00, 1.76183987e+01,\n",
       "        5.47117069e-02, 5.88931084e+00, 4.27399069e-01, 8.95606130e-02,\n",
       "        2.47298583e-01, 1.96231496e+00, 3.07569946e+02, 1.25790104e-01,\n",
       "        1.34648151e+01, 2.11766028e+00, 6.28289366e+00, 6.45816624e-01,\n",
       "        3.14541030e+00, 2.78676128e+00, 6.08464003e-01, 2.10123695e-02,\n",
       "        3.66867232e+00, 2.90201902e-02, 1.20597744e+00, 7.27713555e-02,\n",
       "        1.75696766e+00, 1.58325207e+00, 5.81738186e+00, 1.42245501e-01,\n",
       "        9.45202649e-01, 1.99816227e-01, 3.88373137e-01, 8.33094177e+01,\n",
       "        8.32297742e-01, 8.46238285e-02, 3.51874256e+00, 2.20348430e+00,\n",
       "        2.66385656e-02, 4.76497793e+00, 8.98555741e-02, 7.64251947e-02,\n",
       "        1.16415568e-01, 3.50732245e-02, 9.57669163e+00, 2.83394158e-01,\n",
       "        9.88502324e-01, 1.28968477e-01, 5.80920465e-02, 1.51831970e+01,\n",
       "        1.43560559e-01, 2.94676256e+00, 2.77967453e+00, 2.28960350e-01,\n",
       "        9.28630531e-01, 1.64725333e-01, 6.63990751e-02, 1.70368624e+00,\n",
       "        7.96665251e-02, 1.27391834e+01, 1.22700918e+00, 3.50109935e-01,\n",
       "        1.42741621e+00, 2.89389968e-01, 2.08955908e+00, 2.55621254e-01,\n",
       "        1.12856708e-01, 7.64343719e+01, 2.08302164e+00, 4.40425491e+00,\n",
       "        5.33638559e-02, 2.70293816e-03, 1.23855732e-02, 7.24222660e-02,\n",
       "        9.26129913e+00, 5.16127968e+00, 6.43561959e-01, 2.50439215e+00,\n",
       "        3.40449274e-01, 2.77916729e-01, 2.76293308e-01, 1.58330345e+00,\n",
       "        1.95693746e-02, 3.36668044e-01, 3.72334301e-01, 5.89008749e-01,\n",
       "        6.68943644e+00, 3.91421057e-02, 2.58591920e-01, 8.79577160e-01,\n",
       "        2.17920989e-01, 1.39983582e+00, 1.15439701e+00, 3.73752892e-01,\n",
       "        2.85958433e+00, 7.58126259e-01, 1.21914136e+00, 1.54122329e+00,\n",
       "        1.23023331e-01, 9.40471888e-01, 2.78896749e-01, 2.73190856e-01,\n",
       "        2.51762867e-01, 2.40095481e-01, 1.12183511e+00, 1.14272165e+00,\n",
       "        3.93754363e+00, 1.53578615e+00, 4.43884134e-01, 5.81733942e-01,\n",
       "        3.15729946e-01, 1.69040155e+00, 7.21880102e+00, 1.82689369e-01,\n",
       "        2.57084703e+00, 7.62480378e-01, 1.53930950e+00, 6.56188190e-01,\n",
       "        4.91904207e-02, 1.72594547e+00, 5.50979674e-01, 3.61712694e+00,\n",
       "        3.43802986e+01, 4.90036964e-01, 1.60334849e+00, 6.32177219e-02,\n",
       "        2.42789268e+00, 3.47943395e-01, 7.67288685e-01, 2.99472064e-01,\n",
       "        2.20482612e+00, 1.82462782e-01, 3.85626650e+00, 2.25165263e-01,\n",
       "        1.30820602e-01, 1.15619086e-01, 8.33818465e-02, 1.05868256e+00,\n",
       "        9.03057384e+00, 1.70071404e-02, 2.36504883e-01, 1.32590011e-01,\n",
       "        5.55053242e-02, 8.65181160e+00, 4.85210419e+00, 6.41302526e-01,\n",
       "        2.78168060e-02, 6.77430928e-02, 2.71182060e-01, 1.11463976e+01,\n",
       "        2.45280385e+00, 2.77839571e-01, 2.25407219e+00, 5.75285797e+01,\n",
       "        3.75315762e+00, 2.27169946e-01, 2.46220335e-01, 1.27223740e+01,\n",
       "        5.59641151e+01, 4.11484289e+00, 5.47345757e-01, 5.69956112e+00,\n",
       "        2.21226788e+00, 3.35258818e+00, 2.73592997e+00, 4.09058407e-02,\n",
       "        3.72042131e+00, 1.44386072e+01, 4.83934546e+00, 1.28996444e+00,\n",
       "        4.45038795e-01, 7.32211733e+00, 3.05797744e+00, 3.44322957e-02,\n",
       "        4.45183640e+01, 1.22389376e+00, 1.22673355e-01, 3.48118711e+00,\n",
       "        1.87829340e+00, 1.74468184e+00, 3.73178422e-01, 3.07947576e-01,\n",
       "        4.05009747e+00, 3.03374380e-02, 7.47009087e+00, 5.25378180e+00,\n",
       "        7.58502960e+01, 3.69242573e+00, 5.05115092e-01, 9.32182431e-01,\n",
       "        4.82270420e-01, 4.11262751e+00, 1.20288029e+01, 2.32080460e+01,\n",
       "        1.39755690e+00, 3.95559132e-01, 2.47389916e-03, 5.76772785e+00,\n",
       "        1.20588401e-02, 1.11935587e+01, 9.11258399e-01, 1.07921219e+00,\n",
       "        2.73886242e+01, 8.87466446e-02, 5.64388096e-01, 3.15148264e-01,\n",
       "        1.04958378e-01, 1.41450111e-02, 1.91796068e-02, 2.48120155e+01,\n",
       "        9.78477374e-02, 1.36607029e-02, 7.93582296e+00, 4.75532246e+00,\n",
       "        5.20005859e-02, 1.00669909e+00, 7.77359247e-01, 7.92310333e+00,\n",
       "        4.76437807e+00, 2.32946128e-01, 1.28514811e-01, 2.41771293e+00,\n",
       "        2.94909567e-01, 2.00391650e-01, 8.82500935e+00, 7.40938783e-01,\n",
       "        2.73076344e+00, 3.96046877e-01, 1.75397813e-01, 6.87451696e+00,\n",
       "        3.18063945e-01, 2.09063435e+00, 6.66461706e-01, 2.20763385e-02,\n",
       "        1.95303291e-01, 1.16690174e-01, 1.28730638e-02, 5.32146311e+00,\n",
       "        5.13792191e+01, 4.43213999e-01, 1.16585340e+01, 2.78305149e+00,\n",
       "        2.01732069e-01, 7.82548308e-01, 1.20926642e+00, 2.41294169e+00,\n",
       "        1.19989894e-01, 9.17292893e-01, 3.40692425e+00, 2.38588750e-01,\n",
       "        7.59572983e-01, 1.55588126e+00, 1.71683073e+00, 1.89433134e+00,\n",
       "        1.05617344e+00, 1.80770218e+00, 9.39505577e+00, 4.35281172e-02,\n",
       "        8.56157303e-01, 4.15055618e+01, 5.20620060e+00, 3.19566298e+00,\n",
       "        1.32180139e-01, 7.97433913e-01, 7.01427817e-01, 1.01830631e-01,\n",
       "        5.07234693e-01, 9.86520112e-01, 7.27593064e-01, 1.15341778e+01,\n",
       "        9.25196171e+00, 2.29934216e+00, 1.78380400e-01, 2.44113490e-01,\n",
       "        3.20831418e+00, 1.01328301e+00, 1.66645489e+01, 2.68183613e+00,\n",
       "        4.25809801e-01, 7.87760139e-01, 1.10825241e-01, 2.08175731e+00,\n",
       "        1.03322802e+01, 2.32740831e+00, 1.17664170e+00, 2.40530781e-02,\n",
       "        3.98520947e-01, 1.70951819e+00, 9.26590919e-01, 1.68277967e+00,\n",
       "        3.27568799e-01, 5.17039821e-02, 1.09406185e+00, 3.46642828e+00,\n",
       "        4.99729700e-02, 5.53480577e+00, 3.52962404e-01, 3.49417105e-02,\n",
       "        1.55932933e-01, 1.96756292e-02, 4.49888349e-01, 5.19266129e-01,\n",
       "        8.56213748e-01, 6.96944594e-01, 3.63984442e+00, 1.93008089e+00,\n",
       "        1.23262197e-01, 7.71175265e-01, 1.19298375e+00, 5.69028080e-01,\n",
       "        4.01445299e-01, 3.44568520e+01, 5.59636021e+00, 2.30269680e+01,\n",
       "        3.91478866e-01, 2.50916243e-01, 7.12178946e-01, 1.06668243e+02,\n",
       "        3.42858024e-02, 3.69264223e-02, 1.73801270e+01, 3.71067971e-02,\n",
       "        2.33768806e-01, 1.86491280e+01, 7.13092422e+00, 2.48614877e-01,\n",
       "        2.38254509e+01, 5.69141030e-01, 1.47821128e+00, 8.26590806e-02,\n",
       "        3.63907528e+00, 1.22100361e-01, 4.27071542e-01, 2.43478036e+00,\n",
       "        2.93952465e+00, 2.90937924e+00, 7.60238528e-01, 1.37405300e+00,\n",
       "        6.20557606e-01, 9.55959260e-01, 4.93241653e+01, 7.09580183e-01,\n",
       "        3.83824706e-01, 7.91821182e-02, 5.48770308e-01, 1.83580565e+00,\n",
       "        6.10363901e-01, 2.17539668e+00, 1.41665602e+00, 1.61924591e+01,\n",
       "        1.81592190e+00, 9.02995527e-01, 5.68223381e+00, 3.57227921e-01,\n",
       "        3.57845664e-01, 1.41008466e-01, 1.03919089e+00, 2.26167908e+01,\n",
       "        4.36668217e-01, 9.48163927e-01, 2.33770370e-01, 1.12772636e+01,\n",
       "        5.34465909e-01, 7.13059068e-01, 8.82860087e-03, 4.71881771e+00,\n",
       "        5.22846520e-01, 7.27684975e+00, 7.09992371e+01, 1.12560976e+00,\n",
       "        4.02947158e-01, 8.54561985e-01, 2.15264440e-01, 1.65239617e-01,\n",
       "        1.14370403e+01, 7.26302505e-01, 4.78558689e-02, 7.45465934e-01,\n",
       "        9.56649840e-01, 3.28278422e-01, 7.60484785e-02, 1.29721045e-01,\n",
       "        3.78095806e-01, 7.23694921e-01, 9.09356028e-02, 9.48884338e-03,\n",
       "        1.29534686e-02, 1.09014571e+00, 2.76626814e-02, 2.15888166e+00,\n",
       "        7.32082214e+01, 4.76814359e-02, 5.63013852e-01, 7.31639028e-01,\n",
       "        7.40627991e-03, 1.38072297e-01, 1.50609481e+00, 2.79728103e+00,\n",
       "        3.14244366e+01, 1.84297636e-01, 6.24623857e-02, 8.61966400e+01,\n",
       "        2.88518131e-01, 6.10402763e-01, 8.41918111e-01, 2.13445377e+00,\n",
       "        5.52617535e-02, 5.21258295e-01, 2.39284778e+00, 2.41859937e+00,\n",
       "        6.49309754e-01, 8.90093148e-01, 1.55021214e+00, 3.98970470e-02,\n",
       "        8.20615292e-01, 1.72807217e-01, 3.75485916e+01, 8.21577072e-01,\n",
       "        6.64803982e-01, 2.05465287e-01, 6.88034222e-02, 1.28786460e-01,\n",
       "        3.15750504e+00, 1.06309795e+00, 3.64285745e-02, 2.18347877e-01,\n",
       "        6.02958262e-01, 1.57504523e+00, 1.18799889e+00, 2.19103277e-01,\n",
       "        2.39965606e+00, 1.03103867e+01, 2.51075816e+00, 8.32636237e-01,\n",
       "        1.56476307e+01, 1.87592316e+02, 1.23210609e-01, 2.00510144e-01,\n",
       "        1.51414223e+01, 3.80193639e+00, 1.00141935e-01, 5.44562645e+01,\n",
       "        2.28505939e-01, 2.84810998e-02, 5.65395164e+00, 1.52638167e-01,\n",
       "        1.39911156e+01, 2.14283252e+00, 9.86184120e+00, 2.07714820e+00,\n",
       "        1.44638705e+00, 3.66551988e-02, 1.58385208e+02, 3.24747622e-01,\n",
       "        1.38496310e-01, 2.14627326e-01, 4.47397321e-01, 3.44438732e-01,\n",
       "        3.91426861e-01, 3.32887840e+00, 9.79910433e-01, 2.44388655e-02,\n",
       "        3.78504455e-01, 1.43081367e-01, 7.81579132e+01, 5.89138365e+00,\n",
       "        1.69203532e+00, 1.09337175e+00, 8.12721178e-02, 2.08727217e+00,\n",
       "        3.29456019e+00, 1.87509894e+00, 5.78359425e-01, 1.59802294e+01,\n",
       "        3.23634362e+00, 2.29434896e+00, 4.56054837e-01, 1.54410410e+00,\n",
       "        1.12095498e-01, 6.52856731e+00, 1.25826101e+01, 2.19412208e+00,\n",
       "        3.82865214e+00, 2.01510353e+01, 1.04165304e+00, 6.00540817e-01,\n",
       "        3.99796391e+00, 6.06808513e-02, 4.69100857e+00, 8.20167661e-02,\n",
       "        7.67097092e+00, 4.90689325e+00, 1.47942444e+02, 6.16844893e+00,\n",
       "        2.14651793e-01, 1.62089801e+00, 2.55464196e+00, 1.49636686e-01,\n",
       "        4.52047348e+00, 1.32469058e-01, 1.71876764e+00, 5.77410638e-01,\n",
       "        1.56135917e+00, 7.34895134e+00, 2.31665999e-01, 1.34614348e-01,\n",
       "        2.12271285e+00, 5.73711544e-02, 2.09892076e-02, 1.80834460e+00,\n",
       "        2.41978383e+00, 2.01669922e+01, 5.56314564e+00, 3.11135530e+00,\n",
       "        5.76796412e-01, 2.58171201e-01, 3.19361019e+00, 1.79908518e-02,\n",
       "        4.49867174e-02, 5.42101860e-01, 7.12393746e-02, 2.51955181e-01,\n",
       "        3.82200170e+00, 1.93046455e+01, 9.93508875e-01, 7.20849705e+00,\n",
       "        8.22880459e+00, 3.66725612e+00, 6.48297906e-01, 9.16265488e-01,\n",
       "        9.72939372e-01, 1.54407148e+01, 2.00151563e-01, 3.83703351e-01,\n",
       "        1.69877899e+00, 5.73431253e-01, 2.16499224e-01, 2.22769165e+00,\n",
       "        4.09516296e+01, 7.63758123e-02, 2.25976348e+00, 1.21210203e-01,\n",
       "        1.72584271e+00, 5.50241613e+00, 4.65016216e-02, 3.07376146e-01,\n",
       "        3.67154312e+01, 1.40750465e+01, 3.75472736e+00, 4.95914668e-01,\n",
       "        6.52567625e-01, 1.52943265e+00, 2.69775462e+00, 2.60670161e+00,\n",
       "        1.50851083e+00, 6.26138628e-01, 1.88142538e+00, 4.47143734e-01,\n",
       "        9.12221491e-01, 2.35126281e+00, 8.86874485e+00, 1.27029431e+00,\n",
       "        5.30616283e+00, 2.51126379e-01, 1.54121292e+00, 1.78119481e-01,\n",
       "        4.09441113e-01, 4.19495487e+00, 2.84843184e-02, 1.00586295e+00,\n",
       "        1.20155487e+01, 2.76484537e+00, 7.44419172e-02, 2.70126724e+00,\n",
       "        5.69623224e-02, 2.48505309e-01, 2.25644946e+00, 2.56405234e-01,\n",
       "        7.23256111e-01, 5.37466717e+00, 1.93067493e+01, 4.81508350e+00,\n",
       "        1.01120746e+00, 3.76599371e-01, 2.97080696e-01, 2.31870204e-01,\n",
       "        9.17075276e-02, 5.96835315e-02, 7.72666073e+00, 8.42288211e-02,\n",
       "        8.97899437e+00, 1.07909508e+01, 1.64874992e+01, 1.19850242e+00,\n",
       "        1.76514611e-01, 1.71086521e+01, 1.58030856e-02, 9.36947405e-01,\n",
       "        3.14005518e+00, 4.98046398e+00, 4.45245028e-01, 1.77009910e-01,\n",
       "        1.89374357e-01, 4.03089702e-01, 1.86383843e-01, 3.39792788e-01,\n",
       "        2.40405035e+00, 9.93740618e-01, 3.97212327e-01, 1.98472068e-02,\n",
       "        4.76744843e+00, 2.36460710e+00, 1.13526750e+00, 1.10386439e-01,\n",
       "        6.39403462e-02, 4.08109009e-01, 7.27008097e-03, 2.48427558e+00,\n",
       "        2.41658717e-01, 4.70913458e+00, 1.12327516e+00, 3.08872395e+01,\n",
       "        1.81206679e+00, 1.89754248e+00, 5.80937639e-02, 4.68836784e-01,\n",
       "        1.67445153e-01, 2.67527604e+00, 6.35014343e+02, 6.63377953e+00,\n",
       "        1.04557190e+01, 3.56604218e-01, 3.59419227e-01, 1.16211998e+00,\n",
       "        3.85863364e-01, 2.26898417e-01, 4.46932971e-01, 2.00684023e+00,\n",
       "        2.07620907e+00, 6.28967583e-02, 4.70104814e-01, 1.84122193e+00,\n",
       "        5.23408203e+01, 1.67829752e+00, 9.61457748e+01, 2.21067762e+00,\n",
       "        2.09141803e+00, 1.36288404e+00, 1.41227043e+00, 4.58974302e-01,\n",
       "        5.65286219e-01, 4.05721970e+01, 8.00310150e-02, 7.69099045e+01,\n",
       "        4.45707366e-02, 3.24545503e-01, 1.69612241e+00, 3.57254601e+01,\n",
       "        1.13023605e+01, 7.97888637e-02, 5.56409001e-01, 9.21226889e-02,\n",
       "        2.06045437e+00, 4.93089318e-01, 1.66515803e+00, 3.14175546e-01,\n",
       "        4.72161174e-02, 2.58658528e+00, 1.12444937e+00, 5.24198246e+00,\n",
       "        6.39048386e+00, 1.59712210e+01, 3.66876185e-01, 9.54116106e-01,\n",
       "        6.63767147e+00, 2.52110243e-01, 3.53070297e+01, 9.76176113e-02,\n",
       "        3.66966963e-01, 3.82148972e+01, 1.79293364e-01, 2.61576710e+01,\n",
       "        4.71665919e-01, 1.36975718e+00, 1.68981463e-01, 7.34958029e+00,\n",
       "        5.50149307e+01, 7.36747622e-01, 1.96696103e+00, 4.55198135e+01,\n",
       "        1.71798058e-02, 6.56618309e+00, 1.25896009e-02, 1.45659775e-01,\n",
       "        3.22978020e-01, 1.30641747e+00, 4.38826680e-01, 4.76096802e+01,\n",
       "        1.54508039e-01, 4.81790695e+01, 2.11133793e-01, 3.16516697e-01,\n",
       "        4.60727272e+01, 1.08547187e+00, 1.00393593e+00, 2.66877055e+00,\n",
       "        2.31807303e+00, 1.46158905e+01, 9.22110140e-01, 6.79874897e-01,\n",
       "        1.31660242e+01, 3.80427289e+00, 1.16475773e+01, 3.09875071e-01,\n",
       "        8.12321949e+00, 2.39170223e-01, 1.06370139e+00, 2.24348640e+01,\n",
       "        1.56104398e+00, 4.47443295e+00, 5.15494168e-01, 2.68055916e-01,\n",
       "        5.29225618e-02, 1.03690636e+02, 2.36404681e+00, 3.17508221e+00],\n",
       "       dtype=float32)}"
      ]
     },
     "execution_count": 443,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "advi_posterior_samples"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "MCMC?"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 385,
   "metadata": {},
   "outputs": [],
   "source": [
    "from pyro.infer.mcmc import NUTS, MCMC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 395,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Sample: 100%|██████████| 150/150 [17:09,  6.86s/it, step size=2.85e-04, acc. prob=0.516]\n"
     ]
    }
   ],
   "source": [
    "from gpytorch.priors import LogNormalPrior, NormalPrior, UniformPrior, GammaPrior\n",
    "\n",
    "class ExactGPModel(gpytorch.models.ExactGP):\n",
    "    def __init__(self, train_x, train_y, likelihood):\n",
    "        super(ExactGPModel, self).__init__(train_x, train_y, likelihood)\n",
    "        self.mean_module = gpytorch.means.ConstantMean()\n",
    "        self.covar_module = gpytorch.kernels.ScaleKernel(gpytorch.kernels.RBFKernel())\n",
    "        \n",
    "    def forward(self, x):\n",
    "        mean_x = self.mean_module(x)\n",
    "        covar_x = self.covar_module(x)\n",
    "        return gpytorch.distributions.MultivariateNormal(mean_x, covar_x)\n",
    "    \n",
    "def pyro_model(x, y):\n",
    "    model.pyro_sample_from_prior()\n",
    "    output = model(x)\n",
    "    loss = mll.pyro_factor(output, y)\n",
    "    return y\n",
    "\n",
    "# Standardize the data s.t. input is on unit cube and output has zero mean and std=1.\n",
    "train_x = X_train_tensor.view(-1,1)\n",
    "train_y = y_train_tensor.view(-1,1)\n",
    "min_x = torch.min(train_x)\n",
    "max_x = torch.max(train_x - min_x)\n",
    "train_x_trans = train_x #(train_x - min_x) / max_x\n",
    "\n",
    "mu_y = torch.mean(train_y)\n",
    "sigma_y = torch.std(train_y)\n",
    "train_y_trans = train_y #(train_y - mu_y) / sigma_y\n",
    "\n",
    "# Define likelihood, model and set priors\n",
    "length_scale_prior = LogNormalPrior(loc=0, scale=1)# GammaPrior(3, 6)\n",
    "noise_prior = LogNormalPrior(loc=0, scale=1)\n",
    "likelihood = gpytorch.likelihoods.GaussianLikelihood(noise_constraint=gpytorch.constraints.Positive())\n",
    "model = ExactGPModel(train_x_trans, train_y_trans, likelihood)\n",
    "model.covar_module.base_kernel.register_prior(\"lengthscale_prior\", length_scale_prior, \"lengthscale\")\n",
    "likelihood.register_prior(\"noise_prior\", noise_prior, \"noise\")\n",
    "mll = gpytorch.mlls.ExactMarginalLogLikelihood(likelihood, model)\n",
    "\n",
    "# Get posteriors of hyperparam\n",
    "#nuts_kernel = NUTS(pyro_model, adapt_step_size=False, target_accept_prob=0.8, step_size=2e-1, max_tree_depth=10)\n",
    "#nuts_kernel = NUTS(pyro_model, adapt_step_size=True, target_accept_prob=0.8)\n",
    "#mcmc_run = MCMC(nuts_kernel, num_samples=100, warmup_steps=50, num_chains=1)\n",
    "pyro.clear_param_store() \n",
    "pyro.set_rng_seed(1)\n",
    "kernel = NUTS(pyro_model, target_accept_prob=0.8)\n",
    "mcmc_run = MCMC(kernel, num_samples=100, warmup_steps=50)\n",
    "mcmc_run.run(train_x_trans, train_y_trans)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 396,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Extract samples from posterior\n",
    "posterior_samples = mcmc_run.get_samples()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 404,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0.8829, 0.8819, 0.8802, 0.8779, 0.8767, 0.8753, 0.8741, 0.8724, 0.8695,\n",
       "        0.8681, 0.8658, 0.8659, 0.8652, 0.8611, 0.8588, 0.8565, 0.8535, 0.8530,\n",
       "        0.8528, 0.8520, 0.8516, 0.8514, 0.8513, 0.8512, 0.8495, 0.8490, 0.8482,\n",
       "        0.8482, 0.8460, 0.8459, 0.8434, 0.8429, 0.8412, 0.8408, 0.8343, 0.8342,\n",
       "        0.8297, 0.8272, 0.8258, 0.8228, 0.8222, 0.8219, 0.8214, 0.8206, 0.8192,\n",
       "        0.8177, 0.8159, 0.8151, 0.8148, 0.8142, 0.8139, 0.8137, 0.8131, 0.8095,\n",
       "        0.8094, 0.8062, 0.8001, 0.7995, 0.7987, 0.7987, 0.7973, 0.7961, 0.7912,\n",
       "        0.7891, 0.7834, 0.7821, 0.7779, 0.7777, 0.7776, 0.7733, 0.7674, 0.7673,\n",
       "        0.7640, 0.7640, 0.7628, 0.7617, 0.7614, 0.7609, 0.7608, 0.7606, 0.7567,\n",
       "        0.7522, 0.7507, 0.7507, 0.7506, 0.7498, 0.7497, 0.7490, 0.7429, 0.7426,\n",
       "        0.7426, 0.7426, 0.7424, 0.7417, 0.7416, 0.7413, 0.7408, 0.7407, 0.7402,\n",
       "        0.7399], dtype=torch.float64)"
      ]
     },
     "execution_count": 404,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "posterior_samples['likelihood.noise_prior'].squeeze(-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 408,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for k in posterior_samples.keys():\n",
    "    tmp = posterior_samples[k].squeeze(-1).numpy()\n",
    "    plt.hist(tmp, bins=30, label=k, range=(0,1.3))\n",
    "    #plt.hist(advi_posterior_samples[k], bins=30, label=k)\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## VariationalGP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "metadata": {
    "id": "gug-ME5O5A5-"
   },
   "outputs": [],
   "source": [
    "class VariationalGP(GPModel):\n",
    "    r\"\"\"\n",
    "    Variational Gaussian Process model.\n",
    "    This model deals with both Gaussian and non-Gaussian likelihoods. Given inputs\\\n",
    "    :math:`X` and their noisy observations :math:`y`, the model takes the form\n",
    "    .. math::\n",
    "        f &\\sim \\mathcal{GP}(0, k(X, X)),\\\\\n",
    "        y & \\sim p(y) = p(y \\mid f) p(f),\n",
    "    where :math:`p(y \\mid f)` is the likelihood.\n",
    "    We will use a variational approach in this model by approximating :math:`q(f)` to\n",
    "    the posterior :math:`p(f\\mid y)`. Precisely, :math:`q(f)` will be a multivariate\n",
    "    normal distribution with two parameters ``f_loc`` and ``f_scale_tril``, which will\n",
    "    be learned during a variational inference process.\n",
    "    .. note:: This model can be seen as a special version of\n",
    "        :class:`.SparseVariationalGP` model with :math:`X_u = X`.\n",
    "    .. note:: This model has :math:`\\mathcal{O}(N^3)` complexity for training,\n",
    "        :math:`\\mathcal{O}(N^3)` complexity for testing. Here, :math:`N` is the number\n",
    "        of train inputs. Size of variational parameters is :math:`\\mathcal{O}(N^2)`.\n",
    "    :param torch.Tensor X: A input data for training. Its first dimension is the number\n",
    "        of data points.\n",
    "    :param torch.Tensor y: An output data for training. Its last dimension is the\n",
    "        number of data points.\n",
    "    :param ~pyro.contrib.gp.kernels.kernel.Kernel kernel: A Pyro kernel object, which\n",
    "        is the covariance function :math:`k`.\n",
    "    :param ~pyro.contrib.gp.likelihoods.likelihood Likelihood likelihood: A likelihood\n",
    "        object.\n",
    "    :param callable mean_function: An optional mean function :math:`m` of this Gaussian\n",
    "        process. By default, we use zero mean.\n",
    "    :param torch.Size latent_shape: Shape for latent processes (`batch_shape` of\n",
    "        :math:`q(f)`). By default, it equals to output batch shape ``y.shape[:-1]``.\n",
    "        For the multi-class classification problems, ``latent_shape[-1]`` should\n",
    "        corresponse to the number of classes.\n",
    "    :param bool whiten: A flag to tell if variational parameters ``f_loc`` and\n",
    "        ``f_scale_tril`` are transformed by the inverse of ``Lff``, where ``Lff`` is\n",
    "        the lower triangular decomposition of :math:`kernel(X, X)`. Enable this flag\n",
    "        will help optimization.\n",
    "    :param float jitter: A small positive term which is added into the diagonal part of\n",
    "        a covariance matrix to help stablize its Cholesky decomposition.\n",
    "    \"\"\"\n",
    "    def __init__(self, X, y, kernel, likelihood, mean_function=None,\n",
    "                 latent_shape=None, whiten=False, jitter=1e-6):\n",
    "        super().__init__(X, y, kernel, mean_function, jitter)\n",
    "\n",
    "        \n",
    "        self.likelihood = likelihood\n",
    "\n",
    "        y_batch_shape = self.y.shape[:-1] if self.y is not None else torch.Size([])\n",
    "        self.latent_shape = latent_shape if latent_shape is not None else y_batch_shape\n",
    "\n",
    "        # Vector for mean function (but what is input mean_function when for) or\n",
    "        # is it the \"inducing points\" to use for variational inference.\n",
    "        # (should the inducing point locations Z be learned (i.e. are they parameters of the model)?)\n",
    "        N = self.X.size(0)\n",
    "        f_loc = self.X.new_zeros(self.latent_shape + (N,)) # Dim: [N]\n",
    "        self.f_loc = Parameter(f_loc)\n",
    "\n",
    "        # Matric for covariance function?\n",
    "        identity = eye_like(self.X, N)\n",
    "        f_scale_tril = identity.repeat(self.latent_shape + (1, 1))\n",
    "        self.f_scale_tril = PyroParam(f_scale_tril, constraints.lower_cholesky)  # Dim: [N, N]\n",
    "        # Why is this a PyroParam, when f_loc is just param?\n",
    "\n",
    "        # This variational strategy uses “whitening” to accelerate\n",
    "        # the optimization of the variational parameter\n",
    "        self.whiten = whiten \n",
    "        \n",
    "        self._sample_latent = True  # What is this?\n",
    "\n",
    "    @pyro_method\n",
    "    def model(self):\n",
    "        self.set_mode(\"model\")\n",
    "\n",
    "        N = self.X.size(0)\n",
    "        Kff = self.kernel(self.X).contiguous()\n",
    "        Kff.view(-1)[::N + 1] += self.jitter  # add jitter to the diagonal\n",
    "        Lff = Kff.cholesky()\n",
    "\n",
    "        zero_loc = self.X.new_zeros(self.f_loc.shape)\n",
    "        if self.whiten:\n",
    "            identity = eye_like(self.X, N)\n",
    "            pyro.sample(self._pyro_get_fullname(\"f\"),\n",
    "                        dist.MultivariateNormal(zero_loc, scale_tril=identity)\n",
    "                            .to_event(zero_loc.dim() - 1))\n",
    "            f_scale_tril = Lff.matmul(self.f_scale_tril)\n",
    "            f_loc = Lff.matmul(self.f_loc.unsqueeze(-1)).squeeze(-1)\n",
    "        else:\n",
    "            pyro.sample(self._pyro_get_fullname(\"f\"),\n",
    "                        dist.MultivariateNormal(zero_loc, scale_tril=Lff)\n",
    "                            .to_event(zero_loc.dim() - 1))\n",
    "            f_scale_tril = self.f_scale_tril\n",
    "            f_loc = self.f_loc\n",
    "\n",
    "        f_loc = f_loc + self.mean_function(self.X)\n",
    "        f_var = f_scale_tril.pow(2).sum(dim=-1)\n",
    "        if self.y is None:  # why either return (mean, variance) or the likelihood?\n",
    "            return f_loc, f_var  \n",
    "        else:\n",
    "            return self.likelihood(f_loc, f_var, self.y)\n",
    "\n",
    "    @pyro_method\n",
    "    def guide(self):\n",
    "        self.set_mode(\"guide\")\n",
    "        self._load_pyro_samples()\n",
    "        \n",
    "        # Original: MultivariateNormal\n",
    "        pyro.sample(self._pyro_get_fullname(\"f\"),\n",
    "                dist.MultivariateNormal(self.f_loc, scale_tril=self.f_scale_tril).to_event(self.f_loc.dim()-1))\n",
    "        \n",
    "        # Diagonal matrix w/ multiple sigmas\n",
    "        #scale_diag = torch.diag(self.f_scale_tril.diag())\n",
    "        #pyro.sample(self._pyro_get_fullname(\"f\"),\n",
    "        #        dist.MultivariateNormal(self.f_loc, scale_tril=scale_diag).to_event(self.f_loc.dim()-1))\n",
    "        \n",
    "        # Diagonal matriax w/ single sigma\n",
    "        #mean_sigma = torch.mean(torch.diag(self.f_scale_tril.diag()))\n",
    "        #scale_diag = eye_like(self.f_scale_tril, self.f_scale_tril.shape[0]) * mean_sigma\n",
    "        #pyro.sample(self._pyro_get_fullname(\"f\"),\n",
    "        #        dist.MultivariateNormal(self.f_loc, scale_tril=scale_diag).to_event(self.f_loc.dim()-1))\n",
    "\n",
    "    def forward(self, Xnew, full_cov=False):\n",
    "        r\"\"\"\n",
    "        Computes the mean and covariance matrix (or variance) of Gaussian Process\n",
    "        posterior on a test input data :math:`X_{new}`:\n",
    "        .. math:: p(f^* \\mid X_{new}, X, y, k, f_{loc}, f_{scale\\_tril})\n",
    "            = \\mathcal{N}(loc, cov).\n",
    "        .. note:: Variational parameters ``f_loc``, ``f_scale_tril``, together with\n",
    "            kernel's parameters have been learned from a training procedure (MCMC or\n",
    "            SVI).\n",
    "        :param torch.Tensor Xnew: A input data for testing. Note that\n",
    "            ``Xnew.shape[1:]`` must be the same as ``self.X.shape[1:]``.\n",
    "        :param bool full_cov: A flag to decide if we want to predict full covariance\n",
    "            matrix or just variance.\n",
    "        :returns: loc and covariance matrix (or variance) of :math:`p(f^*(X_{new}))`\n",
    "        :rtype: tuple(torch.Tensor, torch.Tensor)\n",
    "        \"\"\"\n",
    "        self._check_Xnew_shape(Xnew)\n",
    "        self.set_mode(\"guide\")\n",
    "\n",
    "        loc, cov = conditional(Xnew, self.X, self.kernel, self.f_loc, self.f_scale_tril,\n",
    "                               full_cov=full_cov, whiten=self.whiten, jitter=self.jitter)\n",
    "        return loc + self.mean_function(Xnew), cov"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 265
    },
    "executionInfo": {
     "elapsed": 7515,
     "status": "ok",
     "timestamp": 1589213519859,
     "user": {
      "displayName": "Daniele Gammelli",
      "photoUrl": "",
      "userId": "02727525050247971435"
     },
     "user_tz": -120
    },
    "id": "-qEUo9UXdUKI",
    "outputId": "48ddee33-73d5-4889-efa4-a569be95e372",
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# initialize the kernel, likelihood, and model\n",
    "pyro.clear_param_store()\n",
    "kernel = gp.kernels.RBF(input_dim=1)\n",
    "#likelihood = Gaussian()\n",
    "likelihood = gp.likelihoods.Gaussian()\n",
    "\n",
    "# turn on \"whiten\" flag for more stable optimization\n",
    "vsgp = VariationalGP(X_train_tensor.view(-1,), y_train_tensor.view(-1,), kernel, \n",
    "                     likelihood=likelihood, whiten=True)\n",
    "\n",
    "# instead of defining our own training loop, we will\n",
    "# use the built-in support provided by the GP module\n",
    "num_steps = 1500\n",
    "losses = gp.util.train(vsgp, num_steps=num_steps)  # default: loss_fn=TraceMeanField_ELBO().differentiable_loss\n",
    "plt.plot(losses);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 111,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 374
    },
    "executionInfo": {
     "elapsed": 864,
     "status": "ok",
     "timestamp": 1589213668819,
     "user": {
      "displayName": "Daniele Gammelli",
      "photoUrl": "",
      "userId": "02727525050247971435"
     },
     "user_tz": -120
    },
    "id": "MDhj_6PcdgY1",
    "outputId": "6248877f-40e3-426d-a2e4-f9c7cb1d29d9"
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAs4AAAFpCAYAAACMHa7nAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAACdpElEQVR4nOzdd3RU5dbA4d+Zmg4koUgTAekQQJQSBIRQFDWCgqIGVLxSVfQDBAWuAgoqKnIlgIqi8coVFCmiIkVBEukwgKj0XtPrTGbmnO+PSUYiCQQyyaTsZy0WZMo5OweY7Hlnv3srmqZpCCGEEEIIIa5K5+0AhBBCCCGEKAskcRZCCCGEEKIQJHEWQgghhBCiECRxFkIIIYQQohAkcRZCCCGEEKIQJHEWQgghhBCiEAxFPUB8fDxz584lOTkZRVGIiIjgnnvuyfOY33//nbfeeotq1aoB0L59ex566KGinloIIYQQQogSU+TEWa/XExUVRf369cnKymLChAm0atWK2rVr53lc06ZNmTBhQlFPJ4QQQgghhFcUuVSjSpUq1K9fHwBfX19q1apFYmJikQMTQgghhBCiNCnyivPlLl68yLFjx2jYsOEV9x08eJBx48ZRpUoVoqKiqFOnjidPLYQQQgghRLFSPDVy22q18u9//5v+/fvTvn37PPdlZmai0+nw8fFh165dLFq0iDlz5uR7nHXr1rFu3ToAZs6c6YnQhBBCCCGEKDKPJM4Oh4M333yTsLAw7r333ms+ftSoUcyYMYOgoKBrPvbs2bNFDU8AoaGhxMfHezuMckOup2fJ9fQcuZaeJdfTs+R6eo5cS8+qWbNmoR5X5BpnTdOYP38+tWrVKjBpTk5OJjc/P3z4MKqqEhgYWNRTCyGEEEIIUWKKXOP8119/sWnTJurWrcu4ceMAGDRokPtdUK9evdiyZQs//fQTer0ek8nEmDFjUBSlqKcWQgghhBCixBQ5cW7SpAlLliy56mP69OlDnz59inoqIYQQQgghvMajXTWEEEIIIcoCTdOwWq2oqlomPwW/cOECNpvN22GUKZqmuZtV3OjfuSTOQgghhKhwrFYrRqMRg6FspkIGgwG9Xu/tMMoch8OB1WrF19f3hp5f5M2BQgghhBBljaqqZTZpFjfOYDCgquoNP18SZyGEEEJUOGWxPEN4RlH+7uWtlhBCCCGEF9SpU4cmTZrgcDjQ6/U89NBDPPPMM+h0Ba9rnjp1ih07djBgwIASjFTkkhVnIYQQQggv8PHxYe3atfz888/873//4+eff+bdd9+96nNOnTrFt99+W0IRin+SxFkIIYQQwstCQ0N56623+PTTT9E0jVOnTtGvXz969+5N79692b59OwBvvPEG27Zto3v37nz44YcFPk4UDynVEEIIIUSFVrNWrWI57tkzZ67r8TfffDOqqhIfH09oaCiLFy/Gx8eHo0ePMmrUKH744Qdefvll5s+fz5dffonD4SArKyvfx4niIYmzEEIIIUQpY7fbeeWVVzhw4AA6nY6jR48W6XHCMyRxFkIIIUSFdr0rw8XlxIkT6HQ6QkNDeffdd6latSpr165FVVXq16+f73M++uijQj1OeIbUOAshhBBCeFlCQgITJkzgySefRFEUUlNTqVatGjqdjm+++Qan0wlAQEAAGRkZ7ucV9DhRPGTFWQghhBDCC6xWKz179ryiHR3AkCFDeOaZZ/j666+566678PPzA6Bp06bodDruuusuBgwYUODjRPFQNE3TvB3E1Zw9e9bbIZQLoaGhxMfHezuMckOup2fJ9fQcuZaeJdfTs0rT9czMzCzTSabBYMDhcHg7jDIpv7/7mjVrFuq5UqohhBBCCCFEIUjiLIQQQgghRCFI4iyEEEIIIUQhSOIshBBCCCFEIUjiLIQQQgghRCFI4iyEEEIIIUQhSOIshBBCCOEFt9566xW3ff755yxduhSAhx56CIvFUqhjnTp1iu7duwNgsViYPHkyAO+88w7z58/3UMR/89Rxz58/z7/+9S8PRFQyZACKEEIIISq8PXsMJCZ6bj0xOFildevr77M8ePDgIp87LCyMsLCwIh+nJNSoUYOPPvrI22EUmqw4CyGEEKLCS0zU4XAoHvt1o0l4fiu5qqoyZswY3nzzTZxOJ9OmTaN3795EREQQExNzxTHi4uLyJOAHDx7koYceomPHjixcuNB9+4IFC+jevTvdu3fPk7wWdPv7779P586deeCBBzhy5Ei+8Y8ZM4bJkydz//3307FjR7777jsANE1j2rRpdO/enR49erBixQog70r5X3/9Rd++fenZsycREREcPXoUgG+++cZ9+/jx4706VlxWnIUQQgghSimHw8Ho0aNp3Lgxzz//PF988QWBgYGsWbOGjIwMHnjgAbp27YqiKAUe4/DhwyxdupSMjAzuvPNOBg8ezB9//MGSJUv47rvv0DSNe++9l44dO6KqaoG3r1y5krVr1+JwOOjTpw+tWrXK93wXLlxg+fLlHD58mCeffJJ7772X77//nt9//521a9eSmJjIPffcQ4cOHfI8LyYmhqFDh9K/f3+ys7NxOp0cOnSIlStXsnz5coxGIxMnTmTZsmUMGDDAo9e5sCRxFkIIIYQopV566SXuu+8+nn/+eQA2btzIH3/8wffff4+maaSlpXHs2DHq169f4DF69OiB2WzGbDYTGhrKpUuX2LZtG3369HGPnr777rvZunUrmqble7uqqvTp0wdfX18AevbsWeD5+vTpg06no1GjRly6dAmAbdu28cADD6DX66latSodOnTAYrHQtGlT9/Nuu+025syZw7lz57j77rupX78+mzdvZt++fdxzzz0AWK1WQkNDi3BFi0YSZyGEEEKIUqpdu3bExcUxbNgwfHx8AJg+fToRERE4HH/XUJ86darAY5jNZvef9Xp9sZc6mEwm9581TSv08/r160ebNm1Yv349UVFRvPnmm2iaxoABA5g4cWJxhHrdpMZZCCGEEKKUGjRoEN27d2f48OE4HA66du3K559/jt1uB+DIkSNkZmZe93Hbt2/PmjVryMrKIjMzkx9//JH27dsXeHuHDh3ct6enp7N27drrPt/KlStxOp0kJCSwdetWWrdunecxJ06c4Oabb2bo0KH07t2bP/74g86dO/Pdd98RHx8PQFJSEqdPn77u79dTZMVZCCGEEMILsrKyuO2229xfP/PMM/k+btiwYaSlpfHcc8/xwQcfcOrUKSIiItA0jeDgYD755JPrPnfLli0ZMGAAffv2BVwJeosWLQAKvP2+++6jZ8+ehIaGXpH0Xsvdd9/Nzp076dmzJ4qi8Morr1CtWrU8K+WrVq3im2++wWAwUK1aNZ599lmqVKnC+PHjGTRoEJqmYTAYeP3116ldu/Z1f8+eoGjXs4aej/j4eObOnUtycjKKohAREeGuQ8mlaRqffvopu3fvxmw2M3LkyKvW4lzu7NmzRQlP5AgNDXW/WxNFJ9fTs+R6eo5cS8+S6+lZpel6ZmZmuut4ofS0oyssg8GQp1RDFN4//+4BatasWajnFnnFWa/XExUVRf369cnKymLChAm0atUqzzuB3bt3c/78eebMmcOhQ4f4+OOPeeONN4p6aiGEEEKUEmpSApw/A1kZgAZGM1QJQalRG8VQ+j/gLs4kV5QfRX5rVaVKFffqsa+vL7Vq1SIxMTHPY3bs2EGXLl1QFIVGjRqRkZFBUlJSUU8thBBCCC/TVCfqn3vh4H6UbCuKXo+iN6CoTrhwBm33FtRL570dphAe4dHNgRcvXuTYsWM0bNgwz+2JiYl5WoeEhIRckVwLIYQQomzRHA60vTshMx3Fx/eK+xWDEcVkgmMHUY/8iaaqXohSCM/x2GcnVquVd955hyeeeOKKupHrsW7dOtatWwfAzJkzvdqrrzwxGAxyLT1IrqdnyfX0HLmWniXXs2CaqpK9ZxtagD+KXn+NRwehZdtx/mkhpEkYis77Tb0uXLiAoQyUkFxNWY/fW3L7Wd8Ij1xxh8PBO++8w5133kn79u2vuD84ODjPZoCEhASCg4PzPVZERAQRERHur0vLJoKyrjRtyCgP5Hp6llxPz5Fr6VlyPQumHj8E8RdRjMZCPycwCRLjfkFp3PKqk+5Kgs1mQ3/NhL/0ks2BN85ms13x/7qwmwOL/JZP0zTmz59PrVq1uPfee/N9TLt27di0aROapnHw4EH8/PyoUqVKUU8thBBCCC9Q01LgwtnrSpoBFJMR0lPRjh0spsiEKF5FTpz/+usvNm3axP79+xk3bhzjxo1j165d/PTTT/z0008AtGnThmrVqvHcc8+xYMECnn766SIHLoQQQoiSp2kaHPoj35rmwlCMJoi/gHpe2s1eunSJUaNG0bFjR/r06cN9993HDz/8AEBcXBxNmjShZ8+edO3alXffffeK5586dYoGDRrQs2dPunXrxksvvYR6nXXk+/fvZ/369dcd+/nz5/nXv/513c+7XK1atXj22WfdXzscDlq2bMngwYOLdNziVORSjSZNmrBkyZKrPkZRFEmWhRBCiHJAO38GVAfoTdd+cAEUsw/aycOogYHo/AM9GN2NU48dhPQ0zx0wIBDdLY0KvFvTNJ566ikGDBjA3LlzATh9+rR70RHgjjvu4PPPPyczM5OePXvSs2dPWrZsmec4N998M2vXrsXhcDBw4EB+/PHHK+ZpXM3vv//O3r176dGjR6Gf43A4qFGjBh999NF1PeefNdl+fn78+eefZGVl4evry6ZNm6hRo0ahj+kN3q/OF0IIIUSZoKlOOHvStWpcVCYz/LUPzeks+rE8IT0NRXV67Ne1kvDNmzdjMpnyrK7Wrl2bp5566orH+vn50apVK44dO1bg8QwGA+3ateP48eOcOnWKAQMGEBERwcCBAzlz5gzgmszXvXt3IiIi6N+/P9nZ2cyaNYuVK1fSs2dPVqxYQWZmJi+++CJ9+/alV69erFmzBoCvvvqKJ554ggEDBvDwww9z6tQpunfvDrgaRLzwwgv06NGDXr16ERsbm+9z8tO9e3f3ivfy5ct54IEH3PcVFMupU6fo168fvXv3pnfv3mzfvh1wrdI/9NBD/Otf/6JLly6MHj2aIs75u/I6e/RoQgghhCi3tHOnQfNMSzlFUdAA7cifKI2ae+SYZcnBgwfdo6yvJTExkV27djFmzJgCH5OVlcXmzZsZO3YskyZNYsCAAQwcOJD//e9/TJ48mU8++YTZs2fz3//+l5tuuomUlBRMJhNjx45l7969vP766wDMmDGD8PBw3n33XVJSUujbty933nknAPv27WPdunVUqVIlz6jsRYsWoSgK69ev5/DhwwwaNIhff/31iufkJzIykvfee4+IiAj++OMPHnnkEbZu3QrA+++/n28soaGhLF68GB8fH44ePcqoUaPcJS779+9nw4YN1KhRg8jISLZv384dd9xRqOtcGJI4CyGEEOKaNFWF82c8s9qcQ9Eb0JLiUeMvogut5rHjlkUvv/wy27Ztw2Qy8f333wOwbds2evXqhU6nY9SoUTRu3PiK5504cYKePXuiKAq9e/eme/fuPPfcc3z88ccAPPjgg0yfPh1wNWt44YUXuO+++7j77rvzjWPTpk2sXbuW+fPnA64OFLkr1l26dMk3Ad6+fTtPPvkkAA0bNqR27docPXr0qs/J1axZM06fPs2KFSvcK9jXiqV69eq88sorHDhwAJ1O5z4XQOvWrd0dMpo3b86pU6ckcRZCCCFEydISLoDqxNOpg+Lji3bsIFrlKiiG6+vSUZY1atTInSADvPHGGyQmJuZJaHNrnK8mt8a5MN5880127drF+vXrufvuu92rtJfTNI0PP/zwimF2u3btuqE5HYV5Tq9evZg6dSpff/11nsnSBcXyzjvvULVqVdauXYuqqu4J1gAm099v7PR6vcdb9kmNsxBCCCGu7dxpFJO5eI6t16Md/qN4jl1Kde7cGZvNxmeffea+LSsryyPHbteuHStWrABg2bJl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3LlzycjIaICIReRKqXAWERGpJ1ujCMyuPWHfLqywSxfPlmVBZSXpWdn8vORbXnnlFcaPH6+iWSQEqFVDRETED2xRTaBrLzDNi/Y8W64qwILuaWzdVcSSJUsYP348S5YsoaCgoGEDFpHLphVnERERP7FFRmH1+DHWF0ewvvoSTDfYbGCaYLNDi3iMxBsp3Poxjz/+uLc9Iz09vcZtEQlOKpxFRET8yLDZMdq2x0pqh3X2X1BRAY0aYUQ28Y6cKy4urlEkZ2RkMHfuXIqLi1U4iwQxFc4iIiJXgWGzYTSJhia1/23s2LG17svIyFDRLBLk1OMsIiIiIuIDFc4iIiIiIj5Q4SwiIiIi4oN69Thv3bqVFStWcOzYMV588UWSk5MveNy4ceOIiIjAZrNht9vJz8+vz2lFRERERBpcvQrnxMREcnJymD9/fp3HTp06lejo6PqcTkREREQkYOpVOCckJPgrDhERERGRoNZg4+imTZsGwF133UVmZmZDnVZERERExC/qLJzz8vI4ffp0rfuzsrLo3bu3TyfJy8vD6XTyzTff8MILL9C6dWu6dOlywWPXrVvHunXrAMjPzycuLs6nc8ilORwO5dKPlE//Uj79R7n0L+XTv5RP/1EuA6POwnnKlCn1PonT6QQgJiaG3r17c/jw4YsWzpmZmTVWpE+dOlXv8wvExcUpl36kfPqX8uk/yqV/KZ/+pXz6j3LpX61bt/bpuKs+jq68vJyysjLv33fv3k1SUtLVPq2IiIiIiF/Vq8d527ZtLFq0iDNnzpCfn0/btm2ZNGkSpaWlzJs3j9zcXL755htmzJgBgNvtpk+fPvTo0cMfsYuIiIiINBjDsiwr0EFcyvHjxwMdwjVBv9LxL+XTv5RP/1Eu/Uv59C/l03+US/8KmlYNEREREZFrgQpnEREREREfqHAWEREREfGBCmcRERERER+ocBYRERER8YEKZxERERERH6hwFhERERHxgQpnEREREREfqHAWEREREfGBCmcRERERER+ocBYRERER8YEKZxERERERH6hwFhERERHxgQpnEREREREfqHAWEREREfGBCmcRERERER+ocBYRERER8YEKZxERERERH6hwFhERERHxgQpnEREREREfqHAWEREREfGBCmcRERERER+ocBYRERER8YEKZxERERERH6hwFhERERHxgQpnEREREREf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\n",
      "text/plain": [
       "<Figure size 864x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot(model=vsgp, plot_observed_data=True, plot_predictions=True)\n",
    "plt.ylim(-2, 2.5)\n",
    "None"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "yO76w7urg0ML"
   },
   "source": [
    "The plot above shows the posterior predictive mean described by the GP together with the $\\pm 2\\sigma$ interval around the mean. Notice how the uncertainty increases in regions where we have less observed data. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Copyright (c) 2017-2019 Uber Technologies, Inc.\n",
    "# SPDX-License-Identifier: Apache-2.0\n",
    "\n",
    "import torch\n",
    "from torch.distributions import constraints\n",
    "\n",
    "import pyro\n",
    "import pyro.distributions as dist\n",
    "from pyro.contrib.gp.likelihoods.likelihood import Likelihood\n",
    "from pyro.nn.module import PyroParam\n",
    "\n",
    "\n",
    "class Gaussian(Likelihood):\n",
    "    \"\"\"\n",
    "    Implementation of Gaussian likelihood, which is used for regression problems.\n",
    "\n",
    "    Gaussian likelihood uses :class:`~pyro.distributions.Normal` distribution.\n",
    "\n",
    "    :param torch.Tensor variance: A variance parameter, which plays the role of\n",
    "        ``noise`` in regression problems.\n",
    "    \"\"\"\n",
    "    def __init__(self, variance=None):\n",
    "        super().__init__()\n",
    "\n",
    "        variance = torch.tensor(1.) if variance is None else variance\n",
    "        self.variance = PyroParam(variance, constraints.positive)\n",
    "\n",
    "    def forward(self, f_loc, f_var, y=None):\n",
    "        r\"\"\"\n",
    "        Samples :math:`y` given :math:`f_{loc}`, :math:`f_{var}` according to\n",
    "\n",
    "            .. math:: y \\sim \\mathbb{Normal}(f_{loc}, f_{var} + \\epsilon),\n",
    "\n",
    "        where :math:`\\epsilon` is the ``variance`` parameter of this likelihood.\n",
    "\n",
    "        :param torch.Tensor f_loc: Mean of latent function output.\n",
    "        :param torch.Tensor f_var: Variance of latent function output.\n",
    "        :param torch.Tensor y: Training output tensor.\n",
    "        :returns: a tensor sampled from likelihood\n",
    "        :rtype: torch.Tensor\n",
    "        \"\"\"\n",
    "        \n",
    "        y_dist = dist.Normal(f_loc + torch.randn(f_loc.dim(), device=f_loc.device)*f_var, self.variance.sqrt())\n",
    "        self.y_dist = y_dist\n",
    "        \n",
    "        #y_var = f_var + self.variance\n",
    "        #y_dist = dist.Normal(f_loc, y_var.sqrt())\n",
    "        if y is not None:\n",
    "            y_dist = y_dist.expand_by(y.shape[:-f_loc.dim()]).to_event(y.dim())\n",
    "        return pyro.sample(self._pyro_get_fullname(\"y\"), y_dist, obs=y)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 113,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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8a8GAAAA6GBtBubjjjtOmZmZQcuKi4s1btw4SdK4ceNUXFwsSVq2bJnOOOMMGWM0dOhQVVdXq7y8XKtWrdKIESOUmZmpzMxMjRgxQqtWrer4V9NhqMkAAACAq82SjFAqKirUq1cvSVJOTo4qKiokSV6vV/n5+f7t8vLy5PV65fV6lZeX51+em5srr9cb8thFRUUqKiqSJE2dOjXoeJ2lvqJUXknGmISc/2CRmppK/8WJPuwY9GP86MP40Yfxow/jRx/GJqbAHMgYI2NMR7RFklRQUKCCggL/89LS0g47drTs7t3uT2u16923ZLdtkees8zq9HQe6/Pz8hLx/BxP6sGPQj/GjD+NHH8aPPowffRhe//79w66LaZaM7OxslZeXS5LKy8uVlZUlyR05DnwTysrKlJubq9zcXJWVlfmXe71e5ebmxnLqzmGbSzKcB38p+9wfE9gYAAAAJFJMgXnMmDFavHixJGnx4sU66aST/MvfeecdWWu1ceNGZWRkqFevXho1apRWr16tqqoqVVVVafXq1Ro1alSHvQgAAABgf2mzJGPGjBlav369Kisrde211+riiy/WBRdcoOnTp2vhwoX+aeUk6YQTTtCKFSs0ceJEpaWlqbCwUJKUmZmp733ve7r99tslSd///vdbXUjYpXDNHwAAABq1GZgnTZoUcvldd93VapkxRldddVXI7SdMmKAJEya0r3UAAABAgnGnPwAAACACAnNI1GQAAADARWAGAAAAIiAwAwAAABEQmEOxlGQAAADARWAGAAAAIiAwAwAAABEQmEOhJAMAAACNCMwAAABABARmAAAAIAICMwAAABABgRkAAACIgMAcChf9AQAAoBGBGQAAAIiAwBwJI80AAABJj8AcEkEZAAAALgJzJMYkugUAAABIMAJzJJRkAAAAJD0CcyjkZAAAADQiMAMAAAAREJhDoRQDAAAAjQjMAAAAQAQEZgAAACACAnNIlGQAAADARWAGAAAAIiAwAwAAABEQmEOhIgMAAACNCMwAAABABARmAAAAIAICc0itazIsNzMBAABISgTmaBGYAQAAkhKBOSIb5jEAAACSBYE5lFCjyeRlAACApERgjsgkugEAAABIMAJzKCFHmBliBgAASEYE5qgRmAEAAJIRgTkiG/IhAAAAkgeBOWokZgAAgGREYI4o4KI/apgBAACSEoE5Ikoy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\n",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# initialize the kernel, likelihood, and model\n",
    "pyro.clear_param_store()\n",
    "kernel = gp.kernels.RBF(input_dim=1)\n",
    "likelihood = Gaussian()\n",
    "#likelihood = gp.likelihoods.Gaussian()\n",
    "\n",
    "# turn on \"whiten\" flag for more stable optimization\n",
    "vsgp_d = VariationalGP(X_train_tensor.view(-1,), y_train_tensor.view(-1,), kernel, \n",
    "                     likelihood=likelihood, whiten=True)\n",
    "\n",
    "# instead of defining our own training loop, we will\n",
    "# use the built-in support provided by the GP module\n",
    "num_steps = 1500\n",
    "losses = gp.util.train(vsgp_d, num_steps=num_steps)  # default: loss_fn=TraceMeanField_ELBO().differentiable_loss\n",
    "plt.plot(losses);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 115,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAs4AAAFpCAYAAACMHa7nAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAC75ElEQVR4nOzdeXxU5fX48c+9syUhCZCEEELY9yUEEEUJirKIuKEoWltBq1YBrWJ/YNFq26+0FbcWrUJstSpqrSIoLiiKGxIUWcNOCGuA7Ps6mZn7/P64ySSBAIFMMkk479crL8jMvXOf3Exmzjz3POdoSimFEEIIIYQQ4rR0fw9ACCGEEEKIlkACZyGEEEIIIepBAmchhBBCCCHqQQJnIYQQQggh6kECZyGEEEIIIepBAmchhBBCCCHqwdrQB8jOzubll18mPz8fTdMYP348V199da1tdu7cyTPPPENkZCQAI0eO5Oabb27ooYUQQgghhGgyDQ6cLRYL06ZNo2fPnpSVlTFv3jyGDBlCTExMre0GDBjAvHnzGno4IYQQQggh/KLBqRrt27enZ8+eAAQGBtK5c2dyc3MbPDAhhBBCCCGakwbPONeUmZnJwYMH6d2790n3JScnM3fuXNq3b8+0adPo0qWLLw8thBBCCCFEo9J81XK7vLycP/3pT0yZMoWRI0fWuq+0tBRd1wkICGDz5s288cYbvPjii3U+zurVq1m9ejUACxYs8MXQhBBCCCGEaDCfBM5ut5unn36auLg4rr322jNuf//99/PUU08RGhp6xm2PHz/e0OEJICIiguzsbH8Po9WQ8+lbcj59R86lb8n59C05n74j59K3oqOj67Vdg3OclVIkJCTQuXPnUwbN+fn5VMXnKSkpGIZBSEhIQw8thBBCCCFEk2lwjvPevXtZs2YNXbt2Ze7cuQDcdttt3k9BV155JT/99BNffvklFosFu93O7Nmz0TStoYcWQgghhBCiyTQ4cO7fvz/vv//+abe56qqruOqqqxp6KCGEEEIIIfzGp1U1hBBCCCFaAqUU5eXlGIbRIq+CZ2Rk4HQ6/T2MFkUp5S1Wca6/cwmchRBCCHHeKS8vx2azYbW2zFDIarVisVj8PYwWx+12U15eTmBg4Dnt3+DFgUIIIYQQLY1hGC02aBbnzmq1YhjGOe8vgbMQQgghzjstMT1D+EZDfvfyUUsIIYQQwg+6dOlC//79cbvdWCwWbr75Zu699150/dTzmqmpqWzcuJGpU6c24UhFFZlxFkIIIYTwg4CAAL766iu+/fZb/ve///Htt9/y97///bT7pKam8uGHHzbRCMWJJHAWQgghhPCziIgInnnmGV5//XWUUqSmpnLjjTcyceJEJk6cyIYNGwD429/+xs8//8zYsWP517/+dcrtROOQVA0hhBBCnNeiO3dulMc9fuzYWW3frVs3DMMgOzubiIgI3n33XQICAjhw4AD3338/n3/+OY899hgJCQn897//xe12U1ZWVud2onFI4CyEEEII0cy4XC7+8Ic/sGvXLnRd58CBAw3aTviGBM5CCCGEOK+d7cxwYzl8+DC6rhMREcHf//53OnTowFdffYVhGPTs2bPOff7973/XazvhG5LjLIQQQgjhZzk5OcybN49f//rXaJpGYWEhkZGR6LrOsmXL8Hg8AAQHB1NSUuLd71TbicYhM85CCCGEEH5QXl7OhAkTTipHB3DHHXdw77338sEHH3DFFVcQFBQEwIABA9B1nSuuuIKpU6eecjvRODSllPL3IE7n+PHj/h5CqxAREUF2dra/h9FqyPn0LTmfviPn0rfkfPpWczqfpaWlLTrItFqtuN1ufw+jRarrdx8dHV2vfSVVQwghhBBCiHqQwFkIIYQQQoh6kMBZCCGEEEKIepDAWQghhBBCiHqQwFkIIYQQQoh6kMBZCCGEEEKIepDAWQghhBDCD/r06XPSbUuWLGHp0qUA3HzzzSQlJdXrsVJTUxk7diwASUlJPPHEEwA8//zzJCQk+GjE1Xz1uOnp6fzmN7/xwYiahjRAEUIIIcR5b+tWK7m5vptPDAszGDr07OssT58+vcHHjouLIy4ursGP0xSioqL497//7e9h1JvMOAshhBDivJebq+N2az77OtcgvK6ZXMMwmD17Nk8//TQej4f58+czceJExo8fz1tvvXXSY6xbt65WAJ6cnMzNN9/MJZdcwmuvvea9/ZVXXmHs2LGMHTu2VvB6qttfeOEFRo8ezQ033MD+/fvrHP/s2bN54oknuP7667nkkkv49NNPAVBKMX/+fMaOHcu4ceNYsWIFUHumfO/evVxzzTVMmDCB8ePHc+DAAQCWLVvmvf2RRx7xa1txmXEWQgghhGim3G43DzzwAP369eOhhx7i7bffJiQkhFWr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\n",
      "text/plain": [
       "<Figure size 864x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot(model=vsgp_d, plot_observed_data=True, plot_predictions=True)\n",
    "plt.ylim(-2, 2.5)\n",
    "None"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Extend the VariationalGP class"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Diag matrix with multiple sigmas"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [],
   "source": [
    "class VGP_diag1(VariationalGP):\n",
    "    @pyro_method\n",
    "    def guide(self):\n",
    "        self.set_mode(\"guide\")\n",
    "        self._load_pyro_samples()\n",
    "\n",
    "        # Diagonal matrix w/ multiple sigmas\n",
    "        scale_diag = torch.diag(self.f_scale_tril.diag())\n",
    "        pyro.sample(self._pyro_get_fullname(\"f\"),\n",
    "                dist.MultivariateNormal(self.f_loc, scale_tril=scale_diag).to_event(self.f_loc.dim()-1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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6t+/vyIjI5Wdna2JEyfqp59+UpkyZTRw4EBVqlTJ6/hBYd++fZoyZYo2b94sY4zuuOMOJSYmciyegoULF2rRokUyxqh69erq27evdu/ezbF4EpMnT9by5ctVrlw5jRkzRpJO67+Dixcv1ltvvSVJuvLKK9WhQwevvlKRO9YYzpo1S8uWLVNkZKQqV66svn37qnTp0pKkuXPnatGiRXIcRzfffLOaNGkiKbx/fx9rDP+wYMECzZo1S9OmTVPZsmU5Dk+XxVFyc3PtnXfeabdv326zs7Ptvffeazdv3ux1rKCUkZFhN27caK21dv/+/XbAgAF28+bNdtasWXbu3LnWWmvnzp1rZ82aZa21dtmyZXbEiBHWdV27bt06+8ADD3gVPegsWLDAjh8/3o4aNcpaa+2YMWPs559/bq21durUqfb999+31lr73nvv2alTp1prrf3888/t2LFjvQkchJ577jmbnJxsrbU2OzvbZmVlcSyegvT0dNu3b1976NAha63vGPz44485FgtgzZo1duPGjXbQoEF520712MvMzLT9+vWzmZmZ+X4OF8caw5UrV9qcnBxrrW88/xjDzZs323vvvdcePnzY7tixw9555502Nzc37H9/H2sMrbV2586d9oknnrB33HGH3bNnj7WW4/B0MVXjGDZs2KAqVaqocuXKioyMVNu2bZWSkuJ1rKBUoUKFvD+hlipVStWqVVNGRoZSUlLUvn17SVL79u3zxm/p0qW64IILZIxRvXr1tG/fPu3atcuz/MEiPT1dy5cvV+fOnSVJ1lqtWbNGrVu3liR16NAh3xj+8af/1q1ba/Xq1bJcqqD9+/fr+++/V6dOnSRJkZGRKl26NMfiKXJdV4cPH1Zubq4OHz6s8uXLcywWQP369RUbG5tv26keeytXrlSjRo0UGxur2NhYNWrUSCtXrizqr+KZY41h48aNFRERIUmqV6+eMjIyJPnGtm3btoqKilKlSpVUpUoVbdiwIex/fx9rDCXphRde0A033CBjTN42jsPTw1SNY8jIyFB8fHze4/j4eK1fv97DRMVDamqqNm3apDp16mjPnj2qUKGCJKl8+fLas2ePJN/YJiQk5L0mPj5eGRkZefuGq5kzZ6pnz546cOCAJCkzM1MxMTF5vzDi4uLyfmEceXxGREQoJiZGmZmZKlu2rDfhg0RqaqrKli2ryZMn65dfflGtWrXUq1cvjsVTEBcXp0svvVR33HGHSpQoocaNG6tWrVoci6fpVI+9v/7uOXKsIS1atEht27aV5BvDunXr5j135Fjx+zu/lJQUxcXF6ayzzsq3nePw9HDGGQFx8OBBjRkzRr169VJMTEy+54wx+f6Ui/yWLVumcuXKMb/WT7m5udq0aZMuvPBCPfXUU4qOjta8efPy7cOxeGJZWVlKSUnRpEmTNHXqVB08eJAzTQHCseeft956SxEREWrXrp3XUYqVQ4cOae7cubruuuu8jhIyKM7HEBcXp/T09LzH6enpiouL8zBRcMvJydGYMWPUrl07tWrVSpJUrly5vL/23rVrV94ZqLi4OKWlpeW9lrGV1q1bp6VLl6pfv34aP368Vq9erZkzZ2r//v3Kzc2V5Dsz8Mc4HXl85ubmav/+/SpTpoxn+YNFfHy84uPj885CtW7dWps2beJYPAXfffedKlWqpLJlyyoyMlKtWrXSunXrOBZP06kee3/93XPkWIezxYsXa9myZRowYEDeHz6ON1b8/s5vx44dSk1N1X333ad+/fopPT1dgwcP1u7duzkOTxPF+Rhq166tbdu2KTU1VTk5OVqyZIlatGjhdaygZK3VlClTVK1aNV1yySV521u0aKFPPvlEkvTJJ5+oZcuWeds//fRTWWv1448/KiYmJqz/alySevTooSlTpmjSpEkaOHCgGjZsqAEDBqhBgwb66quvJPl+cfxxDDZv3lyLFy+WJH311Vdq0KABZ7Lk+6vw+Ph4bd26VZKvBJ5xxhkci6cgISFB69ev16FDh2StzRtDjsXTc6rHXpMmTbRq1SplZWUpKytLq1atylspIlytXLlS8+fP1+DBgxUdHZ23vUWLFlqyZImys7OVmpqqbdu2qU6dOvz+/osaNWpo2rRpmjRpkiZNmqT4+Hg9+eSTKl++PMfhaeIGKMexfPlyvfDCC3JdVx07dtSVV17pdaSg9MMPP+jhhx9WjRo18n5hXn/99apbt67GjRuntLS0o5Zhmj59ulatWqUSJUqob9++ql27tsffInisWbNGCxYs0JAhQ7Rjxw6NHz9eWVlZqlmzpvr376+oqCgdPnxYEydO1KZNmxQbG6uBAweqcuXKXkcPCj///LOmTJminJwcVapUSX379pW1lmPxFMyePVtLlixRRESEzjrrLN1+++3KyMjgWDyJ8ePHa+3atcrMzFS5cuV07bXXqmXLlqd87C1atEhz586V5FsGrGPHjl5+rSJ1rDGcO3eucnJy8i54q1u3rvr06SPJN33j448/luM46tWrl5o2bSopvH9/H2sM/7hgWpL69eunUaNG5S1Hx3F46ijOAAAAQAEwVQMAAAAoAIozAAAAUAAUZwAAAKAAKM4AAABAAVCcAQAAgAKgOAMAAAAFQHEGAAAACoDiDAAAABTA/wMVJ50jwG6JZQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# initialize the kernel, likelihood, and model\n",
    "pyro.clear_param_store()\n",
    "kernel = gp.kernels.RBF(input_dim=1)\n",
    "likelihood = gp.likelihoods.Gaussian()\n",
    "vsgp_diag1 = VGP_diag1(X_train_tensor.view(-1,), y_train_tensor.view(-1,), kernel, \n",
    "                     likelihood=likelihood, whiten=True)\n",
    "\n",
    "# instead of defining our own training loop, we will\n",
    "# use the built-in support provided by the GP module\n",
    "num_steps = 1500\n",
    "losses = gp.util.train(vsgp_diag1, num_steps=num_steps)  # default: loss_fn=TraceMeanField_ELBO().differentiable_loss\n",
    "plt.plot(losses);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot(model=vsgp_diag1, plot_observed_data=True, plot_predictions=True)\n",
    "plt.ylim(-2, 2.5)\n",
    "None"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Diag matrix with single sigma"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [],
   "source": [
    "class VGP_diag2(VariationalGP):\n",
    "    @pyro_method\n",
    "    def guide(self):\n",
    "        self.set_mode(\"guide\")\n",
    "        self._load_pyro_samples()\n",
    "\n",
    "        # Diagonal matriax w/ single sigma\n",
    "        mean_sigma = torch.mean(torch.diag(self.f_scale_tril.diag()))\n",
    "        scale_diag = eye_like(self.f_scale_tril, self.f_scale_tril.shape[0]) * mean_sigma\n",
    "        pyro.sample(self._pyro_get_fullname(\"f\"),\n",
    "                dist.MultivariateNormal(self.f_loc, scale_tril=scale_diag).to_event(self.f_loc.dim()-1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAs4AAAHSCAYAAAD8EE1RAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAABFsklEQVR4nO3deXhUVYL+8ffcJARCyFJZCLsCIqKsBkWUrYkboiIq7vu0rdgy6tjT2tPLzNi22DMI7Yij/cNGRduWVsCl2y0ioNKOQRYbaEUQBWQJSYWQsCf3/P64GEBBK1Qlp1L5fp7Hx6pb21vH+5g3N+eea6y1VgAAAAC+k+c6AAAAANAUUJwBAACACFCcAQAAgAhQnAEAAIAIUJwBAACACFCcAQAAgAhQnAEAAIAIJLsOEKmNGzc6+dzc3FyVlZU5+exEwRhGjzGMDcYxeoxh9BjD6DGG0WMMj6x9+/ZHfIwjzgAAAEAEKM4AAABABCjOAAAAQAQozgAAAEAEKM4AAABABCjOAAAAQAQozgAAAEAEKM4AAABABCjOAAAAQAQozgAAAEAEIr7kdllZmaZOnapt27bJGKOioiKNGjVK1dXVmjx5srZu3aq8vDzdeeedSk9Pl7VW06dP15IlS5Samqrx48era9eukqR58+Zp1qxZkqSxY8dq+PDhDfLlAAAAgFiJuDgnJSXpmmuuUdeuXbVr1y7dc8896tOnj+bNm6fevXtrzJgxmjNnjubMmaOrr75aS5Ys0ebNm/Xwww/rs88+07Rp0/Sb3/xG1dXVeuGFFzRx4kRJ0j333KPCwkKlp6c32JcEAAAAohXxVI3s7Oy6I8atWrVShw4dFA6HVVJSomHDhkmShg0bppKSEknSokWLNHToUBlj1KNHD+3YsUMVFRVaunSp+vTpo/T0dKWnp6tPnz5aunRp7L8ZAAAAEENHNce5tLRUa9euVffu3VVZWans7GxJUlZWliorKyVJ4XBYubm5da/JyclROBxWOBxWTk5O3fZQKKRwOBzNdwAAAAAaXMRTNb62e/duTZo0Sddff73S0tIOecwYI2NMTIIVFxeruLhYkjRx4sRDSnhjSk5OdvbZiYIxjB5jGBuMY/QYw+gxhtFjDKPHGB6dehXnmpoaTZo0SUOGDNGpp54qScrMzFRFRYWys7NVUVGhjIwMScGR5LKysrrXlpeXKxQKKRQKaeXKlXXbw+GwevXq9a3PKioqUlFRUd39g9+rMeXm5jr77ETBGEaPMYwNxjF6jGH0GMPoMYbRYwyPrH379kd8LOKpGtZaPfbYY+rQoYNGjx5dt72wsFDz58+XJM2fP18DBw6s275gwQJZa7Vq1SqlpaUpOztb/fr107Jly1RdXa3q6motW7ZM/fr1O8qv1rDsvn3yKytcxwAAAEAciPiI86effqoFCxaoc+fO+slPfiJJuuKKKzRmzBhNnjxZc+fOrVuOTpL69++vxYsXa8KECWrRooXGjx8vSUpPT9fFF1+se++9V5J0ySWXxOWKGtZa+T/7oaoKT5cu+6HrOAAAAHDMWGut6xCR2LhxY6N/Zu3/PiBv/efS/b+P2dzt5og/B0WPMYwNxjF6jGH0GMPoMYbRYwyPLCZTNZoj07Ov/K1bpK2bXEcBAACAYxTn72BO6CtJsiuXOU4CAAAA1yjO36Vte3m5bWX/QXEGAABo7ijO38EYoxZ9B0r/WCZbs891HAAAADhEcf4eqacMkXbtkFYtdx0FAAAADlGcv0dq31OkFqmyS/7PdRQAAAA4RHH+HiY1VTppgOzSD2R933UcAAAAOEJxjoAZMFjaFpY+W/n9TwYAAEBCojhHwPQbJLVsJbvwbddRAAAA4AjFOQImNVVm4BDZj96X3b3LdRwAAAA4QHGOkBk8UtqzW/bD+a6jAAAAwAGKc6S69ZQ6d5MtfkXWWtdpAAAA0MgozhEyxsiceYG0ab20YrHrOAAAAGhkFOd6MIVnSJkh+W/OcR0FAAAAjYziXA8mOUWm6PzgEtyrWZoOAACgOaE415MZcZ6UmS1/9gzmOgMAADQjFOd6MqktZc4bJ61aIa1c6joOAAAAGgnF+SiYIWdJOfkcdQYAAGhGKM5HwSSnyJx/hfTlamnJ31zHAQAAQCOgOB8lM2i4VNBB/pxnZf1a13EAAADQwCjOR8kkJclccJW0ab3shwtcxwEAAEADozhHwZw8WOp4rOzLz8nW1LiOAwAAgAZEcY6C8Tx5Y66Wtm6WXVjsOg4AAAAaEMU5Wn0KpW49ZV+dKbtvr+s0AAAAaCAU5ygZY4KjzhVlsvNfcx0HAAAADYTiHAOmZx/phL6yf31Bdvcu13EAAADQACjOMeKNuVqqqpR9+xXXUQAAANAAKM4xYroeL/U9RfaN2bI7qlzHAQAAQIxRnGPIG3OVtHun7OuzXEcBAABAjFGcY8h0PFbmlKGyc1+RrSh3HQcAAAAxRHGOMXPhVZLvy778R9dRAAAAEEMU5xgzeQUyw0fJvv+27MZ1ruMAAAAgRijODcCMGie1bCl/1tOuowAAACBGKM4NwLTJkDl7rLTsQ9nPVrqOAwAAgBigODcQU3ShlBWS/+KTsta6jgMAAIAoUZwbiElNlbngSmnNJ9KSD1zHAQAAQJQozg3IDB4pFXSUP/tp2dpa13EAAAAQBYpzAzJJSfIuvlba/JXs+2+5jgMAAIAoUJwbWt9Tpe4nyL78nOye3a7TAAAA4ChRnBuYMUbexddLlRWyxS+7jgMAAICjRHFuBKb7CVK/QbKvvyhbVek6DgAAAI4CxbmReGOvlfbskf3LTNdRAAAAcBQozo3EtOsoc0aR7LzXZLdudh0HAAAA9URxbkTmgiukJE92zjOuowAAAKCeKM6NyGTlyBSNkf1wgeyXa1zHAQAAQD1QnBuZOWeslN5G/otPuo4CAACAeqA4NzLTKk3mvMukfyyTXbHEdRwAAABEiOLsgBl2rpTbVv6LT8r6vus4AAAAiADF2QGTkiIz5mpp/VrZDxe4jgMAAIAIUJwdMQOHSJ27yc55RnbfPtdxAAAA8D0ozo4Yz5N38bVSeansgtddxwEAAMD3oDg7ZHr1l07oK/vq87K7drqOAwAAgO9AcXbMu/g6qXq77JuzXUcBAADAd6A4O2a6dJcZOET2zTmylRWu4wAAAOAIKM5xwIy5SqqtkX31eddRAAAAcAQU5zhg8tvLDDlb9t03ZLdsdB0HAAAAh0FxjhNm9GVScorsnGdcRwEAAMBhUJzjhMnMljlzjOyi92S/+Mx1HAAAAHwDxTmOmLPGSOkZ8l98StZa13EAAABwEIpzHDGt0oIpG598LK1c6joOAAAADkJxjjNm6DlSTr78WU/J+r7rOAAAANiP4hxnTEqKzJirpXWfy5a86zoOAAAA9qM4xyFzylCp47Gyc56RrdnnOg4AAABEcY5LxvPkXXytVLZFdv4bruMAAABAFOf4deIA6fjesq/+SXbnDtdpAAAAmj2Kc5wyxsi79Aapervs6y+6jgMAANDsUZzjmOnSXebUYbLFL8uGt7qOAwAA0KxRnOOcuegayVrZOc+6jgIAANCsUZzjnMnJlxk5WvaDd2TXfe46DgAAQLOVHOkTH330US1evFiZmZmaNGmSJGnmzJl6++23lZGRIUm64oorNGDAAEnS7NmzNXfuXHmepxtuuEH9+vWTJC1dulTTp0+X7/saOXKkxowZE9tvlIDMqEtl3yuW/8J0eXf+p4wxriMBAAA0OxEX5+HDh+ucc87R1KlTD9l+3nnn6YILLjhk24YNG7Rw4UI99NBDqqio0H333aff/e53kqQnnnhCP//5z5WTk6N7771XhYWF6tixYwy+SuIyaekyoy+TfX6atGKxdNLJriMBAAA0OxFP1ejVq5fS09Mjem5JSYkGDx6slJQU5efnq6CgQKtXr9bq1atVUFCgtm3bKjk5WYMHD1ZJSclRh29OzPBzpbwC+S88KevXuo4DAADQ7EQ9x/mNN97Q3XffrUcffVTV1dWSpHA4rJycnLrnhEIhhcPhb23PyclROByONkKzYJJT5I29VvrqS9n333YdBwAAoNmJeKrG4Zx11lm65JJLJEnPP/+8nn76aY0fPz4mwYqLi1VcXCxJmjhxonJzc2PyvvWVnJzs7LO/yZ59oSre+YtqX/mTcs69SKZlK9eRIhJPY9hUMYaxwThGjzGMHmMYPcYweozh0YmqOGdlZdXdHjlypB588EFJwRHm8vLyusfC4bBCoZAkHbK9vLy8bvs3FRUVqaioqO5+WVlZNFGPWm5urrPPPhx70TXyH7xHW//0hLzRl7uOE5F4G8OmiDGMDcYxeoxh9BjD6DGG0WMMj6x9+/ZHfCyqqRoVFRV1tz/88EN16tRJklRYWKiFCxdq3759Ki0t1aZNm9S9e3d169ZNmzZtUmlpqWpqarRw4UIVFhZGE6HZMd17SQNOk319tuz2iu9/AQAAAGIi4iPOU6ZM0cqVK1VVVaVbbrlF48aN04oVK/TFF1/IGKO8vDzdfPPNkqROnTrptNNO01133SXP83TTTTfJ84KOfuONN+r++++X7/saMWJEXdlG5Lyx18lf9qHsy8/JXB2bqTEAAAD4bsZaa12HiMTGjRudfG68/inD/+PjsvNfk/fv/yPTLr5/+YjXMWxKGMPYYByjxxhGjzGMHmMYPcbwyBpsqgbcMedfLqW2lP/iU66jAAAANAsU5ybKtMmUOfcSadmHsp8udx0HAAAg4VGcmzAz8nwplCv/z3+Q9X3XcQAAABIaxbkJMy1SZS68WvpytWzJu67jAAAAJDSKcxNnBg2XOh0rO3uG7L69ruMAAAAkLIpzE2c8T96lN0rlpbJz/+I6DgAAQMKiOCcAc0Jf6aSTZf86U3ZHles4AAAACYninCC8S66Xdu2SfXWm6ygAAAAJieKcIEyHLjKnj5R95y+ypZtcxwEAAEg4FOcEYi68UkpKkp09w3UUAACAhENxTiAmK0fmrItkF70nu+YT13EAAAASCsU5wZizL5IysuS/8KSsta7jAAAAJAyKc4IxLVsFUzZWr5SWfOA6DgAAQMKgOCcgc/qZUrtO8l98SramxnUcAACAhEBxTkAmKSlYnq50o+yC113HAQAASAgU50TVu1Dq2Uf2ledkd+5wnQYAAKDJozgnKGOMvEtukKqrZF97wXUcAACAJo/inMBMl24yg0bIFr8sW77VdRwAAIAmjeKc4MyYqyVjZOdwURQAAIBoUJwTnMnJkyk6X/aDebJfrnEdBwAAoMmiODcD5pxLpPQM+X/+AxdFAQAAOEoU52bApLWWOf9y6dO/Sx8vch0HAACgSaI4NxNm6DlSfnv5Lz4pW1vrOg4AAECTQ3FuJkxycnBRlE3rZd97y3UcAACAJofi3Jz0O1Xq3kv2pWdld+90nQYAAKBJoTg3I8YYeZfeIFVVyr4x23UcAACAJoXi3MyYrsfLDBwi++Zs2Ypy13EAAACaDIpzM2QuukbyfdmXnnUdBQAAoMmgODdDJq9A5gejZRe+Lbthres4AAAATQLFuZkyo8ZJrVrL//OTrqMAAAA0CRTnZsq0TpcZfZm0cons8sWu4wAAAMQ9inMzZoaPkvIK5L8wXdbnoigAAADfheLcjJmUFJmLrpW++lJ24VzXcQAAAOIaxbmZM4WnS8f2CC6Ksme36zgAAABxi+LczBlj5I27UdoWln1rjus4AAAAcYviDJnuvaQBp8m+Pku2ssJ1HAAAgLhEcYYkyRt7nVSzT/bl51xHAQAAiEsUZ0iSTNv2MsPOlX33TdmN61zHAQAAiDsUZ9Qxoy+XWraU/+JTrqMAAADEHYoz6pg2GTKjLpU+LpH9xzLXcQAAAOIKxRmHMCPPl0J5+y+K4ruOAwAAEDcozjiESWkhc9E10rrPZT+c7zoOAABA3KA441vMKUOlzt1kZ8+Q3bvHdRwAAIC4QHHGtxjPk3fpDVK4TPbtV13HAQAAiAsUZxyW6dlH6nuK7Gt/lq2qdB0HAADAOYozjsi7+Dppz27ZV/7kOgoAAIBzFGcckWnXSWbIWbILXpfd/JXrOAAAAE5RnPGdzAVXSMkt5M/ioigAAKB5ozjjO5mMbJlzxkpLPpBdtcJ1HAAAAGcozvhe5swxUlYouCiKta7jAAAAOEFxxvcyqakyY66W1q6SXfSe6zgAAABOUJwREXPaCKnjMbKznpbdt891HAAAgEZHcUZEjJcUXBSlbIvsO39xHQcAAKDRUZwRMdOrv3Rif9m/PC+7o8p1HAAAgEZFcUa9eJfcIO3aJfuXma6jAAAANCqKM+rFdDxGZvAPZOf+RXbrZtdxAAAAGg3FGfVmLrxKSkqSnfW06ygAAACNhuKMejPZOTJnXSS76D3ZNZ+4jgMAANAoKM44Kubsi6SMLC6KAgAAmg2KM46KadlK5sIrpdX/kJZ84DoOAABAg6M446iZ08+U2nWS/+KTsjVcFAUAACQ2ijOOmklKknfJ9VLpJtn5b7iOAwAA0KAozohO70KpZx/ZV5+T3bnDdRoAAIAGQ3FGVIwxwUVRqqtkX3vBdRwAAIAGQ3FG1EyXbjKDRsgWvyxbXuo6DgAAQIOgOCMmzEVXS8ZwURQAAJCwKM6ICRPKkzlrjOyHC2Q/W+k6DgAAQMxRnBEz5txLpOxc+X/6vaxf6zoOAABATFGcETMmtaXMJddL6z6Xfe8t13EAAABiKjnSJz766KNavHixMjMzNWnSJElSdXW1Jk+erK1btyovL0933nmn0tPTZa3V9OnTtWTJEqWmpmr8+PHq2rWrJGnevHmaNWuWJGns2LEaPnx47L8VnDEDh8jO+6vs7GdkTz5DpnW660gAAAAxEfER5+HDh+tnP/vZIdvmzJmj3r176+GHH1bv3r01Z84cSdKSJUu0efNmPfzww7r55ps1bdo0SUHRfuGFF/Sb3/xGv/nNb/TCCy+ouro6dt8Gzhlj5F1+s7SjWvaV51zHAQAAiJmIi3OvXr2Unn7o0cOSkhINGzZMkjRs2DCVlJRIkhYtWqShQ4fKGKMePXpox44dqqio0NKlS9WnTx+lp6crPT1dffr00dKlS2P3bRAXTOeuMkPOkn3nL7JfrXMdBwAAICaimuNcWVmp7OxsSVJWVpYqKyslSeFwWLm5uXXPy8nJUTgcVjgcVk5OTt32UCikcDgcTQTEKTPmaqllK/nP/z9Za13HAQAAiFrEc5y/jzFGxphYvZ2Ki4tVXFwsSZo4ceIhRbwxJScnO/vsJi03VzuvvFlV0yarZtH7yh14hutETRr7YWwwjtFjDKPHGEaPMYweY3h0oirOmZmZqqioUHZ2tioqKpSRkSEpOJJcVlZW97zy8nKFQiGFQiGtXHlgjd9wOKxevXod9r2LiopUVFRUd//g92tMubm5zj67qbOFQ6W/vqjKJ6bIduwqk9LCdaQmi/0wNhjH6DGG0WMMo8cYRo8xPLL27dsf8bGopmoUFhZq/vz5kqT58+dr4MCBddsXLFgga61WrVqltLQ0ZWdnq1+/flq2bJmqq6tVXV2tZcuWqV+/ftFEQBwzSUnyLv+hardslH1zjus4AAAAUYn4iPOUKVO0cuVKVVVV6ZZbbtG4ceM0ZswYTZ48WXPnzq1bjk6S+vfvr8WLF2vChAlq0aKFxo8fL0lKT0/XxRdfrHvvvVeSdMkll3zrhEMkFnNCX6UOGq49f/2z7Gk/kAnxZyEAANA0GdtEztzauHGjk8/lTxnRy67dq7IfXyEz4DR5P7zbdZwmif0wNhjH6DGG0WMMo8cYRo8xPLIGm6oBRCKpbXuZsy+S/XCB7Gcrv/8FAAAAcYjijEZhzr1Eys6V/9zjsn6t6zgAAAD1RnFGozCpLWUuvUFav1Z2wRuu4wAAANQbxRmNxhSeIR3fW3b2M7JVla7jAAAA1AvFGY3GGCPvih9Je3bJznradRwAAIB6oTijUZkOnWVGXiD73luyaz5xHQcAACBiFGc0OnP+ZVJWSP4fOVEQAAA0HRRnNDrTMk3m0huldWs4URAAADQZFGc4YQYO2X+i4AxOFAQAAE0CxRlOGGPkXfkjac9uThQEAABNAsUZzpj2nWWKOFEQAAA0DRRnOGVGc6IgAABoGijOcMq0TJMZdxMnCgIAgLhHcYZzpvAMqWcfThQEAABxjeIM5w45UfDFp1zHAQAAOCyKM+KCadcpOFHw/WJOFAQAAHGJ4oy4EZwomCP/j49xoiAAAIg7FGfEjQMnCn4uO58TBQEAQHyhOCOumMLTpRP6BicKVla4jgMAAFCH4oy4EpwoeIu0b4/s89NcxwEAAKhDcUbcMQUdZEaNky15V/bvH7mOAwAAIInijDhlzrlYKugo/9n/ld2z23UcAAAAijPik0lJkXfNbVJ5qewrz7mOAwAAQHFG/DI9TpQZcpbsWy/Jrl/rOg4AAGjmKM6Ia+bi66TWbeTPmMrazgAAwCmKM+Kaad1G5rJ/ktaukp33mus4AACgGaM4I+6ZU4ZKvfoHaztXlLuOAwAAmimKM+KeMUbeVbdItbXy//R713EAAEAzRXFGk2Dy28mcf7m0+G+yS//PdRwAANAMUZzRZJgzx0gdusj/4+Oyu3e6jgMAAJoZijOaDJOcHKztvK1c9qU/uo4DAACaGYozmhTTrafMsHNk335V9svVruMAAIBmhOKMJsdcdK2UkSn/6Udka1nbGQAANA6KM5ock9Za3uU/lNZ9Ljv3VddxAABAM0FxRtN08ulS70LZl56VLd/qOg0AAGgGKM5okurWdrZW/h8fk7XWdSQAAJDgKM5oskxOvsyFV0ofl0iL/+Y6DgAASHAUZzRpZuQFUueu8p/7vezOHa7jAACABEZxRpNmkpKCtZ23b5OdPcN1HAAAkMAozmjyzDHHyfzgPNn5r8mu+cR1HAAAkKAozkgIZsxVUlaO/BlTZWtqXMcBAAAJiOKMhGBapsm78mbpqy9l33rJdRwAAJCAKM5IGKbfIKn/INlXnpPdvMF1HAAAkGAozkgo3pW3SCkt5D/5sKzP5bgBAEDsUJyRUExWSOaKH0prPpEtftl1HAAAkEAozkg45tThUt9TZOc8y5QNAAAQMxRnJBxjjLyrxzNlAwAAxBTFGQkpmLJxM1M2AABAzFCckbDMqcOYsgEAAGKG4oyExZQNAAAQSxRnJDSmbAAAgFihOCPhmVOHSf1OZcoGAACICsUZCY8pGwAAIBYozmgWTGb2gSkbbzFlAwAA1B/FGc3GgSkbz8huYsoGAACoH4ozmo26KRupLeU/xZQNAABQPxRnNCtM2QAAAEeL4oxmx5wylCkbAACg3ijOaHYOmbLx5O+YsgEAACJCcUazVDdl4/NPmbIBAAAiQnFGsxVM2RjElA0AABARijOarWDKxq1M2QAAABGhOKNZO3TKxkuu4wAAgDhGcUazd2DKxrNM2QAAAEdEcUazx5QNAAAQCYozIKZsAACA70dxBvYzpwyV+n89ZWO96zgAACDOUJyB/Ywx8q7aP2VjOlM2AADAoSjOwEHqpmysXcWUDQAAcIjkWLzJbbfdppYtW8rzPCUlJWnixImqrq7W5MmTtXXrVuXl5enOO+9Uenq6rLWaPn26lixZotTUVI0fP15du3aNRQwgJswpQ2U/ej+YstFnoEy7Tq4jAQCAOBCzI86/+tWv9F//9V+aOHGiJGnOnDnq3bu3Hn74YfXu3Vtz5syRJC1ZskSbN2/Www8/rJtvvlnTpk2LVQQgJg5ZZWP672RrmbIBAAAacKpGSUmJhg0bJkkaNmyYSkpKJEmLFi3S0KFDZYxRjx49tGPHDlVUVDRUDOComIxsmSt/FEzZeHO26zgAACAOxGSqhiTdf//9kqQzzzxTRUVFqqysVHZ2tiQpKytLlZWVkqRwOKzc3Ny61+Xk5CgcDtc992vFxcUqLi6WJE2cOPGQ1zSm5ORkZ5+dKJrqGNpzL1Ll8o+05+U/KmvomUru0s1ZlqY6hvGGcYweYxg9xjB6jGH0GMOjE5PifN999ykUCqmyslK//vWv1b59+0MeN8bIGFOv9ywqKlJRUVHd/bKyslhErbfc3Fxnn50omvIY2ktvlJYvVvmU/5R3z29lkpKc5GjKYxhPGMfoMYbRYwyjxxhGjzE8sm/22IPFZKpGKBSSJGVmZmrgwIFavXq1MjMz66ZgVFRUKCMjo+65B/+HKi8vr3s9EG9Mm0yZK34kffGZ7Osvuo4DAAAciro47969W7t27aq7/fHHH6tz584qLCzU/PnzJUnz58/XwIEDJUmFhYVasGCBrLVatWqV0tLSvjVNA4gnpvB0mYFDZF95TnbtZ67jAAAAR6KeqlFZWan//u//liTV1tbqjDPOUL9+/dStWzdNnjxZc+fOrVuOTpL69++vxYsXa8KECWrRooXGjx8fbQSgQRljpKtulV3zD/nTJsn7xWSZlq1cxwIAAI3MWGut6xCR2Lhxo5PPZQ5Q9BJlDO2ny+VP+jeZM86Ud+2PG/WzE2UMXWMco8cYRo8xjB5jGD3G8MgafI4z0ByY40+SOXus7Ltvyn5c4joOAABoZBRnoB7MBVdKHY+R/9T/yG7f5joOAABoRBRnoB5MSoq8m+6Sdu4Iriro+64jAQCARkJxBurJdDxGZtyN0vKPZN9+xXUcAADQSCjOwFEww0dJ/QbJvviU7Ia1ruMAAIBGQHEGjoIxJlhZI621/D9Mka2pcR0JAAA0MIozcJRMmwx519wmrV8rO3uG6zgAAKCBUZyBKJj+g2SGj5J9c7bs4r+5jgMAABoQxRmIkhl3k9Slu/wnfye7dbPrOAAAoIFQnIEomZQUebf8VJKC9Z2bxsU4AQBAPVGcgRgwuW1lLrle+vTvsvNfcx0HAAA0AIozECNmyNlSr/6yM//AEnUAACQgijMQI8YYeTfdESxR9/hvZXfvch0JAADEEMUZiCGTkS3vn/5F2rJJ9tnHmO8MAEACoTgDMWZ69pEZfZnsB+/ILpzrOg4AAIgRijPQAMzocdLxvWX/+Jjs5g2u4wAAgBigOAMNwHhJ8m66S2rRQv6jD8ju2uk6EgAAiBLFGWggJjtH3s3/Km35Sv60SbJ+retIAAAgChRnoAGZE/rKXP5D6eMS2eKXXccBAABRoDgDDcwMHyX1O1V29jOyG9e5jgMAAI4SxRloYMYYedeMl1q2lP/EQ7J797iOBAAAjgLFGWgEJiNb3vX/LK37XHbGo6zvDABAE0RxBhqJ6XuKzAVXBus7v818ZwAAmhqKM9CIzHnjpP6DZP88XXbVctdxAABAPVCcgUZkPE/ejXdIuW3lPzFZducO15EAAECEKM5AIzMt0+TdeKe0rVz+HyazvjMAAE0ExRlwwHTrGazvvOxD2Zl/cB0HAABEINl1AKC58kacJ3/rZtm3XpJf0EHe8FGuIwEAgO/AEWfAIXPJDdJJJ8vO/AMXRwEAIM5RnAGHjOfJu2GC1LKV/GmTZPftdR0JAAAcAcUZcMxkZMu7boK0fm1QnjlZEACAuERxBuKA6TtQ5rKbpMV/k/3j41xZEACAOMTJgUCc8IoulL+tQvaNWVLnbjJDz3YdCQAAHIQjzkAcMWOvlU7oK/v8NNnNG1zHAQAAB6E4A3EkOFnwDimlhfzHfyu7a6frSAAAYD+KMxBnTHaOvB/eLW1aL/9/H5Ct2ec6EgAAEMUZiEvmxP4y194u/WOZ7PTfyfq+60gAADR7FGcgTnmDfyAz9lrZDxdo56szXccBAKDZozgDccycc7HUZ6Cqn31Mds0nruMAANCsUZyBOGaMkXfd7UoK5cl/+D9lv1zjOhIAAM0WxRmIcyYjS9n/8bDUKk3+Qz+XXfe560gAADRLFGegCUjKbyfv7vul1FbyH5sou5tl6gAAaGwUZ6CJMLltg2Xqykq5LDcAAA5QnIEmxBzXS2b0ONm/vSM78w8sUwcAQCNKdh0AQP2Y0ZdLO3fIFr8k7dklXT1exuN3YAAAGhrFGWhijOdJl/2TlNpS9q9/lvLbBcvWAQCABsVhKqAJMsbIjLla5uTTZWfNkP10uetIAAAkPIoz0EQZY2Suu13Kbyf/97+V3brZdSQAABIaxRlowkyrNHm33ivV1sp/8B7ZDV+4jgQAQMKiOANNnOnQWd5PHpCM5P/Xz2Q3b3AdCQCAhERxBhKA6dBZ3r9OlDwjf9pDsjX7XEcCACDhUJyBBGHyCuRd82Ppy9WyTz0iW1vrOhIAAAmF4gwkEDPgNJkLr5L94B35j/xadheX5gYAIFYozkCC8UZfJnP1eGnlEvmTfi67j2kbAADEAsUZSEDesHPk/einwbSN2U+7jgMAQEKgOAMJygw4TWb4KNm3XpK/4A3XcQAAaPK45DaQwMy4m2TLtsjOmCq/qlJm1KUyxriOBQBAk8QRZyCBmZQUebf9TGbQcNk5z8g++7+y1rqOBQBAk8QRZyDBmeQU6cY7pcxs2TdmSx26yIw4z3UsAACaHIoz0AwYY6Sx18luXC/7/BOymdkyAwa7jgUAQJPCVA2gmTCeJ++mu6Qu3eQ/9qD8115g2gYAAPVAcQaaEdM6Xd5dv5YpPEN21tOyM6ZSngEAiBBTNYBmxqSmSj+8W8rNl33tRaltB5mzL3IdCwCAuEdxBpohY4w05hpp6xbZF5+Un50j75ShrmMBABDXmKoBNFPG82Ru+GepW0/Z//ff8l94Ura21nUsAADiFsUZaMZMi9RgzvOwc2TfmCX/8QdlfcozAACHQ3EGmjmTkiLv6vEy426Slnwg+9zvOWEQAIDDYI4zAEmSd+aF8rdvk339RallmnTRNTIev1sDAPA1Z8V56dKlmj59unzf18iRIzVmzBhXUQDsZ8ZeK+3cIfv6i7JffSnvn+6SSUt3HQsAgLjg5HCS7/t64okn9LOf/UyTJ0/W+++/rw0bNriIAuAgxhiZq2+VueoWaeVS+RN/Krut3HUsAADigpPivHr1ahUUFKht27ZKTk7W4MGDVVJS4iIKgG8wxsgbPkreHf8uhcvkT/q5bGWF61gAADjnpDiHw2Hl5OTU3c/JyVE4HHYRBcARmJ595E34pVRRHpTn8q2uIwEA4FTcnhxYXFys4uJiSdLEiROVm5vrJEdycrKzz04UjGH0nI1h7jDtzZikbQ/8q/TA3cq4Z6Ja9Ozd+DlihH0xeoxh9BjD6DGG0WMMj46T4hwKhVRefmDeZHl5uUKh0CHPKSoqUlFRUd39srKyRst3sNzcXGefnSgYw+g5HcOCTjL3/Fb+I79WxS9uk7n6Nnmnj3STJUrsi9FjDKPHGEaPMYweY3hk7du3P+JjTqZqdOvWTZs2bVJpaalqamq0cOFCFRYWuogCIAKmXSd5P/tv6bgTZZ/8nfw//4ELpQAAmh0nR5yTkpJ044036v7775fv+xoxYoQ6derkIgqACJnWbeRN+JXszGmyb86R3bRB3j/9i0xaa9fRAABoFM7mOA8YMEADBgxw9fEAjoJJTpa58hb5HY6Rfe5x+RP/Vd6P/00m/8h/1gIAIFFwWTAA9eYNO0fenf8pbd8m//67Zf+xzHUkAAAaHMUZwFExx/eW92+TpMxs+VN+Jf+tl2StdR0LAIAGQ3EGcNRMXoG8e/9L6nOK7MwnZH//X7K7d7qOBQBAg6A4A4iKaZUmb/y9MhdfJ/vRwmDqxsZ1rmMBABBzFGcAUTPGyDvnYnn/cp+0o0r+/f8if8EbTN0AACQUijOAmDHH95b3yylSt56yM6bKf/QB2artrmMBABATFGcAMWWycuTd8R8yl94g/X2R/P+YILtyqetYAABEjeIMIOaM58k766LgaoNpreVP/mVwtcF9+1xHAwDgqFGcATQY07mrvH97SGb4ubJvzpH/6ztl165yHQsAgKNCcQbQoExqqryrbpU34ZfSzh3yH/hX+TOfkN2zx3U0AADqheIMoFGY3oXy/uMRmSFnyb71kvz/uF32k49dxwIAIGIUZwCNxqS1lnfNeHl33y9J8if9XP60SbLbwo6TAQDw/SjOABqdOb63vF/9j8yocbIfvS//F7fKf3OObE2N62gAABwRxRmAEyY1Vd5FV8v790ek7r1k//wH+ffdIbtyietoAAAcFsUZgFOmbXt5E34p77Z/k/bukT/5V6qd/EvZdWtcRwMA4BDJrgMAgDFG6neqvBMHyM7/q+yrM+Xfd6fMKcNkxlwlk1fgOiIAABRnAPHDpKTIFF0oO3ik7OuzZItflv3ofZkhZ8qcc7FMTr7riACAZoziDCDumLR0mbHXyo44T/bVP8m++5bsu2/KnPYDmXMvlslv7zoiAKAZojgDiFsmO0fmmttkzxsXHIF+903Z99+WOXWozFkXyXQ61nVEAEAzQnEGEPdMKE/myh/JjrpU9s3ZsvNfl/1gnnR8b3lFF0h9CmW8JNcxAQAJjuIMoMkwWSGZcTfJnneZ7Htvys59Vf7U+6W8ApkfnBdM5WjdxnVMAECCojgDaHJM63SZs8fKFl0oLfmb/LdfkX3+CdkXn5YZcJrMGWdKx/eW8VhxEwAQOxRnAE2WSUqSCs9QUuEZsus+l33vLdn/myf74YLgKPTpRTKDhrMaBwAgJijOABKC6dw1mAd9yfWySz4ITiSc84zsnGekbj1lThmq2rMucB0TANCEUZwBJBTTIlXm1GHSqcNkt26WLXlX9sMFss/9XmXPTwumcAwcItP7ZJmsHNdxAQBNCMUZQMIyeQUyoy6VRl0q+9U6tVpeoh3z35B9+hFZScpvJ7VuI3PyYJlh58q0bOU6MgAgjlGcATQLpkNnpfcdoF1njZU2fCG7cons56ukyrDsC0/Kvj5LZvBIqeMxMu07y3Tp5joyACDOUJwBNCvGGKnTsYdcPMWu+UT+X2bKvv2KVFsTHI3u1lPemWOkE/tzJBoAIIniDAAy3XoqacIvZfftk8q3yK5YKvvmbPmPTZSSk6XjTpQJ5UmhXJkRo2XaZLiODABwgOIMAPuZlBSpoKNMQUfZYedIn62QXf6R7Ccfy27aEEzreOslmRGjZAYMljp3Y61oAGhGKM4AcBgmOVk6oa/MCX3rttmN6+S/9EfZ12fJvvailJktdTtBqq6U6TNQ5qyLgqkgAICERHEGgAiZ9p2VdOs9slWVsssXS8s+lP3qC8n3gxMMPy6RGTxSpmcfaUe1lJ3LtA4ASCAUZwCoJ9MmU+a0EdJpIyRJ1lrZuX+RLX5J9smHg5MLJSktXd51Pw6mdQAAmjyKMwBEyRgjM3K07IhR0sYvZT9dIRnJLpwr/38nSu06yfQfJHPcibIb18kcf5JMl+6uYwMA6oniDAAxYjxP6nisTMdgqTs79GzZd9+SXbxQ9vUXZf/652B7SguZq26ROWWolJQk1frBiYkAgLhGcQaABmKSU2RGjJJGjJLdUSWt+1xq2Ur+s48FUzqe+72UkiLt2SNzwx3yBp7hOjIA4DtQnAGgEZjWbaT9K3R4P/tv6ZOPZZf+n7R7p+xX62R//1vVzn9Npt+pMsd0l/1qnUyvfjJ5BY6TAwC+RnEGgEZmPE/q1U+mVz9Jkt29S7b4ZdkPF8g+P63u5EKbli7vhglSn4HS9kopPSNYJg8A4AT/BwYAx0zLVjKjL5NGXyZbukna+KWUnCL/+SfkT/2NlJwi1eyT2neW9+OfcxQaAByhOANAHDH57aT8dpIk7/je0sclsqs/kTxPdv5r8n8xXjq2R1Ck22TKu/52mYxsx6kBoHmgOANAnDIpLaSTT5c5+XRJkh05Wvadv8quWh6sxvHpx/L/fYJM4elSeoa0Z7fMuZfIpHPRFQBoCBRnAGgiTChP5uLr6u7bLz6T/8qfZBe+I+3dLRkju/hvMsPOkUJ5QZEeNDwo4ACAqFGcAaCJMsccp6TbfyHr10o1NdKXa+Q/P032xafqnmPnvy4z8nyZnPxgQ/eeMl6So8QA0LRRnAGgiTNektQiSTqul5J+/pDs9m3S9grZTRtkZz4h+4fJBy4D3rOPvLPGSGnpUut0mYKO7oIDQBNDcQaABGMysqSMLJmOx8oOGCxt3iBtC8tu/kr25WflP/yfB5580gB5Q86WWqVJHboErwUAHBbFGQASmElKkjp0CUrxif1lzzhT+mKVtHev7Lo1sm+/In/5A8GTk5KkPgNlCs+QyW0rdTxGpkWq2y8AAHGE4gwAzYhJTZWO7x3c7n2y7JkXSuvXSnv3yC5fLPu3ubJLPgimdmRkyQwcImXnyLTvLPXq7zQ7ALhGcQaAZsy0SJW69Qxun9BX9qJrgguwlG2R/16x7II3pH17gyKdGdK2E/vJz8qV6d5T6nGSTGpLp/kBoDFRnAEAdUxystS5m9S5m5IGDJa1Vtq9K1gz+m/vqGbtZ7Jb5sn6vpScLB1znEy7TtIJ/WR69ZVp3cb1VwCABkNxBgAckTEmOHGw3yAl9Ruk3Nxcbd34lbR6peyKJbKffyq76H3p3TeDo9K5baXO3WS6dJPp0j243YYLsgBIDBRnAEC9mBapUq/+MvvnPNvaWunzT2VX/0P6cnVw0uHihQeWwAvlSfuLtOncLbjN6h0AmiCKMwAgKiYpWEPaHNerbpvdUS2tWyO7bo305RrZL9ccOOlQkrJzpc5dgzLdJZgaYrJCTvIDQKQozgCAmDOt06UT+sqc0Ldum925Q1q/VvbL1UGZXrdG9uOSYB61JGWGgqPR+6d6qEt3KSsUTBcBgDhAcQYANAqT1lo6/iSZ40+q22Z375TWrT1wZHrdGtm/fyRr/eAJbTKl/Uelg2ke3aVQLmUagBMUZwCAM6ZlmtTjRJkeJ9Zts3t27z8yvSaY7vHlatmVS4KVPCQpPWP/CYhdpQ7HyHQ8ViroEEwZAYAGRHEGAMQVk9pS6n6CTPcT6rbZvXukDV8cWqbffEmqrQnmTScnS+07y3Q4JrjiYcdjpI5dpDZZHJ0GEDMUZwBA3DMtUqWux8t0Pb5um63ZJ23+SnbD2qBUb/hCduVS6W9zD5yEmJYute8ULI3XoYtM2/ZSQUdW9QBwVCjOAIAmySSnHDi6fBBbVRkU6a++lLZ8FRTqd98MLiv+9ZPSM6T8djLtOgbv0bajVNBBysmX8bzG/ioAmgiKMwAgoZg2md9e0cOvlcq3Sls2ym5eL21cL1u6SfbjRdL7bx8o1C1aBEek23eW2nWSad9Jaru/ULdIdfJ9AMQPijMAIOEZL0nKK5DyCmROGlC33VorVVVKpRtlN22QNq2X3bRedtVy6YN5Bwq1FFzIpXM3mfx2wdHq/HZSfnspO4ej1EAzQXEGADRbxhgpI0vKyJLp3uuQx+yunUGRLt0klW2RNq6TXb9WdvlHUs2+Q49S53eQKegQTPdo214mlC/l5gfrUHus9gEkCoozAACHYVqlfeuEREnBsnjbyqXSTbJbNgYnKG75Kriwy0cLJesfKNUpLfav9tFFCuVKGdnac1xP2ew8KS2dFT+AJobiDABAPRjPC6ZthPJkevY55DG7b19wdLq8VLa89MDJiSuWSNsrJGu17esnp7aUsnOk3LYyBR2DaSTZuVK7jlJeO9alBuIQxRkAgBgxKSlB8W3XUd88lmxra6WqSmVUV6hy5d+lijLZcJlUtjmYU71374Ej1caT0tsE75OdK+XkB0eu23WU2naQSW0ZnPBoPI5aA42I4gwAQCMwSUlSVkip3XvI69jtkMes70vVlVJ5meym9dLWTVJlRXCi4ppPpEXvSbW1B4p1dq60Y7uUniHTtWcwDSS3rUxuWym3bdytAmI3bZBy82VSWriOAkSF4gwAgGPG86SMbCkjW+bY4771uK3ZJ23ZKG3eILv5q+Dfe/dIu3fJrvtcWvahtG/voauAZIakvIPKdG5BcDuvbaOetGg3fyX/l+NlzrlY5uLrGuUzgYZCcQYAIM6Z5BSpQ5fg6oeHedxaK23fJm3dLFu2JZhnXbZZtqxU9rOV0v8tOPSkxaTk/ScrZsmE8oK1qtMzZLJDUvvOUus2wXrYMWDn/TX49/rPY/J+gEsUZwAAmjhjjJSZLWVmy3Q/4VuP25p9UrhMKtsiW7Z5/wmMW2UrK2Q//1QqeTd43sEvyswOrrCYky+Tkx+cyBjKC+ZcZ+dIOXnfe9TaWiv74YLgzoolqv3hBTJX/kjeiPNi9M2BxkVxBgAgwZnkFOnrC7cc5nFbWyvt3BGsW122RaraFiyzV1UZrBDy2Qpp187guXVv6kmtW0s5bYMSnZ0bFOv8AqlNlpSTJ1VvDy4w0/0EafU/gtf/8XHZjCzpxAFSSgtWD0GTElVxnjlzpt5++21lZGRIkq644goNGBBckWn27NmaO3euPM/TDTfcoH79+kmSli5dqunTp8v3fY0cOVJjxoyJ6gsAAIDomKQkqU2G1OZEmR4nHvY5dveu4LLlleWy5VulslJpx3bZrVuCS5ivXBrMuf7mCz1P3vX/LFvyruxLz0qS/McePPDZw88NCveAwUGxZ5UQxLGojzifd955uuCCCw7ZtmHDBi1cuFAPPfSQKioqdN999+l3v/udJOmJJ57Qz3/+c+Xk5Ojee+9VYWGhOnbsGG0MAADQgEzLVlKHzlKHzkeeZ72jStq6WaqqlA1vlXbvkjnmOJm27aXzxsn84DwpKUV21lOyc18NXjfvteDfs56W2mRK3U+QyWsnJadIe3dLx/aQyQwF00badeBKjHCqQaZqlJSUaPDgwUpJSVF+fr4KCgq0evVqSVJBQYHatm0rSRo8eLBKSkoozgAANHHGmKDcpgd/hf5muTbGSGnpwe0rbpauuDko2zt3yL7+orRnd1C4v/pS9u+LJN+XkpOl4pcPmh5ipDaZKmuTqdqcfJm01lJBRyk7JziZMa+dlN5GZn8GINaiLs5vvPGGFixYoK5du+raa69Venq6wuGwjjvuwHI6oVBI4XBYkpSTk1O3PScnR5999lm0EQAAQBNkjJFap39rmTq7d08wh9rzpHWfS1XbZCvKpdKN0s4dSqquVG24XPaLz6QP5gWvOfgNWraSskJSZkgmMzuYb90mS8rKCe5n5wS3U1Ia66siQXxvcb7vvvu0bdu2b22//PLLddZZZ+mSSy6RJD3//PN6+umnNX78+JgEKy4uVnFxsSRp4sSJys3Njcn71ldycrKzz04UjGH0GMPYYByjxxhGjzGsp/1/pT5YcnKyampqglU7qrartqJMfnirardslL+9Un7ZFtVWlMsPl8lftVz+tnDdaw8u2KZ1G3nZOUrKzZeXnSsvK6SknDx5OflKCgX3vZw8maTEW0uB/fDofO+e8Itf/CKiNxo5cqQefDCY7B8KhVReXl73WDgcVigUkqRDtpeXl9dt/6aioiIVFRXV3S8rK4soR6zl5uY6++xEwRhGjzGMDcYxeoxh9BjD6H1rDFtnBv906v6t5xpJ3r59wQof4a1SZVi2IixVhqXKCtVWlKl280Zp1YpgZZFvvYEnZWRJmVlSdm6w7nV2rpSZJZOz/+IyWaEmtzpIvO+H1q91Np+9ffv2R3wsql+hKioqlJ2dLUn68MMP1alTJ0lSYWGhHn74YY0ePVoVFRXatGmTunfvLmutNm3apNLSUoVCIS1cuFATJkyIJgIAAMB3MikpwfSM7GC66JHW7bD79koVZVJFuey2/eW6fOuB2+s+l1324YHnH/zizFCwLF9uQTA1JK8gWP/668uhJzMtJFL+X2bKzn1V3i+myGQd/gCrK1EV52eeeUZffPGFjDHKy8vTzTffLEnq1KmTTjvtNN11113yPE833XSTPM+TJN144426//775fu+RowYUVe2AQAAXDIpLaT89lJ++yOXa9+XtoWlirJg5ZDyUim8/3bZFtll/xec6KjDXFAmt21wlDo7JyjWbTKlvIKgXLdqHVx6HbKv/EmqrZFduVRm8A9cxzlEVMX59ttvP+JjY8eO1dixY7+1fcCAAXVrPQMAADQlxvOCohvKlenW87DPsbt2Sps3yJaVBtNDyrbIlpcGl0Tf8MXhi7XxpPQ2wZJ8mdnBEnwZWcH62l+f5JiRJeXmy7RMa+Bv6Y7dvk2qrZE552J5cVaaJa4cCAAAEFOmVVqw/vSxPQ77uN21UyrdJG0LB0eq908Fsdu3Sdu3SZs2yH7692BJvq9f8803+fqS6G0ygyPXX99vnR4sx5edK+W1ldIzmtba1+s+lySZE/s7DnJ4FGcAAIBGZFqlSV26SV26HXFKiLR/Wb5tYSm8VbayQqqsCIr19m3B/epKqXSj7KfLJfsdJdvzpNZtgnnYGVkyrdO1PSdPfsu04H6rtGD5vtz9RdvhfGy7PijO6tzVWYbvQnEGAACIQ6ZFqpTfLrgU+fc81+7eKW2vlLaV7y/W26TtFcFFZaoqD5TurZtl9+zSroNfe7g3TG0pJSUHn98mU/JrZdLSpbbtg9VFCjpI+/YF01aSU6S01gcucHOUl033P3gnuIJkRlbwWXGI4gwAANDEmZZpUsu0oOjqyCuHSMHl0XPS01S+6hOprFR2x/Zgub7t24ITHau3S7t3SZu/ktZ/LtXWBq87+D0O98ZtMqWafVK3E4LXp6bKtO0ghfKkVmnBChkFHYPpJK3bBGV/x479q51Y2TnPBtnPGhP9gDQQijMAAEAzYoyR16q1TIcuUocu338021qpuiqYGlJdJbtxXbBs39YtUpuM4H6r1sG87Q1rpeUfHXjtiiUHbh/8psnJUk1NcDutdXC1x3CZvFvvkRkwOGbfNdYozgAAADgiY0ywukebjOD+cb2O+Fzr+5Ix0t6v18Quk/bsklpnSLt2yG7dIu3eGUwhWbU8OKrdo7e0Z5fM4JFSv1Mb62sdFYozAAAAYqJuLerUVKmgQ/DPwY87yBRLrLQNAAAARIDiDAAAAESA4gwAAABEgOIMAAAARIDiDAAAAESA4gwAAABEgOIMAAAARIDiDAAAAESA4gwAAABEgOIMAAAARIDiDAAAAESA4gwAAABEgOIMAAAARIDiDAAAAESA4gwAAABEgOIMAAAARIDiDAAAAESA4gwAAABEwFhrresQAAAAQLzjiPP3uOeee1xHaPIYw+gxhrHBOEaPMYweYxg9xjB6jOHRoTgDAAAAEaA4AwAAABGgOH+PoqIi1xGaPMYweoxhbDCO0WMMo8cYRo8xjB5jeHQ4ORAAAACIAEecAQAAgAgkuw4Qr5YuXarp06fL932NHDlSY8aMcR0pLpWVlWnq1Knatm2bjDEqKirSqFGjVF1drcmTJ2vr1q3Ky8vTnXfeqfT0dFlrNX36dC1ZskSpqakaP368unbt6vprxAXf93XPPfcoFArpnnvuUWlpqaZMmaKqqip17dpVt99+u5KTk7Vv3z498sgj+vzzz9WmTRvdcccdys/Pdx0/LuzYsUOPPfaY1q9fL2OMbr31VrVv3559sR5effVVzZ07V8YYderUSePHj9e2bdvYF7/Ho48+qsWLFyszM1OTJk2SpKP6/+C8efM0a9YsSdLYsWM1fPhwV1+p0R1uDGfMmKGPPvpIycnJatu2rcaPH6/WrVtLkmbPnq25c+fK8zzdcMMN6tevn6Tm/fP7cGP4tVdeeUUzZszQtGnTlJGRwX54tCy+pba21v74xz+2mzdvtvv27bN33323Xb9+vetYcSkcDts1a9ZYa63duXOnnTBhgl2/fr2dMWOGnT17trXW2tmzZ9sZM2ZYa6396KOP7P33329937effvqpvffee11FjzuvvPKKnTJlin3ggQestdZOmjTJvvfee9Zaax9//HH7xhtvWGutff311+3jjz9urbX2vffesw899JCbwHHof/7nf2xxcbG11tp9+/bZ6upq9sV6KC8vt+PHj7d79uyx1gb74DvvvMO+GIEVK1bYNWvW2LvuuqtuW333vaqqKnvbbbfZqqqqQ243F4cbw6VLl9qamhprbTCeX4/h+vXr7d1332337t1rt2zZYn/84x/b2traZv/z+3BjaK21W7dutb/+9a/trbfeaisrK6217IdHi6kah7F69WoVFBSobdu2Sk5O1uDBg1VSUuI6VlzKzs6u+w21VatW6tChg8LhsEpKSjRs2DBJ0rBhw+rGb9GiRRo6dKiMMerRo4d27NihiooKZ/njRXl5uRYvXqyRI0dKkqy1WrFihQYNGiRJGj58+CFj+PVv/4MGDdLy5ctlOVVBO3fu1D/+8Q/94Ac/kCQlJyerdevW7Iv15Pu+9u7dq9raWu3du1dZWVnsixHo1auX0tPTD9lW331v6dKl6tOnj9LT05Wenq4+ffpo6dKljf1VnDncGPbt21dJSUmSpB49eigcDksKxnbw4MFKSUlRfn6+CgoKtHr16mb/8/twYyhJTz31lK666ioZY+q2sR8eHaZqHEY4HFZOTk7d/ZycHH322WcOEzUNpaWlWrt2rbp3767KykplZ2dLkrKyslRZWSkpGNvc3Ny61+Tk5CgcDtc9t7l68skndfXVV2vXrl2SpKqqKqWlpdX9wAiFQnU/MA7eP5OSkpSWlqaqqiplZGS4CR8nSktLlZGRoUcffVRffvmlunbtquuvv559sR5CoZDOP/983XrrrWrRooX69u2rrl27si8epfrue9/82XPwWEOaO3euBg8eLCkYw+OOO67usYPHip/fhyopKVEoFNIxxxxzyHb2w6PDEWfExO7duzVp0iRdf/31SktLO+QxY8whv+XiUB999JEyMzOZXxul2tparV27VmeddZZ++9vfKjU1VXPmzDnkOeyL3626ulolJSWaOnWqHn/8ce3evZsjTTHCvhedWbNmKSkpSUOGDHEdpUnZs2ePZs+ercsuu8x1lIRBcT6MUCik8vLyuvvl5eUKhUIOE8W3mpoaTZo0SUOGDNGpp54qScrMzKz7s3dFRUXdEahQKKSysrK61zK20qeffqpFixbptttu05QpU7R8+XI9+eST2rlzp2prayUFRwa+HqeD98/a2lrt3LlTbdq0cZY/XuTk5CgnJ6fuKNSgQYO0du1a9sV6+Pvf/678/HxlZGQoOTlZp556qj799FP2xaNU333vmz97Dh7r5mzevHn66KOPNGHChLpfPo40Vvz8PtSWLVtUWlqqn/zkJ7rttttUXl6un/70p9q2bRv74VGiOB9Gt27dtGnTJpWWlqqmpkYLFy5UYWGh61hxyVqrxx57TB06dNDo0aPrthcWFmr+/PmSpPnz52vgwIF12xcsWCBrrVatWqW0tLRm/adxSbryyiv12GOPaerUqbrjjjt00kknacKECTrxxBP1wQcfSAp+cHy9D5588smaN2+eJOmDDz7QiSeeyJEsBX8Kz8nJ0caNGyUFJbBjx47si/WQm5urzz77THv27JG1tm4M2RePTn33vX79+mnZsmWqrq5WdXW1li1bVrdSRHO1dOlSvfTSS/rpT3+q1NTUuu2FhYVauHCh9u3bp9LSUm3atEndu3fn5/c3dO7cWdOmTdPUqVM1depU5eTk6MEHH1RWVhb74VHiAihHsHjxYj311FPyfV8jRozQ2LFjXUeKS5988ol++ctfqnPnznU/MK+44godd9xxmjx5ssrKyr61DNMTTzyhZcuWqUWLFho/fry6devm+FvEjxUrVuiVV17RPffcoy1btmjKlCmqrq7Wscceq9tvv10pKSnau3evHnnkEa1du1bp6em644471LZtW9fR48IXX3yhxx57TDU1NcrPz9f48eNlrWVfrIeZM2dq4cKFSkpK0jHHHKNbbrlF4XCYffF7TJkyRStXrlRVVZUyMzM1btw4DRw4sN773ty5czV79mxJwTJgI0aMcPm1GtXhxnD27NmqqampO+HtuOOO08033ywpmL7xzjvvyPM8XX/99erfv7+k5v3z+3Bj+PUJ05J022236YEHHqhbjo79sP4ozgAAAEAEmKoBAAAARIDiDAAAAESA4gwAAABEgOIMAAAARIDiDAAAAESA4gwAAABEgOIMAAAARIDiDAAAAETg/wOFhyJKgrZAjAAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# initialize the kernel, likelihood, and model\n",
    "pyro.clear_param_store()\n",
    "kernel = gp.kernels.RBF(input_dim=1)\n",
    "likelihood = gp.likelihoods.Gaussian()\n",
    "vsgp_diag2 = VGP_diag2(X_train_tensor.view(-1,), y_train_tensor.view(-1,), kernel, \n",
    "                     likelihood=likelihood, whiten=True)\n",
    "\n",
    "# instead of defining our own training loop, we will\n",
    "# use the built-in support provided by the GP module\n",
    "num_steps = 1500\n",
    "losses = gp.util.train(vsgp_diag2, num_steps=num_steps)  # default: loss_fn=TraceMeanField_ELBO().differentiable_loss\n",
    "plt.plot(losses);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAs4AAAFpCAYAAACMHa7nAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAACo0ElEQVR4nOzdd3gU5fbA8e9sSw8loUkRAUFKCE3BBOkqihIEQUED/IQr9QJeAUFBvaCCgA0lgMIVjdcC19BEROkSRHpoKoKgIiAlgdTt8/tjkyUhhZRtCefzPD6Y3dmZN5PN5sw75z1HUVVVRQghhBBCCFEkjbcHIIQQQgghRHkggbMQQgghhBDFIIGzEEIIIYQQxSCBsxBCCCGEEMUggbMQQgghhBDFIIGzEEIIIYQQxaAr6w4uXbrEggULuHLlCoqi0KNHDx588ME82xw9epQ5c+ZQvXp1ANq3b8+jjz5a1kMLIYQQQgjhMWUOnLVaLbGxsTRo0ICsrCymTJlCy5YtqVOnTp7tmjZtypQpU8p6OCGEEEIIIbyizKkaVapUoUGDBgAEBARQu3ZtkpOTyzwwIYQQQgghfEmZZ5xzu3DhAqdOnaJRo0b5njt+/DiTJk2iSpUqxMbGUrduXVceWgghhBBCCLdSXNVy22g08tJLL9G3b1/at2+f57nMzEw0Gg3+/v7s37+fZcuWMX/+/AL3s3HjRjZu3AjA7NmzXTE0IYQQQgghyswlgbPVauX1118nMjKShx566IbbjxkzhlmzZhEaGnrDbc+ePVvW4QkgPDycS5cuee349pO/QJpjAWlFEBoaSmpqqreHUWEUdT7VrEyUFm1Qgm/8eSG887uuWq2o+3ei+Pm7Z/9GI0rbu1F0erfsvyje/uwsK9VmQ92X6LafTUnJZ6fryLl0HdVmo85D/Yq1bZlznFVVZdGiRdSuXbvQoPnKlSvkxOcnTpzAbrcTEhJS1kOL8sRqrjBBs/AwRUG1Wr09ClEUmxVwyc3LQtjBZnPj/isw1Q6uubEshMAFOc6//PIL27dvp169ekyaNAmAgQMHOq/Q77vvPnbt2sW3336LVqvFYDAwYcIECaJuNhaLt0cgyiuNRoImX2e1uD84s8nFU6lI0CyES5U5cL7jjjtYvnx5kdv07NmTnj17lvVQojyzWkAulkSpKGCXwNmXqUYjaLRuPIKCarEgnyClYJfAWQhXcmlVDSEKZbWA3uDtUYjySFFkxtnXmd0cOGs0YDa7b/8VmWr39gh8lgoYgyuj+vlBObwssxj0WPSB3h5GOaOimEz4p18p9U9cAmfhdqrN5gh8PL+uR1QEGkVu0/s6kxG07gyctWAxuW//FZmq4t788/LLGFwZfbUa6HTlMxTSajXobXJhVFJWqxUjEJB+pVSvL/PiQCFuyGKSPDtRBjLj7PPMbl78q9WCWQLnUpEZ50Kpfn7lNmgWpafT6bLvMpSOBM7C7VSTSfKbRelpNJLj7Ovc/PNRFAWkskrpqKpMOBdK/i7dvEr/s5dLLeF+GWnghfqromJQFMWR7iN8lyeq5sh7oHRkcaBPq9fkDu5o3Bir1YpWp+XRPn34x//9HxpN4fOaf545w979B3j0kRgPjlTkkBln4X6ZGe7NfxQVn6T6+DZP5KDLXYdSUW1WuePnAnHvf0Dirl15HkvctYu49z8o0379/f35du0aNq//ms+WLWPL9u28+e67Rb7mz7/+YtXatWU6rig9CZyF+1mk+YkoI7vkafo0TwS1MuNcOna7BM4uENkyglHjxjuD58Rduxg1bjyRLSNcdozwsDBenzmTZZ/8F1VV+fPMGfoOHEjPmD70jOnD3v37AZg1dx679+6lR6+H+eDDDwvdTriHpGoI97NK8xNRRjLj7LNUVXXkH2vd/OdEAufSsdskcHaB6A4dWDj/HUaNG0/soEHEf/opC+e/Q3SHDi49zq316mG32bh0+TLhYWF8umwZ/n5+/Hb6NGOf+Rdfr0xg6qSJLF6ylE/+swSbzU5WVlaB2wn3kMBZuJ/F7P4/qqJik8DZd1mtnvn5SEnC0lFlxtlVojt0IHbQIN5ZsIDxY8a4PGi+nsVqZdq//83Rn35Gq9Hw2+nTZdpOuIZEM8KtVJvNsXBIAmdRFpLf6rtsHrqjJOk6pWOVGWdXSdy1i/hPP2X8mDHEf/opUR3auzx4/v2PP9BotYSHhfHmu+9SLTyc79auwW6307BFwWkhH3z4YbG2E64hOc7CvcxSw1m4gLyHfJZqtnjm52O3OdJCRMnIjLNL5OQ0L5z/DpMmjHembVy/YLAsLl9OZuqLLzH0ySdQFIW0tHSqV6uGRqPhy1WrsWWnKwUHBZGekeF8XWHbCfeQwFm4lZqV6ajDK0RZyGyj7zJleeaOkorkOZeG3Y7UKy67pEOH8+Q05+Q8Jx06XKb9Go1G7nu4N90eeJDHhw6hU8eO/Ouf/wRg8BODWLFyFfc+/DAnfvuNwEBHe+2mTZqg1Wrp/uBDfPDhh4VuJ9xDUX38Ev7s2bPeHkKFEB4ezqVLlzx+XPufp+DieZQKVo4uNDSU1NRUbw+jwrjR+VQ1WjQRbT04ovLL07/r9jOn4cI5t/+Oq8YslFYdUMrQ8as0vPXZ6Sr2P07C5YsoPjKB4UufnZlhNQmsGubtYZSaVqvBJi23SyUz+TKBl887v1ZtNuo81K9Yr/WN3yRRcRmzKlzQLLxAZpx9l8nombtKKrJAsDSkHJ0QLiWBs3Avi9nbIxAVgk/fGLu5Wa0eqtOuokrb7ZKz2aSOvhAuJIGzcC+z0dsjEBWB5Lb6Lk/NAmu1YDF55lgViW9nYwpR7kjgLNxGtdvBLDPOQlRonrqo0Wjk86Q0JHAWwqUkcBbuYzYht9iFS9jlfeSzPNUZVKOV1K/SkMBZCJeSwFm4jZqZgZRBEi6hSqqGz/JUqoaiSOBcGhI4C+FSEjgL90m/CnqDt0chKgL54++TVLsNPFQOS1EUyXUvFfnd8WUXL11izDP/IqprNx7o8wi9+w9g/bffArDzxx9p2roN9z3cmy739+TNd9/N9/o/z5yhYYsI7nu4N117PsCU6S9iL2EVoqPHjrFp69YSj/3833/z9Nh/lvh1udW5vTH/fHai82ur1UrLu9oz5B9Pl2m/7iSBs3CfrCyfqR0qyj9VStL5HqsVjwZm8h4oObno9FmqqjJs1Gg63HknO7dsZv2qlcS9/Rbnzl+rL3xXu3Z8u3YNX69MIGH1Gg4fPZpvP/Xr1ePbtWv47qu1/HriBN98912JxnH0p5/ZvG1biV5jtVqpWaMG77+XP5gv6jXXCwwM5Jfjx8kyOgoJbE9MpGaNGiUai6dJVCPcxywr4IWLqEjQ5IusFjwaOEsd55KT3xuflfjDD+j1emIHDXQ+Vqd2bZ4aPDjftoGBgbRs0ZzTv/9e6P50Oh1t27Tm9O9/8OeZMwyIHUyPhx7mscGD+Su7mdxX69fT/cFe3Pvww/QbOAiz2cy8d95h7bqvue/h3qxZt47MzEyenTKVXv36cX/vGDZs3AjA8i8T+L8RIxkQO5jHBg/hzzNn6P5gLwCMJhP/em4K3Xs9xP29Y5ytyK9/TUG6denMpi1bAVj91VfEPPSQ87nCxvLnmTP0HTiQnjF96BnTh7379wOOWfpHn3iSp8f+k87338/Yfz2Lq/v8eaBPqrhpWcyOElJClJkqM2c+SDWb8Og6BgkCS05+b4ql9u2N3bLfv349Xuhzv/x6gojmzYu1n5SUFPYfTGL8mDGFbpOVlUXiDz/w7PjxTJ8xk/6P9KF/3758vuJ/vDhzJksXLuSt9xbwyX+WUqtmTa6mpmIwGJg4fjxJRw7z6ksvATD7jTeIursDb8yexdXUVB7q9yj3REUBcPjoUb77ai1VKlfmzzNnnMf+6JNPUBSFTeu+4sTJkwz6v6fY/t23+V5TkN69evH2ewvo0a0rP/38C489+ii79+4FYP7ChQWOJTwsjE+XLcPfz4/fTp9m7DP/4uuVCUB26snXX1OzRnX6PPY4e/bt46527Yp1notDAmfhFqrVkh04B3h7KKKikKDJ95iMoPXgnxGZcS45CZzLjRdefpnd+/Zh0OtZl+AIAnfv3cv9vWPQaDSMefppmtx+e77Xnf7jD+57uDeKonBfj+5069yZ8ZMm8cGC9wDo1yeGV+fOAeDONm3413NTeOjBB3jwvvsKHMf2HYl8t2kzi5csBcBkMjlnrDtFRxcYAO/et4+nYmMBaNSwIXVq38Jvp04V+Zocze64gzN//cXqtV/RrUvnYo2lRo0aTPv3vzn6089oNRp+O33a+ZpWLVtyS62aADRv2pQ///pLAmfh+xwVNYRwEVWVyhq+yJjl2btKcvFUchI4F0tRM8Pu0uT2Rny9YYPz61dffpnk5GQe7NvP+dhd7drx0QfvF7mfnBzn4pg9cwb7DyaxaetWHnikL+uzZ2lzU1WV9997l4YNGuR5/EDSIQICSz4ZVpzX3NutGzNff50Vn8STcuXKDcfyxvz5VAsP57u1a7Db7TRsEeF8zmC4VpRAo9Vgs7r2b4fkOAv3uJoiFTWE6yhILWdfZDF7dgGwXS6eSk5+b3xV9N13YzKZ+Pi/nzofy1kkV1btWrdh9bp1AKxcs9Y543r69z9o0yqSSRPGE1a1CmfPnSMoKIiMjGuTXZ3v6ch/4uOducFHjh674fHat2tHwpq1APx26hR/nT1Hw9sa3OBV1zz26KM8M3YsTZs0yfN4YWNJS0unerVqaDQavly1GpsHK+5I4CzcIzMdRfKbhauoCqgy2+hzXDyTc0N2u1RXKSm54PRZiqKwdGEcu/bs5u6u3ejVrx8TJj/H85Mm3vjFNzDzxeks/zKBHg89zJerVzFj2jQAXnn9dbr3eojuD/aibes2NGvalKgO7fn1xAnn4sDxY8ZgtVjp8dDDdHvgQea+/fYNjzf4iSdQ7Xa693qIUeMn8Obrs/HzK/7k2S21ajJsSP5FkYWNZfATg1ixchX3PvwwJ377jcDAwGIfq6wUtYzLDS9dusSCBQu4cuUKiqLQo0cPHnzwwTzbqKrKhx9+yIEDB/Dz82P06NE0aFC8K5Gz2Xk1omzCw8O5dOmSx45nP7QHpQLfIgwNDSU1NdXbw6gwbnQ+VWMW3NESTaUqHhxV+eTJ33X7kf0oHsw7Vo1ZKG2jUHR6jx3T05+drmY/+KOjBraP8KXPzsywmgRWDfP2MEpNq9Vg81Ad9YomM/kygZevlf1TbTbqPNSviFdcU+YcZ61WS2xsLA0aNCArK4spU6bQsmVL6tSp49zmwIEDnD9/nvnz5/Prr7+yZMkSXnvttbIeWvgoVVUdi4YMft4eiqgoNJrsmsHCp3i6IYmSfUwPBs7lnqo6ui4KIVyizKkaVapUcc4eBwQEULt2bZKTk/Nss3fvXjp16oSiKDRu3JiMjAxSUlLKemjhq0xGua0uXEtRwC6Bs8/xdJULVZXKGiVVge/8CeENLs1xvnDhAqdOnaJRo0Z5Hk9OTiY8PNz5dVhYWL7gWlQcanoqKJI+L1xI0Xg+n1YUSVXV7AYonqSgWjx9zHJOJjGEcCmXlaMzGo288cYbDB06tExJ2hs3bmRjdmeY2bNn5wm4RenpdDqPnUvTxbOoYeE+lVfnahqtltDQUG8Po8K40flUbTa0IcHo5fPghjz1u65aLBhDQtD4e65Wu+pnQBccjM6D7wNPfna6gzE4BMXgOxWOfOmz06LXo9WW30keBaVcj9+b9Hp9nvehWoI7WS4JnK1WK2+88Qb33HMP7du3z/d81apV8yyuuHz5MlWrVi1wXz169KBHjx7Or8vzogxf4tEFQ+fPoVTwslG+tMClIrjh4kBVhUsX0QRX9tygyilP/a6rxizU1FQUs+dmgFWrFS6cR6OVxYHFZb96BcXP39vDcPKlz06rXYMpIBCdrny2tJDFgaVjtVqxpqeRmn7tfajabBT3cq7M7xZVVVm0aBG1a9fmoVz9xXNr164d33zzDdHR0fz6668EBgZSpYqsjq+IVLsdjJmyMFC4lKIoqJ5eiCaKpFrMni8RrNE4OpKK4pMU50L5p1/BCJj9/PBo63gX0Rv0WDx44VoxqCgmE/7pV0q9hzIHzr/88gvbt2+nXr16TJo0CYCBAwc6r9Dvu+8+Wrduzf79+xk3bhwGg4HRo0eX9bDCVxmzpEmBcA/J1fQtJiN4+DaxotFIjnMJSM3roilAQPoVSPf2SErHl2bvbyZlDpzvuOMOli9fXuQ2iqIwfPjwsh5KlAPq1WTQ+U4+nahApDqAbzFmgdYLt7ilqkbxqSoy5SyEa0lWuXCtq1dQymm+mPBxMnvmW0wmR+qEp0knvOKTuzRCuJwEzsK1MsvpPS/h+yRw9i1Wi3cq58iMc/HJXRohXE4CZ+EyqskEZpO3hyEqKgkCfIu3Ali5gCo+mZ0XwuUkcBYuoyZflFa4wn2kqoZv8dbPQ2aci09SNYRwOQmchetcSUbRS+As3EVmz3yKx7sGZpMZ5+KTuzRCuJwEzsIlVFWV/GbhXhIw+RavpWrInYdik98ZIVxOAmfhEmpmuvdmoMTNQYIAn6HabOCtjmV2u9QnLjZVZp2FcDEJnIVr/H1OugUK95IAwHdYLXgtdUZVZda5mFSbDbxR+USICkwCZ+EaqSko3qjpKm4eMsvoO7wZOKPKQtHiskvgLISrSaQjykw1ZoEpy9vDEBWdzDL6DNWYBRqtl46uSGWN4pIZZyFcTgJnUWbq+TOglzQN4X6qpGv4Bq8GzqBaJXAuFrsdkMBZCFeSwFmUiaqqcPkiitZ7f0TFTUTSNXyDyQje+p3XaMBi9s6xyxtJ1RDC5SRwFmWiXk2R26bCM1RVAmdf4a122+AInM0SOBeL3S6BsxAuJoGzKJuzf0g1DeE5Ejj7Bm+mSmi0MuNcXJLjLITLSeAsSs2elQlpV7038yRuLqoKqiwQ9AnerGqhKBI4F5fMOAvhchI4i9L7/ST4+Xt7FOJmoSAzzr7Ci82OFEWRcnTFJTnOQricBM6iVOxZmXA1WWabheeoSODsK7y9rkHeB8Vjs8lntBAuJoGzKJ0TP8lss/AsRUGVtu5ep9pt3p/xlZreQggvkcBZlJj94jnIypSZDOFZGo33AzYBFh+4eJH3QfHIzLwQLieBsygRuzELTv2K4ieVNISHKYp3qzkIB6+2284mM87Fo0rgLISrSeAsik21WuHYQSk/J7xD0Xg/t1Z4ud12NplxLh7ptCmEy0ngLIpFtVpRj+wHkBQN4R0y4+wbsjJBq/PuGCQFoXgkbhbC5bz86SfKA3tGOvycBIpGWmsL79Fo5Ba9LzAZHT8Lb7LbUFVVLuJvRFI1hHA5CZxFoVSbDfXMKTh/Fvz85I+U8CpFUVDlFr33ebPddg4VR7qGTv6EFUlSNYRwOfnUEfmoxkzUv/6AlMuggOIvZeeEj5DA2ft8Il1GlcC5OGTGWQiXk0+dm5hqt4PFgmrMhNQrkJHmyF+0mEDvh6LXe3uIQuQlgYD3+UTgjKTtFIddZpyFcDWfD5ztvx7z9hA8p1S31dQ8/+R7TLWDqmIKCcF+5YpjUU1OAwObzbGRChgMjvxljQb8AsrwTQjhRrIozPtsVvD2WgdVRbVakOQxIYSn+XzgrGSme3sIFYPVgpIzQ6PROP6TGWVR3kjg7FWqqvpG4KzRgNns3TGUB3KHRgiXc0ngHBcXx/79+6lUqRJvvPFGvuePHj3KnDlzqF69OgDt27fn0UcfdcWhhRA3Ewmcvctq9Y2fgUYLVgmcb0gWBwrhci4JnLt06ULPnj1ZsGBBods0bdqUKVOmuOJwQoiblS8EbTczqw+02waZcS4u1e5oHCSEcBmX/EY1a9aM4OBgV+xKCCEKp8qCMG9STUZvD8FBowGLBM43JIsDhXA5j+U4Hz9+nEmTJlGlShViY2OpW7dugdtt3LiRjRs3AjB79mxCQ0M9NcQKTaPVyrl0ITmfrlXc86larfiHh3tgROWXTqcj3E3nyGrKwlqlCore4Jb9l0hQMH4eeC+483y6mzEkBMXHSvbJZ6fryLl0HdVW/GpBHvmNuu2224iLi8Pf35/9+/czd+5c5s+fX+C2PXr0oEePHs6vU1NTPTHECi80NFTOpQvJ+XSt4p5P1WIh/dIlD4yo/AoPD+eSm86R/dwZyMxCUbw/86yaLWg88F5w5/l0N3vqVRSdby0Cl89O15Fz6TqqzUZxL0E8kvwUGBiIf3YTjTZt2mCz2eSHLYQoOand611ms/e7BuaQZjg3JosDhXA5jwTOV65ccZQxAk6cOIHdbickJMQThxZCVDCqLBD0Hl9ZHAgSOBeH/K4I4XIuSdV4++23OXbsGGlpaYwcOZIBAwZgze4udd9997Fr1y6+/fZbtFotBoOBCRMm+M6shRCi/FBVx6yzRioFeEUJ8gDdToLCIjkmq2TGWQhXc0ngPGHChCKf79mzJz179nTFoYQQNzubvRy0bqqgLBbvNz/JIWk7RVPtEjcL4QYybSOEKF+kJJ1XqKrqW6kaEjgXza6CNCUXwuUkcBZClB+q6phxFp5ntfrWYjPJcS6aqoLiQz8vISoICZyFEOWHoqBKwOQdFrNv3fpXVXkvFMUuqRpCuIMEzkKI8kNRpGOcl6hmI2h87Na/Ly1W9DWq3JkRwh0kcBZClB8aDdglWPKKrEzQ+tiqTJlxLpwvpdUIUYFI4CyEKD8UjaOyg/C8rEzfqagB10oTioLZ7RI8C+EGEjgLIcoPjcaxSE14nsXiW/X3NRpUs6TtFEpSNYRwCwmchRDlh6L4Vkm0m4mvnXeNBswmb4/CZ6k2m+P3RQjhUhI4CyHKDUVRZCbNW3xtpl+jlYWiRZHAWQi3kMBZCFG+yIIw77D6WJCq0UjgXJRiBM5xK1aSmHQ4z2OJSYeJW7HSnSMTolyTwFkIUb7YZcGTp6l2G1h964JFURQpR1cU+40D58jGjRg1a54zeE5MOsyoWfOIbNzIEyMUolzysdpCQghxA1JJwfMsFsAHU2Tk7kPh7HZHFZoiREdGsHDqREbNmkdsr/uJX7eBhVMnEh0Z4aFBClH+yIyzEKJ8kRJbHqeaTKD6YL6sBM6Fs1mLleMcHRlBbK/7eeezFcT2ul+CZiFuQAJnIUT5YvfBmc+KLisDdD5UwzmHBM6FK0aqBjjSM+LXbWD8wP7Er9uQL+dZCJGXpGoIIcoXSdXwvKwM0Om9PYr85CKqcMVYHJiYdJihL7/KxNiBjOgbQ1TLCEbNmseYAX2x2eyM7v+IhwYrRPkhM85CiPJFZhk9z2zyreYnOeQiqnB2+w1/ZknHTzAxdiALlieQmHSY6MgIxgzoy7z4z2SBoBCFkMBZCFG+yCyj5/lqm3MJnAtXQL3z68vPje7/CC0aNqBnVAdGzZrH3PhPWbA8gWUvvyC5zkIUQgJnIUT5Ig1QPM/Xmp/kkLsPhSugbGNh5ediOneUBYJCFJPkOAshyhe7HdVuQ9H44GK1ispq9s0cZ1VFtdlQtPJeyKeA6jM55eeGvvwqD0R3YOveAyycOhGA/6xeR3RkBPHrNhDVMkKCZyEKIYGzEKJ8UQCb3dFyWbidarc5ZnZ9MXAGR9k1CZzzK6RsY3RkBA9EdyBh8zb6dusMQOyLM9FqNYx7vD+ALBAUogiSqiGEKF9UJLfVk8xmHCfdF6mSrlGYQlKaEpMOs3XvAfp268zKLduZueRDtFoNuuyLD1kgKETRZMZZCFHOqNJq2YNUk9GH42ZFLqIKU8CMc05Oc053QAX4cvM2+nXrzIB7u+fpICgLBIUomMw4CyHKGQXVKsGSx2Sm+26ahkZBNZu9PQrfVED1maTjJ5xBc2LSYbbsPUC/bp35OnEXgCwQFKIYZMZZCFG+aDRgkWDJYzIzfDeHWKMBs8nbo/BNBcw45+QrXz/zPODewwyfORsUnB0EZYGgEAWTwFkIUb4oEjh7lMXim81PwLFAVN4LhSg8vyb3zLOTAg/f05FJsYOcHQTzbVOqYagYfvoFv337MZz4Df2Vq/jZrKjBwVjq1cUUGYGpTSvUgICyHUcID5HAWQhRvmg0YPXRhhwVkS8HpjLjXLgiGgVdXykj6fgJlkyb4gySc8rWJR0/UfrA2W4nYHsiIZ8tR//nmTxP5dy/8Dt0hOCv1mMP8CezWxfS+/fFVr1a6Y4nhIdI4CyEKF8kcPYsi9lnUzUURUGVqhoFU+2OuzPFUFDJuejI0qdqaM+dp8qb7+J39BgAtqpVyOrUEVOzpvg3qE9GVhaa5BT0J38jYPdeDD8fJ3jdNwRt2Ej6I71JGzgA1d+vVMcWwt1cEjjHxcWxf/9+KlWqxBtvvJHveVVV+fDDDzlw4AB+fn6MHj2aBg0auOLQQoibjKIoqBI4e4RqtzsuUnw0cAakqkZh7Oq1qV0P8tu7n6qvv4EmIxNblcqkxg4is0dX0DnCDUNoKJbUVGgIpjvbkv54f3Snfyfkiy8J3PY9ISsSCEj8gcvPT8La4DbPfwNC3IBLqmp06dKF559/vtDnDxw4wPnz55k/fz5PP/00S5YsccVhhRA3K5u03fYIi7nQRho+Q2acC+H5n1vApq2EvfwqmoxMsu5uz4WF75DZ815n0FwYa/1bSXnuX1x4czaWW+uhO3uO6v+aQuA33/n++0/cdFwSODdr1ozg4OBCn9+7dy+dOnVCURQaN25MRkYGKSkprji0EOJmVEhzB+FaJarhrKroT54iYNsOAjZtwXD0GFg8cGdAAueC2T0bcAZs3kqVN+ej2O2kDehH8guTsYeGlmgfljuacPGtOWTc1wPFbKbK/DgqLV5aZL62EJ7mkRzn5ORkwsPDnV+HhYWRnJxMlSpV8m27ceNGNm7cCMDs2bMJLeEvniiYRquVc+lCcj5dq8TnU2/AL9dnirhGp9Pl+bwtC6spA2vVKih6QxEbWdGvWYfh0y/QnP87z1NqaAjmh3thHjwIgoJcMqZ8VNz6XnDl+fQkY0gwisEzecLavfsJeOs9FFXF9I+nYMgTFPbbfMPf9VCwvziVrDvb4j/nTYLXrMMvy4jxhck3nLm+2cjfIddRS9BUy+fehT169KBHjx7Or1NTU704moojNDRUzqULyfl0rZKeT1WjRXPpkhtHVH6Fh4dzyUXnxn7mDGRmoSjGAp/Xnv+bqq/NxXDiJAC2sKqYmzRG1evQn/od/R9/4vffz9F98y3JUyZibt7UJePKTbXZ3PpecOX59CT7laso/v5uP4723Dmqv/ASis1GWt8YUh95GIr4XS7273p0Bwz/nkbYzFnov9uE7coVLr8wGQxFXMTdZOTvkOuoNluhF3vX80jgXLVq1TwfPJcvX6Zq1aqeOLQQoiKSBWGeYTEVWsNZ/+tJwqe9jCYtHWuN6lwdNhRjVHtH1ZOcbX4+TuXFSzH8cpzwqS+S8ux4sjp3dO0Y5b2Qj+qp1AaTiaqvznHkNHe4i9SnBrt09+ZWLbk0awZhL87Ef88+qs5+g+QXJvv2YlVR4Xmk5Xa7du3Yvn07qqpy/PhxAgMDC0zTEEKIYpG8Vs8opEay/sRJwp9/EU1aOsY723Lh3Tcxdrw7T9AMYLmjMRfnvUZ6714oVitV5r6F/w8/unaMdpvnAsXywkPno9JH/8Xw22mst9Qi5dlx+X7+rmBpfDuXZs3EHhxMwK7dVHnrPcl5Fl7lkhnnt99+m2PHjpGWlsbIkSMZMGAAVqsjX+S+++6jdevW7N+/n3HjxmEwGBg9erQrDiuEuFnJH07PMJtBr8/zkOZyMmH/fs0xyxh9N8nP/avo3FOtlqsjh6MG+BPyxZdUff1NLr4xG0tDF5UaU3HMOrshaCu3VBV3V9UwJB0meNVaVI2G5Mn/QnVXDjtgve1WLs2YTvjzLxG4eSv24CCujhgGvtrRUlRoLgmcJ0yYUOTziqIwfPhwVxxKCCHk9rwHqFarY2Y/d+BstRL26utoLydjat6M5MnPFHvBVurgJ9CkXCHo201UffV1LrwzDzWk8GpMJRipY5w6/Y03vVm4u+qMyUSV+XEApD3eH0vjRu49Ho67F5dfnEr4izMJXrMOa62aZMQ85PbjCnE9uUQXQpQ/KtIxzt3MRiBvABby+QoMPx/HGh5G8rTJ+Waji6QoXBn9NOZGDdGd/5vK7y913VhLsCL+pqCq4MbJ2JAVCejOncdya13SHn/UfQe6jrlVS1Ke+ScAlT74EL/dez12bCFySOAshCiHVJl1djM1Ix0012aT9b+eJOTz/6EqCikTJ2CvVKnkOzUYSJn8DKrBQOCmrfj/uMcFI1VQPVEvujyx293WOET79wVClicAcGXsSI+XiMvq2onUJx5Hsdup+vob6E6d9ujxhZDAWQhRPsmMs3tlpF2bUbbZqPxuHIrdTkbMQ5hbtij1bq11anN1yBMAVFr4AZgKXoBYbBqNIxdbXOPGVI3Q+M9QrFYyu3TC3LyZ245TlLRBA8js0glNlpGwmbNR0tK9Mg5xc5LAWQhR/qiqBM7uZjI6S9EFfb0Bw4nfsFYLJzV2YJl3ndG7F+YG9dFduEjIl6vKtjONFixlDL4rGlUF1fW5GrrfThGwZRuqTkfq4EEu33+xKQopE8ZgbtQA3fm/qfLGO7JgWHiMBM5CiFJR0tLwO5BE4NcbCFq1loBNW9H/ctwzAa1GgyrBkntlz+Iq6RmE/PdzAK6OGIYaEFD2fWu1XB3hWDAevCIBTXJy6fclM875qFarW3KcK30Yj6KqZPTqia1mDdcfoCQMBpKfn+woU7d7L8HLv/TueMRNw+c6BwohfJjFQsD3iQR98x2GYz+jFDDLYw8OIrNLJ9IfeRhbrVruGYcES24VFxdHywAt0W1aE7L8S7SpaVy47VbeOXMWVxUTNUc0JyuqPQE7fyTk8/9xdfTTpdqPotGgWiXHOQ+73eWl2vwOHsJ/3wHsgYGkPd7fpfsuLVvNGiRPmkDYy68SGv8Zlsa3Y2rTytvDEhWczDgLIW5MVQnYtoMaI/5J1Xnv4HfkGGg0mJrdQcZ93Ul/+EEyO3XEekstNOkZBH+1nhojxhH64cfgjoVbGm2hzTlE2bVs3pxRc95ib+IPBK1dB8CgC5eIbHK7S4+TGjsIVVEI+uY7tH9fKP2OJG0nL7utVIFz3IqVJCYdzvNYYtJh4lasJOSTzwBIe7QP9krFbU7sfqY725I2sD+KqlJlzptoL1z09pBEBSczzkKIImlSrlDl7ffw37MPAEvd2qQ/EkNWp2jUwMB82+tOnSYkYTUBm7cRsmIlfvuTSH5hsmtv7Wo0Eji7UVTrSBY+O45Tr85FYzazXqfj6WnPER0Z4dLjWG+tR1aXewjcsp3glWu4OrKU9f6lwkpetuIFznErVhLZuJHz5xrZuBHDZ87m4U7RzBk3msSkw4yaNY/lA/vjd+xn7MHBPlk7OW3gAAy//Ir/vgNUef0NLs15VdpyC7eRGWchRKH0P/9C9XET8d+zD3twECn/HMWFuHfI7HlvgUEzgPW2+qQ8O56Lb8zCWrMGhpO/Ue3ZqehPnnLZuBRFkVlGN+nUqRPPv/AC0Y0bMTI7FeeTmjWY+t4itxwv7dG+AARu2IiSlla6nch7Ia9iBs6RjRsxata8vLPMCqzdnsjc+E8ZNWseC6dOJOrgIQDSH3rANTnurqbVkjJpArawMPx++oWQTz739ohEBSaBsxCiQIHrv6Xa5GloL1/G1Lwpfy+cT+YD9xV7JsdyRxMuvPsGxsgItCkphD//IrrTv7tugDLL6HKxsbFUrlyZ+IRVbJz4Av5WK9v0Oj498xcN69zilmNab7sVY9vWaEwmgr7eULqdSOCcl80Kyo3/vEdHRrBw6kRGzZrnDJSXTJvCUzG9eOezFcT2up/OlSsR8OMeVIOBjN4PemDwpWMPDSV58gRUjYaQ5V9iyA72hXA1CZyFEHmpKsGfr6DKuwtRrFbSe/fi0qwZ2MOqlnxXQUFcnjGdrPZ3oklLJ/yFf6O9eMk147RKtzhX69ixI/v376dVndo89NdZAF6yWGlctw77fjqeL//VVdIf6Q1A8JqvS5cTL50D87JaHOlMxRAdGUFsr/udgTJA/LoNjB/Yn/h1G8j84EMAMu7thr1yZXeN2CXMES1Ie/xRFFWl6ry30VxN9faQRAUkgbMQ4hpVJXTZJ1T6+FNHh7hxoxx5p2XpDqbXkzx1IqaI5mhTUqg6c3bZm16A1G11gxEjRjB9+nS6nvmLMGAHcCAwgM2L32Xh1IkkHT/hluOaWkdiua0+2pQUArdsL/kO5L2Ql83mrMGdW0GL/xYnrOb9hDWMH9if/6xZx/CZs1k4dSKTYgexbPQ/qLP/IHZFIb1vjKdGXyZpAwdgat4UbXIKld96120dFMXNSwJnIYSDqhK6ZBkhKxJQtVpSJj9DZs/7XLNvg4HkFyY7cp5PnKTy+/8p+z5lltGlYmNjWbx4MU8PHcI/s2cr5ymQmpnF1PcWER0Zwej+j7jn4IpCWnZgFpywuuTBjt2KKsHzNYV0Drw+p3lxwmpeWfoRE2MHMil2EA/f0zFP/ecup06jB47cWg9brZoeGLgLaLWkTHrGWd85aPVX3h6RqGAkcBZCABC8/EtCVq5B1elIfmEyWZ3vcen+7aGhXJ72HKpeT9D6b/HfuauMO5RAyZUURWHGjBlMadOW2+x2fldgrQqhQYHEf73BbYsDc2R1isZWtQr6P/7EcOynkr1YRXLecyvkd+P6nOZ58Z8xbdgQRmRftMwZN4ol06Y47ixYLARu2AhArTGlq7HtLbbq1UiZMAaASv/5GP3J37w8IlGRSOAshCDw6w1U+ui/qIpC8qQJGDvc5ZbjWBvcxtX/iwWg8vyFZctBlKYXLhMXF0d0dDR6vZ4BV64AsFAFNBrSMjJpe0djt+U3O+n1ZPboBuAM2IpNQRYI5mYvfMY+d07z0317O4Pm3M+P7v8IATt/RHvlKpZb62Fu1tTdI3Y5Y1QH0nv1RLFaqTL7DZSsLG8PSVQQEjgLcZPz3/kjlRcsBuDKmBEY74l26/EyYh7C1LIF2tRUKi35sPQ7UlVUmWV0icjISN577z2iqoXTCzABS4EXnhrMtOFDCQ0OZvsHC9w+joz7ugMQ8P1OlIyM4r/Qrspi0dyK+L1ITDqcZ/FfYRdEQesdFU4yHrzf5V0IPeXq8KFYbq2H/q+zVFq0xNvDERWEBM5C3MT0J3+jyty3UFSV1CcHkvng/e4/qKKQ8s9RqHo9gZu2YjhyrPT7klnGMouLi0NV7SycOI6H/76ABlgO5NQ+GdE3hvgZ0z0yFtsttTC1bIHGZCJg247iv1BRUC3SEMepkBznnIYmOYv/ctI2rg+edX/8id+hI9j9/cns3sUDA3YTPz+SpzyLajAQ9N1mArZ+7+0RiQpAAmchblKay8mEvfwaGpOJzO5dSBvY32PHttW+hbT+jsYXlZZ8WMp8ZZlldIXIyEhGjRjBhq3bGZx9IfK+ouBn0DNzyTIWJ6z26Hgy7u8BQNC3JUjX0GrBbHbTiMqhQlI1ko6fYOHUic5OgTk5z9dXS8mpp53VtVOhjY7KC+ut9bjy9FMAVH5vEdpz5708IlHeSeAsxM3IbCZsxixnc5OUcaM9fjs2vV8MtipVMBw/gW7z1pLvQFWksoYLHNy7hzF9HiLjuy1UA5KAfQYDHSNaEOjvx9rtiR4dT1ZUB+xBgY73xanTxXuRRist2HMrZMZ5dP9H8rVNz1ctxWQicNMWADIe7Om2IXpS5gP3kRXVAU1mJlXnvCUX3KJMJHAW4iZUOe4DDL+ewFqzBsnTpoBe7/ExqAEBpMYOBMBv8dKSN77QalBdUQ/6JhdZqxpvL1/J4OwScPuaNEZnMLD751949smBPBh9t2cH5OdHZtfOAAQVd5GgRiOBc25lqDgTsGs3moxMzI0bYWl4mwsH5UWKQsr40VirhWP45Tih0pJblIEEzkLcZAI3bCTo242oBgPJLzyHvVKo18aSeW83LLfWQ3PuPMFrvy7ZiyVYKjPVZiPqtnrc3/h27gOswJRfjvPMM8+w5J23sZnN7qvdXITMe3MWCSYWK49dURTJd8+tiMC5oCYoiUmHiVuxEoDAjY7Z5szuXd03Pi9QQ0JImfwMqkZD8IoE/KQltyglCZyFuInoT5ykctz7gKOChtdnlLRarj41GICQL/5XspJRGi1YJK+1LGIff4znFy2lyU8/owPWATUjIpg1axaEhDLKS93iLI0aYL2lFtqUK/gdPlq8F0ngnItaaIB8+tz5PAsCcxYMRjZuhCY5Gb8DSag6HVmdO3pj4G5lbt6MtEEDUFSVKvPeRnP1qreHJMohCZyFuEkoaWlUfXUOisVCxgP3kXlvN28PCQBTuzbYmjdFk5ZO4DffFft1ikYjgXMZdWx+B/HffMf/aR1/CvbcdiuHDx+mS5cuHDp0GEIqoXqjZbGikJkduBW7EoLku19jt+frEpgTIMd07pinCUpOlY3oyAgCt2xHsdsx3tUWe6j37kS5U9pjj2Jq0QxtcgpV3pSW3KLkJHAW4mZgt1N13jvo/r6A+fZGXBkxzNsjukZRMMUOAiAkYU3Jcp1lkU+pqRYLTz9wHy90vJuGmVlc0WiYd+p3YmNj2bdvH5GRkVCthtfSYXI6Vwbs/KF47wnpJHmNzZ6vS2DuADk6MoKQoEDe+WwFsb3udywYVFWM2RVUKlqaRh65WnL779lH0Jp13h6RKGckcBbiJhDy+Qr89+zDHhJM8vOTwGDw9pDysEV1wHJrXbSXLxO4eVsJXiiBc2nExcUx+ZkJ7Dz6Ew8kXwHgE7udkPAw6tWrx6JFi0hKSkIJreK1GTlrvbpYbquPJj0D//0Hb/wCm3SSBLKbAjl+Zrm7BDoDZByzzxdSUgB4f+UaEpMOs/qDD6mRcoUMPz+M7dp4a/geYasWfq0l99KP0J885eURifJEAmchKji/fQcI+e8Xjnbak/+FrUZ1bw8pP43GWdc5ZEVC8fNVJa+1VE6fPs3K9et5etZcmp84CUA8cOnSZf744w+io6MZPXo0il4Pfv5eG2dmp+x0jeI0Q5EZZ4dc56GgLoE5KRvLXnqB6cOHYjSaeGLay5hXrQVAvb+HV6rseFqeltyvv4FiNHp7SKKckMBZiApM+/cFqs55E0VVSXviMUxtW3t7SIXK6nwP1hrV0Z09h//OXcV7kVVmGUtDVVUUFe40mqhsNnMC2A00atSITz75hMWLF1/bOCDIW8N0LlDz37UbxXiDlBFJ23HIDpwL6xK4etv3zpSNEX1juLN5U+w2OwM1jnAgs1tnb47eoxwtueuiP/MXlRYt9fZwRDnhksD54MGDjB8/nn/+85+sWrUq3/Nbt25l2LBhTJo0iUmTJrFp0yZXHFYIURSzmaqvzUWTlo7xzrakPe65zoClotWSnl3FIXhNMUvTyYxzqcTc2x2tVkP/7CDrC8Cg1/Haa68xffp0duzINcNbJQzVS4swbTVrYG7SGI3RiN+evTfcXpXg2Rk4Jx0/Qc+o9s6Hc3KeQXF2ClycsJo9x37m6fr1qGG3kxwSguX2Rt4YtXf4+ZH8XHZL7m83ErClBGli4qZV5sDZbrezdOlSnn/+ed566y0SExM5c+ZMvu2ioqKYO3cuc+fOpXv37mU9rBDiBiovXupoclKjOskTxzvqHvu4zO5dsQf443f0GLpTv9/4BTYbqtyiL7GoBrfyr8f60zf76y8Anc5xe37EiBHEx8c7t1UqVfXqBUrWPVEABOz8segNVVVy3sEROKuOLoExne/JU1kD4Judu4hs3IjFCat5ZelHTBs2hLnNmwHwfloai1eu8dbIvcJa/1bnYunK8xeiO12Mzx1xUyvzX9ITJ05Qs2ZNatSogU6nIyoqij179rhibEKIUgr8bjNB679F1etJfmEyakiIt4dULGpgAJndugAQtG59cV4hwVIp7Ezcyb5PPiMc+An4RadFRWXYsGEkJuZtsa34+YFO55VxAmTdfRcA/nv23bi6hrwXstttX1scWFhljR0HDzFt2BBGxDwEm7YCEPrIw+zIbgySuylKRZfZ814yu3dBYzIR9srrKJmZ3h6S8GFlDpyTk5MJCwtzfh0WFkZycnK+7X788UcmTpzIG2+8waVLl8p6WCFEIfQnT1F5gSNH9crop7E0aujlEZVMxkMPABC4eVvx/oCVtFX3TW7Bu+/y/pcr6Zud1vB7i2ZotVqsVht33XUXSUlJ+V/kF+DhUV5jq1ULS/1b0WRm4nfoSOEbKgqqdJJ0pKsoivPrwiprxM+Yzoi+MfgdOkKw0cgJjYbwO9sRP2N6nqYoNwVF4cqYkVhuq4/u7Dmp7yyK5JFphLZt2xIdHY1er+e7775jwYIFvPTSSwVuu3HjRjZu3AjA7NmzCa2gRdg9TaPVyrl0IZ89n6mpBL02B8VsxvzQA+j698UHR5lPnvMZ0QJrq0h0B5OomrgLS78+hb7OrtdhCAlGWyWs0G1uNjqdjvDw8AKfmzdvHiF6LT8mHWZFdmDwR8sW2I+fQK/XU79+fV588cV8rzPVqImadtXR2toL7F07wYfxhO7dj6lrwYvXVLM/usAgdIV876VV1Pn0RVbVhrVSJZTsaijb9x/gk/XfMnnokyxdtZZ7725PpzbXFgn77doNgHpvN0bPeZNhfR5m6aq1fPzKi3m2cxWf/ewMBdOsGeiGjyJg5y7C1n2DZdBj3h5VkXz2XJZDagnuVpU5cK5atSqXL192fn358mWqVq2aZ5uQXLeJu3fvzieffFLo/nr06EGPHj2cX6emppZ1iAIIDQ2Vc+lCPnk+bTbCXnoFzbnzmG9vxMXhQ8HXxliI68+npee9VD2YhPZ/K7nco2ueGbTcVIsZzp1FY5PZoRzh4eGF3tU7duwYa1atYtxt9any6wl+Dwpi5KfL6dYxmhHjxpOUlFTga+12FZIvo+i9U/9b36YV1T+MR7s9kdR//F+B+fqqzQbnz6IxuLZ8XlHn0xfZL11g4cf/JfKOOwCc6RkAZzq0Z/C0Gc50DaxWam3dDkBon4d5smoV5iz7hPED+9OqUUO3fMb55GdnjtAQTM/8k7CZs/FbtIS0OrUxt2rp7VEVyqfPZTmj2mzFnmQqc6pGw4YNOXfuHBcuXMBqtbJz507atWuXZ5uU7ELrAHv37qVOnTplPawQ4jqhn3yG//6D2EJDSX5hss81OSmJrLvvwlalCvo/z2A4cqzwDTVaMGZ5bmAVgNVqpelvjoYPSzIy0Go01KhT11m7uSBKaBWv5g9bGtyGtXo1tCkpGH45XuA2ilZ7U7VgV60W7MkX8z9htRJ5++15Ss8Bedpt51TV8Dt4CE1aOpZb67LtytV8NZ9vRsa725M2oB+K3U7Ya3PR/nXW20MSPqbMM85arZannnqKV199FbvdTteuXalbty5ffPEFDRs2pF27dqxfv569e/ei1WoJDg4u9MNZCFE6/jt3EfLFl6gaDclTnsVWvZq3h1Q2ej2Z93YjZPmXBG7agjmieYGbKVqt10qllUe9H3qIdQkJ9MyukrFSAZvdTqPGjYt+oZ8/KF6syqIoGKM6ELxqLf47f8Tc9I6Ct7uJytGp587AmVOobaNRDH7XnrBaicq1KLBalcrEr9twbZYZnP8GJP4AwC+NGuVZOBjVMiLP1zeb1NiB6H7/g4Af9xD279e4+ObrqMHeq2cufIuiqr6dAf/X+lXeHkKFILd0XMuXzqfuzzNUmzAJTZaRq8OHOmshlycFnU/dmb+o8fRY7AH+nP/vh6j+Bd+CV/0D0DS5+f64F6ao1AJ7ymU++r//44U9+zgONAFiYx5m3feJLFq0iOjo6EL3az+4u7CMGY8wHD5CteemY72lFn9/sKDA9B1Vb0DTrJVLj+urqRr2A7sc58DPH03TyGuPn/4VriSjKApz4z/lnc9WMH5gfybFDsq7A5uNmk8+hfZqKvNjHqZmhzvzBMmJSYdJOn6C0f0fcem4femzsyhKZhbVJk5Ff/p3jG1acfnf00Cr9faw8igv57I8UG026jzUr1jb+n5hVyFEoZTMTKrOnI0my0hmp46kP9Lb20NyGWud2piaNkGTZcQ/sYhOgtIEpdh2bvyWkH0HAFgFGHQ6Vm3awtixYwuuppGbv/cqawCYmzXFFhqC7uw5dH/m7xUA3DTvBXvaVTCbHIs1M9PzPmmzoShKge22czP89Avaq6lYa9Wk39P/l29mOToywuVBc3miBgZw+aXnsVUKxX//QSp98KG3hyR8hATOQpRXNhtV5r2N/sxfWG6tx5UJYwpdRFdeZfboBkDgxs2FbyS1e4tt9TcbiMluGGO4txt+BgNWm42TJ0/eOIXOzw+v3qDUajG1bQOA/979BW9zs7wXLp53pM8AWK15y/DZ7YW2284dPAdkt7XPimpf4T43XMVWozrJ055D1ekIXrOOoLXF7GgqKjQJnIUop0KXxROwaw/24CAuT3uu0FSG8izrnmhUgwG/Q0fQ/n2h4I1uorzWslDtdm69cpVbgazgYB4dN5olr7yErrjNTYJDvb74znhnWwD89uwreAP7zTHjjMl4rTSgoqBm5Jp1tttJOn4iX05z7kWBqCr+2YGz8e4Onhx5uWNu3oyU8Y6LykqLlhCwPfEGrxAVnQTOQpRDgeu/JeTL1ahaLZefn4yt9i3eHpJbqMFBZN3dHkVVCdy8reCNrNIApTjUzAy6ZzeUsd8TBRYLUQ/0YunSpdSvX/+Gr1eCQhztnL3I2LYVqkaD39GfCm6OY7V6d1bcU0zGa/+vN8DVXE3HVJXR/R8pMPUCHLnL+t9OobtwEVuVKmwxmW6aDoGlldW9K1eHPomiqlSZ9zZ+B26Q1iQqNAmchShn/A4kXesMOHakT9cZdYXMe7PTNTZtKbibl11FleC5UHFxcY422imXuCfNMTO5r0Z1Fq5ehxJSucgydHn4ef+OhhoSgvmOxihWa8HBi0qFz3NW7XbIlZqhaDSQmXFtgyJm3SMbO6pnXFy5BoDTtzdk1Otv3jwdAssgvX9f0vs8jGK1UvWV2eh/PentIQkvkcBZiHJE98efVH1tDordTlr/R8i8v8eNX1TOmSIjsFWtgu7sOfS/nihgC7u03S7C6dOnGTZsGEmrV2M4dRqLnx99v/iS08kpJeoEqGi1jtlNL8tJ1/DfU1Ces73i5zmbTfkvIHPPQBdxVyAnZUPZ+j0Ak48cu2lLzpWYonB1+FAyu3RCk2Uk7MUZ6M785e1RCS+QwFmIckJ78RJh02eiycgkK6oDqUOe9PaQPEOrJeseR5m0gG07CthAQc0dOIg8YmIc5Ql3zHsbgDVWK2YFYgY8XvKd5a4X7CXOwHnvvvwBpEqFz3lXM9Lyd040m1Fzvm9r0XnonapXo5ndzhWg/kMPSNBcEhoNKc+Mxdi2NdqrqYRPmV54hRdRYUngLEQ5oLl6lbAXXkZ38SLmOxqTMnFCgW2HK6rMzh0BCNyemH9GTaeDrALyXQUA0dHRLFm8mAezA6vVCix58Xk6dutW8p35QOBsva0+trCqaJNT0Gd3QHTSaFAtpoJfWFGkXQWd/roHVTAZHfndN7j7cnbVVwCcqleHZd9856y0EbdiZb6SdYlJhyX/+Xp6PckvTMbUsgXa5BRH8PzHn94elfCgm+cvrxDllJKRQdi0GY6yc/Vv5dK/p6P6ez+A8SRLk8ZYa1RHe/kyhqPXteDW6sAkbbcLkpPf7Pf3OaJUFTPwtQqrdxdSzu1GAgJRvZ1DrCgY2znK0uWrrqHVQlYFfy8Ysxx5zblpdaipVxxpHEXkOCcmHeby+g0A1H/0kTxl6nLyn3OC55ySdpL/nJ/q78/ll6dhjIxAm3JFguebjATOQvgwxWgi7OVXMZz8DWutmlx65SXUkGBvD8vzFIWsTo5Z5+vTNRRFAVMFn2UspdOnTzN06FC+nvQcWuBo1SpcttlYvmatY8FgSYWE+kQVE+Od7QDwzxc43wQXUeYC3us6HWSkomZlAIXnrR879jNds//f2LZNnjJ10bnadM+N//SmbrldHKq/H8kvvYCxVSTaK1cJf24auuvvgIgKSQJnIXyVyUTVV2bjd/QnbGFhXHrt39irVvH2qLwms8s9AATs2Jk/j9UHgjlfFBMTg8VioWf2+fooLZ0Af3/0ej2rV68u8f4U/4CCK5t4mKlVS1SdDsPPx9FcvdZyWFEUMHu31rTbFfBed148pqUWuYBzbKMG6KxWzLc3wl6lMpC3Q2B0ZASxve7nnc9WENvrfgmab0D19+PyS1MxtmmF9moq1SZPw3BduouoeCRwFsIHKUYj4S+9gv/+g9hCQ7n06kvYalT39rC8ylr/Viz16qJNTcPv4KHrnqzYC8JKo1OnTqxdu5aBfftyb/ZjK61WKlepwkcffVSs2s35GPx8osucGhiAqUVzFFXFb//BvE9W4Koaqt0OlkK+P5MRsjId1U8KkTNDn7PA8no3atMtCuDnx+WXniezYxSazEzCp88oZBGzqCgkcBbCxyiZmYRNn4HfoSPYqlTh0pxXsNar6+1heV/udI3ru3fZZMb5eqGhocTHx3PLzz8TDCQBf6gqQUFBxa/dfB1Foy1gYZp3GO/Mbr99fbpGRb6IsphxlA4p5Lmi0lRUNVfg3Cbf08Vp0y0KodeTMuVZ0nv3ctR5fv0NQj79wusNg4R7SOAshA/RXE4mfPI0/I7+hDU8jIsSNOeRdU8UAAG7ducNkKxWx2yccGrWrBlarZaaSY5GIeuyH//9999Ll9+cwwdqOQOYcsrS7duft+mJl9uCu5NqNhUaNwNFVpfR/XkG3d8XsFUKxXJ7/gV/N2zTLYqm0XB1xDCuDhuCqiiEfvI5VWfPQzFKqcyKRgJnIXyE7o8/qfavKRh+O4X1llpcmvNqhW2lXVrWunWw1K2DJj0dv0NHrj2hqpLnfJ2YmBgUoFf21+uAgIAAdDpdqfKbnXwkcLbWvgVrzRpo0tLzdnGrwKkaZGWCrpBUDK2uyIsG/72OSiqmtm0KLGVZWJvunPxnUQyKQnq/Plx+6XnsAQEE7PiBas88J7WeKxgJnIXwAX77DlBt4lRnneaLb8zGVrOGt4flk7Ki7wbAf+euXI+qFXqmsTSio6PpWrs2jYBLwC6gY8eOpc9vzqE3OOoFe5uiYGzbGgD/3HnOdvVaM5CKJjPDESAXQNHrISik0HrMl9Z9AxScppFDajm7humudlx863UstW9B//sfVBs3kYBNW7w9LOEiEjgL4U2qSvCKBMJeegVNegZZd7fn0mszsFcK9fbIfJYxugMAAT/8eO0WvVaHmpHuxVH5nilTptDijz8A+AZAo+G7775j7dq1pcpvdgoM8plZXVPrVgD4HTiY61H1ht3zyi2zKX8N51wURSmwHvPk1+ZS/8JF7IrCdkPeOwa5A2Op5ew61np1ufjOPEeLbpOJqm/Mp8rrb6JJTb3xi4VPk8BZCC9R0tKp+tpcKn0Yj2K3k/rE4yS/MPmma25SUpYGt2GtWQNtyhUMP//ieFCnh0wJnHPbtGkTD2dXwLDf24OgoCD0ej2bNm0q246DQgqv7OBhpsgWqBoNhp9+QcnMzu9VVVRzBU3bKUY6UkH1mP8b0wutzcblenUZ9k5coYGx1HJ2LTUwgJRJE0gZNxq7nx+B276n+qgJ+P+4x9tDE2UggbMQXmA4fITqY58hIPEH7AEBXH5xKmlPPHZTtdEuNUUhK2fWOXFX9kOKoxyXYN68eSQmJvJgdDQdVRW7ohA6cBC9e/fG39+frl273ngnRVD8/YvqseFRalAQ5jsao9jt/Lba0UoanQ6MmSQmJhIXF+fdAbraDdpp57i+HnOri5cAMHS5h4VTJzL05VcZP+/tPIFxzsyz1HJ2MUUhs+e9XFjwFqbmTdGmpBD279eo+srraC9c9PboRCnIX2khPEgxGgldsozwKS+iu3gJc5PGXHjvTYwd7vL20MoVY5QjcPZP3HWtIUdFb3xRTO3atWPkyJG0OHsWPXC5wW0MmziRmJgYli5dWrb8ZnAsDvSBWs45TG1aAfDL5/9zzKRqdezc8T0jR44kMjLSu4NztWKWXcxTj/mrb1B++BEAU7u2REdG8GB0B77cvI2u7Vo7g+acmWep5ewetltqcWn2TK48/RT2AH8Cdu6i+oh/EvLZCpSK3ia+gil4lYEQwuX89uyj8oLF6C5cRNVoSH3sUdIGDXDMkIkSMTdpjC2sKrqLF9H/ehJL40ayODBbly5dWLRoEZYnnwQg7uw5Fn30EdHR0QDOf0tLURRUH6nlDGBs04rQTz6nT4A/jWfNI7bX/cR//S1jx48nKSmpzN+vr3A2PylkcWCO3PWYoyMjeKBaNQLnx5EVEoKlQX0Skw6zZe8B+nXrTMKW7ajA1r0HWDh1IkCe10a1jJB0DVfSasno8zBZHe+m0gfLCPw+kdD4Twlau460xx4l48H7Qe87v1uiYDLjLISb6f74k7CXXiH8pVfQXbiIucFtXHzzddIGD5KgubQ0GrLubg9AQOIPjseslpu+lnNsbCxvv/020XffzcMax6zwb02bsmjRItceyEdK0gFYbm+E2d+fsNQ0Hmt+B+98toIud7blvffeq1gzzhYLRRdxdri+HnOH7JbkR2vWIPHQEWcg/M7ECTzStRMJm7fRJXvmWWo5e4Y9PJyUqRO5OGsG5sa3o71ylcqLl1Jj+BgC13/raJ8ufJYEzkK4ifbceSq/s4Dqoyfgv2cf9gB/rj41mIvvzHXMkIoyySlLF5D4gyNdQ7Xf9LPOf/zxB8899xyLhw8nxGjivMHAx/v38/PPP7v2QL40K6bVYssuS2f/YTd3NW/Kyk1bGDt2LEDFyXO2FtE1MJfr6zH773V0C7xtQN88gXFi0mG27j1A326dWZ+4i8Skw1LL2cPMkRFcfOt1Lk+fguXWuuguXqTKuwupOeQfhHz0XzSXk709RFEAme4SwsV0p34nJGEVAVu2o9jtqBoN6b16kjboMexVKnt7eBWGuUUzbKEh6M6eQ/f7H1hqVkc1ZqH4+Xt7aF4zaNAgZsyYgbJhAwAJ2XnfKSkpJCYmui5tQaf3qcWYR6tXox1wv6Kw+OhP9OvckbfeeguApUuXendwLqIas0BTSPOTQihp6Rh++gVVp8PUOpLR2Reb16dzJN57WFIyvEVRMN7dHuNd7Qj4fifBCasxnDhJ6Bf/I+R/K8mK6kBWt86OmuVyh9InyE9BCBdQjCb8d+0maN03+B09BoCq0ZDRoyvpA/phrVPbyyOsgLRajB3aE/TtRgISd2F5rJ+jJF2lKt4emdeMGDGCPXv28ND69YCjW+CLL75IixYtXJvv6x+AmnoFRVuyQM5dtmq1tAO6qipBej1f/7AbNBr69utXYXKcMWZBCc+3//4DKHY7xojmqIGBzseLSsmQwNlLtFqyutxDVueOGI79TPDqtfjv/JHA7xMJ/D4RW2goWZ2iyercEfMdTUr8XhCuI4GzEKVlseC//yAB23bgv2s3GqNjBs4eEEBm9y6k942R7n9ulhXdgaBvN+L/w4+kDhoAN3ETlLi4OCIjI3mgye20W7+eTGAzYEpMZMSIEa4NIAODHTWFfeSP94H0DE4oCo1UlVe63MMz323G4EvpJK5gMpZ4xtl/T3ab7Tvb5nm8oNSL6MgICZp9gaJgbt6U5OZN0V64SMDW7QRu3ob+jz8J/mo9wV+txx4cjLFtK5ROHdHc0UTuZHqYBM5CFJeqojvzF34HD+F/5BhB+w6gyWm6AJgb307mvd3I7NoZNTDAiwO9eZgiI7AH+GP47RS6CxexGm7e5jGnT59m3rx5DMpeWLQ7MABjZhabNm1i8eLFjBgxwmXHUvwDfKPttpPKZq2WRlYrmVu/p2+3ziRs3sb58+dJTEwkKSmpbN0SfYHV4qhXXlx2O357HYGzsV3hbbaF77JVr0b6gH6k9++L/rfTBGzZRsCu3ejOniNw2w7YtoMAwHpLLUzNm2Ju3hTzHU2w1r7FZy5qKyKXBM4HDx7kww8/xG630717d/r06ZPneYvFwnvvvcdvv/1GSEgIEyZMoHr16q44tBBuo7lyBf2J39CfOInh15MYjv+K9rrFGuYG9cm6pyNZnaKx1arppZHexAwGjG3bELhjJ/4//Eh673Bvj8hrYmJi+Oyzz+iV/fVqmx0/Pz9MJhOffvqpSwNnDAZ8pgsKMGfcaBad+A1OnKSL1crsXXuY/tRg5n22gh07dhAfH+/tIZadtWTdGvW/nkCbmoq1RnWsdeu4aVDCIxQFS8PbsDS8jdThQ9H+dRb/PfsIPpCE5tARxzqPs+cI+m4zAKrBgOXWelhuq4+lfj1stWpivaUW1po1fGthbzlV5sDZbrezdOlSpk2bRlhYGFOnTqVdu3bUqXPtF3Xz5s0EBQXx7rvvkpiYyH//+1+eeeaZsh5aiNJTVZT0dLSXk9Emp6C9dBntpcvozp1D99dZdH+dRZOW/7a/rVIoplYt0dzdnitNGmOrIReA3ma8uz2BO3YSsGs36Q/ci2q3oZTwlnZFEB0dTZvGt3NvdhvydUB8fDxHjhxhx44dLj2WotOjanwncAY4V/9WLCdOcpeqEmS1cOy3UxizsujWpVPFyHO22Uq0eU6ahrFdG59qWCPKzlb7FjJq34J28BOkJiej/+0UhqM/4Xf0J/QnTqK7cBHDrycw/Jq3jKCqKNjCw7HVqoEtrCq2qlWwV6mCrWr2/4eGYA8ORg0OQvXzk/dNIcocOJ84cYKaNWtSo4YjlzMqKoo9e/bkCZz37t1L//79AejQoQP/+c9/UFW1WLeddH/8mfeBgm4PFvhYQXsr5msBpSyvL+i1hd7WdO33oxRyHE1gEIaMjGKMyR3fTzFfX8Bjhb5DbDYUiwUsFhSLBcVizf+12YySmYkmPQNNZiZKegaazAw06Zlo0tJQbtBpzh4QgKVBfUed2EYNsDRq6Fjkp9EQGhqKLTW1yNcLzzDe2RZVq8Vw5Bia1FRUoxECg7w9LI9TVZW5Ue0J/fkXDgN/Zn++jhgxwrWzzTl8bObqvu5d2LVpC/eoKlEWK19u/Z5+XTszoEtHFrz0AqNffqVkqQ6+xmoBTfEryOaUoTNel98sKhidDkvj27E0vp2MR3oDoKRnoD91Gv2p0+j+PIPu3Hl0Z8+hvXAR3UXHfzei6nTYg4OwBwWhBgWh+vuh+vmh+hlQ/fyw+/mBwYA9+zG0OlSdFrRaVK3jX7Rax2Mabf7nFAUUxREeKApoFEDJfpw8/68q2c9dv03242qu/y8waCjo9/66x9QSXJiWOXBOTk4mLCzM+XVYWBi//vprodtotVoCAwNJS0sjNDT0hvuvMXJcWYcost18oUTR7AEBjqvusKrYqzr+td5SE2vtW7DWru1YcFGe/9DeJNTgIEwtW+B/IAn//UlktmyLchMGzokbv+Pix/+lC/B382bo//iTYcOGsXTpUvfMuOoMYCtZ+oC75JRXW96mFew7QA9VZbVGw/ofdvHtj3tYMvVZ1L9+R6lT39tDLT2bFTSOxjNxK1YS2bhRnsV8iUmHSTp+gtH9H0GTcgXD8ROoej3mlrLg72ajBgdhjmiOOaJ53iesVkfwfP5vtMnJaJJT0CanOP5NSUGTlo4mPR1NegaK2Yz2ylW0V65655vwhtETirWZzy0O3LhxIxs3bgRg9uzZ2OrXK2CrG189FP5YQUctJDhy9T4LC8Jcvc/iXnEV8rha4HHKts+Cx17M1xb0mEYDej2qQe/oYub8fz2qwQAGPRgMqIGBjttOwcGQ/a8aFIQaGgoFLODTUbxfCo1WW6wLP1E8ZT6fXTvDgSRC9idhGKZgCL/5cp3Xr17FCzZH58SOL07jf5XDGDBgABs2bCAmJsblxzOFV4OsjBtv6AG//PEnH7/yIqs/+JDuwP04JmksVhvoFNbv2c/9HdrjHxqBUsIFpDqdjnAvv59UmxVjYCCaAEdJuajWLRny4kw+mjGdTm1as33/AUa//gYfzZhOaGgousRdANjatCKkejVvDj0f+ex0nVKdy6pV4Y4mzi9VwJb9Xx4mM0p6Okp6OqSlo5hMYDSiGE1gMqKYzI6vTSYwmlBsNkc6kdXq/NfxmN35mOJ8zuY4sprzX/ZI7HZQQbn+OVXN3h7HNuR6PPdzxc1IKOg2uF2luAl+ZQ6cq1atyuXLl51fX758mapVqxa4TVhYGDabjczMTEJCQgrcX48ePejRo4fz6/Nx75R1iAIIDQ0lVVILrrFaINVS6pfL+XStsp5PTauW1AK0u/dw9ffTKGE310JN1W4nQrXRSFWxhwRzuVUbWgSH8MEHH5CUlMSlS5dcfkx7RiakXfWJ9IenHn6QxKTDfPDTL7wMNADqWCyc0elQUTGbzaRlZZF29BCaureVaN/h4eFuOX8loZqMqGmpKBbHDH+rRg2Je+5ZBk+bQWyv+4lft4GFUyfSqlFDUlNTqfJ9IgDprSPJ8LHPKfnsdB23n0u9DqpUdvxXwak2G8VdQlvmltsNGzbk3LlzXLhwAavVys6dO2nXrl2ebdq2bcvWrVsB2LVrF82bN/eJD1shRMVgDw/D3Ph2NCYzfj/u9vZwPCouLo7E7zbwVBVH4xfbne1IPJhEXFwc0dHR7ivD5u8P9pItWHOnpOMn+Gjmi5y9rT4AT9eqicVqJSoigjnjRqPodJB849xOn2TNf5EfHRlBbK/7eeezFcT2up/oyAjiVqxk5/6D+O8/AIDxzjYkJh0mbsVKT49YiAqrzIGzVqvlqaee4tVXX+WZZ57h7rvvpm7dunzxxRfs3bsXgG7dupGens4///lPvvrqK5544okyD1wIIXLLurs9AAGJP6CWsHRXebZu3TqGjh6LMXuW8UjdugwdOpR169a598ABQSUukeZOOU09Pjh3HoDG587zSLfOHPjlOIlJhx0bGTOx+0h6SUkU1G47Mekw8es2MH5gf+LXbSAx6TCRjRvx4Wtz0aRnYKlTm+0XLjFq1jxOnzt/7Rzker0E1EKUnEtynNu0aUObNnkLrD/22GPO/zcYDPzrX/9yxaGEEKJAxrvvotJHn+C/dz/q1RSUMN/K7XSXhx9+mJMHD1L1xG/YFej9+XKMZjO9e/d263EV/wBUuy81QXHMOl9sfDscOkxPvY6Re/Yz5rF+rN72PUnHTzCqXwz8fRbq3+7toZbMde22cxZD5rTNjmoZ4fz6jbvawtbvSQwKdD4GMPTlV5kYO5ARfWOcrx8zoC9xK1YW2ElQCFGwMs84CyGEL7DWrYOl9i1o09IxbN/m7eF4zNMDB7C46z0YgJ0qnDGZmD59untK0OWmN/hSDxQAIhs34quTJzmuKARYrHw6aABvf7actdsTiWzcCEWjgfQ0bw+z5K5rt510/IQzaM75esyAviz6chW1fj4OwCu//ErT2251Pj8xdiCvLP2I8fPedgbNC5YnENm4kee/HyHKMQmchRAVg6JgzEnX2LTZy4PxoL/P0j7V0axnHY4qEC1atHD/cXW6EtUV9oSk4ydYMm0KSoe7ALAk/gAqPNwp+lrptqwMVLvdi6MshevabY/u/0ieUnSRjRuxYHkCD97ekMrn/yYd2GvQs//n4wx/ZTaRjRsxom8Mfbt24svN22hUtzYLlifkCb6FEMXjW596QghRBsa7HQFTQOLOIpr0VAxxcXEkJiayc0ciQfsci8GO3VILq9XKkCFDSExMdOvxFUUBrW9VNM0JKKve1x2ASkeO8VRML+aMy7VA0m5HTS9nVR2ua84Qt2Jlnpzl6MgIxgzoy2/LEwDYCHTvGIVOp3VW3kpMOsyWvQe4q3lTdh/9iS7tWkvQLEQpSOAshKgwzE0aY6tSGd2Fi2gPJXl7OG4VGRnJyBEjWP3Bf6gBXPb3Z0d6Bk8//TRGo5HFixe7fxB6g/uPUQrbFAUzcBfw2YqVLE5Y7Xxu58/Hee6554iLi/Pa+ErsukWYkY0bMWrWPGfwnJh0mAXLE+jn76hR/VOtmiRs3sZTvXuxZPoUVm/73pmeceLPv+jbrTMrt2zPc16EEMUjgbMQosKI+3I1p2935Gz6r1kDQGJiYvkKkopp0aJF9OrciSZnzgKwxmaj1wM9+f3335k+fTqqJ2bcdb414wyOIPIfb77LldvqowW6K/DKkmUsTlhNYtJhhr8yh7WbNhMZGentoRbfdR0aoyMjWDh1IqNmzWNu/KeMmjWPcf1iaJ+RCcDCc+fp260z8es2AFC/Vi1nTvPCqROZP3EC04YNYV78Z/mqbQghiiaBsxCiQlBVlcj6dZl6+CgAARs3kpiYyMiRI8tXkFQMcXFx1K5dm09Wr6F/9izjvrCqxH+xnG7dujFixAji4+PdPxCd3v3HKKGchXN+nToCMLxGDfR6PbM+jGfIS6+AAhMG9OPgwYPeHWhJFNDaPHcd5y7tWnPwiy8JBo5qNAwdPpStew8wZkBfRs2aR2TjRths9jw5zSP6xrDs5RdIOn7Cw9+MEOWbBM5CiIrBbCbpagbNH3+UdMBw4iSv/eMfjB07lqSkipW2ERkZybp16+jfsjlNM7PIAv5z/m/uvfdeJkyY4LmBGAw+t9AuJ8/Z1KYVAO3TM9AqYLXZMJrN3Nv+ThZ8uYrIZk29O9Ai5OSvg+OCEJstX93l3HWc1yfuYmIDR0dEzT1RjOgbw8KpE9lx8BBjBvQl6fgJ53nJvZ/oyAgpRSdECUngLIQo91RjFjSNoFWHKOavXkdStXAA/lmvHu+9916Fm3GOjo5mzNBYgpKOALAZCK9Vk3379jm7tHpEYFCBs6G+wNLwNmyhIQRduUKj7KwVrUbDys3bGNOvD1HNmnh3gEWIjIxk5MiRjuDZamXnoSMMfflVtFrHn+zJ8xcy/JXZjBnQlyD/AJa9/ALhR48BEP5gT8ARFI/s1ydPybmc+s1Sgk6I0pPAWQhR/vn5owmpTHR0NGPHjmXBxUsANDh8mLFjxxIdHe3lAbqeLS2VgUFBACQGBXHm/N/06tXL2bHVI/wCweo7bbfz0Gj4q359AO5ToEXDBtjsdvQ6HW8v/5KdW7f6bP57dHQ0ixYtYuTIkcydN5dRb8xnYuxAFixPyM5JVrFabbz92XIiGzciKDmZJqpKhk6Huem1C4LcudCPTX2R4TNn50nXkO6BQpScBM5CiHJNtdshpBLgWAg4b948EitXxgzcA3w6fz6LFy9m8ODBxMbGenWsrqKqKmd//4P2GY720esUePLJJ/nkk0/QeXDBnmLwvSYoAGqm47zsCQ0BYHjNmvx+/jz+BgM6nZa7mjVj9XcbfTr/PTo6msGDB/POewuIva+HM/1i1Kx5VKtS2Vlqbuehw2x7dxEAyt3t8y3YzMmFTkw6jDXX3QGZfRaidCRwFkKUb2YT1KwNQFJSEv369eOPK1fYAmiBSc2a8dprr7F582Y6duzo1aG6SuKmjZzduIVQwHJrPV6YPoV169bx5JNPsnmzB5u/6PT4WuSsWsygN6DabEQ9/X8A1P7jT/4zZSIf/XsaWo2W7w8m8b+Nm1m4cKHP3o1ITEzk448/ZvzT/yD+240kJh3OsyDwqd69eCqmF+98toIhVSsDYLqzTf79ZOdCR0e2BEVh+CuznZU4cvKfhRDFJ4GzEKJ80+lRAoOBa4vmunfvzlfZXe2q79yJ1WrlySefxGbz0bSCEoiLi2P1l/9jfnazl6w720BAEA888AD16tVjTXYZPk9QdDrQ+FbgjGpHaRYJFjP28HBOGgyEAGF//El0ZAT3drgTs8VCleAQotvmDzR9QU41mEWLFjFx2FAWPvcso2bNY3HCaueCwP+sWcd/Vq9jYv++NDh7HgDjdd9PYtJhhr78KmMG9GXc44+i02gxmc2889kKbqkWJi23hSgFCZyFEOVbQKCzHXFSUhKLFi1ixIgRrDc4mnPcB9QLD2fdunU+e1u+JCIjI/lm63Zu+flXAPaGhjDqpZnExMQwevToG7zaDXytJF1wqONCKiAQANudbQHY+2E84+e9TcLmbRj0ejJNRhI3b/LmSAuV8z6Ojo4Gk4moVi0ZM6Av8+I/Y+HUiUS1jHB0BFTg4cBAAoADGg3f//Fn3v0cP+HMjQaYMGgAZosVRVE4evIUrZvcnu/YkvcsRNEkcBZClFuqqoJfgPPr0aNHO2+9n7ZY+BEIBFpfukSvXr0AfHIxWElEtW9P/NAnCbl8mQyDnsdXrGRhTpDlDT4UOKtmE4TXdHxROYy45V9yPrshTlebjS83b0On1fJo9y4smTaFUZOec3tr8tLI/T5e+Ml/2XnoCDabnWUvv0B0ZASrt33Pw506smTaFAw/7gHA0KWTM+0ipyX36P6POHOjh778KrM+jMeg16GqKo9068zuYz8xfObsPB0IJe9ZiKJJ4CyEKL8sZqhUOc9DiYmJDBkyBJvNRk5D4b6KQnx8PLGxsezatatcB8/q1WSi0tMBWG22MKj3Q97N3fal7oGqHSV7oSihlYi87VYGfbkKq0ZDG1UlDEc9Z61GQ3Srlix8fjJJSUk+W10DIPL2hs5gNjoygsnz41i7PZGYzh2JbtmCdikpAGwPDHDWZL6+JTeAxWrFarOhUTSMH9ifrXsPMGHgAB7uFJ2nA2HuqhtCiPwkcBZClF92O0pwaJ6HkpKSaNKkCY0aNSLnhnMvVUWvKJjNZnbs2FG+UzYuX8C09XsAbO3vJH7dN96dNfWhGWcUDfj5O/43IIioiGbccUcTttrtaIAHdFoMej3xX29gyEuvEtWssbNmsiffE/bLF7Af+AH7r0cLfD53A5SoiBYsnDqR4TNn89jUF1m7PdG5HlN35i90f1/gkqIQfnd75+uvb8k9/JXZ6PU6/A0G9HodUS0dzy9YnkBM53ucCw5je90vQbMQNyCBsxCi/NJcC5RyjB49mueff56///6b3/39+QUIA6JUFVVVee6553y2kkJx7N20ibDfTmHXaOg2+h8sjFtwrVmGN+h9qHugf4Az3x29wRFIo/Jt9tNj6tXluSFPALD9wEHmffypcxGep94Tqt0Gp46jaLRwJRn7+bP5tsnTAMVmAcBqs5KYdJinYno50kxmzeOHRUsASI9sSVTrvIF/7gocFouVR7p05qN/T3O+FmDh1Ims3rbDueAwft2GPLPUQoj8JHAWQpRffv7XAqVckpKSWLp0KVHR0azKfqwPUL9+fVq0aOGzt+WLEhcXx45tW7Fs2Y4OMLdsQeJf5zl09BiLFi3yXlvxgADwlWolhmsXUYpGA3oDNcLC+N7gmBWv+9tp3v7vF0wfPpS7mjfjnRUriR3Q36MXUurZP8mZMlYMfnDud+dzOTPNuRugjJ/7NrEvzkSn1TmDW4DYXvcTesDxMw+9r3u+4+QuQ6fX6xypHZERztnonHzob3buYuHUiUyKHeScpZbgWYjCSeAshCi/rpttzpFTXeKHH37IEzifPn2aIUOGlMtUjcjISEaNHkOHlCsAHKtbm1Fz3iAyMpLo6GjvVNQA8A/0ibbbqs0GQcF5Htt57Be+2bmLhl27cEWvpzbQyOoY66ETJ4iOjCD+8889Nluvqir8fRZFnyu9xWTCnuHIWc890xwdHU2XLl1I2Po9qqqyZPoUZ3A7fOZsvlz9FZ0VBSuwzd8PuLYoMGeR38KpExn3+KM8fE/HPAFxdGQEo/s/QtLxE3lymq8PqoUQ+UngLIQol1S7HfwDCn1+9erVWK1WfgTOAfWBSMBq9X6QVxrR0dG8/9yzVDn2MwBDtmxn4fz5Xk87Ufz8QFW9OgbAsVA0tHKeh5JO/sbCqRNpULc2X1kcKQ/d7XZmL4vHZLbQ7c62LJz2vDNYdfciQTUzA6zmvA/6+cP5M8C1VttDhw7l8ccfZ+XKlTS/rT7+fgaOnPyN2BdncuTkb6DAoEqV0Koqf9aswROvv0li0mG0Wg1DX36V1du+Z+HUiQCMmjWPmM4dCwyIR/d/JF9Oc05QLYQomATOQojyyWqFwOAbbtagYUN2V68OQD+Nhk6dOrF48eJy2X67c2YGwcA+oHuvB+jYvYe3h+RYHKj4wp8SxdkIJ8eop/4P7DYWLE8goPM9APT2M2Cx2njs3m6O+sYWE4sWLWL16tXuXyR48Rzo/fKOWqOBK8nOr6Ojo2nbti3ff/89HaPu5ps3XmPCwAG8svQj6lSvxrz4z5gwcACjatQA4IPkZCbGDmT1th0sWJ7AxNiBfLPzR3YeOpynSoYExEK4hi982gkhRMnZrSiBQYU+Xb9+fT755BOioqJYeOECADFAcnIymzdvpnbt2uUq11k1ZpK6bj0Af7doTvw33/lEDWJFp/eNrtt6naOTYW4hlUj6+bijacg/hgLQNjOLx7rcQ90aNbJzeueSmJjI+vXr3b9IMPUqilab/3GrGdVkBBzlFPft28c999zDjp0/MP6dhSxYnsC0YUOoW6MGy15+gYVffEm1Yz8B8I1GS2pGhjNXeUTfGKmSIYQbSeAshCinFDD4FfpsTs7vunXr+LNhQ1KBlnY7KQcO0KNHD1atWsXp06c9M1QX2Pn1OkIOHAKgzbBYFr7ztneraeTmCyXp9PnfC4p/IKMeeZjoyAi+//Mvjmg0BAKW3fucdZFj7+/BO++8w+DBg90aNKtWC2RlFPykVod65bKz1fayZcv4/PPPeeSBniRs+54u7Vozom+MM7ViWvt2BJnNXAwOplOfh/IEyTmLAqVKhhDuIYGzEKJ80mhuGLDltC5+edYs1mc/NigwkO3btwMQExPj5kGWXU6lhZQNG6imqlhr1mB7RiZJx3/1bjWN3PS+EDgb8j9mMIBG41wsp+3kCIxntWrJqFnzWJywmvgNGxn/j2F8/PHHbr0IUa+mQAEVYAAUvQGupORptZ2YmMjWnTvp27Uz6xN35enup253jHO50cjCL1fTr1tn4tdtYHHCakbNmseYAX0J8g+QKhlCuIEPtXwSQogS0OoKLEWXW86s8+DBgwkHHgPuzcxkjk7HM888Q1JSktcX193IunXrePPNN9nfphUAJxs1YOgrc2hyxx2MGTPGN8av1YHdfOPt3ERVVfDPX2FFURRUvcFZPSJcr4et39Pgt1OM6f8I8+I/Y9lLzxMVHUX0vfe7t6ZzyuUi75CQleF8v+bMPC98aRrRTRo5A/8xA/qyYHkCv1WpDH9f4ButFp0C3+7aw4RBA5gX/xmPdu/CguUJztzmnEWBkrIhhGvIjLMQonwqaIaxAIsXL2bTpk1sNhgwA/cAlaxWXn/99XJRlq53794Ys7LQJ/4AwJgf92A0mejdu7eXR5aL1stzMBZLvlJ0TgY/Z4qDucnt2EJD0J3/myrJV1j28gtEt2oJRqOzooXbZvCzMou+0DOZHOkcXLtTEtWyBeCodNEzqj1rtyfy8YhhVPr7Aka9nnaDBtCnS2ce7hTNguUJPBDdgf9t2pqvxJwsChTCdSRwFkKUT8UMnHfs2EFsbCzpWi2bAS3wMGDJLk/m60aMGME7Ax+nIXAR2GKxMn36dEaMGOHtoV2j0ztmfb3FbkUJCin4OcO190lcwhp+CHYE2E9VrUx0ZAST5y9k6AsvsWDBAmc9bFeXpVNVFYyZRW+kKKhpqYDjTkl0dLTjgiBbTOd7+OP839T6+TgAF+9ozPwvVxPTuSNzxo0mttf9JGzextN9e8vsshBuJIGzEKLcUVW12Hm18fHx2O127HY7Rxo2BGB0zZoEBQWxePFin66skZPf3CX5EgBrATQaTp486dVx5ePvD3Zvdg/U5OkamEdQCGp27e7Ixo1Y9LejwspfCWtYnLCaVVu3sWnvfn78YSeJiYlMnjzZ9WXpjFmQ3ZY8p0lJbolJh1m4Zh1cuZz3dbkay+SkXaR8/Q0As3496ZxZLu6CwMKOHbdiZVm/QyFuGmUKnNPT05k5cybjxo1j5syZpKenF7jdY489xqRJk5g0aRKvv/56WQ4phBCOFs9FlKK7Xv369RkwYABvZQecLc6fZ0CvXuzcudOn0zUiIyMZNmwY1g0bAdgbHo7dbmfFihW+UU0jh3+gd9tu67T5S9HlCApxztxGR0bQbNAArEDjlBTmL1mG1WYnwM/Azh92MWTIENasWVOmPOeci53cEjd+y8LV6wBH8J57wV5O/nJk49sh87qqG9d1ZOx4eyM6qyp2oMoD9zmD5px6zTdqm134sRuV6nsV4mZUpsB51apVREREMH/+fCIiIli1alWB2xkMBubOncvcuXN57rnnynJIIYQAqwUCih84R0ZGsm7dOpp2786PikIAkPz550yaNAmAyZMn++TMc3R0NF1r30JrIF2jYZXZRGxsLBaLhcWLF3t7eE6Kf4B3A+ciFt0p/gF56kwPGTiAXypXQgfcD5gtFh6MuhtUlaysLIYNG1amxYG522aDY6HfqOeeJ/KOJsC1meNRs+YxN/7TPE1KMGY596Pa7fnO6alVa9DZ7ZwOD2PRpq0kJh0uUdvsIo8thCiWMgXOe/bsoXPnzgB07tyZPXv2uGRQQghRJFVFKaCKQmFyFluNGDGCVdmPPR0ezsmTJxk2bBgJCQk+V9M5NjaWxYsX83C6YxYywW6nUfMW/PXXX0yfPt27OcXX0+kLLbXmEUXlu+sdJelyJCYd5tNMR77xQ4BGo/Dllm2oqsqECRPKXJYuZ5HhyJEjmTt3rqM6xvN5g9PoyIiCm5RYLaiW7OokNmueVuaT58dx6rMVAIT1eoCFUycyfOZsTp87V6K22YUeWwhRLGVaCn316lWqVKkCQOXKlbl69WqB21ksFqZMmYJWqyUmJoa77rqr0H1u3LiRjRsdtyVnz55NaGhoWYYosmm0WjmXLiTn07VKej7tBh3+NWqhFDPP+cUXXwRg69atbPD3Z1ZWFnddukS/5ctRDAYMBoOjZF14eKnG72rz5s2jUaNGzJw5k99DHIve9t5Si+9/+IGnn36aF154odDX6nQ6j38fqs2GMSQUTUCAR48Ljnx3TWhlDEV8z6awcFAUtu8/wD9eeZ0GKLwK9NJonLnHGo2Gnj17UqtWLWJjY3nyySeJi4sr1fmMiYnh4MGDvPbaa0ydOpX727VF43dtVnz7/gN8sv5bJg99kqWr1nLv3e3p1KY1dr2e9z74gDs7deaeNq0wBwejCQxi3Jw3OXjsJ97NnoHW3duNk7t2Y7ZaMRgMJfrdKezYniKfna4j59J11OvSoopyw8B55syZXLlyJd/jjz/+eJ6vFUUptNROXFwcVatW5e+//2bGjBnUq1ePmjVrFrhtjx496NGjh/Pr1NTUGw1RFENoaKicSxeS8+laJT2fqslI+pUrN6zjnFtObdxFH33EiSefpJHZTGeLhU2KwocffsjVq1eZMWOGs5auNx07dow1a9bwfx3aU/eHXVxVFBafPUejRo343//+R48ePQpNJwgPD+fSpUseHjHYMzNRvFCpRLVawS8QTRHfs91kRjGb2HngEHc2u4PdR46RHBJC1bQ07gYSgSb16tD/0UcxmkxoNBqMRiOXLl0iPDyc1atXk5SUVOz3RmJiIosWLWLChAksXryIVv4aou9s53guV05ydGQEbZs0ZvC0GY624BHNub1GNQYOHMjCmS8TVe8Wdu47yJebttDZaqMqcFyj4fn/fETClu1MGzaEEX1jiv27U9SxPTXzLJ+driPn0nVUm43iXoLcMHCePn16oc9VqlSJlJQUqlSpQkpKSqFXPlWrVgWgRo0aNGvWjNOnTxcaOAshxA3pbtz85Ho56RoAn9jtvAwMAr612Thy5Ajvvfee83lvO3r0KCaTibq7HelvCaqKGQgODua1117zzcYtOq13jmstooZzjoBAVGOWM33h6b4xbHnrXfqlpfFBl3tou2s3h0+eAlRsdhV/f39nV8mtW7cybNiwYtfNdl6gZS8wvLv5HYx6dhILp04iOjKiyJzk6MgIou643ZHq8Y9/0LT+rRw6cYIl06bQevVXsGs3W0KC+XLzNvp168yIviXrfHmjYwshbqxMOc7t2rVj27ZtAGzbto0777wz3zbp6enOeqmpqan88ssv1KlTpyyHFULc7ErRcCNntnDYsGEs1zqCvD6An83GjBkzGDt2rM8Eo71798ZisdAv+9b88uzHq1Wr5qw17HO03mu7rfjfIEUkpDJk5w7nNEMJf+gBAGr9fJynH+mN1WbDarPTsWNHdDodw4YNY+7cufTv3x8ofnv23G2zAaKa3M7CKdcW6+UcP7c8OcmZ6UTd3YHYB+8jMekQFosV7HYa/Op4/QdXU7mjfj227D1QYOWMokrO3fDYQogbKlPg3KdPHw4dOsS4ceM4fPgwffr0AeDkyZPOmZu//vqLKVOmMGnSJP7973/Tp08fCZyFEGWjKd3sZlJSEtWrV+eE3c6fNaoTDPTGkd/66aef+kRljbi4OFq0aEG/pk2JAJKBTcAtt9zCxo0bfaqaRh7FzDd3i6JaWQNKcEiehXYAjWIewmIwUPn836xbngCAXqfj4IEDPPPMM1itVt5++20sFgtLly4t9kWVs3lJDmMW0a1aFj84VVUSN2wgft03jB/YH71ex6IZs9BeTuYPILBVBBeSrzBmQN98ZedUo5HI2+pJyTkh3KhMiwNDQkKci25ya9iwIQ2zGw00adKEN954oyyHEUKIvEoZpI0ePZrTp09z9uxZ3k5O4Q3g2fBwPr90id9//90najrn1G5+Li0NgJWABbhy5QpPPvkkO3bs8K2ugTm81XZbr0e50YWUwQ+0122j13O+cSPqHjlGL5uNM906M+De7gyfOYt5c+dizW6agqo6G6iUismY/9hF2PnTcUbNfoOFz44j+s52XEy5SqsN3wGwu1oYn702g8UJq5kX/xkTYwc60yxUqxVq1CIqKNhZci621/3Er9sgJeeEcCHpHCiEKH9KOeMMMGfOHKKiovjEYsEKRF66RJ2AAHQ6HatXr3bdGEspOjqa9nfeyZPZX3+aXUrNarVit9uJj4/33uCKojc4ag97mu7GF1GKohQ4K706+300olIoW/YeYPW2HfTp0gmz2YTdZqNfl3tQgNghg9nx9doSt+JWrdY8bbOLI+nXkywcP4qo1q0AaFi7Fn2yZ8s/yshiccJqFixPYGLsQGw2+7WZbLsNQiqBTl9kyTnpHihE2UjgLIQoV1RVBUMRdXuLoWbNmqTo9WwE9MC0Ro3QFdZ5zgtaXrnCrcBpIPKf/+TFF1/EYrFw/vx5L4+sCN5qglKMwBkAv7x50IlJh5l36jQ2rZY7UtP4cOwIvty0hU+/+Q69Xs/zTw3m2937sNvtWK02Zs+dx8gRI5x3JYoTRKvGTKBkFxOj+z9CVPu7UHQ6EpMOs/nz/3E7cElRCGjfjleWfsSYAX0Z0Tcmb/qHze64ONBoimzBLd0DhSgbCZyFEOWLzXbDnNYbiYmJQafT8Wn21y0OH+aZZ55hzpw5QPGCIne659QpAH5p15aP4uNp0aKF7zU9uZ5/QL4W0R5R3IuooOA8tVqTjp9gzvOTMLdtjaKqdLqayuQhTwCORoOpGRnY7DaMZjPNG97GgeMnGNO3N1FRUc7KGTdM7Um7CrqSX+Qp2XcZFn25ildvd6Q9Hm9QnxVbttOxVQQ7Dh4Crp89VlH0et7/XwJDX3610Bbc0j1QiLKRwFkIUb7YbeBX/K6B10tMTGTYsGFYLBZ+adaMNCAaWDNnDlOmTKFXr17FC4rcZNfmzfRISQGg1ZtvObvQtWjRwnfTNACljBczpaHabOAfWLyNq4TlSZvIqTBh7Hg3AP6JPzCibwyfvvoydrvKO5+twG5Xefz+Hhw+8Rt9u3VmwYoE5r78Up5yc0VKT0Mp5p2MglIoOkZGUCc7SH793N/07daZHQcP07FVS+C62WONQuKPe5i3dBkTn3y8yBbc0j1QiNLznXuTQghRHDbbjcuPFSEpKYnevXtz4cIFvvvuO7aFh/HQpcsMMhqZHB9PQEAAH330kcdL08XFxREZGYn9f/8jGDC1jGD7+fPO8mY+Wbs5N29U1bBaICCoWJsqAUGomvxzRVnt76KyVovfoSNosptJ5JQIt6sqX+/4wZny0LVdG95ZspQJEyYU72dhzCr2t5ITBOcEuVqthsTP/8cM4BxwtXFDdifuYtqwISxYnkCLhg3yzB7H3t+D+E1bWfbWPKLq1Miz7+jIiDzB8fWpHFEtIyR4FqKYZMZZCFG+KEqZKjiMHj2amJgY9u3bR2xsLK9eugzAYBwzCSNGjODIkSPExsa6ZrzFFBkZyciRI+n0668AHLnzTufMt8/Wbs5Np78WcXqKXUUJKN6Ms6LRFDg7rYYEY4qMQLHbObNiJcNfmY1Oq6Nvt86YLRasNhtRLSMYM6AvCVu2069zRz7+6CMSExNvfFCLqdjfSu4g+Jfff+eVpR8xo0F9ABKrhbHt4GEeiO7AiL4xeWaQnbPHKxIYPHgwUXd3cLYRL0ju7oEFpXIIIYomgbMQopxRir8grBA5s7izZ8/mrzp1OAbUACY2acLixYuZOXMmHTt2dMloiys6OpplM2dS/dgxrBoNA75MKF46gI9QFAU8vcBSo4C+BDnEgcEF5olnRTvSNXTbd4AKS6ZP4Y5bb2X68KHotFrez65kMW3YEJrcdhsLX3yekSNHFhk8q1ZLsStq5KRp5ATBX27exj2REdx6+CgAb168TN9undma3fQkd9MS5+zx44/y8ccfs3P/wSID56K6BwohbkwCZyFE+aJQ7LzRwuQ0qVi8eDFn/vqLpdmPdzt9GqPRiL+/I4fa0wsEO+/bgxZYYbfTe+jQchM0O3mhlrNSkhSRquFgujYLnBOwGu++C1WjoeWlyzzftzdJx08wuv8jjpznWf/GrqosnDrRUcliQF+iGtZn4cKFJCUlFXooNTOj2MPKSdNYnLCa9xPWcE/rSGwHD1EHR2UVXasI7rj1VsYM6MvQl1/NVxFj4dSJTBway6JFixj17CR2Jh0p9FjSPVCIspHAWQhRvpRxtjlHzsxyt27dqP7MM1iAriYTbWrVYtKkScybN88jCwRjY2NZvHgxamYm+uUrAEhs2ZIFCxYULx3Al3g6cC7JbDOghFRylMzIlhOwfv/7n5haR6JVVS79b1We0myd2rQmfsb0vMGm1UJU68ii02dSrxQ5vpygPad+8pgBfXllyTJqhFVhx4EkhmRfHG4IDmJH0hH+/Ptv3v5sOVEtI5yzw3lmjzUaoqOjWTh/PkknT5bovAghik8CZyFE+VKCLmxF2bFjB9OnT+fjjz8mMySENThynB88e5a5c+eybNkyj8z4KorCjBkzWDXwcQLSM/gzJIQFhw4RERFxw3QAn+Oiixp3HU/R6SAw2Pl17rzi1y9eBGBKjWrOIDkx6TBv//fz/Dsy+MHFG9TUzkhHKeK9mhO0a7UaRs2ax86kw+j1Ok6fPY+/RkOf7G6Fi9Mz6NgqgvivN2AyW3i6b2/n7HBk40bXUiy0jnMRHR3NqEd6F+t8CCFKTgJnIUT5UoaugbnFx8czYsQI58zzylq1ABgF2LKyOHLkCIsXL3b7IsERI0YQGBBAi737AJiVlkZgYCBTpkxxVtMoNzyd41zCGWcAwqqjWszOL3Pyiuf8cYZ0IPz3P9GeO+9Mg2jTtEm+XSgajWNGuSjmohcG5gTtC5Yn0LVdazbvcfz8/Q0GHlIUqgGHgUOKwvcHDqHTaHJPludvXJITpGu15JlWF0K4lATOQojyxUUzzjlyZp5/qlmTJKAWEKvXs2TJEmbMmOFY9OZG0dHRfDn6aToDacDnWq1ztrtcVNPIzeDnsbbbqqqWqgSeUq1Gng6HOYvr/jGwP19lv7e2vvK6M3e4U5vWBbekzspCLWrxn8l4w7HkXgyo1WowW6yM6BfDzFscF3Fba9fClr2YUa/XMXnIEwU2LslzLjQaiZuFcCMJnIUQ5YuLA+f47M58R44eZX52kPwvReHs2bPos4MRdywSjI2NZfDgwezYsJ4q674G4BMgxWZj8eLFLj+eRwR4sHug3eboVlhCik4PQSGoqpqvNFutwYMAaH3qNF3btiI6MoLt+w8U3JJao6BeuVzgMVSzqVjnISdob9HwNmw2O327debrlWtp9OcZrIrC7L8vEuDnR4CfAVB4+7PldG3XOn/jEvu1bpqKRuP5soBC3EQkcBZClC8uStXILSkpiSlTppDg58cFoJnZTOfs4GP37t1uWSSoKAqbNm1iwvCnifjZUbs5JzzftGlT+Qye/QLzzOa6ldVa7OYn+dRvBGZjvtJsFxo24G8FmgB/bNnOwBdeYsiLM53b5Jl51hsg5VKBu1cz0284hJygfcyAvpy9eJlpw4eyde8BJoWHoQV+qFyJNIOBZS+/wLKXp/FI105YrTa++n6ns3GJs/by9W3ovVDdRIibhQTOQohyQ1VVl884g6M83YgRIwisWpWF2Y+NU1U0Gg19+vRh0aJFLj1ebGwsycnJ+BkMjLXbCQTWAkeA1q1bExgYyNq1a116TE9QDHoooE6yW6hqqTtIaoJDIbgyox7tk2ch4Mg5b/FdpcoATA0P4/sDh4ho1JAjJ3/joQmT88w8K4oChZWcu5qSN5AtQE7QbrPZnaXuFk55lj6paQB8HRbGkulTnF3/Yjrfg06npV/3rvkbl9jsYMjVhl4jM85CuIsEzkKI8sNuL92CsGJYvHgxZ8+eZSFgBvoAt5lMxMfHU7t2bZemayiKwoEDBwi12xiT/dir2Y9PnTqVZcuW8eCDD7rseB7j6e6BhtK/F5RGd4DV4myIkhPIXunWGYDuly5zX8vmbN27n5lLlnH8jz/yzE7HrVjJzr178yw0TExMdLxPMjMdKRMFyClDl1NPOadCRtyKlXTV66mWmoqtahXGvvV6nhJ4ScdPsGTaFOaMGwVc17hEUfPWs3bDXRkhhIMEzkKI8sNuL1OwVJS1a9fi5+fHJa2W/+D4cHwZCA0NZd26dS5N1xgxYgSB/v4Mt9qoBGwCfgS02bPp5W5RYA6tzrE4zRM0Gke+cikpBj9o3sYRPNvtzkC2+p1t2QGEAl0vXsthbtu0SZ7uepGNGzHqjXdJ/O5bwBE057RIx5RZ6HFzytDlpFlMnr+Q4a/MJrJxI4LWO/Z1PKI5cQlr8ryu6MYl13VtlMBZCLeRwFkIUX7YbaBzT+DcrFkzNBoNgYGBzA8JwQg8BtyWmsrYsWMBmDx5cplnnjt16sTalSsZGN2BZ7Ifey37X6vVypAhQ8pX7eZcFEXxXH6tC2pGawICUSLbg6I4q4EkHT/Bua6dAHjg3Hl0Gg33tG7J9wcOodU6/mTm5DkvnDKRURMnM3fuXIYNG8YDDzxAVPv2eboTXi937ejHpr7Eio2bsdps+KemEbB9B3ZF4ZHEXZw+d945O51bgRU+rj/vnrp4EeImJL9dQojyw66i+BWdO1pa9evXp2/fvvTp04ef0tKcuc6z9DpOnjzJsGHDSEhI4PTp02U6TlRUFPGffUb1rd9TDdgFbMYRdPr5+XHLLbeUr9rN1/NULWcXNVtR9HqU5q0diw1xzOweq38rF4BI4C67nX0//cL04UNZsDyBxKTDzlljFIXYB+7l7bffxmKxEBMTg5qRdsNj5pShS0w65Kwc9/O8t1CsVlaqKn/otMR07phvdjpf7eYcGm3e1BA3rAMQQjhI4CyEKD8U1W0zmqNHj6Zhw4Z88sknxMbG8o6/PxnAAxYrpz77DKvVik6nIyYmpkzHee3Z8XRr2JBJ2dUnXgZ0Oh2qqqKqKh06dCifaRo5PDXj7MJcd0VvgNsaoZqMLE5Yzb+XfcLGWjUBR0OcTKNjBtmZUwz0jGrP8JmzeT9hDf7+/s7ShaRcvuHCwJwydOMH9sfPz4C/XeX/LI7AfYFWy7KXXiA60tFae8yAvs7azUNffpVeHe/OkzKSmHSYhSuvW0gqqRpCuI0EzkKIckRx62zajh07ePLJJ1m3bh1zP/6YT8PDAXjNbsdmtbJ06VKgdHWd4+Li2PH99/DHbzx1+TJVgG+BnYGBfPrppwQGBlK3bl3q16/vum/IGzw24+za4yhVq4OisOPgIaYNG0Jo7EDswGPZXfw+/eY7oiMjnLPADevUxmqzkmU2M+LJQSxdupSRI0eyMzGx0IWBQL7a0UumTWGAzUY1YC+wS3vttZGNGzk7C77z2QraNbuDT9Z/60wZydnX6b//zpveo9GQePBQ/pQOIUSZSeAshCg/3JxDGx8fT7169Zzl517OyOAi0BkYYLVy5MiRawvASigyMpJRI0Zw9NtNPHblCjbgOSAtM5O1a9eybNkyHn/88fI92wyg0zsrVbiLarOBn/+NNywBRaOBkMp8/O9ptGjYgCGLlnKuaRP0qsoXrSP57a+zjJ/3tjPoPXnmL3RaHeMH9uf9Tz7lyJEjLFy4kKRjx4D8ucg5+cq5a0cnJh3m/S9XMTb77sMCrRY0Goa/MpvEpMNER0YwZkBfErZs567mTdlx8BBPPnAfC5Yn5OkeGNOtCyNHjnQGzzsPHWHU7Dfyp3QIIcpMAmchRPni5oVPOYHrsGHDSAGmZpdXm6uqvDtjBmPHjuXIkSPExsYWe59xcXGoWZksmjCaSgveRwfEKQrNet5HbGws8fHxrF27tvwHzeAIaN3ddttmhcBSNj8pSo1bwHStMYrhqcEAdP71JIPuiebLzdvo2q41AN/s/JEl06cQ1TKCqBZNmTlzJkf27mZUzEMF5iLnzFSfPncOcATWw1+Zjf/+g7QAUvwM9Hr5BXQaLVabjdXbvicx6TALlifwSNdO7D76E4907cS6HT/Q5brugVFt27Bo0SJGjhzJ3LlzGTXtJRZOfiZfFQ4hRNlJeyEhRPmh1ToqN7hZUlISd911F7t378byxBN8/8kn3AMsBF5fs4aDSUlMnz6dxMREkpKSCg144+LiiIyMpGXLloz6xz/YcvddtFRVzgIzdTre69+fjj0d9Zp37tzp9u/LI/yz2267c4GazYbiH+jy3SqVqqBqtM7aymbAFtEc7eGj1P9xD/26dSZhy3aupKWzcOpEAMes7+RniOrQgXnvvkfqmd7Er9uQr+ZzZONGLJw6keEzZ7NyyzZQFJrUrcvcs2chI5Nvbr0VrU7HkulTWL1tB+cuXeL9hNW0btKYrXsPMH5gf/6zZh2N6tRhfeIuZ/fAqJYRREVHEx0dzeDBg3n77bcZ//RwoiKaufz8CCFkxlkIUZ54aNHT6NGj6dChA0uXLuWh3r35h05HOo7ydBEHDzJt6lQAhg4dilarLTDnOS4ujl27djFs2DC4cJYvBvan6YaNAAxXFIwGPUpIJQBmz57N9u3bPfK9uZ2fv6OTnTspCuhdU1Ujz241Gkfgn8v+qPYATNPrmD92JNOGDWHz3v188d0mRs2aR8+o9qDV8nS3Tjz98IO889kKurRrnb/m86x5ADwV04ssk5kso4lHA/1pmpGJMSgIwxOPObeZM24UHSNbsmnPPn44fJiFUycS1TICq9XGwV+OMzF2YJ7ugTsPHSExMZGPP/6YCRMmEL/iS3YeOuLy8yOEAEV1dzJaGf21fpW3h1AhhIaGkpqa6u1hVBhyPl2ruOdTRUETeacHRuSQ09Ri7NixnJkxg6WAEXikUigbUtNo06YNBw4coGbNmtxxxx3Ex8c7X9urVy9++uknNIpCHSDRZqWaxco7wPedOzJg2HBGTfgXixYtIjo62mVjDg8P59KlSy7bX0mpJiNq0o8ofqVrh13cYyjtOha5CK+07Cd/hrSrzjsb/1mzjtHrviHszzNcHfIk6Y/1Y9y8t0nYvI3xA/sT1TKCUbPmMWZAXxYsT6BLu9as3LKdacOGYLPZiWzcyJnPPHzmbEwWM3a7ik6BH6w2WgFXnxpM+qOPOFM8Yu/vQfy3m2jd6DZ2/3Scp2J6Eb9uAz2j2tOwTm1sNrtzVjxx335WHzjCN1u3Od9LO77dwKjx41k4dZLPpWvIZ6fryLl0HdVmo85D/Yq1rcw4CyHKDw/Xp01KSnIuFPwPsBjwBz66mkpTVWXfvn3Y7XbOnj3L1atXadeuHXFxccTFxREREYHZbKaK1cpyo5FqFivbgI8a1GdL0mEU/0AWLVpUvms2F0SnB9ycTqPTuyVoBqByGJivNTCZ8ORA1FH/AMDw2RfE//cLZ+pE/LoNHDn5G62b3M4rSz+ia7vWbN17gGnDhrBgeQJarSZPHWaTxYzZYuXuls0ZqtHSCvhTUdhY/1bgWn3nd1YkMPj//o/2ES24t8OdznzmOeNG06JhgzzDjWrelPr1b81zARYdHcXCf43LM+sthHCNMuU4//DDD6xYsYK//vqL1157jYYNGxa43cGDB/nwww+x2+10796dPn36lOWwQoiblYc7oo0ePZrFixczc+ZMXnzxRRavWE79n37mfhxtsvtwrVX2vn37APjwww9p2rQpW7dupYlezxdmMy2B48CjwIJ/DIMGjRk5ciSLFi2qGAsCc1G0WlR356G7seSdElo5X1UQU6uWGNu2JmDfAar+93PGDB/KiL4xhAYF8crSj+jWrg19u3biy+xZ6BF9Y2jRsIFzkeGoWfO4pVoYFouVe1q35NCBQ3wVGABmWBPRghfnvePMmY5ft4Hxgx7j448/pldUe1Zu2U7fbp2JX7eB0KAgFixPcG7roDJ61CiUwOBc34SGqJbNib6rndvOkxA3qzJ9+tStW5eJEyfy/vvvF7qN3W5n6dKlTJs2jbCwMKZOnUq7du2oU6dOWQ4thLgZeaEj2o4dO5g+fToAB3/+hUF+fnxuMnEvsA14FZhns5GVvf3Zs2e5eP48g+125tlsVAV+BroCGX4Ghr82h6VLlzpnm12ZpuEz3N0ExUVdAwui6PWoBTQwufr0U+hHjmO4qtLz0+WkZmTwfsIannzgPmx2lW927nIu4LuYcpU540Y50yRuqRbGkZOn6NetM01uvZVn/7+9e4+Oqrz3Bv599uxJJtdJJoFASHKQAFYUAgheElIE4qtHW6W6sICkh+PbUoEu7eqhB1JuakTiIZx6WVwLqAetfYtKKUerpxwqSuAtFyFBbYGop74iNpKAQchlZvbz/jHJmJCZzG3vmezJ97OWSyaZmf3kSWbmt5/9e36/M2eR3vAlTtvtmP7EIxhw4gNsfm0XDtS9j+cfWYriGybCPvxqVFZWYs7t/wuv1xzElAnj8PjWF7Dsf/9T9/QLoQCWK+ZDMX4DLVF/FdHyTV5eHnJzc3u9T319PQYNGoScnByoqori4mIcPnw4ksMSUX8Vg8B5+/btuO6667BmzRqMHz8eTW1tuAPAswASATwG4HMAvwawGsBWAB9rGrYBcAD4TwB3pqfh7wA0CLhcLuzatQslJSVxt9rspWNXP58MDJwBAF0qdjz10m9QU3sCrvw8XL53OhR40nY2vrwD/1hyE3739rvY/e5+7wY+SGD3u/u7tck+/elnSLCq+K8/H0aZasF3G76EE8CTeXneqygH6t7HovJZKB5zHaBa4Xa7sexnP0X+gCyU33kbXt27D/dM+TbcV268lBKwXnGiItg5kMgohpeja2pqQlZWlvd2VlYWTp8+7ff+e/bswZ49np3nVVVVSE9PN3qI/YJisXAudcT51Fcw8ymlBiUjGwkd3fyi6fTp0ygvL/deXXMBWGKz4dXWVjwJ4EYAs654zEcAlgP468gRaD53Dj+aNw+/+tWvMHHiRIwaNQrZBv0cqqoa9tzBanM4uuUJ60lqGpSsAYb+HTiH5MHdcBbCYsH1147CjEUVWPbDufjJ/B/h3H//CXnnL+ClgQPwgwN/xrfHF+FA7fs4evIUtv5uN16uegwA8N5fTiIlJRkLnlyLV9euBgD86GdLMOJXz0EBcGDi9fjd6Xp8/fQ67N63HzvWrMK3x4+DdLlgyc3FihUroF2+hD9uWY9/XrUG/zp3Drb+bjf+efp3u71WpC0RtoE53efI2Y7WtDQoSfqX7IsU3zv1w7nUj3S7gr5vwMC5srISFy5c6PH1mTNnYuJE/Xe3l5WVoayszHubO0b1wd23+uJ86iuY+ZRuN2BNghKDihFz585FeXk5CgsLIYSAoig4deoU9gG4CcC3ABQDGASgCZ7WyUfgCWJ//fgqAMCDDz6IOXPm4MyZM5g7d65hlS9iXVUDALRLlyFaLhny3NLZDqTaDf070KAAjecgbEkoHTsG/zJnJpau24Q/1BxE6/kLqBEC9zZ8CTm5FD8+VouikYX4t+dfxMOzZmDscM9en7HDC7F+x06sX/wvnq85nfhDWiryzl/AMVsirlpRgcm/fBb/5609uGfqZIwdXojm5mbItlZgwGAo585h//79mF/5pLc6xvVXj8QPlj3WrUa0dLvx9RVzId1uyIsXIZzBBwPRwvdO/XAu9SPdbgR7ChIwcO7M7QuXw+FAY2Oj93ZjYyMcDkdEz0lE/ZDUjL9E34vOUnM1NTX4/ve/3+17f+34r5MQwnMJHZ4OhF1zmquqqqI04hhKSIC8/LUxzWpcrm6pFEYQyanouj3wx/fcjQ8//gSv7t2H/EED8dAXDdgA4N6ag3h7UA7WHatD6bgx2Pza7z3pGgBqT9V7S8bB7YZz5SoUnb+ARlXF9NY2/MOKx7D/+AmUjhuDP9T8X9Tc6mmxDal5S/nV1dVhQ8W/oqToOgCeqhsbKhah9lT9N3nOvjZKKorhhU2I+ivDt6gXFhbi7NmzaGhogMvlwoEDBzBhAnf6ElGINM2Qphehqq2txezZszF8+HCoqopp06YhKysL6enpEEIgNzcXs2fPxrhx4zBgwADcdddd3k2AcZvTfKXEju6BRhACItFmzHN3HkJVgS4bBGtqT+BPR44hL2cg/t8XDagpvApPAxAuF6o/O4NyIXD8ZD0Wlc/C3EdX4QcrKr3ttsXlFsjFyzH0eC3aVRUzEhNhHz4M7x6rw3WFV+GDj/4Hi8pnfVO2TijeHPEFCxag+IbuV3ZLikZ/E5ADPjdiek5YGDkTGSGiHOdDhw5h27ZtaG5uRlVVFYYOHYqlS5eiqakJmzZtQkVFBSwWCx544AGsWrUKmqZhypQpyM/P12v8RNRfaJqhZciC1Rn8drbT7loVI1AL7n4jKQlwu427QmD05kPA00GwvQ3vvHfM2+DkqV//FglWFe9/9Am2Fg6D5aOP8RMA/yElXmlrwzsnPkBraxumTrweJddeg6R9+5H+3H9AbfgSbUlJaH5sOSadPIXKLc8jf9BAnKj/GMs7Stt1lq8rHvUtT+DeZRyy5ZL/utX+5iJKXTaJ+ht2DuwnmAulL86nvoLKcW65DDH6eoiUtCiNypz6Qo6zvHwJsu4IRJL+3QOlsx3KhEm6P++VtL/VA03n8Nzrb8LpdHarn1y+ohLtTicUIfAjKfEUPI1xAODvNhsyh+RC/fxzKC2tAID24cNwftFPse/8BcxfXY0pE8bh1b37cF3hVfjb2b9jy/Il3tSLmtoTqPu6zXvypTWdA+o/9LnKLjUNcGRD+YfhPcf/3kGIGFShCYTvnfrhXOqHnQOJKP4IwVU0s7BajcsUiFaee0cHwZ/ePxNut9ZtQ56lo06yoij4cupkXA1PGcKLioKc1lYkfPQxlJZWOAvycWHhj/Hlvz+JZ/58BLv27cfC++7Bnzo6D3505nO0tLdh1779ADxB8/yqahQVFXmHIVJSvfnyPbicQLKfE0mjm9AQ9VOxv+5JRBQUGfXOgRQmi2r6wFmkpHk3CHbNKd617124XG4kWFUkJiQgxWbDpwDmCYGHFQWrv3cXfv/mH/GTny7EhJKbvY8rGjkcz/72FUACW5YvAQBs+/3rAIDd7+zHgEw7tr/+FjasXNq9KU5Cov+/e02DSE7x/T2+VogMwVcWEZkEV5zNQiiKgfnNUQqcVRVI7N5BsKb2BN488Gd8e/xYJFoTMH1yKba/8RZuvXECUpKScNO4Ijzyx724edYMHPr8i26PLSkaje+WTgIEcKDuBOavrsaWZUvw/MqlGDOiEE+/vAPld9zWYzOgEAJI6GUzZIK/HGd+vBMZgSvORGQeFgYDpmFA220pZXRLEiZ2L3tXe6rem7JRU3sC9y97FKOHD8P+4yfw/CNLUVI0Gpte24X9x+uw/bGepVz/7aH5GJBpx9Mv78DDs2Z4n+cvn/wND8+age2vv4niW27BpGFXXzEOG9DW0uP5IEQv88FUDSIjMHAmInMQAoIrzuahqp6ay3rS3J4gMlrS0iFbv/be7JqyUVI0GndPnuTd5Ad4VqQ7NxHW1J7oXsu54/vbX3+rI0h+C+kpKd77lxSNRvG3RmJ+xTJsdAzonq6R5KeyhjXBf61sRfHMFxHpiss3RGQODJrNxYiVYZcLSPKT02uEjCxIP63DO2s73zt1Mt7/6BOUr6jEDyurvJU35q+u9tZy7rz//NXV2FCxCD8vn40NFYtQvf1lLLzvHu+mw+LR12LDM8+gtra2xzh8tjDvrSwfUzWIDMEVZyIyBwYC5qJaIeVlfbsHSmlIiTt/RHJyxwlb95XbrkFwSdFoSACv7d0HwJO/vP31t7pV4QC6p3kAnhXr5x9ZitpT9d2eu6S0FJOmTu0+ji4bFbvpLd+brxciQ/CVRUTmoDBn01QSbZ6mNXoSiE7zk87DKRYoST3be9eeqsftxTcC8ATRbx85hnumTobL7fZs8rvztm5BM+BJ87jyaz26AArhs8mPr42KUsre54Ll6IgMwcCZiMyBqRrmkpSsf9ttYWC1Dn+HTEvHlX3CFsz4Hu6eXIofPl7lTc+4dthVkJoGq6pi2+9f97TPDpVq9b9Cb7sigHe2A2l2/8/FFWciQ/CVRUTmIPh2ZSbCluxpu60ni6pv6kcwh8weBLS19vh61/Jyv/3jf+PxrS9g2Q/n4sXKFfhu6STMX10devDcW+pFajpk1xMRTYOwZ/q/P18vRIZgjjMRmUMfbB9MvVCt+qcLRDFNo5Niz/T7c3QtL3fv5FLMu+sOCNXqrbhRe6q+R3pGr3or4ZeRBZz52zf3SUiESEj0f3+LBVLKqJ9oEMU7npISkTkwVcNcrAYEzj7yf40mLBZP2okP3vJy992DP9WewIHjdd7v9chfDkYvaSgiOaX79/2Mycui6p9jTkQMnInIJLg50FSEouh/lSDK+c1e9kxIt5/KGot/hkUPP4SNmzdj/tpnwsttBiA1zX8XQHTMZ0YWpKZBOp2A3dH7E6oqIH3W4iCiCDBwJiJz4GYn89Ex0JWaFt3mJ12InDzPZrwuOsvLFV9zNcSQoSgpKcGGtdWo/ctfwzuI2x1wFVkMKfDUc25vhXBk9/58FhWQ4a04S5erx4kCEXkwx5mI+jwpJVM1zEjP7oEuV+D0BIOIxETIpORuK7gLZnzPE8ynpEJ0bOorue0fUZzdS6WL3gTR3EXYkiAH5wOZDohAJxEWS/grzu1tnhNVS/RqZhOZBZdwiKjv07TYXaan8On5O9NcnjzfWMnMhrzyJKC9DSgo9N4UigLYwgw2hQwcDANQCoZBScsI/HyR5DhzQyGRXwyciajvC9Tsgfom1dqjBnL4BKDG7m9ADM4HuvTvk5oGZGZBuTJQTkoO6mdev2Nn93xooaDm8GGsX79en/FGkuPMuJnILwbORNT3aVpMKipQhGw6dg8Uovc6xwYTqgoUDINsbfUExm4XxNARPe9oz+yRD+1L0cjh3Wo9H/jwr5g/fwGKior0GbCiRBAAC24sJPKDn0RE1PdJLaZBE4XJ1tE9UI/qGqrqSYWIIWXAYGiaBjSeA64p8llHWaRnQGqBN9aVFI3GhopFmL+6GuV33obtr7+FjVu2oKSkRKfBKl0XyEMkEMGDieIaA2ci6vs0CcEcZ9MRSclBBZFB6SO/fyVnCJAzxO/3RaIN0hLcWEuKRqP8ztvw9Ms78PD9M/ULmgFAWCLIVZZgvgaRb0zVICJzYFUN87EmQLcArI8EzkEJcoOgt4HKrBnY/p9/QE1NjX5jiGR1XgBccSbyjYEzEfV9Cthy24xUq371t820OdSWFHCDoLeBSsUiLLp/JjasehQPPvigfsFzRPMuuOBM5AcDZyLq+yTYAMWEhBCesmgRimXzk7DYMwCns9e7dDZQKSkaDbicKJ5Uio0bN6K2tlafMQgRYVk5Rs5EvjDHmYhMQACCgbMpWROASPOcXc6AzUH6EpFmD5jbvWDG9765obkhklNQUlKiW56zUJQI9wYyVYPIF34SEZE5cMXZnPQoI+h2QyTHpmtgWBKTQvx7FcakooT7mpEAJFeciXzhJxER9X2KiHkpMgqTHpv6hEGBpUGEEKGlliiKMT9fJKkajJuJfOInERH1fUzTMK9EmydHORJGBZZGSgyh9bbV6gm29Rb264Z1nIn8iega2sGDB7Fjxw6cOXMGTzzxBAoLC33eb+HChbDZbFAUBRaLBVVVVZEcloj6G4XLX6aVlAK4XEBCBIGvRTUmsDRSSirkpWaIYDZHWns2UtFFuHMmwFQNIj8iCpzz8/OxaNEibN68OeB9V65cifT09EgOR0T9Fj/EzUokJ0NqLgARBM5mW20GgAwHcOZ/gqsq4qMDoS7CTW9SLIBbp8Y1RHEmosA5Ly9Pr3EQEfnH/GbzUhMiT7UxYbt1kZQCGcQJn3S7gCSDNj4KEV51jIhL2RHFr6iVo1u1ahUA4NZbb0VZWVm0DktE8YCBs3npEfSaqWtgB2GxQAazQdDpAtLsBg1CAWQYK8eKwos8RH4EDJwrKytx4cKFHl+fOXMmJk6cGNRBKisr4XA48NVXX+Hxxx9Hbm4uRo0a5fO+e/bswZ49ewAAVVVVTO/QiWKxcC51xPnUV8D5tKhIzM6O3oBMTFVVZPexuWrNdECEWZZOulyw5A6BNUY/UyTz2TYwB2hr7fU+mlWFLS8fwoAGL20ZGZ4a2KESAtrlS1AMWAnne6d+OJf6kW5X0PcN+E62fPnyiAYDAA6HAwBgt9sxceJE1NfX+w2cy8rKuq1INzc3R3x8AtLT0zmXOuJ86ivQfErVCuXcuSiOyLyys7Nxro/NldbaBqFdDuuxsrUFGDA4Zr//SOZTc0vg/HmIXtrFy/Y2fN18EUJ8He4Q/R//4kUIZ3vIj5NCAVouQTiDDyaCxfdO/XAu9SPdbgR7CmL49c/W1la0tLR4/11XV4eCggKjD0tE8YSpGuYWYbqGsJmo+UlX9kzA2db7fawJxlUMCfd5ewn0ifq7iHKcDx06hG3btqG5uRlVVVUYOnQoli5diqamJmzatAkVFRX46quvUF1dDQBwu92YNGkSxo4dG/QxZEt4qxT9Stc3xx7/9mzykC4npNsNKIr5yjoRMXA2N2sCZGtLeO89QkRWyi6GREpa4A2CRlYM4euGSHcRBc433HADbrjhhh5fdzgcqKioAADk5ORgzZo1YR9DXDc+7MfGnS6bo2W3ndLSs3Nayo5/A9A0z781N6BpsKSlA43nAJfTk8vjdntqq7pcnhURt7vjAyqRgTX1PfybNDdbEnChKbz226oKoZhzBTTQBkEpJWDoajpXnIn0FrWqGuESqUx89yXUt0NrdjaU5DS/35ftbZAXm4HzX0Je/ApobwcSbQyiqW/gB7m5paR6NqmFEzibsYZzV8kpkJcv+X4vbW/z1Hs2StgrznzfJ/KnzwfOFB0iIREiawCQNQAAoF1sBj77xBNEcxWaYo5/f2YmbEnhN3A2e+CcmQ18dd53kxNNg0g3qBQdENaVGikloPJElcgfJkCRT0paOpRrioBrxwEApAG7q4mCIaUMrvsa9V1hdsbzBHHmq+Hclchw+O/CZ02AMDjHWYbaAEVKQFGZHkXkBwNn6pWSkgYxZiJgt0O2h17WiChimhbeJX7qM4RiCa+yhtsNJKfoP6AoEtYEwF+esy3J2IMrltA7B0oNUJXwOg4S9QMMnCkgoShQRlwLZA+EDKMmKFFEuOIcH8JZOXY5geRU/ccSbcmpPVZ+paZ5cr+NZAkncJaAYgXTo4h8Y+BMQVOuGgmkZ0C6mLZBUSQ15lzGg7BSEiSEAd3rom7gYM9GwK7a2wCHwd0QVTW8wJmvNyK/GDhTSMTwawBFhJ43RxQuTfPkXJK5WRNCf99QLGHnR/clwp7Zs8KFaoVIyzD2wGGlanTkOIe/nZMorjFwppAIxQJcPabn6gmRUaRkjnM8SEkD3CFerbJa46Kij1AUwJ7pPXGQmgZkZBr/s1ksnis2ofCuOJt/3omMwMCZQqYkpwBZOZ5GKkRGkxKCgbP5paYBoVbnsZp/tdkrtwBobfH8u70NGFxg/DHDWXHWtI49BVxxJvKFgTOFRQwdDrhDXMkgCosABN+qzE7YkkJfxIyDNI1OSkoaUFAIeflrICfXswBhtHA2B4qOK4tccSbyics4FBZhsUDm5EJ++QVXA8lYAhF0QKO+QlgTIEP4PUq3C4iHjYFdKLn5kFkDIRKjc0IgVDWMOs7C83pj3EzkEz+NKGwitwDQ/BT2J9ITW27Hh1BWkJ0uIM3ArnoxEq2g2XMwEUYALDtOVJmqQeQLA2cKm1BVwDHAs9GFyDBM1YgbIZWkkxC2+FpxjjpFQciRsxDhPY6on+CnEUUmt4AVNshYTNWIH4m24FMHFAVIMLAddX8gwlw5VhQuOBP5wU8jioiSlBx3eYjU9wgGzvEhOTX4knQJiXFRii6mwlo57rjCw6kn8omfRhS5gYPZipuMw6A5fqSle9poByMxydix9AdhnXhIQGHUTOQPP5EoYiI7h6XpyDgMnOOGJ2c5cFAmNQ2wMXCOWDivHQHuKSDqBV8dFDGhWoGU1FgPg+IWV7/ihVDV4DYIOtsBe6bxA4p3YaVcCE+KDNNkiHxi4Ez6yHBAuthJkAzAFef4EsxKspQQyTwZj5QnRzzEALjz9cbAmcgnfiKRLsTAwZ5VIiK9MXCOL4lJgStrWCzRrXccz5QQa6Dz9UbUK75CSBciIZE5iWQM5lvGF3tG4JNsbgzUT8gb/cQV/yeirviJRPpJSQu9vStRILxkHFdEajoQqGkSV5t1FEYDFCLyi4Ez6ccxAGhnugbpjJeO40uirdffqXS2AxlZURxQnAu3tBzjZyKf+IlEuhH2TECyLB3pjCtgcUUIASSl+L+DywVhd0RvQPFOhJjj3Pl64+uOyCcGzqQboarMcyb9Mcc5/qSmeWo1+5KQwI2Begp1xZkBM1Gv+IlE+kpJZZ4z6Ysf5PHHMQBob/P9vd5WoykM3BxIpCcGzqQvu4Nl6UhfzHGOOyI13efvVbpdQJo9BiOKYyGvOBszDKJ4oUby4O3bt+Po0aNQVRU5OTlYsGABUlJ6rhYcP34czz33HDRNw7Rp0zB9+vRIDkt9mEjP9H8JligcXHGOO0JRIG3JgObu/g2nEyI7JzaDilehpjrx9UbUq4iWcsaMGYO1a9eiuroagwcPxs6dO3vcR9M0bN26Fb/4xS/wy1/+EjU1Nfjss88iOSz1YSIxEVAjOh8j6i7cqgDUt2VmQzqd3b+WlAzBfRL6CvmKDV9vRL2JKHAuKiqCxeLZsTty5Eg0NTX1uE99fT0GDRqEnJwcqKqK4uJiHD58OJLDUl9nS471CChOSCkBhSdi8UgMGtKtCo90OgGuNuuPK8hEutIteXDv3r0YO3Zsj683NTUhK+ubmpxZWVk+A2yKIympTNcgfWgaYAmxnBaZglBVwJ75zWZitwti4ODYDioehRo4sxwdUa8CLuVUVlbiwoULPb4+c+ZMTJw4EQDw2muvwWKxoLS0NOIB7dmzB3v27AEAVFVVITc3N+LnJI+ozWU/+Z2lxXoAcYbzqR/TvG+aZJymmU9fwh177j36jqMLvtb1w7mMvoArzsuXL8fatWt7/NcZNL/99ts4evQoHnroIU9h+ys4HA40NjZ6bzc2NsLh8F/cvqysDFVVVaiqqsKSJUvC+ZnIB86lvjif+uJ86odzqS/Op744n/rhXOor2PmMKFXj+PHj2LVrFxYvXoxEPwXrCwsLcfbsWTQ0NMDlcuHAgQOYMGFCJIclIiIiIoq6iHbdbN26FS6XC5WVlQCAESNGYN68eWhqasKmTZtQUVEBi8WCBx54AKtWrYKmaZgyZQry8/N1GTwRERERUbREFDg/++yzPr/ucDhQUVHhvT1+/HiMHz8+5OcvKysLe2zUHedSX5xPfXE+9cO51BfnU1+cT/1wLvUV7HwKyf7IREREREQBsZctEREREVEQTNFZYPfu3di+fTu2bNmC9PT0WA/HtH7zm9/gyJEjEELAbrdjwYIFvVY4od4F23KeAjt48CB27NiBM2fO4IknnkBhYWGsh2RKx48fx3PPPQdN0zBt2jRMnz491kMyrfXr1+O9996D3W7H2rVrYz0cUzt37hzWrVuHCxcuQAiBsrIy3HHHHbEelmm1t7dj5cqVcLlccLvduOmmm3DffffFelimpmkalixZAofDEbC6Rp8PnM+dO4e6ujpkZ2fHeiimd9ddd2HmzJkAgDfeeAOvvPIK5s2bF+NRmdeYMWMwe/ZsWCwWvPjii9i5cyfmzJkT62GZUn5+PhYtWoTNmzfHeiimpWkatm7dimXLliErKwsVFRWYMGEC8vLyYj00U7rllltw++23Y926dbEeiulZLBaUl5dj2LBhaGlpwZIlSzBmzBj+bYbJarVi5cqVsNlscLlcWLFiBcaOHYuRI0fGemim9cYbb2DIkCFoaWkJeN8+n6rxwgsv4P777/dZI5pCk5z8TSvstrY2zmmEgmk5T8HJy8szd5OJPqC+vh6DBg1CTk4OVFVFcXExDh8+HOthmdaoUaOQmpoa62HEhczMTAwbNgwAkJSUhCFDhvD9MgJCCNhsNgCA2+2G2+3m53kEGhsb8d5772HatGlB3b9PrzgfPnwYDocDQ4cOjfVQ4sbLL7+Md955B8nJyVi5cmWshxM39u7di+Li4lgPg/qxpqYmZGVleW9nZWXh9OnTMRwRUU8NDQ345JNPMHz48FgPxdQ0TcPixYvxxRdf4LbbbsOIESNiPSTTev755zFnzpygVpuBPhA499bSe+fOnVi2bFn0B2VigVqkz5o1C7NmzcLOnTvx5ptvMi8qgGi3nI9nwcwlEcWv1tZWrF27FnPnzu12BZRCpygK1qxZg0uXLqG6uhqffvopCgoKYj0s0zl69CjsdjuGDRuGDz74IKjHxDxwXr58uc+vf/rpp2hoaMDPf/5zAJ6l9MWLF2P16tXIyMiI4gjNxd98Xqm0tBSrV69m4BxAoPnsbDm/YsUKXioLINi/TQqPw+FAY2Oj93ZjYyM3/1Kf4XK5sHbtWpSWluLGG2+M9XDiRkpKCq699locP36cgXMYTp48iSNHjuDYsWNob29HS0sLnnnmGTz00EN+HxPzwNmfgoICbNmyxXt74cKFWL16NatqRODs2bMYPHgwAE8aDHNKI9PZcv7RRx/123KeKFoKCwtx9uxZNDQ0wOFw4MCBA72++RNFi5QSGzduxJAhQ/Cd73wn1sMxvebmZlgsFqSkpKC9vR11dXW4++67Yz0sU5o9ezZmz54NAPjggw+we/fugO+bfTZwJv299NJLOHv2LIQQyM7OZkWNCPlrOU+hO3ToELZt24bm5mZUVVVh6NChWLp0aayHZSoWiwUPPPAAVq1aBU3TMGXKFOTn58d6WKb11FNP4cMPP8TFixfx4IMP4r777sPUqVNjPSxTOnnyJN555x0UFBR4ryLPmjUrrI7CBJw/fx7r1q2DpmmQUuLmm2/G9ddfH+th9RvsHEhEREREFIQ+X46OiIiIiKgvYOBMRERERBQEBs5EREREREFg4ExEREREFAQGzkREREREQWDgTEREREQUBAbORERERERBYOBMRERERBSE/w/1m61rLf1WXAAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 864x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot(model=vsgp_diag2, plot_observed_data=True, plot_predictions=True)\n",
    "plt.ylim(-2, 2.5)\n",
    "None"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Heteroscedastic GP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 119,
   "metadata": {},
   "outputs": [],
   "source": [
    "class HeteroscedVariationalGP(GPModel):\n",
    "    def __init__(self, X, y, kernel, kernel_g, likelihood, mean_function=None,\n",
    "                 latent_shape=None, whiten=False, jitter=1e-6, use_cuda=False):\n",
    "        super().__init__(X, y, kernel, mean_function, jitter)\n",
    "\n",
    "        self.likelihood = likelihood\n",
    "        self.kernel_g = kernel_g\n",
    "        \n",
    "        y_batch_shape = self.y.shape[:-1] if self.y is not None else torch.Size([])\n",
    "        self.latent_shape = latent_shape if latent_shape is not None else y_batch_shape\n",
    "\n",
    "        N = self.X.size(0)\n",
    "        f_loc = self.X.new_zeros(self.latent_shape + (N,))\n",
    "        g_loc = self.X.new_zeros(self.latent_shape + (N,))\n",
    "        self.f_loc = Parameter(f_loc)\n",
    "        self.g_loc = PyroParam(g_loc)\n",
    "\n",
    "        identity = eye_like(self.X, N)\n",
    "        f_scale_tril = identity.repeat(self.latent_shape + (1, 1))\n",
    "        self.f_scale_tril = PyroParam(f_scale_tril, constraints.lower_cholesky)\n",
    "        identity_g = eye_like(self.X, N)\n",
    "        g_scale_tril = identity_g.repeat(self.latent_shape + (1, 1))\n",
    "        self.g_scale_tril = PyroParam(g_scale_tril, constraints.lower_cholesky)\n",
    "\n",
    "        self.whiten = whiten\n",
    "        self._sample_latent = True\n",
    "        \n",
    "        if use_cuda:\n",
    "            self.cuda()\n",
    "\n",
    "    @pyro_method\n",
    "    def model(self):\n",
    "        self.set_mode(\"model\")\n",
    "\n",
    "        N = self.X.size(0)\n",
    "        Kff = self.kernel(self.X).contiguous()\n",
    "        Kff.view(-1)[::N + 1] += self.jitter  # add jitter to the diagonal\n",
    "        Lff = Kff.cholesky()\n",
    "        Kgg = self.kernel_g(self.X).contiguous()\n",
    "        Kgg.view(-1)[::N + 1] += self.jitter  # add jitter to the diagonal\n",
    "        Lgg = Kgg.cholesky()\n",
    "\n",
    "        zero_loc = self.X.new_zeros(self.f_loc.shape)\n",
    "        if self.whiten:\n",
    "            identity = eye_like(self.X, N)\n",
    "            pyro.sample(self._pyro_get_fullname(\"f\"),\n",
    "                        dist.MultivariateNormal(zero_loc, scale_tril=identity)\n",
    "                            .to_event(zero_loc.dim() - 1))\n",
    "            f_scale_tril = Lff.matmul(self.f_scale_tril)\n",
    "            f_loc = Lff.matmul(self.f_loc.unsqueeze(-1)).squeeze(-1)\n",
    "        else:\n",
    "            pyro.sample(self._pyro_get_fullname(\"f\"),\n",
    "                        dist.MultivariateNormal(zero_loc, scale_tril=Lff)\n",
    "                            .to_event(zero_loc.dim() - 1))\n",
    "            f_scale_tril = self.f_scale_tril\n",
    "            f_loc = self.f_loc\n",
    "            pyro.sample(self._pyro_get_fullname(\"g\"),\n",
    "                        dist.MultivariateNormal(zero_loc, scale_tril=Lgg)\n",
    "                            .to_event(zero_loc.dim() - 1))\n",
    "            g_scale_tril = self.g_scale_tril\n",
    "            g_loc = self.g_loc\n",
    "\n",
    "        f_loc = f_loc + self.mean_function(self.X)\n",
    "        f_var = f_scale_tril.pow(2).sum(dim=-1)\n",
    "        g_var = g_scale_tril.pow(2).sum(dim=-1)\n",
    "        if self.y is None:\n",
    "            return f_loc, Kff, g_loc, Kgg\n",
    "        else:\n",
    "            return self.likelihood(f_loc, f_var, g_loc, g_var, self.y)\n",
    "\n",
    "    @pyro_method\n",
    "    def guide(self):\n",
    "        self.set_mode(\"guide\")\n",
    "        self._load_pyro_samples()\n",
    "\n",
    "        pyro.sample(self._pyro_get_fullname(\"f\"),\n",
    "                    dist.MultivariateNormal(self.f_loc, scale_tril=self.f_scale_tril)\n",
    "                        .to_event(self.f_loc.dim()-1))\n",
    "        pyro.sample(self._pyro_get_fullname(\"g\"),\n",
    "                    dist.MultivariateNormal(self.g_loc, scale_tril=self.g_scale_tril)\n",
    "                        .to_event(self.g_loc.dim()-1))\n",
    "\n",
    "    def forward(self, Xnew, full_cov=False):\n",
    "        r\"\"\"\n",
    "        Computes the mean and covariance matrix (or variance) of Gaussian Process\n",
    "        posterior on a test input data :math:`X_{new}` for both mean and variance\n",
    "        parameters:\n",
    "        .. math:: p(f^* \\mid X_{new}, X, y, k, f_{loc}, f_{scale\\_tril})\n",
    "            = \\mathcal{N}(loc, cov), p(g^* \\mid X_{new}, X, y, k, g_{loc},\n",
    "            g_{scale\\_tril}) = \\mathcal{N}(loc, cov).\n",
    "        .. note:: Variational parameters ``f_loc``, ``f_scale_tril``, ``g_loc``, \n",
    "            ``g_scale_tril``, together with kernel's parameters have been learned \n",
    "            from a training procedure (MCMC or SVI).\n",
    "        :param torch.Tensor Xnew: A input data for testing. Note that\n",
    "            ``Xnew.shape[1:]`` must be the same as ``self.X.shape[1:]``.\n",
    "        :param bool full_cov: A flag to decide if we want to predict full covariance\n",
    "            matrix or just variance.\n",
    "        :returns: loc and covariance matrix (or variance) of :math:`p(f^*(X_{new}))`\n",
    "            and :math:`p(g^*(X_{new}))`\n",
    "        :rtype: tuple(torch.Tensor, torch.Tensor)\n",
    "        \"\"\"\n",
    "        self._check_Xnew_shape(Xnew)\n",
    "        self.set_mode(\"guide\")\n",
    "\n",
    "        loc, cov = conditional(Xnew, self.X, self.kernel, self.f_loc, self.f_scale_tril,\n",
    "                               full_cov=full_cov, whiten=self.whiten, jitter=self.jitter)\n",
    "        \n",
    "        loc_g, cov_g = conditional(Xnew, self.X, self.kernel_g, self.g_loc, self.g_scale_tril,\n",
    "                                   full_cov=full_cov, whiten=self.whiten, jitter=self.jitter)\n",
    "        \n",
    "        return loc + self.mean_function(Xnew), cov, loc_g, cov_g"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 121,
   "metadata": {},
   "outputs": [],
   "source": [
    "class HeteroscedGaussianD(Likelihood):\n",
    "    \n",
    "    def __init__(self, variance=None):\n",
    "        super().__init__()\n",
    "        \n",
    "        self.softplus = torch.nn.Softplus()\n",
    "        \n",
    "    def forward(self, f_loc, f_var, g_loc, g_var, y=None):\n",
    "        scale = g_loc + torch.randn(g_loc.size(), device=g_loc.device)*g_var\n",
    "        y_dist = dist.Normal(loc=f_loc + torch.randn(f_loc.size(), device=f_loc.device)*f_var,\n",
    "                             scale=self.softplus(scale))\n",
    "        self.y_dist = y_dist\n",
    "        if y is not None:\n",
    "            y_dist = y_dist.expand_by(y.shape[:-f_loc.dim()]).to_event(y.dim())\n",
    "        return pyro.sample(\"y\", y_dist, obs=y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 120,
   "metadata": {},
   "outputs": [],
   "source": [
    "class HeteroscedGaussian(Likelihood):\n",
    "    def __init__(self, variance=None):\n",
    "        super().__init__()\n",
    "        \n",
    "        self.softplus = torch.nn.Softplus()\n",
    "        g_variance = torch.tensor(1.) if variance is None else variance\n",
    "        self.g_variance = PyroParam(g_variance, constraints.positive)\n",
    "\n",
    "    def forward(self, f_loc, f_var, g_loc, g_var, y=None):        \n",
    "        # Attempt 1:\n",
    "        noise_var = g_var + self.g_variance\n",
    "        #noise_dist = dist.Normal(g_loc, noise_var.sqrt()).sample(g_loc.shape)\n",
    "        noise_dist = g_loc + g_var * torch.randn(g_loc.size)\n",
    "        y_var = f_var + self.softplus(noise_dist)\n",
    "        y_dist = dist.Normal(f_loc, y_var.sqrt())\n",
    "        \n",
    "        # Attempt 0:\n",
    "        #variance = g_loc + torch.randn(g_loc.size(), device=g_loc.device)*g_var\n",
    "        #y_var = f_var + self.softplus(variance)\n",
    "        #y_dist = dist.Normal(f_loc, y_var.sqrt())\n",
    "        #y_dist = dist.Normal(f_loc + torch.randn(f_loc.dim(), device=f_loc.device)*f_var, self.variance.sqrt())\n",
    "        self.y_dist = y_dist\n",
    "        if y is not None:\n",
    "            y_dist = y_dist.expand_by(y.shape[:-f_loc.dim()]).to_event(y.dim())\n",
    "        return pyro.sample(self._pyro_get_fullname(\"y\"), y_dist, obs=y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 148,
   "metadata": {},
   "outputs": [],
   "source": [
    "from pyro.infer import TraceMeanField_ELBO"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 150,
   "metadata": {},
   "outputs": [],
   "source": [
    "? gp.util.train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 152,
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "pyro.clear_param_store()\n",
    "likelihood = HeteroscedGaussianD()\n",
    "hvsgp = HeteroscedVariationalGP(X_train_tensor.view(-1,), y_train_tensor.view(-1,), kernel, kernel_g=kernel,\n",
    "                               likelihood=likelihood, whiten=False)\n",
    "\n",
    "loss_fn = TraceMeanField_ELBO(num_particles=10).differentiable_loss\n",
    "num_steps = 200\n",
    "losses = gp.util.train(hvsgp, num_steps=num_steps, loss_fn=loss_fn, optimizer=torch.optim.Adam(hvsgp.parameters(), lr=0.1))\n",
    "num_steps = 200\n",
    "tmp_losses = gp.util.train(hvsgp, num_steps=num_steps, loss_fn=loss_fn, optimizer=torch.optim.Adam(hvsgp.parameters(), lr=0.01))\n",
    "losses.extend(tmp_losses)\n",
    "num_steps = 200\n",
    "tmp_losses = gp.util.train(hvsgp, num_steps=num_steps, loss_fn=loss_fn, optimizer=torch.optim.Adam(hvsgp.parameters(), lr=0.001))\n",
    "losses.extend(tmp_losses)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 153,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.0, 1000.0)"
      ]
     },
     "execution_count": 153,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(losses)\n",
    "plt.ylim(0,1e3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 154,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'noise' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-154-9643e2313d28>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     21\u001b[0m     \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mplot\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mXtest\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumpy\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmean\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumpy\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'r'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlw\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m2\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabel\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"Data\"\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# plot the mean\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     22\u001b[0m     plt.fill_between(Xtest.numpy(),\n\u001b[0;32m---> 23\u001b[0;31m                      \u001b[0;34m(\u001b[0m\u001b[0mmean\u001b[0m \u001b[0;34m-\u001b[0m \u001b[0;36m2.0\u001b[0m \u001b[0;34m*\u001b[0m \u001b[0mnoise\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumpy\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     24\u001b[0m                      \u001b[0;34m(\u001b[0m\u001b[0mmean\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m2.0\u001b[0m \u001b[0;34m*\u001b[0m \u001b[0mnoise\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumpy\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     25\u001b[0m                      \u001b[0mcolor\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'b'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0malpha\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0.3\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabel\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"Likelihood noise\"\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'noise' is not defined"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#def plot(plot_observed_data=False, plot_predictions=False, n_prior_samples=0,\n",
    "#         model=None, kernel=None, n_test=500):\n",
    "model=hvsgp\n",
    "plot_observed_data = True\n",
    "plot_predictions=True\n",
    "n_test=500\n",
    "n_prior_samples=0\n",
    "\n",
    "plt.figure(figsize=(12, 6))\n",
    "if plot_observed_data:\n",
    "    plt.plot(X_train_tensor.view(-1,).numpy(), y_train_tensor.view(-1,).numpy(), 'kx')\n",
    "if plot_predictions:\n",
    "    Xtest = torch.linspace(-4, 4, n_test)  # test inputs\n",
    "    # compute predictive mean and variance\n",
    "    with torch.no_grad():\n",
    "        if type(model) == gp.models.VariationalSparseGP:\n",
    "            mean, cov = model(Xtest, full_cov=True)\n",
    "        else:\n",
    "            mean, cov, mean_g, cov_g = model(Xtest.double(), full_cov=True)\n",
    "    sd = cov.diag().sqrt()  # standard deviation at each input point x\n",
    "    plt.plot(Xtest.numpy(), mean.numpy(), 'r', lw=2, label=\"Data\")  # plot the mean\n",
    "    plt.fill_between(Xtest.numpy(),\n",
    "                     (mean - 2.0 * noise).numpy(),\n",
    "                     (mean + 2.0 * noise).numpy(),\n",
    "                     color='b', alpha=0.3, label=\"Likelihood noise\"\n",
    "                    )\n",
    "    plt.fill_between(Xtest.numpy(),  # plot the two-sigma uncertainty about the mean\n",
    "                     (mean - 2.0 * sd).numpy(),\n",
    "                     (mean + 2.0 * sd).numpy(),\n",
    "                     color='C0', alpha=0.3, label=\"GP Posterior Mean\")\n",
    "    plt.legend()\n",
    "if n_prior_samples > 0:  # plot samples from the GP prior\n",
    "    Xtest = torch.linspace(-0.5, 5.5, n_test)  # test inputs\n",
    "    noise = (model.noise if type(model) != gp.models.VariationalSparseGP\n",
    "             else model.likelihood.variance)\n",
    "    cov = kernel.forward(Xtest) + noise.expand(n_test).diag()\n",
    "    samples = dist.MultivariateNormal(torch.zeros(n_test), covariance_matrix=cov)\\\n",
    "                  .sample(sample_shape=(n_prior_samples,))\n",
    "    plt.plot(Xtest.numpy(), samples.numpy().T, lw=2, alpha=0.4)\n",
    "\n",
    "plt.xlim(-4, 4)\n",
    "plt.ylim(-2, 2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 155,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x13c1c65e0>"
      ]
     },
     "execution_count": 155,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAssAAAHSCAYAAAAaOYYVAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAACPoUlEQVR4nO3dd3wb9f3H8ZeGZXnFM8vZkxESQgaEMALEbAoBGsIsLbSUEnZ/7F1KCRQIu1AIG0rKCqNAS9grkAAhIZCEDLKXndhOvCXd7w/dySdZsi1b3u/n48EDjdPd6SQrb330ue/XYRiGgYiIiIiI1OFs6x0QEREREWmvFJZFRERERGJQWBYRERERiUFhWUREREQkBoVlEREREZEYFJZFRERERGJQWBYRERERicHd1jtQn40bN7bJdvPy8igsLGyTbXdEOl7x0fGKj45XfHS84qPjFR8dr/jpmMWnrY5Xfn5+zPtUWRYRERERiUFhWUREREQkBoVlEREREZEYFJZFRERERGJQWBYRERERiUFhWUREREQkBoVlEREREZEYFJZFRERERGJQWBYRERERiUFhWUREREQkBoVlEREREZEYFJZFRERERGJQWBYRERERiUFhWUREREQkBoVlEREREZEYFJZFRERERGJQWBYR6aQCRoBvtnyDP+Bv610REemwFJZFRDqpWT/M4vg3jufhRQ+39a6IiHRYCssiIp3UzfNuBmDG/BkYhtG2O9MKqvxV/Lzj57beDRHpZBSWRUQ6oVUlq0KXe6T0YHvl9jbcm5ZX7a/m5LdO5pCXD+GFpS+09e7EpcpfxX9W/4fNZZvbeldEJAqHkYByw8KFC3nyyScJBAJMnjyZKVOm1Fnmiy++4KWXXsLhcDBgwAAuueSSBte7cePG5u5aXLZvd3DVzT5+6H8lgRg9fkO3XkZWxd4AbMh8lU1Zb0RdLsmXw94b7gldX9j3Ynyu0qjL5hefSH7JCQDsSPmWlT3uj7mPe6+7j6RAJgDLe9xNacriqMtllu/DsG3BY1ztKmJR3z/HXGdzn5PT6apzvDr6c4omUc/Jfrw6y3OyS/RzcjpduKozm/2cMt15zPrdefTL7hFadvZX87j/k1fxGdUAnLTbr+idmcXDX7+AgR8HTv44/jR+d+j40GMMA2bOTGf1ajfDhvk499wyAu5d/Om5xzhjbAGL12zjuw3LeOFPf8ThcADw52df5bNNn4TWkVo9gD033QLA8OE+Lr54FxtKN3PeU09QVLUVALc/k4NK7uXPfy7l7588xfy1S6mormFSxQyuuszgrKfuprBqMx4PJHkMynY5GLbl/+jJWA4/oog5FTfw5rZ/krvrQA5c8S4OHKzP+jeBXt8x65xzyfFmc8o/7mfLzh2MXn8/PXsGuPrqUjwemDUrjQ9++pEVPWbGfO1Grb8bjz8XgJ+730dJ6ndRl+tWMZLhW4PvgRpnCd/3i/3ZP2TrxWRXjAFgY+brbMx6Lepybn83Rq+vfa9+3+dySlN+oCj9cwBcgRTyS47n/PFnMICJvPpqCunpBief9x03vfUi2yq2kJy9DXfGdqq3DMVX5QZg7JonGTbUz+m/28w5Tz/ItUeczssLvmbT4j3JLZsIQGHm+5x8rIdV27by2vI3cQa8TNz2D6ZP38VDn7/E55s+xel00i0pkwdPuZBbXn+VbetyGctv2Xvvaj5ZvIFvut3G70ZPo8bv49lFL1Oc9g07PStIMtLYfcNNDCmcDkByMlx88U7y+1Xwlzdf4r3lCwCD3sVT6Fs6hSlTKigoqKpzfD74IJnvv0/i0kt3AXDnTAev+mIf98Hb/kRO+X4AbOr2Nhuy/x11OVcglQlbZ1FVFdzmoj5XUO3eFnXZniVH0694GgCl3iUs7/n3mNvfa8MdeH09AViZ9zA70r6OulxG5Z7stuVKAHzOMhb2m56Q57TPuto2pZZ4Tmt6/ZNtyV90qufUUq9TVdJm/jDmfKZM2RrzMS0lPz8/5n3u5q48EAgwa9Ysrr/+enJzc7nmmmsYN24cffv2DS2zadMm5syZw6233kp6ejolJSXN3WyLqKhw8PZ7wOUvxlxm/X9+BytSg1cOXQaDXoq+YElfVs95pPb6FW9AWvQ36/rvRsIn5jp3L4RTY6wTWP/4g1BmLnvGF5D/bvTltlSzZI65XLciuLyedeo56Tl1gee0Hjji1Vd5/aQXGZ49nAcWPsCMRTMgy3zgugn8a3Yyu/a9gorsZaH13br4S86a9CluZ/Djct4PRdz97qdQuDu8ujdPv7adzacPB+CzNz+lptc8SIIXP5vI+JGp5Kf25cWyyyG7pnYnN+3D8jnmP0quKn4a8H/8b9u/qErdBeaus6snvzz4GDU95vNixrWQHrz5uZm3szp1DguzH6hdFiAb1r95Hqxy8f7HqRSf/RZ4oei163l9ZVpwmYKfYOD9HPjiMxyUdwxfJb8A/hx+mfM4AIccUslee/m48cZMGLYDzqjntXvyHig1d+DUedAn+pc3Cnfxo/V+SNsJV9SzznfPgGXmspN+hkNjLLurR2ifAbj8LUjfAH43rvWT8A94n3U/9uOlVRlsL13A2q/2g8os3tryHdv3fwi85uN2AqmLQ8dx/X2zAQdv//gVP454kWn/eQOj21pY9jAsKID0zbDPYpZ+8SE7PEvwZ2+CqnTWPvAMqWkB/r1uHYFBP0Pv4BeHS15KYmHKg+Del8WPTwfSYMAi+N2L3PH9EgxHNVXmey2pJo+apEIWFy5hsXW8hr7DJ688SEb/FSwvXg7Z5n4uHMH8j1P58cckCgrq/h2cdVbwS8yBB1bRrZvB/Q954Op6jvvck2GJuc0DVsHhMZatzGTN7KcIHbCL34XsVVEXXf/jQL55z1xuUCmcXc/2n7kddpjL/no+9I2x7KrD+GnOzcHL3urEPac5T9Veb5Hn9CXs1dmeUwu9TrnLmD/fQZSaa5tqdmV5+fLlvPTSS1x33XUAvPZasBJw4oknhpZ57rnn6N27N5MnT45r3a1dWS4vd/DGu35+dn5IRUVl1GWGJR1Alqs3AOt9P7DJtzTqch5HCnsnHxu6/l3VG6HqVaQ+7j3Jd+8JwA7/elbUzIu5j6OTjyPJEfykX179KSWBLVGXy3blMzQpWAmpMspYVPVOzHU29zmlpHjrHK+O/pyiSdRzsh+vzvKc7BL9nFJSvPgrHc16Tgu/d/O9+0kY8CmnDD+F6/e9nvH/Gk+Vrxo+vYYpBwxizhOjSPIEqDl7f9jVk6Mct/Fu6YOkbDuI7+6eToYnA4AH5v6PGat/B8uOY8B3T7Dm133Bbe5LdSp4ygEYnzKF+RVzODT/CD7c+D8o68HZPf8KQKozkxGew3ntP37eHzYBclYGH7/sVxzW4wT69Qvw/TfpLPzXaQyffhnLu98Ly44j6eeTqVl8It5LxlKZuhI+uZbj9x9MeTn07BVgRMpBzLh+N0pLHbj2fhG/4ePOM48jNTX4Mf/yl4v5yHkrDJkbOl55q/5Iv8X38913Hv75z+0MHOjjiCN60GvYGo784/9ivnZ7Jx+DxxH8R+7nms8p9m+KulymsxfDPQcGD49RwfdV/4m5zqFJ+5Pt6gPABt+PbPT9GHW5JEcyo5N/Fbr+fdVbbCupYs5DB8H2oTDkf7Azn72GpPPDEUOhIhvuKIKkcph8LePy92bBpz2hIod+e/3CYQXBCuxXs85m6U8eSCmCP+eHXlfvml9x19in+XL5ap7PnIArkIo/qQRqUhi77p9888yZTJlSzpw5qbh2/w95BU+yJe8VupdOZlu39wG4YGspS5cm0WPwel7sOyz8Cf3737DseMj/hjFjqjnn8L0pKq7mpsL9IGtNcJmioTi/+jNnneIibdcIHr55Iv36+Zg3byszv53Jv5f/mxv3u5F9e+7PqF8thwn3cs6Eozi2++85+ZRu9DjkRY4+um4VGmBI0n7kuPoBsMm3lPW+H6Iu53K4mZR3Fjt37gRgUdU7VBllUZft5R5OP/coAEoDW1hW/WnU5QBGeo7E6wz+fa2smcd2//qoy3Vzdmc3zyQAfEY131XF+IIW53MakzwldL0lntOmpO9ZvzN6L31HfU4t9TpVGjs5YeyhDBkSvRjSkuqrLDc7LM+bN4+FCxdy/vnnA/DJJ5/w888/c+6554aWufPOO8nPz2fZsmUEAgGmTp3K6NGjG1x3a4dlS15eHoWFhW2y7Y5Ixys+Ol7xScTxeumlFC7923q4YBQ9U3ty9p5nc+eCO2HZcaS/+To//riZkSN7UXLgdBj/CHzxZ5bM/DNjxnanqtLN0qWbyMgIflRe98ZTPLXlOnquPY/z+tzJrZ/OhEOCLRXs6gnpwS8R7kAaPmcZOdWj2O5ZRPKmg1h1Y/ivVp995mHaE7fB+Ifh/dvJXnYxC+ZvxesNtnrcdVcG3Bw8tWTAB+9z3MjxPDR7A87fH0igIoNpWxdyz13h/wiefnovPv44+JgePfx8913tl5qlS91MLsgl6dTTqdnt37DycM7xvMIi4yUWeO/mmP5TGJa5G/fd2ZcD+o/l3y9E/we2vZo9O4X//CeFM84o55xzcuhzxAtsmHgGrDiSowpf4913U9hjjxr+979tPPFEGu++62XWLAeZmcH319lXr2buzn8GfzXo/R2MCFbE9lvxGq/esS+fz3NwysIB4DJ/Jdi8N7f1/4Dr/uJkwoHFzJs7kKysAPtNv5f/Jv0Zb/kQKlNXkrZ1EsuvC/ZR+/3Q/2/HQK/vg+tYNwHHE19gGMGWnYcf3s4JJwS/TI879Ts2HTKFPMdwCu/6mD0HZvLee9vYtMnJuOtn4NzrZW7c8xH+9f07LMt+GJfDhdPhombzUOjxI6PTJnNJ3ov87nd5HHZYJc8+2/y+dX1+xU/HLD5tdbxatA2jMQKBAJs2beKmm25i+/bt3HTTTdx1112kpaWFLTd37lzmzg1WPGbMmEFeXl5r7F4dbre7zbbdEel4xUfHKz6JOF7jxztg6164K/LZwkaeW/pc8I6vL2TffaFnzzz69IGSot1g+2BSlv2GIUNyGT7MyeLFsH17Hv0G1GAYBjsCRQB0MwZw6KGp3HrrzbDgfPi/3qGgDMFePYDKop6QlU1azaA6z+PYY8Fx6j0Yc2eAP5kLb/DRt29wmdxcJ5x8RmjZnlUH0aePAwp3J3D3GsheRd+z0snLSwlb5z77OPj449rL9m0ecAAMH+Zk+eznyD/wd2z88iD2vD2ZFWsNyPmRbYHRfFX4Apz9C93Wzicvb1Szjntrmz49+N/PP6dD9ko27H9m8I51+/PgLBcPPODnt7+FHj3yuPpquPrq4PvL5wseo7x+P4DnmeBj3psRDMulfThm+NHk5Tno29sBHwyB7uYvIIW74R+/DK6eyLdlg2H5UySn9qZ7Ri+ohMqU4E/fyUZ22OuQXjqWXb2+h3fuY+iOC8gaa7BgQTAsH3dcOnl5wZ6bs/Y/ijvvW0VxVU+o8rDPPn7y8vIIBIDkEgLpG7j54XWw9Hr4v4fxG378hh8WnQUF17Cw7H2urpoIw+4lL+/IhHzu6PMrfjpm8WmPx6vZYTknJ4eioqLQ9aKiInJycuosM2zYMNxuNz169KB3795s2rSJoUOHhi1XUFBAQUFB6HpbfRPTt8D46HjFR8crPok4Xrm5DqA3fHw9f/9rBYf1P4Q//XMOX686nJHHlVFYuJMePXL4cfMA+PQ68t17UFS0jf79s1m8OIWbPr2SeR/O4r5D7mPDztUApPp60b9/IW53L3y7esL9y9ljYAY/bVkL2atwFdyIP+tnKj+5EH46nj0O3hX1eZx+eibPP5/G2WeX8Yc/lGAtEgikwudX4NjzVYyPbsDtCuDxVABZUJMGW0eSnFxKYeGusPWNGtUD66N9+PDgc7ObPLkby5ens/GTo8xjU0TaL90BWFH1BTscv0BlJgNThnbY92llpRP6fwYO84fT9fvj8RRyZfCcI+xPy/7+GpY+DKzunlHPw+uPw5ZRDJqxi8LCKior3cGqsxWWi3Yj3ZkEQHXaKjjnYEo2HEEKwV9are17/Flhx7J7zT7sAsifT2+Pn1GjKliwIIPddqvB5SoM7d/kyW7uvLMfPvNxgwfvorCwjJ07g1/+AOjxAyz4E3x1Iez3IF5HBpXzLoGCawDY4vsZigeQlFRJYWHzzxfS51f8dMzi0x4ry80eOm7IkCFs2rSJrVu34vP5+OKLLxg3blzYMvvuuy9LliwBoLS0lE2bNtGzZ8/mblpEpFEyMgx69fLjm/cnJqacQa+0Xjg/uw4MJ2PHBtNRr15+WHoifHcOvXoFABg8OBhTSncksbNmJ/M2z6OoZgMA3ehDSorBnnvWAA7YPgyjPBc27As/nIq/KljxDRx/NmSvJCfTFXXfbrmlhLlzt3LbbSW4bIskJwOb9yH3kZ3w6bV4vQZZWYGwx0ZeBxg9urazbq+9aurcbz1fS//+fvKSgn3COxy/BG9cewC9ejii7m9HkJJiwPr9Q9c92/YNO7axDMnvVnulJhW+Oxc2jjdfY/B6DSjarXa9pcPJS8sKW4fHl82e6fvB3RtwfnpjcH+sM/NMAz37BC/0mU9+vp8TT6wgIyPAaaeVhy23114+Ro+ufb322CP4fkxKojYs7/tw8IvBvEvpntybMdUXgC8FtgTv7x0YA9tG0K1b5x9nW6SlNDssu1wuzjnnHG677TYuu+wy9t9/f/r168fs2bNZsGABAHvvvTcZGRlcdtll3HLLLZx55plkZGQ0e+dFRBpr2LBg0Pj552DVdevWYHoaMCA4jJ8VkIOXg7dZYdm5/mAA5m2ax3Z/MCxnO4MBc8yY2kBa7t8ZHDHBWQMZweVIKYYeS6IGW4CUlGAIckRkU683GG5Kit2AA6/XIDs7fB2R1wF2283A6w3ePnJk3bC8zz5RwnJyr/CFNuxLjx4dd4rslBQDiobBl5fBh7eQ6uzW8IOA3r39UGX+27Q+OJxVTo4/9N7weo1gZRlg8WmkrT6V3PQMMGpfPI8/m8xUL+zMJ2AEj2GKIzNsO7tnm+tI30x+Hx977OFj6dLN/OEPdXvEzz679jYrtCclGbVh2VwPO4bwp4qfGLj6huBtrz/B3sZpHF0c7JNPT4/+/hORhiWkZ3nMmDGMGTMm7LZp06aFLjscDs4++2zOPvvsRGxORCRuQ4fW8OmnyaxY4ebww6soLw8GnLS0YIjo3bs2HFqXhwwJhuWSxQfgHuZmUeGi0DI57t5AFdOn72TdOhfvV9/N2snXR9/4aSeQvH014Gn0/lphuabGEbremMqy2w333FPMtm2u0BcBu169AjidBoFAcL2pqQbZqelQngle82f6jePo2bPjhiuPB5xOCPw3ODa3t1fjgn9+fgAenwejnyR/+Q3kjarmkEOqQl9kvF4j+MvBVxfC2oNI8UJqiiM42kZq8OQ5r5EdDOsAH/wVPrqJkaftBGpHDOrfxwV3rAbDSd8b69+344+v4B//SKdbN4Pu3YOvidsN7LT9ZLwm+GVu9Wo369aZ/6xvHM/hZY9QWBr8UmidoCoi8WuVE/xERNpafn4waGzbFgwPZWVWWA6GiF69oodlp9Ng6eIsBk3bh5XV85lS9QxzHpxM+tkeoIr8/AB33FHMuDsW1rv9npndsAemhlhh2X69MWEZCI2mEEv37gG2bKntS0hJMWBzn9qwvGksPXt23MqywxF8TtZrHAqvDcjODpBcugdV7/2d3Q+r5Nlnw/smvV4Dtu0J7zwQvD7YF1x3RU4oLKeQHazsnzoFUrbD0x+Q7vVgf+379PFD8UAA8vPr7830emHu3G04bb8DOxzBVoyaB5bRe0Apm8qCE+1s3uxi3bra17W83BHsbwYyMjrulx+RtqbprkWkS0hNDYaFigoHhlEblq0xiMMry8Fls7IMLr98J4GAgzXv/hqAz113wa6eYWHW4wEqcsM3GHDCG4+FruZmx9cDnJzccFiO1obRGIccEhxv1/qCkJpqwM/H1C6wq1eHrixD7esaebk+DkftMekVpRrt8YDDUbsur9cIvg8qak9qT3VkB7c34BMY8Ckkl9QJ6336+KNejsXlok6bjtttQNFwAhv2Cd22caOLjRvtYdnJrl1WWFZlWaSpFJZFpEuwAkt5uYPKSgeBQLAP2G3+vmYFZAgPSpdeuovRo6vxfXERue4+FLmWQu9vw8JyUpIB5RFDHTkDsPowWHUYvHsPWVnxhZXIynJycrDKmJJSu5+xKssN+etfS7jggp3Mnh0cySg1NQDv/Z19366Ev5WSkRFodDW2vbLvfzzPxfrSZP/yZHE4wl8Xr9cIrnvujFDfcprLbMOoME/qu2g3KlNXhK0nP99vu9y019BjdvRYX/oAli93U11dez1YWQ7+M6+eZZGmUxuGiHQJ9rBc24JRGyCyswN4vQaVlY6woORwBE8OXLgwlV87H2Xruv68tnEkXm9xaJmoYRmCP8M/E5zBLfuq+IZCitaGYe1nRYUTrzdASkq0RzYsNdXguutqh5Sz1v3LL26oTqZHv7onBnY0TQ3L/fr5mTcP+vaNXvH1eg0qKmove70G/HIo3LUJ0rfQ98i82tYMVkFqESmB8LpUt24G5523C7fbaPKXEre79v1ssfrbLWVl9jaMjv3lR6QtKSyLSJdg/RRfWekI/TRt9StDMBRfd10pW7c66dEjvAo3YEDwRD/X+oNJ2hX8mdsecjweooflw6+Epz8A4q8CxwrLWVkGGzcSd6W6PtaxsUYIiXz+HVF4WG7887n44p0MGODjuOOi9317vfbLwV8mkpIMasp6QllPMpN3kZKyEyprh4vL9mbVWc9NN5U2ep+iSQoO7xw6UdPtNvD5gpe7d/ezbZuLiorayrJ6lkWaTmFZRLoEKxCGV5bDA+c550Sf3nngwGCVcc0ad2i8XntocrnAUZFLaG0lfSFzPSyZGlom3rAcrWfZvp6m9itHE1ndzM3t+MGqqZXlwYP9XHbZrpj3R7ZhACQN/pKa3v+FDfvi9R4cfK9V1Q5Xl5WSDlTFsfcNS0oKf079+vlZvTr4T/pee9Xw4Ycuysoc6lkWSQCFZRHpEuxhubzcGXZbQ6zK8po1rlC/aWTlN6m8P9WVmVDaF56ZC72/gRVHhe7PzIwvgEa2WNjbMKDp/crRRB6HRK67rTQ1LDckWlh29vsSDvxL8Lby4uAvDUZt60V6WuIneHFH/Ovdv78vFJZHjKjhww+9YT3LCssiTaewLCJdghWYKipqK8uNPenJXlnOzjbC1mfx7tyD6hnFtTf8fGzoYmpqIDgjXxzqnuDXepXlzhCW7cevpcKytd4kd20wTvGaQ7uVDqUmYrlE8njC12nvsbYmoykudlJV5cDtNuq8n0Sk8TQahoh0CfbKcrSe5fpkZwdITw+wc6eTTZuCH5t1KstJsdfVlPAZqw2jNSrLiQzibaU1K8tW/7B9W2kbjgvesGF8i4Rle2XZ6TRCv3g4HEZopj+rBz093agz9JyINJ7Csoh0CdF6luMZf9eaDW/FimAyqhuW6z7OCrx5efGHT5crPIBb27P2I9rsfE3VGSvLLRWW7euyXpO0mn51bksxcuCri+DHk1u8suzx1A51l5/vJycn+PpVVWlCEpFEUBuGiHQJ9jaM2qmuGx9iBgzwsWRJbSKODMuRP4sDjBtXzf77VzF+fHVTdhmv1wib7hpg6tRy+vb1NXmd0SQlmSM6mNtK5EgbbaUpk5I0RrTKcs+S41j9/m2w5iBSrg3e1s03hE3v3G9uf2vCtm+xho6zLg8eHAzLe+zhq/N81a8s0jwKyyLSJVjBprLSSWlp/BM1RE5SEVktjNaG0a1boN6RFRri9Rrs3Fl7ObgdOPjgxAVlS0qKPSx3/EpktApwIoSHZXNbXuDDa83tFtXZfktUlu2/ZCQlGYwbV80//7md0aNr8HjCv/yosizSPGrDEJEuwemsHW+3qCi+0TCgbh9v3cpy3cekpzcvJEULZi3FfizUsxxbtMpytGDe8mE5vA3D4YBjj60MTZ9tfz2b+z4U6eoUlkWky7ACxLZtwROf4mnDiBx7uDFtGM2dYth+kl9Lj2ZgX39nqyy3dFiONkJGa1eWI9m32a1bx389RdqSwrKIdBlWgCgsDH70xROWrZOmItdliXaCX2Iryy0blu3PJ94xoduj9lRZbonXzh6Qo7337FO5d4ZJZkTaksKyiHQZVmW5Niw3PkTYA4fLZdQJKNGqe809sSpyauXW0tItH62h5cKy/XLDlWWv1wjN+phIDVWW7W0YY8YkvsddpCtRWBaRLsMKENb4s02tLEcLrh29DcMaZqyzaOvKsvVea6nXzT4aRrTKsn2fxo2rqbuAiDSawrKIdBlWgCgujr8Nw15Zjha+ogWWyBE04tWabRhVVS26+lbXXnqWW6JfGSLHWa67jU2basvZ1oQlItI0GjpORLqMyOAST1i2n/QWLRjbA8tZZ5UxaVIVhx3WvARqhTCn0wibsa0lVFd3rspya46zHC2Yt3RYtr8forVhrFtXu4Bm7xNpHlWWRaTLiAxN8fQs28NJZWXd++1huWdPP0cfXdnsgGuvXLZ04FEbRuPUV1l2OAySk8O3mZraMifX2d9v0d5nu+0WbL048cTyFtm+SFeiyrKIdBl1w3LTQlRFRd06g73aHG3M5aaI9jN/S+lsleW26Fm2f6mx3mutUVmO1obxz39u56WXUrnooqZPiiMiQQrLItJlNKcNw66ysm6wtAeWaD+LN0VrhmWjk81b0RaV5YbGW06k8Pdb3fuHDvVzzTU7W2TbIl2N2jBEpMuIrCzH28tqzQAYTXhlOdFhOSGrq9eTT24nN9fPCy8UtfzGWoEVUt3uusP8NUd9lWV7MLbaL9qqZ1lEEkeVZRHpMuz9o926BeIe/zY11aCiIvp9kdMPJ4IVxuxDyLWUSZOq+P77LZ3mZLBu3QL07OmvM5lMc4VXj8Nvs3+pmTixmv33r+KUU2K8YZop/P2msCzSkhSWRaTLsFf5RoyIf+zZtDSDohiF15Zow7BOFmutCUk6S1CGYOX1o4+2JnwUEfsXF+uyvWfZ0r17gJdfbrkqvb1a3tIjpYh0dfoTE5Euwx6W99kn/lnN6utxtleTE9+GocphU3TrlvjjZr0WHo+B02xkHDHCx9ix1RxzTMtUkaNRZVmk9Sgsi0iXYe9R3nvv+CvL99xTzGmn5XLzzSV17rOHl0T1yEYbx1faVmTrBQTfV2+8Udiq+9ES7zcRiU5hWUS6jPDKcvxhedSoGn74YXPUdoWOPhqGNE5urp/sbD+DBrXtrHj2gKwT/ERalsKyiHQZhYW1AwA1dQrgWH29LTHO8rhx1fTv72Py5CizoEib8Hrhs8+2tspJl/VRG4ZI61FYFpEu49BDg9NPH3ZYZcJPZgv/WTwx4WXAAD9ffrk1IeuSxMnKavtwqhP8RFqP/sREpMsYONDPokWbycxM/BTELXGCn0gsbrcqyyKtRWFZRLqU3NzEB2VomXGWRWKxv8d0gp9Iy9IMfiIiCdASJ/iJxGKvLOv9JtKyFJZFRBIgvNKn8CItS5VlkdajsCwikgBqw5DWpMqySOtRWBYRSYCWGA1DJBYNHSfSehSWRUQSIHw0jLbbD+kawiclabv9EOkKFJZFRBJAlWVpTXq/ibQehWURkQSwz+imn8WlpamyLNJ6FJZFRBJA4UVakyrLIq1HYVlEJAGswOJyGbhcbbwz0umFfzlTWBZpSQrLIiIJYJ3Up+AirUFDFYq0HoVlEZEEsMKLgou0Bntl2T7msogknrutd0BEpDPIzg7Qo4ef/v39bb0r0gWosizSehSWRUQSwOOBzz7bqjYMaRWawU+k9Sgsi4gkSFqaQou0Dns1WWFZpGWpZ1lERKSDcbnA4VCfvEhrUFgWERHpgKyQrBP8RFqWwrKIiEgHZIVkVZZFWpbCsoiISAc0eLCPnBw/3boF2npXRDq1hITlhQsXcskll3DRRRcxZ86cmMvNmzePU045hZUrVyZisyIiIl3Wq68W8cknW1VZFmlhzQ7LgUCAWbNmce211zJz5kw+//xz1q9fX2e5iooK3nnnHYYNG9bcTYqIiHR5qakG2dnqVxZpac0OyytWrKBXr1707NkTt9vNxIkTmT9/fp3lZs+ezQknnECSfdohEREREZF2rNnjLG/fvp3c3NzQ9dzcXH7++eewZVatWkVhYSFjxozhjTfeiLmuuXPnMnfuXABmzJhBXl5ec3evSdxud5ttuyPS8YqPjld8dLzio+MVHx2v+Oh4xU/HLD7t8Xi1+KQkgUCAZ555hgsuuKDBZQsKCigoKAhdLywsbMldiykvL6/Ntt0R6XjFR8crPjpe8dHxio+OV3x0vOKnYxaftjpe+fn5Me9rdljOycmhqKgodL2oqIicnJzQ9crKStatW8ctt9wCQHFxMXfeeSdXXnklQ4YMae7mRURERERaTLPD8pAhQ9i0aRNbt24lJyeHL774gosvvjh0f2pqKrNmzQpdv/nmmznrrLMUlEVE2hFnURGps2dTPm0aAVtrnYhIV9fssOxyuTjnnHO47bbbCAQCHHroofTr14/Zs2czZMgQxo0bl4j9FBGRFpQ9fTrJn35K8ocfUvTSS229OyIi7UZCepbHjBnDmDFjwm6bNm1a1GVvvvnmRGxSREQSyPP55wAkf/FFG++JiEj7ohn8REQE3C1+vreISIeksCwiIhgKyyIiUSksi4gIaMIoEZGoFJZFRATD5WrrXRARaZcUlkVERD3LIiIxKCyLiAiosiwiEpXCsoiIYKhnWUQkKoVlERFRZVlEJAaFZRER0dBxIiIxKCyLiIhO8BMRiUFhWUREVFkWEYlBYVlERFRZFhGJQWFZRER0gp+ISAwKyyIiojYMEZEYFJZFRERtGCIiMSgsi4iIJiUREYlBYVlERMBp++fAMNpuP0RE2hmFZRERCQ/I1dVttx8iIu2MwrKIiEAgELroUFgWEQlRWBYRERx+f+1lhWURkRCFZRERAVtYpqqq7fZDRKSdUVgWEZGwnmVVlkVEaiksi4hIWGVZYVlEpJbCsoiIhPUsazQMEZFaCssiIhI+GkZlZRvuiIhI+6KwLCIiGjpORCQGhWUREVHPsohIDArLIiKinmURkRgUlkVEJLwNQ+Msi4iEKCyLiIh6lkVEYlBYFhERTXctIhKDwrKIiIRVljXdtYhILYVlERHRaBgiIjEoLIuIiHqWRURiUFgWERENHSciEoPCsoiIaOg4EZEYFJZFREQ9yyIiMSgsi4hI+NBxqiyLiIQoLIuICBhG7WVVlkVEQhSWRUQkvA1DlWURkRCFZRERUc+yiEgMCssiIoLDPoOfwrKISIjCsoiIaFISEZEYFJZFRCS8DcPna8MdERFpXxSWRUS6OsMIb8NQWBYRCVFYFhHp6uxBGVWWRUTsFJZFRLq6iLCsynIHZBgkf/wxzm3b2npPRDodhWURka7O1q8MKCx3QEmLF5N7+ulk3nhjW++KSKejsCwi0sU51IbR4TkLC8P+LyKJ407EShYuXMiTTz5JIBBg8uTJTJkyJez+t956i/fffx+Xy0W3bt3405/+RPfu3ROxaRERaS5Vljs+6zWMfC1FpNmaXVkOBALMmjWLa6+9lpkzZ/L555+zfv36sGUGDhzIjBkzuOuuu5gwYQLPPfdcczcrIiKJospyx2cYADgUlkUSrtlhecWKFfTq1YuePXvidruZOHEi8+fPD1tmr732Ijk5GYBhw4axffv25m5WREQSRZXlDs+hyrJIi2l2WN6+fTu5ubmh67m5ufWG4Q8++IDRo0c3d7MiIpIg6lnuBBSWRVpMQnqWG+uTTz5h1apV3HzzzVHvnzt3LnPnzgVgxowZ5OXlteLe1XK73W227Y5Ixys+Ol7x0fGKT5OOV01N2FVnINBljnlneX8509KA4D/qLfl8Osvxak06ZvFpj8er2WE5JyeHoqKi0PWioiJycnLqLLdo0SJee+01br75ZpKSkqKuq6CggIKCgtD1wjY6qzcvL6/Ntt0R6XjFR8crPjpe8WnK8XIWFtILMJKTcVRVYVRXd5lj3lneXynFxWQD/hZ+7TrL8WpNOmbxaavjlZ+fH/O+ZrdhDBkyhE2bNrF161Z8Ph9ffPEF48aNC1tm9erVPPbYY1x55ZVkZmY2d5MiIpJAVhuG4fEEb1AbRsdjtV/otRNJuGZXll0uF+eccw633XYbgUCAQw89lH79+jF79myGDBnCuHHjeO6556isrOSee+4Bgt8arrrqqmbvvIiIJIAZtKywrJ7lDsh8DTUahkjiJaRnecyYMYwZMybstmnTpoUu33DDDYnYjIiItAQrLJujFqk62fGETtJUWBZJOM3gJyLS1VlBy15ZNsftlQ5Co2GItBiFZRGRLi7Us+xyYTjNfxYUujoWtWGItBiFZRGRrs4KWC4XWKMVRQwnJ+2c9euAWmhEEq5Vx1kWEZF2yBaWDZcLB8EKpRox2j9nYSFJixZpBj+RFqTKsohIV2f1Jzudqix3MN1uuYXcs87Cs2ABoDYMkZagsCwi0sVZActwOjFcrrDbpH1zmpM3OLdtC96g100k4RSWRUS6OvUsd1jWmNiO6urg/xWWRRJOYVlEpKuzApYqyx2PdWKf9eVGr5tIwiksi4h0cQ6zZ9lQZbnDCVWWrddLo2GIJJzCsohIF+MoLyftH//AtW5d8AZ7G4Yqyx2LNb5yVVXw/4ZRW20WkYRQWBYR6WIy7riDzL/+lbwTTwzeYAVjhwNDleWOxXrt7K+XvuiIJJTCsohIF5P85ZcAuDZtAmpn8LNXlhW4OoY6bRigVgyRBFNYFhHpYhwVFeE32Ke7NivLDlWWO4aINgwIfvnxvvUWPQ44APfy5W21ZyKdhsKyiEhXU1kZfj1Kz7Kqkx1EtDYMn4+cP/4R9y+/kHnllW2zXyKdiMKyiEgX44gVlm09yw6F5Q4hcpxlIKyFxlla2tq7JNLpKCyLiHQxkW0YDlsbhirLHYzVhmGrLNtHMqnzxUhE4qawLCLSxThj9Cxj71lWWO4Yop2IqbAsklAKyyIiXZTh8QQv2GbwU2W5Y4k2HnZYZTnyi5GIxE1hWUSkizJSUoIXrMqy06nKckcT7XVSZVkkoRSWRUS6EnNqawDD6wVqK5HqWe54os60aHvtwk78E5EmUVgWEelCHOXldW9UZbnjitaGEQiEvgiJSPMpLIuIdCGO4uLay9ZEFhpnueOK9jr5fArLIgmksCwi0oWEjbtrhmWHrbKMKssdSui1s/P5ak/eNK+LSNMpLIuIdCHOkpLQ5VA/q61n2XC7g7cpYHUMUV4nRyAQ1qusiUlEmkdhWUSkCwkLy35/MCjbK8sKyx2HYcQ+wc9qsQEcttdcROKnsCwi0oXYe5bBrC7bJyUxw7LaMDqAaC0YAH5/eGVZYVmkWRSWRUS6kDrBqbKydug4VZY7lhivkaOqKqzirLAs0jwKyyIiXUhk/6qjujpsBj9VljuOqC0Y1B0eMPLXBBGJj8KyiEgXEtm/GtmGocpyBxIrLEdMca3KskjzKCyLiHQhdUZGqKqqHX5MPcsdS4zXyBlRWdZoGCLNo7AsItKF1PmJ3taGoZ7ljiVmG0ZZWfh1VZZFmkVhWUSkC3Hs2hV+vaoqrGcZVZY7jkb2LKsNQ6R5FJZFRLoQp1l1NBwOIPbQcdTUtMXuSTxijYYRGZZ37myNvRHptBSWRUS6EOsn+kB2dvAGW8+yYTvBL9ZP/NJ+NHo0jIhfE0QkPgrLIiJdSCgs5+QEr9uHjnM4VFnuSBoYDcNwuYLXVVkWaRaFZRGRLsSqMoaF5WhDx6my3O41VFkO5OYC4FRlWaRZFJZFRLoQa1ixUFi2z/ZmHzpOleX2r4GeZSssq7Is0jwKyyIiXUVNDY6qKgyXCyMjI3ibrbJsqLLcscR4jayTOAN5ecHrqiyLNIvCsohIF2H1KxtpaRgeT/A2+9Bxtp5lVZbbv4baMPz2yrJhtNp+iXQ2CssiIl2E0x6Wk5MB9Sx3aLHaMKwT/NLSMLxeHH4/jsrK1twzkU5FYVlEpIsIndyXlgZWZbm6OlShNNSz3LE0UFk2vF4C6enB29SKIdJkCssiIl1EqA0jPT1UWaaqqraybJ/uWpXldq/B6a49HgwrLOskP5EmU1gWEekirOqikZoa3rNsC8uqLHcgDYyGYSQnEzBP5NRJfiJNp7AsItJFhIaNs1WWwyYlUc9yh2LNvBjJafUsq7IskhAKyyIinYxj506c27fjXrKE3JNPJum774K3W5VlW88yET3LJCUFl1Vluf2LUVm2qLIskhjutt4BERFJrNxTT8W1YQOVxxxD8rx5pL78MiX77BN96Dj7aBhOZ2iKZFWWO4CGwrLXq8qySAIoLIuIdCY7d+JZuBCA5LlzAXCtWQNEDB0XrWdZleUOJVYbRojHE5p8RqNhiDSdwrKISCfiWLEidNm9YUPw/6tXB++zZnZLT8fweoO3VVWBwxF8gCrLHUs8bRiqLIs0mXqWRUQ6EcfPP9e5zbV+Pfh8YaNh2HuWrWBsOJ2hyjKqLLd/DXyhMZKTa9swVFkWaTKFZRGRzmT58jo3OXw+XBs31g4plp4e3rNsTYXscoUqy7HG8JX2o6HXyPB4QpOSqLIs0nQJacNYuHAhTz75JIFAgMmTJzNlypSw+2tqanjwwQdZtWoVGRkZXHrppfTo0SMRmxYREZtolWUA9y+/hEZEiOxZti7be5ZVWe4AGmjDQCf4iSREsyvLgUCAWbNmce211zJz5kw+//xz1q9fH7bMBx98QFpaGg888ADHHnsszz//fHM3KyIiUcQKy65ffqntWU5LA9s4yw5bG4Yqyx2Hw+9nKfAusD7K/YZO8BNJiGZXllesWEGvXr3o2bMnABMnTmT+/Pn07ds3tMyCBQuYOnUqABMmTOCJJ57AMAwc1kkl7UUggFFeTlkgQMX27VEX8Xg8uM1B+6urq/HF+mbvcJCakhK6Wm7+/BmN2+3GY1Z2fD4f1dXVMZdNSUkJHbfKqioCMf5Bc7pceM1/DAOBAJWVlTHX2dznFO14dfTnFE2inpP9eHWW52SX6OdUFghQsWNHs59TUno6bvOkNrua8nKcHg8ud+3HYcWOHcERItxuUjIzY24rFiMQwOF0hl2v3L49WMF1h3/sepOTcVon1RlG6LMxUFZGwOnEnZoaus9RWRmcYS8pCV9lJTW7duHNyQluq6oKR3l5KCwbyckYVVXg9RKorKTqp58IFBeTRG1l2Q9UlZWRlJYW3IbZsxwAysz1WcorKmrbNSLE8z7yer04zWPT2PeRYRhUmBNtYBikVlfjrKjAyMoikJWFueFgH7bTSU15OYZh4DGfl/318FdXU11aSnJWFk63m5rq6tp/j6zn53Bg+P04XK7gbVaV3eOhqqyMZHO9FYWFwX31eEju1i3mc65P9c6dOFwuklJTQ/vmyczElZQU3Lb172QggGvDhuDrmpJCpd9Pqt/PDOBp4Angd7b1BjBP8EtPxw9QXBx6Pes77g6nkxTz7yTsuJvsn1/2v9+amhpq6vk1ItV6H1P/e8nlcpFsvu5+v5+qqqqY62zse6mh52TXEs+pyukMHfvO8pxa9HWqZ11txmimL7/80vjHP/4Ruv7xxx8bjz/+eNgyl19+uVFYWBi6fuGFFxolJSUNrnvDhg2t+t+mr7821oJBPf+9HXzrGAYY19ezXF/bcgYY3etZ9i+25V5rYPtbbMseVc9yJ9iW03PSc9JzwsgC46uXXgr7m99+333GJQ6HARguMC7aZx/j+oMOClvfdQceGPaYFd9/b+yWlGQMycgwbr/99jqfI2cPGWIMcruNnxcvDt12cGZmzP0d6nYbK5YsMTYuWWLU5OcbZ3o8htu8LxWMN2+7zdiwYYNRfuyxhgGGPzPTWPL000YPc78PS083im6+2Qg4naHn7c/KMm7Lzzdywfhg7Fgj17a9fmCsfPllY9WbbxoDwDjJdrwKn3vOWLdwoTHaPMb2Y963nmN+nW25txt4zdfalp1Sz3JH2ZbbEnHfeDDuAWM4GP+1LVe9xx7GS1dcYXjBOAKMkquuMv64557GAJfLWPrRR8byb781+rtcBmDsk5JiPHf55UYyGIUjRhiFTz5plB9zjPFNfr7x4IUXGjlgPHL66caugoLa4+p2G0PBuLWgwDhz4MDQ/rjA+MfZZxvb77nH+ObPfzbOOeccY/ny5cbatWuNab/+tXHlFVeE3gsfv/yyMcjtNq6YMMG4aPTo0Ov86vXXG0Pd7uB71eEw9u3Rw8gE47lLLgm+/scdF9qPABhDwDjPdkym2Y7DH8DoA8aq1183Vr3yitEfjKW2+0+t57hPsi1X2sBr+YJt2b/Xs1x6xHtpWD3L/tm23IcNbH+ZnlOnfE6+3/621fPfhg0b6s2j7WrouLlz5zLXHBd0xowZ5OXlte4OVFayxesltZ5KmDM5OfQzpbumhtQY39BSHA4MWyUstaKC1FhVmaQkDLNP0OnzkVpPVcZIScEwKw3JVVWkxviGluxyhaazJRDQc9Jz6tLPqRIoBn754ANGH398aFnX118Hq4qAH3hr8WKeGDmSjQQrdQAfL17MjbbPooX/+x/LamqgpoZrrrmGvfbaiyOOOCJ0/9MrVwLwzXvvceL06VRUVBAoKQk+D8D+e1oScKvPR05FBenFxbg3bmQHYNXXy4GfPv+cIy64gKR33uE84KWSEk6bMYOt5vN/Z9cuTrz5ZtYDs9LTGZuejvH733PdX/8KwOm//EIRwZ67ADCqWzeqhwyhdOdO1gBrIDg6Rn4+GYccwq6aGhaa2zdsVaaUxh5zv5/U+ipDXm9w1A0a/z4yDINUs3JWA8w3/wMIOBwYDgeXBQJs+uknuvv9VAL/A9K//JJHf/wRAP+VV7L13HNZa27vu4oK3nvzTaqAt5cs4azf/Y6ngXMB/4MPAnDXCy8wHegLrAY+8vlYAXzx/fdM8ftZACwl+N758PPP+eOLL/J5VRVPAIsXL+bW669n9ssvA3DOuefSs2dPfv2b37DN56Ni9WqmdevGAwRf57f/9S9WmL+sFBsGX2/dSjLgXrqUvJwc/vTuu2wCHs7NpaaoiJWE91FusV1+zPz/pooKkvLzWQv81eXiGfN41nfcvU5naFhB+3GPxunxBH/pAFz1/P2m0vj3UpLbXdtPn6D3kp5Tx3pOzuTk1s9/DWh2WM7JyaGoqCh0vaioiJycnKjL5Obm4vf7KS8vJ8Pso7IrKCigoKAgdL3Q/Imr1Xi9uFauZEdeXr3b3mT+/w/mfw0tB/BFA5u2lh0HRO84DPLbln24ket0NbBO+7JNeU55MY5XR35ODS3bnOcUebw6w3OKtc5EPCfreDXnOV1+6KHMXr6c4rVrw4599rZt3Adc9Oc/M+zuu9kVCLB/cjKHAL8/+2wmPv00RdXVYY8pKi0N29aFF17I+++/zyeffMI+++wTun3j5s3BxxkGn5q3bfnsM1LeeYekxYvx5+eT/sgjAGzduZPSzZvJBV4aPJjCp5/m7gsv5L7vv6eispLX7ruPrECAUoKhf5sZvo8ieIw/A0qBopdf5tDbb8c7f35oPwrNZX91wgk8/HDtK7f0l1+Cx2jcOJ6/5BKWL19OgRn0AQYPHsymTz8NXf+okcd8JI1/ze8x/2toOWzr3Lp1KyeeeCJr1qzh6quvZtg557ApNZU5AwawxufjJPO1ugPwlZUxGFgFeL7+mnV77BG2/nU7dgBgdfMeAngAK3aUEXzfB4BN69ez46674N57qfL5ODc5mfOAub/+NYe//DI/79iBo6qKg4ABHg/z58/nD+efH9rW/X/9Kz2HDGFbeTm7Abd0706G3891wG3ANvPf0VFeL7OOOIINb7zBwUBSnz7s+PprPjGD+rrXXsO9fTtMmYJ9SpIy2+V8YCOQnJXFZvP9+sPIkWz6z38A+Jv5XzzH3RLr82ua+V9j1vlOPcvZlx0WZfuxlm3Oc4q1bKKeU15eHpvMY9ZZnpN92UQ/p1iZoqXl5+fHvK/ZYXnIkCFs2rSJrVu3kpOTwxdffMHFF18ctszYsWP56KOPGD58OPPmzWPEiBHtr19ZRDqtFLOftNL2xR5qh9NK6d0bgJ2BQHAoNSDT7IUtjuijzk1P548EA8nzycksX7OGq666ildeeSXsXI0SK1TbKjP+QYPYdcEFoevJn3xC0o8/QnU1ny9cyAZgv9696TV4MG6z4u7z+fj744/zDZBrPq7UrNYn9ejBt/36UfrNN/Tr2ZPevXvz8ccfk5ubG9qG1Qeebo6KYCkzT/ZLS0vjlVdeYc6cOfTs2ZP+/fsD0K2JPbgtrUePHrz33nsUFhaG9hXA63aDz0ex+bxSAKqrqXE6IRDAAxR/9llo+YeB18wKl/uUUyjee28GXHcd9xP80uYGuhP8xzvf4QCHgySzyFPl94dGohjUvTsA3xUV8RfgMOCu6mqmAus21UaPF155hbHDhgFwNZBhGOD3Y9XxqsrL2R0YmJFB/j/+wdD99yfrmmsoq6rC88MPWHW75ORkAmZF0V6fs5++Z4X95NxcqtetAyDJGuVEROLW7NEwXC4X55xzDrfddhuXXXYZ+++/P/369WP27NksWLAAgMMOO4xdu3Zx0UUX8dZbb3HGGWc0e8dFRBrLawbfyogTUacsXsxQYGVNDQ6gErh/0yYeADxmMNoREZYH9erFI8CNwNVVVVx+4YX88MMPAKxfv55e5s+NqeZP3tsLC6mB2pnxbH4G7gXe+vBD5sybxwXAh2bIdpnLb921i2/WrycFOMF8XKn5k2ehz8e+33wDwLiJE/GaIaqyspL9998/bFvdunWjoqKCDRs2sH379rCwbJ2oU1VVxU7zC0S0X//ai9TU1LCgDJBi/sy8wzw2FwMnrVpFjfllZR/g4TVrOA14HPgT4DLDckZGBuW//S3Ve+3F74GA00kNcJ257nyzuJNkHqeaQIDZ5eW8DORkZGB9DbkJeItghRrA6/FQBAwBiisqeH/RIgD6Axds2MDJ69ez2Fx2t+pqfgL+ddBBABjJyewA5m3cSPmCBVjNTB6PB6f5U7m9smwPyzvM/28vK6s9wVVhWaTJEtKzPGbMGMaMGRN227RptYV+j8fD5ZdfnohNiYjEbchuuzF57lz6RPT1/VJZGez9zMkhneBP2VeY1cCV6elcAWTk5hIIBEJncxOojSi/A7aceSaj992X3/zmN+y+++4sKikhadMmNhx1FK+//joXXHABbuA1h4PwT0n4oaaGy4Aj3nsPl7lvvc2K7pl77cWx8+ezc+hQHv32W3oBmT16wNatFJsBqE9aGphfAHbfffdQWK6oqODFF1/E5XJRWlrKli1byMjI4N577+XBBx/kiiuuoLdZTU9NTQ2NZFFZWUmpGdbba2U5Fq/5HOxfh36prqbaDMvbgQk+Hy/Y7t9pHsfQFwNrpBLzMRvN5fLN2z3Wl4pAgLPKywkARUlJ3Atc7HJR7vczxOkka+BARq5axeLqahYDM4BvgduBnsDnwOPFxQAMMrdhjTsSGt3D4+Ek4KMPP+SNPfcMqyxboxnYK8tWG4Y9QK/fsIGA+X61XmMRiZ9m8BORTu/Mc85hLnBqRFguNSuLafn5bAVqkpOx6r9pOTncCVzTrVttUAZ2FBczn+AJXwDO4uJQEMnJycFpBq3V69dzgdly4QP6Out+3A4wWyPWbd3KZjM89TaHqhuQk8PBQG+zIugGksyeujK/HyfQzetl3LhxABx11FG43W6SkpIIBAIEAgEcDgeZmZkMHz6c3r17k2W1lhQXh4bfs1eWq6urQ5XlzhCWqwMB7KcyWU0RXxE8gfNrs50l3Xqu5mvkMAx8wAJz+d5mWLYqyxV+PwGC/4A6U1I4Fxhlvm5DXS4qCwo42Hzsh8CvCfZ1AuyflsYI2z4dTbASbd1vmOsxPB6sDuufV60KhWWPxxP61SEAoWX+Zf7ffjqtz+cLBWuFZZGmU1gWkU4v0L07hsuFq7CwdgxPw6DUDLapffviBaqqq/EDyYDLqjZGtGF8+v337AtcARQCcz/4INRyFggEeKisjPuAqx94IOxxw9x1f8jrb25j7bZtbDIrur2sE6TN4GZsCY5z4Ha7Q60hZzkc+IGZBx/MM888w2effcbQoUODz8X8if7vf/87Dz74YNj4p5lmECspKWHUqFFccsklHHLIIWFtGPvvvz/33nsvp5xySoPHtT2xqur3AP8xb6sxDAZS+xPqd8AKgqNFnEtwZI29gKzsbCC8VeYIwJo+K9/8wpKekcEoYKAZPJMhNOPhKnPSjyEuF7hcHENw5JMsgtXio0aM4BXg92ecERaW/49goO5OcDSCy82+aiMpiT3NZX6srAyrLKekpDAtKYkpBPurLwV2N++3h+Wamhq1YYgkQLsaOk5EpCX4DIPteXm4t2zBtWUL/v79McrKQn2eaXl5GE4nu8yfrNMJDqH0HbCqtJQhW7fSo0cPgNpKHcHhy06/887QdpYtW8Yl1rTCZn+qJcXtpiRivzLT0uhG8IQ962f0Hjk5VAGfbdjAe0Da2rUAuBwODhwyhL99+ikTzYq4IyWFzMzMUAiG4OQxJSUloZEvbr/9dk4++WTOP//8sLA8duxYxo4dCwSHOYNgWB48eDCDBw+O5/C2CyPy86n45ReGA9be1wQCLAKqMYMtwQruUebl2wmebFfYpw/VEDZhTG/z//sA+5rDFvbNz+d7YFufPvRYuhQPwVD7A7DVDKX5LhcVTifHAF8VFLDn3Ln48/Iw3nqLA9auxUhJIe+f/8QLuB0OBphf2MoInpgXsCrAyckMN/dhOXByUhJlkyfjdDrJzMzk+dxcXJs31zkOOcApwL8J/lLwq1/9ipUrV2LEGAJMRBqmyrKIdHpz5swhb8sWpgMusye53Awa6Q4HTqeTixwOhpjLpwNGWho3AL8uLmbhwoWhdVXbwnLPiO2cffrpdbY9ZtQoHoBQpTiM18tA29UeBGcaBFi0bRv3Ah9u3QoEg9V+w4ZxDTDJXD40nrXNiSeeyEknnRR22yuvvML27dtDbRglJeGxPSUlhZSUlLB2k47m+hNO4CMIDrdm3maNGu4B7KO2DjGfpzUIYOg42p6/FZanAbtZY3yblecqMxh7AJKS+Mm2bqfLFZp1b0R6OmnWej0e/EOHgtuNG/glL4+VZvtHKbDBfHyy+fobHg9WI0wVMDs3l1mzZoW2Y+1zGTCVYKuHxWq4qKmpwel04vV6SbGNUy4i8VFlWUQ6PSsolFMblsvM9oZuZkBaDZg14VBYzjavF5v9xAA1tqAUGZav+t//uNd2PSkpiTefeor8MWPwRxkNA4+HQYBVg86H0EQDVl/qyLQ0PiwupqpvX/xmQLoHeAY4f9kyjo9Y5b333suaNWt49dVXw27PyMgIrbOkpIRFixZRWFjIiBEjuOCCC0L91f/9739Zv349hx12GIMGDaKjCJjB83JgqTmMnL1fuTvBthmAgd26QXEx28zrockdbJVla8TVjRCafMGqPFeYrS3JBFs3TgQu6NOHozZsCAZjq/fZauGxfwkx15EXCOAwDOYDE2z7mWK22hgeD1a8rbDvA8HphZc5nSQB24CXredBsPXDHpZFpPk6bhlBRKSR7GHZaVaUU2tquBH4k9lekW4LNFkE2zCs6ZXsYdleWe5h24YT6PFz+ND8PXr0CJ3wR5SwbHg8nAZkpaTw0PjxfA2hmQqtcZb9Ph8egiewrTeHK/sX8D2wPUYYqowya2JGRkbYCX6PPvooZ511Fl98ET7Fy4svvsiNN97IsmXLoq67vfJlZLATmA284/NxNHAWwS8+/ZzOsC8V2WY7yuNAPwCrsmx7jbLM/z8IoYBbVlODCxi+IVgH9pjjL7uBewYO5FcQnOXSei9ZM5XZ5hWw+qId5ljNtfOlBXmtE/ySk0NhuRRY4XCwxfyCV1ZWxl6rVzMeOM/22ErgG2pnnwR4/fXXOeGEE3jiCfutIhIPhWUR6fTCKsvbgvXEXOAW4ArzxLh0M8T8k+CMeEZqaqiybG9bqDGrhR5qf+6H4MgEr0dsNyMjozYwRWlxMDweTgEWXnwxv83PJ4naKqfbDGg+2+MXbNjAVGpHaUiO8tP6hg0bwtpG7PvSvXt3nnzySR555JGwcZbtOsI4y9HcNmcO3agd7u2R5GRuItimUAacap74uCfBkU4sXqK3YVivbQBCU3l7vF4CBKu3pcDXKSm1j7GqyC5XoyrL+HzBaYIjnkeyNTKHx8MAgiclPgrssWYNJ554ork6Z2jf7MPHWTM8AhzcuzennXYaGzduZMGCBaxfvz7ykIlII6kNQ0Q6PXtYdphDpjnM0ScCZihMN0OMddKf4fXWVpZ3WNM8hLdhRLoi4rrb7cZhnjQYbVISIzkZB5DtdOIwq8FWZdlpLv/1rl1MBMZs2cL+EeE42QzWdn/84x9577336tyekZFBcnIyRxxxBFA7g19qairvv/8+t9xyC5MmTQp9MehoQ8clR4R7b1ISNWa7RJLDwZb0dCgvpyeQnlfbwdyN2rBsb8M4ieCEMb+iNiy7kpNxEgypqUBaUhLFVjC2qvxOJ0ZEZdmwheXIynLk150UM8gbSUkkA6OBJdZzNPfTCsvWVNyWUmpn77OG0tNoGCLNp8qyiHR60cLyxnXreAv4wWyTsCrLuzDDkdNJltXjawvLpx90EN8Af4pS1a2CsErhOeecU1tZjtGzDEB1dW1YtnqWzeC2raaGL4Gl1dUkp4bXIaNVllNTI2uV5rIRJwNa4yynpqZSWVnJypUr2bRpU4etLCdHhPtvnU7+a172OBz8Yh7rXQ4HBwwbxtvmffawbK8ApxFsabgZaqvBbnfoS1IVZvCNbLlwOmvbLuqrLNfU1Kks/93pZMyEYAezvUfZPsZycHW1leXIsGxNbmK9562+5cjXX0QaT2FZRDo9K0Daw/InP/zAr4CZK1YAwSohBKex/qv5uGwz2Ngryz0yMhgD9DGrky/n57Ob2crgAXZmZPAwcNXUqRxwwAENtmEAOKqqcJgTpliV5cy0NHYD8syQ7XY4SI5omYgMz1Abkh544AHOOussAPbZZx8cZoB7+umnufnmm1m9OjitSqzprjtcZdk2fB7ACaWl/Na87HY6Gd+7N4OBSzMycKWmhgJoWFiOMhY2hJ/gZ0XOicD/VVSEqsahlgtbz7Ij2mtvrywDXvO+JOCynBz22NMcXTk5GYPgeNDWSBfRwnJkG4ZVWX596VL++c9/hsKyKssiTaewLCKdXl5eHv+cPp1HAYfZfrDLbDfIMAPoPrYgWmKGkUO9XjYAj8+cGbrPYVaiA+bP5VN8PuaY4xX7AQIB/gT830kn0bdv3wbbMAAcUSrLR40cyVLgNjMEup1OPI0Iy9YXg4qKCmbMmMGGDRt46623Qvf/+9//5rHHHgu1W6SlpUWd7rqjVZa9tv31OJ14bSfVJTmd7N6nDyuBqT16QHJyaNi4bhA6wS/aawSEQrThcoUqy98Di/z+Oj3LYdXmQIA67G0agMftxulwUANU2b6gGB4PDuBZameLrK8NY28gw+kMVZYBioqK1IYhkgAKyyLS6aWkpHDi5MkcSW1leVdEu8HknByuN5e3WjJSPB7ygVRbiHr5yy/5A/CBGcacO3bgNquEPgAzTFuhOhSYolWWrbAcpbJsVSD9ZmUwMiyfD/Tr06fOOq2Z7KKNiAGETWACwXBtPaakpIRu3bqRkZHR4cKV19a/fWD//iTZwrLH6SRgzdKXmUmVy8XZ5n0ZtqHeorbKEL2yDJBsHybO1rNc56S/yNfeXsF2u3n8uOM4F3jR72f79u1h27Q32lhh2T7dtRWW3wTGeDyhyjIE+5WtsKzprkWaTmFZRLqEgBk0nWZleac5PXGaWc0zkpJCJ/dZYdk6satwy5bQtNHzli/ncWBpTQ2BlBQcNTW4zXVtBvaoqOBgqA3JTexZtpa3RsNwOxyhCSuGAf8Ahg0ZQiSrDePGG2/k17/+NW+//TabzLGloTYs33rrrXz11VdkZWWFhbAlS5bw008/1Vlve2eF5ROAV889lyQzoF4GXNS/P4YZlgOZmbhtFfmT7SdJNqKyfDtwjHmzxx6MbS0Xka0ZRkRYDqtgu92cOGEC3wPnrlnDmjVrzJXXDctW4HU4HPzn2GP5CPgI+BHoBZCczFhqR/Koqalh9OjRnHzyyaHp0EUkfhoNQ0S6hEfffBMD+D+rDcOs5Kab4XGXw8FH5rJW/zJJSbwGnHvKKZx73nlcdtlltdNdO50YWVlQUYHH7Gn2A8sNIxi6rbBcX2W5np7lD5Yu5TdAuVkBd7lc9B80iEKCw51B9Bn87Cf4ffnll3z55ZdAcEg5CLakQLDq2Ldv3+BzMffD+kLgsFVlO4q9996bpwYOZOgvvxDo1i0YZIGLgZ6DBlFtheVu3cDrJRvYAYxKTQ1NXhKrDcP60oTbzZkE/+F8G/M9EFlFNsdeBmL3q9sqy4bLhX/AgDon5uF0YrjdpJjrvW/CBIZfdlnocQcNGoTVeFIBbAWSXC4mAfcDfyL4Gk+dOpWpU6fGPnAi0iBVlkWkS7jnmWe4CdhlVZatsGyGqMXV1Sw0l003w5GRlBQMVaWl3H///SxevJhqa5xll4uAOclHj+JiSiE07bELQkHJOpEras+yFZZjVJbLCY7KcDZwQFYWrrQ0coGlwHwI+8ndcuaZZ3LyySfHPA7WrHyrVq0K3ZaXl8fvf/97TjnllJiPa+/69OnDSYMHswdQnp6O2wysNQSPc9XEifj69KHq8MMxkpNDU0mX2tsTYlWWrbBsTXdt3myvLDui9CxHHWc5cjtuN89t28aP5lV7O4nh8YS+GE3s04dRo0bV3mdb7j6gL3CH+WXHekY+a/si0iwKyyLSJVgVuworLJvBwpqgIt1WpU23VZYPAX573HFUV1fzhz/8gUKz0pvkdofCsru0lAxqQ4oLW89yfW0Y1jarq+tUlq2h4/YFngLO698fzIB0inn7ll27iDRw4EBGjhwZ8zgMMVs3nn/+ea688koAunfvzi233MKIESOYMGEC11xzTczHt2fzjj+eXODomTPxmMf7aeDTkhJ8u+/O1q+/pmLKFAyvF7PZge+t1wli9yxblWCnkzccDu4zb7f3LBOtZznKDH4Q8cXJ5WKWbXa9FPtwgLYpr8sj9u3mL77gcuB3gPVqbQN+AD7H2qUa1q5dy/Lly9kV5b0iIo2jsCwiXYLXNkoEhsGzWVmsAQ486CAA0myVuqHmslbl99bf/54RI0awbt06PjD7eT0uV1h1D8wT/DD72yJ7lutpw3CWleHw+4MhygzqTmsGP2tZt5sap5MjAasmnBQxOoaloiK85jxx4sTQ5SG2Pud58+aFLbd9+3bWrVvHDttQeR3F9u3buefddwHwpqTwyujR3A/cBtwVOXW37YvRZ7Ypw2O2Ydiqz3cRnFWvDzAuPT3qMHF1WjPqa8Nwu8MCsv2ykZzMGPPy7QsW8P7774fue3T+fGYCL9hWW2gY/J3gdNfZmZkceuih3HDDDRx66KF1pjUXkcZTWBaRLiFUWQYclZVk7tpFfyC1Z08AUs3gmwvsZg1DZgbXZGDfffcNW5/H5QqFqGpgkvkfmG0YZliud+g4qw3DHK7NsAUla7rrzcBiYFN1Na7kZP5n34cow7stWrSIO+64A4Bzzz2XG264gX/84x+h+/v27ct//vMfoHaqa7/fz7x583j77eBUHR1tjGWAHTt28K4Vlr1eBmVlMcC8zx0xfrKRnMzlBF+nC3r3rr2jgRP8IDjBCcCTwLk9etQ+JkrPsiPKDH5Q9wQ/e+tFZBvG48CdwLurVvHZZ5+F7rOGj6uN+rA1EAj1Pt8+YwYnnXRSbY+9RsMQaTKd4CciXULYLH5lZTjNdgpruusM8/5d1IZY68QuR01NWMVvLJCdnFxbBQY+sW0ramW5nnGWneaYx/ZKtdtc98/AKOD8Vau4weEgmdqe2chZ64DQZCMAvXv35vzzz6+zjDXVtT0s2/ucO2JYtofM5ORkjOTkUJBMijj2RnIydwO3A+6sLDZbdzR0gh+1YbmaYFXYsIJxtHGWGzN0nNMZFubtQ/ZZ78PQ622riFsnYdqaSCgMBIKjYhCsroOmuxZJBFWWRaRLsIdlZ1ERZ/t8THE6KTJ7OT1m2KoCysxwYw/LWVlZ9OjRg78efzwLgAk9eoTCjD1iXQqcCY1qw7DaAZxRKsuuiHBjja2bbB8/2BxKLtrzBBg3blzdbVIblv3mvkUGqY42IQmEP2+v18vfV6wIzXwX+fysLykeCGvJiDkpiT0sm6/jYmCHYdTbs9yYE/wMtzv05eRvf/tb+EgkHg8BoNi8ag/Lrijvp60+HyXmDIALFy5k0aJFGmdZJAEUlkWkS8jOzqa7y4UBuDZv5r/A64FAKDA6bGGi2goiVkiqrmb69Ol89913TD/wQCD403poUhFqP0zvAq6m9gQ/qw0jamXZ6lkuLg5et1VH87t3525gtHndbe6T/edAd5RqoTV03L777sv48eOjHou77roLgK+//jq4jw5HWGW2o1eWvV4vH23bFroeKyybC9debkRl2fqycg3w6NattcHYPkRg5Ax+kSf42SvLLldo3+vsp8fD74C7zev2wOuMEpYrAgGKzPfdvffeyy233KLprkUSQGFZRLqERx55hPWjRnEE4Ny8OTTsmhVUjKQkFgDvA5lme0Kop9g2BFdNTU1w1jSnM6ziaMWs0JIRleX6epZD123V0e45OVxOcOQLALf1+AbGQA71ZldEG1gu6PTTTwfg+OOPD91mD2IdsbIc2Ybhsbc2RPQs2wOy/QuKEblcaAV1K8sQnKq6TsB2OOI+wa9bt25kZWXVGd/aPnSc9bwskWH5VeC9cePChourrq5WWBZJAIVlEekyDLPq6ooSlklKYixwmHkZqA015k/ZAIc88AAuYHFxcVjYteLPh8AiiKsNI7R/UaqcNaGrwevZ5v9fiBForcry4sWLKSoqirrMb37zG1577TXuuece264E9+Wkk05i9913j/q49sweHk8++eSYfcBQT2U52mtEeIi2h+VklyvUsxzictU9wa++oePcbn7zm98waNCgUKW/dmOeqDP4AQzMz2c3YC/gQI+HXwEH5OWFheWamppQG0ZylAlsRKRxFJZFpMuwprw2Nm7ER7B9Isk2AYnFiLjNUVPD3LlzGTNmDD9uDp4OluR2h4UuK/4cDUyHOqNh1NeGEbpuqyzvrKrieWC2ed1qwzgmM5NTgf1iDBtnr7AuXrw46jJOp5N99903rM/XClNXXnkle+21V9THtXc9e/YkKyuLPfbYI1RZfhy49bjjwpYLC8v2y7F6lm2v08N5efzevJzkdtcJ2Ia9DaMxJ/i5XJSUlPDdd9+xdOnSOvtpD8vWVOUA/7n/fpYS7J3+MD8/+GXN6eSll17i0UcfBYJh+eGHH+bVV1+lT58+0Z+biDRIo2GISJfw8MMP89Snn3IlcNqmTQCkuFy1owrYAlFoNAyrDaOmhkAgwJYtW0LLJLndYT/PTwP+B6zDDM4Rk5I0qg3DFnR3lJcHTxQ0WZXSvw8aRHJhITVpaWyjrnTbSX/eiHGg6xM55XVH9O2334YuW/3cXiAtIyM0pBrErizHasOw3+5yu7F+Z0iOEpbDTvCL9atCxAl+VstM2IQkBN8f1i2Xn3wyJ5xwQu19EUPMvQW8t3Qpk9asCf0yUF1d3WG/+Ii0J6osi0iXUFFRwYaKCoqAarM6nGIPsPaf6q1wZDvBLzLIeNzusLD7OMGxd8Gcwc+qKNtP/IpQX2XZZQtonwOnDRsGwFrD4DfAX8zh5iJ17949NC1yPGH52Wef5W9/+xsbNmwI/XTf0Xz88cc89NBDLF68ONSnbE13HSYpqbav2P66xmjDsL83DFtYTkpKitqzHOort4+9bBN5gt8LLwSnFvnqq6/qbNd6BSus4G2tw+vFIDjUYZnbzYfA/atW8e2334a++NTU1CAizafKsoh0Cfah45K2bmUKkNyvX+h+e4CpM86yz1c3LLtc4RVK4p/Br76eZWvouJ7ARGBXt26UAktqangWGLpzJ3+K8VwrKyuB+MLywIEDOeqoo9i5cydLlizpkEONvfvuuzzzzDOkpaUxvGdPWLyY3wEPLljAibZxpHE4MJKTg1OM249RrMqyLSzPKi3lRfNysm2c5RDbOMuNHTquJMYXH3tluTIiLB96+umsJPhlwP3jj9xq3n7bbbfxwQcfAMGwfPPNNxMIBLj22mvjej+ISC1VlkWkS7CH5R7btvEa8JjtZ217X2qokmj9P2JSkuBdSWEVx5UE+0eh8TP44XSGBTF7cHOZ+xM6Xct8/Lk//gjAinraJZoSlgOBALvMMac74mgYAM888wwAq1at4tLJk7nOvH2DOY51GPOLSlg7QyOGjttmttfsB0zs2TNqz3KdE/oil4moLB955JEA7L333uHLJSdzuHn5yTffDJuevLK6OnTyp9PhoLvtcV9//TUff/wxc+bM4dlnn2XWrFkYhn36EhGJhyrLItIl2MOyJWALhfWe4BetDSMpKezn/cOAteblxs7gB8HqocP8uTyQkxO63W2uuwi4CPjV1q3sBQ0OHQewdm1wT+wjIzTkjjvuCAUqV6wT3TqImpqasBn83FGq5KGQbK/uN6INw5oN8ACge3o6u+rpWY653oih40477TT69etXJyzj8bC7ua3PIWxoOYftNXI6HPS0heHjjz+eoUOHYhhGqAe9I/5SINJeKCyLSJdgD8uVwFbA73ZjRSUjWmXZdoKfPSw/CiRHhGV7vIx2gl/MYck8HrBm1Ovdu3YdtoD2IDC0uJjGnqp1yCGHsHr1agYMGNDIR8D777/f6GU7ghqXi+3m5aQoFfZQC01j2jBstyebIbUawlouQqKF5WitGrZtOp1ODj744LrbNd9flda2Y4yz7AQOAaYOGMCI3/2Oc845BwjO0GgYBk6ns8N/ARJpS2rDEJEuwR6WvwIGAGeaP9sD4dU+q7Js3VZTQ2ZmJpdeeim3H3YY52FWX6OMszwHuI/a9ov6ho4Dwiqb/vz80GVnRCWwsZOSADz33HN8+umncU1E0ZFHwbBcd9115ObmcuGFF3L7O+/wuHl71MpylLDcmOmurRMHHwTWVlZGP8GvgcpyZBtGLIbHwzrgG/O6vTpsD78uh4N04MmDDuIPf/gDDoeD6dOnh0KzqsoizaOwLCJdwpAhQ7js6KM5FWonJLFVi8PaMKIMHZeamsoVV1zBBWPHBhdyOqNWlocB/aFRM/jZtwHhlWVvSgo7ganW+q2A1Yiw7HA44q4kdtQRMOwuuOACvv/+e/r06RMWkN1RJuSIWlluRM+yx7ZMUU1N9AlHGmrDiDjBLyaPhxVhV6NPdx26bK7X4XDw+uuvh34tUFgWaR6FZRHpEoYMGcJ1Z5zBGdSGZY85213wSv0n+EGw+vrPb74JDhEXcXKeFXlCYxY0ZjQMYodlXC7SAWsLVmW5lzkZSWqCf1bvDJVlqO3r9dhCcLQ2jNAJfo2ZlMQelu2z+Xk8UYNxvCf4xWIfDQPCT9i09y87rbHCbWHZHpA11bVI86hnWUS6DN/AgUBtD6jXFpYbOsEP4J133uGKDz4gDfi10xnWQmFFnlOBS4BpkeMsxwhFjoqK0GWjW7faO8zlrVP0rMryscOH8+OXX3JZ5MlgzXTEEUfw/PPPc+GFFyZ0vW3FXlmO1rsdOsHP/utCrC80tvfGUNukL0kxwnKiKsuRYdkegP/4xz+yefNmvF4vgz75BD74IGw7SUlJVFVV0a9fP/r27RtzGyLSMIVlEekSKioq+GrNGrL696fCHC3CG2M0jDqVZXNUienTpwNQhjlEWJSe5R+BL4EzfvmFnNNOCwXgWG0YzqKi6DvsclEAWKfdWWF5WkEBR335Jd0POqihpxwXa+a/7OzshK63rSSZX2QuBibutx/+iPvLzj6bQFoarokTwRxqL9YJfvbK8ticHPoRnKnRE2tSkoZO8GtsZTliumv7kH5Tp04NXe62eXPUsAzw9ttvk2MbZUVE4qewLCJdQnFxMWeccQa90tO53rzNY7Y0AOGztMWoLDscjtrxaiPaMB4leGLfswSrzGnPPhu+AzGqlk4zqEVOcILLxRfmxUFAllkB7X3eefQ78EB85pTGiTJ48GAOOOAAettbQTowq0856gx+QOUxx1B5zDHkpafXhuVYPcv2cOt2YzWseJKT652UJKS+Gfwa6Fm2Gi969epVZ/jC0Pqs/bbtv1WF7gy96CJtTWFZRLqEyKHjALy2n9QbOsEPgtW6UPiIaMMYS3CmvWeJ8cHaQI9xIKL6ZzidofUsBIzhwykzt+vbq7GDyDXemWeeyZlnnpnw9bYVt9lm8SNQ5vMRPWaGa8ykJLsMg63m5aSkpKiTkiSsDSMpqXYGPyvQmz755BN++eUX1q9fz24//cRFEftvVZY15bVI8yksi0iXYIXliqoqCm6+mRd37KBHHDP4QcRkHRFtGGDrL46y/ZjDkpn8eXnhN7hcoQ9oH+DUOLlxOXDffQH4GPh68WIm2Ybli6kRJ/j9YI6JDea4x404wa85Q8dZYbm4uDjsvrvvvpsFCxYA0Cc9nYsitjN+/HhKSkqYMGEC++67L6+99lrM7YhI/RSWRaRL8Hg8OJ1OampqyPrtbzkoYoSAek/wM8Oy2z4Wc0Qbxj8IzrQHMT5YY80OZ/L36xd+g8sVCt0+wNPA4yXcwMGDOQT4CHA1dtrvWJOS2EfDMC/vA6SmpFDeiJ7lOicONnbouORk0oFLcnJw/OY3EauwzeCXnIxRVkaNrTXnwQcf5Ouvv+bEE08kYJ1kKiJNok9fEekSHA5HqLoc+ZM2EFY9jFVZDhuCy+EIa8N41baqqLXCGGF3+z/+QfXIkZTcfHPY7fY2jJ7AF2vXRj5U6mOb7jrq0HFRxBoNI2xSEvNyFQTDdbQgHM8Mfg1UlgHuHDCAK664Iuw++zjLjrQ0Ni9dSqX9lxJq+5U1zrJI8ygsi0iXYYXlV155hTvvvJNFixaF7mvM0HETJkwA4N8Qc1ISgCHRNh4jFFUefzyF775LoE+fOsvba46O+iqQUscvW7bwuXm50eMMN6JnOdm8XE2wKhx1TOV4ZvCrr2fZPAHVsI8HbgobZ9npxLD130Nw9JfCwkJAYVmkufTpKyJdhhWW33zzTebNm0f//v0ZNWoUEDF0nBUuIk7wu+OOO3goK4s+L7xAucsVdVKSN4BfRdl2Qz3LdbhcnATcb61fPctxWb5pU+hyo8NyI4aOs36TWAHRq8jxnuBXz+taPXYsO6dPp+qww+rcF1ZZjjKr4xlnnMFXX31l7r4mJRFpDlWWRaTLePXVV1m4cCG5ubmAeYKWxVZ9i6wsW+Ms5+Tk0N3jIQmzghhlUpLI8XxD4u05djq5DxhjXnUr8MSlKTPYxZyUxBaiM+zDt7ndUcdZTtQJfrjd7Lz2WqrNXzTswnqWo+x3UpTWERFpGoVlEeky8vPz6d69Oz4z/NqnDw5rwzDDjPV/qw3js88+Y785c7gcgqEoSmW5hNpRMcI0oTJsuFy1I2wo8MTFfjKmu7EtLI2oLPfPyuIh4HXMqnAjepbrO8Gv3nGW62EPyNHGX7Z/WVAbhkjzqA1DRLoc6wQ/e1imnjYM6wS/p556iiXFxSwBbnQ6we3GcDpxBAKhyvJvgbXADRHbjLsNA/jF6WSRP1irVmU5PvZqap/IfvAYor1GkYHYcLu5wLy8w+2ue/JetDaMembwa8r7AuCxxx4jEAjg9XrDhzQMbSK4jYMPPjhstj8RiZ/Csoh0Gffddx8LFizgyy+/BMLbMBozdNyqVatqV2YGIsPjwVFZSV/bduIZDaM+J/pqa9SqLMfHCsujRo2KOfNdHVFeIyPyuEfpN7a+MFmXGzzBLwGV5Yaek/X8Tz/9dA455JAmbUNEgtSGISJdxg8//MAHH3wQGlIrrLJsDy0xKsthP+dbAchc5h7AGtyrKTP4ReM2K5JnAXlZWXE/viuzXqu4ZrCLFlwjw3K0kSzsr63DUbftogUqyw2xWi80g59I8yksi0iXYQ/HvXr1Is0cmgsIhhxrmmursmz1LJuB48gjjwRgAraqoq0ftDkz+EXjMkPWBUBWt25xP74rs341+Omnn6ioqGjUY6Kd4Bc5aUjUqrD9cS5X9NaMWOtsYmX573//OyNGjKBPnz784Q9/qHP/8uXLAULDx4lI0yksi0iXYf10ffvtt/PNN9+w2267hd0feWJf5DjLF110Ec9NmMB/IBSI7GHZGgkjUW0Y9hn8mlKZ7sqGDRsWer0bPYNdtOAaeXJclKpw2OgXUdowmjyDXz2WL18emgJ748aNde6/6aabOPjgg0Nf8ESk6dSzLCJdRqo5uUOsSmPlEUfg2rABw2p5MMOWwzwh0OPxcGJ+PqnAjog2jEuwjYkcbeXNaMN4AviLz6fqRpysUU8aPRpGtBP8IivL0arC9hMA4zzBr6lfguwn9UUbZ/mAAw7ggAMOaNK6RSRcs8Lyrl27mDlzJtu2baN79+5cdtllpEfMIvTLL7/w2GOPUVFRgdPp5KSTTmLixInN2mkRkaawKo2xwnLxQw+FXTe83tAJfFRWgtcLhhG803aCH4QPFxc1/jQlLJvbeBK42ucjvf7FxcYwjFC/brPGWW7ECX5h4biVTvCzDx0XbTQMEUmcZhUq5syZw8iRI7n//vsZOXIkc+bMqbOMx+Phwgsv5J577uHaa6/lqaeeoqysrDmbFRFpEiss//3vf2f06NEN97I6HATMXmFnSUnwNusn/YiwbEWeccDkKKuKNeFFfewxyq2xcuNSVFQUuhxt0o6oogTXOqNhNHSCn9PZ4KQkiTjBz/6cGv38RKRJmvUXNn/+fCZNmgTApEmTmD9/fp1l8vPz6d27NxCc/SozM5PS0tLmbFZEpEmGDh1KQUEBANu2bWtUxTGQmQnUhuXQEGFWIDLXYUWeU4Hh0VbUhFA0wzYChlNDx8XF7485l2Js9qqx9WUo4tfSqFXhBnqWW6KybG+9UFgWaVnNasMoKSkhOzsbgKysLEqsyksMK1aswOfz0bNnz+ZsVkSkSY455hgOPfRQhg4ditvtblQvqxERlrFCmBWmzFEXrDUlbLprYFRKCslAFaosx6tHjx5MmDCBvLy8Rj/GHmJ9u+1G+a9/Tc0++4QvFO0EvwbaMOr8qmBfRxPDckM9yyKSOA3+ld56662hM27tTj311LDrDoej3j/YHTt28MADDzB9+vSY34Lnzp3L3LlzAZgxY0ZcH3KJ5Ha722zbHZGOV3x0vOKT6OP1yiuvADBixIhGrdfdvTsAmYEARl5eaCa9jOxs0vPycJvDz1nR5S7gBGC3iPVkZGWRFufzcCUlhXqh87p3x9mY/dX7K+Tjjz9ucJmw42Wr3ru8XlKuv57IqT+ctmp/Vl4eRl4eTlvgTUlPJzk3N+wxaenppNheE4dZZALolp2N0YTX6+CDD2b16tX4/X6mTZvWaq+53l/x0zGLT3s8Xg2G5RtuiJy0tVZmZiY7duwgOzubHTt20C3GOKDl5eXMmDGD0047jeHDo/5ACUBBQUHoJ1Jou/Eh8/LyNDZlHHS84qPjFZ9EHq/q6mr+8pe/APDrX/+6UevNSk0lFdi1bh0VhYVkV1aSAuzctYvKwkJyAC+1H6bbgO+oG5ZLy8qojPN5vFtaGqpUl5SV4W/E4/X+io/9eDnKyuht3u4zjKjHMaWiAivq7ti1C19hIT0djtCXpfKKCipKSrD/flpWUUGZbV3J5eVYcbq0vJyqJrxeJ510EieddFLoemu95np/xU/HLD5tdbzy8/Nj3tesRqdx48aFvrl//PHHjB8/vs4yPp+Pu+66i4MPPpgJEyY0Z3MiIs3y3//+l6VLlwJw4oknNuoxkW0YYdMaU9uGcbTtMYkaOu4/5eWhy44m/lwvjRfWSxzj9Qo74S9az3IjJiVpjRn8RCRxmvXpO2XKFGbOnMkHH3wQGjoOYOXKlbz33nucf/75fPHFF/z000/s3LmTjz76CIDp06czcODA5u67iEhcJkyYQE5ODqecckrofIuGWCf4OSJHw7AmJTHD00SC7Revk7ih45LNkPXPJj5e4hRtWLhGLBPZs9zQaBiJOMFv27ZtrF69mqKiIgYNGsTuu+/epPWISMOaFZYzMjK48cYb69w+ZMgQhgwZAgT7qg4++ODmbEZEJCG6d+/OokWL4npMaDQM69yNiHGWaeQMfk0ZOi7JfIy7iY+XODWishx16LgGJiWpE54TUFmeOXMmTz/9NBBsYbQui0ji6dNXRLqUhk5GjhQwT+iKORqGGZZ/At4yH5OwGfzMbfigyRVIiYO9KhyrDSNaVdh+m8MR3wx+CZiUREPHibQs/YWJiNQjVs+yFZCssPyO7TGJasMoNbd1XhMfL01ghteYQ7pFqwpH9iy38gx+CssiLUt/YSIi9Qj1LFuTKUVOShIxgx9AtOlDmtJGYZ9CW20YrSTaFNY2UYNunNNdawY/kY5Ff2EiIvVoaLpr634r8vwJOCzaipoQirrbJyJRZblVhL6UNKJnOdoJfkYrneBnn5REYVmkZekvTESkHobVsxzjBL/yM8+k5IYbGp7Brwlh9899+gAwANSz3FriaMNobM9ynV8FokyrHS9VlkVaj/7CRETqEXPoOKuynJdH2fnn4zDHW/bVWUNQU0KRX6NhtD7rODe1DSNaz7JO8BPp0FSqEBGph5GWhuFy4ayogOrq2hP8IgKKNXLFE8ClwMjIFTWhslxjC8tqw2gdRnNP8GtEz3Ii2jBOP/10xo4di9frZdiwYU1ah4g0jsKyiEh9HA4CmZm4tm8P9i2bQ8dF9qW6bNdroq2nCWH3tjVrAFjWxMdLE1jHOY6h4yInJWmNE/wGDBjAgAEDmvRYEYmPfrsREWlA2PBxVs9yRMiZ5vEwxLwcNf404afyDNvUypoWuZU00IYRCsj23uSIHuTWOMFPRFqPwrKISAPCho+L0YaR5HSSbF5O1Ax+A1JTAbgaVFluJY1uw7Df30Bluc5rn4DK8ieffMIRRxzBHnvswfPPP9+kdYhI4ygsi4g0wMjIAMBZT1jG6Qyd3JeoGfxc9hn8FJZbRyPbMIzIETAs0dowWuAEv++++44lS5ZQWlrKwoULm7QOEWkchWURkQZYYyk7SktDJ/hF/tT+uc/HcvNyombwqzBbPn6GJrVxSPyMBsJyUyrLkWE50TP4xTN9u4jET5++IiINCE1MUlpaZ5xlS7HtcrT405Q2jMU7dwLwOtStTkrLiFY5tgndbm+liJiUpM5r1cIz+Ln0q4NIi1JYFhFpgNWG4di5MzQaRmQAso+GkRltJU0JNArIra+B6a6jjoBhf23NsGxEtmbYaAY/kY5Ff2EiIg0IqyxbPcsR4ddthqPJQE60lTQhLI/PzQUgqYHlJHGiVY7tAnl5VE6eTMXUqbU3RgvGka0ZdrFaOOJgb71QWBZpWRqzRkSkAYYtLMfqWbYqy4mcwW93c6rtw/Uze+tpoA0Dp5PtzzxT57Y6l53OmGNy43az69xzg9tq4q8H6lkWaT0KyyIiDQhYbRj1jIZhzeD3McFJSepUg5sQeH1mCHIrDLWehk7wi6LOpCT2/0deNpX+5S9N2buQLPOLFMCgQYOatS4RqZ/CsohIA0KTkuzcGfMEP6ct0JYBWZEraUJYXrVrFwBfWH3S0uIaHA0jmohJSSBYTQ69I1qgTWLq1KlMtbeCiEiLUaOTiEgDGlNZ7mHrQ03U0HFecwa/DFWWW09DbRjRxNuzLCIdiv6CRUQaEPUEv4gANNTjwWteTtQMfufuuSevAp+bJ/pJK2hKZbkJbRiJUFVVRVlZGdXV1S2yfhEJUlgWEWmAdYKfY+dOHLFO2nI4sJolEjaDn9vNiUD3JI2H0Vqa0obRUM9ynfdKAvz73/9m8ODBDB8+nJkzZyZ8/SJSS2FZRKQBAft011bPckSYqnQ4qDEvJ6oNo0lVTmkeaxzleMY/tvcsW8G4hSvLAesXDjR0nEhL01+YiEgDwiYl8ZmDw0UElJW+2kHjon2wNqW62KSTzaR5orVRNMT+2lo9z/VMSpIIGmdZpPXoL0xEpCFuN4G0NByGERwRA+oGIFt4iRqLmxJ4rZEVFJZbTZO+oDTUs9wCbRj2gKywLNKy9BcmItIIoeqydTJVREBJbiiwqA2jY2jKaBhtcIKfprsWaT36CxMRaQRrRAxLZFtFkhle+sVaQRMCTahvVmG59TTlBD/7sq10gp8qyyKtR39hIiKNYESE5cjwa8WlWNNdN+mn+Kb0z0qzhL6gxHOCn+21DY2MoZ5lkU5DM/iJiDRCZGU5MgBVmP/flMiNWi0B8QQ3aR5rNIzmtmG0cFgeMWIEJ510En6/n4KCgoSvX0Rq6RNYRKQRrOHjQiLCVF4LjIUcCmyqHLaa8qlTce7YQdWkSY1/UJSwHHXs5QQaOnQoDzzwQMLXKyJ1KSyLiDSCkZoafj2irSIzKYmVQHoiN2qFLPUst5rqAw5g+wEHxPWYhnqW9WVHpGPTX7CISGNEVo6jDB03GOiRyG02ZWQGaX32k/la6QS/TZs28ec//5nf/OY3/PDDDwlfv4jUUmVZRKQRjIbCcgtUDzUpSQcRrT+5hXuWlyxZwosvvgjAYYcdxl577ZXwbYhIkCrLIiKN4fGEX2+Nn9bVhtExtPE4y44WqFyLSC2FZRGRRmiLyrLaMDqINjjBT+Msi7Qe/YWJiDSCYassGw5HnXGTjRYMyzpBrH2zf5mJ1rOscZZFOjb9hYmINIa9shwtnLTAT+FW8NI4y+1ctP5k+wl+LbBJe0B26ZcHkRalsCwi0ghGQ2G5JSvLCkPtWxtMSqKeZZHWo7AsItII9jaM1qosqw2jg2iDE/zsleWkFpgQR0Rq6bc9EZHGsAWSqOPmtkBYrtlzTwKpqVSPGZPwdUviROtZbukT/MaOHcvy5ctxOp2kpKQkfP0iUkthWUSkERpsw2iBsOzbbTc2//hj3QlRpH1poGe5JcKy2+3GrV52kVah3/ZERBqjoTaMlmqVUFBu/xpow2iJGfxEpPUoLIuINEJYZTnKCXcKRF1YG5zgt2LFCvr06UOfPn348MMPE75+EamlsCwi0ghhJ/hFC8Y6Ca/LCps0JtpJmS3w3qioqAhdLi8vT/j6RaSWGp5ERBrDfoJfI3uWff37U7PXXlROntySeyZtzfbaW78wtOYMfhpnWaRlKSyLiDRCU07wM5KT2fHYYy24V9IutPHQcZrBT6Rl6S9MRKQxmjLOsip+XUMDPcst0c9uD8ialESkZSksi4g0QpNm8FPFr2uwfylqg8qy2jBEWpY+yUVEGsFooGc5WvUwam+zdDr219mIFpZbuLKsNgyRlqW/MBGRxmjKOMuq+HUNUYaJa+kT/DIyMkKX+/btm/D1i0gtneAnItIIasOQmNrgBL8ePXqwYcOGhK9XROpqVljetWsXM2fOZNu2bXTv3p3LLruM9PT0qMuWl5dz+eWXM378eM4999zmbFZEpPU1VFmORpXlriFaz3ILT0oiIq2nWX/Bc+bMYeTIkdx///2MHDmSOXPmxFx29uzZ7LHHHs3ZnIhImwmrLDdyUhJDYblLiNpy0cLTXft8PubMmcMLL7xAaWlpwtcvIrWaFZbnz5/PpEmTAJg0aRLz58+PutyqVasoKSlh7733bs7mRETaTEMn+GlWvy7MmojE4ai93MJtGIWFhUyfPp0rrriCpUuXJnz9IlKrWW0YJSUlZGdnA5CVlUVJSUmdZQKBAM888wwXXXQRixcvrnd9c+fOZe7cuQDMmDGDvLy85uxek7nd7jbbdkek4xUfHa/4tJvj5fWGLrqTkurskyslpc5DkpKTW33f283x6iAScbyc3bqZF5yhdblt75e8Hj3AndhThHw+X+hydnZ2q73men/FT8csPu3xeDX413vrrbdSXFxc5/ZTTz017LrD4Yg6MPr//vc/9tlnH3JzcxvcmYKCAgoKCkLXCwsLG3xMS8jLy2uzbXdEOl7x0fGKT7s5XtXV5JsXfdT9fMqqriY18iGBANtbed/bzfHqIBJxvFLLy8kCcDpD68r2+bC+PhVu357w6rL93+WdO3e22muu91f8dMzi01bHKz8/P+Z9DYblG264IeZ9mZmZ7Nixg+zsbHbs2EE369u1zfLly/npp5/43//+R2VlJT6fD6/XyxlnnNHI3RcRaQea0LOsE/y6hlBvuv31tr9HNM6ySIfWrN+Fxo0bx8cff8yUKVP4+OOPGT9+fJ1lLr744tDljz76iJUrVyooi0jHYw88fn/8j5HOy96zbLHGW7b1MSeSwrJI62nWX9iUKVNYtGgRF198MYsXL2bKlCkArFy5kkceeSQR+yci0u44bP2iIaosd13RRsCINt5yQjepsCzSWppVWc7IyODGG2+sc/uQIUMYMmRIndsPOeQQDjnkkOZsUkSk7UWrLEeb7lphuWuob4rrFgqyLtt7S2FZpGVpBj8RkXg1trKsENM1ROtZjjY5SQJ5vV5mzpyJ3+9n8ODBLbINEQlSWBYRiZMjSmU56sQTqix3CUa0nuVWqCyfcsopLbJuEQmnsoeISLyitWFEm8FPleWuIVobhv0EPxHp0PRJLiISr0b2LKuy3EXUE5ZbqrIcCATo06cPffr0YevWrS2yDREJUlgWEYlTtDYMTXfdhUXpWW7p0TDsk4CVl5e3yDZEJEif5CIi8dLQcWJjRDuZrxXDcrTZc0UkcRSWRUTi1NjKsoaO6yKsE/yiDR2nICvS4Sksi4jEK0plOerJfApKXUN9J/ipFUekw9NfsYhIvHSCn9jVN86ywrJIh6e/YhGRRrKqhA7DqHun2jC6rig9yy19gp+ItB79FYuINJa7nnmcNBpGl2XU17PcCu+BpKSkFt+GSFemGfxERBrJcLmI2YWs0TC6rvrGWW7BvvUNGza02LpFpJbKHiIijaXKskRjfSnSDH4inZI+yUVEGqu+SnG06a5VWe4a2mAGPxFpPforFhFppPqGAYtaQVRQ6hKMKP3JOsFPpPPQX7GISGPV14ahnuWuK9qYyq14gp+ItCz9FYuINFac4VdtGF1DIDMTAMP8P9AqJ/iJSOvQaBgiIo1kxFtZVlDqEvxDh7L98cep2X332hs1g59Ip6GwLCLSWHGe4Kc2jK6j8uijw29Qz7JIp6G/YhGRRqq3sqzprsVGJ/iJdB76KxYRaax6wm+0n9vVs9yF6QQ/kU5Df8UiIo1VX/jV0HFipxP8RDoNfZKLiDRS+dSpAFROnlz3ToVlsdMJfiKdhk7wExFppLJzz6Vm9GiqR46se6ctLBsuFw6/X20YXZl6lkU6DYVlEZHGcrmo3nff6PfZQ5HLBX6/glIXZqgNQ6TT0Ce5iEgiRFSWAY2G0ZXpBD+RTkN/xSIiiRBZWY68TboWVZZFOg19kouIJIBhD0XmeMzqWe7C1LMs0mnor1hEJBHsbRjW5CUKy12WodEwRDoNneAnIpIItrBcMWUKSUuWUDVxYhvukLQp9SyLdBr6KxYRSQRbKKosKKDo5ZcJ5Oe34Q5Jm7LCsnqWRTo8hWURkUSwhyJVE0U9yyKdhv6KRUQSwR6KVE0UhWWRTkN/xSIiCRB2IpcCkugEP5FOQ3/FIiKJpspyl2eosizSaeivWEQkEdSGIXY6wU+k01BYFhFJBPs4ywpIohn8RDoNhWURkURQZVns1IYh0ml0qElJDMOgsrKSQCCAowX/MdqyZQtVVVUttv6WZhgGTqcTr9fbosdJRGw0dJzY6QQ/kU6jQ4XlyspKkpKScLtbdrfdbjeuDj5Nrc/no7KykpSUlLbeFZEuwVBlWWwMzeAn0ml0qL/iQCDQ4kG5s3C73QQCgbbeDZGuQ5VlsfN6ATA8njbeERFprg6VPNVSEB8dL5FWZP97099el1d10EHs+uMfqZgypa13RUSaqUOFZRGRdss+GoYqy12ekZpK6Y03tvVuiEgC6BO9CWbNmsWkSZO48MIL23pXRKS9UEAWEemUVFlugqeffpoXX3yR/Pz8tt4VEWkv1LMsItIpKSzH6aqrrmLt2rWcddZZTJs2jfPOOy/s/rvvvpu1a9eydu1aNmzYwM0338y3337Lhx9+SK9evXjqqadISkpi0aJF3HLLLZSVlZGTk8PMmTPp2bMnzz//PM8//zzV1dUMGjSI+++/n5SUFC699FIyMjL4/vvv2bZtG9dddx3HHXdcGx0FEalDo2GIiHRKHTYs5/fp0yLr3bhhQ73333HHHXz00Ue89NJL5OTkRF1mzZo1vPTSSyxfvpzjjz+exx57jOuvv55zzz2X999/n8mTJ3P99dfz5JNPkpuby+uvv84dd9zBPffcw9FHH80ZZ5wR2ta//vUvzjnnHCA4/vOcOXNYsWIFv/vd7xSWRdoRQ5VlEZFOqcOG5fbs0EMPJSkpiT322INAIMChhx4KwO677866detYuXIly5Yt49RTTwWCQ+L16NEDgGXLlnHnnXdSWlpKWVkZkyZNCq33qKOOwul0Mnz4cLZt29b6T0xEYtNoGCIinVKHDcsNVYDbUnJyMgBOpxO32x0aws3pdOL3+zEMg+HDh/Pmm2/Weexll13GrFmzGDFiBLNnz+bLL78M3eexjddpGEYLPwsRiYvaMEREOiX9VtgGhgwZwvbt21mwYAEANTU1LFu2DIBdu3bRs2dPampqeO2119pyN0UkHvah4xSWRUQ6jWZVlnft2sXMmTPZtm0b3bt357LLLiM9Pb3OcoWFhTzyyCMUFRUBcM0114TaDroij8fDo48+yo033khpaSl+v5/f//737LbbblxxxRUcd9xx5Obmss8++7Br16623l0RaQxVlkVEOiWH0Yzf85977jnS09OZMmUKc+bMYdeuXZx55pl1lrv55ps56aSTGDVqFJWVlTgcjlCrQn02btwYdr28vJzU1NSm7m6jud1ufD5fi2+npbXW8crLy6OwsLDFt9NZ6HjFp6McL++775Jz7rkAbPnsM/yDBrXJfnSU49Ve6HjFR8crfjpm8Wmr41XfcMDNasOYP39+6AS0SZMmMX/+/DrLrF+/Hr/fz6hRowDwer2NCsoiIh2JocqyiEin1Kw2jJKSErKzswHIysqipKSkzjIbN24kLS2Nu+66i61btzJy5EjOOOMMnFGGVpo7dy5z584FYMaMGeTl5YXdv2XLFtzu1jknsaHt/Otf/+Kxxx4Lu23fffdlxowZLblbcUlOTq5zDFuC2+1ule10Fjpe8ekox8vRrVvocnZuLrTRPneU49Ve6HjFR8crfjpm8WmPx6vB5HnrrbdSXFxc53Zr2DOLw+EIjfpgFwgE+Omnn7jzzjvJy8tj5syZfPTRRxx22GF1li0oKKCgoCB0PbIMX1VVhcvlamiXm60xbRhTp05l6tSpdW5vT+0bVVVVrfJThn5iio+OV3w6yvFK3rWLXPPyjuJi/G20zx3leLUXOl7x0fGKn45ZfNpjG0aDYfmGG26IeV9mZiY7duwgOzubHTt20M1WWbHk5OQwcOBAevbsCQSrr8uXL48alkVEOixNSiIi0ik16xN93LhxfPzxxwB8/PHHjB8/vs4yQ4cOpby8nNLSUgB++OEH+vbt25zNioi0P7aArFHQRUQ6j2aF5SlTprBo0SIuvvhiFi9ezJQpUwBYuXIljzzySHADTidnnXUWf/nLX/jzn/+MYRhhrRYiIp2CKssiIp1Ss86Wy8jI4MYbb6xz+5AhQxgyZEjo+qhRo7jrrruasykRkfZNo2GIiHRKKn+IiCRAWOuFKssiIp2GPtFFRBJBlWURkU6pdQYt7mRmzpzJq6++Sm5uLvn5+YwaNYrzzz+/znK//vWvGTFiBF9//TXl5eXcd999PPjgg/z0008cf/zxXHXVVQC88sorPPHEE1RXV7PPPvtw++2343K5uPrqq/n++++prKzk2GOP5f/+7/8A2G+//Zg6dSrvvfcePp+PRx99lKFDh7bqMRCRCPaArLAsItJpdOjKcp8+fWL+99xzz4WWe+655+pdNh4LFy7k7bff5r333uO5557j+++/r3d5j8fDO++8w1lnncU555zDbbfdxgcffMC///1vtm/fzs8//8wbb7zBnDlzeO+993C5XLz66qsAXHXVVbzzzjvMnTuXefPm8eOPP4bWm5OTw3//+1/OOuus0MmUItKG7JVltWGIiHQaqizHaf78+Rx55JF4vV4ADj/88HqXP+KIIwDYfffdGT58eGi86QEDBrBx40bmz5/P4sWLOeaYYwCorKwMzVzz5ptv8vzzz+P3+9myZQs///wze+65JwBHH300EDx58p133kn8ExWR+GjoOBGRTqlDh+UNGzY0arkzzzyTM888s4X3JjqPxwMEh9CzLlvX/X4/hmEwdepUrrnmmrDHrV27lkcffZT//Oc/ZGVlcemll1JZWRm6Pzk5GQCXy4Xf72+FZyIi9dLQcSIinZI+0eM0fvx43nvvPSorKykrK2Pu3LnNWt+BBx7IW2+9FZracceOHaxfv56dO3eSkpJCt27d2LZtGx9++GEidl9EWoihnmURkU6pQ1eW28Lo0aM54ogjKCgooHv37uyxxx5kZGQ0eX3Dhw/nyiuv5LTTTsMwDNxuN7fddhtjx45lr7324uCDDyY/Pz/q7Igi0o6osiwi0ik5DMNot+11GzduDLteXl5Oampqi2/X7Xbj8/li3l9WVkZaWhoVFRWcdNJJ3HnnnYwcObLF9yterXW88vLyQpVxaZiOV3w6yvFK+vZbuv/qVwBsWrYMIz29Tfajoxyv9kLHKz46XvHTMYtPWx2v/Pz8mPepstwEV155JcuXL6eqqoqpU6e2y6AsIq1MlWURkU5JYbkJHnroobDr1157LfPnzw+77fe//z3Tpk1rzd0SkbakSUlERDolheUE+Nvf/tbWuyAibc0WkA2FZRGRTkO/FYqIJIChyrKISKeksCwikmjqWRYR6TT0iS4ikgiqLIuIdEoKyyIiiaDRMEREOiV9ojfBrFmzmDRpEhdeeGFb74qItBeqLIuIdEoaDaMJnn76aV588cV6B7AWkS5G012LiHRKHTYs9+nTMkF1w4aN9d5/1VVXsXbtWs466yymTZvGeeedF3Z/WVkZ119/PYsWLcLhcHDZZZdx7LHHMmfOHB544AEMw2Dy5Mlcd911PPPMM6xZs4YbbrgBgNmzZ7No0SJuu+22FnluItKCzMqyho0TEelcOmxYbit33HEHH330ES+99BI5OTl17r/33nvJyMjg/fffB6C4uJjNmzdz22238e6775KZmclpp53Gu+++y7HHHsvxxx8fCstvvvkmF198cas+HxFJjFBIVlgWEelUOmxYbqgC3FY+/fRTHn744dD1rKws/vvf/7L//vuTm5sLwEknncS8efM46qij6N+/P9988w2DBg1ixYoVjB8/vq12XUSawwrJOrlPRKRT6bBhubM44YQTePPNNxk6dChHHXUUDlWlRDomKyTrb1hEpFNRCSTBDj74YJ566qnQ9eLiYkaPHs28efPYvn07fr+fOXPmsP/++wNw1FFH8b///Y85c+ZwwgkntNFei0izqbIsItIp6VM9wS655BJKSko47LDDKCgo4IsvvqBnz55ce+21TJ06lcMPP5xRo0Zx5JFHAsE2jaFDh7Jhwwb22WefNt57EWkyVZZFRDoltWE0wVdffRXzvrS0NO677746t0+ZMoUpU6ZEfcwzzzyTqF0TkbZihmSNhiEi0rmosiwikgAaDUNEpHNSZbmJZs+ezeOPPx522/jx4/nb3/7WRnskIm1KPcsiIp2SwnITTZs2jWnTprX1bohIe6GeZRGRTkklEBGRRFBlWUSkU9KnuohIIqiyLCLSKSksi4gkgkKyiEinpJ5lEZEECGRnUzNiBL5Bg9p6V0REJIEUlkVEEsHlYtt//6sKs4hIJ6M2DBGRRFFQFhHpdDp0ZbnPY31i3nfHgXdw5h5nAvDcT89x1WdXxVx2wx82xLXdmTNn8uqrr5Kbm0t+fj6jRo3i/PPPr7Pc6tWrufrqqykqKsLlcvHoo48yYMAA/vrXv/Lhhx/icDi4+OKLOeGEE/jTn/7EySefTEFBAQCXXnopBQUFHHfccXHtm4iIiIgkTocOy21h4cKFvP3227z33nv4fD6OPPJIRo0aFXXZiy66iOnTp3P00UdTWVmJYRi8/fbbLFmyhPfee4/t27dzzDHHMGHCBI4//njefPNNCgoKqK6u5rPPPuP2229v5WcnIiIiInYdOiw3tiJ85h5nhqrMzTV//nyOPPJIvF4vAIcffnjU5Xbt2sWmTZs4+uijAULLf/3110yZMgWXy0X37t2ZMGEC33//PYceeig33ngjVVVVfPTRR0yYMIGUlJSE7LOIiIiINI16ltsJr9fL/vvvz8cff8wbb7zB8ccf39a7JCIiItLlKSzHafz48bz33ntUVlZSVlbG3Llzoy6Xnp5O7969effddwGoqqqioqKC/fbbjzfeeAO/309RURFfffUVo0ePBuD4449n9uzZfPXVVxxyyCGt9IxEREREJJYO3YbRFkaPHs0RRxxBQUEB3bt3Z4899iAjIyPqsvfffz9XXXUVd911F263m0cffZSjjz6ab775hsMPPxyHw8F1111Hjx49AJg0aRKXXHIJRxxxBB6PpzWfloiIiIhE4TAMw2jrnYhl48aNYdfLy8tJTU1t8e263W58Pl/M+8vKykhLS6OiooKTTjqJO++8k5EjR7b4fsWrtY5XXl4ehYWFLb6dzkLHKz46XvHR8YqPjld8dLzip2MWn7Y6Xvn5+THvU2W5Ca688kqWL19OVVUVU6dObZdBWURERESaT2G5CR566KGw69deey3z588Pu+33v/8906ZNa83dEhEREZEEU1hOgL/97W9tvQsiIiIi0gI61GgY7bi9ul3S8RIRERFpng4Vlp1OZ70n3kktn8+H09mhXl4RERGRdqdDtWF4vV4qKyupqqrC4XC02HaSk5OpqqpqsfW3NMMwcDqdoVkDRURERKRpOlRYdjgcrTIFtIZ5ERERERHoYG0YIiIiIiKtSWFZRERERCQGhWURERERkRja9XTXIiIiIiJtSZXlKK6++uq23oUORccrPjpe8dHxio+OV3x0vOKj4xU/HbP4tMfjpbAsIiIiIhKDwrKIiIiISAwKy1EUFBS09S50KDpe8dHxio+OV3x0vOKj4xUfHa/46ZjFpz0eL53gJyIiIiISgyrLIiIiIiIxdKjprtvCm2++ybPPPsvjjz9Ot27d2np32q0XX3yRBQsW4HA4yMzM5IILLiAnJ6etd6vdevbZZ/nmm29wu9307NmTCy64gLS0tLberXbryy+/5KWXXmLDhg387W9/Y8iQIW29S+3SwoULefLJJwkEAkyePJkpU6a09S61Ww8//DDffvstmZmZ3H333W29O+1eYWEhDz30EMXFxTgcDgoKCjjmmGPaerfarerqam666SZ8Ph9+v58JEyZwyimntPVutXuBQICrr76anJycdjUqhsJyPQoLC1m0aBF5eXltvSvt3vHHH8+pp54KwNtvv83LL7/Meeed18Z71X6NGjWK008/HZfLxXPPPcdrr73GmWee2da71W7169eP//u//+Of//xnW+9KuxUIBJg1axbXX389ubm5XHPNNYwbN46+ffu29a61S4cccghHHXUUDz30UFvvSofgcrk466yzGDx4MBUVFVx99dWMGjVK768YkpKSuOmmm/B6vfh8Pm688UZGjx7N8OHD23rX2rW3336bPn36UFFR0da7EkZtGPV4+umnOeOMM3A4HG29K+1eampq6HJVVZWOWQP23ntvXC4XAMOHD2f79u1tvEftW9++fcnPz2/r3WjXVqxYQa9evejZsydut5uJEycyf/78tt6tdmvPPfckPT29rXejw8jOzmbw4MEApKSk0KdPH31u1cPhcOD1egHw+/34/X79u9iAoqIivv32WyZPntzWu1KHKssxzJ8/n5ycHAYOHNjWu9Jh/Otf/+KTTz4hNTWVm266qa13p8P44IMPmDhxYlvvhnRw27dvJzc3N3Q9NzeXn3/+uQ33SDqrrVu3snr1aoYOHdrWu9KuBQIBrrrqKjZv3syRRx7JsGHD2nqX2rWnnnqKM888s91VlaGLh+Vbb72V4uLiOrefeuqpvPbaa1x//fWtv1PtWH3Ha/z48Zx22mmcdtppvPbaa7z77rtdvj+roeMF8Oqrr+JyuTjooINaee/an8YcLxFpW5WVldx999389re/DftFUepyOp38/e9/p6ysjLvuuou1a9fSv3//tt6tdumbb74hMzOTwYMHs2TJkrbenTq6dFi+4YYbot6+du1atm7dyhVXXAEEfxq46qqruP3228nKymrFPWxfYh2vSAcddBC33357lw/LDR2vjz76iG+++YYbb7xRP8/R+PeXRJeTk0NRUVHoelFRkU6ylYTy+XzcfffdHHTQQey3335tvTsdRlpaGiNGjGDhwoUKyzEsW7aMBQsW8N1331FdXU1FRQX3338/F198cVvvGtDFw3Is/fv35/HHHw9dnz59OrfffrtGw6jHpk2b6N27NxBsYVF/af0WLlzI66+/zi233EJycnJb7450AkOGDGHTpk1s3bqVnJwcvvjii3bzD410fIZh8Mgjj9CnTx+OO+64tt6ddq+0tBSXy0VaWhrV1dUsWrSIE044oa13q906/fTTOf300wFYsmQJb775Zrv6/FJYloR4/vnn2bRpEw6Hg7y8PI2E0YBZs2bh8/m49dZbARg2bJiOWT2+/vprnnjiCUpLS5kxYwYDBw7kuuuua+vdaldcLhfnnHMOt912G4FAgEMPPZR+/fq19W61W/feey8//vgjO3fu5Pzzz+eUU07hsMMOa+vdareWLVvGJ598Qv/+/UO/up522mmMGTOmjfesfdqxYwcPPfQQgUAAwzDYf//9GTt2bFvvljSRZvATEREREYlBQ8eJiIiIiMSgsCwiIiIiEoPCsoiIiIhIDArLIiIiIiIxKCyLiIiIiMSgsCwiIiIiEoPCsoiIiIhIDArLIiIiIiIx/D89uUnQhmfc3QAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(Xtest.numpy(), mean.numpy(), 'r', lw=2, label='f_mean') \n",
    "plt.plot(Xtest.numpy(), mean_g.numpy(), 'k--', lw=2, label='g_mean') \n",
    "plt.plot(Xtest.numpy(), cov.diag().sqrt().numpy(), 'b', lw=2, label='f_cov') \n",
    "plt.plot(Xtest.numpy(), cov_g.diag().sqrt().numpy(), 'g--', lw=2, label='g_cov')\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "colab": {
   "collapsed_sections": [
    "8bnJcoggg-fi"
   ],
   "name": "12 - Gaussian processes - Pyro.ipynb",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python NOSTROMO",
   "language": "python",
   "name": "nostromo"
  },
  "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.9.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
