{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "CrSZiwbewKr_"
   },
   "source": [
    "# Active Learning with Fully Bayesian Gaussian processes\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import math\n",
    "import torch\n",
    "import gpytorch\n",
    "import pyro\n",
    "from pyro.infer.mcmc import NUTS, MCMC\n",
    "from matplotlib import pyplot as plt\n",
    "import seaborn as sns\n",
    "import scipy\n",
    "from scipy import stats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "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",
    "\n",
    "# matplotlib options\n",
    "%matplotlib inline\n",
    "plt.style.use('ggplot')\n",
    "plt.rcParams['figure.figsize'] = (12, 8)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "hly4mrkewKth"
   },
   "source": [
    "## Generate data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "id": "ZHt9E6JDwKth"
   },
   "outputs": [],
   "source": [
    "# generate some training data\n",
    "X_train = np.linspace(-0.5, 1.5, 2) #np.hstack([-0.75 + np.random.rand(1,2), 0.75 + np.random.rand(1,2)]).T\n",
    "y_train = np.sin(4.0*X_train) + 0.1 * np.random.randn(len(X_train)) #*X_train**3\n",
    "X_test = np.linspace(-0.5,1.5,101) \n",
    "y_test = np.sin(4.0*X_test) + 0.1 * np.random.randn(len(X_test)) # *X_test**3\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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\n",
      "text/plain": [
       "<Figure size 864x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(X_test, y_test, \"ro\")\n",
    "plt.plot(X_train, y_train, \"bo\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "id": "MJjSv8GWgHmX"
   },
   "outputs": [],
   "source": [
    "# Build torch.tensors\n",
    "train_x = torch.from_numpy(X_train).view(-1,)\n",
    "train_y = torch.from_numpy(y_train).view(-1,)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Make GP model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "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.mean_module = gpytorch.means.ZeroMean()\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)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "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"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Functions for estimating new priors"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def fit_gamma(tmp_data):\n",
    "    fit_alpha, fit_loc, fit_beta = stats.gamma.fit(tmp_data, floc=0)\n",
    "    #print(\"\\nGamma\")\n",
    "    #print(\"Parameters\", fit_alpha, fit_loc, fit_beta) #shape, location, scale\n",
    "\n",
    "\n",
    "    # calc the log likelihood \n",
    "    logLik = -np.sum( stats.gamma.logpdf(tmp_data, fit_alpha, loc=fit_loc, scale=fit_beta) )\n",
    "\n",
    "    # calc AIC\n",
    "    aic = 2 * 3 - 2 * logLik\n",
    "    #print(\"AIC:\", aic)\n",
    "    \n",
    "    return aic, fit_alpha, fit_loc, fit_beta\n",
    "\n",
    "def fit_lognorm(tmp_data):\n",
    "    fit_shape, fit_loc, fit_scale = stats.lognorm.fit(tmp_data, floc=0)\n",
    "    #print(\"\\nLogNormal\")\n",
    "    #print(\"Parameters\", fit_shape, fit_loc, fit_scale) \n",
    "\n",
    "    # calc the log likelihood \n",
    "    logLik = -np.sum( stats.lognorm.logpdf(tmp_data, fit_shape, loc=fit_loc, scale=fit_scale) )\n",
    "\n",
    "    # calc AIC\n",
    "    aic = 2 * 2 - 2 * logLik\n",
    "    #print(\"AIC:\", aic)\n",
    "    \n",
    "    return aic, fit_shape, fit_loc, fit_scale\n",
    "\n",
    "def find_my_prior(tmp_data):\n",
    "    aic_g, fit_g_alpha, fit_g_loc, fit_g_beta = fit_gamma(tmp_data)\n",
    "    aic_l, fit_l_shape, fit_l_loc, fit_l_scale = fit_lognorm(tmp_data)\n",
    "    \n",
    "    l_loc = np.log(fit_l_scale)\n",
    "    l_scale = fit_l_shape\n",
    "    concentration = fit_g_alpha\n",
    "    rate = 1/fit_g_beta\n",
    "    \n",
    "    if aic_l < aic_g:\n",
    "        print(f\"LogNormal is best: loc = {l_loc}, scale = {l_scale}\")\n",
    "        fun = LogNormalPrior(loc=l_loc, scale=l_scale)\n",
    "    else:\n",
    "        print(f\"Gamma is best: alpha = {concentration}, beta = {rate}\")\n",
    "        fun = GammaPrior(concentration, rate)\n",
    "    \n",
    "    stats = {\"logN_loc\": l_loc,\n",
    "             \"logN_scale\": l_scale,\n",
    "             \"Gamma_alpha\": concentration,\n",
    "             \"Gamma_beta\": rate\n",
    "            }\n",
    "    return fun, stats"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Plotting functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Plot posteriors --> new priors\n",
    "def plot_posterior(ax, post_samples, stats, title=\"Something?\"):\n",
    "    tmp_data = post_samples\n",
    "    \n",
    "    quan_l = torch.quantile(post_samples, q=0).numpy()\n",
    "    quan_h = torch.quantile(post_samples, q=0.97).numpy()\n",
    "    ax.hist(x=tmp_data.squeeze(-1).squeeze(-1).numpy(), bins=20, density=True, range=(quan_l,quan_h),\n",
    "            color=\"lightblue\", edgecolor=\"b\")\n",
    "    ylim_l, ylim_h = ax.get_ylim()\n",
    "    \n",
    "    x_range_l = np.max([0.0001, quan_l-0.05])\n",
    "    x_range_h = quan_h + 0.05\n",
    "    tmp_x = np.linspace(x_range_l, x_range_h, 1000)\n",
    "    \n",
    "    beta, alpha = stats['Gamma_beta'], stats['Gamma_alpha']\n",
    "    tmp_pdf_g = np.power(beta, alpha) * np.power(tmp_x, alpha-1) * np.exp(-beta * tmp_x) / scipy.special.gamma(alpha)\n",
    "    mu, sigma = stats['logN_loc'], stats['logN_scale']\n",
    "    tmp_pdf_l = np.exp(- np.power(np.log(tmp_x) - mu, 2) / (2*np.power(sigma, 2))) / (tmp_x * sigma * np.sqrt(2*np.pi))\n",
    "    \n",
    "    ax.plot(tmp_x, tmp_pdf_g, label=\"Gamma distribution\", lw=3)\n",
    "    ax.plot(tmp_x, tmp_pdf_l, label=\"LogNormal distribution\", lw=3)\n",
    "    ylim_h = ylim_h + 0.1\n",
    "    ax.set_ylim(ylim_l, ylim_h)\n",
    "    ax.set_title(title)\n",
    "    ax.legend()\n",
    "    \n",
    "    \n",
    "    \n",
    "# Plot mean functions drawn from batch model\n",
    "def plot_mean_functions(ax, train_x, train_y, test_x, output):\n",
    "    \n",
    "    # Plot training data as black stars\n",
    "    ax.plot(train_x.numpy(), train_y.numpy(), 'k*', zorder=10, label='Observed Data')\n",
    "    \n",
    "    mean_all = torch.mean(output.mean, axis=0) * sigma_y + mu_y\n",
    "    stddev_all = torch.std(output.mean, axis=0) * sigma_y\n",
    "    mean_all, stddev_all = mean_all.detach().numpy(), stddev_all.detach().numpy()\n",
    "    ax.plot(test_x.numpy(), mean_all, c='r', label=\"Mean of sampled means\")\n",
    "    ax.fill_between(test_x.squeeze(-1).numpy(), mean_all - 2*stddev_all, mean_all + 2*stddev_all,\n",
    "                    alpha=0.2, label='Std. of samples means')\n",
    "\n",
    "    for i in range(min(num_samples, 50)):\n",
    "        # Plot predictive means as blue line\n",
    "        y_pred = output.mean[i].detach()\n",
    "        y_pred = y_pred * sigma_y + mu_y\n",
    "        if i == 0:\n",
    "            ax.plot(test_x.numpy(), y_pred.numpy(), 'b', linewidth=0.3, label='Sampled Means')\n",
    "        else:\n",
    "            ax.plot(test_x.numpy(), y_pred.numpy(), 'b', linewidth=0.3)\n",
    "    \n",
    "    ax.set_title(\"Samples of GP mean functions\")\n",
    "    ax.legend()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Test 1 active learning step with update of posteriors "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Run MCMC to estimate posteriors of the hyperparameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Build torch.tensors\n",
    "train_x = torch.from_numpy(X_train).view(-1,)\n",
    "train_y = torch.from_numpy(y_train).view(-1,)\n",
    "\n",
    "test_x = torch.from_numpy(X_test).view(-1,).unsqueeze(-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Sample: 100%|██████████| 150/150 [00:11, 12.88it/s, step size=2.00e-01, acc. prob=0.571]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                     mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "                      likelihood.noise_prior[0]      0.21      0.41      0.09      0.00      0.39     27.22      1.07\n",
      "covar_module.base_kernel.lengthscale_prior[0,0]      0.37      0.16      0.34      0.12      0.63     18.19      1.13\n",
      "\n",
      "Number of divergences: 0\n",
      "LogNormal is best: loc = -1.0789251582127437, scale = 0.4436445707395555\n",
      "Gamma is best: alpha = 0.7076319379126161, beta = 3.410070515121735\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Sample: 100%|██████████| 150/150 [00:08, 16.89it/s, step size=2.00e-01, acc. prob=0.626]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "                                                     mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "                      likelihood.noise_prior[0]      0.13      0.12      0.09      0.00      0.33     38.73      1.00\n",
      "covar_module.base_kernel.lengthscale_prior[0,0]      0.28      0.09      0.27      0.15      0.39     29.46      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Gamma is best: alpha = 12.00541259438353, beta = 43.57366978808693\n",
      "LogNormal is best: loc = -2.773126899846757, scale = 1.4996988233567419\n"
     ]
    }
   ],
   "source": [
    "# MCMC settings\n",
    "num_samples = 100\n",
    "warmup_steps = 50\n",
    "\n",
    "\n",
    "active_learning_steps = 2\n",
    "\n",
    "# Initial priors\n",
    "length_scale_prior = GammaPrior(3, 6)\n",
    "noise_prior = LogNormalPrior(loc=0, scale=2)\n",
    "\n",
    "\n",
    "\n",
    "for i in range(active_learning_steps):\n",
    "    \n",
    "    # Convert data to torch\n",
    "    if i > 0:\n",
    "        train_x = torch.tensor(train_x)\n",
    "        train_y = torch.tensor(train_y)\n",
    "    \n",
    "    # Standardize the data s.t. input is on unit cube and output has zero mean and std=1.\n",
    "    min_x = torch.min(train_x)\n",
    "    max_x = torch.max(train_x - min_x)\n",
    "    train_x_trans = (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 - mu_y) / sigma_y\n",
    "    \n",
    "    # Define likelihood, model and set priors\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",
    "    model.covar_module.outputscale = torch.tensor(1.)\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",
    "    mcmc_run = MCMC(nuts_kernel, num_samples=num_samples, warmup_steps=warmup_steps, num_chains=1)\n",
    "    mcmc_run.run(train_x_trans, train_y_trans)\n",
    "    \n",
    "    # Look at summary\n",
    "    mcmc_run.summary()\n",
    "    \n",
    "    # Extract samples from posterior\n",
    "    posterior_samples = mcmc_run.get_samples()\n",
    "    \n",
    "    # Get new priors\n",
    "    length_scale_prior, l_stats = find_my_prior(posterior_samples[\"covar_module.base_kernel.lengthscale_prior\"])\n",
    "    noise_prior, n_stats = find_my_prior(posterior_samples[\"likelihood.noise_prior\"])\n",
    "    \n",
    "    # Turn model into batch model in order to draw mean functions\n",
    "    model.pyro_load_from_samples(posterior_samples)\n",
    "    \n",
    "    # Propogate search space through model\n",
    "    model.eval()\n",
    "    test_x_trans = (test_x - min_x) / max_x\n",
    "    test_y = torch.from_numpy(y_test).view(-1,)\n",
    "    expanded_test_x = test_x_trans.unsqueeze(0).repeat(num_samples, 1, 1)\n",
    "    output = model(expanded_test_x)\n",
    "    \n",
    "    # Get mean(mean) and std(mean)\n",
    "    with torch.no_grad():\n",
    "        mean_all = torch.mean(output.mean, axis=0) * sigma_y + mu_y\n",
    "        stddev_all = torch.std(output.mean, axis=0) * sigma_y\n",
    "        mean_all, stddev_all = mean_all.numpy(), stddev_all.numpy()\n",
    "    \n",
    "    # AL, where is stddev highest\n",
    "    idx = np.argmax(stddev_all)\n",
    "     \n",
    "    # Plot\n",
    "    f, ax = plt.subplots(1, 3, figsize=(20, 6))\n",
    "    plot_mean_functions(ax[0], train_x, train_y, test_x, output)\n",
    "    plot_posterior(ax[1], posterior_samples[\"covar_module.base_kernel.lengthscale_prior\"], l_stats,\n",
    "               title=\"Posterior sample of the length scale\")\n",
    "    plot_posterior(ax[2], posterior_samples[\"likelihood.noise_prior\"], n_stats,\n",
    "               title=\"Posterior sample of the noise\")\n",
    "    plt.savefig(f'mbml/initial_experiment_{i}_MCMC1.pdf',\n",
    "                                bbox_inches=\"tight\")\n",
    "    f.clf()\n",
    "    plt.close()\n",
    "    \n",
    "    # Get new point\n",
    "    new_x = test_x[idx]\n",
    "    new_y = np.sin(4.0*new_x) + 0.1* np.random.randn(len(new_x), 1)[0] # *new_x**3 \n",
    "    \n",
    "    # Add to data set\n",
    "    train_x = np.concatenate([train_x, new_x])\n",
    "    train_y = np.concatenate([train_y, new_y])\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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amoIhUJs2LCBpUuX9rrNMcccw/r16wHT3W3evHmj/upFIs97rErkue/cuZOHHnqIK6+8ctTMR0lEIs+954np66+/zoQJE4Z7mGkR77l7vV7Wrl3L/fffz/3338+sWbO48sorx0QXx0Re966DP5h5t2Olc2ciz33ZsmW8/fbbALS0tFBdXU1FRUUmhjso4/lzPBW01jzwwANMmjSJj33sY90/X7p0KS+//DIAL7/8Mscee2ymhjgqfPazn+WBBx7g/vvv5/LLL2f+/PlceumlzJs3j1deeQUwXWJl34yvsLCQkpKS7rLrzZs3M3nyZNknB6m0tJStW7fi9/vRWndvR9knU0/pNHbleP311/nFL36BbduceOKJnHnmmTz55JNUVVWxdOlSAoEA9913Hzt37iQ3N5fLL798VBy844n3vLdt28btt99Oe3s7LpeLwsJC7rzzzkwPOyXiPfebb76ZPXv2UFhYCJg3+3e+853MDjpF4j33Rx55hM2bN+NwOMjNzeWCCy5gypQpmR52SsR77j2tWbOGL3zhC2MiQIP4z/1Xv/oVr776avfrfuGFFzJp0qRMDzsl4j13rTW//OUv2bRpE5ZlceaZZ/KBD3wg08NOSLTnJhLz7rvvcv311zN16tTui67nnnsus2bN4q677qKurk5amg/S22+/zR/+8AeuuuoqDh06xN13301bWxtHHHEEl1xyyZipRkmnXbt28cADDxAKhSgvL+fiiy9Gay375CD913/9Fxs2bMDhcDB9+nS+/vWv09DQIPtkiqU1QBNCCCGEEEIIkThpEiKEEEIIIYQQI4QEaEIIIYQQQggxQkiAJoQQQgghhBAjhARoQgghhBBCCDFCSIAmhBBCCCGEECOEBGhCCCGEEEIIMUJIgCaEEEIIIYQQI4QEaEIIIYQQQggxQkiAJoQQQgghhBAjhARoQgghhBBCCDFCSIAmhBBCCCGEECOEBGgipdasWcM3v/nNhG6rlKKurm5Q979+/Xrmz5+fzNBSZjDPMR0effRRPvaxj0X93XCM7e677+bAgQMJjSfVktlnhmLx4sU0NTUN2+MJIUYfOe6lnxz35Lg33kiANoaFQqFMD0HEMJpfm74HqrGo6/XZtGkThYWFSf2tEGL4yftv5BrNr40c9xL7W5E6EqANk3/961+sXLmShQsXsnDhQh566CF27NjBKaecwsKFC1mwYAEPPfRQ921nzZrV6++/+MUvcueddwJw3nnnceyxx7Jw4UJOPvlk9uzZA8CuXbvIzc3luuuuY+nSpdx8880xx3P++efzla98hZNPPpmqqirOPvtsNm/ezEknncSsWbM499xzsW0bgNraWs4++2wWLFjA/Pnzuemmm7rv59ChQ5x22mnMnTuXE044ge3bt3f/ru8VpldffZXp06dHHc/27dv5+Mc/zrJly1i4cCHXXXddzLGHw2G++tWvdo/nhRde6P5drG1TW1vLKaecwvz581m4cCGf+tSnuv/mN7/5DcuXL+eYY47huOOO46WXXor52H3t2rWLo48+mkcffXTA+1q/fj1z5szh61//OkcffTQ///nPOeGEE/j2t7/NypUrmTVrFmeffTbBYBAwH3bXXXcdy5Yt4+ijj+a0005j9+7dCY+ryz333MOyZcs45phjWLlyJW+++SZgXpuPfOQjnHfeed373+uvv979dz/72c848sgjWbJkCT/4wQ+6r+Bdf/31HDhwgM997nMsXry4+/l1dHREva+Btvtjjz3G0UcfzaJFizj66KN59dVXgdivYV+D2Wfg8Pvj2muvZdGiRcyePZtf/epX3b+fPn06V199Nccddxyf+MQngN5XLl9//XU++MEPsnDhQhYvXszvfve7Af9WiPFOjnty3JPjnhz3RJK0SLuGhgZdXl6u//znP3f/rLa2Vi9fvlzffffdWmutq6ur9cSJE/Xf//53rbXW8+fP1+vXr9daa93U1KQLCgp0bW2t1lrrmpqa7vu599579Wc+8xmttdY7d+7UgF67dm3cMZ133nn6mGOO0e3t7ToYDOoFCxbolStX6ra2Nh0IBPS8efP0M888o7XW+jOf+Yy+/PLLtdZat7S06IULF+pf/epXWmutzz77bP3tb39ba631oUOH9KRJk/Q3vvENrbXWjzzyiP6P//iP7sfcuHGjnjZtWvf3gK6trdWhUEgvWbJEv/HGG1prrQOBgD7ppJP0r3/9637jfumllzTQPbYNGzbo0tJS3dzcPOC2ufPOO/VXvvKV7t/V19drrbX++9//rletWqU7Ojq01lq///77uqKiovv7aG644Qb9jW98Q2/YsEHPmTOn+3Ua6L66xr1u3bru+1m5cqX+6Ec/qgOBgA4EAnrJkiX6N7/5jdZa6x/84Af66quv1rZt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\n",
      "text/plain": [
       "<Figure size 864x288 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import arviz as az\n",
    "\n",
    "data = az.from_pyro(mcmc_run)\n",
    "az.plot_trace(data, compact=True);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.6931, grad_fn=<SoftplusBackward>)"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.covar_module.outputscale"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "from tqdm import tqdm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "100"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "num_samples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [00:01<00:00, 78.24it/s]\n"
     ]
    }
   ],
   "source": [
    "mlls = 0\n",
    "rmse = 0\n",
    "with torch.no_grad():\n",
    "    for j in tqdm(range(num_samples)):\n",
    "        mlls += torch.mean(-mll(output[j], test_y))\n",
    "        rmse += torch.sqrt(torch.mean(torch.pow(output.mean[j] - test_y, 2)))\n",
    "    mlls = mlls/num_samples\n",
    "    rmse = rmse/num_samples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(-1.4494, dtype=torch.float64)\n",
      "tensor(1.0185, dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "print(mlls)\n",
    "print(rmse)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(1.0158, dtype=torch.float64, grad_fn=<SqrtBackward>)"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.sqrt(torch.mean(torch.pow(output.mean.mean(0) - test_y, 2)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "likelihood.noise_prior:\n",
      "posterior mode=0.79 mean=0.12 std=0.14\n",
      "\n",
      "covar_module.base_kernel.lengthscale_prior:\n",
      "posterior mode=0.18 mean=0.32 std=0.08\n"
     ]
    }
   ],
   "source": [
    "from scipy import stats\n",
    "\n",
    "for k in posterior_samples.keys():\n",
    "    print(\"\\n%s:\" % k)\n",
    "    print(\"posterior mode=%.2f mean=%.2f std=%.2f\" % (stats.mode(posterior_samples[k].numpy())[0][0], \n",
    "                                                      posterior_samples[k].mean(), posterior_samples[k].std()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "# make a GP with these variables\n",
    "likelihood = gpytorch.likelihoods.GaussianLikelihood(noise_constraint=gpytorch.constraints.Positive())\n",
    "model = ExactGPModel(train_x_trans, train_y_trans, likelihood)\n",
    "#likelihood.register_prior(\"noise_prior\", noise_prior, \"noise\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Actual lengthscale: tensor([[0.6931]], grad_fn=<SoftplusBackward>)\n",
      "Actual outputscale: 0.6931471824645996\n",
      "Actual noise: tensor([0.6931], grad_fn=<SoftplusBackward>)\n",
      "\n",
      "Actual lengthscale: tensor([[0.1100]], grad_fn=<SoftplusBackward>)\n",
      "Actual outputscale: 1.0\n",
      "Actual noise: tensor([0.], grad_fn=<SoftplusBackward>)\n"
     ]
    }
   ],
   "source": [
    "# Convenient way of getting true outputscale\n",
    "print(f'Actual lengthscale: {model.covar_module.base_kernel.lengthscale}')\n",
    "#print(f'Actual mean: {model.mean_module.constant}')\n",
    "print(f'Actual outputscale: {model.covar_module.outputscale}')\n",
    "print(f'Actual noise: {likelihood.noise}')\n",
    "\n",
    "# Convenient way of setting true outputscale\n",
    "model.covar_module.outputscale = 1.\n",
    "model.covar_module.base_kernel.lengthscale = 0.11\n",
    "likelihood.noise = 0\n",
    "print(f'\\nActual lengthscale: {model.covar_module.base_kernel.lengthscale}')\n",
    "print(f'Actual outputscale: {model.covar_module.outputscale}')\n",
    "print(f'Actual noise: {likelihood.noise}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/christofferriis/envs/mbml/lib/python3.9/site-packages/gpytorch/utils/cholesky.py:51: NumericalWarning: A not p.d., added jitter of 1.0e-08 to the diagonal\n",
      "  warnings.warn(f\"A not p.d., added jitter of {jitter_new:.1e} to the diagonal\", NumericalWarning)\n"
     ]
    }
   ],
   "source": [
    "model.eval()\n",
    "with torch.no_grad(), gpytorch.settings.fast_pred_var():\n",
    "    predictions = likelihood(model(test_x_trans))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(101,)"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_y.numpy().shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x14183d8e0>]"
      ]
     },
     "execution_count": 25,
     "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(test_x_trans.numpy(), (test_y - mu_y) / sigma_y, 'o')\n",
    "plt.plot(test_x_trans.numpy(), predictions.mean)\n",
    "plt.plot(train_x_trans, train_y_trans, 'bo')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "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": "mbml",
   "language": "python",
   "name": "mbml"
  },
  "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
}
