{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Active Learning with Fully Bayesian GPs"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Setup\n",
    "The initial cells are identical to part 1, so these can be skipped. Therefore, please go to the section **Setup for doing Active Learning**."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import math\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from tqdm import tqdm\n",
    "import warnings\n",
    "import time\n",
    "\n",
    "import scipy\n",
    "from scipy import stats\n",
    "from scipy.stats import norm, multivariate_normal\n",
    "\n",
    "\n",
    "import torch\n",
    "from torch.distributions import constraints\n",
    "from torch.nn import Parameter\n",
    "\n",
    "import pyro \n",
    "from pyro.infer.mcmc import NUTS\n",
    "from pyro.infer.mcmc.api import MCMC\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 gpytorch\n",
    "from gpytorch.priors import LogNormalPrior, NormalPrior, UniformPrior, GammaPrior\n",
    "\n",
    "import arviz as az  # for trace plots\n",
    "\n",
    "from matplotlib import pyplot as plt\n",
    "from matplotlib import gridspec\n",
    "import seaborn as sns\n",
    "from seaborn import kdeplot\n",
    "\n",
    "from importlib import reload\n",
    "import mbml_utility_functions\n",
    "reload(mbml_utility_functions)\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": {},
   "outputs": [],
   "source": [
    "class argument_handler:\n",
    "    def __init__(self):\n",
    "        # default configurations\n",
    "        self.seed = 1\n",
    "        self.simulator = None\n",
    "\n",
    "        # Initial data set\n",
    "        self.space_filling_design = \"uniform\" #\"random\"\n",
    "        self.initial_samples = 10\n",
    "        self.test_samples = 1020\n",
    "\n",
    "        # Parameters for the active learning scheme\n",
    "        self.plot = False\n",
    "        self.active_learning_steps = 3\n",
    "        self.k_samples = 1        # Size of the batch of new points to query\n",
    "        self.beta_sampling = -1 # Distance between the points in the batch given by percentage of range\n",
    "        self.repeat_sampling = 1  # Number of times to sample for each input,\n",
    "                            # i.e. equal 4 will give for simulations for each data point\n",
    "\n",
    "        # Hyperparameters for optimizing hyperparameters of GP\n",
    "        self.n_runs = 1\n",
    "        self.milestones = [300, 600]  # Epochs at which we will lower the learning rate by a factor\n",
    "        self.initial_lr = .1                  # Initial learning rate\n",
    "        self.n_epochs = 1000                  # Number of epochs in optimizing the hyperparameters\n",
    "\n",
    "        \n",
    "args = argument_handler()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# note that this helper function does three different things:\n",
    "# (i) plots the observed data;\n",
    "# (ii) plots the predictions from the learned GP after conditioning on data;\n",
    "# (iii) plots samples from the GP prior (with no conditioning on observed data)\n",
    "\n",
    "def plot(X, y, 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.numpy(), y.numpy(), 'kx')\n",
    "    if plot_predictions:\n",
    "        Xtest = torch.linspace(-0.5, 5.5, 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, full_cov=True, noiseless=False)\n",
    "        sd = cov.diag().sqrt()  # standard deviation at each input point x\n",
    "        plt.plot(Xtest.numpy(), mean.numpy(), 'r', lw=2)  # plot the mean\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)\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(-0.5, 1.5)\n",
    "    plt.ylim(-2.2, 2.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import functions for handling the data\n",
    "from mbml_utility_functions import oracle_simulator, get_search_space, sample_dataset_from_simulator, \\\n",
    "sample_initial_inputs\n",
    "\n",
    "# import simulators\n",
    "from mbml_utility_functions import mbml_fun_homo, mbml_fun_hetero, gramacy_and_lee_1d, higdon1d"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAlsAAANfCAYAAADuIxjTAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAEAAElEQVR4nOzdd3jUVdbA8e/NJJn03iAFSCgCiijYEAUpAjZAXSyAZXXVFdsWXfu6FsTXAq5dUVTAXXXXvhRBxQJIEREpQiB00ntIMklm7vvHjwyETJKZZCaZZM7neXggM79yb4Zkztx77rlKa60RQgghhBAe4dfRDRBCCCGE6Mok2BJCCCGE8CAJtoQQQgghPEiCLSGEEEIID5JgSwghhBDCgyTYEkIIIYTwIAm2hBBdklKKBQsWdJn7uMt1113HmDFjXDpn5MiR3HjjjR5qkRBdnwRbQnRSzb1pdrYAoDMYM2YM1113XaPHs7Ozufzyy9u/QUKITsO/oxsghBCdWVJSUkc3QQjh5WRkSwgfkJ2dzZVXXklUVBTBwcGMHDmS9evX259fsWIFSikWLVrEWWedRXBwMEOGDGHLli1s2bKF4cOHExISwumnn87WrVsbXHvRokUMGTIEs9lMQkICt956K4cPH7Y/v2XLFsaNG0dUVBShoaH079+f+fPn25+vqKjgrrvuIjU1FbPZTM+ePZk5c6b9+dzcXK677jri4+MJDw/n7LPP5rvvvmvQhm+++YZBgwYRFBTEoEGD+Oabbxp9Dx544AH69+9PSEgIqamp3HLLLZSWltqfLysr4/rrrycpKQmz2Uxqaip//vOfAWMU8auvvuKdd95BKYVSihUrVgCNRxFb6s/xHnnkEXr37s0HH3xAnz59CAkJYdKkSZSVlfHRRx/Rr18/wsPDufzyyxu0V2vNM888Q3p6OoGBgWRkZDBnzpwG1y4qKuKKK64gNDSUxMREHnzwQRxtGvLCCy9wwgknEBQURJ8+fXjiiSeoq6trss1CCNfIyJYQXZzWmkmTJmGxWPjiiy+IjIzk8ccfZ+zYsWRmZhIXF2c/9oEHHuDZZ58lKSmJG264gauuuoqoqCj+8Y9/0L17d/7whz9w/fXXs2bNGgA2bdrEJZdcwu23387ChQvZvXs3N998M+Xl5faA6qqrruLEE09k1apVBAUFsX37dqxWq71tF110Efv27eOFF15g0KBBHDhwgO3btwNQVVXFeeedR//+/Vm8eDFRUVG8//77jB07lo0bN9K/f38OHTrERRddxJQpU/j3v//NwYMHufPOOxt9H4KDg3n99ddJTU1l165dzJgxgzvuuIN33nkHgAcffJANGzbw6aef0q1bNw4cOMCWLVsAeP7558nKyqJbt248//zzAMTExDj8XjfXn6ZkZ2fzzjvv8N///pfi4mIuv/xyLr/8cvz9/fnggw8oLy/nsssuY+bMmTz11FMAvPzyyzz00EM8//zznHfeeXz11VfcddddhIeHc8MNNwBwww038Ouvv/L555+TmJjIk08+yWeffcbpp59uv/cjjzzCvHnzmDNnDoMHD2bbtm3ccsstVFdX89hjj7X030sI4QwthOiUrr32Wm0ymXRoaGijP4CeP3++1lrr5cuXa0Bv2bLFfm51dbVOSkrS//jHP7TWWn/zzTca0B9//LH9mA8++EAD+j//+Y/9sY8++kgDury8XGut9bRp0/Rpp53WoF2ffPKJVkrpPXv2aK21joiI0PPmzXPYh/q2rVu3zuHz8+bN08nJybq2trbB4+edd56+8847tdZaP/DAAzotLa3BMZ9//nmD74EjH330kQ4MDNRWq1VrrfUll1yir7322iaPHz16tMPnHX2vm+qPI3//+9+1yWTS+fn59sduvfVW7efnp/Py8uyP3XHHHXrIkCH2r1NSUvTdd9/d4Fp33XWX7tWrl9Za68zMTA3oL7/80v68xWLR3bt316NHj9Zaa3348GEdHBysFy9e3OA677zzjo6MjLR/PWLECH3DDTc43SchREMysiVEJ3bGGWfYR2aO1adPH/u/t2zZQmxsLAMGDLA/ZjabOeOMM+wjN/VOPvlk+7/rc5EGDRrU6LG8vDzCwsLYsmULo0aNanCNESNGoLVm69at9OjRg7/+9a/ceOONvP3224wcOZJLLrmEU089FYCffvqJ6Ohohg4d6rB/69atIycnh6ioqAaPWywWgoODAdi6dSunn346/v5Hf50NHz680bU++ugj5syZw86dOykrK8Nms1FTU0NOTg7du3fn1ltv5bLLLmP9+vWMHj2a8ePHM27cOPz8nM+2aKk/TUlOTm4wwpiUlERSUhLx8fENHsvLywOMKc8DBw5w7rnnNrjOiBEjeP7556msrLRP9w4bNsz+fGBgIKeddhoVFRWA8X+jqqqKyy67DKWU/Tir1Up1dTX5+fkN2iCEaB0JtoToxIKDg+ndu7fbrhcQEGD/d/2br6PHbDab09d86KGHmDp1KkuWLOHrr79m5syZ3HPPPTz++OMtnmuz2ejfvz8ff/xxo+dCQkKcbsOaNWv43e9+x3333cfTTz9NdHQ0P/74I9deey01NTUAjBs3jn379rF06VJWrFjBtGnTOOmkk/jqq68wmUxO36s1jv0eg/F9dvSYK993Z9Rf78MPP6Rv376Nnnc0VSqEcJ0kyAvRxQ0cOJDCwsIGie0Wi4U1a9Zw4okntvnaxyerf/vttyilGDhwoP2x9PR0br31Vv7zn//w6KOP8sorrwAwZMgQiouLGyTrH2vo0KFkZWURERFB7969G/zp3r07AAMGDGDt2rX2PDCAlStXNrjODz/8QFxcHI8//jhnnHEGffv25cCBA43uFxMTw1VXXcVrr73G//73P7799lv79y0wMLDBPRxpqT/uEhERQUpKisPvfa9evQgJCbGPZK5atcr+fE1NDevWrbN/PXDgQIKCgsjKymr0/e3du7fHg0whfIUEW0J0caNGjeL000/n6quvZuXKlWzevJlrrrmG6upq/vjHP7bp2nfffTcbNmzgT3/6E7/99htLlizh9ttvZ+rUqaSlpVFRUcGMGTP4+uuv2b17Nz///DNLliyxBwKjRo3inHPO4YorruDTTz9l9+7drFy5krlz5wIwdepUevXqxYUXXsiXX37Jnj17WLNmDU8++SSffPIJAH/84x/Jz8/npptuYtu2bXz11Vc88MADDdrZr18/8vPzefPNN8nKyuLdd9/l5ZdfbnDMAw88wEcffcT27dvJzMxk4cKFhIWFkZaWBkCvXr346aef2LVrFwUFBdTW1jr8XjfXH3e67777eOGFF3jjjTfIzMzktdde45VXXuH+++8HoHfv3lxyySXMmDGDb775hq1bt3LjjTdSXl5uv0ZYWBj3338/999/Py+99BLbt29ny5Yt/Pvf/+Zvf/ub29sshK+SYEuILk4pxSeffMIJJ5zAhRdeyGmnnUZOTg7Lli1rkCfUGoMGDeKzzz7ju+++4+STT2b69OlceOGFvPrqqwD4+/tTXFzMDTfcQP/+/Rk3bhyJiYm899579rb973//44ILLuCWW26hX79+TJs2jYKCAgCCgoL49ttv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qdG5ubn6tttu01artd370BbO9P/XX3/V1dXVWmutly5dau+/1k3/DHQGzvT9m2++0XPnzm10bnl5uZ4xY4YuLy9v8O/Owpm+H2vRokX6pZdesn/dmV93rbXesmWL3rVrl/7zn//s8PmffvpJP/HEE9pms+nt27fr++67T2vd+V/3ei31/7fffrP3a8OGDfb+a631rbfeqktLS9ulnZ7QUt83b96sn3zyyUaPu/oz01Y+MY24bt06RowYAcCIESNYt26d0+dqrdmyZQtnnnkmACNHjnTp/I7mTN+7d+9Ot27dAIiJiSEyMpKysrJ2bae77Ny5k6SkJBITE/H392fYsGGN+rx+/Xr7p9czzzyTzZs3o7Vm3bp1DBs2jICAABISEkhKSmLnzp0d0IvWc6b/J554ImazGYA+ffpQVFTUEU11O2f63pSNGzcyaNAgwsLCCAsLY9CgQWzcuNGzDXYjV/u+cuVKhg8f3o4t9KwBAwY4nK2ot379es4991yUUvTt25fDhw9TXFzc6V/3ei31v1+/fvbn+/TpQ2FhYXs1zeNa6ntT2vL7ojU6x1xYG5WWlhIdHQ1AVFQUpaWlDo+rra3l3nvvxWQyMXHiRE4//XTKy8sJCQnBZDIBRjDSmd6cnO17vZ07d1JXV0diYqL9sX/961/85z//4cQTT2Tq1KkEBAR4tM1tUVRURGxsrP3r2NhYMjMzmzzGZDIREhJCeXk5RUVF9OnTx35cZ3utwbn+H+vrr79uMFXq6Gegs3C272vWrGHbtm1069aNa6+9lri4uEbndrbX3pXXPT8/n7y8PE488UT7Y535dXdGUVERcXFx9q9jY2MpKirq9K97a3z99deccsopDR574oknABg7dmyHl0jwhB07dnD33XcTHR3N9OnTSU1Ndfl3ZVt1mWDrscceo6SkpNHjV155ZYOvlVIopRxe4+WXXyYmJobc3FweffRR0tLS7LlK3swdfQcoLi7mhRdeYMaMGfj5GYOeV199NVFRUdTV1fHaa6/x6aef2ue7Ref23XffkZWVxSOPPGJ/zNHPQFJSUsc10s2GDBnC2WefTUBAAMuWLeOll17i73//e0c3q12tXLmSM8880/4zDl3/dReGzZs388033/Doo4/aH3vssceIiYmhtLSUxx9/nO7duzNgwIAObKV79erVi5dffpmgoCA2bNjA008/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17j22mv16NGjnbrfs88+q2NiYlxqoxC+TEa2hOgEioqKWLRoEbfffjsREREOj1FKNfj6gw8+ID8/n6+++oply5YBxkjGgw8+yIYNG1i2bBkmk4kLL7yw0cjXQw89xB//+Ec2btxI//79ufLKK7n22mv5wx/+wM8//8yAAQO4+uqrqa2tBUBrTUJCAu+99x7btm1jzpw5zJs3j5kzZ9qvuXz5csaNG8eQIUNYvXo1a9as4ZprrqG2tpaRI0fSp08f3nrrrQbteOONN7j66qsJDQ112OeKigpGjRrF4sWL+fXXX7npppu4/vrr+eabbxoc95///IeioiJWrFjBv//9b7744gueeuop+/MvvPACzz33HE8//TQbNmxgyJAh/OMf/2juJWlRbm4uw4cPJyEhge+//54ff/yRfv36MXLkSPLz8wHYunUrI0aM4KyzzmL9+vV8/fXXmEwmxo4dS3V1tdP3qqqqoqampsH3aeXKlYwfP77BcePHj2fv3r0cOHCgTX0rKSlp8jURQjjQ0dGeEKJla9as0YD+6KOPGjx+1lln6dDQUB0aGqoHDBhgf3zEiBG6T58+2mq1NnvdwsJCDegffvhBa310ZGv27Nn2Y9auXasB/cwzz9gf27Bhgwb0r7/+2uS1n3vuOd27d2/718OHD9cXXnhhk8c/++yzOi0tzd7mbdu2aUBv2LCh2T4c75JLLtE33nij/esRI0boQYMGNTjmlltu0Weeeab96+TkZH3//fc3OOayyy5r08jW3//+d33GGWc0eMxms+n09HT79/faa6/VV1xxRYNjqqurdXBwsP7444+bvfexbrjhBt2jR48Go3UBAQH6tddea3Dc5s2bNaDXrl3b6BrOjmxt3bpVh4eH6xdeeMHp9gnh62RkS4hORGvd4Ov333+fjRs3ctNNN3H48OEGzw0ZMgQ/v4Y/4hs3bmTy5Mn06tWL8PBw0tLSANi7d2+D404++WT7v5OSkgAYNGhQo8fy8vLsj73xxhucccYZJCYmEhYWxn333dfguj/99BPnn39+k3279tprycvLY+nSpQDMnTuXIUOGcMoppzR5TmVlJffeey8DBw4kJiaGsLAwFi1a1Gx/ALp3705ubi4AZWVlHDx4kGHDhjU4Zvjw4U3e1xnr1q3jp59+IiwszP4nPDycPXv2kJmZaT/m448/bnBMbGws1dXV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jUaj0fgTbWxpNBqNRqPR+JGgN7ZmzJjR20PoNYJ57hDc8w/muUNwz1/PPXgJ5vn39tx1grxGo9FoNBqNHwl6z5ZGo9FoNBqNP9HGlkaj0Wg0Go0fCevtAfiT7du389JLL2G32zn//POZM2eO0/ufffYZK1asICkpCYBZs2Zx/vnnO9578803AbjyyiuZPn16IIfeYzzN/eWXX2bXrl0ANDc3U11dzcsvvwzAj370IwYOHAhASkoK99xzTyCH3mOefvpptm3bRnx8PI8//niH96WUvPTSS3z77bcYjUZuu+02hg4dCpz4993T3L/44gveeecdpJRERkZy8803M3jwYABuv/12IiIiCAkJITQ0lCVLlgR49D3H0/x37drFn/70J9LS0gA47bTTuOqqqwDP35m+jqe5v/vuu3zxxRcA2O12CgoKePHFF4mJiTnh773JZOKpp56iqqoKIQQzZszg4osvdjqmv37vvZl7f/7eezP/PvG9l/0Um80m77jjDllcXCwtFou866675NGjR52O+fTTT+Xy5cs7fLa2tlbefvvtsra21unfJwrezL09q1evlk899ZTj5/nz5wdimH5j165d8uDBg/I3v/mNy/e/+eYbuXDhQmm32+XevXvlfffdJ6U88e+7lJ7nvmfPHsectm3b5pi7lFLedtttsrq6OiDj9Bee5r9z5065ePHiDq939TvTF/E09/Z8/fXX8ve//73j5xP93ldUVMiDBw9KKaVsaGiQv/zlLzvcv/76vfdm7v35e+/N/PvC977fhhEPHDhARkYG6enphIWFccYZZ/D111979dnt27czfvx4YmJiiImJYfz48Wzfvt2/A/YhXZ37hg0bOOusswI4Qv8yZswYYmJi3L6/detWpk2bhhCCESNGUF9fT2Vl5Ql/38Hz3EeOHOl4f/jw4ZSXlwdqaAHB0/zd0ZPnRV+hK3PfsGEDZ555pp9HFDgSExMdXqrIyEiysrKoqKhwOqa/fu+9mXt//t57M393BPJ732/DiBUVFSQnJzt+Tk5OZv/+/R2O27x5Mz/88AMDBgzghhtuICUlpcNnk5KSvL55fQFv5w5QVlZGaWkp48aNc7xmsVi49957CQ0NZfbs2Zx66ql+H3MgqaioICUlxfFzcnIyFRUVJ/x97yqffPIJJ598stNrCxcuBOCCCy7o9VJpf7Fv3z7uvvtu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Ly+PuLi4DgZlZmYmAGPGjGHLli1ORtGGDRuczvPll1+SkpLCY489xmmnncaIESMoKCjocL2kpCSuueYannvuOf73v//x+eefO35v4eHhHg0vT/Nxx4ABA7jpppt49dVXefHFF1m1ahU1NTVdOkd70tLSKCwsdHpt27Ztfr+uRqNRaGNLowkyzjvvPE499VSuvfZaNmzYwM6dO7n++utpamri5z//eY/Offfdd7Nt2zZ+/etfs2fPHtauXcsvfvELrrvuOgYOHEhdXR233347n3zyCfn5+Xz77besXbvWEdI877zzOPvss/nRj37EO++8Q35+Phs2bGD58uUAXHfddQwZMoRLLrmEDz/8kEOHDrF582YWL17M22+/DcDPf/5zysrK+L//+z9++OEHPv74Y+6//36ncY4cOZKysjJefPFF8vLyePXVV3n66aedjrn//vt588032bt3L/v372fVqlXExMQwcOBAAIYMGcI333zDwYMHMZlMHTxF3szHFXfccQerV6/m4MGD7Nq1izfffJOcnBxiY2O7fV9mzJjBnj17eOqppzh48CAvvPACb7zxht+vq9FoFNrY0miCDCEEb7/9NqNGjeKSSy7hlFNOobi4mI8++sipErE7jB8/nnfffZf169czYcIEFixYwCWXXOII0YWFhVFZWclPf/pTRo8ezcyZM0lPT+e1115zjO1///sfF198MbfeeisjR45k/vz5mEwmACIiIvj888+ZMmUKN910EyNGjODKK69ky5YtDBo0CICsrCzee+89tmzZwsSJE/nVr37FX//6V6dxXnrppdx///387ne/46STTuL111/vIHMQERHBQw89xOTJk5kyZQrff/89a9asIT4+HoD/9//+HykpKUyYMIHU1NQO3jNv5uMKKSV33nkn48aNY9q0adTX17NmzRonmYauMmPGDB577DEWLVrEhAkT+OSTT3jooYf8fl2NRqMQ8vhAvkaj0Wg0Go3GZ2jPlkaj0Wg0Go0f0caWRqPRaDQajR/RxpZGo9FoNBqNH9HGlkaj0Wg0Go0f8YmC/NNPP822bduIj4/n8ccf7/D+rl27+NOf/kRaWhqgVK6vuuoqX1xao9FoNBqNpk/jE2Nr+vTpzJo1i6eeesrtMaNHj+bee+/t8rmPF+LzNSkpKZ2WYWsCj74nfRN9X/oe+p70TfR96XsE6p60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\n",
      "text/plain": [
       "<Figure size 720x1080 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "n_samples = 100\n",
    "\n",
    "simulators = [\"mbml_homo_01\", 'gramacy1d', 'homo1']\n",
    "sim2name = {\"mbml_homo_01\": \"Homoscedastic model\", \n",
    "            'gramacy1d': \"Gramacy and Lee 2012\",\n",
    "            'homo1': 'Homoscedastic sinus'\n",
    "           }\n",
    "n_simulators = len(simulators)\n",
    "f, ax = plt.subplots(n_simulators, 1, figsize=(10, 5*n_simulators))\n",
    "\n",
    "for idx, sim in enumerate(simulators):\n",
    "    args.simulator = sim\n",
    "    search_space = get_search_space(simulator=args.simulator)\n",
    "\n",
    "    # We do need to sample a training set\n",
    "    train_x, train_y = sample_dataset_from_simulator(args, search_space, n_samples=n_samples, seed=0)\n",
    "    #test_x, test_y = sample_dataset_from_simulator(args, search_space, n_samples=args.test_samples, seed=4242)\n",
    "\n",
    "    # A simulator where we can access the true mean and stddev\n",
    "    _, true_mean, true_std = oracle_simulator(args, torch.Tensor(search_space))\n",
    "\n",
    "    ax[idx].plot(search_space, true_mean)\n",
    "    ax[idx].fill_between(search_space, true_mean - 2*true_std, true_mean + 2*true_std, alpha=0.3)\n",
    "    ax[idx].plot(train_x, train_y, 'k*')\n",
    "    ax[idx].set_title(sim2name[sim])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define GP Model: This is a wrapper for the pyro.models.GPRegression where we put priors on the hyperparameters\n",
    "def gp_pyro(X, y, length_prior, noise_prior):  #variance_prior=dist.LogNormal(0.0, 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 = pyro.nn.PyroSample(length_prior)\n",
    "    ##gpr.kernel.variance = pyro.nn.PyroSample(variance_prior)\n",
    "    #gpr.noise = pyro.nn.PyroSample(noise_prior)\n",
    "    gpr.kernel.lengthscale = pyro.nn.PyroSample(length_prior)\n",
    "    gpr.noise = pyro.nn.PyroSample(noise_prior)\n",
    "    \n",
    "    return gpr\n",
    "\n",
    "\n",
    "# GP model from GPyTorch (used for plotting)\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",
    "        self.covar_module.outputscale = torch.tensor(1.)\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",
    " "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Setup for doing Active Learning\n",
    "In the rest of this notebook, I will do the central experiments. I will use the toy simulator *Homoscedastic sine function* to demonstrate the proposed active learning strategy."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "First, we generate some training data and make it ready for analysis."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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jxBCiI0bN4qf/OQn1RjqlDOaa//GG2+IZDIphBDir3/9K137MhrN9RdCiHg8Lr797W+Lr3/966Ktra0KI516RnPtOzo6xFe+8hURjUaFEEKEw+FqDHXKGc21/8UvfiH++te/CiGEOHjwoLjxxhurMdQpafv27WLPnj3iS1/6Usmvv/baa+L73/++4JyLnTt3iltuuaXCIywfWkYs0NbWhqamJjQ2NkLTNJx33nl49dVXi47ZvHkzLrzwQgDAOeecgzfffBOC0t7GbDTX/tRTT4XD4QAALFy4EKFQqBpDnZJGc/0B4OGHH8bll18OXderMMqpaTTX/plnnsH73vc+eL1eALIbBxm70Vx7xhji8TgAIB6Po66urhpDnZKWLFli/06XsnnzZrz73e8GYwyLFi1CLBbDwMBABUdYPhRsFQiFQqivr7c/r6+vH/GCXniMqqpwu92IRqMVHedUNJprX+jZZ5+dlMVxJ6rRXP+9e/eir6+PllDKbDTXvqOjA52dnfjWt76Fb3zjG3j99dcrPMqpaTTX/qqrrsLf//53fOYzn8Gtt96K66+/vtLDPGGFQqGi/ohHe12YyCjYIpPO888/j7179+KDH/xgtYdywuCc48EHH8THP/7xag/lhMQ5R2dnJ77zne/gC1/4Au655x7EYrFqD+uE8MILL+DCCy/EL37xC9xyyy248847wTmv9rDIJEPBVoFAIID+/n778/7+fruJdqljLMtCPB6Hz+er6DinotFcewDYtm0bHnnkEXz1q1+lpawyOtr1TyaTOHjwIP793/8dn/3sZ7F792788Ic/xJ49e6ox3ClltM87K1euhKZpmDZtGqZPn47Ozs5KD3XKGc21f/bZZ3HuuecCABYtWoRMJkOrGRUSCASKmlEf7nVhMqBgq0BLSws6OzvR09MD0zTx4osvYuXKlUXHrFixAs899xwAuSvrlFNOAWOsCqOdWkZz7fft24df/vKX+OpXv0o5K2V2tOvvdrtx//334+6778bdd9+NhQsX4qtf/SrtRiyD0fzun3XWWdi+fTsAIBKJoLOzE42NjdUY7pQymmsfDAbx5ptvAgDa29uRyWTg9/urMdwTzsqVK/H8889DCIFdu3bB7XZP2pw5Kmo6zJYtW/B//+//Beccq1atwj/+4z/i4YcfRktLC1auXIl0Oo277roL+/btg9frxU033URPemVytGv/3e9+FwcOHEBtbS0A+ST4ta99rbqDnkKOdv0L/du//Ruuu+46CrbK5GjXXgiBBx98EK+//joURcE//uM/4vzzz6/2sKeEo1379vZ23HPPPUgmkwCAj33sY1i2bFmVRz013HHHHdixYwei0Shqamrw4Q9/GKZpAgDWrFkDIQTuv/9+tLa2wjAM3HjjjZP2OYeCLUIIIYSQcUTLiIQQQggh44iCLUIIIYSQcUTBFiGEEELIOKJgixBCCCFkHFGwRQghhBAyjijYIoQQQggZRxRsEUIIIYSMIwq2CCGEEELG0f8Pj+N+D9APBe0AAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 720x360 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Generate some data\n",
    "n_samples = 10\n",
    "args.space_filling_design = \"random\"\n",
    "args.simulator = simulators[1]\n",
    "search_space = get_search_space(simulator=args.simulator)\n",
    "\n",
    "train_x, train_y = sample_dataset_from_simulator(args, search_space, n_samples=n_samples, seed=0)\n",
    "test_x, test_y = sample_dataset_from_simulator(args, search_space, n_samples=args.test_samples, seed=4242)\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",
    "test_x_trans = (test_x - min_x) / max_x\n",
    "test_y_trans = (test_y - mu_y) / sigma_y\n",
    "\n",
    "plt.figure(figsize=(10,5))\n",
    "plt.plot(test_x_trans, test_y_trans, \"ro\", label=\"Test data\", alpha=0.3)\n",
    "plt.plot(train_x_trans, train_y_trans, \"k*\", label=\"Training data\")\n",
    "plt.title(\"Initial data\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import functions for computing loss\n",
    "from mbml_utility_functions import compute_loss\n",
    "\n",
    "# import function for plotting\n",
    "from mbml_utility_functions import plot_one_variable"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Active Learning\n",
    "\n",
    "**Experiment 1: Active Learning with a Fully Bayesian GP**\n",
    "\n",
    "We will test the following settings of active learning:\n",
    "1. ~~A single GP without priors and the samling strategy is the predicted variance (ALM)~~\n",
    "2. A single GP with priors and the sampling strategy is the predicted variance (ALM)\n",
    "3. ~~A fully Bayesian GP, where we use the mode to estimate the GP and the sampling strategy is the predicted variance (ALM)~~\n",
    "    - (i) Get the posteriors by MCMC\n",
    "    - (ii) Get the posteriors by V\n",
    "4. A fully Bayesian GP, where we use the mode to estimate the GP and the sampling strategy is the predicted variance between mean functions drawn from the posteriors of the hyperparameters\n",
    "    - (i) Get the posteriors by MCMC\n",
    "    - (ii) Get the posteriors by VI\n",
    "5. A fully Bayesian GP, where we use the mode to estimate the GP and the sampling strategy is the predicted variance between mean functions drawn from the posteriors of the hyperparameters. We will additionally update the priors of the hyperparameters after each iteration by using the information of the posteriors.\n",
    "    - (i) Get the posteriors by MCMC\n",
    "    - (ii) Get the posteriors by VI\n",
    "\n",
    "We will evaluate the models by looking at the predictive power and the computational time. We will repeat all the setups three times (the more, the better but for this project three repetitions is considered to be enough).\n",
    "\n",
    "**Experiment 1b: Different ways of updating the prior**\n",
    "\n",
    "**Experiment 2: The assumption of noise**\n",
    "Here, we will consider the three best approaches from experiment 1. We will test three different levels of homoscedastic noise. Lastly, we will also test what happens if the assumption of homoscedastic noise is violated and the data actually have heteroscedastic noise. Thus, we will have the following experiments.\n",
    "\n",
    "For the two best models and the baseline, we will test..\n",
    "1. Noise level of 0.1 (reuse results from experiment 1)\n",
    "2. Noise level of 0.2\n",
    "3. Noise level of 0.5\n",
    "4. Homoscedastic noise\n",
    "5. Higdon"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Experiment 1\n",
    "Settings:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "args.simulator = \"homo1\"  #\"gramacy1d\"\n",
    "args.plot = False\n",
    "args.initial_samples = 10\n",
    "args.active_learning_steps = 100\n",
    "args.test_samples = 505\n",
    "args.space_filling_design = \"random\"\n",
    "repetitions = 5"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Active Learning: Baseline\n",
    "In the baseline, we will use a single GP with priors and the sampling strategy is the predicted variance (ALM)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "First, we define some functions and the model for handling the fitting of a single GP with priors."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "from mbml_utility_functions import get_optimizer, BaseExactGPModel"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define model\n",
    "class FancyGPWithPriors(BaseExactGPModel):\n",
    "    def __init__(self, train_x, train_y, likelihood):\n",
    "        super(FancyGPWithPriors, self).__init__(train_x, train_y, likelihood)\n",
    "        self.mean_module = gpytorch.means.ZeroMean()\n",
    "\n",
    "        # value of priors:\n",
    "        # https://botorch.org/api/_modules/botorch/models/gp_regression.html#SingleTaskGP\n",
    "        # https://docs.gpytorch.ai/en/stable/examples/00_Basic_Usage/Hyperparameters.html#Priors\n",
    "        lengthscale_prior = gpytorch.priors.GammaPrior(3.0, 6.0)\n",
    "\n",
    "        self.covar_module = gpytorch.kernels.ScaleKernel(\n",
    "            gpytorch.kernels.RBFKernel(\n",
    "                lengthscale_prior=lengthscale_prior,\n",
    "            )\n",
    "        )\n",
    "\n",
    "        # Initialize lengthscale to mean of the prior\n",
    "        self.covar_module.base_kernel.lengthscale = lengthscale_prior.mean\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": 12,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 1/100: train NMLL: 1.394, valid NMLL 1.484, valid RMSE of mean 0.717, valid RMSE of std 0.436\n",
      "Iteration 2/100: train NMLL: 1.397, valid NMLL 1.523, valid RMSE of mean 0.716, valid RMSE of std 0.410\n",
      "Iteration 3/100: train NMLL: 1.400, valid NMLL 1.556, valid RMSE of mean 0.714, valid RMSE of std 0.388\n",
      "Iteration 4/100: train NMLL: 1.402, valid NMLL 1.552, valid RMSE of mean 0.725, valid RMSE of std 0.405\n",
      "Iteration 5/100: train NMLL: 1.404, valid NMLL 1.581, valid RMSE of mean 0.723, valid RMSE of std 0.386\n",
      "Iteration 6/100: train NMLL: 1.406, valid NMLL 1.568, valid RMSE of mean 0.737, valid RMSE of std 0.407\n",
      "Iteration 7/100: train NMLL: 1.407, valid NMLL 1.574, valid RMSE of mean 0.754, valid RMSE of std 0.422\n",
      "Iteration 8/100: train NMLL: 1.408, valid NMLL 1.594, valid RMSE of mean 0.751, valid RMSE of std 0.406\n",
      "Iteration 9/100: train NMLL: 1.409, valid NMLL 1.569, valid RMSE of mean 0.765, valid RMSE of std 0.414\n",
      "Iteration 10/100: train NMLL: 1.410, valid NMLL 1.576, valid RMSE of mean 0.755, valid RMSE of std 0.409\n",
      "Iteration 11/100: train NMLL: 1.409, valid NMLL 1.580, valid RMSE of mean 0.749, valid RMSE of std 0.397\n",
      "Iteration 12/100: train NMLL: 1.405, valid NMLL 1.588, valid RMSE of mean 0.755, valid RMSE of std 0.387\n",
      "Iteration 13/100: train NMLL: 1.408, valid NMLL 1.550, valid RMSE of mean 0.736, valid RMSE of std 0.420\n",
      "Iteration 14/100: train NMLL: 1.410, valid NMLL 1.569, valid RMSE of mean 0.738, valid RMSE of std 0.408\n",
      "Iteration 15/100: train NMLL: 1.401, valid NMLL 1.555, valid RMSE of mean 0.745, valid RMSE of std 0.408\n",
      "Iteration 16/100: train NMLL: 1.399, valid NMLL 1.525, valid RMSE of mean 0.732, valid RMSE of std 0.429\n",
      "Iteration 17/100: train NMLL: 1.412, valid NMLL 1.522, valid RMSE of mean 0.746, valid RMSE of std 0.460\n",
      "Iteration 18/100: train NMLL: 1.410, valid NMLL 1.528, valid RMSE of mean 0.742, valid RMSE of std 0.450\n",
      "Iteration 19/100: train NMLL: 1.400, valid NMLL 1.512, valid RMSE of mean 0.750, valid RMSE of std 0.450\n",
      "Iteration 20/100: train NMLL: 1.400, valid NMLL 1.523, valid RMSE of mean 0.747, valid RMSE of std 0.439\n",
      "Iteration 21/100: train NMLL: 1.400, valid NMLL 1.536, valid RMSE of mean 0.747, valid RMSE of std 0.429\n",
      "Iteration 22/100: train NMLL: 1.384, valid NMLL 1.507, valid RMSE of mean 0.756, valid RMSE of std 0.435\n",
      "Iteration 23/100: train NMLL: 1.376, valid NMLL 1.499, valid RMSE of mean 0.752, valid RMSE of std 0.434\n",
      "Iteration 24/100: train NMLL: 1.380, valid NMLL 1.490, valid RMSE of mean 0.739, valid RMSE of std 0.441\n",
      "Iteration 25/100: train NMLL: 1.372, valid NMLL 1.462, valid RMSE of mean 0.739, valid RMSE of std 0.462\n",
      "Iteration 26/100: train NMLL: 1.375, valid NMLL 1.452, valid RMSE of mean 0.728, valid RMSE of std 0.468\n",
      "Iteration 27/100: train NMLL: 1.368, valid NMLL 1.443, valid RMSE of mean 0.729, valid RMSE of std 0.466\n",
      "Iteration 28/100: train NMLL: 1.367, valid NMLL 1.453, valid RMSE of mean 0.737, valid RMSE of std 0.464\n",
      "Iteration 29/100: train NMLL: 1.355, valid NMLL 1.451, valid RMSE of mean 0.740, valid RMSE of std 0.454\n",
      "Iteration 30/100: train NMLL: 1.357, valid NMLL 1.461, valid RMSE of mean 0.740, valid RMSE of std 0.448\n",
      "Iteration 31/100: train NMLL: 1.357, valid NMLL 1.442, valid RMSE of mean 0.733, valid RMSE of std 0.459\n",
      "Iteration 32/100: train NMLL: 1.356, valid NMLL 1.449, valid RMSE of mean 0.733, valid RMSE of std 0.450\n",
      "Iteration 33/100: train NMLL: 1.359, valid NMLL 1.443, valid RMSE of mean 0.743, valid RMSE of std 0.471\n",
      "Iteration 34/100: train NMLL: 1.344, valid NMLL 1.434, valid RMSE of mean 0.748, valid RMSE of std 0.463\n",
      "Iteration 35/100: train NMLL: 1.354, valid NMLL 1.443, valid RMSE of mean 0.743, valid RMSE of std 0.467\n",
      "Iteration 36/100: train NMLL: 1.365, valid NMLL 1.451, valid RMSE of mean 0.746, valid RMSE of std 0.476\n",
      "Iteration 37/100: train NMLL: 1.363, valid NMLL 1.456, valid RMSE of mean 0.746, valid RMSE of std 0.469\n",
      "Iteration 38/100: train NMLL: 1.354, valid NMLL 1.454, valid RMSE of mean 0.748, valid RMSE of std 0.461\n",
      "Iteration 39/100: train NMLL: 1.349, valid NMLL 1.455, valid RMSE of mean 0.749, valid RMSE of std 0.455\n",
      "Iteration 40/100: train NMLL: 1.348, valid NMLL 1.461, valid RMSE of mean 0.749, valid RMSE of std 0.448\n",
      "Iteration 41/100: train NMLL: 1.349, valid NMLL 1.449, valid RMSE of mean 0.741, valid RMSE of std 0.455\n",
      "Iteration 42/100: train NMLL: 1.353, valid NMLL 1.458, valid RMSE of mean 0.740, valid RMSE of std 0.452\n",
      "Iteration 43/100: train NMLL: 1.352, valid NMLL 1.459, valid RMSE of mean 0.748, valid RMSE of std 0.454\n",
      "Iteration 44/100: train NMLL: 1.344, valid NMLL 1.459, valid RMSE of mean 0.749, valid RMSE of std 0.448\n",
      "Iteration 45/100: train NMLL: 1.338, valid NMLL 1.450, valid RMSE of mean 0.751, valid RMSE of std 0.450\n",
      "Iteration 46/100: train NMLL: 1.338, valid NMLL 1.456, valid RMSE of mean 0.751, valid RMSE of std 0.444\n",
      "Iteration 47/100: train NMLL: 1.328, valid NMLL 1.454, valid RMSE of mean 0.753, valid RMSE of std 0.438\n",
      "Iteration 48/100: train NMLL: 1.321, valid NMLL 1.447, valid RMSE of mean 0.756, valid RMSE of std 0.438\n",
      "Iteration 49/100: train NMLL: 1.322, valid NMLL 1.454, valid RMSE of mean 0.756, valid RMSE of std 0.433\n",
      "Iteration 50/100: train NMLL: 1.324, valid NMLL 1.444, valid RMSE of mean 0.752, valid RMSE of std 0.442\n",
      "Iteration 51/100: train NMLL: 1.316, valid NMLL 1.430, valid RMSE of mean 0.757, valid RMSE of std 0.448\n",
      "Iteration 52/100: train NMLL: 1.311, valid NMLL 1.418, valid RMSE of mean 0.762, valid RMSE of std 0.456\n",
      "Iteration 53/100: train NMLL: 1.300, valid NMLL 1.413, valid RMSE of mean 0.764, valid RMSE of std 0.451\n",
      "Iteration 54/100: train NMLL: 1.299, valid NMLL 1.418, valid RMSE of mean 0.764, valid RMSE of std 0.445\n",
      "Iteration 55/100: train NMLL: 1.299, valid NMLL 1.422, valid RMSE of mean 0.763, valid RMSE of std 0.441\n",
      "Iteration 56/100: train NMLL: 1.293, valid NMLL 1.415, valid RMSE of mean 0.768, valid RMSE of std 0.443\n",
      "Iteration 57/100: train NMLL: 1.282, valid NMLL 1.410, valid RMSE of mean 0.770, valid RMSE of std 0.438\n",
      "Iteration 58/100: train NMLL: 1.282, valid NMLL 1.415, valid RMSE of mean 0.770, valid RMSE of std 0.433\n",
      "Iteration 59/100: train NMLL: 1.282, valid NMLL 1.421, valid RMSE of mean 0.770, valid RMSE of std 0.428\n",
      "Iteration 60/100: train NMLL: 1.276, valid NMLL 1.420, valid RMSE of mean 0.772, valid RMSE of std 0.424\n",
      "Iteration 61/100: train NMLL: 1.268, valid NMLL 1.419, valid RMSE of mean 0.773, valid RMSE of std 0.419\n",
      "Iteration 62/100: train NMLL: 1.267, valid NMLL 1.424, valid RMSE of mean 0.773, valid RMSE of std 0.415\n",
      "Iteration 63/100: train NMLL: 1.268, valid NMLL 1.428, valid RMSE of mean 0.775, valid RMSE of std 0.413\n",
      "Iteration 64/100: train NMLL: 1.262, valid NMLL 1.425, valid RMSE of mean 0.778, valid RMSE of std 0.411\n",
      "Iteration 65/100: train NMLL: 1.258, valid NMLL 1.427, valid RMSE of mean 0.777, valid RMSE of std 0.407\n",
      "Iteration 66/100: train NMLL: 1.258, valid NMLL 1.433, valid RMSE of mean 0.777, valid RMSE of std 0.403\n",
      "Iteration 67/100: train NMLL: 1.250, valid NMLL 1.432, valid RMSE of mean 0.778, valid RMSE of std 0.399\n",
      "Iteration 68/100: train NMLL: 1.251, valid NMLL 1.431, valid RMSE of mean 0.777, valid RMSE of std 0.399\n",
      "Iteration 69/100: train NMLL: 1.245, valid NMLL 1.426, valid RMSE of mean 0.781, valid RMSE of std 0.398\n",
      "Iteration 70/100: train NMLL: 1.245, valid NMLL 1.432, valid RMSE of mean 0.782, valid RMSE of std 0.395\n",
      "Iteration 71/100: train NMLL: 1.239, valid NMLL 1.429, valid RMSE of mean 0.785, valid RMSE of std 0.392\n",
      "Iteration 72/100: train NMLL: 1.230, valid NMLL 1.426, valid RMSE of mean 0.786, valid RMSE of std 0.389\n",
      "Iteration 73/100: train NMLL: 1.229, valid NMLL 1.432, valid RMSE of mean 0.786, valid RMSE of std 0.385\n",
      "Iteration 74/100: train NMLL: 1.223, valid NMLL 1.424, valid RMSE of mean 0.792, valid RMSE of std 0.387\n",
      "Iteration 75/100: train NMLL: 1.223, valid NMLL 1.428, valid RMSE of mean 0.791, valid RMSE of std 0.384\n",
      "Iteration 76/100: train NMLL: 1.214, valid NMLL 1.426, valid RMSE of mean 0.792, valid RMSE of std 0.380\n",
      "Iteration 77/100: train NMLL: 1.214, valid NMLL 1.430, valid RMSE of mean 0.792, valid RMSE of std 0.377\n",
      "Iteration 78/100: train NMLL: 1.209, valid NMLL 1.430, valid RMSE of mean 0.794, valid RMSE of std 0.375\n",
      "Iteration 79/100: train NMLL: 1.208, valid NMLL 1.434, valid RMSE of mean 0.794, valid RMSE of std 0.371\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 80/100: train NMLL: 1.201, valid NMLL 1.433, valid RMSE of mean 0.794, valid RMSE of std 0.368\n",
      "Iteration 81/100: train NMLL: 1.196, valid NMLL 1.432, valid RMSE of mean 0.797, valid RMSE of std 0.366\n",
      "Iteration 82/100: train NMLL: 1.195, valid NMLL 1.437, valid RMSE of mean 0.797, valid RMSE of std 0.362\n",
      "Iteration 83/100: train NMLL: 1.195, valid NMLL 1.442, valid RMSE of mean 0.798, valid RMSE of std 0.360\n",
      "Iteration 84/100: train NMLL: 1.186, valid NMLL 1.438, valid RMSE of mean 0.799, valid RMSE of std 0.357\n",
      "Iteration 85/100: train NMLL: 1.180, valid NMLL 1.433, valid RMSE of mean 0.803, valid RMSE of std 0.358\n",
      "Iteration 86/100: train NMLL: 1.180, valid NMLL 1.438, valid RMSE of mean 0.804, valid RMSE of std 0.355\n",
      "Iteration 87/100: train NMLL: 1.168, valid NMLL 1.430, valid RMSE of mean 0.806, valid RMSE of std 0.353\n",
      "Iteration 88/100: train NMLL: 1.168, valid NMLL 1.435, valid RMSE of mean 0.805, valid RMSE of std 0.350\n",
      "Iteration 89/100: train NMLL: 1.162, valid NMLL 1.428, valid RMSE of mean 0.811, valid RMSE of std 0.351\n",
      "Iteration 90/100: train NMLL: 1.162, valid NMLL 1.433, valid RMSE of mean 0.811, valid RMSE of std 0.349\n",
      "Iteration 91/100: train NMLL: 1.156, valid NMLL 1.430, valid RMSE of mean 0.815, valid RMSE of std 0.348\n",
      "Iteration 92/100: train NMLL: 1.146, valid NMLL 1.425, valid RMSE of mean 0.816, valid RMSE of std 0.347\n",
      "Iteration 93/100: train NMLL: 1.147, valid NMLL 1.428, valid RMSE of mean 0.817, valid RMSE of std 0.346\n",
      "Iteration 94/100: train NMLL: 1.141, valid NMLL 1.426, valid RMSE of mean 0.821, valid RMSE of std 0.344\n",
      "Iteration 95/100: train NMLL: 1.141, valid NMLL 1.430, valid RMSE of mean 0.821, valid RMSE of std 0.342\n",
      "Iteration 96/100: train NMLL: 1.136, valid NMLL 1.431, valid RMSE of mean 0.820, valid RMSE of std 0.339\n",
      "Iteration 97/100: train NMLL: 1.136, valid NMLL 1.436, valid RMSE of mean 0.820, valid RMSE of std 0.337\n",
      "Iteration 98/100: train NMLL: 1.131, valid NMLL 1.427, valid RMSE of mean 0.827, valid RMSE of std 0.340\n",
      "Iteration 99/100: train NMLL: 1.131, valid NMLL 1.432, valid RMSE of mean 0.827, valid RMSE of std 0.337\n",
      "Iteration 100/100: train NMLL: 1.131, valid NMLL 1.436, valid RMSE of mean 0.825, valid RMSE of std 0.336\n",
      "Repetition 1 took 40.447680950164795 sec.\n",
      "\n",
      "Iteration 1/100: train NMLL: 1.393, valid NMLL 1.673, valid RMSE of mean 0.846, valid RMSE of std 0.394\n",
      "Iteration 2/100: train NMLL: 1.397, valid NMLL 1.689, valid RMSE of mean 0.827, valid RMSE of std 0.379\n",
      "Iteration 3/100: train NMLL: 1.400, valid NMLL 1.711, valid RMSE of mean 0.813, valid RMSE of std 0.363\n",
      "Iteration 4/100: train NMLL: 1.402, valid NMLL 1.688, valid RMSE of mean 0.791, valid RMSE of std 0.365\n",
      "Iteration 5/100: train NMLL: 1.404, valid NMLL 1.726, valid RMSE of mean 0.788, valid RMSE of std 0.346\n",
      "Iteration 6/100: train NMLL: 1.406, valid NMLL 1.750, valid RMSE of mean 0.780, valid RMSE of std 0.333\n",
      "Iteration 7/100: train NMLL: 1.407, valid NMLL 1.687, valid RMSE of mean 0.759, valid RMSE of std 0.353\n",
      "Iteration 8/100: train NMLL: 1.408, valid NMLL 1.671, valid RMSE of mean 0.782, valid RMSE of std 0.381\n",
      "Iteration 9/100: train NMLL: 1.409, valid NMLL 1.702, valid RMSE of mean 0.783, valid RMSE of std 0.366\n",
      "Iteration 10/100: train NMLL: 1.410, valid NMLL 1.621, valid RMSE of mean 0.759, valid RMSE of std 0.402\n",
      "Iteration 11/100: train NMLL: 1.411, valid NMLL 1.636, valid RMSE of mean 0.771, valid RMSE of std 0.403\n",
      "Iteration 12/100: train NMLL: 1.167, valid NMLL 0.535, valid RMSE of mean 0.652, valid RMSE of std 0.380\n",
      "Iteration 13/100: train NMLL: 1.420, valid NMLL 1.486, valid RMSE of mean 0.752, valid RMSE of std 0.447\n",
      "Iteration 14/100: train NMLL: 1.412, valid NMLL 1.513, valid RMSE of mean 0.727, valid RMSE of std 0.481\n",
      "Iteration 15/100: train NMLL: 1.413, valid NMLL 1.523, valid RMSE of mean 0.733, valid RMSE of std 0.477\n",
      "Iteration 16/100: train NMLL: 1.405, valid NMLL 1.481, valid RMSE of mean 0.730, valid RMSE of std 0.462\n",
      "Iteration 17/100: train NMLL: 1.399, valid NMLL 1.470, valid RMSE of mean 0.726, valid RMSE of std 0.471\n",
      "Iteration 18/100: train NMLL: 1.396, valid NMLL 1.478, valid RMSE of mean 0.726, valid RMSE of std 0.458\n",
      "Iteration 19/100: train NMLL: 1.398, valid NMLL 1.493, valid RMSE of mean 0.726, valid RMSE of std 0.449\n",
      "Iteration 20/100: train NMLL: 1.394, valid NMLL 1.501, valid RMSE of mean 0.726, valid RMSE of std 0.438\n",
      "Iteration 21/100: train NMLL: 1.375, valid NMLL 1.487, valid RMSE of mean 0.734, valid RMSE of std 0.428\n",
      "Iteration 22/100: train NMLL: 1.369, valid NMLL 1.489, valid RMSE of mean 0.734, valid RMSE of std 0.418\n",
      "Iteration 23/100: train NMLL: 1.361, valid NMLL 1.472, valid RMSE of mean 0.738, valid RMSE of std 0.427\n",
      "Iteration 24/100: train NMLL: 1.360, valid NMLL 1.482, valid RMSE of mean 0.738, valid RMSE of std 0.418\n",
      "Iteration 25/100: train NMLL: 1.336, valid NMLL 1.464, valid RMSE of mean 0.745, valid RMSE of std 0.410\n",
      "Iteration 26/100: train NMLL: 1.329, valid NMLL 1.445, valid RMSE of mean 0.747, valid RMSE of std 0.417\n",
      "Iteration 27/100: train NMLL: 1.326, valid NMLL 1.454, valid RMSE of mean 0.748, valid RMSE of std 0.407\n",
      "Iteration 28/100: train NMLL: 1.313, valid NMLL 1.444, valid RMSE of mean 0.758, valid RMSE of std 0.404\n",
      "Iteration 29/100: train NMLL: 1.313, valid NMLL 1.452, valid RMSE of mean 0.757, valid RMSE of std 0.399\n",
      "Iteration 30/100: train NMLL: 1.316, valid NMLL 1.462, valid RMSE of mean 0.757, valid RMSE of std 0.396\n",
      "Iteration 31/100: train NMLL: 1.297, valid NMLL 1.455, valid RMSE of mean 0.760, valid RMSE of std 0.388\n",
      "Iteration 32/100: train NMLL: 1.295, valid NMLL 1.464, valid RMSE of mean 0.760, valid RMSE of std 0.380\n",
      "Iteration 33/100: train NMLL: 1.287, valid NMLL 1.458, valid RMSE of mean 0.766, valid RMSE of std 0.380\n",
      "Iteration 34/100: train NMLL: 1.272, valid NMLL 1.456, valid RMSE of mean 0.767, valid RMSE of std 0.372\n",
      "Iteration 35/100: train NMLL: 1.272, valid NMLL 1.441, valid RMSE of mean 0.770, valid RMSE of std 0.381\n",
      "Iteration 36/100: train NMLL: 1.260, valid NMLL 1.436, valid RMSE of mean 0.778, valid RMSE of std 0.376\n",
      "Iteration 37/100: train NMLL: 1.257, valid NMLL 1.445, valid RMSE of mean 0.778, valid RMSE of std 0.369\n",
      "Iteration 38/100: train NMLL: 1.249, valid NMLL 1.448, valid RMSE of mean 0.777, valid RMSE of std 0.364\n",
      "Iteration 39/100: train NMLL: 1.250, valid NMLL 1.456, valid RMSE of mean 0.778, valid RMSE of std 0.360\n",
      "Iteration 40/100: train NMLL: 1.255, valid NMLL 1.463, valid RMSE of mean 0.778, valid RMSE of std 0.360\n",
      "Iteration 41/100: train NMLL: 1.232, valid NMLL 1.445, valid RMSE of mean 0.782, valid RMSE of std 0.358\n",
      "Iteration 42/100: train NMLL: 1.231, valid NMLL 1.454, valid RMSE of mean 0.782, valid RMSE of std 0.352\n",
      "Iteration 43/100: train NMLL: 1.225, valid NMLL 1.439, valid RMSE of mean 0.792, valid RMSE of std 0.359\n",
      "Iteration 44/100: train NMLL: 1.225, valid NMLL 1.432, valid RMSE of mean 0.795, valid RMSE of std 0.363\n",
      "Iteration 45/100: train NMLL: 1.215, valid NMLL 1.432, valid RMSE of mean 0.799, valid RMSE of std 0.357\n",
      "Iteration 46/100: train NMLL: 1.193, valid NMLL 1.416, valid RMSE of mean 0.802, valid RMSE of std 0.355\n",
      "Iteration 47/100: train NMLL: 1.192, valid NMLL 1.425, valid RMSE of mean 0.802, valid RMSE of std 0.350\n",
      "Iteration 48/100: train NMLL: 1.189, valid NMLL 1.431, valid RMSE of mean 0.803, valid RMSE of std 0.343\n",
      "Iteration 49/100: train NMLL: 1.190, valid NMLL 1.439, valid RMSE of mean 0.803, valid RMSE of std 0.341\n",
      "Iteration 50/100: train NMLL: 1.182, valid NMLL 1.440, valid RMSE of mean 0.802, valid RMSE of std 0.337\n",
      "Iteration 51/100: train NMLL: 1.181, valid NMLL 1.449, valid RMSE of mean 0.802, valid RMSE of std 0.332\n",
      "Iteration 52/100: train NMLL: 1.169, valid NMLL 1.433, valid RMSE of mean 0.813, valid RMSE of std 0.336\n",
      "Iteration 53/100: train NMLL: 1.167, valid NMLL 1.420, valid RMSE of mean 0.822, valid RMSE of std 0.342\n",
      "Iteration 54/100: train NMLL: 1.150, valid NMLL 1.412, valid RMSE of mean 0.823, valid RMSE of std 0.338\n",
      "Iteration 55/100: train NMLL: 1.149, valid NMLL 1.421, valid RMSE of mean 0.823, valid RMSE of std 0.334\n",
      "Iteration 56/100: train NMLL: 1.148, valid NMLL 1.429, valid RMSE of mean 0.824, valid RMSE of std 0.329\n",
      "Iteration 57/100: train NMLL: 1.132, valid NMLL 1.421, valid RMSE of mean 0.825, valid RMSE of std 0.326\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 58/100: train NMLL: 1.131, valid NMLL 1.428, valid RMSE of mean 0.825, valid RMSE of std 0.323\n",
      "Iteration 59/100: train NMLL: 1.125, valid NMLL 1.421, valid RMSE of mean 0.832, valid RMSE of std 0.324\n",
      "Iteration 60/100: train NMLL: 1.125, valid NMLL 1.429, valid RMSE of mean 0.832, valid RMSE of std 0.320\n",
      "Iteration 61/100: train NMLL: 1.107, valid NMLL 1.416, valid RMSE of mean 0.835, valid RMSE of std 0.318\n",
      "Iteration 62/100: train NMLL: 1.106, valid NMLL 1.424, valid RMSE of mean 0.835, valid RMSE of std 0.314\n",
      "Iteration 63/100: train NMLL: 1.096, valid NMLL 1.414, valid RMSE of mean 0.844, valid RMSE of std 0.316\n",
      "Iteration 64/100: train NMLL: 1.101, valid NMLL 1.417, valid RMSE of mean 0.844, valid RMSE of std 0.318\n",
      "Iteration 65/100: train NMLL: 1.095, valid NMLL 1.410, valid RMSE of mean 0.851, valid RMSE of std 0.320\n",
      "Iteration 66/100: train NMLL: 1.085, valid NMLL 1.409, valid RMSE of mean 0.851, valid RMSE of std 0.316\n",
      "Iteration 67/100: train NMLL: 1.088, valid NMLL 1.411, valid RMSE of mean 0.850, valid RMSE of std 0.316\n",
      "Iteration 68/100: train NMLL: 1.081, valid NMLL 1.414, valid RMSE of mean 0.851, valid RMSE of std 0.313\n",
      "Iteration 69/100: train NMLL: 1.077, valid NMLL 1.416, valid RMSE of mean 0.850, valid RMSE of std 0.310\n",
      "Iteration 70/100: train NMLL: 1.079, valid NMLL 1.421, valid RMSE of mean 0.850, valid RMSE of std 0.309\n",
      "Iteration 71/100: train NMLL: 1.074, valid NMLL 1.424, valid RMSE of mean 0.852, valid RMSE of std 0.306\n",
      "Iteration 72/100: train NMLL: 1.073, valid NMLL 1.432, valid RMSE of mean 0.852, valid RMSE of std 0.303\n",
      "Iteration 73/100: train NMLL: 1.067, valid NMLL 1.433, valid RMSE of mean 0.851, valid RMSE of std 0.300\n",
      "Iteration 74/100: train NMLL: 1.067, valid NMLL 1.439, valid RMSE of mean 0.851, valid RMSE of std 0.298\n",
      "Iteration 75/100: train NMLL: 1.060, valid NMLL 1.439, valid RMSE of mean 0.855, valid RMSE of std 0.296\n",
      "Iteration 76/100: train NMLL: 1.060, valid NMLL 1.445, valid RMSE of mean 0.855, valid RMSE of std 0.293\n",
      "Iteration 77/100: train NMLL: 1.053, valid NMLL 1.447, valid RMSE of mean 0.857, valid RMSE of std 0.290\n",
      "Iteration 78/100: train NMLL: 1.046, valid NMLL 1.448, valid RMSE of mean 0.857, valid RMSE of std 0.288\n",
      "Iteration 79/100: train NMLL: 1.045, valid NMLL 1.456, valid RMSE of mean 0.857, valid RMSE of std 0.285\n",
      "Iteration 80/100: train NMLL: 1.045, valid NMLL 1.461, valid RMSE of mean 0.857, valid RMSE of std 0.283\n",
      "Iteration 81/100: train NMLL: 1.040, valid NMLL 1.455, valid RMSE of mean 0.863, valid RMSE of std 0.284\n",
      "Iteration 82/100: train NMLL: 1.035, valid NMLL 1.457, valid RMSE of mean 0.862, valid RMSE of std 0.282\n",
      "Iteration 83/100: train NMLL: 1.027, valid NMLL 1.450, valid RMSE of mean 0.869, valid RMSE of std 0.283\n",
      "Iteration 84/100: train NMLL: 1.028, valid NMLL 1.457, valid RMSE of mean 0.870, valid RMSE of std 0.281\n",
      "Iteration 85/100: train NMLL: 1.027, valid NMLL 1.463, valid RMSE of mean 0.870, valid RMSE of std 0.279\n",
      "Iteration 86/100: train NMLL: 1.022, valid NMLL 1.464, valid RMSE of mean 0.873, valid RMSE of std 0.277\n",
      "Iteration 87/100: train NMLL: 1.021, valid NMLL 1.469, valid RMSE of mean 0.871, valid RMSE of std 0.275\n",
      "Iteration 88/100: train NMLL: 1.008, valid NMLL 1.461, valid RMSE of mean 0.872, valid RMSE of std 0.274\n",
      "Iteration 89/100: train NMLL: 1.007, valid NMLL 1.468, valid RMSE of mean 0.872, valid RMSE of std 0.272\n",
      "Iteration 90/100: train NMLL: 1.010, valid NMLL 1.469, valid RMSE of mean 0.874, valid RMSE of std 0.273\n",
      "Iteration 91/100: train NMLL: 1.006, valid NMLL 1.473, valid RMSE of mean 0.875, valid RMSE of std 0.270\n",
      "Iteration 92/100: train NMLL: 0.995, valid NMLL 1.469, valid RMSE of mean 0.876, valid RMSE of std 0.268\n",
      "Iteration 93/100: train NMLL: 0.988, valid NMLL 1.470, valid RMSE of mean 0.879, valid RMSE of std 0.267\n",
      "Iteration 94/100: train NMLL: 0.988, valid NMLL 1.476, valid RMSE of mean 0.878, valid RMSE of std 0.265\n",
      "Iteration 95/100: train NMLL: 0.995, valid NMLL 1.470, valid RMSE of mean 0.881, valid RMSE of std 0.270\n",
      "Iteration 96/100: train NMLL: 0.991, valid NMLL 1.474, valid RMSE of mean 0.881, valid RMSE of std 0.267\n",
      "Iteration 97/100: train NMLL: 0.985, valid NMLL 1.476, valid RMSE of mean 0.884, valid RMSE of std 0.265\n",
      "Iteration 98/100: train NMLL: 0.990, valid NMLL 1.468, valid RMSE of mean 0.887, valid RMSE of std 0.270\n",
      "Iteration 99/100: train NMLL: 0.997, valid NMLL 1.470, valid RMSE of mean 0.884, valid RMSE of std 0.272\n",
      "Iteration 100/100: train NMLL: 0.992, valid NMLL 1.473, valid RMSE of mean 0.885, valid RMSE of std 0.270\n",
      "Repetition 2 took 51.807761907577515 sec.\n",
      "\n",
      "Iteration 1/100: train NMLL: 1.199, valid NMLL 0.462, valid RMSE of mean 0.836, valid RMSE of std 0.600\n",
      "Iteration 2/100: train NMLL: 1.232, valid NMLL 0.460, valid RMSE of mean 0.892, valid RMSE of std 0.544\n",
      "Iteration 3/100: train NMLL: 1.270, valid NMLL 0.453, valid RMSE of mean 0.795, valid RMSE of std 0.490\n",
      "Iteration 4/100: train NMLL: 1.402, valid NMLL 1.329, valid RMSE of mean 0.711, valid RMSE of std 0.712\n",
      "Iteration 5/100: train NMLL: 1.402, valid NMLL 1.316, valid RMSE of mean 0.710, valid RMSE of std 0.731\n",
      "Iteration 6/100: train NMLL: 1.390, valid NMLL 1.301, valid RMSE of mean 0.732, valid RMSE of std 0.707\n",
      "Iteration 7/100: train NMLL: 1.394, valid NMLL 1.315, valid RMSE of mean 0.737, valid RMSE of std 0.683\n",
      "Iteration 8/100: train NMLL: 1.401, valid NMLL 1.337, valid RMSE of mean 0.721, valid RMSE of std 0.671\n",
      "Iteration 9/100: train NMLL: 1.383, valid NMLL 1.317, valid RMSE of mean 0.746, valid RMSE of std 0.654\n",
      "Iteration 10/100: train NMLL: 1.383, valid NMLL 1.329, valid RMSE of mean 0.748, valid RMSE of std 0.632\n",
      "Iteration 11/100: train NMLL: 1.384, valid NMLL 1.342, valid RMSE of mean 0.747, valid RMSE of std 0.611\n",
      "Iteration 12/100: train NMLL: 1.384, valid NMLL 1.353, valid RMSE of mean 0.751, valid RMSE of std 0.591\n",
      "Iteration 13/100: train NMLL: 1.385, valid NMLL 1.364, valid RMSE of mean 0.750, valid RMSE of std 0.574\n",
      "Iteration 14/100: train NMLL: 1.364, valid NMLL 1.351, valid RMSE of mean 0.766, valid RMSE of std 0.557\n",
      "Iteration 15/100: train NMLL: 1.363, valid NMLL 1.362, valid RMSE of mean 0.766, valid RMSE of std 0.542\n",
      "Iteration 16/100: train NMLL: 1.378, valid NMLL 1.378, valid RMSE of mean 0.755, valid RMSE of std 0.556\n",
      "Iteration 17/100: train NMLL: 1.361, valid NMLL 1.370, valid RMSE of mean 0.767, valid RMSE of std 0.542\n",
      "Iteration 18/100: train NMLL: 1.361, valid NMLL 1.381, valid RMSE of mean 0.770, valid RMSE of std 0.527\n",
      "Iteration 19/100: train NMLL: 1.365, valid NMLL 1.393, valid RMSE of mean 0.761, valid RMSE of std 0.519\n",
      "Iteration 20/100: train NMLL: 1.359, valid NMLL 1.399, valid RMSE of mean 0.762, valid RMSE of std 0.506\n",
      "Iteration 21/100: train NMLL: 0.905, valid NMLL 0.194, valid RMSE of mean 0.284, valid RMSE of std 0.260\n",
      "Iteration 22/100: train NMLL: 1.382, valid NMLL 1.394, valid RMSE of mean 0.747, valid RMSE of std 0.560\n",
      "Iteration 23/100: train NMLL: 1.383, valid NMLL 1.403, valid RMSE of mean 0.748, valid RMSE of std 0.548\n",
      "Iteration 24/100: train NMLL: 1.371, valid NMLL 1.398, valid RMSE of mean 0.755, valid RMSE of std 0.537\n",
      "Iteration 25/100: train NMLL: 1.369, valid NMLL 1.404, valid RMSE of mean 0.755, valid RMSE of std 0.527\n",
      "Iteration 26/100: train NMLL: 1.375, valid NMLL 1.403, valid RMSE of mean 0.746, valid RMSE of std 0.536\n",
      "Iteration 27/100: train NMLL: 1.366, valid NMLL 1.402, valid RMSE of mean 0.750, valid RMSE of std 0.525\n",
      "Iteration 28/100: train NMLL: 1.368, valid NMLL 1.411, valid RMSE of mean 0.751, valid RMSE of std 0.517\n",
      "Iteration 29/100: train NMLL: 1.369, valid NMLL 1.408, valid RMSE of mean 0.747, valid RMSE of std 0.521\n",
      "Iteration 30/100: train NMLL: 1.383, valid NMLL 1.421, valid RMSE of mean 0.739, valid RMSE of std 0.530\n",
      "Iteration 31/100: train NMLL: 1.371, valid NMLL 1.414, valid RMSE of mean 0.745, valid RMSE of std 0.522\n",
      "Iteration 32/100: train NMLL: 1.371, valid NMLL 1.421, valid RMSE of mean 0.745, valid RMSE of std 0.513\n",
      "Iteration 33/100: train NMLL: 1.371, valid NMLL 1.427, valid RMSE of mean 0.744, valid RMSE of std 0.505\n",
      "Iteration 34/100: train NMLL: 0.722, valid NMLL 0.172, valid RMSE of mean 0.191, valid RMSE of std 0.165\n",
      "Iteration 35/100: train NMLL: 1.391, valid NMLL 1.440, valid RMSE of mean 0.730, valid RMSE of std 0.513\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 36/100: train NMLL: 1.389, valid NMLL 1.449, valid RMSE of mean 0.738, valid RMSE of std 0.515\n",
      "Iteration 37/100: train NMLL: 1.388, valid NMLL 1.453, valid RMSE of mean 0.737, valid RMSE of std 0.508\n",
      "Iteration 38/100: train NMLL: 1.389, valid NMLL 1.460, valid RMSE of mean 0.737, valid RMSE of std 0.501\n",
      "Iteration 39/100: train NMLL: 1.375, valid NMLL 1.445, valid RMSE of mean 0.743, valid RMSE of std 0.499\n",
      "Iteration 40/100: train NMLL: 1.374, valid NMLL 1.450, valid RMSE of mean 0.743, valid RMSE of std 0.492\n",
      "Iteration 41/100: train NMLL: 1.372, valid NMLL 1.448, valid RMSE of mean 0.738, valid RMSE of std 0.488\n",
      "Iteration 42/100: train NMLL: 0.699, valid NMLL 0.215, valid RMSE of mean 0.169, valid RMSE of std 0.092\n",
      "Iteration 43/100: train NMLL: 1.364, valid NMLL 1.439, valid RMSE of mean 0.737, valid RMSE of std 0.485\n",
      "Iteration 44/100: train NMLL: 1.362, valid NMLL 1.444, valid RMSE of mean 0.745, valid RMSE of std 0.485\n",
      "Iteration 45/100: train NMLL: 1.350, valid NMLL 1.437, valid RMSE of mean 0.749, valid RMSE of std 0.480\n",
      "Iteration 46/100: train NMLL: 1.354, valid NMLL 1.441, valid RMSE of mean 0.745, valid RMSE of std 0.477\n",
      "Iteration 47/100: train NMLL: 1.351, valid NMLL 1.442, valid RMSE of mean 0.746, valid RMSE of std 0.475\n",
      "Iteration 48/100: train NMLL: 1.351, valid NMLL 1.448, valid RMSE of mean 0.748, valid RMSE of std 0.469\n",
      "Iteration 49/100: train NMLL: 1.349, valid NMLL 1.453, valid RMSE of mean 0.748, valid RMSE of std 0.463\n",
      "Iteration 50/100: train NMLL: 1.340, valid NMLL 1.450, valid RMSE of mean 0.749, valid RMSE of std 0.457\n",
      "Iteration 51/100: train NMLL: 1.334, valid NMLL 1.445, valid RMSE of mean 0.752, valid RMSE of std 0.456\n",
      "Iteration 52/100: train NMLL: 1.333, valid NMLL 1.449, valid RMSE of mean 0.752, valid RMSE of std 0.450\n",
      "Iteration 53/100: train NMLL: 1.323, valid NMLL 1.444, valid RMSE of mean 0.752, valid RMSE of std 0.445\n",
      "Iteration 54/100: train NMLL: 1.320, valid NMLL 1.448, valid RMSE of mean 0.755, valid RMSE of std 0.440\n",
      "Iteration 55/100: train NMLL: 1.317, valid NMLL 1.448, valid RMSE of mean 0.754, valid RMSE of std 0.438\n",
      "Iteration 56/100: train NMLL: 1.317, valid NMLL 1.449, valid RMSE of mean 0.750, valid RMSE of std 0.434\n",
      "Iteration 57/100: train NMLL: 1.314, valid NMLL 1.450, valid RMSE of mean 0.750, valid RMSE of std 0.429\n",
      "Iteration 58/100: train NMLL: 1.311, valid NMLL 1.454, valid RMSE of mean 0.756, valid RMSE of std 0.427\n",
      "Iteration 59/100: train NMLL: 1.304, valid NMLL 1.453, valid RMSE of mean 0.757, valid RMSE of std 0.423\n",
      "Iteration 60/100: train NMLL: 1.302, valid NMLL 1.457, valid RMSE of mean 0.757, valid RMSE of std 0.418\n",
      "Iteration 61/100: train NMLL: 1.300, valid NMLL 1.461, valid RMSE of mean 0.757, valid RMSE of std 0.414\n",
      "Iteration 62/100: train NMLL: 1.292, valid NMLL 1.459, valid RMSE of mean 0.758, valid RMSE of std 0.409\n",
      "Iteration 63/100: train NMLL: 0.582, valid NMLL 0.230, valid RMSE of mean 0.121, valid RMSE of std 0.045\n",
      "Iteration 64/100: train NMLL: 1.310, valid NMLL 1.447, valid RMSE of mean 0.744, valid RMSE of std 0.428\n",
      "Iteration 65/100: train NMLL: 1.307, valid NMLL 1.447, valid RMSE of mean 0.746, valid RMSE of std 0.427\n",
      "Iteration 66/100: train NMLL: 1.309, valid NMLL 1.453, valid RMSE of mean 0.744, valid RMSE of std 0.425\n",
      "Iteration 67/100: train NMLL: 1.305, valid NMLL 1.452, valid RMSE of mean 0.747, valid RMSE of std 0.423\n",
      "Iteration 68/100: train NMLL: 1.302, valid NMLL 1.452, valid RMSE of mean 0.748, valid RMSE of std 0.420\n",
      "Iteration 69/100: train NMLL: 1.302, valid NMLL 1.455, valid RMSE of mean 0.752, valid RMSE of std 0.419\n",
      "Iteration 70/100: train NMLL: 1.301, valid NMLL 1.460, valid RMSE of mean 0.752, valid RMSE of std 0.415\n",
      "Iteration 71/100: train NMLL: 1.295, valid NMLL 1.460, valid RMSE of mean 0.752, valid RMSE of std 0.411\n",
      "Iteration 72/100: train NMLL: 1.294, valid NMLL 1.464, valid RMSE of mean 0.752, valid RMSE of std 0.407\n",
      "Iteration 73/100: train NMLL: 1.290, valid NMLL 1.459, valid RMSE of mean 0.755, valid RMSE of std 0.407\n",
      "Iteration 74/100: train NMLL: 1.283, valid NMLL 1.458, valid RMSE of mean 0.756, valid RMSE of std 0.403\n",
      "Iteration 75/100: train NMLL: 1.283, valid NMLL 1.457, valid RMSE of mean 0.753, valid RMSE of std 0.403\n",
      "Iteration 76/100: train NMLL: 1.279, valid NMLL 1.456, valid RMSE of mean 0.756, valid RMSE of std 0.401\n",
      "Iteration 77/100: train NMLL: 1.274, valid NMLL 1.452, valid RMSE of mean 0.759, valid RMSE of std 0.402\n",
      "Iteration 78/100: train NMLL: 1.270, valid NMLL 1.450, valid RMSE of mean 0.763, valid RMSE of std 0.400\n",
      "Iteration 79/100: train NMLL: 1.270, valid NMLL 1.455, valid RMSE of mean 0.763, valid RMSE of std 0.396\n",
      "Iteration 80/100: train NMLL: 1.263, valid NMLL 1.453, valid RMSE of mean 0.763, valid RMSE of std 0.393\n",
      "Iteration 81/100: train NMLL: 1.263, valid NMLL 1.458, valid RMSE of mean 0.763, valid RMSE of std 0.390\n",
      "Iteration 82/100: train NMLL: 1.263, valid NMLL 1.461, valid RMSE of mean 0.765, valid RMSE of std 0.389\n",
      "Iteration 83/100: train NMLL: 1.262, valid NMLL 1.464, valid RMSE of mean 0.764, valid RMSE of std 0.386\n",
      "Iteration 84/100: train NMLL: 1.262, valid NMLL 1.469, valid RMSE of mean 0.764, valid RMSE of std 0.383\n",
      "Iteration 85/100: train NMLL: 1.254, valid NMLL 1.466, valid RMSE of mean 0.765, valid RMSE of std 0.380\n",
      "Iteration 86/100: train NMLL: 1.252, valid NMLL 1.469, valid RMSE of mean 0.765, valid RMSE of std 0.377\n",
      "Iteration 87/100: train NMLL: 1.251, valid NMLL 1.473, valid RMSE of mean 0.765, valid RMSE of std 0.374\n",
      "Iteration 88/100: train NMLL: 1.251, valid NMLL 1.476, valid RMSE of mean 0.765, valid RMSE of std 0.371\n",
      "Iteration 89/100: train NMLL: 1.246, valid NMLL 1.475, valid RMSE of mean 0.767, valid RMSE of std 0.370\n",
      "Iteration 90/100: train NMLL: 1.238, valid NMLL 1.472, valid RMSE of mean 0.768, valid RMSE of std 0.367\n",
      "Iteration 91/100: train NMLL: 1.237, valid NMLL 1.475, valid RMSE of mean 0.768, valid RMSE of std 0.364\n",
      "Iteration 92/100: train NMLL: 1.237, valid NMLL 1.479, valid RMSE of mean 0.768, valid RMSE of std 0.361\n",
      "Iteration 93/100: train NMLL: 1.228, valid NMLL 1.475, valid RMSE of mean 0.769, valid RMSE of std 0.359\n",
      "Iteration 94/100: train NMLL: 1.224, valid NMLL 1.468, valid RMSE of mean 0.773, valid RMSE of std 0.362\n",
      "Iteration 95/100: train NMLL: 1.224, valid NMLL 1.472, valid RMSE of mean 0.774, valid RMSE of std 0.359\n",
      "Iteration 96/100: train NMLL: 1.223, valid NMLL 1.473, valid RMSE of mean 0.771, valid RMSE of std 0.358\n",
      "Iteration 97/100: train NMLL: 1.219, valid NMLL 1.474, valid RMSE of mean 0.775, valid RMSE of std 0.356\n",
      "Iteration 98/100: train NMLL: 1.212, valid NMLL 1.472, valid RMSE of mean 0.776, valid RMSE of std 0.353\n",
      "Iteration 99/100: train NMLL: 1.208, valid NMLL 1.467, valid RMSE of mean 0.780, valid RMSE of std 0.354\n",
      "Iteration 100/100: train NMLL: 1.208, valid NMLL 1.471, valid RMSE of mean 0.780, valid RMSE of std 0.352\n",
      "Repetition 3 took 25.948806285858154 sec.\n",
      "\n",
      "Iteration 1/100: train NMLL: 1.393, valid NMLL 1.497, valid RMSE of mean 0.738, valid RMSE of std 0.434\n",
      "Iteration 2/100: train NMLL: 1.397, valid NMLL 1.529, valid RMSE of mean 0.732, valid RMSE of std 0.410\n",
      "Iteration 3/100: train NMLL: 1.400, valid NMLL 1.517, valid RMSE of mean 0.719, valid RMSE of std 0.419\n",
      "Iteration 4/100: train NMLL: 1.402, valid NMLL 1.548, valid RMSE of mean 0.717, valid RMSE of std 0.398\n",
      "Iteration 5/100: train NMLL: 1.382, valid NMLL 1.427, valid RMSE of mean 0.781, valid RMSE of std 0.426\n",
      "Iteration 6/100: train NMLL: 1.358, valid NMLL 1.434, valid RMSE of mean 0.800, valid RMSE of std 0.398\n",
      "Iteration 7/100: train NMLL: 1.407, valid NMLL 1.466, valid RMSE of mean 0.709, valid RMSE of std 0.490\n",
      "Iteration 8/100: train NMLL: 1.408, valid NMLL 1.486, valid RMSE of mean 0.708, valid RMSE of std 0.471\n",
      "Iteration 9/100: train NMLL: 1.375, valid NMLL 1.384, valid RMSE of mean 0.754, valid RMSE of std 0.467\n",
      "Iteration 10/100: train NMLL: 1.410, valid NMLL 1.461, valid RMSE of mean 0.720, valid RMSE of std 0.523\n",
      "Iteration 11/100: train NMLL: 1.405, valid NMLL 1.432, valid RMSE of mean 0.720, valid RMSE of std 0.491\n",
      "Iteration 12/100: train NMLL: 1.401, valid NMLL 1.419, valid RMSE of mean 0.722, valid RMSE of std 0.501\n",
      "Iteration 13/100: train NMLL: 1.403, valid NMLL 1.441, valid RMSE of mean 0.719, valid RMSE of std 0.504\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 14/100: train NMLL: 1.402, valid NMLL 1.455, valid RMSE of mean 0.720, valid RMSE of std 0.488\n",
      "Iteration 15/100: train NMLL: 1.381, valid NMLL 1.435, valid RMSE of mean 0.730, valid RMSE of std 0.473\n",
      "Iteration 16/100: train NMLL: 1.367, valid NMLL 1.419, valid RMSE of mean 0.740, valid RMSE of std 0.471\n",
      "Iteration 17/100: train NMLL: 1.354, valid NMLL 1.400, valid RMSE of mean 0.753, valid RMSE of std 0.478\n",
      "Iteration 18/100: train NMLL: 1.318, valid NMLL 1.362, valid RMSE of mean 0.767, valid RMSE of std 0.475\n",
      "Iteration 19/100: train NMLL: 1.313, valid NMLL 1.351, valid RMSE of mean 0.771, valid RMSE of std 0.473\n",
      "Iteration 20/100: train NMLL: 1.317, valid NMLL 1.366, valid RMSE of mean 0.767, valid RMSE of std 0.465\n",
      "Iteration 21/100: train NMLL: 1.307, valid NMLL 1.370, valid RMSE of mean 0.771, valid RMSE of std 0.452\n",
      "Iteration 22/100: train NMLL: 1.306, valid NMLL 1.381, valid RMSE of mean 0.772, valid RMSE of std 0.441\n",
      "Iteration 23/100: train NMLL: 1.310, valid NMLL 1.382, valid RMSE of mean 0.775, valid RMSE of std 0.452\n",
      "Iteration 24/100: train NMLL: 1.290, valid NMLL 1.376, valid RMSE of mean 0.778, valid RMSE of std 0.440\n",
      "Iteration 25/100: train NMLL: 1.288, valid NMLL 1.386, valid RMSE of mean 0.778, valid RMSE of std 0.430\n",
      "Iteration 26/100: train NMLL: 1.278, valid NMLL 1.385, valid RMSE of mean 0.785, valid RMSE of std 0.422\n",
      "Iteration 27/100: train NMLL: 1.276, valid NMLL 1.394, valid RMSE of mean 0.780, valid RMSE of std 0.417\n",
      "Iteration 28/100: train NMLL: 1.275, valid NMLL 1.405, valid RMSE of mean 0.781, valid RMSE of std 0.408\n",
      "Iteration 29/100: train NMLL: 1.272, valid NMLL 1.394, valid RMSE of mean 0.786, valid RMSE of std 0.414\n",
      "Iteration 30/100: train NMLL: 1.259, valid NMLL 1.390, valid RMSE of mean 0.794, valid RMSE of std 0.406\n",
      "Iteration 31/100: train NMLL: 1.252, valid NMLL 1.391, valid RMSE of mean 0.799, valid RMSE of std 0.401\n",
      "Iteration 32/100: train NMLL: 1.258, valid NMLL 1.391, valid RMSE of mean 0.800, valid RMSE of std 0.408\n",
      "Iteration 33/100: train NMLL: 1.232, valid NMLL 1.374, valid RMSE of mean 0.806, valid RMSE of std 0.403\n",
      "Iteration 34/100: train NMLL: 1.232, valid NMLL 1.384, valid RMSE of mean 0.807, valid RMSE of std 0.397\n",
      "Iteration 35/100: train NMLL: 1.216, valid NMLL 1.379, valid RMSE of mean 0.808, valid RMSE of std 0.389\n",
      "Iteration 36/100: train NMLL: 1.205, valid NMLL 1.374, valid RMSE of mean 0.816, valid RMSE of std 0.387\n",
      "Iteration 37/100: train NMLL: 1.205, valid NMLL 1.382, valid RMSE of mean 0.816, valid RMSE of std 0.382\n",
      "Iteration 38/100: train NMLL: 1.206, valid NMLL 1.382, valid RMSE of mean 0.817, valid RMSE of std 0.382\n",
      "Iteration 39/100: train NMLL: 1.193, valid NMLL 1.377, valid RMSE of mean 0.825, valid RMSE of std 0.377\n",
      "Iteration 40/100: train NMLL: 1.179, valid NMLL 1.375, valid RMSE of mean 0.825, valid RMSE of std 0.369\n",
      "Iteration 41/100: train NMLL: 1.171, valid NMLL 1.373, valid RMSE of mean 0.831, valid RMSE of std 0.368\n",
      "Iteration 42/100: train NMLL: 1.171, valid NMLL 1.382, valid RMSE of mean 0.832, valid RMSE of std 0.363\n",
      "Iteration 43/100: train NMLL: 1.176, valid NMLL 1.386, valid RMSE of mean 0.832, valid RMSE of std 0.365\n",
      "Iteration 44/100: train NMLL: 1.159, valid NMLL 1.381, valid RMSE of mean 0.834, valid RMSE of std 0.359\n",
      "Iteration 45/100: train NMLL: 1.159, valid NMLL 1.388, valid RMSE of mean 0.833, valid RMSE of std 0.356\n",
      "Iteration 46/100: train NMLL: 1.148, valid NMLL 1.385, valid RMSE of mean 0.838, valid RMSE of std 0.351\n",
      "Iteration 47/100: train NMLL: 1.140, valid NMLL 1.380, valid RMSE of mean 0.846, valid RMSE of std 0.351\n",
      "Iteration 48/100: train NMLL: 1.127, valid NMLL 1.379, valid RMSE of mean 0.846, valid RMSE of std 0.345\n",
      "Iteration 49/100: train NMLL: 1.127, valid NMLL 1.387, valid RMSE of mean 0.846, valid RMSE of std 0.342\n",
      "Iteration 50/100: train NMLL: 1.127, valid NMLL 1.394, valid RMSE of mean 0.846, valid RMSE of std 0.337\n",
      "Iteration 51/100: train NMLL: 1.118, valid NMLL 1.395, valid RMSE of mean 0.850, valid RMSE of std 0.333\n",
      "Iteration 52/100: train NMLL: 1.103, valid NMLL 1.391, valid RMSE of mean 0.851, valid RMSE of std 0.329\n",
      "Iteration 53/100: train NMLL: 1.102, valid NMLL 1.400, valid RMSE of mean 0.851, valid RMSE of std 0.324\n",
      "Iteration 54/100: train NMLL: 1.101, valid NMLL 1.409, valid RMSE of mean 0.851, valid RMSE of std 0.319\n",
      "Iteration 55/100: train NMLL: 1.095, valid NMLL 1.413, valid RMSE of mean 0.851, valid RMSE of std 0.315\n",
      "Iteration 56/100: train NMLL: 1.084, valid NMLL 1.412, valid RMSE of mean 0.851, valid RMSE of std 0.311\n",
      "Iteration 57/100: train NMLL: 1.083, valid NMLL 1.421, valid RMSE of mean 0.851, valid RMSE of std 0.307\n",
      "Iteration 58/100: train NMLL: 1.075, valid NMLL 1.423, valid RMSE of mean 0.855, valid RMSE of std 0.304\n",
      "Iteration 59/100: train NMLL: 1.081, valid NMLL 1.422, valid RMSE of mean 0.857, valid RMSE of std 0.307\n",
      "Iteration 60/100: train NMLL: 1.073, valid NMLL 1.425, valid RMSE of mean 0.858, valid RMSE of std 0.303\n",
      "Iteration 61/100: train NMLL: 1.062, valid NMLL 1.425, valid RMSE of mean 0.858, valid RMSE of std 0.299\n",
      "Iteration 62/100: train NMLL: 1.062, valid NMLL 1.434, valid RMSE of mean 0.858, valid RMSE of std 0.296\n",
      "Iteration 63/100: train NMLL: 1.055, valid NMLL 1.437, valid RMSE of mean 0.860, valid RMSE of std 0.292\n",
      "Iteration 64/100: train NMLL: 1.061, valid NMLL 1.434, valid RMSE of mean 0.863, valid RMSE of std 0.296\n",
      "Iteration 65/100: train NMLL: 1.053, valid NMLL 1.435, valid RMSE of mean 0.866, valid RMSE of std 0.294\n",
      "Iteration 66/100: train NMLL: 1.049, valid NMLL 1.438, valid RMSE of mean 0.865, valid RMSE of std 0.292\n",
      "Iteration 67/100: train NMLL: 1.049, valid NMLL 1.446, valid RMSE of mean 0.865, valid RMSE of std 0.289\n",
      "Iteration 68/100: train NMLL: 1.046, valid NMLL 1.452, valid RMSE of mean 0.864, valid RMSE of std 0.285\n",
      "Iteration 69/100: train NMLL: 1.045, valid NMLL 1.455, valid RMSE of mean 0.867, valid RMSE of std 0.285\n",
      "Iteration 70/100: train NMLL: 1.041, valid NMLL 1.460, valid RMSE of mean 0.866, valid RMSE of std 0.281\n",
      "Iteration 71/100: train NMLL: 1.039, valid NMLL 1.467, valid RMSE of mean 0.865, valid RMSE of std 0.278\n",
      "Iteration 72/100: train NMLL: 1.044, valid NMLL 1.457, valid RMSE of mean 0.871, valid RMSE of std 0.285\n",
      "Iteration 73/100: train NMLL: 1.044, valid NMLL 1.462, valid RMSE of mean 0.867, valid RMSE of std 0.283\n",
      "Iteration 74/100: train NMLL: 1.033, valid NMLL 1.461, valid RMSE of mean 0.868, valid RMSE of std 0.280\n",
      "Iteration 75/100: train NMLL: 1.032, valid NMLL 1.469, valid RMSE of mean 0.868, valid RMSE of std 0.277\n",
      "Iteration 76/100: train NMLL: 1.039, valid NMLL 1.473, valid RMSE of mean 0.864, valid RMSE of std 0.277\n",
      "Iteration 77/100: train NMLL: 0.492, valid NMLL 0.239, valid RMSE of mean 0.191, valid RMSE of std 0.114\n",
      "Iteration 78/100: train NMLL: 1.095, valid NMLL 1.440, valid RMSE of mean 0.854, valid RMSE of std 0.314\n",
      "Iteration 79/100: train NMLL: 1.095, valid NMLL 1.446, valid RMSE of mean 0.854, valid RMSE of std 0.311\n",
      "Iteration 80/100: train NMLL: 1.087, valid NMLL 1.446, valid RMSE of mean 0.854, valid RMSE of std 0.308\n",
      "Iteration 81/100: train NMLL: 1.083, valid NMLL 1.449, valid RMSE of mean 0.855, valid RMSE of std 0.305\n",
      "Iteration 82/100: train NMLL: 1.082, valid NMLL 1.456, valid RMSE of mean 0.855, valid RMSE of std 0.303\n",
      "Iteration 83/100: train NMLL: 1.077, valid NMLL 1.457, valid RMSE of mean 0.854, valid RMSE of std 0.300\n",
      "Iteration 84/100: train NMLL: 1.074, valid NMLL 1.462, valid RMSE of mean 0.854, valid RMSE of std 0.297\n",
      "Iteration 85/100: train NMLL: 1.072, valid NMLL 1.466, valid RMSE of mean 0.852, valid RMSE of std 0.294\n",
      "Iteration 86/100: train NMLL: 1.073, valid NMLL 1.473, valid RMSE of mean 0.853, valid RMSE of std 0.293\n",
      "Iteration 87/100: train NMLL: 1.073, valid NMLL 1.474, valid RMSE of mean 0.856, valid RMSE of std 0.293\n",
      "Iteration 88/100: train NMLL: 1.071, valid NMLL 1.479, valid RMSE of mean 0.855, valid RMSE of std 0.290\n",
      "Iteration 89/100: train NMLL: 1.060, valid NMLL 1.474, valid RMSE of mean 0.856, valid RMSE of std 0.288\n",
      "Iteration 90/100: train NMLL: 1.063, valid NMLL 1.478, valid RMSE of mean 0.852, valid RMSE of std 0.288\n",
      "Iteration 91/100: train NMLL: 1.063, valid NMLL 1.485, valid RMSE of mean 0.852, valid RMSE of std 0.286\n",
      "Iteration 92/100: train NMLL: 1.063, valid NMLL 1.486, valid RMSE of mean 0.855, valid RMSE of std 0.285\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 93/100: train NMLL: 1.052, valid NMLL 1.482, valid RMSE of mean 0.856, valid RMSE of std 0.284\n",
      "Iteration 94/100: train NMLL: 1.050, valid NMLL 1.486, valid RMSE of mean 0.856, valid RMSE of std 0.281\n",
      "Iteration 95/100: train NMLL: 1.050, valid NMLL 1.491, valid RMSE of mean 0.853, valid RMSE of std 0.279\n",
      "Iteration 96/100: train NMLL: 1.050, valid NMLL 1.498, valid RMSE of mean 0.854, valid RMSE of std 0.277\n",
      "Iteration 97/100: train NMLL: 1.053, valid NMLL 1.490, valid RMSE of mean 0.859, valid RMSE of std 0.282\n",
      "Iteration 98/100: train NMLL: 1.052, valid NMLL 1.495, valid RMSE of mean 0.858, valid RMSE of std 0.280\n",
      "Iteration 99/100: train NMLL: 1.042, valid NMLL 1.489, valid RMSE of mean 0.859, valid RMSE of std 0.279\n",
      "Iteration 100/100: train NMLL: 1.036, valid NMLL 1.488, valid RMSE of mean 0.863, valid RMSE of std 0.278\n",
      "Repetition 4 took 40.27078986167908 sec.\n",
      "\n",
      "Iteration 1/100: train NMLL: 1.393, valid NMLL 1.495, valid RMSE of mean 0.709, valid RMSE of std 0.417\n",
      "Iteration 2/100: train NMLL: 1.397, valid NMLL 1.494, valid RMSE of mean 0.710, valid RMSE of std 0.428\n",
      "Iteration 3/100: train NMLL: 1.399, valid NMLL 1.440, valid RMSE of mean 0.721, valid RMSE of std 0.469\n",
      "Iteration 4/100: train NMLL: 1.404, valid NMLL 1.473, valid RMSE of mean 0.722, valid RMSE of std 0.445\n",
      "Iteration 5/100: train NMLL: 1.405, valid NMLL 1.502, valid RMSE of mean 0.722, valid RMSE of std 0.422\n",
      "Iteration 6/100: train NMLL: 1.403, valid NMLL 1.523, valid RMSE of mean 0.728, valid RMSE of std 0.404\n",
      "Iteration 7/100: train NMLL: 1.362, valid NMLL 1.479, valid RMSE of mean 0.751, valid RMSE of std 0.392\n",
      "Iteration 8/100: train NMLL: 1.360, valid NMLL 1.509, valid RMSE of mean 0.752, valid RMSE of std 0.373\n",
      "Iteration 9/100: train NMLL: 1.369, valid NMLL 1.517, valid RMSE of mean 0.760, valid RMSE of std 0.380\n",
      "Iteration 10/100: train NMLL: 1.401, valid NMLL 1.535, valid RMSE of mean 0.759, valid RMSE of std 0.406\n",
      "Iteration 11/100: train NMLL: 1.381, valid NMLL 1.531, valid RMSE of mean 0.768, valid RMSE of std 0.389\n",
      "Iteration 12/100: train NMLL: 1.380, valid NMLL 1.554, valid RMSE of mean 0.769, valid RMSE of std 0.374\n",
      "Iteration 13/100: train NMLL: 1.375, valid NMLL 1.522, valid RMSE of mean 0.760, valid RMSE of std 0.383\n",
      "Iteration 14/100: train NMLL: 1.378, valid NMLL 1.541, valid RMSE of mean 0.764, valid RMSE of std 0.372\n",
      "Iteration 15/100: train NMLL: 1.376, valid NMLL 1.562, valid RMSE of mean 0.766, valid RMSE of std 0.359\n",
      "Iteration 16/100: train NMLL: 1.390, valid NMLL 1.583, valid RMSE of mean 0.765, valid RMSE of std 0.361\n",
      "Iteration 17/100: train NMLL: 1.388, valid NMLL 1.599, valid RMSE of mean 0.763, valid RMSE of std 0.350\n",
      "Iteration 18/100: train NMLL: 1.391, valid NMLL 1.557, valid RMSE of mean 0.749, valid RMSE of std 0.384\n",
      "Iteration 19/100: train NMLL: 1.366, valid NMLL 1.543, valid RMSE of mean 0.758, valid RMSE of std 0.372\n",
      "Iteration 20/100: train NMLL: 1.387, valid NMLL 1.552, valid RMSE of mean 0.761, valid RMSE of std 0.386\n",
      "Iteration 21/100: train NMLL: 1.384, valid NMLL 1.560, valid RMSE of mean 0.768, valid RMSE of std 0.387\n",
      "Iteration 22/100: train NMLL: 1.382, valid NMLL 1.573, valid RMSE of mean 0.768, valid RMSE of std 0.377\n",
      "Iteration 23/100: train NMLL: 1.365, valid NMLL 1.569, valid RMSE of mean 0.773, valid RMSE of std 0.367\n",
      "Iteration 24/100: train NMLL: 1.355, valid NMLL 1.544, valid RMSE of mean 0.770, valid RMSE of std 0.377\n",
      "Iteration 25/100: train NMLL: 1.353, valid NMLL 1.555, valid RMSE of mean 0.769, valid RMSE of std 0.368\n",
      "Iteration 26/100: train NMLL: 1.328, valid NMLL 1.531, valid RMSE of mean 0.783, valid RMSE of std 0.356\n",
      "Iteration 27/100: train NMLL: 1.351, valid NMLL 1.542, valid RMSE of mean 0.780, valid RMSE of std 0.379\n",
      "Iteration 28/100: train NMLL: 1.350, valid NMLL 1.554, valid RMSE of mean 0.780, valid RMSE of std 0.370\n",
      "Iteration 29/100: train NMLL: 0.805, valid NMLL 0.280, valid RMSE of mean 0.316, valid RMSE of std 0.138\n",
      "Iteration 30/100: train NMLL: 1.389, valid NMLL 1.538, valid RMSE of mean 0.756, valid RMSE of std 0.416\n",
      "Iteration 31/100: train NMLL: 1.381, valid NMLL 1.532, valid RMSE of mean 0.754, valid RMSE of std 0.412\n",
      "Iteration 32/100: train NMLL: 1.372, valid NMLL 1.534, valid RMSE of mean 0.756, valid RMSE of std 0.404\n",
      "Iteration 33/100: train NMLL: 1.373, valid NMLL 1.544, valid RMSE of mean 0.757, valid RMSE of std 0.397\n",
      "Iteration 34/100: train NMLL: 1.367, valid NMLL 1.517, valid RMSE of mean 0.751, valid RMSE of std 0.408\n",
      "Iteration 35/100: train NMLL: 1.363, valid NMLL 1.520, valid RMSE of mean 0.751, valid RMSE of std 0.403\n",
      "Iteration 36/100: train NMLL: 1.363, valid NMLL 1.530, valid RMSE of mean 0.753, valid RMSE of std 0.397\n",
      "Iteration 37/100: train NMLL: 1.354, valid NMLL 1.531, valid RMSE of mean 0.754, valid RMSE of std 0.390\n",
      "Iteration 38/100: train NMLL: 1.341, valid NMLL 1.498, valid RMSE of mean 0.757, valid RMSE of std 0.404\n",
      "Iteration 39/100: train NMLL: 1.341, valid NMLL 1.506, valid RMSE of mean 0.756, valid RMSE of std 0.398\n",
      "Iteration 40/100: train NMLL: 1.323, valid NMLL 1.492, valid RMSE of mean 0.762, valid RMSE of std 0.394\n",
      "Iteration 41/100: train NMLL: 1.322, valid NMLL 1.501, valid RMSE of mean 0.761, valid RMSE of std 0.387\n",
      "Iteration 42/100: train NMLL: 1.317, valid NMLL 1.476, valid RMSE of mean 0.763, valid RMSE of std 0.403\n",
      "Iteration 43/100: train NMLL: 1.309, valid NMLL 1.477, valid RMSE of mean 0.764, valid RMSE of std 0.397\n",
      "Iteration 44/100: train NMLL: 1.307, valid NMLL 1.463, valid RMSE of mean 0.762, valid RMSE of std 0.405\n",
      "Iteration 45/100: train NMLL: 1.303, valid NMLL 1.445, valid RMSE of mean 0.767, valid RMSE of std 0.417\n",
      "Iteration 46/100: train NMLL: 1.302, valid NMLL 1.452, valid RMSE of mean 0.768, valid RMSE of std 0.411\n",
      "Iteration 47/100: train NMLL: 1.299, valid NMLL 1.457, valid RMSE of mean 0.767, valid RMSE of std 0.405\n",
      "Iteration 48/100: train NMLL: 1.301, valid NMLL 1.462, valid RMSE of mean 0.770, valid RMSE of std 0.405\n",
      "Iteration 49/100: train NMLL: 1.291, valid NMLL 1.460, valid RMSE of mean 0.771, valid RMSE of std 0.399\n",
      "Iteration 50/100: train NMLL: 1.290, valid NMLL 1.467, valid RMSE of mean 0.772, valid RMSE of std 0.394\n",
      "Iteration 51/100: train NMLL: 1.283, valid NMLL 1.462, valid RMSE of mean 0.775, valid RMSE of std 0.392\n",
      "Iteration 52/100: train NMLL: 1.268, valid NMLL 1.454, valid RMSE of mean 0.778, valid RMSE of std 0.388\n",
      "Iteration 53/100: train NMLL: 1.268, valid NMLL 1.459, valid RMSE of mean 0.777, valid RMSE of std 0.384\n",
      "Iteration 54/100: train NMLL: 1.267, valid NMLL 1.459, valid RMSE of mean 0.776, valid RMSE of std 0.384\n",
      "Iteration 55/100: train NMLL: 1.257, valid NMLL 1.450, valid RMSE of mean 0.781, valid RMSE of std 0.383\n",
      "Iteration 56/100: train NMLL: 1.251, valid NMLL 1.452, valid RMSE of mean 0.781, valid RMSE of std 0.378\n",
      "Iteration 57/100: train NMLL: 1.250, valid NMLL 1.459, valid RMSE of mean 0.781, valid RMSE of std 0.373\n",
      "Iteration 58/100: train NMLL: 1.244, valid NMLL 1.447, valid RMSE of mean 0.786, valid RMSE of std 0.377\n",
      "Iteration 59/100: train NMLL: 1.243, valid NMLL 1.451, valid RMSE of mean 0.786, valid RMSE of std 0.375\n",
      "Iteration 60/100: train NMLL: 1.232, valid NMLL 1.447, valid RMSE of mean 0.787, valid RMSE of std 0.371\n",
      "Iteration 61/100: train NMLL: 0.436, valid NMLL 0.158, valid RMSE of mean 0.174, valid RMSE of std 0.055\n",
      "Iteration 62/100: train NMLL: 1.235, valid NMLL 1.434, valid RMSE of mean 0.788, valid RMSE of std 0.382\n",
      "Iteration 63/100: train NMLL: 1.234, valid NMLL 1.440, valid RMSE of mean 0.788, valid RMSE of std 0.378\n",
      "Iteration 64/100: train NMLL: 1.221, valid NMLL 1.433, valid RMSE of mean 0.790, valid RMSE of std 0.374\n",
      "Iteration 65/100: train NMLL: 1.222, valid NMLL 1.438, valid RMSE of mean 0.789, valid RMSE of std 0.372\n",
      "Iteration 66/100: train NMLL: 1.213, valid NMLL 1.434, valid RMSE of mean 0.793, valid RMSE of std 0.369\n",
      "Iteration 67/100: train NMLL: 1.206, valid NMLL 1.434, valid RMSE of mean 0.793, valid RMSE of std 0.365\n",
      "Iteration 68/100: train NMLL: 1.206, valid NMLL 1.440, valid RMSE of mean 0.794, valid RMSE of std 0.362\n",
      "Iteration 69/100: train NMLL: 1.199, valid NMLL 1.434, valid RMSE of mean 0.799, valid RMSE of std 0.362\n",
      "Iteration 70/100: train NMLL: 1.198, valid NMLL 1.440, valid RMSE of mean 0.799, valid RMSE of std 0.358\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 71/100: train NMLL: 1.187, valid NMLL 1.435, valid RMSE of mean 0.800, valid RMSE of std 0.354\n",
      "Iteration 72/100: train NMLL: 1.186, valid NMLL 1.441, valid RMSE of mean 0.800, valid RMSE of std 0.351\n",
      "Iteration 73/100: train NMLL: 1.179, valid NMLL 1.423, valid RMSE of mean 0.803, valid RMSE of std 0.355\n",
      "Iteration 74/100: train NMLL: 1.193, valid NMLL 1.425, valid RMSE of mean 0.793, valid RMSE of std 0.362\n",
      "Iteration 75/100: train NMLL: 0.364, valid NMLL 0.130, valid RMSE of mean 0.082, valid RMSE of std 0.024\n",
      "Iteration 76/100: train NMLL: 0.374, valid NMLL 0.138, valid RMSE of mean 0.094, valid RMSE of std 0.018\n",
      "Iteration 77/100: train NMLL: 0.380, valid NMLL 0.146, valid RMSE of mean 0.109, valid RMSE of std 0.014\n",
      "Iteration 78/100: train NMLL: 1.246, valid NMLL 1.422, valid RMSE of mean 0.775, valid RMSE of std 0.398\n",
      "Iteration 79/100: train NMLL: 0.366, valid NMLL 0.135, valid RMSE of mean 0.111, valid RMSE of std 0.014\n",
      "Iteration 80/100: train NMLL: 0.378, valid NMLL 0.146, valid RMSE of mean 0.121, valid RMSE of std 0.013\n",
      "Iteration 81/100: train NMLL: 1.270, valid NMLL 1.433, valid RMSE of mean 0.761, valid RMSE of std 0.408\n",
      "Iteration 82/100: train NMLL: 1.271, valid NMLL 1.437, valid RMSE of mean 0.760, valid RMSE of std 0.405\n",
      "Iteration 83/100: train NMLL: 1.271, valid NMLL 1.441, valid RMSE of mean 0.759, valid RMSE of std 0.402\n",
      "Iteration 84/100: train NMLL: 0.355, valid NMLL 0.149, valid RMSE of mean 0.120, valid RMSE of std 0.016\n",
      "Iteration 85/100: train NMLL: 0.373, valid NMLL 0.151, valid RMSE of mean 0.111, valid RMSE of std 0.013\n",
      "Iteration 86/100: train NMLL: 0.362, valid NMLL 0.145, valid RMSE of mean 0.110, valid RMSE of std 0.014\n",
      "Iteration 87/100: train NMLL: 0.370, valid NMLL 0.151, valid RMSE of mean 0.109, valid RMSE of std 0.013\n",
      "Iteration 88/100: train NMLL: 0.373, valid NMLL 0.154, valid RMSE of mean 0.100, valid RMSE of std 0.013\n",
      "Iteration 89/100: train NMLL: 0.386, valid NMLL 0.164, valid RMSE of mean 0.108, valid RMSE of std 0.011\n",
      "Iteration 90/100: train NMLL: 0.383, valid NMLL 0.160, valid RMSE of mean 0.109, valid RMSE of std 0.010\n",
      "Iteration 91/100: train NMLL: 0.385, valid NMLL 0.164, valid RMSE of mean 0.106, valid RMSE of std 0.010\n",
      "Iteration 92/100: train NMLL: 0.376, valid NMLL 0.156, valid RMSE of mean 0.108, valid RMSE of std 0.011\n",
      "Iteration 93/100: train NMLL: 0.368, valid NMLL 0.151, valid RMSE of mean 0.107, valid RMSE of std 0.012\n",
      "Iteration 94/100: train NMLL: 0.355, valid NMLL 0.143, valid RMSE of mean 0.106, valid RMSE of std 0.013\n",
      "Iteration 95/100: train NMLL: 0.375, valid NMLL 0.152, valid RMSE of mean 0.094, valid RMSE of std 0.009\n",
      "Iteration 96/100: train NMLL: 0.378, valid NMLL 0.157, valid RMSE of mean 0.091, valid RMSE of std 0.009\n",
      "Iteration 97/100: train NMLL: 0.387, valid NMLL 0.160, valid RMSE of mean 0.084, valid RMSE of std 0.008\n",
      "Iteration 98/100: train NMLL: 0.384, valid NMLL 0.162, valid RMSE of mean 0.083, valid RMSE of std 0.009\n",
      "Iteration 99/100: train NMLL: 0.395, valid NMLL 0.170, valid RMSE of mean 0.080, valid RMSE of std 0.007\n",
      "Iteration 100/100: train NMLL: 0.405, valid NMLL 0.170, valid RMSE of mean 0.076, valid RMSE of std 0.004\n",
      "Repetition 5 took 44.57719683647156 sec.\n",
      "\n",
      "The experiment took 203.06082487106323 sec.\n"
     ]
    }
   ],
   "source": [
    "tic_all = time.time()\n",
    "nmll_losses_baseline = []\n",
    "nmll_losses_valid_baseline = []\n",
    "rmse_losses_valid_baseline = []\n",
    "rmse_std_losses_valid_baseline = []\n",
    "lengthscale_baseline = []\n",
    "noise_baseline = []\n",
    "for rep in range(repetitions):\n",
    "\n",
    "    # Load data\n",
    "    search_space = get_search_space(simulator=args.simulator)\n",
    "\n",
    "    # We don't need the oracle labels since we just call the simulator, likewise, don't need pool_labeled\n",
    "    oracle_labels = None\n",
    "    pool_labeled = None\n",
    "\n",
    "    # We do need to sample a training set\n",
    "    train_x, train_y = sample_dataset_from_simulator(args, search_space, n_samples=args.initial_samples, seed=rep)\n",
    "    test_x, test_y = sample_dataset_from_simulator(args, search_space, n_samples=args.test_samples, seed=4242)\n",
    "\n",
    "    # A simulator where we can access the true mean and stddev\n",
    "    _, true_mean, true_std = oracle_simulator(args, torch.Tensor(search_space))\n",
    "    true_mean, true_std = torch.Tensor(true_mean), torch.Tensor(true_std)\n",
    "\n",
    "\n",
    "    # Remove any seed that may appear\n",
    "    np.random.seed()\n",
    "\n",
    "    # Active learning scheme\n",
    "    nmll_losses = []\n",
    "    nmll_losses_valid = []\n",
    "    rmse_losses_valid = []\n",
    "    rmse_std_losses_valid = []\n",
    "    lst_lengthscales = []\n",
    "    lst_noises = []\n",
    "    tic = time.time()\n",
    "\n",
    "    for i in range(args.active_learning_steps):\n",
    "\n",
    "        # Prepare data\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",
    "        test_x_trans = (test_x - min_x) / max_x\n",
    "        test_y_trans = (test_y - mu_y) / sigma_y\n",
    "        gp_train_loader = (train_x_trans, train_y_trans)\n",
    "        gp_test_loader = (test_x_trans, test_y_trans)\n",
    "\n",
    "        # Setup model\n",
    "        likelihood = gpytorch.likelihoods.GaussianLikelihood(\n",
    "                noise_constraint=gpytorch.constraints.GreaterThan(1e-6),\n",
    "                noise_prior=gpytorch.priors.LogNormalPrior(0, 1)\n",
    "            )\n",
    "        model = FancyGPWithPriors(train_x_trans, train_y_trans, likelihood)\n",
    "\n",
    "        # Fit model\n",
    "        mll = gpytorch.mlls.ExactMarginalLogLikelihood(model.likelihood, model)\n",
    "        nmll_loss, fit_losses = model.fit(gp_train_loader, args)\n",
    "        nmll_losses.append(nmll_loss)\n",
    "        lst_lengthscales.append(model.covar_module.base_kernel.lengthscale.item())\n",
    "        lst_noises.append(model.likelihood.noise.item())\n",
    "\n",
    "\n",
    "        # Make predictions on the test set\n",
    "        # Validate with: marginal log likelihood (MLL)\n",
    "        predict_output = model.predict(gp_test_loader)\n",
    "        predictions_mll = predict_output['predictions']\n",
    "        losses = compute_loss(args, gp_test_loader, predictions_mll, lst_metrics=['mll'], mll=mll)\n",
    "        nmll_losses_valid.append(losses['nmll'])\n",
    "\n",
    "        # Points of interest for querying\n",
    "        candidate_points = search_space\n",
    "\n",
    "        # Make predictions for validation, querying and plotting\n",
    "        # Make predictions on the search space\n",
    "        # Also predictions for PLOTTING and for QUERYING the next label\n",
    "        # Validation: RMSE(mean), RMSE(std)\n",
    "        # Get the unique values to query and transform them according to the input transformation\n",
    "        ss_unique = np.unique(search_space, axis=0)\n",
    "        pred_x = torch.Tensor(ss_unique)\n",
    "        pred_x_trans = (pred_x - min_x) / max_x\n",
    "        predict_output = model.predict(dataloader=(pred_x_trans, None))\n",
    "        predict_output_querying = predict_output\n",
    "\n",
    "        # Transform pred_x, mean and standard deviation back\n",
    "        pred_mean = predict_output['mean'] * sigma_y + mu_y\n",
    "        pred_std = predict_output['stddev'] * sigma_y\n",
    "        # Compute loses\n",
    "        losses = compute_loss(args, dataloader=(None, true_mean), predictions=pred_mean, lst_metrics=['rmse'])\n",
    "        rmse_losses_valid.append(losses['rmse'])\n",
    "        losses = compute_loss(args, dataloader=(None, true_std), predictions=pred_std, lst_metrics=['rmse'])\n",
    "        rmse_std_losses_valid.append(losses['rmse'])\n",
    "\n",
    "\n",
    "        # predicted standard deviation for each sample in the search space\n",
    "        pred_std = predict_output_querying['stddev']  \n",
    "        selection_array = pred_std**2\n",
    "\n",
    "        # Get the sequence of possible new data points\n",
    "        ss_unique = np.unique(candidate_points, axis=0)\n",
    "        new_points = ss_unique[torch.argsort(selection_array, descending=True)]\n",
    "\n",
    "        # Get query\n",
    "        new_y, _, _ = oracle_simulator(args, new_points[0])\n",
    "        pool_labeled = new_points\n",
    "\n",
    "\n",
    "        # Add point and label to train_x and train_y\n",
    "        if oracle_labels is None:\n",
    "            # Stupid if-statement due to missing batch size on 1d problems\n",
    "            if len(train_x.shape) > 1 and args.k_samples == 1 and args.repeat_sampling == 1:\n",
    "                new_x = np.array(pool_labeled).reshape(1,-1)\n",
    "            else:\n",
    "                new_x = np.repeat(pool_labeled[:args.k_samples], args.repeat_sampling, axis=0)\n",
    "            pool_labeled = None\n",
    "        else:\n",
    "            new_x = search_space[pool_labeled[-(args.k_samples * args.repeat_sampling):]]\n",
    "        train_x = torch.cat((train_x, torch.FloatTensor(new_x)))\n",
    "        train_y = torch.cat((train_y, torch.FloatTensor(new_y)))\n",
    "\n",
    "        print(\"Iteration %d/%d: train NMLL: %.3f, valid NMLL %.3f, valid RMSE of mean %.3f, valid RMSE of std %.3f\"\n",
    "              % (i+1, args.active_learning_steps, nmll_losses[-1], nmll_losses_valid[-1],\n",
    "                 rmse_losses_valid[-1], rmse_std_losses_valid[-1]))\n",
    "\n",
    "        # Plot results\n",
    "        if args.plot:\n",
    "            p_dct = {}\n",
    "            with torch.no_grad(), gpytorch.settings.fast_pred_var():\n",
    "                p_dct['train_x'] = train_x\n",
    "                p_dct['train_y'] = train_y\n",
    "                p_dct['test_x'] = test_x\n",
    "                p_dct['test_y'] = test_y\n",
    "                p_dct['pred_x'] = pred_x\n",
    "                p_dct['mean'] = pred_mean\n",
    "                p_dct['pred_std'] = pred_std\n",
    "                p_dct['lower'] = p_dct['mean'] - 2 * p_dct['pred_std']\n",
    "                p_dct['upper'] = p_dct['mean'] + 2 * p_dct['pred_std']\n",
    "                p_dct['variance'] = p_dct['pred_std'] ** 2\n",
    "\n",
    "\n",
    "            #f = plt.figure(figsize=(4, 3), dpi=400)\n",
    "            #ax = plt.axes()\n",
    "            #plot_single_flow(ax, p_dct, new_points=args.k_samples * args.repeat_sampling, test_data=True)\n",
    "            #ax.set_xlabel(\"Turn-around time [min]\")\n",
    "            #ax.set_ylabel(\"Flight delay (mean arrival) [min]\")\n",
    "\n",
    "\n",
    "\n",
    "            \"\"\"\n",
    "            f, ax = plt.subplots(2, 3, figsize=(15, 6), dpi=50)\n",
    "            ax[0,0].plot(train_x[:-1].numpy(), train_y[:-1].numpy(), 'kx', label=\"Training data\")\n",
    "            ax[0,0].plot(train_x[-1].numpy(), train_y[-1].numpy(), 'k|', mew=3, label=\"New point to add\")\n",
    "            ax[0,0].plot(pred_x.numpy(), pred_mean.numpy(), 'r', lw=2, label=\"Predicted mean\")  # plot the mean\n",
    "            ax[0,0].fill_between(pred_x.numpy(),  # plot the two-sigma uncertainty about the mean\n",
    "                             (pred_mean - 2.0 * pred_std).numpy(),\n",
    "                             (pred_mean + 2.0 * pred_std).numpy(),\n",
    "                             color='C0', alpha=0.3, label=\"Confidence interval of predictions\")\n",
    "            ax[0,0].set_xlim(-0.5, 1.5)\n",
    "            ax[0,0].set_ylim(-2.2, 2.5)\n",
    "            ax[0,0].set_title(f\"Iteration {i}\")\n",
    "            ax[0,0].legend()\n",
    "\n",
    "            ax[0,1] = plot_one_variable(ax[0,1], nmll_losses_valid, 'NMLL')\n",
    "            ax[0,2] = plot_one_variable(ax[0,2], rmse_losses_valid, 'RMSE of mean')\n",
    "            ax[1,2] = plot_one_variable(ax[1,2], rmse_std_losses_valid, 'RMSE of std')\n",
    "            ax[1,0] = plot_one_variable(ax[1,0], selection_array, \"Variance\")\n",
    "            f.delaxes(ax[1, 1])\n",
    "            \"\"\"\n",
    "            fig = plt.figure(figsize=(20,10))\n",
    "\n",
    "            # create grid for different subplots\n",
    "            spec = gridspec.GridSpec(ncols=3, nrows=2,\n",
    "                                     width_ratios=[2, 1, 1], wspace=0.5,\n",
    "                                     hspace=0.5, height_ratios=[1, 1])\n",
    "            ax0 = fig.add_subplot(spec[0])\n",
    "            ax0.plot(train_x[:-1].numpy(), train_y[:-1].numpy(), 'kx', label=\"Training data\")\n",
    "            ax0.plot(pred_x.numpy(), pred_mean.numpy(), 'r', lw=2, label=\"Predicted mean\")  # plot the mean\n",
    "            ax0.fill_between(pred_x.numpy(),  # plot the two-sigma uncertainty about the mean\n",
    "                             (pred_mean - 2.0 * pred_std).numpy(),\n",
    "                             (pred_mean + 2.0 * pred_std).numpy(),\n",
    "                             color='C0', alpha=0.2, label=\"Confidence interval of predictions\")\n",
    "            ax0.plot(train_x[-1].numpy(), train_y[-1].numpy(), 'g*', ms=10, label=\"New point to add\")\n",
    "            #ax0.set_xlim(-0.5, 1.5)\n",
    "            ax0.set_xlim(-0.1, 5.1)\n",
    "            ax0.set_ylim(-2.2, 2.5)\n",
    "            ax0.set_title(f\"Iteration {i}\")\n",
    "            ax0.legend()\n",
    "\n",
    "            ax1 = fig.add_subplot(spec[1])    \n",
    "            ax1 = plot_one_variable(ax1, nmll_losses_valid, 'NMLL')\n",
    "            ax1 = plot_one_variable(ax1, nmll_losses, 'NMLL')\n",
    "            ax2 = fig.add_subplot(spec[2])\n",
    "            ax2 = plot_one_variable(ax2, rmse_losses_valid, 'RMSE of mean')\n",
    "            ax5 = fig.add_subplot(spec[5])\n",
    "            ax5 = plot_one_variable(ax5, rmse_std_losses_valid, 'RMSE of std')\n",
    "            ax3 = fig.add_subplot(spec[3])\n",
    "            ax3 = plot_one_variable(ax3, selection_array, \"Variance\")\n",
    "\n",
    "            #plt.savefig(f'output/two_runs/00_{args.selection_criteria}_{args.model_type}\n",
    "            #_{args.simulator}_{i}.pdf',bbox_inches=\"tight\")\n",
    "            #f.clf()\n",
    "            #plt.close()\n",
    "            plt.show()\n",
    "\n",
    "    \n",
    "    nmll_losses_baseline.append(nmll_losses)\n",
    "    nmll_losses_valid_baseline.append(nmll_losses_valid)\n",
    "    rmse_losses_valid_baseline.append(rmse_losses_valid)\n",
    "    rmse_std_losses_valid_baseline.append(rmse_std_losses_valid)\n",
    "    lengthscale_baseline.append(lst_lengthscales)\n",
    "    noise_baseline.append(lst_noises)\n",
    "    print(f\"Repetition {rep+1} took {time.time()- tic} sec.\\n\")\n",
    "print(f\"The experiment took {time.time()- tic_all} sec.\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Look at the losses"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABIEAAAFRCAYAAADjML1JAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAEAAElEQVR4nOzdd3gc1bn48e+Z2V6l1aoXy5ab3G0MNtU2NiVUAwESIISEhJRfQnJTbhLKTXIJ9yY35aZcwk0hcFNICCaUUIMDxhgM2Lj3Lqt3aXubOb8/1lpbloR7P5/n8WNpdnbmnF3tzsw773mPkFJKFEVRFEVRFEVRFEVRlNOadqIboCiKoiiKoiiKoiiKohx7KgikKIqiKIqiKIqiKIpyBlBBIEVRFEVRFEVRFEVRlDOACgIpiqIoiqIoiqIoiqKcAVQQSFEURVEURVEURVEU5QyggkCKoiiKoiiKoiiKoihnABUEUhRFURRFOQShUIjrrrsOv9+PEIJdu3ad6CYpiqIoygDH+3g1e/ZsPvWpTx3TfShHTgWBlGPqjjvuQAjBv/7rv/Zb3tDQgBCCRYsWASCEQAjBc889N2Ab1113HUKIfl8od9xxB/PmzRtyv+oLSFEU5cTrOwYIIdB1nYqKCm6//XYaGxv7rTd79myEEHzlK18ZsI2f/exnCCEYOXJkv+WPPvooZ511Fj6fD6/XS21tLZ/+9Kdzjy9atCi37/3/LViw4Ij69fDDD7N06VKWLFlCc3MzlZWVR7Q9RVEU5cRSx6uhfepTn2L27NlH1A7l5KKCQMox53A4+PnPf05dXd0HrldVVcVvf/vbfsuampp44YUX1Am2oijKKerCCy+kubmZ3bt38/jjj7Ny5UpuvPHGAetVVVXxhz/8gVQq1W/5r3/9a4YNG9Zv2WOPPcbnPvc5PvGJT7B8+XLef/99vv/972MYxoDtrlixgubm5n7/rr766iPq09atWxk/fjwTJ06kpKQEXdePaHuKoijKiaeOV8qZQgWBlGPuvPPOY/Lkydxzzz0fuN4nP/lJXn755X4R99/97ndceOGFjBgx4lg3U1EURTkGbDYbJSUllJeXc9FFF3HXXXexdOlSQqFQv/Xmzp2Lx+Ph6aefzi1bsmQJ9fX1A07Cn3nmGa666iq+8IUvMHr0aEaPHs21117L7373uwH7LywspKSkpN8/u90+ZHvT6TTf/OY3KS8vx2azMW7cOB5//PHc49XV1TzyyCO89tprCCGGvDvad2f3xRdf5Nxzz8XpdHLWWWexfv161q9fzwUXXIDL5eKcc85hw4YN/Z77/vvvc+mll+LxeCgsLOT666/vdyNl586dXH/99ZSVleFyuZg4cSJ/+MMf+m2jLyP2gQceoKSkhEAgwO23304kEhmy74qiKGeyM/V4lU6n+cpXvkJFRQV2u53S0lI+8pGPAPCd73yHRx55hDfeeCOXnfTYY48BUFdXx+WXX47T6aSyspJf/OIXH/j6KicPFQRSjjkhBD/60Y/485//zPLly4dcr6amhosuuohHH30UANM0eeSRR/qlSyqKoiinrqamJhYsWICu6wPuRmqaxp133slvfvOb3LJf//rX3HLLLbjd7n7rlpaWsnz5crZs2XLU23jPPffwm9/8hp/+9KesW7eO2267jdtuu41//vOfACxbtoybbropd8f4b3/72wdu79577+XBBx/k/fffx2az8dGPfpTPfe5zfPe7380t+8QnPpFbf8OGDcyaNYtzzz2X5cuX89prr6HrOpdccgmJRAKASCTCxRdfzEsvvcTatWu56667+MQnPsHrr7/eb98LFiygq6uLRYsW8Ze//IXnn3+eH/zgB0f5FVMURTn9nEnHq1/84hf89a9/5Y9//CNbt27lueeeY+bMmQB87Wtf45ZbbuHcc8/NZSfdfPPNSCm57rrr6OzsZNGiRfz973/nueeeY8WKFUe9n8oxIBXlGPr4xz8u586dK6WUcv78+XLWrFlSSinr6+slIF9//XUppZSA/MMf/iCfeOIJWV1dLU3TlC+99JIMBoMymUzKWbNmyTvvvHPQ7Q5m//UVRVGU4+/jH/+41HVdut1u6XQ6JSAB+dWvfrXfen3f2Y2NjdJqtcrt27fLrq4u6XQ65fvvvy+//e1vy5qamtz6zc3N8vzzz5eAHDZsmLzpppvkr371KxmJRHLrvP766xKQLpdLut3ufv8aGxsHbW80GpU2m00+9NBD/ZbPnz9fzpkzp1+/PugYtO/+n3766dyyv/71rxKQCxYsyC3729/+JgEZDodz27755pv7bSuRSEin09lvW/u75ppr5Kc+9anc77NmzZKTJk3qt85nP/tZOXPmzA9st6IoypnoTD5e3X333XLOnDnSNM1BH7/zzjtz13B9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\n",
      "text/plain": [
       "<Figure size 1440x360 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(20,5))\n",
    "\n",
    "# create grid for different subplots\n",
    "spec = gridspec.GridSpec(ncols=3, nrows=1,\n",
    "                         width_ratios=[1, 1, 1], wspace=0.5,\n",
    "                         hspace=0.5, height_ratios=[1])\n",
    "\n",
    "ax1 = fig.add_subplot(spec[0])    \n",
    "ax2 = fig.add_subplot(spec[1])\n",
    "ax3 = fig.add_subplot(spec[2])\n",
    "\n",
    "for rep in range(repetitions):\n",
    "    ax1 = plot_one_variable(ax1, nmll_losses_valid_baseline[rep], 'NMLL')\n",
    "    ax2 = plot_one_variable(ax2, rmse_losses_valid_baseline[rep], 'RMSE of mean')\n",
    "    ax3 = plot_one_variable(ax3, rmse_std_losses_valid_baseline[rep], 'RMSE of std')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Get some stats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Evaluation of the models\n",
      "Average validation values after 100 iterations\n",
      "----------------------\n",
      "Baseline model with priors\n",
      "-- NMLL          1.207 (±0.519)\n",
      "-- RMSE of mean  0.686 (±0.307)\n",
      "-- RMSE of std   0.248 (±0.126)\n"
     ]
    }
   ],
   "source": [
    "iteration = args.active_learning_steps-1\n",
    "print(\"Evaluation of the models\")\n",
    "print(f\"Average validation values after {args.active_learning_steps} iterations\")\n",
    "print(\"----------------------\")\n",
    "print(\"Baseline model with priors\")\n",
    "print(u\"-- NMLL         % .3f (\\u00B1%.3f)\" % (np.mean(nmll_losses_valid_baseline, axis=0)[iteration], \n",
    "                                               np.std(nmll_losses_valid_baseline, axis=0)[iteration]))\n",
    "print(u\"-- RMSE of mean % .3f (\\u00B1%.3f)\" % (np.mean(rmse_losses_valid_baseline, axis=0)[iteration],\n",
    "                                               np.std(rmse_losses_valid_baseline, axis=0)[iteration]))\n",
    "print(u\"-- RMSE of std  % .3f (\\u00B1%.3f)\" % (np.mean(rmse_std_losses_valid_baseline, axis=0)[iteration],\n",
    "                                               np.std(rmse_std_losses_valid_baseline, axis=0)[iteration]))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Look at the hyperparameters: length scale and noise"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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QqFQKBTnG8OHD+euu+7if/7nf3rEwJ8oEydOZP/+/bz66qu88cYb3HPPPXzjG99gxYoVyXn/gQceYO7cuT3OLS4uPqV7KxQngrLAKc5Jpk6dyr59+0hLS2Po0KEp/04k3e/o0aPZvn17ShKQnTt30tTUlHKc2+3GsqzT1XwGDx7MZz7zGZ544gn+7//+j9///vcATJkyhcbGxl799QHeeustcnJy+O53v8v06dMZPnz4cevTTJ06la1bt1JcXNzjWXWPrVMoFAqF4nzkm9/8JhUVFfzpT39KbhszZgzbtm2jrq4uua26upqdO3cyduzYPq8VDAZ597vfza9+9SvWrFnD9u3bWbx4Mfn5+ZSUlLBz584ec+3QoUPxer1ntI8KRXeUgFOcVcLhMBs2bEj5t2PHDu644w4GDRrEu971Ll555RUOHDjAypUr+cEPfsAzzzzT7+vfcccdBINBPvShD7Fp0yZWrlzJxz72MXw+X4plbtCgQbzxxhtUVFSkDPYn05/PfvazvP766+zfv5/169ezYMECRo8eDcDll1/OJZdcwm233cazzz7L/v37Wbp0KX/5y18AGDFiBLW1tTz44IPs27ePv//97/zud7875j3vvvtuLMvixhtvZMmSJRw4cIC33nqLr3/96yxbtuyk+6JQKBQKxTuB3NxcvvKVr/DLX/4yue39738/ubm53Hbbbaxbt461a9dy++23U1RUxG233dbrdX7yk5/wr3/9i61bt7J//37++te/ous6w4cPB+B73/sev/rVr/je977Hli1b2LlzJ8888wx33XXX29FNhSKJEnCKs8rKlSuZNGlSyr+bbroJr9fL4sWLmTp1KnfeeSfDhw/n5ptvZtWqVZSVlfX7+n6/nxdffJHq6mouuugiPvCBD/CFL3yBYDCYslr2s5/9jLVr1zJw4MBTsloZhkFjYyMf+9jHGDVqFFdddRX5+fk88sgjgOOC+cILL3DttdfyqU99ihEjRvCBD3wgKRqvu+46vv71r/O1r32NcePG8dhjj/GTn/zkmPfMz89n+fLl5OTkcPPNNzNixAjuuOMODh48SGFh4Un3RaFQKBSKdwpf/OIXU+LdfD4fr7zyCh6Ph0svvZTLLruMQCDAggULeg29AEhLS+PnP/85M2fOZNy4cTz99NM8+eSTjBgxAoAPfvCDPP744zz//PNMmzaN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\n",
      "text/plain": [
       "<Figure size 1080x360 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(15,5))\n",
    "\n",
    "# create grid for different subplots\n",
    "spec = gridspec.GridSpec(ncols=2, nrows=1,\n",
    "                         width_ratios=[1, 1], wspace=0.5,\n",
    "                         hspace=0.5, height_ratios=[1])\n",
    "\n",
    "ax1 = fig.add_subplot(spec[0])    \n",
    "ax2 = fig.add_subplot(spec[1])\n",
    "\n",
    "for rep in range(repetitions):\n",
    "    ax1 = plot_one_variable(ax1, lengthscale_baseline[rep], 'Length scale')\n",
    "    ax2 = plot_one_variable(ax2, noise_baseline[rep], 'Noise')\n",
    "ax1.set_ylim(0,.4)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Active learning: Fully Bayesian GP and sampling strategy is variance between mean functions\n",
    "A fully Bayesian GP, where we use the mode to estimate the GP and the sampling strategy is the predicted variance between mean functions drawn from the posteriors of the hyperparameters. We will additionally update the priors of the hyperparameters after each iteration by using the information of the posteriors."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Functions for finding new priors\n",
    "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": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.neighbors import KernelDensity\n",
    "def get_mode_from_kde2d(data):\n",
    "    kde = KernelDensity(kernel='gaussian', bandwidth=0.3)\n",
    "    kde.fit(data)\n",
    "    logprob = kde.score_samples(data)\n",
    "    np.argmax(logprob)\n",
    "    return data.iloc[np.argmax(logprob)].values.tolist()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "def predictive_posterior_moments(output):\n",
    "    # Predictive posterior mean\n",
    "    pp_mean = torch.mean(output.mean, axis=0)\n",
    "    \n",
    "    # Preditive posterior covariance\n",
    "    diff_in_mean = (pp_mean - output.mean).unsqueeze(-1)\n",
    "    diff_in_mean_t = torch.transpose(diff_in_mean, 1, 2)\n",
    "    pp_covar = torch.mean(output.covariance_matrix, axis=0) + torch.mean(diff_in_mean * diff_in_mean_t, axis=0)\n",
    "    pp_stddev = torch.sqrt(pp_covar.diag())\n",
    "    \n",
    "    return pp_mean, pp_stddev"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Import functions for plotting histogram of posterior and mean functions\n",
    "from mbml_utility_functions import plot_posterior, plot_mean_functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "#args.plot = False\n",
    "#repetitions = 2\n",
    "#args.active_learning_steps = 2\n",
    "#args.space_filling_design = \"random\"\n",
    "#args.test_samples = 101"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "**(ii) MCMC: FBGP with variance between mean functions**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "# MCMC settings\n",
    "num_samples = 300\n",
    "warmup_steps = 200\n",
    "num_chains = 5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.49      0.32      0.45      0.03      0.92    516.92      1.00\n",
      "               noise      1.11      0.59      1.00      0.26      1.87    670.85      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  9.05541181564331\n",
      "Iteration 1/100: train NMLL: 1.652, valid NMLL 1.524, valid RMSE of mean 0.717, valid RMSE of std 0.576\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.46      0.32      0.42      0.03      0.92    276.88      1.02\n",
      "               noise      1.13      0.64      0.99      0.17      1.97    509.54      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  9.24038314819336\n",
      "Iteration 2/100: train NMLL: 1.648, valid NMLL 1.536, valid RMSE of mean 0.729, valid RMSE of std 0.550\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.34      0.35      0.19      0.02      0.82    226.26      1.03\n",
      "               noise      0.84      0.60      0.75      0.04      1.57    349.46      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  10.275095701217651\n",
      "Iteration 3/100: train NMLL: 1.518, valid NMLL 1.152, valid RMSE of mean 0.789, valid RMSE of std 0.439\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.18      0.25      0.08      0.02      0.49    107.31      1.05\n",
      "               noise      0.49      0.43      0.33      0.04      1.12    123.73      1.04\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  10.354360103607178\n",
      "Iteration 4/100: train NMLL: 1.377, valid NMLL 0.776, valid RMSE of mean 0.721, valid RMSE of std 0.423\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.12      0.17      0.07      0.01      0.19    117.74      1.02\n",
      "               noise      0.36      0.35      0.24      0.04      0.84    116.90      1.03\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  12.013339042663574\n",
      "Iteration 5/100: train NMLL: 1.308, valid NMLL 0.687, valid RMSE of mean 0.699, valid RMSE of std 0.391\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.18      0.26      0.06      0.02      0.57     70.11      1.06\n",
      "               noise      0.49      0.48      0.29      0.04      1.21     73.99      1.05\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  12.575805902481079\n",
      "Iteration 6/100: train NMLL: 1.342, valid NMLL 0.680, valid RMSE of mean 0.557, valid RMSE of std 0.398\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.04      0.06      0.03      0.09    195.68      1.03\n",
      "               noise      0.20      0.21      0.15      0.03      0.38    223.50      1.02\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  13.754517078399658\n",
      "Iteration 7/100: train NMLL: 1.233, valid NMLL 0.533, valid RMSE of mean 0.519, valid RMSE of std 0.398\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.09      0.15      0.05      0.02      0.09     90.29      1.04\n",
      "               noise      0.28      0.32      0.17      0.02      0.60    119.35      1.04\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  13.097174882888794\n",
      "Iteration 8/100: train NMLL: 1.261, valid NMLL 0.582, valid RMSE of mean 0.492, valid RMSE of std 0.377\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.07      0.05      0.03      0.07    163.96      1.02\n",
      "               noise      0.17      0.18      0.12      0.02      0.34    219.62      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.05441403388977\n",
      "Iteration 9/100: train NMLL: 1.169, valid NMLL 0.466, valid RMSE of mean 0.474, valid RMSE of std 0.359\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.13      0.05      0.02      0.07     80.40      1.11\n",
      "               noise      0.17      0.24      0.10      0.02      0.28     71.85      1.13\n",
      "\n",
      "Number of divergences: 1\n",
      "Validation using full posterior took  13.85739803314209\n",
      "Iteration 10/100: train NMLL: 1.118, valid NMLL 0.390, valid RMSE of mean 0.457, valid RMSE of std 0.345\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.03      0.07    795.21      1.00\n",
      "               noise      0.12      0.08      0.09      0.03      0.21    588.85      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.70513105392456\n",
      "Iteration 11/100: train NMLL: 1.082, valid NMLL 0.382, valid RMSE of mean 0.458, valid RMSE of std 0.327\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.03      0.07    844.25      1.00\n",
      "               noise      0.11      0.08      0.09      0.03      0.20    658.39      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  13.627113103866577\n",
      "Iteration 12/100: train NMLL: 1.071, valid NMLL 0.366, valid RMSE of mean 0.452, valid RMSE of std 0.311\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.08      0.05      0.03      0.06     80.79      1.07\n",
      "               noise      0.12      0.19      0.09      0.02      0.20     68.38      1.07\n",
      "\n",
      "Number of divergences: 1\n",
      "Validation using full posterior took  14.283881902694702\n",
      "Iteration 13/100: train NMLL: 1.100, valid NMLL 0.327, valid RMSE of mean 0.437, valid RMSE of std 0.297\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.05      0.05      0.03      0.06     43.47      1.09\n",
      "               noise      0.12      0.16      0.08      0.02      0.20     58.59      1.06\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.336426019668579\n",
      "Iteration 14/100: train NMLL: 1.085, valid NMLL 0.325, valid RMSE of mean 0.425, valid RMSE of std 0.275\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.03      0.06    902.73      1.00\n",
      "               noise      0.08      0.05      0.07      0.02      0.13    869.20      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.236658096313477\n",
      "Iteration 15/100: train NMLL: 1.013, valid NMLL 0.235, valid RMSE of mean 0.420, valid RMSE of std 0.260\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.07    596.76      1.00\n",
      "               noise      0.08      0.05      0.06      0.02      0.13    667.18      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.324795961380005\n",
      "Iteration 16/100: train NMLL: 1.008, valid NMLL 0.234, valid RMSE of mean 0.396, valid RMSE of std 0.228\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.03      0.06    886.28      1.01\n",
      "               noise      0.08      0.05      0.06      0.02      0.13    726.77      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.786449909210205\n",
      "Iteration 17/100: train NMLL: 1.015, valid NMLL 0.241, valid RMSE of mean 0.390, valid RMSE of std 0.191\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    994.94      1.00\n",
      "               noise      0.07      0.04      0.06      0.02      0.12    599.81      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.623321294784546\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 18/100: train NMLL: 1.002, valid NMLL 0.219, valid RMSE of mean 0.390, valid RMSE of std 0.174\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    768.32      1.00\n",
      "               noise      0.07      0.04      0.06      0.02      0.11    788.30      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.670886039733887\n",
      "Iteration 19/100: train NMLL: 0.979, valid NMLL 0.194, valid RMSE of mean 0.357, valid RMSE of std 0.153\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    749.46      1.00\n",
      "               noise      0.07      0.04      0.06      0.02      0.11    808.74      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.558779239654541\n",
      "Iteration 20/100: train NMLL: 0.972, valid NMLL 0.196, valid RMSE of mean 0.325, valid RMSE of std 0.130\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    587.71      1.01\n",
      "               noise      0.06      0.03      0.06      0.02      0.11    745.72      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.79144024848938\n",
      "Iteration 21/100: train NMLL: 0.994, valid NMLL 0.182, valid RMSE of mean 0.295, valid RMSE of std 0.098\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1114.95      1.00\n",
      "               noise      0.05      0.03      0.05      0.02      0.10    770.00      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.222118139266968\n",
      "Iteration 22/100: train NMLL: 0.944, valid NMLL 0.139, valid RMSE of mean 0.296, valid RMSE of std 0.079\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.09      0.05      0.04      0.06     29.72      1.13\n",
      "               noise      0.08      0.17      0.05      0.02      0.10     19.84      1.23\n",
      "\n",
      "Number of divergences: 131\n",
      "Validation using full posterior took  14.274374961853027\n",
      "Iteration 23/100: train NMLL: 0.930, valid NMLL 0.151, valid RMSE of mean 0.293, valid RMSE of std 0.075\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1023.22      1.00\n",
      "               noise      0.05      0.02      0.04      0.02      0.08    562.58      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.856675863265991\n",
      "Iteration 24/100: train NMLL: 0.875, valid NMLL 0.114, valid RMSE of mean 0.293, valid RMSE of std 0.061\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.08      0.14      0.05      0.04      0.06     16.70      1.32\n",
      "               noise      0.11      0.25      0.04      0.01      0.11     12.69      1.53\n",
      "\n",
      "Number of divergences: 147\n",
      "Validation using full posterior took  14.900362968444824\n",
      "Iteration 25/100: train NMLL: 0.909, valid NMLL 0.124, valid RMSE of mean 0.276, valid RMSE of std 0.071\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.11      0.05      0.04      0.06     30.55      1.13\n",
      "               noise      0.08      0.17      0.04      0.02      0.09     18.15      1.26\n",
      "\n",
      "Number of divergences: 145\n",
      "Validation using full posterior took  16.047799110412598\n",
      "Iteration 26/100: train NMLL: 0.876, valid NMLL 0.114, valid RMSE of mean 0.277, valid RMSE of std 0.065\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1117.84      1.00\n",
      "               noise      0.04      0.02      0.04      0.02      0.07    507.41      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.765658855438232\n",
      "Iteration 27/100: train NMLL: 0.839, valid NMLL 0.092, valid RMSE of mean 0.280, valid RMSE of std 0.057\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.08      0.16      0.05      0.04      0.06     18.86      1.26\n",
      "               noise      0.10      0.23      0.04      0.01      0.09     13.92      1.42\n",
      "\n",
      "Number of divergences: 90\n",
      "Validation using full posterior took  16.23097801208496\n",
      "Iteration 28/100: train NMLL: 0.843, valid NMLL 0.117, valid RMSE of mean 0.286, valid RMSE of std 0.058\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    945.07      1.00\n",
      "               noise      0.05      0.02      0.04      0.02      0.07    620.74      1.01\n",
      "\n",
      "Number of divergences: 4\n",
      "Validation using full posterior took  15.774010181427002\n",
      "Iteration 29/100: train NMLL: 0.821, valid NMLL 0.115, valid RMSE of mean 0.289, valid RMSE of std 0.054\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.12      0.24      0.05      0.03      0.41      8.07      1.83\n",
      "               noise      0.16      0.33      0.04      0.01      0.84      6.61      2.59\n",
      "\n",
      "Number of divergences: 146\n",
      "Validation using full posterior took  16.139657974243164\n",
      "Iteration 30/100: train NMLL: 0.793, valid NMLL 0.108, valid RMSE of mean 0.291, valid RMSE of std 0.052\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    423.86      1.04\n",
      "               noise      0.05      0.10      0.04      0.02      0.07     50.74      1.07\n",
      "\n",
      "Number of divergences: 196\n",
      "Validation using full posterior took  16.252718925476074\n",
      "Iteration 31/100: train NMLL: 0.773, valid NMLL 0.109, valid RMSE of mean 0.292, valid RMSE of std 0.051\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.12      0.23      0.05      0.03      0.36      7.58      1.80\n",
      "               noise      0.17      0.35      0.04      0.01      0.82      5.14      2.29\n",
      "\n",
      "Number of divergences: 54\n",
      "Validation using full posterior took  16.44735622406006\n",
      "Iteration 32/100: train NMLL: 0.756, valid NMLL 0.113, valid RMSE of mean 0.294, valid RMSE of std 0.056\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1156.83      1.00\n",
      "               noise      0.04      0.01      0.03      0.02      0.05   1030.77      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.850393772125244\n",
      "Iteration 33/100: train NMLL: 0.700, valid NMLL 0.087, valid RMSE of mean 0.294, valid RMSE of std 0.043\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.08      0.05      0.04      0.06     39.31      1.09\n",
      "               noise      0.07      0.16      0.04      0.02      0.07     22.21      1.20\n",
      "\n",
      "Number of divergences: 149\n",
      "Validation using full posterior took  17.27452301979065\n",
      "Iteration 34/100: train NMLL: 0.736, valid NMLL 0.120, valid RMSE of mean 0.297, valid RMSE of std 0.054\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1082.84      1.00\n",
      "               noise      0.04      0.01      0.04      0.02      0.06    458.83      1.01\n",
      "\n",
      "Number of divergences: 7\n",
      "Validation using full posterior took  16.58141827583313\n",
      "Iteration 35/100: train NMLL: 0.699, valid NMLL 0.105, valid RMSE of mean 0.297, valid RMSE of std 0.045\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1033.72      1.00\n",
      "               noise      0.04      0.01      0.04      0.02      0.06    516.51      1.01\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  17.518973112106323\n",
      "Iteration 36/100: train NMLL: 0.683, valid NMLL 0.108, valid RMSE of mean 0.299, valid RMSE of std 0.044\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    953.02      1.01\n",
      "               noise      0.05      0.01      0.04      0.02      0.07    714.66      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.56131601333618\n",
      "Iteration 37/100: train NMLL: 0.705, valid NMLL 0.134, valid RMSE of mean 0.301, valid RMSE of std 0.048\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1065.13      1.00\n",
      "               noise      0.05      0.02      0.05      0.03      0.08    713.93      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.24861741065979\n",
      "Iteration 38/100: train NMLL: 0.736, valid NMLL 0.168, valid RMSE of mean 0.301, valid RMSE of std 0.057\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    897.20      1.00\n",
      "               noise      0.05      0.02      0.05      0.03      0.07    385.08      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.53582191467285\n",
      "Iteration 39/100: train NMLL: 0.712, valid NMLL 0.157, valid RMSE of mean 0.303, valid RMSE of std 0.050\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.08      0.16      0.05      0.04      0.06     21.56      1.21\n",
      "               noise      0.10      0.20      0.05      0.03      0.08     14.78      1.36\n",
      "\n",
      "Number of divergences: 138\n",
      "Validation using full posterior took  17.24707579612732\n",
      "Iteration 40/100: train NMLL: 0.709, valid NMLL 0.169, valid RMSE of mean 0.305, valid RMSE of std 0.050\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1064.00      1.00\n",
      "               noise      0.05      0.01      0.05      0.03      0.07   1156.73      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.256199836730957\n",
      "Iteration 41/100: train NMLL: 0.678, valid NMLL 0.157, valid RMSE of mean 0.306, valid RMSE of std 0.046\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    963.66      1.00\n",
      "               noise      0.05      0.01      0.05      0.03      0.07    884.98      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.949882745742798\n",
      "Iteration 42/100: train NMLL: 0.677, valid NMLL 0.163, valid RMSE of mean 0.313, valid RMSE of std 0.030\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.05      0.06   1242.38      1.00\n",
      "               noise      0.05      0.01      0.05      0.03      0.07    541.69      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.4939022064209\n",
      "Iteration 43/100: train NMLL: 0.667, valid NMLL 0.169, valid RMSE of mean 0.314, valid RMSE of std 0.025\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.08      0.05      0.04      0.06     39.34      1.10\n",
      "               noise      0.08      0.17      0.05      0.03      0.07     23.87      1.17\n",
      "\n",
      "Number of divergences: 180\n",
      "Validation using full posterior took  18.2256920337677\n",
      "Iteration 44/100: train NMLL: 0.653, valid NMLL 0.170, valid RMSE of mean 0.312, valid RMSE of std 0.024\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1265.60      1.00\n",
      "               noise      0.04      0.01      0.04      0.02      0.06   1138.11      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.811089038848877\n",
      "Iteration 45/100: train NMLL: 0.625, valid NMLL 0.161, valid RMSE of mean 0.313, valid RMSE of std 0.021\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1098.49      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.06    824.28      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.620375156402588\n",
      "Iteration 46/100: train NMLL: 0.599, valid NMLL 0.154, valid RMSE of mean 0.314, valid RMSE of std 0.018\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    879.26      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.06    783.91      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.11067509651184\n",
      "Iteration 47/100: train NMLL: 0.588, valid NMLL 0.163, valid RMSE of mean 0.314, valid RMSE of std 0.018\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    937.12      1.01\n",
      "               noise      0.04      0.01      0.04      0.02      0.06    695.42      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.77630615234375\n",
      "Iteration 48/100: train NMLL: 0.576, valid NMLL 0.167, valid RMSE of mean 0.314, valid RMSE of std 0.018\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1059.94      1.00\n",
      "               noise      0.04      0.01      0.04      0.02      0.05    715.32      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.24680185317993\n",
      "Iteration 49/100: train NMLL: 0.555, valid NMLL 0.166, valid RMSE of mean 0.314, valid RMSE of std 0.019\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.05      0.06   1336.86      1.00\n",
      "               noise      0.04      0.01      0.04      0.02      0.05    703.34      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.99729084968567\n",
      "Iteration 50/100: train NMLL: 0.544, valid NMLL 0.174, valid RMSE of mean 0.315, valid RMSE of std 0.020\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1098.47      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.06    836.34      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.444599628448486\n",
      "Iteration 51/100: train NMLL: 0.545, valid NMLL 0.181, valid RMSE of mean 0.316, valid RMSE of std 0.019\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.03      0.05      0.05      0.06    395.75      1.01\n",
      "               noise      0.05      0.08      0.04      0.02      0.06     56.96      1.07\n",
      "\n",
      "Number of divergences: 168\n",
      "Validation using full posterior took  19.22480821609497\n",
      "Iteration 52/100: train NMLL: 0.532, valid NMLL 0.180, valid RMSE of mean 0.316, valid RMSE of std 0.019\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1193.29      1.00\n",
      "               noise      0.04      0.01      0.04      0.02      0.05    730.69      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.62162494659424\n",
      "Iteration 53/100: train NMLL: 0.503, valid NMLL 0.179, valid RMSE of mean 0.317, valid RMSE of std 0.022\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1006.04      1.00\n",
      "               noise      0.04      0.01      0.04      0.02      0.05    944.14      1.01\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  19.09869122505188\n",
      "Iteration 54/100: train NMLL: 0.513, valid NMLL 0.189, valid RMSE of mean 0.318, valid RMSE of std 0.020\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.05      0.06    999.20      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.06    757.35      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.600403785705566\n",
      "Iteration 55/100: train NMLL: 0.520, valid NMLL 0.200, valid RMSE of mean 0.320, valid RMSE of std 0.019\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1322.37      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.05    866.24      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.4927659034729\n",
      "Iteration 56/100: train NMLL: 0.511, valid NMLL 0.207, valid RMSE of mean 0.320, valid RMSE of std 0.020\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.05      0.06    936.33      1.01\n",
      "               noise      0.04      0.01      0.04      0.03      0.06    744.91      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.441676139831543\n",
      "Iteration 57/100: train NMLL: 0.504, valid NMLL 0.217, valid RMSE of mean 0.320, valid RMSE of std 0.021\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06    693.02      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.05   1305.95      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.258151054382324\n",
      "Iteration 58/100: train NMLL: 0.490, valid NMLL 0.223, valid RMSE of mean 0.320, valid RMSE of std 0.023\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1067.39      1.00\n",
      "               noise      0.04      0.01      0.04      0.02      0.05    751.03      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.076684713363647\n",
      "Iteration 59/100: train NMLL: 0.476, valid NMLL 0.222, valid RMSE of mean 0.321, valid RMSE of std 0.024\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1107.24      1.00\n",
      "               noise      0.04      0.01      0.04      0.02      0.05    971.73      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.550829887390137\n",
      "Iteration 60/100: train NMLL: 0.462, valid NMLL 0.229, valid RMSE of mean 0.321, valid RMSE of std 0.026\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1277.11      1.00\n",
      "               noise      0.04      0.01      0.04      0.02      0.05    306.53      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.167730808258057\n",
      "Iteration 61/100: train NMLL: 0.450, valid NMLL 0.241, valid RMSE of mean 0.321, valid RMSE of std 0.029\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06    992.40      1.00\n",
      "               noise      0.04      0.01      0.04      0.02      0.05    512.62      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.584764003753662\n",
      "Iteration 62/100: train NMLL: 0.434, valid NMLL 0.242, valid RMSE of mean 0.321, valid RMSE of std 0.030\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1283.11      1.00\n",
      "               noise      0.04      0.01      0.03      0.02      0.05   1168.37      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.24201512336731\n",
      "Iteration 63/100: train NMLL: 0.422, valid NMLL 0.243, valid RMSE of mean 0.320, valid RMSE of std 0.031\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1222.35      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.05    968.10      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.30309820175171\n",
      "Iteration 64/100: train NMLL: 0.404, valid NMLL 0.245, valid RMSE of mean 0.320, valid RMSE of std 0.033\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1229.29      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    944.96      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  21.026144981384277\n",
      "Iteration 65/100: train NMLL: 0.393, valid NMLL 0.250, valid RMSE of mean 0.321, valid RMSE of std 0.034\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1305.21      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    890.51      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.071976900100708\n",
      "Iteration 66/100: train NMLL: 0.390, valid NMLL 0.255, valid RMSE of mean 0.321, valid RMSE of std 0.034\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.06      0.06      0.05      0.06    161.47      1.02\n",
      "               noise      0.05      0.10      0.03      0.02      0.04     45.44      1.08\n",
      "\n",
      "Number of divergences: 160\n",
      "Validation using full posterior took  20.60792088508606\n",
      "Iteration 67/100: train NMLL: 0.391, valid NMLL 0.261, valid RMSE of mean 0.322, valid RMSE of std 0.033\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.06      0.05      0.06    951.77      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04   1341.34      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.363992929458618\n",
      "Iteration 68/100: train NMLL: 0.368, valid NMLL 0.268, valid RMSE of mean 0.321, valid RMSE of std 0.037\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06    510.51      1.01\n",
      "               noise      0.04      0.05      0.03      0.02      0.05     39.25      1.10\n",
      "\n",
      "Number of divergences: 191\n",
      "Validation using full posterior took  21.171321153640747\n",
      "Iteration 69/100: train NMLL: 0.390, valid NMLL 0.267, valid RMSE of mean 0.317, valid RMSE of std 0.030\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.13      0.23      0.05      0.04      0.42      7.89      1.93\n",
      "               noise      0.15      0.33      0.03      0.02      0.90      5.66      2.62\n",
      "\n",
      "Number of divergences: 72\n",
      "Validation using full posterior took  19.722068071365356\n",
      "Iteration 70/100: train NMLL: 0.371, valid NMLL 0.271, valid RMSE of mean 0.317, valid RMSE of std 0.033\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.19      0.30      0.06      0.04      0.66      3.22      2.21\n",
      "               noise      0.23      0.41      0.03      0.02      1.02      2.59      5.57\n",
      "\n",
      "Number of divergences: 1\n",
      "Validation using full posterior took  18.977816104888916\n",
      "Iteration 71/100: train NMLL: 0.343, valid NMLL 0.284, valid RMSE of mean 0.317, valid RMSE of std 0.040\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.21      0.33      0.06      0.04      0.75      3.86      1.80\n",
      "               noise      0.28      0.44      0.04      0.02      1.06      3.12      2.63\n",
      "\n",
      "Number of divergences: 409\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  18.98419499397278\n",
      "Iteration 72/100: train NMLL: 0.402, valid NMLL 0.250, valid RMSE of mean 0.317, valid RMSE of std 0.014\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1048.31      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    183.94      1.02\n",
      "\n",
      "Number of divergences: 33\n",
      "Validation using full posterior took  20.593496799468994\n",
      "Iteration 73/100: train NMLL: 0.313, valid NMLL 0.290, valid RMSE of mean 0.317, valid RMSE of std 0.042\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.19      0.31      0.06      0.04      0.70      3.15      2.28\n",
      "               noise      0.24      0.41      0.03      0.02      1.02      2.63      4.59\n",
      "\n",
      "Number of divergences: 120\n",
      "Validation using full posterior took  19.028735160827637\n",
      "Iteration 74/100: train NMLL: 0.330, valid NMLL 0.284, valid RMSE of mean 0.318, valid RMSE of std 0.037\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.12      0.22      0.06      0.05      0.07     12.95      1.56\n",
      "               noise      0.14      0.30      0.03      0.02      0.45     10.76      1.93\n",
      "\n",
      "Number of divergences: 284\n",
      "Validation using full posterior took  20.425532817840576\n",
      "Iteration 75/100: train NMLL: 0.371, valid NMLL 0.256, valid RMSE of mean 0.318, valid RMSE of std 0.018\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.11      0.20      0.06      0.04      0.07     11.63      1.77\n",
      "               noise      0.12      0.29      0.03      0.02      0.15      8.52      3.43\n",
      "\n",
      "Number of divergences: 124\n",
      "Validation using full posterior took  19.879462957382202\n",
      "Iteration 76/100: train NMLL: 0.303, valid NMLL 0.284, valid RMSE of mean 0.319, valid RMSE of std 0.039\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.09      0.17      0.06      0.04      0.06     15.08      1.39\n",
      "               noise      0.10      0.25      0.03      0.02      0.12     10.29      1.84\n",
      "\n",
      "Number of divergences: 127\n",
      "Validation using full posterior took  20.505087852478027\n",
      "Iteration 77/100: train NMLL: 0.304, valid NMLL 0.272, valid RMSE of mean 0.319, valid RMSE of std 0.034\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06   1158.75      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04   1060.97      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.762794017791748\n",
      "Iteration 78/100: train NMLL: 0.257, valid NMLL 0.312, valid RMSE of mean 0.319, valid RMSE of std 0.048\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06    534.88      1.01\n",
      "               noise      0.03      0.00      0.03      0.02      0.04    867.23      1.00\n",
      "\n",
      "Number of divergences: 6\n",
      "Validation using full posterior took  20.842504024505615\n",
      "Iteration 79/100: train NMLL: 0.259, valid NMLL 0.322, valid RMSE of mean 0.320, valid RMSE of std 0.048\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06   1189.57      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    753.18      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  21.16440200805664\n",
      "Iteration 80/100: train NMLL: 0.248, valid NMLL 0.326, valid RMSE of mean 0.320, valid RMSE of std 0.049\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06   1350.86      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04   1038.29      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  21.47386598587036\n",
      "Iteration 81/100: train NMLL: 0.243, valid NMLL 0.335, valid RMSE of mean 0.320, valid RMSE of std 0.050\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06   1143.62      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.03    691.64      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  21.342790126800537\n",
      "Iteration 82/100: train NMLL: 0.236, valid NMLL 0.349, valid RMSE of mean 0.320, valid RMSE of std 0.052\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06   1296.92      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.04    917.42      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  21.728681802749634\n",
      "Iteration 83/100: train NMLL: 0.229, valid NMLL 0.355, valid RMSE of mean 0.320, valid RMSE of std 0.052\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06   1242.87      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.03    948.66      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  21.334241151809692\n",
      "Iteration 84/100: train NMLL: 0.226, valid NMLL 0.362, valid RMSE of mean 0.321, valid RMSE of std 0.053\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06    812.08      1.01\n",
      "               noise      0.03      0.00      0.03      0.02      0.03   1019.71      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  21.628412008285522\n",
      "Iteration 85/100: train NMLL: 0.210, valid NMLL 0.374, valid RMSE of mean 0.321, valid RMSE of std 0.055\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.11      0.20      0.06      0.04      0.07     10.19      2.09\n",
      "               noise      0.12      0.30      0.03      0.02      0.04      8.70      3.28\n",
      "\n",
      "Number of divergences: 130\n",
      "Validation using full posterior took  20.154657125473022\n",
      "Iteration 86/100: train NMLL: 0.211, valid NMLL 0.374, valid RMSE of mean 0.321, valid RMSE of std 0.054\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06    786.82      1.01\n",
      "               noise      0.03      0.00      0.03      0.02      0.03   1121.12      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  21.651357889175415\n",
      "Iteration 87/100: train NMLL: 0.193, valid NMLL 0.390, valid RMSE of mean 0.321, valid RMSE of std 0.057\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.08      0.13      0.06      0.05      0.06     19.14      1.24\n",
      "               noise      0.08      0.22      0.03      0.02      0.09     11.20      1.57\n",
      "\n",
      "Number of divergences: 124\n",
      "Validation using full posterior took  21.176671981811523\n",
      "Iteration 88/100: train NMLL: 0.254, valid NMLL 0.302, valid RMSE of mean 0.322, valid RMSE of std 0.034\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06    446.51      1.01\n",
      "               noise      0.03      0.00      0.03      0.02      0.03    147.57      1.04\n",
      "\n",
      "Number of divergences: 206\n",
      "Validation using full posterior took  21.98404097557068\n",
      "Iteration 89/100: train NMLL: 0.173, valid NMLL 0.395, valid RMSE of mean 0.322, valid RMSE of std 0.058\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.12      0.20      0.06      0.04      0.07      9.54      2.24\n",
      "               noise      0.12      0.29      0.03      0.02      0.04      8.42      4.94\n",
      "\n",
      "Number of divergences: 67\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  20.09789490699768\n",
      "Iteration 90/100: train NMLL: 0.164, valid NMLL 0.399, valid RMSE of mean 0.322, valid RMSE of std 0.059\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06   1346.93      1.00\n",
      "               noise      0.02      0.00      0.02      0.02      0.03    576.92      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.166419982910156\n",
      "Iteration 91/100: train NMLL: 0.149, valid NMLL 0.409, valid RMSE of mean 0.323, valid RMSE of std 0.060\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06    943.21      1.00\n",
      "               noise      0.02      0.00      0.02      0.02      0.03    818.58      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.184876680374146\n",
      "Iteration 92/100: train NMLL: 0.146, valid NMLL 0.417, valid RMSE of mean 0.323, valid RMSE of std 0.060\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06    799.15      1.00\n",
      "               noise      0.02      0.00      0.02      0.02      0.03    884.52      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.526220083236694\n",
      "Iteration 93/100: train NMLL: 0.136, valid NMLL 0.435, valid RMSE of mean 0.323, valid RMSE of std 0.062\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06   1225.63      1.00\n",
      "               noise      0.02      0.00      0.02      0.02      0.03    509.36      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  21.948030948638916\n",
      "Iteration 94/100: train NMLL: 0.131, valid NMLL 0.446, valid RMSE of mean 0.324, valid RMSE of std 0.063\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06   1422.15      1.00\n",
      "               noise      0.02      0.00      0.02      0.02      0.03    818.56      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.17355489730835\n",
      "Iteration 95/100: train NMLL: 0.135, valid NMLL 0.448, valid RMSE of mean 0.325, valid RMSE of std 0.062\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.10      0.06      0.05      0.06     30.99      1.13\n",
      "               noise      0.06      0.17      0.03      0.02      0.06     19.85      1.23\n",
      "\n",
      "Number of divergences: 329\n",
      "Validation using full posterior took  22.139495849609375\n",
      "Iteration 96/100: train NMLL: 0.210, valid NMLL 0.341, valid RMSE of mean 0.326, valid RMSE of std 0.039\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06    912.99      1.00\n",
      "               noise      0.02      0.00      0.02      0.02      0.03    798.87      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  23.069042205810547\n",
      "Iteration 97/100: train NMLL: 0.127, valid NMLL 0.459, valid RMSE of mean 0.326, valid RMSE of std 0.063\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06   1168.30      1.00\n",
      "               noise      0.02      0.00      0.02      0.02      0.03    896.55      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.746440887451172\n",
      "Iteration 98/100: train NMLL: 0.117, valid NMLL 0.477, valid RMSE of mean 0.326, valid RMSE of std 0.064\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.09      0.06      0.05      0.06     68.50      1.05\n",
      "               noise      0.04      0.12      0.02      0.02      0.03     33.72      1.11\n",
      "\n",
      "Number of divergences: 172\n",
      "Validation using full posterior took  23.389553785324097\n",
      "Iteration 99/100: train NMLL: 0.138, valid NMLL 0.412, valid RMSE of mean 0.326, valid RMSE of std 0.055\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06    812.58      1.00\n",
      "               noise      0.02      0.00      0.02      0.02      0.03    391.85      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.836390733718872\n",
      "Iteration 100/100: train NMLL: 0.097, valid NMLL 0.485, valid RMSE of mean 0.326, valid RMSE of std 0.065\n",
      "Repetition 1 took 3171.5417869091034 sec.\n",
      "\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.48      0.31      0.43      0.03      0.90    597.24      1.00\n",
      "               noise      1.07      0.58      0.95      0.22      1.88    628.51      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  9.626451969146729\n",
      "Iteration 1/100: train NMLL: 1.614, valid NMLL 1.549, valid RMSE of mean 0.910, valid RMSE of std 0.505\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.42      0.32      0.37      0.03      0.88    316.05      1.01\n",
      "               noise      0.98      0.69      0.89      0.04      1.74    252.39      1.00\n",
      "\n",
      "Number of divergences: 4\n",
      "Validation using full posterior took  9.341970205307007\n",
      "Iteration 2/100: train NMLL: 1.586, valid NMLL 1.424, valid RMSE of mean 0.879, valid RMSE of std 0.648\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.27      0.28      0.10      0.03      0.69     87.96      1.04\n",
      "               noise      0.58      0.52      0.44      0.02      1.25     85.28      1.06\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  10.578186988830566\n",
      "Iteration 3/100: train NMLL: 1.372, valid NMLL 0.647, valid RMSE of mean 0.848, valid RMSE of std 0.515\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.22      0.27      0.09      0.02      0.63    137.60      1.04\n",
      "               noise      0.55      0.50      0.38      0.05      1.17    199.56      1.03\n",
      "\n",
      "Number of divergences: 1\n",
      "Validation using full posterior took  10.640431880950928\n",
      "Iteration 4/100: train NMLL: 1.370, valid NMLL 0.756, valid RMSE of mean 0.835, valid RMSE of std 0.543\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.14      0.19      0.08      0.03      0.30     68.93      1.06\n",
      "               noise      0.34      0.35      0.21      0.03      0.80     68.83      1.07\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  11.720652103424072\n",
      "Iteration 5/100: train NMLL: 1.258, valid NMLL 0.599, valid RMSE of mean 0.754, valid RMSE of std 0.558\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.08      0.05      0.07      0.04      0.11    386.63      1.01\n",
      "               noise      0.18      0.16      0.13      0.04      0.34    377.20      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  11.921171188354492\n",
      "Iteration 6/100: train NMLL: 1.161, valid NMLL 0.464, valid RMSE of mean 0.701, valid RMSE of std 0.555\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.11      0.14      0.07      0.03      0.12     27.71      1.11\n",
      "               noise      0.27      0.28      0.17      0.03      0.63     37.75      1.09\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  12.895266056060791\n",
      "Iteration 7/100: train NMLL: 1.229, valid NMLL 0.510, valid RMSE of mean 0.590, valid RMSE of std 0.544\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.04      0.07      0.04      0.09    125.63      1.04\n",
      "               noise      0.19      0.15      0.14      0.04      0.34    347.15      1.01\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  12.980254173278809\n",
      "Iteration 8/100: train NMLL: 1.185, valid NMLL 0.492, valid RMSE of mean 0.579, valid RMSE of std 0.536\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.03      0.06      0.04      0.08    211.69      1.02\n",
      "               noise      0.19      0.15      0.15      0.03      0.36    422.30      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.189448118209839\n",
      "Iteration 9/100: train NMLL: 1.233, valid NMLL 0.501, valid RMSE of mean 0.417, valid RMSE of std 0.533\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.10      0.17      0.06      0.01      0.10     38.03      1.10\n",
      "               noise      0.28      0.32      0.17      0.03      0.65     39.14      1.12\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  13.73927092552185\n",
      "Iteration 10/100: train NMLL: 1.255, valid NMLL 0.535, valid RMSE of mean 0.363, valid RMSE of std 0.507\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.08      0.13      0.06      0.03      0.08     45.50      1.12\n",
      "               noise      0.23      0.28      0.14      0.03      0.44     46.08      1.12\n",
      "\n",
      "Number of divergences: 1\n",
      "Validation using full posterior took  13.928733825683594\n",
      "Iteration 11/100: train NMLL: 1.211, valid NMLL 0.476, valid RMSE of mean 0.354, valid RMSE of std 0.489\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.10      0.18      0.06      0.03      0.09     19.25      1.19\n",
      "               noise      0.23      0.29      0.14      0.03      0.44     18.52      1.21\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.564635038375854\n",
      "Iteration 12/100: train NMLL: 1.181, valid NMLL 0.463, valid RMSE of mean 0.365, valid RMSE of std 0.469\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.04      0.08    781.96      1.00\n",
      "               noise      0.14      0.08      0.12      0.04      0.24    611.16      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.430137157440186\n",
      "Iteration 13/100: train NMLL: 1.128, valid NMLL 0.405, valid RMSE of mean 0.356, valid RMSE of std 0.464\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.03      0.07    406.99      1.00\n",
      "               noise      0.13      0.08      0.11      0.04      0.22    736.18      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.661993980407715\n",
      "Iteration 14/100: train NMLL: 1.137, valid NMLL 0.395, valid RMSE of mean 0.342, valid RMSE of std 0.414\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.07    869.31      1.00\n",
      "               noise      0.13      0.07      0.12      0.04      0.22    605.36      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.098596096038818\n",
      "Iteration 15/100: train NMLL: 1.135, valid NMLL 0.392, valid RMSE of mean 0.365, valid RMSE of std 0.364\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.07    570.20      1.01\n",
      "               noise      0.13      0.07      0.11      0.04      0.22    685.26      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.998639822006226\n",
      "Iteration 16/100: train NMLL: 1.143, valid NMLL 0.369, valid RMSE of mean 0.363, valid RMSE of std 0.310\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.03      0.06    654.58      1.00\n",
      "               noise      0.13      0.07      0.11      0.04      0.22    778.37      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.816865921020508\n",
      "Iteration 17/100: train NMLL: 1.161, valid NMLL 0.394, valid RMSE of mean 0.347, valid RMSE of std 0.298\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.03      0.06    874.07      1.01\n",
      "               noise      0.12      0.06      0.11      0.04      0.20    759.68      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.041436910629272\n",
      "Iteration 18/100: train NMLL: 1.162, valid NMLL 0.368, valid RMSE of mean 0.330, valid RMSE of std 0.271\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.13      0.24      0.05      0.01      0.41     12.88      1.58\n",
      "               noise      0.27      0.37      0.12      0.03      0.94     10.13      1.78\n",
      "\n",
      "Number of divergences: 124\n",
      "Validation using full posterior took  15.150588989257812\n",
      "Iteration 19/100: train NMLL: 1.141, valid NMLL 0.366, valid RMSE of mean 0.335, valid RMSE of std 0.269\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.17      0.27      0.05      0.02      0.60      3.41      2.02\n",
      "               noise      0.31      0.44      0.11      0.03      1.03      2.93      2.67\n",
      "\n",
      "Number of divergences: 50\n",
      "Validation using full posterior took  14.031293869018555\n",
      "Iteration 20/100: train NMLL: 1.095, valid NMLL 0.313, valid RMSE of mean 0.335, valid RMSE of std 0.244\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.15      0.26      0.05      0.02      0.51     11.53      1.50\n",
      "               noise      0.27      0.38      0.10      0.04      0.95      8.79      1.69\n",
      "\n",
      "Number of divergences: 54\n",
      "Validation using full posterior took  15.080471754074097\n",
      "Iteration 21/100: train NMLL: 1.075, valid NMLL 0.319, valid RMSE of mean 0.334, valid RMSE of std 0.242\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.14      0.05      0.03      0.06     22.89      1.19\n",
      "               noise      0.14      0.19      0.09      0.04      0.18     19.25      1.25\n",
      "\n",
      "Number of divergences: 36\n",
      "Validation using full posterior took  15.285338878631592\n",
      "Iteration 22/100: train NMLL: 1.040, valid NMLL 0.293, valid RMSE of mean 0.335, valid RMSE of std 0.234\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    836.06      1.00\n",
      "               noise      0.09      0.04      0.08      0.04      0.15    590.10      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.083019018173218\n",
      "Iteration 23/100: train NMLL: 0.999, valid NMLL 0.259, valid RMSE of mean 0.337, valid RMSE of std 0.219\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    876.26      1.00\n",
      "               noise      0.09      0.04      0.08      0.04      0.14    608.36      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.662895202636719\n",
      "Iteration 24/100: train NMLL: 0.974, valid NMLL 0.239, valid RMSE of mean 0.335, valid RMSE of std 0.206\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    869.11      1.01\n",
      "               noise      0.09      0.04      0.08      0.04      0.13    619.12      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.29681897163391\n",
      "Iteration 25/100: train NMLL: 0.974, valid NMLL 0.237, valid RMSE of mean 0.264, valid RMSE of std 0.181\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.17      0.27      0.05      0.03      0.62      3.16      2.24\n",
      "               noise      0.28      0.41      0.09      0.03      1.02      2.74      3.51\n",
      "\n",
      "Number of divergences: 29\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  14.489774703979492\n",
      "Iteration 26/100: train NMLL: 0.968, valid NMLL 0.243, valid RMSE of mean 0.258, valid RMSE of std 0.173\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    841.61      1.00\n",
      "               noise      0.08      0.03      0.07      0.03      0.11    660.37      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.367440938949585\n",
      "Iteration 27/100: train NMLL: 0.922, valid NMLL 0.198, valid RMSE of mean 0.259, valid RMSE of std 0.154\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    608.96      1.01\n",
      "               noise      0.08      0.03      0.07      0.04      0.12    445.38      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.740949153900146\n",
      "Iteration 28/100: train NMLL: 0.921, valid NMLL 0.209, valid RMSE of mean 0.260, valid RMSE of std 0.153\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    991.43      1.01\n",
      "               noise      0.07      0.03      0.07      0.04      0.11    722.99      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.683682203292847\n",
      "Iteration 29/100: train NMLL: 0.892, valid NMLL 0.181, valid RMSE of mean 0.264, valid RMSE of std 0.139\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    805.98      1.00\n",
      "               noise      0.07      0.03      0.07      0.04      0.11    625.22      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.195887088775635\n",
      "Iteration 30/100: train NMLL: 0.893, valid NMLL 0.188, valid RMSE of mean 0.271, valid RMSE of std 0.118\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    926.32      1.00\n",
      "               noise      0.07      0.02      0.06      0.04      0.11    442.60      1.00\n",
      "\n",
      "Number of divergences: 4\n",
      "Validation using full posterior took  16.543612241744995\n",
      "Iteration 31/100: train NMLL: 0.865, valid NMLL 0.164, valid RMSE of mean 0.274, valid RMSE of std 0.105\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1112.75      1.00\n",
      "               noise      0.07      0.02      0.06      0.03      0.10    489.96      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.435688972473145\n",
      "Iteration 32/100: train NMLL: 0.853, valid NMLL 0.167, valid RMSE of mean 0.276, valid RMSE of std 0.101\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    931.42      1.00\n",
      "               noise      0.07      0.02      0.06      0.03      0.10    447.87      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.603811025619507\n",
      "Iteration 33/100: train NMLL: 0.842, valid NMLL 0.165, valid RMSE of mean 0.275, valid RMSE of std 0.093\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    873.63      1.00\n",
      "               noise      0.06      0.02      0.06      0.03      0.09    844.03      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.84035086631775\n",
      "Iteration 34/100: train NMLL: 0.820, valid NMLL 0.155, valid RMSE of mean 0.277, valid RMSE of std 0.087\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    651.30      1.01\n",
      "               noise      0.06      0.02      0.05      0.03      0.09    470.96      1.02\n",
      "\n",
      "Number of divergences: 79\n",
      "Validation using full posterior took  17.668984174728394\n",
      "Iteration 35/100: train NMLL: 0.789, valid NMLL 0.132, valid RMSE of mean 0.278, valid RMSE of std 0.076\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.11      0.19      0.05      0.03      0.26      9.53      1.95\n",
      "               noise      0.17      0.32      0.06      0.03      0.72      7.72      3.22\n",
      "\n",
      "Number of divergences: 82\n",
      "Validation using full posterior took  16.43333387374878\n",
      "Iteration 36/100: train NMLL: 0.787, valid NMLL 0.146, valid RMSE of mean 0.280, valid RMSE of std 0.076\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1037.06      1.00\n",
      "               noise      0.06      0.02      0.06      0.03      0.09    896.51      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.93393611907959\n",
      "Iteration 37/100: train NMLL: 0.764, valid NMLL 0.137, valid RMSE of mean 0.282, valid RMSE of std 0.072\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.06      0.04      0.06    987.96      1.01\n",
      "               noise      0.06      0.02      0.05      0.03      0.08    754.75      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.395268201828003\n",
      "Iteration 38/100: train NMLL: 0.752, valid NMLL 0.136, valid RMSE of mean 0.284, valid RMSE of std 0.063\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.06    863.42      1.00\n",
      "               noise      0.05      0.02      0.05      0.03      0.08    637.70      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.69134521484375\n",
      "Iteration 39/100: train NMLL: 0.729, valid NMLL 0.125, valid RMSE of mean 0.285, valid RMSE of std 0.057\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.10      0.17      0.06      0.04      0.07     12.36      1.58\n",
      "               noise      0.13      0.26      0.05      0.02      0.09     10.15      1.97\n",
      "\n",
      "Number of divergences: 99\n",
      "Validation using full posterior took  17.230459213256836\n",
      "Iteration 40/100: train NMLL: 0.721, valid NMLL 0.135, valid RMSE of mean 0.286, valid RMSE of std 0.056\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.06    808.50      1.00\n",
      "               noise      0.05      0.01      0.05      0.03      0.07    514.73      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.715250968933105\n",
      "Iteration 41/100: train NMLL: 0.702, valid NMLL 0.126, valid RMSE of mean 0.286, valid RMSE of std 0.052\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07   1195.12      1.01\n",
      "               noise      0.05      0.01      0.05      0.03      0.07    409.00      1.01\n",
      "\n",
      "Number of divergences: 8\n",
      "Validation using full posterior took  18.292134761810303\n",
      "Iteration 42/100: train NMLL: 0.689, valid NMLL 0.128, valid RMSE of mean 0.287, valid RMSE of std 0.047\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.06   1011.36      1.00\n",
      "               noise      0.05      0.01      0.05      0.03      0.07    783.06      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.01033902168274\n",
      "Iteration 43/100: train NMLL: 0.670, valid NMLL 0.123, valid RMSE of mean 0.288, valid RMSE of std 0.046\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.06      0.05      0.07    702.50      1.01\n",
      "               noise      0.05      0.01      0.05      0.03      0.07    892.27      1.00\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  18.724697828292847\n",
      "Iteration 44/100: train NMLL: 0.658, valid NMLL 0.124, valid RMSE of mean 0.288, valid RMSE of std 0.040\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.06    914.72      1.00\n",
      "               noise      0.05      0.01      0.05      0.03      0.07   1206.09      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.13210701942444\n",
      "Iteration 45/100: train NMLL: 0.641, valid NMLL 0.121, valid RMSE of mean 0.289, valid RMSE of std 0.039\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.06    975.87      1.00\n",
      "               noise      0.05      0.01      0.05      0.03      0.06    421.82      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.724586963653564\n",
      "Iteration 46/100: train NMLL: 0.620, valid NMLL 0.115, valid RMSE of mean 0.290, valid RMSE of std 0.036\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.06   1109.33      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.06    686.16      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.949737071990967\n",
      "Iteration 47/100: train NMLL: 0.601, valid NMLL 0.109, valid RMSE of mean 0.290, valid RMSE of std 0.025\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.06    813.53      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.06    484.71      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.695513010025024\n",
      "Iteration 48/100: train NMLL: 0.588, valid NMLL 0.109, valid RMSE of mean 0.289, valid RMSE of std 0.026\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.08      0.12      0.06      0.05      0.07     28.47      1.14\n",
      "               noise      0.08      0.18      0.04      0.02      0.06     19.28      1.24\n",
      "\n",
      "Number of divergences: 167\n",
      "Validation using full posterior took  19.05269694328308\n",
      "Iteration 49/100: train NMLL: 0.583, valid NMLL 0.116, valid RMSE of mean 0.290, valid RMSE of std 0.025\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    922.51      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.06    359.79      1.02\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.980626106262207\n",
      "Iteration 50/100: train NMLL: 0.561, valid NMLL 0.110, valid RMSE of mean 0.291, valid RMSE of std 0.022\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.06    114.18      1.03\n",
      "               noise      0.05      0.06      0.04      0.03      0.06     13.36      1.32\n",
      "\n",
      "Number of divergences: 153\n",
      "Validation using full posterior took  19.845297813415527\n",
      "Iteration 51/100: train NMLL: 0.579, valid NMLL 0.133, valid RMSE of mean 0.292, valid RMSE of std 0.035\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.11      0.06      0.05      0.06     28.61      1.14\n",
      "               noise      0.08      0.18      0.04      0.02      0.08     13.49      1.38\n",
      "\n",
      "Number of divergences: 127\n",
      "Validation using full posterior took  19.03952693939209\n",
      "Iteration 52/100: train NMLL: 0.555, valid NMLL 0.124, valid RMSE of mean 0.292, valid RMSE of std 0.030\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.10      0.06      0.05      0.07     31.03      1.12\n",
      "               noise      0.07      0.18      0.04      0.02      0.06     18.25      1.25\n",
      "\n",
      "Number of divergences: 152\n",
      "Validation using full posterior took  19.71464204788208\n",
      "Iteration 53/100: train NMLL: 0.510, valid NMLL 0.102, valid RMSE of mean 0.292, valid RMSE of std 0.018\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    959.60      1.00\n",
      "               noise      0.04      0.01      0.04      0.02      0.05    579.14      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.54835319519043\n",
      "Iteration 54/100: train NMLL: 0.485, valid NMLL 0.096, valid RMSE of mean 0.293, valid RMSE of std 0.015\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07   1118.02      1.00\n",
      "               noise      0.04      0.01      0.04      0.02      0.05    739.11      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.49114489555359\n",
      "Iteration 55/100: train NMLL: 0.477, valid NMLL 0.103, valid RMSE of mean 0.292, valid RMSE of std 0.015\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    615.13      1.00\n",
      "               noise      0.04      0.01      0.04      0.02      0.05    826.05      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.949917793273926\n",
      "Iteration 56/100: train NMLL: 0.467, valid NMLL 0.112, valid RMSE of mean 0.293, valid RMSE of std 0.015\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    618.58      1.00\n",
      "               noise      0.04      0.01      0.04      0.02      0.05    982.02      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.817007064819336\n",
      "Iteration 57/100: train NMLL: 0.462, valid NMLL 0.123, valid RMSE of mean 0.293, valid RMSE of std 0.016\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07   1255.18      1.00\n",
      "               noise      0.04      0.01      0.04      0.02      0.05    437.69      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.483829021453857\n",
      "Iteration 58/100: train NMLL: 0.447, valid NMLL 0.122, valid RMSE of mean 0.293, valid RMSE of std 0.017\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.06      0.06      0.05      0.06    109.52      1.03\n",
      "               noise      0.05      0.10      0.03      0.02      0.05     47.30      1.07\n",
      "\n",
      "Number of divergences: 177\n",
      "Validation using full posterior took  21.019079208374023\n",
      "Iteration 59/100: train NMLL: 0.440, valid NMLL 0.128, valid RMSE of mean 0.293, valid RMSE of std 0.017\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07   1051.74      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.05    746.57      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.4737331867218\n",
      "Iteration 60/100: train NMLL: 0.421, valid NMLL 0.127, valid RMSE of mean 0.295, valid RMSE of std 0.019\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1235.26      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    350.94      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  21.093159914016724\n",
      "Iteration 61/100: train NMLL: 0.415, valid NMLL 0.136, valid RMSE of mean 0.294, valid RMSE of std 0.020\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    828.90      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    499.17      1.01\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  20.87362504005432\n",
      "Iteration 62/100: train NMLL: 0.407, valid NMLL 0.143, valid RMSE of mean 0.294, valid RMSE of std 0.021\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07   1155.54      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.05    351.61      1.02\n",
      "\n",
      "Number of divergences: 2\n",
      "Validation using full posterior took  21.01322078704834\n",
      "Iteration 63/100: train NMLL: 0.405, valid NMLL 0.152, valid RMSE of mean 0.295, valid RMSE of std 0.022\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    977.18      1.01\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    905.09      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  21.169454097747803\n",
      "Iteration 64/100: train NMLL: 0.386, valid NMLL 0.153, valid RMSE of mean 0.296, valid RMSE of std 0.024\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1118.69      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    447.33      1.02\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  21.726452112197876\n",
      "Iteration 65/100: train NMLL: 0.381, valid NMLL 0.162, valid RMSE of mean 0.297, valid RMSE of std 0.026\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    781.27      1.01\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    864.50      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  21.655845165252686\n",
      "Iteration 66/100: train NMLL: 0.372, valid NMLL 0.171, valid RMSE of mean 0.296, valid RMSE of std 0.028\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1112.67      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    827.17      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.353471994400024\n",
      "Iteration 67/100: train NMLL: 0.366, valid NMLL 0.181, valid RMSE of mean 0.296, valid RMSE of std 0.029\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1076.19      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    910.35      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.08369207382202\n",
      "Iteration 68/100: train NMLL: 0.348, valid NMLL 0.184, valid RMSE of mean 0.296, valid RMSE of std 0.031\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1113.07      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    688.86      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.644723892211914\n",
      "Iteration 69/100: train NMLL: 0.336, valid NMLL 0.184, valid RMSE of mean 0.297, valid RMSE of std 0.032\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    835.52      1.01\n",
      "               noise      0.03      0.01      0.03      0.02      0.04   1110.58      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.45983910560608\n",
      "Iteration 70/100: train NMLL: 0.321, valid NMLL 0.186, valid RMSE of mean 0.297, valid RMSE of std 0.033\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    876.57      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    811.06      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.01271891593933\n",
      "Iteration 71/100: train NMLL: 0.311, valid NMLL 0.191, valid RMSE of mean 0.297, valid RMSE of std 0.035\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    862.13      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04   1135.49      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.415003061294556\n",
      "Iteration 72/100: train NMLL: 0.307, valid NMLL 0.200, valid RMSE of mean 0.299, valid RMSE of std 0.037\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1065.53      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    983.11      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.49560308456421\n",
      "Iteration 73/100: train NMLL: 0.304, valid NMLL 0.211, valid RMSE of mean 0.300, valid RMSE of std 0.038\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1152.59      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    948.94      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.478368759155273\n",
      "Iteration 74/100: train NMLL: 0.301, valid NMLL 0.220, valid RMSE of mean 0.300, valid RMSE of std 0.039\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1163.87      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    942.91      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.5438392162323\n",
      "Iteration 75/100: train NMLL: 0.293, valid NMLL 0.232, valid RMSE of mean 0.301, valid RMSE of std 0.041\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1080.13      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    808.07      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.64456295967102\n",
      "Iteration 76/100: train NMLL: 0.289, valid NMLL 0.242, valid RMSE of mean 0.301, valid RMSE of std 0.042\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1114.67      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    717.65      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  23.132278203964233\n",
      "Iteration 77/100: train NMLL: 0.282, valid NMLL 0.253, valid RMSE of mean 0.300, valid RMSE of std 0.044\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06   1035.11      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04   1196.26      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  23.13916802406311\n",
      "Iteration 78/100: train NMLL: 0.272, valid NMLL 0.260, valid RMSE of mean 0.301, valid RMSE of std 0.046\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1068.27      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    814.89      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  23.00130796432495\n",
      "Iteration 79/100: train NMLL: 0.267, valid NMLL 0.272, valid RMSE of mean 0.301, valid RMSE of std 0.047\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    583.14      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.04   1237.06      1.00\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  24.24803614616394\n",
      "Iteration 80/100: train NMLL: 0.255, valid NMLL 0.280, valid RMSE of mean 0.301, valid RMSE of std 0.048\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1304.80      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.04   1172.36      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  23.578057050704956\n",
      "Iteration 81/100: train NMLL: 0.247, valid NMLL 0.292, valid RMSE of mean 0.300, valid RMSE of std 0.050\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1017.56      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.04    954.56      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.254771947860718\n",
      "Iteration 82/100: train NMLL: 0.242, valid NMLL 0.292, valid RMSE of mean 0.301, valid RMSE of std 0.050\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1156.05      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.03    963.13      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  23.88408136367798\n",
      "Iteration 83/100: train NMLL: 0.228, valid NMLL 0.301, valid RMSE of mean 0.301, valid RMSE of std 0.052\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1363.49      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.03    848.35      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.156465768814087\n",
      "Iteration 84/100: train NMLL: 0.224, valid NMLL 0.312, valid RMSE of mean 0.301, valid RMSE of std 0.053\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    948.74      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.03    710.03      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.249030828475952\n",
      "Iteration 85/100: train NMLL: 0.219, valid NMLL 0.327, valid RMSE of mean 0.302, valid RMSE of std 0.054\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1055.58      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.03   1034.94      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.637548208236694\n",
      "Iteration 86/100: train NMLL: 0.215, valid NMLL 0.338, valid RMSE of mean 0.302, valid RMSE of std 0.055\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1379.38      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.03    774.92      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  23.55565595626831\n",
      "Iteration 87/100: train NMLL: 0.203, valid NMLL 0.340, valid RMSE of mean 0.301, valid RMSE of std 0.056\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    955.50      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.03    823.69      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.735615015029907\n",
      "Iteration 88/100: train NMLL: 0.198, valid NMLL 0.359, valid RMSE of mean 0.302, valid RMSE of std 0.058\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    934.74      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.03    682.58      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.48413109779358\n",
      "Iteration 89/100: train NMLL: 0.188, valid NMLL 0.364, valid RMSE of mean 0.302, valid RMSE of std 0.059\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1011.62      1.00\n",
      "               noise      0.03      0.00      0.02      0.02      0.03    852.31      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.672470092773438\n",
      "Iteration 90/100: train NMLL: 0.175, valid NMLL 0.372, valid RMSE of mean 0.302, valid RMSE of std 0.060\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1312.16      1.01\n",
      "               noise      0.02      0.00      0.02      0.02      0.03    760.15      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.592674016952515\n",
      "Iteration 91/100: train NMLL: 0.170, valid NMLL 0.380, valid RMSE of mean 0.302, valid RMSE of std 0.060\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    922.67      1.00\n",
      "               noise      0.02      0.00      0.02      0.02      0.03   1049.21      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.79585099220276\n",
      "Iteration 92/100: train NMLL: 0.163, valid NMLL 0.391, valid RMSE of mean 0.302, valid RMSE of std 0.061\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1080.45      1.00\n",
      "               noise      0.02      0.00      0.02      0.02      0.03    845.58      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.620677947998047\n",
      "Iteration 93/100: train NMLL: 0.151, valid NMLL 0.401, valid RMSE of mean 0.302, valid RMSE of std 0.063\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1110.47      1.00\n",
      "               noise      0.02      0.00      0.02      0.02      0.03    609.22      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.4564151763916\n",
      "Iteration 94/100: train NMLL: 0.144, valid NMLL 0.415, valid RMSE of mean 0.302, valid RMSE of std 0.064\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    997.86      1.00\n",
      "               noise      0.02      0.00      0.02      0.02      0.03   1160.24      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.287950038909912\n",
      "Iteration 95/100: train NMLL: 0.141, valid NMLL 0.417, valid RMSE of mean 0.302, valid RMSE of std 0.064\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    841.99      1.00\n",
      "               noise      0.02      0.00      0.02      0.02      0.03   1151.45      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.569256067276\n",
      "Iteration 96/100: train NMLL: 0.137, valid NMLL 0.431, valid RMSE of mean 0.303, valid RMSE of std 0.065\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    893.25      1.00\n",
      "               noise      0.02      0.00      0.02      0.02      0.03   1148.18      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  25.156872987747192\n",
      "Iteration 97/100: train NMLL: 0.128, valid NMLL 0.434, valid RMSE of mean 0.303, valid RMSE of std 0.065\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1129.60      1.00\n",
      "               noise      0.02      0.00      0.02      0.02      0.03   1050.50      1.00\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  25.08238697052002\n",
      "Iteration 98/100: train NMLL: 0.122, valid NMLL 0.449, valid RMSE of mean 0.303, valid RMSE of std 0.067\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1050.26      1.00\n",
      "               noise      0.02      0.00      0.02      0.02      0.03   1233.10      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  25.539297103881836\n",
      "Iteration 99/100: train NMLL: 0.115, valid NMLL 0.459, valid RMSE of mean 0.303, valid RMSE of std 0.068\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1304.50      1.00\n",
      "               noise      0.02      0.00      0.02      0.02      0.03   1347.85      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  25.396997928619385\n",
      "Iteration 100/100: train NMLL: 0.109, valid NMLL 0.479, valid RMSE of mean 0.303, valid RMSE of std 0.069\n",
      "Repetition 2 took 3273.0203909873962 sec.\n",
      "\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.29      0.24      0.21      0.04      0.62    619.29      1.01\n",
      "               noise      0.65      0.49      0.54      0.06      1.26    500.05      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  9.726388931274414\n",
      "Iteration 1/100: train NMLL: 1.389, valid NMLL 1.139, valid RMSE of mean 0.994, valid RMSE of std 0.682\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.20      0.18      0.13      0.04      0.42    276.17      1.03\n",
      "               noise      0.48      0.43      0.33      0.03      1.02    416.07      1.02\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  9.361919164657593\n",
      "Iteration 2/100: train NMLL: 1.297, valid NMLL 0.814, valid RMSE of mean 0.972, valid RMSE of std 0.660\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.13      0.12      0.10      0.03      0.20    321.05      1.01\n",
      "               noise      0.29      0.31      0.19      0.02      0.59    360.29      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  10.460697889328003\n",
      "Iteration 3/100: train NMLL: 1.187, valid NMLL 0.584, valid RMSE of mean 0.900, valid RMSE of std 0.633\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.12      0.16      0.08      0.03      0.16    217.90      1.03\n",
      "               noise      0.26      0.30      0.15      0.01      0.61    225.07      1.03\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  10.541053295135498\n",
      "Iteration 4/100: train NMLL: 1.196, valid NMLL 0.479, valid RMSE of mean 0.823, valid RMSE of std 0.603\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.13      0.17      0.08      0.03      0.31    167.46      1.04\n",
      "               noise      0.35      0.39      0.20      0.01      0.90    170.45      1.05\n",
      "\n",
      "Number of divergences: 4\n",
      "Validation using full posterior took  11.490926265716553\n",
      "Iteration 5/100: train NMLL: 1.260, valid NMLL 0.550, valid RMSE of mean 0.657, valid RMSE of std 0.580\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.03      0.07      0.04      0.09    379.29      1.01\n",
      "               noise      0.16      0.21      0.11      0.01      0.31    413.61      1.02\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  11.808576822280884\n",
      "Iteration 6/100: train NMLL: 1.170, valid NMLL 0.380, valid RMSE of mean 0.619, valid RMSE of std 0.548\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.09      0.12      0.06      0.03      0.09     41.81      1.14\n",
      "               noise      0.20      0.29      0.12      0.02      0.43     49.46      1.12\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  12.760197877883911\n",
      "Iteration 7/100: train NMLL: 1.205, valid NMLL 0.400, valid RMSE of mean 0.480, valid RMSE of std 0.518\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.02      0.06      0.04      0.09    693.01      1.00\n",
      "               noise      0.13      0.12      0.10      0.02      0.26    570.20      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  12.469671249389648\n",
      "Iteration 8/100: train NMLL: 1.148, valid NMLL 0.360, valid RMSE of mean 0.470, valid RMSE of std 0.501\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.03      0.08    685.31      1.00\n",
      "               noise      0.14      0.11      0.11      0.02      0.26    721.19      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  13.411707878112793\n",
      "Iteration 9/100: train NMLL: 1.175, valid NMLL 0.386, valid RMSE of mean 0.409, valid RMSE of std 0.455\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.07      0.06      0.03      0.08    147.91      1.03\n",
      "               noise      0.16      0.17      0.12      0.03      0.31    155.55      1.03\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  12.812410831451416\n",
      "Iteration 10/100: train NMLL: 1.176, valid NMLL 0.414, valid RMSE of mean 0.381, valid RMSE of std 0.444\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.04      0.08    668.96      1.00\n",
      "               noise      0.13      0.11      0.10      0.02      0.23    536.85      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  13.385586261749268\n",
      "Iteration 11/100: train NMLL: 1.140, valid NMLL 0.353, valid RMSE of mean 0.358, valid RMSE of std 0.406\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.04      0.07    824.95      1.00\n",
      "               noise      0.12      0.09      0.09      0.02      0.22    543.74      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  12.78524899482727\n",
      "Iteration 12/100: train NMLL: 1.141, valid NMLL 0.322, valid RMSE of mean 0.353, valid RMSE of std 0.346\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.04      0.07    610.20      1.00\n",
      "               noise      0.10      0.07      0.08      0.02      0.18    844.96      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  13.64729619026184\n",
      "Iteration 13/100: train NMLL: 1.089, valid NMLL 0.270, valid RMSE of mean 0.349, valid RMSE of std 0.328\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.03      0.07    641.21      1.00\n",
      "               noise      0.11      0.07      0.09      0.03      0.20    979.93      1.00\n",
      "\n",
      "Number of divergences: 1\n",
      "Validation using full posterior took  13.34390926361084\n",
      "Iteration 14/100: train NMLL: 1.126, valid NMLL 0.305, valid RMSE of mean 0.271, valid RMSE of std 0.300\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.07    681.78      1.00\n",
      "               noise      0.10      0.07      0.08      0.02      0.18    912.76      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  13.805997133255005\n",
      "Iteration 15/100: train NMLL: 1.111, valid NMLL 0.273, valid RMSE of mean 0.263, valid RMSE of std 0.264\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.07    285.49      1.02\n",
      "               noise      0.09      0.05      0.07      0.02      0.15    907.69      1.00\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  13.273492097854614\n",
      "Iteration 16/100: train NMLL: 1.086, valid NMLL 0.219, valid RMSE of mean 0.198, valid RMSE of std 0.219\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.07    613.48      1.00\n",
      "               noise      0.09      0.06      0.07      0.02      0.16    775.49      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.163670063018799\n",
      "Iteration 17/100: train NMLL: 1.090, valid NMLL 0.224, valid RMSE of mean 0.130, valid RMSE of std 0.197\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.07    914.46      1.00\n",
      "               noise      0.08      0.05      0.06      0.02      0.13    485.86      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  13.569820165634155\n",
      "Iteration 18/100: train NMLL: 1.042, valid NMLL 0.163, valid RMSE of mean 0.130, valid RMSE of std 0.166\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.07    785.77      1.01\n",
      "               noise      0.07      0.04      0.06      0.02      0.11    441.65      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.200443267822266\n",
      "Iteration 19/100: train NMLL: 1.001, valid NMLL 0.117, valid RMSE of mean 0.127, valid RMSE of std 0.142\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07     25.61      1.12\n",
      "               noise      0.06      0.04      0.05      0.02      0.10     86.27      1.04\n",
      "\n",
      "Number of divergences: 74\n",
      "Validation using full posterior took  13.245115041732788\n",
      "Iteration 20/100: train NMLL: 0.973, valid NMLL 0.094, valid RMSE of mean 0.127, valid RMSE of std 0.119\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.04      0.07    932.31      1.00\n",
      "               noise      0.05      0.03      0.05      0.02      0.09    829.50      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.380481958389282\n",
      "Iteration 21/100: train NMLL: 0.937, valid NMLL 0.064, valid RMSE of mean 0.126, valid RMSE of std 0.104\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.09      0.17      0.06      0.04      0.07     28.76      1.15\n",
      "               noise      0.12      0.26      0.05      0.01      0.15     19.12      1.27\n",
      "\n",
      "Number of divergences: 287\n",
      "Validation using full posterior took  13.810338020324707\n",
      "Iteration 22/100: train NMLL: 0.921, valid NMLL 0.071, valid RMSE of mean 0.125, valid RMSE of std 0.099\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.14      0.23      0.06      0.03      0.45      6.19      1.65\n",
      "               noise      0.18      0.37      0.04      0.01      0.91      5.02      2.01\n",
      "\n",
      "Number of divergences: 48\n",
      "Validation using full posterior took  14.039923906326294\n",
      "Iteration 23/100: train NMLL: 0.864, valid NMLL 0.020, valid RMSE of mean 0.124, valid RMSE of std 0.079\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.09      0.15      0.06      0.04      0.07     15.13      1.39\n",
      "               noise      0.11      0.27      0.04      0.01      0.09     12.33      1.57\n",
      "\n",
      "Number of divergences: 106\n",
      "Validation using full posterior took  13.89940094947815\n",
      "Iteration 24/100: train NMLL: 0.843, valid NMLL 0.030, valid RMSE of mean 0.122, valid RMSE of std 0.087\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    924.07      1.00\n",
      "               noise      0.04      0.02      0.04      0.02      0.06    807.64      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.645138025283813\n",
      "Iteration 25/100: train NMLL: 0.794, valid NMLL -0.003, valid RMSE of mean 0.122, valid RMSE of std 0.074\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    948.30      1.00\n",
      "               noise      0.04      0.02      0.04      0.02      0.07    849.18      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.307746887207031\n",
      "Iteration 26/100: train NMLL: 0.796, valid NMLL 0.019, valid RMSE of mean 0.115, valid RMSE of std 0.076\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    974.95      1.00\n",
      "               noise      0.04      0.02      0.04      0.02      0.07    712.84      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.75703501701355\n",
      "Iteration 27/100: train NMLL: 0.769, valid NMLL 0.003, valid RMSE of mean 0.108, valid RMSE of std 0.059\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.08      0.14      0.06      0.05      0.07     20.15      1.23\n",
      "               noise      0.09      0.24      0.04      0.02      0.08     14.24      1.41\n",
      "\n",
      "Number of divergences: 140\n",
      "Validation using full posterior took  14.018868923187256\n",
      "Iteration 28/100: train NMLL: 0.760, valid NMLL 0.008, valid RMSE of mean 0.108, valid RMSE of std 0.046\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.15      0.25      0.06      0.04      0.52      4.73      1.75\n",
      "               noise      0.20      0.39      0.04      0.01      0.94      3.65      2.20\n",
      "\n",
      "Number of divergences: 103\n",
      "Validation using full posterior took  14.233307123184204\n",
      "Iteration 29/100: train NMLL: 0.733, valid NMLL 0.001, valid RMSE of mean 0.107, valid RMSE of std 0.043\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    855.91      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.05    405.97      1.01\n",
      "\n",
      "Number of divergences: 2\n",
      "Validation using full posterior took  14.347897052764893\n",
      "Iteration 30/100: train NMLL: 0.683, valid NMLL -0.033, valid RMSE of mean 0.105, valid RMSE of std 0.032\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.10      0.17      0.06      0.05      0.07     14.80      1.40\n",
      "               noise      0.10      0.26      0.03      0.01      0.08     11.36      1.68\n",
      "\n",
      "Number of divergences: 141\n",
      "Validation using full posterior took  14.76295018196106\n",
      "Iteration 31/100: train NMLL: 0.671, valid NMLL -0.025, valid RMSE of mean 0.106, valid RMSE of std 0.032\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.17      0.27      0.06      0.04      0.59      3.41      1.95\n",
      "               noise      0.25      0.44      0.04      0.01      1.04      2.73      3.51\n",
      "\n",
      "Number of divergences: 169\n",
      "Validation using full posterior took  14.091033935546875\n",
      "Iteration 32/100: train NMLL: 0.660, valid NMLL -0.012, valid RMSE of mean 0.105, valid RMSE of std 0.038\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    943.97      1.01\n",
      "               noise      0.03      0.01      0.03      0.01      0.04    523.61      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.443655967712402\n",
      "Iteration 33/100: train NMLL: 0.593, valid NMLL -0.055, valid RMSE of mean 0.105, valid RMSE of std 0.028\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.05      0.06      0.05      0.07    157.72      1.02\n",
      "               noise      0.05      0.12      0.03      0.01      0.05     20.92      1.20\n",
      "\n",
      "Number of divergences: 198\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  15.379335880279541\n",
      "Iteration 34/100: train NMLL: 0.636, valid NMLL -0.017, valid RMSE of mean 0.102, valid RMSE of std 0.030\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    392.56      1.01\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    308.39      1.03\n",
      "\n",
      "Number of divergences: 158\n",
      "Validation using full posterior took  15.918900966644287\n",
      "Iteration 35/100: train NMLL: 0.576, valid NMLL -0.052, valid RMSE of mean 0.101, valid RMSE of std 0.026\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07   1075.97      1.00\n",
      "               noise      0.03      0.01      0.03      0.01      0.04    504.53      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.44572401046753\n",
      "Iteration 36/100: train NMLL: 0.557, valid NMLL -0.056, valid RMSE of mean 0.098, valid RMSE of std 0.027\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.07      0.06      0.05      0.07     76.98      1.04\n",
      "               noise      0.04      0.11      0.03      0.01      0.04     36.29      1.10\n",
      "\n",
      "Number of divergences: 202\n",
      "Validation using full posterior took  16.318293809890747\n",
      "Iteration 37/100: train NMLL: 0.556, valid NMLL -0.043, valid RMSE of mean 0.098, valid RMSE of std 0.026\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    809.58      1.00\n",
      "               noise      0.03      0.01      0.02      0.01      0.04    568.94      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.019505977630615\n",
      "Iteration 38/100: train NMLL: 0.506, valid NMLL -0.055, valid RMSE of mean 0.098, valid RMSE of std 0.033\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    878.86      1.00\n",
      "               noise      0.02      0.01      0.02      0.01      0.04    815.82      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.501240015029907\n",
      "Iteration 39/100: train NMLL: 0.484, valid NMLL -0.056, valid RMSE of mean 0.097, valid RMSE of std 0.035\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.08      0.12      0.06      0.05      0.07     26.54      1.15\n",
      "               noise      0.06      0.17      0.02      0.01      0.04     20.91      1.21\n",
      "\n",
      "Number of divergences: 444\n",
      "Validation using full posterior took  15.974585056304932\n",
      "Iteration 40/100: train NMLL: 0.483, valid NMLL -0.051, valid RMSE of mean 0.097, valid RMSE of std 0.031\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.14      0.24      0.06      0.02      0.48     11.63      1.87\n",
      "               noise      0.16      0.35      0.02      0.01      0.87     10.17      2.11\n",
      "\n",
      "Number of divergences: 267\n",
      "Validation using full posterior took  16.255014181137085\n",
      "Iteration 41/100: train NMLL: 0.453, valid NMLL -0.055, valid RMSE of mean 0.097, valid RMSE of std 0.034\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    911.94      1.00\n",
      "               noise      0.02      0.01      0.02      0.01      0.03    724.51      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.58060097694397\n",
      "Iteration 42/100: train NMLL: 0.422, valid NMLL -0.057, valid RMSE of mean 0.096, valid RMSE of std 0.039\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    781.47      1.00\n",
      "               noise      0.02      0.01      0.02      0.01      0.03    562.55      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.176780223846436\n",
      "Iteration 43/100: train NMLL: 0.398, valid NMLL -0.056, valid RMSE of mean 0.095, valid RMSE of std 0.042\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.11      0.18      0.06      0.04      0.07     16.67      1.33\n",
      "               noise      0.11      0.29      0.02      0.01      0.10     12.81      1.51\n",
      "\n",
      "Number of divergences: 308\n",
      "Validation using full posterior took  15.932440042495728\n",
      "Iteration 44/100: train NMLL: 0.429, valid NMLL -0.052, valid RMSE of mean 0.093, valid RMSE of std 0.026\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    511.97      1.01\n",
      "               noise      0.02      0.01      0.02      0.01      0.03    750.82      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.2497501373291\n",
      "Iteration 45/100: train NMLL: 0.361, valid NMLL -0.052, valid RMSE of mean 0.093, valid RMSE of std 0.045\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.06      0.06      0.05      0.07    112.46      1.03\n",
      "               noise      0.04      0.12      0.02      0.01      0.04     24.49      1.16\n",
      "\n",
      "Number of divergences: 163\n",
      "Validation using full posterior took  16.730857133865356\n",
      "Iteration 46/100: train NMLL: 0.404, valid NMLL -0.047, valid RMSE of mean 0.092, valid RMSE of std 0.027\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    653.52      1.01\n",
      "               noise      0.02      0.00      0.02      0.01      0.03    970.37      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.060085773468018\n",
      "Iteration 47/100: train NMLL: 0.327, valid NMLL -0.038, valid RMSE of mean 0.092, valid RMSE of std 0.053\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.17      0.29      0.06      0.03      0.59     14.01      1.55\n",
      "               noise      0.22      0.39      0.02      0.01      0.98      8.42      2.74\n",
      "\n",
      "Number of divergences: 181\n",
      "Validation using full posterior took  15.959234952926636\n",
      "Iteration 48/100: train NMLL: 0.452, valid NMLL -0.007, valid RMSE of mean 0.092, valid RMSE of std 0.013\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1108.23      1.00\n",
      "               noise      0.02      0.00      0.02      0.01      0.03    618.01      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.214328050613403\n",
      "Iteration 49/100: train NMLL: 0.301, valid NMLL -0.031, valid RMSE of mean 0.091, valid RMSE of std 0.055\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.13      0.23      0.06      0.03      0.32     16.57      1.38\n",
      "               noise      0.15      0.33      0.02      0.01      0.84     10.69      1.86\n",
      "\n",
      "Number of divergences: 264\n",
      "Validation using full posterior took  15.959053039550781\n",
      "Iteration 50/100: train NMLL: 0.386, valid NMLL -0.035, valid RMSE of mean 0.090, valid RMSE of std 0.022\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.11      0.06      0.05      0.07     28.15      1.14\n",
      "               noise      0.06      0.19      0.02      0.01      0.06     15.93      1.30\n",
      "\n",
      "Number of divergences: 394\n",
      "Validation using full posterior took  17.66357684135437\n",
      "Iteration 51/100: train NMLL: 0.357, valid NMLL -0.042, valid RMSE of mean 0.088, valid RMSE of std 0.026\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1096.73      1.01\n",
      "               noise      0.02      0.00      0.02      0.01      0.02   1147.69      1.00\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  16.846165895462036\n",
      "Iteration 52/100: train NMLL: 0.244, valid NMLL -0.018, valid RMSE of mean 0.088, valid RMSE of std 0.062\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    892.16      1.01\n",
      "               noise      0.02      0.00      0.02      0.01      0.02    942.01      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.304062128067017\n",
      "Iteration 53/100: train NMLL: 0.235, valid NMLL -0.011, valid RMSE of mean 0.088, valid RMSE of std 0.063\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    802.03      1.00\n",
      "               noise      0.02      0.00      0.02      0.01      0.02   1094.41      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.31086492538452\n",
      "Iteration 54/100: train NMLL: 0.219, valid NMLL -0.002, valid RMSE of mean 0.088, valid RMSE of std 0.066\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    939.68      1.00\n",
      "               noise      0.02      0.00      0.02      0.01      0.02   1158.53      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.977846145629883\n",
      "Iteration 55/100: train NMLL: 0.204, valid NMLL -0.001, valid RMSE of mean 0.088, valid RMSE of std 0.067\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.08      0.12      0.06      0.05      0.07     24.97      1.16\n",
      "               noise      0.06      0.19      0.02      0.01      0.04     13.55      1.39\n",
      "\n",
      "Number of divergences: 149\n",
      "Validation using full posterior took  17.67735195159912\n",
      "Iteration 56/100: train NMLL: 0.279, valid NMLL -0.038, valid RMSE of mean 0.087, valid RMSE of std 0.040\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    987.58      1.00\n",
      "               noise      0.02      0.00      0.02      0.01      0.02   1089.87      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.040514945983887\n",
      "Iteration 57/100: train NMLL: 0.171, valid NMLL 0.025, valid RMSE of mean 0.087, valid RMSE of std 0.073\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1318.52      1.00\n",
      "               noise      0.02      0.00      0.02      0.01      0.02    453.52      1.00\n",
      "\n",
      "Number of divergences: 1\n",
      "Validation using full posterior took  17.827911853790283\n",
      "Iteration 58/100: train NMLL: 0.177, valid NMLL 0.019, valid RMSE of mean 0.087, valid RMSE of std 0.070\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    906.94      1.00\n",
      "               noise      0.02      0.00      0.02      0.01      0.02   1109.07      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.124938011169434\n",
      "Iteration 59/100: train NMLL: 0.163, valid NMLL 0.031, valid RMSE of mean 0.086, valid RMSE of std 0.073\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.09      0.17      0.06      0.05      0.07     17.31      1.30\n",
      "               noise      0.09      0.25      0.02      0.01      0.08      9.75      1.85\n",
      "\n",
      "Number of divergences: 120\n",
      "Validation using full posterior took  18.18607473373413\n",
      "Iteration 60/100: train NMLL: 0.233, valid NMLL -0.028, valid RMSE of mean 0.087, valid RMSE of std 0.047\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1032.75      1.00\n",
      "               noise      0.02      0.00      0.01      0.01      0.02    823.13      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.102753162384033\n",
      "Iteration 61/100: train NMLL: 0.130, valid NMLL 0.044, valid RMSE of mean 0.086, valid RMSE of std 0.076\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1125.21      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.02    964.10      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.686185121536255\n",
      "Iteration 62/100: train NMLL: 0.118, valid NMLL 0.065, valid RMSE of mean 0.086, valid RMSE of std 0.079\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    775.78      1.01\n",
      "               noise      0.01      0.00      0.01      0.01      0.02    994.19      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.650382041931152\n",
      "Iteration 63/100: train NMLL: 0.110, valid NMLL 0.069, valid RMSE of mean 0.086, valid RMSE of std 0.079\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.08      0.13      0.06      0.05      0.07     27.17      1.16\n",
      "               noise      0.07      0.20      0.01      0.01      0.08     11.38      1.51\n",
      "\n",
      "Number of divergences: 172\n",
      "Validation using full posterior took  18.993118047714233\n",
      "Iteration 64/100: train NMLL: 0.224, valid NMLL -0.019, valid RMSE of mean 0.086, valid RMSE of std 0.041\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1052.39      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.02    831.49      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.34946608543396\n",
      "Iteration 65/100: train NMLL: 0.080, valid NMLL 0.090, valid RMSE of mean 0.086, valid RMSE of std 0.082\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.09      0.06      0.05      0.07     86.55      1.04\n",
      "               noise      0.02      0.10      0.01      0.01      0.02     58.08      1.06\n",
      "\n",
      "Number of divergences: 198\n",
      "Validation using full posterior took  19.241387844085693\n",
      "Iteration 66/100: train NMLL: 0.076, valid NMLL 0.098, valid RMSE of mean 0.086, valid RMSE of std 0.082\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1014.22      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.02    818.86      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.8630268573761\n",
      "Iteration 67/100: train NMLL: 0.059, valid NMLL 0.110, valid RMSE of mean 0.086, valid RMSE of std 0.084\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1253.45      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.02   1159.27      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.81790018081665\n",
      "Iteration 68/100: train NMLL: 0.048, valid NMLL 0.120, valid RMSE of mean 0.086, valid RMSE of std 0.085\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.10      0.06      0.05      0.07     85.42      1.04\n",
      "               noise      0.02      0.11      0.01      0.01      0.02     63.69      1.05\n",
      "\n",
      "Number of divergences: 153\n",
      "Validation using full posterior took  20.013895988464355\n",
      "Iteration 69/100: train NMLL: 0.039, valid NMLL 0.116, valid RMSE of mean 0.086, valid RMSE of std 0.085\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1332.70      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.02    809.68      1.01\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  19.543740272521973\n",
      "Iteration 70/100: train NMLL: 0.023, valid NMLL 0.126, valid RMSE of mean 0.086, valid RMSE of std 0.087\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1265.40      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.02    927.37      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.972376108169556\n",
      "Iteration 71/100: train NMLL: 0.014, valid NMLL 0.147, valid RMSE of mean 0.086, valid RMSE of std 0.089\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1185.79      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.02   1098.36      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.024036645889282\n",
      "Iteration 72/100: train NMLL: 0.000, valid NMLL 0.154, valid RMSE of mean 0.085, valid RMSE of std 0.090\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.05      0.06      0.05      0.07    189.52      1.02\n",
      "               noise      0.03      0.10      0.01      0.01      0.02     43.88      1.08\n",
      "\n",
      "Number of divergences: 211\n",
      "Validation using full posterior took  20.515180110931396\n",
      "Iteration 73/100: train NMLL: 0.040, valid NMLL 0.059, valid RMSE of mean 0.085, valid RMSE of std 0.076\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    929.03      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.02    625.20      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.10087299346924\n",
      "Iteration 74/100: train NMLL: -0.025, valid NMLL 0.173, valid RMSE of mean 0.085, valid RMSE of std 0.092\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1096.09      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.02    726.66      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.593389987945557\n",
      "Iteration 75/100: train NMLL: -0.027, valid NMLL 0.177, valid RMSE of mean 0.085, valid RMSE of std 0.092\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1012.61      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.02    780.64      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.053910970687866\n",
      "Iteration 76/100: train NMLL: -0.026, valid NMLL 0.177, valid RMSE of mean 0.085, valid RMSE of std 0.091\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    947.37      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.02    836.80      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.61596703529358\n",
      "Iteration 77/100: train NMLL: -0.038, valid NMLL 0.191, valid RMSE of mean 0.085, valid RMSE of std 0.093\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    937.62      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.02    868.67      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.805038928985596\n",
      "Iteration 78/100: train NMLL: -0.047, valid NMLL 0.203, valid RMSE of mean 0.085, valid RMSE of std 0.094\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1247.95      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.02   1204.21      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.934119939804077\n",
      "Iteration 79/100: train NMLL: -0.060, valid NMLL 0.209, valid RMSE of mean 0.085, valid RMSE of std 0.095\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    804.21      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.02    934.63      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.90284490585327\n",
      "Iteration 80/100: train NMLL: -0.065, valid NMLL 0.226, valid RMSE of mean 0.085, valid RMSE of std 0.096\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1212.74      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.02    327.39      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  21.304298877716064\n",
      "Iteration 81/100: train NMLL: -0.075, valid NMLL 0.239, valid RMSE of mean 0.085, valid RMSE of std 0.097\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1067.70      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.02    961.91      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  21.38204526901245\n",
      "Iteration 82/100: train NMLL: -0.085, valid NMLL 0.254, valid RMSE of mean 0.085, valid RMSE of std 0.098\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1187.78      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.02    375.16      1.00\n",
      "\n",
      "Number of divergences: 1\n",
      "Validation using full posterior took  21.982576847076416\n",
      "Iteration 83/100: train NMLL: -0.092, valid NMLL 0.254, valid RMSE of mean 0.085, valid RMSE of std 0.098\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    114.33      1.04\n",
      "               noise      0.02      0.06      0.01      0.01      0.03     15.61      1.30\n",
      "\n",
      "Number of divergences: 210\n",
      "Validation using full posterior took  22.24169087409973\n",
      "Iteration 84/100: train NMLL: 0.017, valid NMLL 0.054, valid RMSE of mean 0.085, valid RMSE of std 0.071\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    970.17      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.01    764.64      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.103678941726685\n",
      "Iteration 85/100: train NMLL: -0.115, valid NMLL 0.295, valid RMSE of mean 0.084, valid RMSE of std 0.101\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    991.36      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.01    734.97      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  21.75869607925415\n",
      "Iteration 86/100: train NMLL: -0.114, valid NMLL 0.294, valid RMSE of mean 0.085, valid RMSE of std 0.100\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    774.92      1.01\n",
      "               noise      0.01      0.00      0.01      0.01      0.01    919.36      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  21.930367946624756\n",
      "Iteration 87/100: train NMLL: -0.121, valid NMLL 0.305, valid RMSE of mean 0.084, valid RMSE of std 0.101\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1168.17      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.01   1080.99      1.00\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  22.003959894180298\n",
      "Iteration 88/100: train NMLL: -0.132, valid NMLL 0.321, valid RMSE of mean 0.084, valid RMSE of std 0.102\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1066.54      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.01    907.88      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.74935293197632\n",
      "Iteration 89/100: train NMLL: -0.145, valid NMLL 0.333, valid RMSE of mean 0.084, valid RMSE of std 0.103\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    598.32      1.00\n",
      "               noise      0.01      0.01      0.01      0.01      0.01     67.32      1.04\n",
      "\n",
      "Number of divergences: 183\n",
      "Validation using full posterior took  22.346568822860718\n",
      "Iteration 90/100: train NMLL: -0.148, valid NMLL 0.308, valid RMSE of mean 0.084, valid RMSE of std 0.102\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    951.15      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.01   1155.45      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  23.164465188980103\n",
      "Iteration 91/100: train NMLL: -0.157, valid NMLL 0.340, valid RMSE of mean 0.084, valid RMSE of std 0.103\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    634.97      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.01    841.17      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  23.18539023399353\n",
      "Iteration 92/100: train NMLL: -0.170, valid NMLL 0.368, valid RMSE of mean 0.084, valid RMSE of std 0.105\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    959.99      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.01    996.41      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  23.544223070144653\n",
      "Iteration 93/100: train NMLL: -0.174, valid NMLL 0.366, valid RMSE of mean 0.084, valid RMSE of std 0.105\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1227.75      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.01   1149.00      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  23.50778603553772\n",
      "Iteration 94/100: train NMLL: -0.182, valid NMLL 0.382, valid RMSE of mean 0.084, valid RMSE of std 0.106\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1065.87      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.01    959.71      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.01771593093872\n",
      "Iteration 95/100: train NMLL: -0.197, valid NMLL 0.403, valid RMSE of mean 0.084, valid RMSE of std 0.107\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1095.96      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.01   1005.44      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.061749935150146\n",
      "Iteration 96/100: train NMLL: -0.201, valid NMLL 0.414, valid RMSE of mean 0.084, valid RMSE of std 0.108\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1157.65      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.01    854.47      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.373565912246704\n",
      "Iteration 97/100: train NMLL: -0.206, valid NMLL 0.426, valid RMSE of mean 0.084, valid RMSE of std 0.108\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    625.14      1.01\n",
      "               noise      0.01      0.00      0.01      0.01      0.01    973.79      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.315387964248657\n",
      "Iteration 98/100: train NMLL: -0.217, valid NMLL 0.442, valid RMSE of mean 0.084, valid RMSE of std 0.109\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1043.63      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.01   1218.04      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.74688196182251\n",
      "Iteration 99/100: train NMLL: -0.226, valid NMLL 0.460, valid RMSE of mean 0.084, valid RMSE of std 0.110\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    881.23      1.00\n",
      "               noise      0.01      0.00      0.01      0.01      0.01    935.75      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.61886715888977\n",
      "Iteration 100/100: train NMLL: -0.227, valid NMLL 0.461, valid RMSE of mean 0.084, valid RMSE of std 0.110\n",
      "Repetition 3 took 3093.7869760990143 sec.\n",
      "\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.47      0.30      0.40      0.05      0.92    871.38      1.00\n",
      "               noise      1.05      0.56      0.92      0.35      1.80    803.08      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  9.009407043457031\n",
      "Iteration 1/100: train NMLL: 1.587, valid NMLL 1.493, valid RMSE of mean 0.783, valid RMSE of std 0.524\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.44      0.28      0.38      0.04      0.83    833.53      1.00\n",
      "               noise      0.97      0.53      0.84      0.29      1.72    659.25      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  9.19034194946289\n",
      "Iteration 2/100: train NMLL: 1.538, valid NMLL 1.467, valid RMSE of mean 0.787, valid RMSE of std 0.504\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.37      0.25      0.32      0.02      0.71    846.98      1.00\n",
      "               noise      0.85      0.45      0.75      0.24      1.51    554.84      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  8.892003059387207\n",
      "Iteration 3/100: train NMLL: 1.484, valid NMLL 1.409, valid RMSE of mean 0.838, valid RMSE of std 0.502\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.34      0.24      0.29      0.01      0.63    828.60      1.00\n",
      "               noise      0.81      0.46      0.71      0.17      1.45    721.99      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  9.36994481086731\n",
      "Iteration 4/100: train NMLL: 1.482, valid NMLL 1.403, valid RMSE of mean 0.826, valid RMSE of std 0.506\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.23      0.19      0.20      0.01      0.45    421.34      1.01\n",
      "               noise      0.59      0.41      0.52      0.04      1.11    505.29      1.01\n",
      "\n",
      "Number of divergences: 1\n",
      "Validation using full posterior took  10.859172105789185\n",
      "Iteration 5/100: train NMLL: 1.388, valid NMLL 1.334, valid RMSE of mean 0.874, valid RMSE of std 0.438\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.17      0.17      0.10      0.02      0.38    246.68      1.01\n",
      "               noise      0.44      0.35      0.37      0.02      0.88    279.47      1.01\n",
      "\n",
      "Number of divergences: 1\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  11.659791946411133\n",
      "Iteration 6/100: train NMLL: 1.345, valid NMLL 0.999, valid RMSE of mean 0.827, valid RMSE of std 0.390\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.11      0.14      0.06      0.02      0.27    192.99      1.02\n",
      "               noise      0.33      0.36      0.20      0.01      0.78    254.10      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  12.796288013458252\n",
      "Iteration 7/100: train NMLL: 1.272, valid NMLL 0.605, valid RMSE of mean 0.645, valid RMSE of std 0.402\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.09      0.16      0.05      0.01      0.14    217.20      1.01\n",
      "               noise      0.26      0.29      0.16      0.02      0.65    207.34      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.017137289047241\n",
      "Iteration 8/100: train NMLL: 1.258, valid NMLL 0.540, valid RMSE of mean 0.528, valid RMSE of std 0.391\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.11      0.05      0.01      0.09     40.54      1.17\n",
      "               noise      0.22      0.26      0.13      0.02      0.49     62.12      1.10\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.3524169921875\n",
      "Iteration 9/100: train NMLL: 1.209, valid NMLL 0.484, valid RMSE of mean 0.532, valid RMSE of std 0.384\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.09      0.05      0.02      0.08     73.86      1.07\n",
      "               noise      0.18      0.20      0.12      0.02      0.31     69.05      1.07\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  13.845101118087769\n",
      "Iteration 10/100: train NMLL: 1.182, valid NMLL 0.442, valid RMSE of mean 0.503, valid RMSE of std 0.357\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.03      0.05      0.03      0.07    327.91      1.03\n",
      "               noise      0.15      0.14      0.11      0.03      0.27    493.36      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.0034339427948\n",
      "Iteration 11/100: train NMLL: 1.169, valid NMLL 0.431, valid RMSE of mean 0.498, valid RMSE of std 0.310\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.04      0.05      0.03      0.07    262.73      1.02\n",
      "               noise      0.14      0.14      0.11      0.03      0.26    300.50      1.02\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.42197585105896\n",
      "Iteration 12/100: train NMLL: 1.178, valid NMLL 0.432, valid RMSE of mean 0.477, valid RMSE of std 0.315\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.08      0.05      0.03      0.07    177.00      1.03\n",
      "               noise      0.15      0.14      0.12      0.02      0.28    200.44      1.02\n",
      "\n",
      "Number of divergences: 1\n",
      "Validation using full posterior took  14.204661130905151\n",
      "Iteration 13/100: train NMLL: 1.186, valid NMLL 0.457, valid RMSE of mean 0.480, valid RMSE of std 0.267\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.03      0.07    664.35      1.01\n",
      "               noise      0.11      0.08      0.09      0.02      0.21    676.38      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.011456966400146\n",
      "Iteration 14/100: train NMLL: 1.118, valid NMLL 0.368, valid RMSE of mean 0.478, valid RMSE of std 0.259\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.03      0.07    667.80      1.01\n",
      "               noise      0.12      0.08      0.10      0.03      0.22    620.12      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.260571002960205\n",
      "Iteration 15/100: train NMLL: 1.122, valid NMLL 0.401, valid RMSE of mean 0.479, valid RMSE of std 0.243\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.03      0.07    531.22      1.01\n",
      "               noise      0.12      0.07      0.10      0.03      0.20    847.26      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.697517156600952\n",
      "Iteration 16/100: train NMLL: 1.115, valid NMLL 0.404, valid RMSE of mean 0.485, valid RMSE of std 0.222\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.03      0.07    777.47      1.00\n",
      "               noise      0.12      0.07      0.10      0.03      0.21    727.97      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.992578268051147\n",
      "Iteration 17/100: train NMLL: 1.093, valid NMLL 0.402, valid RMSE of mean 0.486, valid RMSE of std 0.206\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.03      0.06    734.55      1.00\n",
      "               noise      0.11      0.06      0.09      0.03      0.19    790.01      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.690140962600708\n",
      "Iteration 18/100: train NMLL: 1.067, valid NMLL 0.391, valid RMSE of mean 0.487, valid RMSE of std 0.195\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.03      0.07    692.34      1.01\n",
      "               noise      0.10      0.05      0.09      0.03      0.17    883.71      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.873425960540771\n",
      "Iteration 19/100: train NMLL: 1.047, valid NMLL 0.385, valid RMSE of mean 0.488, valid RMSE of std 0.183\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.03      0.06    804.50      1.00\n",
      "               noise      0.11      0.06      0.10      0.04      0.18    657.46      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.4235999584198\n",
      "Iteration 20/100: train NMLL: 1.073, valid NMLL 0.412, valid RMSE of mean 0.458, valid RMSE of std 0.159\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.03      0.06    821.52      1.00\n",
      "               noise      0.10      0.05      0.09      0.03      0.17    799.43      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.2173011302948\n",
      "Iteration 21/100: train NMLL: 1.069, valid NMLL 0.378, valid RMSE of mean 0.429, valid RMSE of std 0.140\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    681.54      1.00\n",
      "               noise      0.10      0.06      0.09      0.03      0.17    685.59      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.706921815872192\n",
      "Iteration 22/100: train NMLL: 1.082, valid NMLL 0.375, valid RMSE of mean 0.344, valid RMSE of std 0.124\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    885.17      1.00\n",
      "               noise      0.09      0.05      0.08      0.03      0.15    672.41      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.11519479751587\n",
      "Iteration 23/100: train NMLL: 1.043, valid NMLL 0.339, valid RMSE of mean 0.336, valid RMSE of std 0.109\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    889.95      1.00\n",
      "               noise      0.08      0.04      0.07      0.03      0.14   1006.82      1.01\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  15.678924083709717\n",
      "Iteration 24/100: train NMLL: 1.004, valid NMLL 0.314, valid RMSE of mean 0.338, valid RMSE of std 0.093\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    742.04      1.00\n",
      "               noise      0.08      0.04      0.07      0.03      0.12    952.44      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.351125955581665\n",
      "Iteration 25/100: train NMLL: 0.963, valid NMLL 0.283, valid RMSE of mean 0.339, valid RMSE of std 0.088\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    886.76      1.00\n",
      "               noise      0.07      0.03      0.06      0.03      0.11    889.34      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.02032208442688\n",
      "Iteration 26/100: train NMLL: 0.945, valid NMLL 0.282, valid RMSE of mean 0.340, valid RMSE of std 0.082\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    684.87      1.01\n",
      "               noise      0.07      0.03      0.06      0.03      0.10    878.01      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.875160217285156\n",
      "Iteration 27/100: train NMLL: 0.923, valid NMLL 0.275, valid RMSE of mean 0.341, valid RMSE of std 0.069\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    511.00      1.01\n",
      "               noise      0.07      0.03      0.06      0.03      0.10   1112.57      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.279927015304565\n",
      "Iteration 28/100: train NMLL: 0.911, valid NMLL 0.282, valid RMSE of mean 0.343, valid RMSE of std 0.066\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    626.13      1.01\n",
      "               noise      0.08      0.03      0.07      0.03      0.12    689.48      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.780458927154541\n",
      "Iteration 29/100: train NMLL: 0.939, valid NMLL 0.310, valid RMSE of mean 0.343, valid RMSE of std 0.080\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    924.88      1.00\n",
      "               noise      0.08      0.03      0.07      0.04      0.12    826.56      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.33476996421814\n",
      "Iteration 30/100: train NMLL: 0.930, valid NMLL 0.314, valid RMSE of mean 0.346, valid RMSE of std 0.079\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    909.69      1.01\n",
      "               noise      0.07      0.03      0.07      0.03      0.11    728.85      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.85177230834961\n",
      "Iteration 31/100: train NMLL: 0.892, valid NMLL 0.291, valid RMSE of mean 0.345, valid RMSE of std 0.070\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    955.47      1.00\n",
      "               noise      0.07      0.03      0.06      0.03      0.10    801.45      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.434752941131592\n",
      "Iteration 32/100: train NMLL: 0.864, valid NMLL 0.279, valid RMSE of mean 0.344, valid RMSE of std 0.063\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    852.27      1.00\n",
      "               noise      0.07      0.02      0.06      0.04      0.10    669.20      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.108340978622437\n",
      "Iteration 33/100: train NMLL: 0.849, valid NMLL 0.282, valid RMSE of mean 0.345, valid RMSE of std 0.059\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    845.02      1.00\n",
      "               noise      0.06      0.02      0.06      0.03      0.10    827.04      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.968669176101685\n",
      "Iteration 34/100: train NMLL: 0.838, valid NMLL 0.287, valid RMSE of mean 0.343, valid RMSE of std 0.054\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    858.15      1.00\n",
      "               noise      0.06      0.02      0.06      0.03      0.10    934.78      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.769075870513916\n",
      "Iteration 35/100: train NMLL: 0.821, valid NMLL 0.286, valid RMSE of mean 0.344, valid RMSE of std 0.052\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    716.42      1.01\n",
      "               noise      0.06      0.02      0.06      0.03      0.09   1067.95      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.5961811542511\n",
      "Iteration 36/100: train NMLL: 0.803, valid NMLL 0.289, valid RMSE of mean 0.345, valid RMSE of std 0.048\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1137.35      1.00\n",
      "               noise      0.06      0.02      0.06      0.03      0.08    809.75      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.263123035430908\n",
      "Iteration 37/100: train NMLL: 0.784, valid NMLL 0.285, valid RMSE of mean 0.346, valid RMSE of std 0.046\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    895.93      1.00\n",
      "               noise      0.06      0.02      0.05      0.03      0.08   1129.80      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.031709909439087\n",
      "Iteration 38/100: train NMLL: 0.767, valid NMLL 0.289, valid RMSE of mean 0.346, valid RMSE of std 0.042\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    844.40      1.00\n",
      "               noise      0.07      0.02      0.06      0.04      0.10    511.32      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.87873387336731\n",
      "Iteration 39/100: train NMLL: 0.810, valid NMLL 0.310, valid RMSE of mean 0.319, valid RMSE of std 0.043\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1082.41      1.00\n",
      "               noise      0.06      0.02      0.06      0.03      0.09   1192.39      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.193217992782593\n",
      "Iteration 40/100: train NMLL: 0.815, valid NMLL 0.301, valid RMSE of mean 0.311, valid RMSE of std 0.029\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1095.55      1.00\n",
      "               noise      0.06      0.02      0.06      0.03      0.09    880.60      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.276939868927002\n",
      "Iteration 41/100: train NMLL: 0.795, valid NMLL 0.292, valid RMSE of mean 0.313, valid RMSE of std 0.024\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    840.84      1.00\n",
      "               noise      0.07      0.02      0.06      0.04      0.10   1190.01      1.00\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  19.56929111480713\n",
      "Iteration 42/100: train NMLL: 0.825, valid NMLL 0.316, valid RMSE of mean 0.316, valid RMSE of std 0.032\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1021.04      1.00\n",
      "               noise      0.07      0.02      0.06      0.04      0.09    861.14      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.310595989227295\n",
      "Iteration 43/100: train NMLL: 0.802, valid NMLL 0.307, valid RMSE of mean 0.317, valid RMSE of std 0.028\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.11      0.05      0.04      0.06     26.46      1.15\n",
      "               noise      0.10      0.19      0.07      0.04      0.10     18.42      1.26\n",
      "\n",
      "Number of divergences: 96\n",
      "Validation using full posterior took  19.37665891647339\n",
      "Iteration 44/100: train NMLL: 0.807, valid NMLL 0.322, valid RMSE of mean 0.320, valid RMSE of std 0.031\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1090.84      1.00\n",
      "               noise      0.06      0.02      0.06      0.04      0.09    689.57      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.534953117370605\n",
      "Iteration 45/100: train NMLL: 0.770, valid NMLL 0.303, valid RMSE of mean 0.319, valid RMSE of std 0.024\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    920.31      1.00\n",
      "               noise      0.06      0.02      0.06      0.04      0.09   1066.53      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.08414125442505\n",
      "Iteration 46/100: train NMLL: 0.762, valid NMLL 0.310, valid RMSE of mean 0.321, valid RMSE of std 0.023\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    696.95      1.00\n",
      "               noise      0.06      0.02      0.06      0.04      0.09   1048.00      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.700500965118408\n",
      "Iteration 47/100: train NMLL: 0.740, valid NMLL 0.303, valid RMSE of mean 0.322, valid RMSE of std 0.021\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1436.66      1.00\n",
      "               noise      0.06      0.02      0.06      0.03      0.08    498.04      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.462828159332275\n",
      "Iteration 48/100: train NMLL: 0.711, valid NMLL 0.293, valid RMSE of mean 0.321, valid RMSE of std 0.017\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1152.54      1.00\n",
      "               noise      0.06      0.01      0.05      0.03      0.08    936.87      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.269563674926758\n",
      "Iteration 49/100: train NMLL: 0.690, valid NMLL 0.287, valid RMSE of mean 0.321, valid RMSE of std 0.016\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1318.58      1.00\n",
      "               noise      0.06      0.01      0.05      0.03      0.08    484.98      1.01\n",
      "\n",
      "Number of divergences: 5\n",
      "Validation using full posterior took  20.79091787338257\n",
      "Iteration 50/100: train NMLL: 0.684, valid NMLL 0.296, valid RMSE of mean 0.323, valid RMSE of std 0.014\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1118.15      1.00\n",
      "               noise      0.06      0.01      0.05      0.03      0.08    652.50      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.311612844467163\n",
      "Iteration 51/100: train NMLL: 0.671, valid NMLL 0.296, valid RMSE of mean 0.321, valid RMSE of std 0.013\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1093.14      1.00\n",
      "               noise      0.05      0.01      0.05      0.03      0.08    741.27      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.76341414451599\n",
      "Iteration 52/100: train NMLL: 0.652, valid NMLL 0.291, valid RMSE of mean 0.320, valid RMSE of std 0.012\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.04      0.06    534.32      1.01\n",
      "               noise      0.05      0.02      0.05      0.03      0.07     68.82      1.08\n",
      "\n",
      "Number of divergences: 177\n",
      "Validation using full posterior took  20.556249856948853\n",
      "Iteration 53/100: train NMLL: 0.631, valid NMLL 0.287, valid RMSE of mean 0.321, valid RMSE of std 0.012\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1105.00      1.00\n",
      "               noise      0.05      0.01      0.05      0.03      0.07    788.80      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.89175510406494\n",
      "Iteration 54/100: train NMLL: 0.608, valid NMLL 0.283, valid RMSE of mean 0.318, valid RMSE of std 0.012\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1437.33      1.00\n",
      "               noise      0.05      0.01      0.05      0.03      0.07    846.45      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.572804927825928\n",
      "Iteration 55/100: train NMLL: 0.604, valid NMLL 0.294, valid RMSE of mean 0.320, valid RMSE of std 0.013\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    960.77      1.00\n",
      "               noise      0.05      0.01      0.05      0.03      0.07   1093.84      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  21.35807204246521\n",
      "Iteration 56/100: train NMLL: 0.599, valid NMLL 0.305, valid RMSE of mean 0.320, valid RMSE of std 0.013\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1370.39      1.00\n",
      "               noise      0.05      0.01      0.05      0.03      0.07    707.57      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  21.33503007888794\n",
      "Iteration 57/100: train NMLL: 0.592, valid NMLL 0.316, valid RMSE of mean 0.321, valid RMSE of std 0.015\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.05      0.05      0.04      0.06    236.06      1.02\n",
      "               noise      0.06      0.08      0.05      0.03      0.07     46.71      1.07\n",
      "\n",
      "Number of divergences: 178\n",
      "Validation using full posterior took  21.832114934921265\n",
      "Iteration 58/100: train NMLL: 0.597, valid NMLL 0.323, valid RMSE of mean 0.322, valid RMSE of std 0.013\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    926.63      1.00\n",
      "               noise      0.05      0.01      0.04      0.03      0.06    857.19      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  21.433908939361572\n",
      "Iteration 59/100: train NMLL: 0.564, valid NMLL 0.320, valid RMSE of mean 0.321, valid RMSE of std 0.019\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    801.96      1.00\n",
      "               noise      0.05      0.01      0.04      0.03      0.06    921.02      1.00\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  21.99389910697937\n",
      "Iteration 60/100: train NMLL: 0.550, valid NMLL 0.325, valid RMSE of mean 0.322, valid RMSE of std 0.021\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1003.85      1.00\n",
      "               noise      0.05      0.01      0.04      0.03      0.06    691.84      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.010813236236572\n",
      "Iteration 61/100: train NMLL: 0.546, valid NMLL 0.334, valid RMSE of mean 0.323, valid RMSE of std 0.021\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06    975.54      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.06   1114.42      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.62741708755493\n",
      "Iteration 62/100: train NMLL: 0.523, valid NMLL 0.333, valid RMSE of mean 0.322, valid RMSE of std 0.024\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1249.04      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.06   1003.65      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.088547706604004\n",
      "Iteration 63/100: train NMLL: 0.505, valid NMLL 0.335, valid RMSE of mean 0.322, valid RMSE of std 0.027\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1181.46      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.05    866.03      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.51508092880249\n",
      "Iteration 64/100: train NMLL: 0.494, valid NMLL 0.336, valid RMSE of mean 0.323, valid RMSE of std 0.028\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.06   1172.66      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.05   1300.14      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.79725217819214\n",
      "Iteration 65/100: train NMLL: 0.487, valid NMLL 0.347, valid RMSE of mean 0.323, valid RMSE of std 0.029\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06    871.88      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.05    976.46      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  23.02323079109192\n",
      "Iteration 66/100: train NMLL: 0.482, valid NMLL 0.344, valid RMSE of mean 0.324, valid RMSE of std 0.029\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1011.74      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.05    763.69      1.00\n",
      "\n",
      "Number of divergences: 1\n",
      "Validation using full posterior took  22.906155109405518\n",
      "Iteration 67/100: train NMLL: 0.461, valid NMLL 0.347, valid RMSE of mean 0.324, valid RMSE of std 0.032\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06    915.22      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.05    850.53      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  23.217473030090332\n",
      "Iteration 68/100: train NMLL: 0.445, valid NMLL 0.348, valid RMSE of mean 0.324, valid RMSE of std 0.033\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1101.67      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.05   1042.65      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.944657802581787\n",
      "Iteration 69/100: train NMLL: 0.437, valid NMLL 0.354, valid RMSE of mean 0.325, valid RMSE of std 0.034\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1169.39      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.05    991.52      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  23.662790060043335\n",
      "Iteration 70/100: train NMLL: 0.418, valid NMLL 0.358, valid RMSE of mean 0.325, valid RMSE of std 0.036\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06    853.50      1.01\n",
      "               noise      0.04      0.01      0.04      0.03      0.05    550.84      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.635112047195435\n",
      "Iteration 71/100: train NMLL: 0.423, valid NMLL 0.363, valid RMSE of mean 0.326, valid RMSE of std 0.035\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1152.72      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.05    709.93      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.069872856140137\n",
      "Iteration 72/100: train NMLL: 0.415, valid NMLL 0.380, valid RMSE of mean 0.326, valid RMSE of std 0.037\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1079.79      1.00\n",
      "               noise      0.04      0.01      0.04      0.02      0.05    920.59      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  23.898422956466675\n",
      "Iteration 73/100: train NMLL: 0.405, valid NMLL 0.387, valid RMSE of mean 0.327, valid RMSE of std 0.039\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1084.42      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.05    705.34      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.595962047576904\n",
      "Iteration 74/100: train NMLL: 0.401, valid NMLL 0.398, valid RMSE of mean 0.327, valid RMSE of std 0.040\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06    958.75      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.05    900.38      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.488486766815186\n",
      "Iteration 75/100: train NMLL: 0.396, valid NMLL 0.411, valid RMSE of mean 0.327, valid RMSE of std 0.041\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1266.22      1.00\n",
      "               noise      0.04      0.01      0.04      0.03      0.05   1125.36      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.751277923583984\n",
      "Iteration 76/100: train NMLL: 0.385, valid NMLL 0.420, valid RMSE of mean 0.328, valid RMSE of std 0.042\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1204.24      1.00\n",
      "               noise      0.04      0.01      0.04      0.02      0.05    881.52      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.754328727722168\n",
      "Iteration 77/100: train NMLL: 0.377, valid NMLL 0.422, valid RMSE of mean 0.328, valid RMSE of std 0.043\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1246.02      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    809.85      1.00\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  24.944008111953735\n",
      "Iteration 78/100: train NMLL: 0.364, valid NMLL 0.445, valid RMSE of mean 0.329, valid RMSE of std 0.047\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1152.35      1.00\n",
      "               noise      0.03      0.01      0.03      0.03      0.04   1064.16      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.907787084579468\n",
      "Iteration 79/100: train NMLL: 0.360, valid NMLL 0.451, valid RMSE of mean 0.328, valid RMSE of std 0.047\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06    849.05      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    526.53      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  24.844743967056274\n",
      "Iteration 80/100: train NMLL: 0.350, valid NMLL 0.450, valid RMSE of mean 0.328, valid RMSE of std 0.047\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1289.99      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04   1312.94      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  25.543644189834595\n",
      "Iteration 81/100: train NMLL: 0.331, valid NMLL 0.455, valid RMSE of mean 0.328, valid RMSE of std 0.049\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06    958.26      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    971.48      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  25.662285804748535\n",
      "Iteration 82/100: train NMLL: 0.323, valid NMLL 0.471, valid RMSE of mean 0.328, valid RMSE of std 0.051\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1037.21      1.01\n",
      "               noise      0.03      0.01      0.03      0.02      0.04   1052.57      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  26.083331823349\n",
      "Iteration 83/100: train NMLL: 0.319, valid NMLL 0.480, valid RMSE of mean 0.329, valid RMSE of std 0.052\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1238.38      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04   1067.03      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  25.604336977005005\n",
      "Iteration 84/100: train NMLL: 0.312, valid NMLL 0.490, valid RMSE of mean 0.329, valid RMSE of std 0.053\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1181.24      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04   1167.12      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  26.336679935455322\n",
      "Iteration 85/100: train NMLL: 0.307, valid NMLL 0.507, valid RMSE of mean 0.329, valid RMSE of std 0.055\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06    972.75      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    836.20      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  26.467080116271973\n",
      "Iteration 86/100: train NMLL: 0.301, valid NMLL 0.524, valid RMSE of mean 0.329, valid RMSE of std 0.056\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1434.12      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    803.03      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  26.36077380180359\n",
      "Iteration 87/100: train NMLL: 0.294, valid NMLL 0.529, valid RMSE of mean 0.330, valid RMSE of std 0.056\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06    917.31      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    513.25      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  26.79317283630371\n",
      "Iteration 88/100: train NMLL: 0.283, valid NMLL 0.539, valid RMSE of mean 0.330, valid RMSE of std 0.058\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06    652.15      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04    993.43      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  27.24746584892273\n",
      "Iteration 89/100: train NMLL: 0.271, valid NMLL 0.534, valid RMSE of mean 0.330, valid RMSE of std 0.057\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1032.99      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.04    978.77      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  27.278056859970093\n",
      "Iteration 90/100: train NMLL: 0.253, valid NMLL 0.545, valid RMSE of mean 0.330, valid RMSE of std 0.059\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1033.29      1.00\n",
      "               noise      0.03      0.01      0.03      0.02      0.04   1052.22      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  27.48949408531189\n",
      "Iteration 91/100: train NMLL: 0.251, valid NMLL 0.554, valid RMSE of mean 0.330, valid RMSE of std 0.060\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1180.04      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.04   1198.15      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  27.35166072845459\n",
      "Iteration 92/100: train NMLL: 0.237, valid NMLL 0.565, valid RMSE of mean 0.330, valid RMSE of std 0.061\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06   1100.88      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.04    842.68      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  27.64504599571228\n",
      "Iteration 93/100: train NMLL: 0.227, valid NMLL 0.578, valid RMSE of mean 0.330, valid RMSE of std 0.063\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06    962.60      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.04    743.19      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  27.41449809074402\n",
      "Iteration 94/100: train NMLL: 0.212, valid NMLL 0.592, valid RMSE of mean 0.330, valid RMSE of std 0.064\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.00      0.05      0.05      0.06    850.04      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.04    785.45      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  27.304616928100586\n",
      "Iteration 95/100: train NMLL: 0.209, valid NMLL 0.588, valid RMSE of mean 0.331, valid RMSE of std 0.064\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06    985.12      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.03    974.06      1.00\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  27.701956033706665\n",
      "Iteration 96/100: train NMLL: 0.209, valid NMLL 0.601, valid RMSE of mean 0.332, valid RMSE of std 0.065\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06    979.62      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.04   1322.62      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  28.449634790420532\n",
      "Iteration 97/100: train NMLL: 0.208, valid NMLL 0.614, valid RMSE of mean 0.333, valid RMSE of std 0.065\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06    859.56      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.03    835.05      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  28.055899143218994\n",
      "Iteration 98/100: train NMLL: 0.198, valid NMLL 0.626, valid RMSE of mean 0.333, valid RMSE of std 0.066\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06   1057.89      1.01\n",
      "               noise      0.03      0.00      0.03      0.02      0.03    742.10      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  28.309921979904175\n",
      "Iteration 99/100: train NMLL: 0.188, valid NMLL 0.631, valid RMSE of mean 0.333, valid RMSE of std 0.067\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.06    926.39      1.00\n",
      "               noise      0.03      0.00      0.03      0.02      0.03    922.62      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  28.432392835617065\n",
      "Iteration 100/100: train NMLL: 0.185, valid NMLL 0.641, valid RMSE of mean 0.333, valid RMSE of std 0.067\n",
      "Repetition 4 took 3343.761593103409 sec.\n",
      "\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.51      0.30      0.44      0.03      0.92   1009.40      1.00\n",
      "               noise      1.16      0.59      1.02      0.36      1.99    649.08      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  9.149672031402588\n",
      "Iteration 1/100: train NMLL: 1.635, valid NMLL 1.532, valid RMSE of mean 0.725, valid RMSE of std 0.543\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.47      0.28      0.42      0.03      0.86    940.65      1.00\n",
      "               noise      1.04      0.51      0.94      0.38      1.75    737.58      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  8.947473049163818\n",
      "Iteration 2/100: train NMLL: 1.589, valid NMLL 1.485, valid RMSE of mean 0.733, valid RMSE of std 0.543\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.40      0.29      0.35      0.02      0.78    588.45      1.00\n",
      "               noise      0.96      0.51      0.85      0.15      1.60    504.93      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  9.574477910995483\n",
      "Iteration 3/100: train NMLL: 1.550, valid NMLL 1.441, valid RMSE of mean 0.746, valid RMSE of std 0.537\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.33      0.25      0.27      0.02      0.66    425.63      1.00\n",
      "               noise      0.83      0.48      0.75      0.09      1.46    413.28      1.01\n",
      "\n",
      "Number of divergences: 1\n",
      "Validation using full posterior took  9.47313904762268\n",
      "Iteration 4/100: train NMLL: 1.510, valid NMLL 1.411, valid RMSE of mean 0.763, valid RMSE of std 0.515\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.30      0.28      0.19      0.02      0.72    258.76      1.02\n",
      "               noise      0.78      0.54      0.72      0.03      1.47    294.04      1.02\n",
      "\n",
      "Number of divergences: 1\n",
      "Validation using full posterior took  10.34126091003418\n",
      "Iteration 5/100: train NMLL: 1.491, valid NMLL 1.363, valid RMSE of mean 0.782, valid RMSE of std 0.477\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.19      0.27      0.07      0.02      0.58    202.72      1.03\n",
      "               noise      0.52      0.47      0.34      0.02      1.20    226.74      1.03\n",
      "\n",
      "Number of divergences: 1\n",
      "Validation using full posterior took  11.041347026824951\n",
      "Iteration 6/100: train NMLL: 1.369, valid NMLL 0.699, valid RMSE of mean 0.537, valid RMSE of std 0.435\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.12      0.18      0.06      0.02      0.27    134.30      1.04\n",
      "               noise      0.33      0.37      0.19      0.01      0.88    139.35      1.04\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  11.776434898376465\n",
      "Iteration 7/100: train NMLL: 1.282, valid NMLL 0.570, valid RMSE of mean 0.487, valid RMSE of std 0.412\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.08      0.13      0.05      0.02      0.08     76.33      1.11\n",
      "               noise      0.19      0.27      0.10      0.01      0.37    109.12      1.08\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  12.651948928833008\n",
      "Iteration 8/100: train NMLL: 1.190, valid NMLL 0.397, valid RMSE of mean 0.451, valid RMSE of std 0.394\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.08      0.05      0.03      0.07     67.39      1.07\n",
      "               noise      0.13      0.20      0.07      0.01      0.22     75.46      1.06\n",
      "\n",
      "Number of divergences: 1\n",
      "Validation using full posterior took  12.663388013839722\n",
      "Iteration 9/100: train NMLL: 1.103, valid NMLL 0.281, valid RMSE of mean 0.441, valid RMSE of std 0.382\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.08      0.06      0.03      0.07     30.18      1.23\n",
      "               noise      0.13      0.24      0.06      0.00      0.21     35.56      1.18\n",
      "\n",
      "Number of divergences: 2\n",
      "Validation using full posterior took  12.522318840026855\n",
      "Iteration 10/100: train NMLL: 1.084, valid NMLL 0.241, valid RMSE of mean 0.422, valid RMSE of std 0.353\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.07    685.69      1.00\n",
      "               noise      0.06      0.05      0.04      0.01      0.11    681.28      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  12.417712211608887\n",
      "Iteration 11/100: train NMLL: 1.000, valid NMLL 0.137, valid RMSE of mean 0.413, valid RMSE of std 0.340\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.07    570.12      1.01\n",
      "               noise      0.06      0.06      0.04      0.01      0.12    747.59      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  13.125319242477417\n",
      "Iteration 12/100: train NMLL: 1.022, valid NMLL 0.147, valid RMSE of mean 0.349, valid RMSE of std 0.304\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.07    727.85      1.00\n",
      "               noise      0.05      0.05      0.04      0.00      0.11    772.50      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  12.687105894088745\n",
      "Iteration 13/100: train NMLL: 1.017, valid NMLL 0.128, valid RMSE of mean 0.372, valid RMSE of std 0.255\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.07    742.20      1.00\n",
      "               noise      0.05      0.05      0.04      0.00      0.11    913.73      1.00\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  12.968294858932495\n",
      "Iteration 14/100: train NMLL: 1.028, valid NMLL 0.111, valid RMSE of mean 0.332, valid RMSE of std 0.207\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.10      0.05      0.04      0.07     27.23      1.15\n",
      "               noise      0.08      0.19      0.04      0.00      0.12     22.97      1.18\n",
      "\n",
      "Number of divergences: 80\n",
      "Validation using full posterior took  12.687643766403198\n",
      "Iteration 15/100: train NMLL: 1.040, valid NMLL 0.103, valid RMSE of mean 0.221, valid RMSE of std 0.166\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.12      0.05      0.04      0.06     22.81      1.19\n",
      "               noise      0.08      0.20      0.04      0.01      0.10     18.46      1.25\n",
      "\n",
      "Number of divergences: 273\n",
      "Validation using full posterior took  13.121803998947144\n",
      "Iteration 16/100: train NMLL: 0.979, valid NMLL 0.075, valid RMSE of mean 0.214, valid RMSE of std 0.155\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.06      0.05      0.04      0.06    725.62      1.00\n",
      "               noise      0.03      0.07      0.02      0.00      0.06    131.74      1.03\n",
      "\n",
      "Number of divergences: 125\n",
      "Validation using full posterior took  12.872002124786377\n",
      "Iteration 17/100: train NMLL: 0.894, valid NMLL 0.026, valid RMSE of mean 0.209, valid RMSE of std 0.136\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.01      0.05      0.04      0.07    970.39      1.00\n",
      "               noise      0.03      0.02      0.02      0.00      0.06    592.87      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  13.281584024429321\n",
      "Iteration 18/100: train NMLL: 0.896, valid NMLL 0.014, valid RMSE of mean 0.147, valid RMSE of std 0.100\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.12      0.06      0.04      0.07     25.66      1.16\n",
      "               noise      0.06      0.19      0.02      0.00      0.07     17.42      1.29\n",
      "\n",
      "Number of divergences: 164\n",
      "Validation using full posterior took  12.804300785064697\n",
      "Iteration 19/100: train NMLL: 0.882, valid NMLL 0.009, valid RMSE of mean 0.136, valid RMSE of std 0.052\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.11      0.06      0.04      0.07     39.05      1.09\n",
      "               noise      0.05      0.16      0.02      0.00      0.06     20.05      1.20\n",
      "\n",
      "Number of divergences: 149\n",
      "Validation using full posterior took  13.19413685798645\n",
      "Iteration 20/100: train NMLL: 0.842, valid NMLL 0.000, valid RMSE of mean 0.135, valid RMSE of std 0.049\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.10      0.17      0.06      0.04      0.07     19.93      1.27\n",
      "               noise      0.10      0.29      0.02      0.00      0.11     14.11      1.45\n",
      "\n",
      "Number of divergences: 477\n",
      "Validation using full posterior took  13.013078927993774\n",
      "Iteration 21/100: train NMLL: 0.807, valid NMLL -0.005, valid RMSE of mean 0.136, valid RMSE of std 0.050\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.19      0.28      0.06      0.04      0.68      8.51      1.65\n",
      "               noise      0.27      0.47      0.02      0.00      1.08      6.84      2.04\n",
      "\n",
      "Number of divergences: 153\n",
      "Validation using full posterior took  12.834519147872925\n",
      "Iteration 22/100: train NMLL: 0.744, valid NMLL -0.015, valid RMSE of mean 0.135, valid RMSE of std 0.049\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.11      0.06      0.05      0.07     29.88      1.14\n",
      "               noise      0.06      0.22      0.01      0.00      0.03     15.88      1.31\n",
      "\n",
      "Number of divergences: 131\n",
      "Validation using full posterior took  13.191830158233643\n",
      "Iteration 23/100: train NMLL: 0.656, valid NMLL 0.033, valid RMSE of mean 0.136, valid RMSE of std 0.062\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    478.42      1.01\n",
      "               noise      0.02      0.04      0.01      0.00      0.02     51.17      1.07\n",
      "\n",
      "Number of divergences: 205\n",
      "Validation using full posterior took  13.830971240997314\n",
      "Iteration 24/100: train NMLL: 0.603, valid NMLL 0.082, valid RMSE of mean 0.135, valid RMSE of std 0.070\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.17      0.27      0.06      0.04      0.56      3.39      2.01\n",
      "               noise      0.22      0.43      0.01      0.00      1.00      2.67      4.11\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  12.793467283248901\n",
      "Iteration 25/100: train NMLL: 0.560, valid NMLL 0.250, valid RMSE of mean 0.131, valid RMSE of std 0.085\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.17      0.27      0.06      0.04      0.59      3.40      2.08\n",
      "               noise      0.22      0.45      0.01      0.00      1.07      2.70      3.71\n",
      "\n",
      "Number of divergences: 6\n",
      "Validation using full posterior took  13.629719018936157\n",
      "Iteration 26/100: train NMLL: 0.507, valid NMLL 0.297, valid RMSE of mean 0.132, valid RMSE of std 0.088\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07   1039.48      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    617.94      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.140076875686646\n",
      "Iteration 27/100: train NMLL: 0.444, valid NMLL 0.546, valid RMSE of mean 0.132, valid RMSE of std 0.100\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.14      0.23      0.06      0.04      0.45      6.16      1.52\n",
      "               noise      0.17      0.37      0.02      0.00      0.91      4.01      2.19\n",
      "\n",
      "Number of divergences: 51\n",
      "Validation using full posterior took  13.618003129959106\n",
      "Iteration 28/100: train NMLL: 0.597, valid NMLL -0.022, valid RMSE of mean 0.109, valid RMSE of std 0.050\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.09      0.15      0.06      0.05      0.07     19.62      1.24\n",
      "               noise      0.06      0.21      0.01      0.01      0.04     14.59      1.37\n",
      "\n",
      "Number of divergences: 162\n",
      "Validation using full posterior took  13.704114198684692\n",
      "Iteration 29/100: train NMLL: 0.529, valid NMLL -0.002, valid RMSE of mean 0.108, valid RMSE of std 0.060\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.24      0.34      0.06      0.04      0.78      4.95      1.86\n",
      "               noise      0.33      0.51      0.02      0.00      1.17      3.76      3.47\n",
      "\n",
      "Number of divergences: 106\n",
      "Validation using full posterior took  13.191120147705078\n",
      "Iteration 30/100: train NMLL: 0.481, valid NMLL 0.011, valid RMSE of mean 0.109, valid RMSE of std 0.064\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.09      0.16      0.06      0.05      0.07     19.01      1.26\n",
      "               noise      0.07      0.24      0.01      0.00      0.03     13.40      1.44\n",
      "\n",
      "Number of divergences: 175\n",
      "Validation using full posterior took  13.890811920166016\n",
      "Iteration 31/100: train NMLL: 0.434, valid NMLL 0.033, valid RMSE of mean 0.108, valid RMSE of std 0.069\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    480.62      1.01\n",
      "               noise      0.01      0.01      0.01      0.00      0.02     28.36      1.17\n",
      "\n",
      "Number of divergences: 146\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  14.523422002792358\n",
      "Iteration 32/100: train NMLL: 0.373, valid NMLL 0.108, valid RMSE of mean 0.108, valid RMSE of std 0.079\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.05      0.06      0.05      0.07    132.82      1.02\n",
      "               noise      0.02      0.12      0.01      0.01      0.02     58.72      1.05\n",
      "\n",
      "Number of divergences: 233\n",
      "Validation using full posterior took  14.01919412612915\n",
      "Iteration 33/100: train NMLL: 0.357, valid NMLL 0.067, valid RMSE of mean 0.107, valid RMSE of std 0.075\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.10      0.16      0.06      0.05      0.07     13.13      1.51\n",
      "               noise      0.09      0.27      0.01      0.00      0.02     10.60      1.84\n",
      "\n",
      "Number of divergences: 115\n",
      "Validation using full posterior took  14.243600130081177\n",
      "Iteration 34/100: train NMLL: 0.308, valid NMLL 0.116, valid RMSE of mean 0.108, valid RMSE of std 0.081\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    961.71      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01   1156.36      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  14.474015235900879\n",
      "Iteration 35/100: train NMLL: 0.249, valid NMLL 0.264, valid RMSE of mean 0.106, valid RMSE of std 0.092\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.11      0.20      0.06      0.04      0.07     10.67      1.94\n",
      "               noise      0.11      0.32      0.01      0.00      0.09      9.02      2.77\n",
      "\n",
      "Number of divergences: 103\n",
      "Validation using full posterior took  15.007927894592285\n",
      "Iteration 36/100: train NMLL: 0.309, valid NMLL 0.148, valid RMSE of mean 0.055, valid RMSE of std 0.080\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    819.45      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    931.93      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.46138596534729\n",
      "Iteration 37/100: train NMLL: 0.245, valid NMLL 0.322, valid RMSE of mean 0.055, valid RMSE of std 0.092\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.07      0.09      0.06      0.05      0.07     49.85      1.07\n",
      "               noise      0.04      0.14      0.01      0.00      0.04     20.54      1.19\n",
      "\n",
      "Number of divergences: 171\n",
      "Validation using full posterior took  15.781463146209717\n",
      "Iteration 38/100: train NMLL: 0.321, valid NMLL 0.012, valid RMSE of mean 0.055, valid RMSE of std 0.061\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07    727.72      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    505.99      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.489863872528076\n",
      "Iteration 39/100: train NMLL: 0.204, valid NMLL 0.342, valid RMSE of mean 0.054, valid RMSE of std 0.094\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    959.28      1.01\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    867.46      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.912537097930908\n",
      "Iteration 40/100: train NMLL: 0.186, valid NMLL 0.430, valid RMSE of mean 0.052, valid RMSE of std 0.102\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.01      0.06      0.05      0.07   1258.60      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    471.20      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.597270965576172\n",
      "Iteration 41/100: train NMLL: 0.165, valid NMLL 0.448, valid RMSE of mean 0.050, valid RMSE of std 0.103\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1012.55      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    800.13      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.589051961898804\n",
      "Iteration 42/100: train NMLL: 0.170, valid NMLL 0.398, valid RMSE of mean 0.045, valid RMSE of std 0.101\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1151.44      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    451.52      1.01\n",
      "\n",
      "Number of divergences: 1\n",
      "Validation using full posterior took  15.654656887054443\n",
      "Iteration 43/100: train NMLL: 0.158, valid NMLL 0.414, valid RMSE of mean 0.045, valid RMSE of std 0.101\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1114.07      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    620.81      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.300361156463623\n",
      "Iteration 44/100: train NMLL: 0.129, valid NMLL 0.469, valid RMSE of mean 0.045, valid RMSE of std 0.104\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1365.63      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    489.34      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.08054804801941\n",
      "Iteration 45/100: train NMLL: 0.127, valid NMLL 0.437, valid RMSE of mean 0.039, valid RMSE of std 0.103\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    908.79      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    974.80      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.56154990196228\n",
      "Iteration 46/100: train NMLL: 0.106, valid NMLL 0.522, valid RMSE of mean 0.039, valid RMSE of std 0.107\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.10      0.19      0.06      0.05      0.07     13.33      1.50\n",
      "               noise      0.09      0.28      0.01      0.00      0.02     10.57      1.82\n",
      "\n",
      "Number of divergences: 131\n",
      "Validation using full posterior took  15.893412113189697\n",
      "Iteration 47/100: train NMLL: 0.141, valid NMLL 0.284, valid RMSE of mean 0.040, valid RMSE of std 0.095\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    930.84      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    863.97      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.66537570953369\n",
      "Iteration 48/100: train NMLL: 0.067, valid NMLL 0.577, valid RMSE of mean 0.039, valid RMSE of std 0.110\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    732.79      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    846.33      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.445826053619385\n",
      "Iteration 49/100: train NMLL: 0.053, valid NMLL 0.581, valid RMSE of mean 0.039, valid RMSE of std 0.110\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1137.69      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    672.36      1.01\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  16.84127187728882\n",
      "Iteration 50/100: train NMLL: 0.031, valid NMLL 0.636, valid RMSE of mean 0.039, valid RMSE of std 0.112\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    976.96      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01     55.18      1.05\n",
      "\n",
      "Number of divergences: 92\n",
      "Validation using full posterior took  16.74601697921753\n",
      "Iteration 51/100: train NMLL: 0.017, valid NMLL 0.690, valid RMSE of mean 0.039, valid RMSE of std 0.114\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    368.32      1.02\n",
      "               noise      0.01      0.02      0.01      0.00      0.01     37.81      1.10\n",
      "\n",
      "Number of divergences: 188\n",
      "Validation using full posterior took  16.821362257003784\n",
      "Iteration 52/100: train NMLL: 0.029, valid NMLL 0.458, valid RMSE of mean 0.039, valid RMSE of std 0.106\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.06      0.06      0.05      0.07    201.24      1.01\n",
      "               noise      0.02      0.09      0.01      0.00      0.05     17.58      1.19\n",
      "\n",
      "Number of divergences: 187\n",
      "Validation using full posterior took  17.032174825668335\n",
      "Iteration 53/100: train NMLL: 0.168, valid NMLL 0.068, valid RMSE of mean 0.039, valid RMSE of std 0.073\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    963.61      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    975.71      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.123909950256348\n",
      "Iteration 54/100: train NMLL: -0.050, valid NMLL 0.849, valid RMSE of mean 0.038, valid RMSE of std 0.119\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1148.52      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01   1175.01      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.731709003448486\n",
      "Iteration 55/100: train NMLL: -0.059, valid NMLL 0.918, valid RMSE of mean 0.038, valid RMSE of std 0.122\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    506.87      1.01\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    856.62      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.123088836669922\n",
      "Iteration 56/100: train NMLL: -0.052, valid NMLL 0.830, valid RMSE of mean 0.036, valid RMSE of std 0.120\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1001.21      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    621.66      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.864647150039673\n",
      "Iteration 57/100: train NMLL: -0.074, valid NMLL 0.898, valid RMSE of mean 0.035, valid RMSE of std 0.122\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1047.80      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    504.84      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.30833888053894\n",
      "Iteration 58/100: train NMLL: -0.088, valid NMLL 0.930, valid RMSE of mean 0.035, valid RMSE of std 0.123\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1133.16      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    804.17      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.201465129852295\n",
      "Iteration 59/100: train NMLL: -0.103, valid NMLL 0.962, valid RMSE of mean 0.035, valid RMSE of std 0.124\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1113.80      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    814.95      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.557069778442383\n",
      "Iteration 60/100: train NMLL: -0.119, valid NMLL 1.032, valid RMSE of mean 0.035, valid RMSE of std 0.125\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1076.19      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    944.25      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.57197093963623\n",
      "Iteration 61/100: train NMLL: -0.133, valid NMLL 1.102, valid RMSE of mean 0.035, valid RMSE of std 0.127\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    861.97      1.01\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    759.62      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.850629091262817\n",
      "Iteration 62/100: train NMLL: -0.138, valid NMLL 1.076, valid RMSE of mean 0.035, valid RMSE of std 0.126\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.04      0.06      0.05      0.07    207.56      1.02\n",
      "               noise      0.02      0.09      0.01      0.00      0.01     32.46      1.12\n",
      "\n",
      "Number of divergences: 164\n",
      "Validation using full posterior took  17.368547201156616\n",
      "Iteration 63/100: train NMLL: -0.062, valid NMLL 0.471, valid RMSE of mean 0.035, valid RMSE of std 0.109\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1039.88      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    508.93      1.02\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.682723999023438\n",
      "Iteration 64/100: train NMLL: -0.182, valid NMLL 1.201, valid RMSE of mean 0.035, valid RMSE of std 0.129\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1092.76      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    636.99      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.63058304786682\n",
      "Iteration 65/100: train NMLL: -0.205, valid NMLL 1.251, valid RMSE of mean 0.035, valid RMSE of std 0.130\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    676.40      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    932.84      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.00043296813965\n",
      "Iteration 66/100: train NMLL: -0.221, valid NMLL 1.273, valid RMSE of mean 0.035, valid RMSE of std 0.131\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1180.49      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01   1228.43      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.383943796157837\n",
      "Iteration 67/100: train NMLL: -0.220, valid NMLL 1.244, valid RMSE of mean 0.033, valid RMSE of std 0.130\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    738.67      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    939.08      1.00\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  17.80367088317871\n",
      "Iteration 68/100: train NMLL: -0.235, valid NMLL 1.290, valid RMSE of mean 0.033, valid RMSE of std 0.131\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.06      0.07    813.74      1.01\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    734.18      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.702319860458374\n",
      "Iteration 69/100: train NMLL: -0.247, valid NMLL 1.337, valid RMSE of mean 0.033, valid RMSE of std 0.132\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    806.45      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    647.53      1.01\n",
      "\n",
      "Number of divergences: 9\n",
      "Validation using full posterior took  18.025793075561523\n",
      "Iteration 70/100: train NMLL: -0.264, valid NMLL 1.391, valid RMSE of mean 0.033, valid RMSE of std 0.133\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1129.53      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    895.82      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.43226718902588\n",
      "Iteration 71/100: train NMLL: -0.282, valid NMLL 1.442, valid RMSE of mean 0.033, valid RMSE of std 0.134\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    967.67      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01   1021.73      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.992983102798462\n",
      "Iteration 72/100: train NMLL: -0.279, valid NMLL 1.397, valid RMSE of mean 0.029, valid RMSE of std 0.133\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1080.01      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    865.00      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.79329490661621\n",
      "Iteration 73/100: train NMLL: -0.292, valid NMLL 1.413, valid RMSE of mean 0.028, valid RMSE of std 0.134\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    847.20      1.00\n",
      "               noise      0.01      0.01      0.01      0.00      0.01    145.76      1.03\n",
      "\n",
      "Number of divergences: 3\n",
      "Validation using full posterior took  18.084567070007324\n",
      "Iteration 74/100: train NMLL: -0.281, valid NMLL 1.248, valid RMSE of mean 0.028, valid RMSE of std 0.131\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1146.84      1.00\n",
      "               noise      0.01      0.00      0.01      0.00      0.01    758.51      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.01787805557251\n",
      "Iteration 75/100: train NMLL: -0.317, valid NMLL 1.513, valid RMSE of mean 0.028, valid RMSE of std 0.135\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1078.93      1.00\n",
      "               noise      0.01      0.00      0.00      0.00      0.01    692.10      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.380382776260376\n",
      "Iteration 76/100: train NMLL: -0.326, valid NMLL 1.571, valid RMSE of mean 0.028, valid RMSE of std 0.136\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1165.08      1.00\n",
      "               noise      0.01      0.00      0.00      0.00      0.01   1208.75      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.686208963394165\n",
      "Iteration 77/100: train NMLL: -0.337, valid NMLL 1.647, valid RMSE of mean 0.028, valid RMSE of std 0.137\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.06      0.07   1101.03      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.01    785.68      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.73396897315979\n",
      "Iteration 78/100: train NMLL: -0.350, valid NMLL 1.674, valid RMSE of mean 0.028, valid RMSE of std 0.137\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.06      0.07    555.54      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.01   1422.48      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.475363969802856\n",
      "Iteration 79/100: train NMLL: -0.367, valid NMLL 1.693, valid RMSE of mean 0.028, valid RMSE of std 0.138\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    955.36      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.01   1095.78      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.41268301010132\n",
      "Iteration 80/100: train NMLL: -0.379, valid NMLL 1.756, valid RMSE of mean 0.028, valid RMSE of std 0.138\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.06      0.07    853.86      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.01   1154.76      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.012990951538086\n",
      "Iteration 81/100: train NMLL: -0.385, valid NMLL 1.782, valid RMSE of mean 0.028, valid RMSE of std 0.139\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07   1116.09      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.01   1109.17      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.451454162597656\n",
      "Iteration 82/100: train NMLL: -0.398, valid NMLL 1.805, valid RMSE of mean 0.028, valid RMSE of std 0.139\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.06      0.07   1055.82      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.01    703.97      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.042119026184082\n",
      "Iteration 83/100: train NMLL: -0.398, valid NMLL 1.761, valid RMSE of mean 0.027, valid RMSE of std 0.139\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.06      0.07    833.93      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.01   1246.50      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.917438983917236\n",
      "Iteration 84/100: train NMLL: -0.406, valid NMLL 1.796, valid RMSE of mean 0.027, valid RMSE of std 0.139\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.11      0.19      0.06      0.05      0.07     13.36      1.54\n",
      "               noise      0.10      0.28      0.00      0.00      0.20      7.63      3.01\n",
      "\n",
      "Number of divergences: 89\n",
      "Validation using full posterior took  19.12910485267639\n",
      "Iteration 85/100: train NMLL: -0.290, valid NMLL 0.765, valid RMSE of mean 0.028, valid RMSE of std 0.121\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.06      0.07   1350.91      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.01    786.06      1.00\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  18.698617935180664\n",
      "Iteration 86/100: train NMLL: -0.436, valid NMLL 1.917, valid RMSE of mean 0.027, valid RMSE of std 0.141\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.06      0.07   1282.72      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.01   1322.41      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.079962253570557\n",
      "Iteration 87/100: train NMLL: -0.453, valid NMLL 1.996, valid RMSE of mean 0.027, valid RMSE of std 0.141\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.06      0.07   1156.64      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.01   1381.70      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.990337133407593\n",
      "Iteration 88/100: train NMLL: -0.466, valid NMLL 2.045, valid RMSE of mean 0.027, valid RMSE of std 0.142\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.06      0.07   1101.56      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.01   1075.66      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.48580503463745\n",
      "Iteration 89/100: train NMLL: -0.474, valid NMLL 2.112, valid RMSE of mean 0.027, valid RMSE of std 0.143\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.06      0.07   1282.49      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.01    629.63      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  18.998900890350342\n",
      "Iteration 90/100: train NMLL: -0.488, valid NMLL 2.154, valid RMSE of mean 0.027, valid RMSE of std 0.143\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.06      0.07    991.54      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.01    965.08      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.430830001831055\n",
      "Iteration 91/100: train NMLL: -0.505, valid NMLL 2.215, valid RMSE of mean 0.027, valid RMSE of std 0.144\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.06      0.07   1278.00      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.01    973.07      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.457823038101196\n",
      "Iteration 92/100: train NMLL: -0.512, valid NMLL 2.227, valid RMSE of mean 0.027, valid RMSE of std 0.144\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.06      0.07   1251.25      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.01    918.46      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.87149691581726\n",
      "Iteration 93/100: train NMLL: -0.525, valid NMLL 2.354, valid RMSE of mean 0.027, valid RMSE of std 0.145\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.06      0.07    761.65      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.01    898.38      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.73811101913452\n",
      "Iteration 94/100: train NMLL: -0.521, valid NMLL 2.237, valid RMSE of mean 0.026, valid RMSE of std 0.144\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.05      0.07    499.80      1.01\n",
      "               noise      0.00      0.00      0.00      0.00      0.01    956.11      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  19.880757093429565\n",
      "Iteration 95/100: train NMLL: -0.527, valid NMLL 2.304, valid RMSE of mean 0.026, valid RMSE of std 0.145\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.09      0.14      0.06      0.05      0.07     21.84      1.20\n",
      "               noise      0.06      0.22      0.00      0.00      0.05     10.27      1.75\n",
      "\n",
      "Number of divergences: 145\n",
      "Validation using full posterior took  19.98530912399292\n",
      "Iteration 96/100: train NMLL: -0.273, valid NMLL 0.440, valid RMSE of mean 0.027, valid RMSE of std 0.109\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.06      0.07   1145.66      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.00   1188.73      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.23958921432495\n",
      "Iteration 97/100: train NMLL: -0.550, valid NMLL 2.427, valid RMSE of mean 0.026, valid RMSE of std 0.146\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.06      0.07   1231.50      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.00   1142.16      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.119356155395508\n",
      "Iteration 98/100: train NMLL: -0.556, valid NMLL 2.441, valid RMSE of mean 0.026, valid RMSE of std 0.146\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.06      0.07   1148.28      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.01    982.73      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.495139837265015\n",
      "Iteration 99/100: train NMLL: -0.565, valid NMLL 2.433, valid RMSE of mean 0.026, valid RMSE of std 0.146\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.06      0.00      0.06      0.06      0.07    934.51      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.00   1123.01      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  20.160906076431274\n",
      "Iteration 100/100: train NMLL: -0.573, valid NMLL 2.459, valid RMSE of mean 0.026, valid RMSE of std 0.146\n",
      "Repetition 5 took 2995.744099855423 sec.\n",
      "\n",
      "The experiment took 15877.870990991592 sec.\n"
     ]
    }
   ],
   "source": [
    "#### \n",
    "tic_all = time.time()\n",
    "nmll_losses_model1 = []\n",
    "nmll_losses_valid_model1 = []\n",
    "rmse_losses_valid_model1 = []\n",
    "rmse_std_losses_valid_model1 = []\n",
    "nmll_losses_valid_model1_mode = []\n",
    "rmse_losses_valid_model1_mode = []\n",
    "rmse_std_losses_valid_model1_mode = []\n",
    "lengthscale_model1 = []\n",
    "noise_model1 = []\n",
    "for rep in range(repetitions):\n",
    "\n",
    "    # Load data\n",
    "    search_space = get_search_space(simulator=args.simulator)\n",
    "\n",
    "    # We don't need the oracle labels since we just call the simulator, likewise, don't need pool_labeled\n",
    "    oracle_labels = None\n",
    "    pool_labeled = None\n",
    "\n",
    "    # We do need to sample a training set\n",
    "    train_x, train_y = sample_dataset_from_simulator(args, search_space, n_samples=args.initial_samples, seed=rep)\n",
    "    test_x, test_y = sample_dataset_from_simulator(args, search_space, n_samples=args.test_samples, seed=4242)\n",
    "\n",
    "    # A simulator where we can access the true mean and stddev\n",
    "    _, true_mean, true_std = oracle_simulator(args, torch.Tensor(search_space))\n",
    "    true_mean, true_std = torch.Tensor(true_mean), torch.Tensor(true_std)\n",
    "\n",
    "    # Remove any seed that may appear\n",
    "    np.random.seed()\n",
    "\n",
    "    # Active learning scheme\n",
    "    nmll_losses = []\n",
    "    nmll_losses_valid = []\n",
    "    rmse_losses_valid = []\n",
    "    rmse_std_losses_valid = []\n",
    "    nmll_losses_valid_mode = []\n",
    "    rmse_losses_valid_mode = []\n",
    "    rmse_std_losses_valid_mode = []\n",
    "    lst_lengthscales = []\n",
    "    lst_noises = []\n",
    "    tic = time.time()\n",
    "\n",
    "    # Initial priors\n",
    "    length_scale_prior = GammaPrior(3, 6)\n",
    "    noise_prior = LogNormalPrior(loc=0, scale=1)\n",
    "    for i in range(args.active_learning_steps):\n",
    "\n",
    "        # Prepare data\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",
    "        test_x_trans = (test_x - min_x) / max_x\n",
    "        test_y_trans = (test_y - mu_y) / sigma_y\n",
    "\n",
    "        # Setup model and do inference\n",
    "        pyro.clear_param_store() \n",
    "        pyro.set_rng_seed(rep)\n",
    "        nuts_gpr = gp_pyro(train_x_trans, train_y_trans, length_scale_prior, noise_prior)\n",
    "        nuts_kernel = NUTS(nuts_gpr.model, target_accept_prob=0.8)\n",
    "        mcmc_run = MCMC(nuts_kernel, num_samples=num_samples, warmup_steps=warmup_steps, num_chains=num_chains,\n",
    "                       disable_progbar=True)\n",
    "        mcmc_run.run()\n",
    "\n",
    "        # Look at summary\n",
    "        mcmc_run.summary()\n",
    "\n",
    "        # Extract samples and mode from posterior\n",
    "        posterior_samples = mcmc_run.get_samples()\n",
    "        mode_l, mode_n = get_mode_from_kde2d(pd.DataFrame(posterior_samples))\n",
    "        posterior_samples[\"covar_module.base_kernel.lengthscale_prior\"] = posterior_samples['kernel.lengthscale'].view(-1, 1, 1)\n",
    "        posterior_samples[\"likelihood.noise_prior\"] = posterior_samples['noise'].view(-1,1)\n",
    "        del posterior_samples['kernel.lengthscale']\n",
    "        del posterior_samples['noise']\n",
    "        \n",
    "\n",
    "        # Turn model into batch model in order to draw mean functions\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.likelihood.register_prior(\"noise_prior\", noise_prior, \"noise\")\n",
    "        mll = gpytorch.mlls.ExactMarginalLogLikelihood(model.likelihood, model)\n",
    "        model.pyro_load_from_samples(posterior_samples)\n",
    "        \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",
    "        model.eval()\n",
    "        \n",
    "        # Validation using the full posterior\n",
    "        tacos = time.time()\n",
    "        with torch.no_grad():\n",
    "            expanded_test_x = test_x_trans.view(-1,1).unsqueeze(0).repeat(num_samples*num_chains, 1, 1)\n",
    "            output = model(expanded_test_x)\n",
    "            mll = gpytorch.mlls.ExactMarginalLogLikelihood(model.likelihood, model)\n",
    "            nmll_loss = torch.mean(-mll(output, test_y_trans))\n",
    "            nmll_losses_valid_mode.append(nmll_loss.item())\n",
    "            #output_mean = output.mean * sigma_y + mu_y\n",
    "            #output_std = output.stddev.detach() * sigma_y\n",
    "            #rmse_losses_valid_mode.append(torch.sqrt(torch.mean(torch.pow(output_mean - test_y, 2))))\n",
    "            #rmse_std_losses_valid_mode.append(torch.sqrt(torch.mean(torch.pow(output_std - test_y, 2))))\n",
    "            \n",
    "        # Validation using the first and second order moments of the predictive posteriors\n",
    "        pp_mean, pp_std = predictive_posterior_moments(output)\n",
    "        pp_mean = pp_mean * sigma_y + mu_y\n",
    "        pp_std = pp_std.detach() * sigma_y\n",
    "        rmse_losses_valid_mode.append(torch.sqrt(torch.mean(torch.pow(pp_mean - test_y, 2))))\n",
    "        rmse_std_losses_valid_mode.append(torch.sqrt(torch.mean(torch.pow(pp_std - test_y, 2))))\n",
    "        print(\"Validation using full posterior took \", time.time()-tacos)\n",
    "    \n",
    "        # Make predictions on search space for plotting and querying\n",
    "        ss_trans = (torch.FloatTensor(search_space) - min_x) / max_x\n",
    "        expanded_test_x = ss_trans.view(-1,1).unsqueeze(0).repeat(num_samples*num_chains, 1, 1)\n",
    "        output = model(expanded_test_x)\n",
    "    \n",
    "        # Validation using the mode of the posterior\n",
    "        # Make ExactGP with modes of hyperparameters\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.likelihood.register_prior(\"noise_prior\", noise_prior, \"noise\")\n",
    "        model.covar_module.base_kernel.lengthscale = torch.tensor(mode_l)\n",
    "        model.likelihood.noise = torch.tensor(mode_n)\n",
    "        lst_lengthscales.append(mode_l)\n",
    "        lst_noises.append(mode_n)\n",
    "        #print(\"lengthscale:\", model.covar_module.base_kernel.lengthscale.item())\n",
    "        #print(\"noise\", model.likelihood.noise.item())\n",
    "        mll = gpytorch.mlls.ExactMarginalLogLikelihood(model.likelihood, model)\n",
    "        \n",
    "        model.train()\n",
    "        # Train NMLL\n",
    "        with torch.no_grad():\n",
    "            preds = model.likelihood(model(train_x_trans))\n",
    "            nmll_loss = torch.mean(-mll(preds, train_y_trans))\n",
    "            nmll_losses.append(nmll_loss.item())\n",
    "        model.eval()\n",
    "        # Valid NMLL\n",
    "        with torch.no_grad():\n",
    "            preds = model.likelihood(model(test_x_trans))\n",
    "            nmll_loss = torch.mean(-mll(preds, test_y_trans))\n",
    "            nmll_losses_valid.append(nmll_loss.item())\n",
    "        \n",
    "        # Search_space to get predictions of true mean and std\n",
    "        with torch.no_grad():\n",
    "            preds = model.likelihood(model(ss_trans))\n",
    "\n",
    "        # Compute loses\n",
    "        pred_mean = preds.mean * sigma_y + mu_y\n",
    "        pred_std = preds.stddev.detach() * sigma_y\n",
    "        losses = compute_loss(args, dataloader=(None, true_mean), predictions=pred_mean, lst_metrics=['rmse'])\n",
    "        rmse_losses_valid.append(losses['rmse'].item())\n",
    "        losses = compute_loss(args, dataloader=(None, true_std), predictions=pred_std, lst_metrics=['rmse'])\n",
    "        rmse_std_losses_valid.append(losses['rmse'].item())\n",
    "        \n",
    "        # Querying\n",
    "        # AL, where is stddev of the mean is highest\n",
    "        idx = np.argmax(torch.std(output.mean, axis=0).detach().numpy())\n",
    "        \n",
    "        # Get new point\n",
    "        new_x = search_space[idx]\n",
    "        new_y, _, _ = oracle_simulator(args, new_x)\n",
    "\n",
    "        # Add to data set\n",
    "        train_x = torch.FloatTensor(np.concatenate([train_x, [new_x]]))\n",
    "        train_y = torch.FloatTensor(np.concatenate([train_y, new_y]))\n",
    "\n",
    "        \n",
    "        print(\"Iteration %d/%d: train NMLL: %.3f, valid NMLL %.3f, valid RMSE of mean %.3f, valid RMSE of std %.3f\"\n",
    "              % (i+1, args.active_learning_steps, nmll_losses[-1], nmll_losses_valid[-1],\n",
    "                 rmse_losses_valid[-1], rmse_std_losses_valid[-1]))\n",
    "\n",
    "        # Plot results\n",
    "        if args.plot:\n",
    "            f, ax = plt.subplots(1, 3, figsize=(20, 6))\n",
    "            plot_mean_functions(ax[0], train_x[:-1], train_y[:-1], torch.FloatTensor(search_space), output,\n",
    "                               mu_y, sigma_y)\n",
    "            ax[0].plot(search_space, pred_mean, 'r--',lw=2, label=\"Mean w/ mode parameters\")\n",
    "            ax[0].plot(train_x[-1].numpy(), train_y[-1].numpy(), 'g*', ms=10, label=\"New point to add\")\n",
    "            ax[0].legend()\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.show()\n",
    "    \n",
    "    nmll_losses_model1.append(nmll_losses)\n",
    "    nmll_losses_valid_model1.append(nmll_losses_valid)\n",
    "    rmse_losses_valid_model1.append(rmse_losses_valid)\n",
    "    rmse_std_losses_valid_model1.append(rmse_std_losses_valid)\n",
    "    nmll_losses_valid_model1_mode.append(nmll_losses_valid_mode)\n",
    "    rmse_losses_valid_model1_mode.append(rmse_losses_valid_mode)\n",
    "    rmse_std_losses_valid_model1_mode.append(rmse_std_losses_valid_mode)\n",
    "    lengthscale_model1.append(lst_lengthscales)\n",
    "    noise_model1.append(lst_noises)\n",
    "    print(f\"Repetition {rep+1} took {time.time()- tic} sec.\\n\")\n",
    "print(f\"The experiment took {time.time()- tic_all} sec.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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m2+mqamJxx57jPe85z0HnPIRBAEXXXQR//zP/zzhsX2DqxBCCFFtTj75ZD74wQ/yqU99asIa+CN19tlns3nzZn75y1/y61//mmuuuYbPfe5zPPbYY5XX/a985SusWLFiwrlz5859Rc8txJGQETgxLXV2drJp0ybq6+tZtGjRuD9HUu731FNP5fnnnx9XBGT9+vUMDg6OO851XXzfP1bNZ+HChVx99dX84Ac/4O/+7u/413/9VwDOOeccBgYGJp2vD/DII4+QyWT4+7//e17zmtdw8sknH3J/ms7OTp577jnmzp074Xu179o6IYQQohp9/vOfZ8eOHXzzm9+s3Hfaaaexbt06ent7K/ft2rWL9evXc/rppx/wWslkkj/+4z/mq1/9Kr/73e94/vnnefDBB2ltbaW9vZ3169dPeK1dtGgR0Wj0uPZRiH1JgBNTKpvNsnbt2nF/XnjhBa688kpOOukk3vrWt3LfffexZcsWHn/8cf7hH/6BH//4x4d9/SuvvJJkMsmf//mf88wzz/D444/z/ve/n1gsNm5k7qSTTuLXv/41O3bsGPfL/mj685GPfIT777+fzZs389RTT3HPPfdw6qmnAnDhhRfy+te/niuuuIL//u//ZvPmzTz66KP827/9GwBLlixh9+7d3HbbbWzatInvfve7fP3rXz/oc370ox/F930uvfRSHn74YbZs2cIjjzzCZz7zGVavXn3UfRFCCCFmgubmZj796U/zT//0T5X7/vRP/5Tm5mauuOIKnnzySZ544gne9a53MWfOHK644opJr3PzzTfz//7f/+O5555j8+bN/Pu//zuWZXHyyScDcOONN/LVr36VG2+8kd///vesX7+eH//4x3zwgx88Ed0UokICnJhSjz/+OK961avG/bnsssuIRqM8+OCDdHZ28r73vY+TTz6Zyy+/nN/+9rfMnz//sK8fj8f5+c9/zq5du3j1q1/Nu9/9bj7+8Y+TTCbHfVp2yy238MQTT7BgwYJXNGpl2zYDAwO8//3vZ+nSpbz5zW+mtbWV//iP/wDCKZg/+9nPeMtb3sKHPvQhlixZwrvf/e5KaPzDP/xDPvOZz3D99ddzxhln8P3vf5+bb775oM/Z2trKb37zGzKZDJdffjlLlizhyiuvZOvWrcyaNeuo+yKEEELMFJ/4xCfGrXeLxWLcd999RCIR3vCGN3DBBReQSCS45557Jl16AVBfX8+tt97K+eefzxlnnMHdd9/ND3/4Q5YsWQLAn/3Zn3HXXXfx05/+lHPPPZdXv/rV3HDDDcyZM+eE9FGIMcoYY6a6EUKcSFu3bmXBggX85Cc/4W1ve9tUN0cIIYQQQojDJgFOVL077riDOXPmcNJJJ7F161auvfbayjz4SCQy1c0TQgghhBDisB3WFMq1a9dyzTXX8Fd/9VcHXX/02GOP8c53vpOXXnqpct/dd9/NX/3VX3HNNdewdu3aV9peIY5YX18ff/EXf8Epp5zC//pf/4t58+bx0EMPSXgTQgghhBAzziG3EQiCgNtuu43PfvazpNNprrvuOjo7OyeUS83n8/ziF79g8eLFlfu6urpYvXo1t956KwMDA3zhC1/gK1/5ClrL0jtx4lxzzTVcc801U90MIYQQQgghXrFDJqmNGzfS1tZGa2srtm2zfPly1qxZM+G4O++8k0svvRTHcSr3rVmzhuXLl+M4Di0tLbS1tclGh0IIIYQQQghxlA4Z4Pr7+0mn05Xb6XSa/v7+ccds2rSJ3t5eli1bdtBzU6nUhHOFEEIIIYQQQhyeQ06hPJQgCPjud7/L1VdffdTXWLVqFatWrQLgpptueqVNEkIIIYQQQoiqdMgAl0ql6Ovrq9zu6+sjlUpVbhcKBbZt28bf/u3fAjA4OMg//uM/cu211044t7+/f9y5Y1auXMnKlSsrt3fs2HF0vQEymQze0//AC7uG+cVjc3jf1ZNv1lhNMpnMK9p8eqaqxX7XYp+hNvt9pH2ePXv2cWyNqBVf//rXefLJJ2loaOCWW26Z8Lgxhttvv52nnnqKSCTC1VdfzcKFCw/r2kf72i7//2tHLfa7FvsMtdnvY/m6fsgplB0dHXR3d9PT04PneaxevZrOzs7K4/F4nNtuu41/+Zd/4V/+5V9YvHgx1157LR0dHXR2drJ69WrK5TI9PT10d3ezaNGiw2740QqsBA1OEV82SBBCCCEO2xvf+Eauv/76Az7+1FNPsXPnTr761a/ygQ98gH/7t387ga0TQggBhzECZ1kWV111FTfeeCNBELBixQra29u58847KyHtQNrb2zn//PP55Cc/idaa97///SekAmWg4zTYRXzUcX8uIYQQolqceuqp9PT0HPDx3/3ud7zhDW9AKcXJJ5/MyMgIAwMDNDU1ncBWCiFEbTusNXDLli2bUKDkiismn5p4ww03jLt9+eWXc/nllx9d646SsRLU2SVkj3IhhBDi2Onv7yeTyVRujxU2myzA7b++fd/zjoRt20d97kxVi32G2ux3LfYZarPfx7LPr7iIyXQUWHEsZXCcYKqbIoQQQtSk/de3H+16F1krUztqsd+12GeozX6f0DVwM1FgJQCIuf4Ut0QIIYSoHqlUatwbkP0LmwkhhDj+qjLAGSsOQNT2prglQgghRPXo7OzkoYcewhjDiy++SDwel/VvQghxglXnFEo9NgInAU4IIYQ4XP/0T//EunXrGB4e5kMf+hDvfOc78bzwtfTiiy/mVa96FU8++SQf+9jHcF33Fe0BK4QQ4uhUZ4CTKZRCCCHEEfv4xz9+0MeVUvzFX/zFiWmMEEKISVXlFMpgdAplXEbghBBCCCGEEFWkKgMc2qXgWyQkwAkhhBAzVvDYA3jbNk91M4QQYlqpmgCXy+W477772LRpEwB7ylGSkfIUt0oIIYQQR8OUS5gffpu+T/w5wQ9uxxTyU90kIYSYFqomwLmuy/r169m8OfykbqgcoU5G4IQQQogZSTku+m++QnTFWzD33k3wuasxG9dNdbOEEGLKVU2As22bdDrN9u3bARjyItTJCJwQQggxY6m6Bho+ch360/8Ivkdw791T3SQhhJhyVRPgAFpaWtixYwfGGIbLUepcCXBCCCHETKc6ToFMK5RLU90UIYSYclUV4FpbW8nlcgwPDzPsRUi6ZYwvIU4IIYSY8WwbPFkaIYQQVRXgWlpaAOjp6WG4HEUr0OXhKW6VEEIIIV4x2wFfApwQQlRVgEun01iWxa5du8j6EUACnBBCCFEVLAt8f6pbIYQQU66qApxt27S2ttLT00PWiwKg/aEpbpUQQgghXjHLBk+WRQghRFUFOIDZs2fT09NDriwjcEIIIUTVkDVwQggBVGGAmzNnDsVikVxJAaD97BS3SAghhBBHIz7wIPQ9AYCybJlCKYQQgD3VDTjWZs+eDYBfzFP0NdqXETghhBBiJooOrUGZ3ZCaH06hlCImQghRfSNwLS0tWJaFLo8wWIqg/ZGpbpIQQgghjoLvZKCwK7whUyiFEAKowgBnWRaZTAZdyjJYjqADCXBCCCHETBQGuB4wJgxwMgInhBDVF+Ag3NBblUYYKEUlwAkhhBAzlO+mUUEprCgtUyiFEAKo0gDX0tICxmeo5KBNbqqbI4QQQoij4DnNAFil3tFtBCTACSFEVQa41tZWALIlhTYFMMEUt0gIIYQQR8p3MgBY5T6ZQimEEKOqMsA1NTUBMFJQKAxKCpkIIYQQM05g12OUg10eHYELAkwgWwkIIWpbVQY4rTXKcskWw+7JXnBCCCHEDKQ0RFvCKZT26M5HshecEKLGHdY+cGvXruX2228nCAIuuugiLrvssnGP33fffdx7771orYlGo3zwgx9k7ty59PT08IlPfKKyN9vixYv5wAc+cMw7MRllO4wUw6mT2s8iv+6FEEKIGSjWijW8DayF4W3PA8ed2jYJIcQUOmSAC4KA2267jc9+9rOk02muu+46Ojs7mTt3buWY173udVx88cUA/O53v+M73/kOn/nMZwBoa2vj5ptvPk7NPzBtu+SK+fBrGYETQgghZqZoC1b/02AtDm/LOjghRI075BTKjRs30tbWRmtrK7Zts3z5ctasWTPumHg8Xvm6UCiglDr2LT1C2nYpFk34tScBTgghhJiJTLQVhY8VGQ1uUolSCFHjDjkC19/fTzqdrtxOp9Ns2LBhwnH33HMPP/vZz/A8j7/5m7+p3N/T08O1115LLBbjXe96F0uXLj1GTT84y3bxS2WM0TICJ4QQQsxU0bCytBUp4YGMwAkhat5hrYE7HJdccgmXXHIJjzzyCD/84Q/56Ec/SlNTE1//+tepq6tj06ZN3Hzzzdxyyy3jRuwAVq1axapVqwC46aabyGQyR90O27bJZDJE4gnyfQGBihG3y8RewTWnu7E+15pa7Hct9hlqs9+12GchJjUa4GynQBEkwAkhat4hA1wqlaKvr69yu6+vj1QqdcDjly9fzre+9S0AHMfBcRwAFi5cSGtrK93d3XR0dIw7Z+XKlaxcubJyu7e398h6sY9MJhOerywAip6Nletlzyu45nRX6XONqcV+12KfoTb7faR9HisWJUTVceoIdATLDte1yxRKIUStO+QauI6ODrq7u+np6cHzPFavXk1nZ+e4Y7q7uytfP/nkk8yaNQuAoaEhgiCsBLlr1y66u7srm2wfb7YbAaBYdmQNnBBCCDHD+IHh5ke2859Pbcd3Mth2LnxAApwQosYdcgTOsiyuuuoqbrzxRoIgYMWKFbS3t3PnnXfS0dFBZ2cn99xzD88++yyWZZFMJvnIRz4CwLp167jrrruwLAutNX/5l39JMpk87p0CcJwwwBXKNvWyBk4IIYSYUSyt6M95/PS5Hi5/VRpXbwwfkH3ghBA17rDWwC1btoxly5aNu++KK66ofP2+971v0vPOO+88zjvvvFfQvKPnRKMAZEsWbf4ImCDcEFQIIYQQM8IbFtTzjTW76PebmK1yYCnwy1PdLCGEmFJVm2gcNwZAtqhRBKggN8UtEkIIIcSRWD6vDkvBU/1xlAK70ZUplEKImle9Ac6x8ZTFUCG8LevghBBCiJmlIWrz6nlN/HpHWBDNSkmAE0KIqg1wWitKymUoH24qLnvBCSGEEDPPm5Y088xAAgC7yZU1cEKImle1Ac6yLEraZXB05qQEOCGEEGLmeX1HihIRsn4UOxWRNXBCiJpXtQFOa01ZufTnTXhbApwQQggx4yRcm845Sbbm67FSLkamUAohalzVBjjL0pS0y1AhwGChveGpbpIQQgghjsIb5tezOV+HScVlCqUQouZVeYCLUPQDArsO7UuAE0IIIWaic+Yk2FVqIJpQKD8/1c0RQogpVbUBTmtNSbkAeCqBJSNwQgghxIzkWpoRGgGwlCyJEELUtuoNcKNFTACKxNH+0BS3SAghhBBH4qGHHuKJJ54AoNdrBMDSI1PYIiGEmHpVG+AsS1MeDXAFP4r2JMAJIYQQM8nLL7/M+vXrAej1GwCwdW4qmySEEFOuqgPc2BTKnOeigwIEpSlulRBCCCEOVzqdZteuXQB4KsJgwcWyJcAJIWpb1QY4rXVlCmW2bANgSSETIYQQYsZIp9MMDAxQLpexLcXOfAzbKUx1s4QQYkpVbYCztaKsHACG8mE3ZRqlEEIIMXOk02kA+vv7sbWiO5fAcopT3CohhJha9lQ34HjRWoFSOFozkDPQiOwFJ4QQQhzC2rVruf322wmCgIsuuojLLrts3OO9vb38y7/8CyMjIwRBwJ/+6Z+ybNmy49KWsQDX19eHpetHA5yPCgoYHT0uzymEENNd1QY4SykAbG0xkDUAaG/PVDZJCCGEmNaCIOC2227js5/9LOl0muuuu47Ozk7mzp1bOeaHP/wh559/PhdffDFdXV38wz/8w3ELcPX19di2HQY41cD2Qh0AVqkPLzrnuDynEEJMd1U7hVKH+Q1baQazRYxyZA2cEEIIcRAbN26kra2N1tZWbNtm+fLlrFmzZtwxSilyubCQSC6Xo6mp6bi1R2tNc3MzfX192FrRNRbgyr3H7TmFEGK6q94RuNEEZytNLpfHt+tkDZwQQghxEP39/ZVpixBOYdywYcO4Y97xjnfw93//99xzzz0Ui0U+97nPHdc2tba2smHDBqxWxfaiBDghhKjeAKfG/tZk83kCq14CnBBCCPEKPfroo7zxjW/kbW97Gy+++CJf+9rXuOWWW9B6/KSeVatWsWrVKgBuuukmMpnMUT1fW1sba9euJeEociZCULRI6Czxo7zeTGDb9lF/v2ayWux3LfYZarPfx7LP1RvgRkfgLKUpl8t4Oo1b7p7iVgkhhBDTVyqVoq+vr3K7r6+PVCo17pj777+f66+/HoCTTz6ZcrnM8PAwDQ0N445buXIlK1eurNzu7T26UbOxNzylwd34SlPOKfTwdgaO8nozQSaTOerv10xWi/2uxT5Dbfb7SPs8e/bsAz5W9WvgtAq7WDKxsAqlMVPYKiGEEGL66ujooLu7m56eHjzPY/Xq1XR2do47JpPJ8Pvf/x6Arq4uyuUy9fX1x61NLS0tAKjCEJ6y8EcUVrnvEGcJIUT1qtoROD1ahVIT/p3zIzSaEsoUMUpKDwshhBD7syyLq666ihtvvJEgCFixYgXt7e3ceeeddHR00NnZyZ//+Z/zf//v/+VnP/sZAFdffTVq9DX3eGhoaMBxHMgP4at6vCzoIIfy8xgrdtyeVwghpquqDXBjUyjHRuByZTe87Q3huxLghBBCiMksW7ZswrYAV1xxReXruXPn8oUvfOGEtUcpRTqdpje3B9+ahzcczqSxyr14VvsJa4cQQkwXVTuFcqyICSbs4nAx/Fs28xZCCCFmlnQ6jT8yiIfGG/IBqUQphKhdVRvgdGU6R9jFocJogPOlEqUQQggxk6TTaYxXwjUlSkMBBoVdknVwQojaVLUBzhrtmUHhOA592SC8X7YSEEIIIWaUsb3pEn4WrxwQ2A0yAieEqFmHtQZu7dq13H777QRBwEUXXcRll1027vH77ruPe++9F6010WiUD37wg8ydOxeAu+++m/vvvx+tNe973/s4++yzj3UfJmWNjsAFJiyLvGv3IMHciOwFJ4QQQswwYwEu6WXx/QDfyUglSiFEzTrkCFwQBNx2221cf/31fPnLX+bRRx+lq6tr3DGve93ruOWWW7j55pu59NJL+c53vgOE5YVXr17Nrbfeymc+8xluu+02giA4Pj3Zz9gUSt+EJYh3794dbubtyxo4IYQQYiaJxWJoJ0LCz+L7Bs/NYJV3y9ZAQoiadMgAt3HjRtra2mhtbcW2bZYvX86aNWvGHROPxytfFwqFSjnhNWvWsHz5chzHoaWlhba2NjZu3HiMuzC5sX3gAgPNzc2USiVKxGUETgghhJhhlFK4yQbifg4vCPCdZnRQlA9lhRA16ZBTKPv7+ytTFyCcxrBhw4YJx91zzz387Gc/w/M8/uZv/qZy7uLFiyvHpFIp+vv7j0W7D2kswPns3QQ0W7JJOyfm+YUQQghx7LixJNE9O/ANeG4zAFapl8A+fpuICyHEdHTM9oG75JJLuOSSS3jkkUf44Q9/yEc/+tHDPnfVqlWsWrUKgJtuuolMJnPU7bBtu3K+ZZ4HpTn55JOxLItsyaZZD5NJp+E4bjp6ou3b51pSi/2uxT5Dbfa7FvssxMFEEkkiQZGSH47AAVjl3ZRZOMUtE0KIE+uQAS6VStHXt3ehcF9fH6lU6oDHL1++nG9961uTntvf3z/puStXrmTlypWV2729R19ZKpPJVM63CCj7AYODg6TTabr7Blg426O352WMlTjq55hu9u1zLanFftdin6E2+32kfZ49e/ZxbI0QUy8aT6IxZJVFYNdjlINd2j3VzRJCiBPukGvgOjo66O7upqenB8/zWL16NZ2dneOO6e7urnz95JNPMmvWLAA6OztZvXo15XKZnp4euru7WbRo0THuwoFpDD7hSFtzczPdffnwftnMWwghhJhRoskkAMPaAaXx3OawkIkQQtSYQ47AWZbFVVddxY033kgQBKxYsYL29nbuvPNOOjo66Ozs5J577uHZZ5/FsiySySQf+chHAGhvb+f888/nk5/8JFpr3v/+96P1idt6ThtDMFqgqqWlhZd27N0Lzo+0nbB2CCGEEOKVicfrABjRFgC+k8EpbJvKJgkhxJQ4rDVwy5YtY9myZePuu+KKKypfv+997zvguZdffjmXX375UTbvlbEwjG1a0NLSwtpCGB61L5UohRBCiJkklkxigBHLAcJCJpHssxCUQTtT2zghhDiBTtxw2BSwMPgmnEKZTqfJlsK8KlMohRBCiJnFtW2KOkLOdjCBj+80ozCyobcQouZUdYDThNsIQFjRraEpQ8GzZQROCCGEmGEsDQUdI2874Pv4o1sJ2LIOTghRY6o6wFnKELB3u4CWlhZGSgrtjUxhq4QQQghxpGylyOsYBdsBz8NzRrcMkkqUQogaU9UBTjM+wDU3N1MsG/xyYQpbJYQQQogjZWlFwYpRtCyCUgm0i283ylYCQoiaU9UBztpnGwEIR+DKvqJckhE4IYQQYiaxtSKvo6AU2eFwKYTnyFYCQojaU9UBLlwDtzfAZTIZyoEikBE4IYQQYkYZG4EDGBraA4DvZsIplMZMZdOEEOKEquoAZ6nxI3CO44B2IShNYauEEEIIcaTGipgADA+F1aR9txltSmhfqksLIWpHdQc4GLcGDsA3FhpvahokhBBCiKNiK0VBR8EYhobDwOY5YSVKKWQihKglVR3g9H5VKAECZWMp/wBnCCGEEGI6srTCKI0dGIay4Vp22UpACFGLqjvAMX4NHIDBwVbB1DRICCGEEEfF1uHruR0YhnNhgAusegLlygicEKKmVHWAsxT4anwXjXawtQQ4IYQQYiaxRgOcFRiGcvnwTqXwXalEKYSoLVUf4AIUZp/qVEY5OJaRilVCCCHEDGKPvmPRgSJbKBAE4YexvpPGKvdPYcuEEOLEqvoA5ysNwT4jbtoN/zZSyEQIIYSYKSwVjsDp0c9gs9ksAIGVQPuyv6sQonZUdYDTQHCAABd4shecEEIIMVOMrYHDhG9dhobCzbwDK4EOCmCkQJkQojZUd4CrjMDt/aWurDDA+aX8VDVLCCGEEEdoLL9NDHDJ8HEZhRNC1IiqDnCWGh2B8/f5VM6KAOCV5Be9EEIIMVMopbAVGMYHOGPFw8f93JS1TQghTiR7qhtwPFmTjMBpeyzAyQicEEIIMZNYCnxtk3QUg4OD5PN58MOZNdofQSZRCiFqQVUHOK3UhDVw2o6BL2vghBBCiJnG0gpfWaQimhdffJEXX3yRlmSZj71BplAKIWpHVQc4S08cgbOcKPjgl2UETgghhJhJbA2e0lwwu4nu2R0YY3j5pd8DvRLghBA1o6oDnFYQoMHfdwQuCsgInBBCCDHTjI3ApW2L5jPPBGBozwDwewlwQoiaUdVFTLRSE0fg3HCxc+AVp6pZQgghhDgKtlb42gJ/716ubiRGrqTAz05hy4QQ4sSp6gBnVQLc3hE4ezTAGRmBE0IIIWYUSys8ZYG3T4BzXUZKGsoS4IQQtaG6A5weK2KydwTOdmPhF0FpilolhBBCiKNhax1+MLvPCFwkEiFX0ihPApwQojZUeYCbuA/c2Bo4fJlCKYQQQswkllZ42h43AheJRBgpaVkDJ4SoGVVexEThKzVuBM6o0S4H5SlqlRBCCCGOhq3Bt+xxH8y6rkuupLEC2chbCFEbDivArV27lttvv50gCLjooou47LLLxj3+05/+lF/96ldYlkV9fT0f/vCHaW5uBuCKK65g3rx5AGQyGT71qU8d2x4chKU1vmLcGjiUhR+AMhLghBBCiJnEUhOLmEQiEfpKGoscGANKTWELhRDi+DtkgAuCgNtuu43PfvazpNNprrvuOjo7O5k7d27lmAULFnDTTTcRiUS47777uOOOO/jEJz4BhJ+M3XzzzcevBwcx2RRKAC/QEuCEEEKIGcbWCk/Z4O19DXddl5GyRmNQQQFjxaawhUIIcfwdcg3cxo0baWtro7W1Fdu2Wb58OWvWrBl3zOmnn04kEgFg8eLF9Pf3H5/WHiGtxoqYBOPu94wlAU4IIYSYYazKNgJ7P5iNRCLkiuHbGVkHJ4SoBYccgevv7yedTldup9NpNmzYcMDj77//fs4+++zK7XK5zKc//Wksy+LSSy/l3HPPfWUtPgJaawKlCXwPa5/7PaPReAc8TwghhBDTj6UVBX2AbQQA5Y8AmSlqnRBCnBjHtIjJQw89xKZNm7jhhhsq9339618nlUqxa9cu/u7v/o558+bR1tY27rxVq1axatUqAG666SYymaP/5WvbduX8RDwGlEgmEyT2ueYQDpYKXtHzTCf79rmW1GK/a7HPUJv9rsU+C3EotmLCGjjLsigGLgBaCpkIIWrAIQNcKpWir6+vcruvr49UKjXhuGeeeYa7776bG264Acdxxp0P0NrayqmnnsqWLVsmBLiVK1eycuXKyu3e3t4j78moTCZTOb9cCvd6G+wfIL/PNbXRaFN+Rc8znezb51pSi/2uxT5Dbfb7SPs8e/bs49gaUSsOVbQMYPXq1fzXf/0XSinmz5/PNddcc8LaZ2mFryyMN34ZRJlwiyCZQimEqAWHDHAdHR10d3fT09NDKpVi9erVfOxjHxt3zObNm/nWt77F9ddfT0NDQ+X+bDZLJBLBcRyGhoZYv349l1566bHvxQFYWgEGf78iJgE2lpJ94IQQQogxh1O0rLu7mx//+Md84QtfIJlMsmfPnhPaxrCIiTWxOJkKC5dIgBNC1IJDBjjLsrjqqqu48cYbCYKAFStW0N7ezp133klHRwednZ3ccccdFAoFbr31VmDvdgHbt2/nm9/8ZrgWLQi47LLLxr0QHG96LMDtV8TEKAdbBwRBgNZVvZe5EEIIcVj2LVoGVIqW7fu6/atf/Yo3v/nNJJNJgHEf2p4IYyNw+66BA7CcGOVAj66BE0KI6nZYa+CWLVvGsmXLxt13xRVXVL7+3Oc+N+l5S5Ys4ZZbbnkFzXtltKWBgMDfP8DZOJahVC5XqmcKIYQQtexwipbt2LEDCF/3gyDgHe94x7jCZcebrcFTetwaOAgLmRQ8C1sCnBCiBhzTIibTjTW6mae/f4DTLq5lyJZKEuCEEEKIwxQEAd3d3Xz+85+nv7+fz3/+83zpS18ikUhMOPZYFSgbV5wsNkCgLRylSO1zvfr6enJlixarTKQKiv/UahGjWux3LfYZarPfx7LP1R3grHB65P5TKNFOOAI3WuRECCGEqHWHU7QslUqxePFibNumpaWFWbNm0d3dzaJFiyZc71gVKNu3oI9XKuKhKBfyE66XLSpS+QEGqqDgUS0WboLa7Hct9hlqs9/HsjhZVS8AG1vf5vtm3P1KR3C0BDghhBBizL5FyzzPY/Xq1XR2do475txzz+W5554DYGhoiO7u7sqauRPB0iqcQulNnEKZLSi0L9sICCGqX42MwPn7PeDiWIZyuTzJWUIIIUTtOZyiZWeddRZPP/00n/jEJ9Ba8+53v5u6uroT1kZbK3wmroGLRCJkB5UUMRFC1ISqDnBhFUomFDFRVgRLQ7lUmIpmCSGEENPSoYqWKaV4z3vew3ve854T3TQALMWkAc51XXIlhTZFMB6oqn57I4SocVU9hdKyLACCYPwUSm2HG356JZlqIYQQQswUY1MojTdxBG6kFL7my15wQohqV9UBrrIGbr8iJmMBLvBkBE4IIYSYKewDzKwZG4EDCXBCiOpX1QHuQFUotRMGOL8sAU4IIYSYKazRAOft97q+7wickkImQogqVxMBLvAnn0IZlPMnvE1CCCGEODr26LsWf7+lEWGACx/UfvZEN0sIIU6omghw+/+iN8oJ//aLJ7xNQgghhDg6lgpH4PxJp1COBTiZQimEqG5VHeC0Hi1iYsb/opcAJ4QQQsw8dmUK5fj7I5EI+bLCGGQvOCFE1avuAGdNvpG30WGAw5eNvIUQQoiZYmwNnK8UZp89Xl3XxaAoGVf2ghNCVL2qDnD22Bo4GYETQgghZrzKCJyyYJ+tBJRSuK5L0XdkCqUQoupVdYCrfFK331QLRgOcMuUT3CIhhBBCHC0rfFnHVxb4/rjHIpEIBd+WACeEqHpVHeD02C/6/coNV6ZQBhLghBBCiJmiMgKn9bgROBgtZFK20YGsgRNCVLeqDnBj1ar2y28Y5QKgZQROCCGEmDH2roGzwB//Gh5uJaBkDZwQoupVdYAbG4ELzORFTGQKpRBCCDFz2OMC3PgplK7rUiyDCqRAmRCiulV1gKt8UrdfgAMrLDWMj5nwmBBCCCGmI6tSxGTiFMpIJEKhZMIPZ+W1XQhRxao6wOmxDT/328gbpfCxcCxDuSyjcEIIIcRMUClioq1J18DlSwEKAzLDRghRxao6wFV+0e9fhRIIsHEsQ6kkUy2EEEKImWDcNgKTrIHLF8MXfFkiIYSoZtUd4EZ/0e+/Bg4kwAkhhBAzjXWQNXCRSITS6F2yDk4IUc2qOsAdqIgJhJt5yxRKIYQQYubYW8Rk8m0ESn74uDIS4IQQ1auqA9zYNgL+JGuZjXJwtIzACSGEEDPF2NIIT1vgTZxCWR4LcLLPqxCiilV1gNP6IAFOOzKFUgghhJhBDrWNQFlG4IQQNaCqA5xVmUI5yYPalQAnhBBCzCDjthHwJ24jUPLGRuDktV0IUb3swzlo7dq13H777QRBwEUXXcRll1027vGf/vSn/OpXv8KyLOrr6/nwhz9Mc3MzAA888AA/+tGPALj88st54xvfeEw7cDAH3gcOlCUBTgghhJhJxo3AHXQNnEyhFEJUr0OOwAVBwG233cb111/Pl7/8ZR599FG6urrGHbNgwQJuuukmvvSlL3Heeedxxx13AJDNZvnBD37AF7/4Rb74xS/ygx/8gGw2e3x6MomxIiaTTaFER6SIiRBCCDGDVD6Y1RZmkhG4vWvg5MNZIUT1OmSA27hxI21tbbS2tmLbNsuXL2fNmjXjjjn99NOJRCIALF68mP7+fiAcuTvzzDNJJpMkk0nOPPNM1q5de+x7AXie4eVNRQb79/7SPlgRExmBE0IIIWYWe6yIySRVKMNtBGQNnBCi+h0ywPX395NOpyu30+l0JaBN5v777+fss8+e9NxUKnXQc18J3zc8vSbPjq5c5T59kDVwRru4FhLghBBCiBli/D5w4wOcbdt4Qfi2RqpQCiGq2WGtgTtcDz30EJs2beKGG244ovNWrVrFqlWrALjpppvIZDJH/NyBb4AhvDLjztfmedDWhGuqkXo8bdBaH9XzTSe2bc/4PhyNWux3LfYZarPftdhnIQ7FrhQxmbgGTimFsqPhDRmBE0JUsUMGuFQqRV9fX+V2X18fqVRqwnHPPPMMd999NzfccAOO41TOXbduXeWY/v5+Tj311Annrly5kpUrV1Zu9/b2HlkvRlk2FPLlcedrDGU/mHDNRMEjYRmGh4eO+vmmi0wmM+P7cDRqsd+12GeozX4faZ9nz559HFsjxPSwdw3cxCqUAK4bwQu0jMAJIaraIadQdnR00N3dTU9PD57nsXr1ajo7O8cds3nzZr71rW9x7bXX0tDQULn/7LPP5umnnyabzZLNZnn66acr0yuPB8dRlIrBuPsszAH3gQMIyoXj1h4hhBBCHDtj2wNNNoUSwnVwXqBlDZwQoqodcgTOsiyuuuoqbrzxRoIgYMWKFbS3t3PnnXfS0dFBZ2cnd9xxB4VCgVtvvRUIPzn+1Kc+RTKZ5O1vfzvXXXcdAH/yJ39CMpk8bp1xXEWxFADW3vYbQzDJsUaNBjiveNzaI4QQQohjRymFpSafQgmjlSgDjS0jcEKIKnZYa+CWLVvGsmXLxt13xRVXVL7+3Oc+d8BzL7zwQi688MKjbN6RcdyJI3D6ECNwxpcAJ4QQQswUllYHHIEb2wvOkRE4IUQVO+QUypkknELpj7tPYwhQE44dG4GTACeEEELMHLZWeJZ9wBG4kif7wAkhqlsVBrhJ1sBNGuDc8Av5JS+EEELMGJZW+JZ9wDVwRQ+UkSmUQojqVV0BbpIplBZm0n3g0OHsUWXKGDPZAUIIIYSYbmwFvrbB9yc8FovFKJUBmV0jhKhi1RfgSsG4QKbVwUfgHMvIZt5CCCHEDGFphadt8CaOssViMUq+kgAnhKhq1RXgnDColct7A5x1iDVwjpYAJ4QQQswU9tgUyknWwMViMcq+kuURQoiqVl0Bzg2DmlfaZwQOJh+BG61CKSNwQgghxMxRGYGbZA3c2Aic7AMnhKhmVRXg7MlG4NTB94GTACeEEELMHLZS+No64Bq4sq/QZmK4E0KIalFVAc5xw+6UZQROCCGEqEqWBl9ZmEnWwEWjUUq+wlIemMk+vhVCiJmvugLcpGvgwJ+km5UiJrIGTgghhJgx9hYxmTjKFo1GwzVwADIKJ4SoUtUV4EbXwO07AhdOoZw4AocKtxGQETghhBBi5rD1gadQKqVAhx/Qyjo4IUS1sqe6AcfSZAFOKw4Q4DQGC8cy5CXACSGEENPOSNYnGhk/VdLSCl9ZkxYxCQ+IAKCCMsY63i0UQogTr6pG4GwblBo/hVIDvpokwAFGuzICJ4QQQkxTj/4qy9o1/ePusxV42oLS5Hu9KSsa/i0jcEKIKlVVAU4phePq/aZQgq80Jpi4mNkoh4itJMAJIYQQ01Akqsnnxk+VtLTCtxwY3jPpOcoeDXCyF5wQokpVVYADiET0ftsIhAGOyQKcdog4EuCEEEKIMWvXruWaa67hr/7qr/jxj398wOMee+wx3vnOd/LSSy8dt7ZEY2pCgAvXwNkwNDjpObYbB8IplEIIUY2qLsC5EWvCCFyAhmDiYmejHFwbCXBCCCEEEAQBt912G9dffz1f/vKXefTRR+nq6ppwXD6f5xe/+AWLFy8+ru2JRDT53Pi1bpZWeFY4hdIUCxPO0U4s/CKY+JgQQlSD6gtw+02h1AoCNXmAQzlEJMAJIYQQAGzcuJG2tjZaW1uxbZvly5ezZs2aCcfdeeedXHrppTiOc1zbE4kp8nkfY/a+rttK4Y9Wkp5sFM6JhCNwXil/XNsmhBBTpfoCXHT8FEp90CmUrozACSGEEKP6+/tJp9OV2+l0mv7+8UVENm3aRG9vL8uWLTvu7YlENSbYb3sgDZ4affsySYCzI0kAvOLIcW+fEEJMharaRgDAdS28ydbA+ZMHOKlCKYQQQhyeIAj47ne/y9VXX33IY1etWsWqVasAuOmmm8hkMkf8fEMDw0CeWLSBpnS4PUAiPoDRWQDqlCG633WH+2dBPzg6IHUUzzkd2LZ9VN+vma4W+12LfYba7Pex7HP1BbiIpjRuDZw64BRKo1xcK5AAJ4QQQgCpVIq+vr7K7b6+PlKpVOV2oVBg27Zt/O3f/i0Ag4OD/OM//iPXXnstHR0d4661cuVKVq5cWbnd29t7xO0plcNCJDt39uObcLqmVypSHp1SOdT1MtmF469b9MKtg7LD/QRH8ZzTQSaTOarv10xXi/2uxT5Dbfb7SPs8e/bsAz5WdQEuEtEEPvi+wbLU3jVw/iQBTrvY2pcAJ4QQQgAdHR10d3fT09NDKpVi9erVfOxjH6s8Ho/Hue222yq3b7jhBv7sz/5sQng7ViLRcKpksbDvFEqFZ0b3d51kK4FINAlDEJRlDZwQojpVXYBzI+Eve68cBjhLq3AKpZlsHzgXR4UjcMYY1AE2/BZCCCFqgWVZXHXVVdx4440EQcCKFStob2/nzjvvpKOjg87OzhPankg0fF0uFva+htsKfGMglpg0wMXicUo+GH/yjb6FEGKmq74A51pAuOA5EgWtFL6yDjwCpzyMCfA877hX0xJCCCGmu2XLlk0oUHLFFVdMeuwNN9xwXNviOAqtJxmBC4C6hsmLmNg2ZV9LgBNCVK3qq0I5OgI3VonSUhAodcA1cEqBraUSpRBCCDHdKKWIxe3xI3Ba4QcG6hsxB9jM2ws0SgKcEKJKVW+AGy1kEo7AHbgKJYArlSiFEEKIaSkWtyaMwBnAr2+YdAolgG8slCmfoBYKIcSJVXUBLhIZnUI5NgKnR6tQmsmnUAJSiVIIIYSYpmJxi2J+3zVw4bq4oK5p0imUAD42WgKcEKJKHdYauLVr13L77bcTBAEXXXQRl1122bjH161bx3e+8x22bt3Kxz/+cc4777zKY1dccQXz5s0DwvKZn/rUp45d6yex/whcpYjJZCNwajTA2TICJ4QQQkxHsbhNz87xG3kD+HWNOCPDGN9HWda4cwIcNDKFUghRnQ4Z4IIg4LbbbuOzn/0s6XSa6667js7OTubOnVs5JpPJcPXVV/M///M/E853XZebb7752Lb6ICYGuIOsgdNh0RLZzFsIIYSYnmJxi2LRYAKD0gpbhyNwXrIRjIHsEDQ0jTvHaAdLjUiFaSFEVTrkFMqNGzfS1tZGa2srtm2zfPly1qxZM+6YlpYW5s+fPy1+Sdq2Ruu9Uyi10uEIXDDZCFwEkDVwQgghxHQVi1tgoFjcO7MGIEg2hAcMD044xygXRxs8zztRzRRCiBPmkCNw/f39pNPpyu10Os2GDRsO+wnK5TKf/vSnsSyLSy+9lHPPPffoWnoEHFeNm0IZKAvj+ewfL8dG4GQKpRBCCDE9xeLhW5ViwRCNsXcELlEfHjA0SSETK4JjGYbyedkiSAhRdY77PnBf//rXSaVS7Nq1i7/7u79j3rx5tLW1jTtm1apVrFq1CoCbbrqJTCZz1M9n2zbRqI1WLplMhng8BpSpSyaI7X/dXAm6whE427Zf0fNOpZnc9leiFvtdi32G2ux3LfZZiMnEYuH6tnArAQtr9NNYP1EHgBkanPABrbIiuJYhn89TX19/4horhBAnwCEDXCqVoq+vr3K7r6+PVCp12E8wdmxrayunnnoqW7ZsmRDgVq5cycqVKyu3e3t7D/v6+8tkMmgrIJst0NvbS7lUBDQDAwOM7HddXc6RASI2DA4OvqLnnUqZTGbGtv2VqMV+12KfoTb7faR9nj179nFsjRBTJxYfC3Djp1B68TDATbaVgHZiOH5APp8/MY0UQogT6JBr4Do6Ouju7qanpwfP81i9ejWdnZ2HdfFsNku5HJbxHRoaYv369eOKnxwvtqPwxtbA6bCL/qT7wIXTKmIRLVMohRBCiGlo7xTK8HV8bAql78bAsifdSsCyY7gW5PO5E9ZOIYQ4UQ45AmdZFldddRU33ngjQRCwYsUK2tvbufPOO+no6KCzs5ONGzfypS99iZGREZ544gnuuusubr31VrZv3843v/lNtNYEQcBll112QgKc4ypy2fAXffhJnZk8wI1uIxBzNT0S4IQQQohpx3E1ljVxBM43QF3DpEVMLDcGeSjlsyewpUIIcWIc1hq4ZcuWsWzZsnH3XXHFFZWvFy1axDe+8Y0J5y1ZsoRbbrnlFTbxyDmOGreR94ECHMrGoIi6itIeCXBCCCHEdBSJ6r0jcGoswBmob8RMUsREOzEASgUJcEKI6nPIKZQz0VgVSmNMZQplMMk+cCiF0S4RR8kUSiGEEGKaikTVPiNw4X1eYKC+YdIplOhwmyCvNHKCWiiEECdOdQY4R2EM+B5Yo7/p/cBMeqxRLhEbCXBCCCHENBWJagr7r4ELQNU1TlrExKhwjbtfkiImQojqU50Bzg1/uZfLe0fgfG+SETgIR+AkwAkhhBDT1vgRuNEqlGMjcMN7MGb8h7RGh2vc/bIUMRFCVJ/qDnAlgzUW4IJJ1sARjsDJRt5CCCHE9BWNacolQ+CbfUbgDNQ1QrkEhfEjbWNFyoKyjMAJIapPdQY4Z+8I3NgUymCyIiaEn9I5OpAAJ4QQQkxTbiR8XS8WDdZoERNvtIgJMKES5dg2QYFXOFFNFEKIE6Y6A9w+I3Da2qda1SSMcnGsAN/38TzvhLVRCCGEEIcnGgvfrhQLAfboOxc/MKi6hvDGfoVMxkbgVFCS13YhRNWpzgDn7DuF0gIOPQIHVDYdF0IIIcT0EYmOjsAVzD5r4AjXwAHst5XA2Bo41zaMjEglSiFEdanOALdvERNrn7nykzDaxVJhgROZRimEEEJMP3sDXDB+DdzoFEozvH+AC6dQOpYEOCFE9anKAGc7ChSUigF6bATuIEVMbBVOr5AAJ4QQQkw/kcjYFMq9a+B8YyB58CmUjmXIZmUzbyFEdanKAKe1IpHQZIeCQ+4Dh3axkAAnhBBCTFeWrbCdcARu3428lW1Dom5CEROUDYArAU4IUYWqMsABJOs12SF/nwB3oBE4B42HQrYSEEIIIaarSFRTyJtxG3kDUNeA2W8EDqUxyiHqKAlwQoiqU7UBrq7eIpsNKht5BwdcAxcBwmkWEuCEEEKI6SkW1+RzwfiNvIHhhmZ6RyYWITPKJR61JcAJIaqOPdUNOF6S9RYmAL90qAC3d6GzBDghhBBiekokNTu2lccXMQG+1fwGXvZcvrbf8UY7xCJaApwQoupU8Qjc6NTJfHj7gFUoRxc6R2wJcEIIIcR0FU9oyiVDMLqtmze6v+t6t4WuSJpSb++44412ibkS4IQQ1adqA1yyPqw+6eXCX/AH3kYgnELp2lLERAghhJiu4snwLUspFy5+8wPDUMFjd+AQKM2O59ePO94oh4itGBkZOWAlaiGEmImqNsDZjiIaU5THApw5cBETgHjEkgAnhBBCTFOJ0QCXGwnQKtzIe9NAsfL49pe7xx1vlItrgzGGXC53QtsqhBDHU9UGOIC6BoviSBjgDrwGLpxCmYhKgBNCCCGmq3ginFmTy4abefuBYWN/ofJ4V+/4qZJGuzhW+OGtTKMUQlSTqg5wyTpNaSzA5QuTHjO2Bi4mI3BCCCHEtOW4CsdV5EYCLKXwjGFTf4HWpENGldjuOZjsUOV4o11sLQFOCFF9qjvA1VsEPiTRePv8Ut/X2AhczNUS4IQQQohpLJHUjGQDbB2ugXupv8DCpihz6hy64i2wcV3lWKMcbOUDEuCEENWlqgNcXUM43aJR2fgH+OU9FuCirqJYLE56jBBCCCGmXjypyWXDveCGij47s2UWpaLMbWlke7yFYP1zlWONdtGmjNZSiVIIUV2qOsAlR7cSaMQmyOcx3uQbfUJYxGRkZOSEtk8IIYQQhy+eCDfztpViQ1+4NGJhKsLcpigFO0Lfps2VY41yUaZEMpmU13chRFWp6gAXiWhsNxyBC5SC/t4Jx4yNwMUjFvl8HmMmL3YihBBCiKmVSGqMgTplsSsbfii7MBVlbn34Wr59II8phBUnjZVAGY90Q5Th4eEpa7MQQhxrVR3gIJxu0ahsfKWhr2fiAcrCYBF1NUEQkM/nT3wjhRBCCHFIY3vBJQmXSKTjNo1RmzljAS6WgY0vAOC5rQDMaZI1cEKI6lL1AS5Rr2kkDHCmd9ekxxjtEg23g5NpFkIIIcQ0NbaVQN1ogOtIRQFIxWxitqIr2YrZEK6D8yKzAGir98hmszLDRghRNeypbsDxlqiziCqNbyehf/ekxxjt4qrwa9nsUwghhJieYjGF1hAfC3BNYYBTSjG3IcL2pvmYNXcSeGUC3yN4lU0mlq/MsInH41PZfCGEOCYOK8CtXbuW22+/nSAIuOiii7jsssvGPb5u3Tq+853vsHXrVj7+8Y9z3nnnVR574IEH+NGPfgTA5Zdfzhvf+MZj1vjDMVbIJKifDb1bJz3GKBfXCj+ZkxE4IYQQYnpSWhFLaBL58LV9bAQOYE69y+8TLTDYj3ngFxAElDOzaZjXALiMjIxIgBNCVIVDTqEMgoDbbruN66+/ni9/+cs8+uijdHV1jTsmk8lw9dVX87rXvW7c/dlslh/84Ad88Ytf5Itf/CI/+MEPTvg89Pr68FM6Es2Y/knWwBGOwDk63CtGApwQQggxfcUTmpgJX9sXpiKV++fWu/QGDqWv3IX1L/+Fvvo6yruLxNUgCiPr4IQQVeOQAW7jxo20tbXR2tqKbdssX76cNWvWjDumpaWF+fPno5Qad//atWs588wzSSaTJJNJzjzzTNauXXtMO3Ao8YSmZAKIpqH3AAFOuWjj4bquTKEUQgghprFEUhMNNI0Ri1Rs70SiufVhmNsxXBq94yS8ngKW8kklfAlwQoiqccgA19/fTzqdrtxOp9P09/cf1sX3PzeVSh32uceKpRW7TRltN8JgH8b3JxxjtIMyJRKJhIzACSGEENNYPKmxjeLikxrHfXA8pyGsRNm1pxje0ZiinA3f5swaLWQihBDVYFoUMVm1ahWrVq0C4KabbiKTyRz1tWzbnnB+D9uZTQJPObSpACvTOu5x1V8HuSEaGhoolUqv6PmnwmR9rgW12O9a7DPUZr9rsc9CHI5EMpw++dYFTePun5V00Aq6hsIROKUUXmw2JghoTym2SIATQlSJQwa4VCpFX19f5XZfXx+pVOqwLp5KpVi3bl3ldn9/P6eeeuqE41auXMnKlSsrt3t7J264fbgymcyE83spoUgyWL8Qd8N6lHbGPV5XBtfL47ouO3fufEXPPxUm63MtqMV+12KfoTb7faR9nj179nFsjagVhypa9tOf/pRf/epXWJZFfX09H/7wh2lubj6hbYwnwlG1kZGAxr2TfHAsTVvSYftogANQs0/CG3ieWQ0ev98mAU4IUR0OOYWyo6OD7u5uenp68DyP1atX09nZeVgXP/vss3n66afJZrNks1mefvppzj777Ffa5iPWqzwABhsXY/om7gVntIMKwimUuVxO9ooRQghRcw6naNmCBQu46aab+NKXvsR5553HHXfcccLbORbgctlgwmNz6iOVETgA5i7A21WgOV6QKZRCiKpxyBE4y7K46qqruPHGGwmCgBUrVtDe3s6dd95JR0cHnZ2dbNy4kS996UuMjIzwxBNPcNddd3HrrbeSTCZ5+9vfznXXXQfAn/zJn5BMJo97p/bnKyg7AQMNi6F3x4THjYpUApzneZRKJSKRyCRXEkIIIarTvkXLgErRsrlz51aOOf300ytfL168mIcffviEt9N2FJGomjTAzW+M8OSOLEUvIGJrVPtJlNcXqD+1RLkwhDFmQsE1IYSYaQ5rDdyyZctYtmzZuPuuuOKKyteLFi3iG9/4xqTnXnjhhVx44YWvoImv3Jx6l02DBazUUkb6n6Vuv8eNdlD4JOLhfjK5XE4CnBBCiJoyWdGyDRs2HPD4+++/f0pm1UA4CpcdnliUbEkmim9gY3+B01riMKsdb3c4IpeK5hkZGZmSD5KFEOJYmhZFTI63v72wnR890o/udfiMdQEf2JXj9Na9m3kaFVauqouHf4+MjNDU1DTptYQQQoha99BDD7Fp0yZuuOGGAx5zrAqUTVbQZ+58+P3aQerqmohErMr958cb4MHtdOU0F4ye06/DdfttdWW6urom7Fk7HdVqEaNa7Hct9hlqs9/Hss81EeDqIhZvPzfFr38+TIux+b9rdvLVt55UmUZhdBjcEqP7ychWAkIIIWrN4RYte+aZZ7j77ru54YYbcBxnwuNjjlWBsskK+tQ3eZgAXnhuF3PmuZX7i4WAkxNRntjay5sXhLNqgsa5BMU+Fra53LtmDUuWLJn20yhrsXAT1Ga/a7HPUJv9PpbFyQ5ZxKRaJJIahyJn5wd5eU+JF/sKlccqAS4avhBJgBNCCFFrDqdo2ebNm/nWt77FtddeS0NDwxS1FJpSFm5EsXN7edz9T6/J8dpyA+t35/cWJJuzgPKuPO1NhoGBAbq3bCZ4/EEpWCaEmLFqYgQOwv1gmiIjZJ1Gohbct3GQJZkYsHcKZcQJi7bkcrmpbKoQQghxwh1O0bI77riDQqHArbfeCoSfKH/qU5864W1VWtE626G7q0TgG7SlyI347NrhYaHwPdiVLdNW56LaT8Jbt4q69j04zizW/eIntD51PyrTCh2nnPC2CyHEK1UzAQ4g1WDoKc7igoadPLBliPef00LcsSojcNqElShlBE4IIUQtOlTRss997nMnukkH1DbHYdvmEn29Hs2tDltf2rt9QFrZvNCbp63OhbkLKD9YIKE8zp6dZO2mXl6rLSLPr0XtE+DKvuHJ7izLZiVxrOk9xVIIUdtqZgolQNOscMTtXFWk6Bse2jIE7B2BU0GJeDwuAU4IIYSY5jKtNtqCXdvL+L7h5U0lmtvCz6VbLJf1vfnwwKYM3lD4duf03rWULZuXFpyKWbe2cq2yb7j5ke188cHt3L2ub/+nEkKIaaWmAlzjvBQq8HCzsKAxwn0b9wB718ApU65s5i2EEEKI6cu2Fc2tNjt3eOzYVqZUNHQsiZCs17Q7Li/sDgOcUoqd8Q6CAFJOlsZ4jBeaZsOm9ZhCvhLeHu/K0pZ0+NG6fgYL3hT3TgghDqymApwdj9I28DRbvfmsTDTwUn+BTf0FGAtwQVGmUAohhBAzROtsh/xIwAvP5EnUaTKtNg2NFg3GZstgkYIX4AeGL7VczJZCAxtOOZ3mxaezo+TTZ0fpfe45/nE0vH2gs5XPrZhL0Q+469naqo4nhJhZairAAZx90h7mbn8AdmkutBr473X9BITVJ9XoGrhisYjnyadvQgghxHTWOjt8/S7kDQs6XJRS1DdaaE9hG8WGvjw/f3GA9TSQ36NZkBzi37clMdrmtlMu5i9eSPLb0fD21iVNzK2PcPGiRu7ZMEj3cOkQzy6EEFOj5gKc/QeXc+aSMks23MlCFcNsU/zghSwAKigTj4cbfMs0SiGEEGJ6i8Y0jSkLbUH7SeFsmvrGcGPvtHJ4YPMQ31u7m87ZCeaddi4t7ggrFyXYEp1PIhjmit0P8S9vO4m3LmmqXPNdZ2RwLMX31u6ekj4JIcSh1FyAA7De+g4WvaaN+S/fyyIV5b+eGQbCIiaJRAKQveCEEEKImeCMc2J0Lk/guOFbmoamMMCdFI2w6qU9WFrx4de04UfCTXE/ehZ88d0XEdGK+EgXc4Lxr/dNMZvLlqZ49OVh/t/Tu+nJjt9rTgghplpNBjgA/aZLmZ8aRinFRU2NFHyLrQNDlRE4CXBCCCHE9NeYsitTKQEiUU0kqmh3IwC8b1kLmbiDF5kFgF3sJhaNcs4pS3i5LsOO366ecM3LlqbpnJ3grt/38YH/fom/+dXLMqVSCDFt1GyAA6hbehKNgxvo8GzKOLywaw+P7QrXvkmAE0IIIWam+kaLZu3w7rMyvKmjAYDAriOwktjFbgDOfP0FxPwyj294acL5MUfzuRXtfPPShbzrjAwb+wt85TfdBMac0H4IIcRkajrAqVPOon3Hg4zkLSJ2lLlJxW1P7wGUrIETQgghZqj6RovSiOHtS9MotXdTbs9twy6FAc6NROiMKLp8xbp16ya9TmvS5V1nZrhqWQvP787zwOahE9J+IYQ4mNoOcKkMs+jCCkqUyg5nNNu8dn49ReXybFc/Rj5pE0IIIWachkaLIIDscDDu/nJkFnapB4wPwOmnn8bcbB/3/+pXdHV1HfB6Fy5sYEkmyref6iFb8o9r24UQ4lBqOsABOEtOYVbPb8kXbVRQ4n+/djZuLEZX7x6+8ptuyn5w6IsIIYQQYtoYq0S5Z3B82PIis1DGwyqF+7zZrzqPN29/ngYNP/vZzxgYGJj0elopPvjqNoYKPv/xjOwRJ4SYWjUf4NTSs2nfdj9l38Ur5LG04qSWRtoiPr/ePMTnfrWNPQXZE04IIYSYKRJ1Gm3B0EAY4IqFgL4eD88dLWRS2gGAqmsgtuw83vLSkwQBfP8/f8yTv3uBQqEw4ZodqSgXNxfY/fjPuec3T8ssHSHElLGnugFTbsnpNA7dxFD+NbTVPc1wdidNTU28/PLLfPINzfzz73q57pcv809vWYBr1XzeFUIIIaY9rRV19Rb9vR7rns6zZUMR34dTTq9jecTCLu6kWBceO3DOpTzDxWRcl12D9/PI6vt4ZDW0tLQwZ84c5syZQyqV4vHHH8dbv546YO0Ta/if3UnetLiRufURil5A0TcsbIqwoClaaYcXGH65cZCiH/DWk1M4lpq8wUIIcQRqPsCpeBK1YBFm7U7KK1146afMm3cJTz31FLOCPv66cza3Pd7DT54f4E9OT091c4UQQghxGBqaLF7eVGKw32fOvHCbgRd+X+bMVzXjFrvJ5wKefybP9q1popFBXrvzf4i85y/59b0vY8d68MxOnn76aZ566ikAtNace+65RONJHnrgflJeP7c/OXGPuNfMTXLFGRn2FDxue6KHrqFw+4H7XxriI+e1sSQTO3HfBCFEVar5AAegTjmTxnt/RP8ffIRZ1v1seLmPaDTGmsfXU++28Id2inufG+DCjgZSMfmWCTEdKb+Am1tPZOQFjLIpxRdTii/CWPGJBxsfMKDsCferoAxKYZQFaFAHGHk3BgjAjK6TVQpQoKxJjg1QpgRBGWU8UBaBjoJywHhY3iCWN4BBUY4vPvpvghCiYn6Hi2XB/EUR6uotjDFYVp7u/mbmmU3c/5shMLDolAgdAxuwHvwlevAiTj/rJDasa+G8172GTKti586d9PT0MH/+fNLpNJ7n8dvHVvMadxcfWnkW2ZJP1NY4WvHw1iH++4V+Hv/FFgBm1Tlcf8EcFPCN3+7iU/du5dy5SZKuhWMpTmqK8OZFjeMqZQohxKFIGgHU0rMwv/gBeriOUrKR0xru5zG1hP7BLZz1Oovt2wKW5+r5j6d289Hls6a6udObMdilndiFl7HK/VjlPnSQB8I3t56TZiRzCUZHD3Wl6jTuTb+h8oZ/spBg/NGgocKgcaAX+KCE9rOooIwypTAgoDCo8BxlY7BAKbQ/gvaG0f4wypRRgQfGC88xHgofo2yMimB0ZLRd4bWU8cLrB+GnyUZZo2HFGv1ah0ElKIT/5sbD6MjoteywH4AywehzF8NrGQ9lyhD4GHR4rNIo448+Zxm1U9FULqJMeAxq9DlHr2eMj1PahcInsBJgfGLDv8OgCKy6vd87E6CDQvh8gFEOgRXHKBvt50Z/Vvf7Z1DOPmGrPNr2MoqJlegMilJ8CcMNKyjYcyEoUJd9jOTwo1jBxK1JDBrF3kJJJXcOg/MkwAlxLDSmbBpTe9/mKKU489UxBp+dRdR6lgXteU46vYV4wsIUX0/wo3/HPPBzTr7qf7Nrh8fTa3K84eI65s6dy9y5cyvXsW2b0047jSeffJILLigyJxPOxTTG8I7TUvzhkibu2ziIa2kuXtSAM7r84vTWOHes3c0TO0Yo+4aiH3DPhgCF4s2LG0/o90YIMbNJgANYtBQcF/PC78m/5Q9I7/pPVr7qZH602iPesJvOufN49P5hureWeOmUAh2pGgkfxscq7cYudWN5e9BeFh2MYLDCN71WnECP/R3DLm4nNvwUdmlneLqy8e2m8A01oIxPbGgNbn4Te2a9G99teWXtCzzs4g7sYjcqKAAGTIDRUQIrSWAn0X4eq9yHVQ6rhgVWPYFdh2/XE9j1BFY9AFa5F6vci/ZzGOVilE3ZU5hyHlPOoY2Pm0xi7CRGR1BBEfwRvNwIlp9F+1ksk4XAC0dxjI8xoyEKha1LOCqPNgUUExe+7z0WUApFMO64wCh8E6H0YoR4YOEbB0VA1BrG1RMX2x8J31gExiYwFgaNxsfWRSw1sQKrMQrPOIBCKx+Fj1ZmwvU8EyMwGosytiph6f0qwQVO+Me4eIGN59v4gUarAEv5aOXjGxvf2ATGDn+WgnjYPmXQOjwuMOD7FkFgM1A4h13FJRTsuViWIqm2k3FeImaF+zYpDL7RFMsRCmUXYxRRp0DMyWNpn3w5RqEco+i5aGWwLIOtPWxdxtFFLO3h+RZlL2y7bzTGaILRWlAKiNp5FqWfJZP7V3YOz6UptpuIXWTbnoXsGJqPb2y8wEarANcqErGL+IHNcLGebKkBHU9xzrxX9M8phDgIpRTpJUth2310LnmJfCL8UFZFoqjlF2Ie+AXq1Fdx9uLTePTJKA/cM8RpZ8doP8kdN0p2xhln8MQTT/D73/+e888/n76+Pn7+858zODhINBolHo/jNjby7MgsZs2aRUtLC3HH4gOvbqtcww8MX3igi2/+bhcLUxEWp2VqpRDi8EiAA5TjwilnYh66l0LHEuKt7ZyVeooH6xp56aWXeNObFrLg5AjqRcUPHu3jmj+YRdTeO2JSKgX07PBonePQnSvxm5eHOXdukpOaTmzQ0+VBnMLLWN4AujyAMiXK0QWU4osInNShLxCUcApbcXMv4eZfwi7tHB3NGX1YuXiEoxsRk0OridU5s8xll/8Whq2TSc9OE9lvyqmT20TDrv+gadvXyTa/Fd9pxmiXQMcI7MZxo0zKz4X9Ke3GLvdilfvCkRPjh1PRXuojZQ5vPx4vcDFonFcSdooHuNuLki/HyXlxvMAdDUQ6jG7KoAgoB00UvRglP4If2AQoQGPbBtsKsLRP4Bt8z4AyGKPxAwu0jW0TBkBdxLE9LErY2sMAu8rt5Mp1DOXilAOXpuYYdU0uXVtKFHI+dfWKSMRA4IMJyJdj5EoJRkoJAlzQNlqH33NjIDAGx9FEo4pIJDynXDKUyj6Fkqboa3x/9HJemFcxBtv2sZ0gHIHyHPzAYBQ4EUUioYlHFUU/oOAZyr7BRmMb0CgcV+FEFbaj8Pzw8aIXkCsGFEoBpbLBtmzwfTThORpQRqFtwAHthIOapgRm2A+/u3YbW+02jIKybyj5Bh+DCr+tGAV+zuB7EATgYfACD9/z0I6LRmEpRdRWRG2Na2tKJqAYGAp+gNJgaYWlRp87ABMYHhg5j7Mb13JG/TPsKLezduB8BrxZFHXAUNlnT9nHBIYoGnf058Q3Bk9BAs05R/8TKoQ4DEGkjXJkDtHhp8g3vq5yv7robZjfPYr59ldIAq9rWcyzZ36Yp9dk2L61zNmviROLh6/99fX1LFiwgOeee47m5mZ++ctf4jgO55xzDoVCgZGREXbv3s1LL70EQDwep7Ozk9NPPx3bDl8XLa345Gtn88mfb+YfH+riixfOprkhQWAMJU+2MBJCHJgy07AO7o4dO4763EwmQ2/vke/RYgb7Cb5xE7z0AvZlf0j6lO305yN86zdp3nvVX6DQ/OLne8iPBLwQyXHlBWlOSsXYM+Dxu0dz5EYCfG1Y62X5/ehUqfObk7xhbgPnLEmgj1XlqaCEHnweM9KLdlws16Uh5uHtfgKn1F05zFfhaIVtsuFtq250SpyNURoVlCpT2JTxAb8y4hMYzZA/h/7iHPpyLewaaqZvuB7Pd8c1xVJlonaeiF0gYucZKdUxVNwnKCrItNhkWmwcN3yDjgFvZIAl1l002OP/nYt+hP58GzmvkXSsmwa3p5Lnil6MoVITZd/BDyz8wGJPMUVfrpW+XCtFL4ZBYYzCtYpEnRyNyRzKjrKn2ESuGAcUtlUm7gyTcEeIu1lcPUSpEDA4kkLH0xinjt3deaIRj7o2RTQZJxFP4vuaHV2DeHuGcUyJnIqQj0QoRqKMoMiVfUbKAf1lj96iR2+xTNRW1EVtGiMWrq9wS5qop/G0oRQxqDikEzaz611m17mUA0P3YIndg2Vy5YCCCvCVQSlFxFJEbE0iFmMknycwUPQCBvIegwUPvwhLgxgnEcNCkcVnQyTPUMSj6AfkywGlwJBwLBqiFklXk/cMw0WfbNEPn88LKmN+jg6DSzkwFLwj/xWhVfjnlb4H0QoaIhZKa4pln6Jv8IKj+5Vla4jYmpJnKI9eI2Zr4q4mpsEe2YMz1I8O/HBEvilDKZakL+cxXNrbEddS1EUsgiAMheXAYGGwFdgKPBRlAyXfsH9TGx1DxjE4lsJTFiUswGAFPnbgMT9m+OglpwNH/rts9uzZR/V9EeJEOdrX9qN9XT+Y2OCj1PX+lL72j+NHWiv3m8CHHdswG5/HrHsKs3YN2+ZcwPNLriSWtHjtmxpxI2GI27JlCz/5yU+AsGLlW9/6Vurq6sY9z8jICN3d3TzzzDN0dXWRSCRYtmwZS5cuJRoNP+T97Qtb+OX9vybpZRnInMI61U6gFJedkuIdp6eJ2LVTAft4/FtPd7XYZ6jNfh/L13UJcPsw5TLm+9/CPHQPkYvOItXpseblGHrx+2hvbyeX9Xn4oSylYcMOk+ekOSOUdzaQNxa/DYZZQIR2FUWp0aVOo3QzvPXCxqPuEybAzW0kMvwU7vBzWGp81avAKHrzc9iZP5me/AJ2DtRTLEUAQ6ZugMWzt5FJ7CQol/BLHoHvV6avlQMXzwtHjAJsBopt7Bppxwtc3IgiFtdEY+HfY3+iMU0kqnBdhR9AIReQzwWgqDyeywbs2FZix8tlRrIT38XHYgGzGncRi5SJuh4xJ0dSdZO0dhDVe+grtrIjO5eu7Bx6SxnyxBirKYEKl1u5EYeyX0Zp8PxwJMX3DFZUUZ+2aG60McBQ0Wew4IGBqKOJ2ZquoRJrtmfZPlTCRrFExTjLShBB83szwlp/hPIkUx0BmhyLvAkoegYDRCxFfcSiLmLRFLNpitk0RCzyXsBgwWdPvoytFXHXImprip7PcLbAcL5MT1mR88eH+4bRa9laYWlGw1q4XiIwCoXBUuDamkYHmlSZpCmhLQsLB8ePMuAUyY+OOrnGJ2Y8nKDMSNmwx1OMBIqoCqhTPnVWQLw+SSydIRoJR8/yXhjoHK1IuBYxC+qiNg1Rm7qIhWtpAmPwg9HRo9Eg42hFJmGTimhU/252bt3Otp397MmVaUq4pBuTJBMRhodGGB7Okc2XCWybwHZBW0SLWeK5IaK5PaSdgMaYgxVPELM0+b7dmPwIuBG8WB1evA6/XMYfyeKNjKCLeaxSAV3MUx4eIlf0ydlR7MAjpcrUzZ2DbspAuYRfKmI8Dyvww/+sL2+CQg5es4Ly0jPxf/U/BNtfhroGbNvG8wOGlYujDZ7jULBdrHwOd2QIO/AIUHjaoqwtRpwIw4kGhuubUOUyzkgW2ysTCcIRa09rjAo/LjEoNAZtAixjSDQ0csqn/x6QACeqz3QKcMrLktnyD+QaX89I5pIDHmd278T86n/ofXYra06/hno3z/lvm4O2NRvWFXjw4Z/gukle//oLWLg4cdBiJF1dXTz22GPs2LEDy7Lo6OhAa80LL7yAE40zoBIk87vRDa0EHefz4OY9zI75vOO0DG9YOveA160m8qa+dtRiv094gFu7di233347QRBw0UUXcdlll417vFwu88///M9s2rSJuro6Pv7xj9PS0kJPTw+f+MQnKg1YvHgxH/jABw7Z4KkKcGOCh+7B/Mf/Jf7mk2g4I8KTA6cwt/PPQGlMYHh5/Wbml/6HlsROAqPYXa6nnxZiredSMifTtc0nGlVE40XWb3gRs2cWmdObOHtJuBbMDwwPbhmiIxVlfmNk/JMbD+3nKkUenOwLRPeswQkGKfpRNvcvoV+dTt3chfilMl6xiFFJ+vcYSkWDMZCs0yTrLSxLsXtXmZ5uj3LJ4DiKhpRFfWNY/CHwDUEADY0WTRmb+gaN0gcfKfQDw7Y9RV7sK/Bibx7HUixKRVmUjpGJ2ygFWimGiz7bh0rsGC4xMOLhe6MByzcUdEDJhOHCCwJKviFXDtg9UmYw76EwmNGiHnWuRiuFFxj8wBAQTvMLDONGN7SCqK2JWIpsKaiMsByIjeH0tMO5J6VoTbq8vKfItsEi+XLA7HqXuQ0R6iOaoT0jDAwOU8oXOMkuskiPkPJHoFjAFAp4ZQ8nGoFYHNwI5LIwNAh7BjC9u2D3zvA2gONCJAoj2UrlQgMMOQl2xtJYSjHLKpGIj17PiYDjhAGjkIdCHsv38EtF8H3Ij0A+V7lO0XIYcqMULIdEuUhduYAd+AxG4uyO1dMfSaAAO/DRxlCybPKWQ9FywlCsFCpRRzQSIWZbxCyLPcUSO8s+u7GwFcyqr2P24iVEtCK78QWy3TvwyyUcrXFsG9sE2IUcdn4EjKEwev2S7eAphac0/j4FWzSGZLlAXalI3Cvia40XTVCOxCgYQ8FAEYWvbYxlYbSFE3hEy0UipQJF22EkkiDrRPCVVemHpTWu6+BGomhj8HIj+IUCBB4WYCuFUgpfKQKlKFsuuUiMfKlEEBybqUsx4xMoTZHDH31vy6R5559eCUiAE9VnOgU4gIYd38Yu7aRv/rUHrjY7yvTvZsdd9/Jk41vIFLbg12cYKNczq26YottAf19AY8rizM44DU2TVKLdx+7du1m3bh0vvPAC5XKZV73qVbz61a/GcRzWrVvHgw8+iOftt0Rh1hL+8rKVxJyDX3umkzf1taMW+31CA1wQBFxzzTV89rOfJZ1Oc91113HNNdeMq8h07733snXrVj7wgQ/w6KOP8tvf/pZPfOIT9PT08H/+z//hlltuOezGwtQHOACz/lmCb9yE//b5zG0zlD2X0p56sF3iDTsJdIwt3mtpbiqR691IHTtJOB6ek6aYPBO70IWb31SpVNeba4b0EkbqzuSm3xp6ezwcFKe0xHhzB8xzNpEsryfhb0YzfoRtx9B8Xug9i57SyZz6qnpaZlmochmKOSjkqS/l2fO732A2rIOeHcDo/DUDlIuYUolC3Szi7/1L9ClnHLjPxtCb89g+VKJrqMiubJndI2V2j3gMFX1yZZ9cycfxi9R7e8gwjPbL+EE4lmAZH8eUcYMSBkXeipG34njKxjUeLh5aQcmtoxypR9kuyfIeYsU9uKUhHL8A5QKYgNZEkmX1ERaqMnRthq0bITscvsimMpBpxbE0xaEhgmIRq1RAlUvglTBljz12jN5oE8oYGspZ6ssjaBNQsCLkrQhJL0/ML0JdAzSkYGQYRoYxpSI5N05/vI6ctnC8Mo7vEyhFbyxJb7SOYTdKUyFHpjBMqpxH+3tHYPqiSXYnGuiP1RNYFtqy0ZZNQBhW/cDgWpp4NEoikaQuFqEBQ4NfopTLsjubY3exjBcEJH2PhF/CweDZDp7t4NsuuQCKSlFCU7YsPKUp+j5lb+J6QK0Uweh/caUU+/53V0oRjUaJui6qXCIoFgjKJYooinp0jYYJaA7KtNqKUjZLtxVhMJoY+4EhToBtWZQDQ9mAN8mnzxHXxY1EsC2L0XqYKMsG28I3MDw8TD4/sfpjJBIhGo1W/vb9sH/lcplCoUCxWMR1XZLJJMlkEsdxMMZgjMH3fUqlEsViEWMMtm1jWeEbH8/z8H2fIAiwLAvLsnAch3g8TiwWIxqNYlkWWuvK8Z7nEQQBsViMZDJJLBbD933K5TLlchmtNbZtY9s2yWSSurq6yjqXIAgoFMK1l2PPp7UOA7NSBEFAEASV/kUi4Yc6EuBEtZluAS4y/AwNu/6TgdnvpxxfdMjjjTFs/eUzPDswH7s8wmkvfJc5u36DOetcdr7tWtatzeP7hvPfmBxX/fJAxn4Xjf2fHzMwMMC2bdvwfR83GuPhZzdS2rmJweRc/vSPLmFRZpKtUaqEvKmvHbXY72P5un7I3zAbN26kra2N1tZwjvjy5ctZs2bNuAD3u9/9jne84x0AnHfeefz7v/8703Bm5hFRS85Af/pm+r/xj6w5pZnTZxdZ1LIbZSlyPXGy534Cb7jE91atorvbx9bNvHZpjAuWeCQGfo3npMk1LqccW0jvrpeJeRtpG1lNJv8INzS38pI+g4STpb3hJVL+bvBhqNjA83vOYDCfAcshEo/iR2fhxBO0z+rllJ7H0D99DrNhHWZPf6WtgxAGm3kLUae9qlLOHcC3XbqMzc6ubUS++29sfe3lrI/Poy4eJRN3qItYbB8qsam/wOaBIvl9Fi1FNHSYXcwd3oT2CuE4ggnCChaE4SASjRIo8A1gWWg3gnbq0QSYQpbCyG6MCdBaE41E8D2fYm7buO+1qzXNQYnEUD+JYg5PaV70ZvGLEYd0YZhX+R6Lz3oN1tz54ehVz05Mfw84MXS6GSsaC0e/bCccsbIcLKVxfdhjoCeAYS+gSLjSzwMsDAmvTDw3jCqXyDa7DCuLQd9QPMjoXX0iQV0yydahIV6YJHQANDQ0kMlksG278uZ83zf4xWKRkZERekdG2NzbV3njDmGoSqXbcByH7dksIyMjlf9LjuMQiURwXZdoNErCdXEcB9u2cV2X+vp66uvriUajjIyMMDQ0RKFQIJVK0draSlNTUyUw+L6P4zgHnO7j+z75fJ5YLFYJPsYY2LaZ3BO/wXccEq+5AKu5ddx5Y+Fp7NNj13UrQehgPM8jl8tVwpRt2+POm8m/6LXWxOMHfsOlta78fAghTpxiYimBjhAdfuqwApxSigUXn0ViR4GEZYit/HPMo7Phnh8y580bSa08hdX3D/PYgyMsX5GszHY5kLHXhP01NTWxePHiyu+8U09Zwv/c/whbnnuK7/3gx6ROfy1vO7WVhbVSEVsIMcEh3zH09/eTTqcrt9PpNBs2bDjgMZZlEY/HGR4eBqCnp4drr72WWCzGu971LpYuXXos239cqdbZZD59E2bds3z/8Seo32LzB3U+ux5ew5bnvsPGUvjJ/psueANBXw+/+v0LBKnXs+zM92KsveWA6xeewv880om7qUhH6jlObXuG5fNWYdBkdTu/6n8d92yK4eWKtDKAo7tIBmUSA7txhgcJfB8DxL0SbZah7eQzKM9ZyHPU83wpQsmNMau1kUVtTSRdxYvbe3l5Zx/Z/h7U4A6Un4dEJvzz0tPEeJpBp5HnnVZ63QyugvaY4YK0S7OXJT24nXjPy6z3DYOWS3NxhFm5PajAhyCgvpynJTdEppDFxkBjGlpmoRpSYMch6oVhKu4QNNbj7RnE7tqI2v4yxvfIJRroa51LQWmau16isZhDpVtQp54NS89CLTqV1zouL27azNPPPsuqvj4eN3WcnZ5H+uQ0rutiWeGmrFu2bKGvr49CoUC5XKZULDE0NDRu+onWmrq6OqLRKLZtE7EsPM+jxwsYMQ7GsqlL1lFXV8fihgZSqRTpdJpkMonneZTLZYwxpNPpyqJzYwwjIyMMDAxUnkNrTSqVmvBp6sEYY8hmswwODuI4TiX4jRkLgJZloZQ6JkFmbBToUMckk8lx9ymlYN5CEvMWHvA8pdQB35QcjG3b1NfXH9E5QgjximiHYvIMIsPPkM38AcZKHvocoHl2FIgCTfCH78L85tcEP/oOsWtv4vwVSVbfn+U3D2Q59awYpWJAbiSgocli3sLDf23Yl1KKP7ro9fw2Vc9jDz9EYe29/O3G02mbNYdMwq6suS94YcGqcmC4ZHEjKzsaj+r5hBDT33H9yLepqYmvf/3r1NXVsWnTJm6++WZuueWWCZ9Gr1q1ilWrVgFw0003kclkjvo5bdt+RedPpnnOXBpPO4tvf/vbfHegCPPPJDqcY2kiyvml3bhf/1tM4PPSSa9i9cMPcUp+gNYlp5KNJdk2sIeTTjqJ9/zRIlb9tof5HZeS8y5g9W9+wfbeEQb6RxjJvUQEcIEuu5Go72EHRSwrCU3JcERNKfDLYaXIAvgvbcdi70jWyy/By/u12yiboXgrvdE2ctEMy9sclj75P5idm9lc30xdbJCTc+vDgwegvAN2EP4Bh5QV8La44eTWDDo2D9wIynFRrgu2g7JtguEh/O4u/J1dBC9vJMiNYHJZ8LxwPzOtcRN1OAtPxj5nOboxRbxnB03d2zHFApF3/DmRV78Oq/2kCaNBsxecxAUrVvDiiy/y8MMP8/DDD0/4t1FK0djYSDKZJJFI0NTUxMknn0xzczPNzc2k02kSicQBR4HMPtMLj/jnormZBQsWHPF5k13ncB2Pn++ZoBb7XYt9FuJEy9efS3ToSdIv/xPDmT+kmDxr3HY2h6IiEdQfXoH5f/8Kz6whcda5nP/GJKt/nWXtb8M1ypYFWzaGL4sLTz66EAdw7qvOor2thXvuvZdzhn7HoO5nc/0SsCwUYZXdmKPxvICvPbaTncNlrjwrc1Svb0KI6e2QAS6VStHX11e53dfXRyqVmvSYdDqN7/vkcjnq6upQSuE4DgALFy6ktbWV7u5uOjo6xp2/cuVKVq5cWbn9SkYYjtdUK9d1+eM//mM2btxIe3s7bff+APXYfdA6B/XmP0YvWMyK55/hP3tG+MEjj+E+9Ai74o0AaBOwRHmc2pTkwUdsnh/K4VoWbV6e2QO9xJShxbVJeSV+0NjKyw0dFJJNFOwIgSGsRqgUMcun0R8mURqgTpWZ1VRPe6aelkyarTt30z2Yp+AFtLemWTKnmVRj/YTgYs79MDz7BOcn6xmMJeka2IMayeIM9uHu6cPOtGKftAi3MUVTUxNa778i7+A0k4cif/TP/vKjf9jnZ2x/6XSayy67jIGBAXK5XGXd0bx589BaV37GJlMsFikWD7CB2ww0k6cSvhK12G9ZAyfE8edF2+lv/yj1PT+iYdedFIfXMtT6Lox1+NMT1evehPnljwnu/h76jHNI1lu88Q/qyI8Y4gmNbcPvVud47qk8kahizjz30Bc9gFmzZnHln/4pjz76KM8++yzzTR8XXngh7e3tlWP8wPCNNTv5r+f62DVS5nXz6nixr8BL/QXmNbj8yWlpisMDdHd3V2Z5pNNp5s2bJ2FPiBnikAGuo6OD7u5uenp6SKVSrF69mo997GPjjjnnnHN44IEHOPnkk3nsscc47bTTUEoxNDREMplEa82uXbvo7u6urKWbicZGdQDMVdfAH18JTXs/3apbdj4rNmzgF7/4BZlknPPjEWaXRlg/mOV5Y/P8QAltCpzZt43Ons1Ek3WolX+EesMlqHhYGOLDR9GuTCZDW9vhvdFTjgvLzgegCWhqP/jxR+N4vQA0NTXR1NRUuV2Lb+qFEEIcW35kFgNzP0xsz2qSvT8nPvBrRjJ/cNjnK9tGXfZuzDdvxnz7q5jGNLYx1GkLXBfjRnhVYwuPp5by1OM5XFfR3HbgDx4PxXVdVqxYwaJFi7j//vu5++67Wbp0Keeccw5NTU1YWnH1uW20Jly+9/RuHtoyhFYwt97l6Z0j/Ob5rZwxuKaynn3M3Llzef3rX39Es0KEEFPjkAHOsiyuuuoqbrzxRoIgYMWKFbS3t3PnnXfS0dFBZ2cnF154If/8z//MX/3VX5FMJvn4xz8OwLp167jrrrsqVdf+8i//csK6mplKKQWpib/kFi9ezPz583HdvZ+wzQHOy+XYtGkTs5ubabJVWPVwVnsYqIQQQggxdZQm3/g6nMJ24nt+Q77xtQT24a/LVee8FrPkHsxvHyLczwTwg0pBMQWc4yR57LzP89sHM5x+tsv8JXUHu+Qhtbe3c+WVV/Lb3/6WJ598kueff57GxkYWLlzIqaeeyp+cnuasWXG8wLCwKUrE1qzb1sN9P3mAHBHWNi6jrGxA0VbsJujexH/+53+yaNEiFi1axLx58yrrvoUQ04ts5F0FarHPUJv9rsU+Q232W6ZQimoz3bYRmIxV6iX18pfJN7yGbPMfvaJrGWPA96BUhB3bMOueovj8CzxV92b60qcxz93OaZd0YMcmhqQj7XM2m2XTpk1s2rSJrq4ugiBg4cKFnHPOOcyaNQuAXC7HXXfdRalU4tyL/4gh4sQdTczWPLNrhHtf2E16cCOzSztwRrcD8mONRBJ11NfX05puYlF7G/Pamo9b1dxMJkNXVxePPPII+Xye9vZ25s6dS6lUYuPGjWzcuBGtNZ2dnSxduvSQBblmglp8fYPa7PcJ38j7RJMAd2Rqsc9Qm/2uxT5DbfZbApyoNjMhwAHU9fyI6NCT9M3/3wRO06FPOEL+pg28cP8WNtW9mrrhl5m3/X5m73ocxxQhWQ91DUTaT6L8R3+KSrcc8fVzuRzPPPMMTz/9NMViEaXUuKBz+eWX09bWNuG8ohfw6817WL87R3FPH2ZwBybbjyqOEAkKaMK3iwZFEEmSbqijtSms4Dxnzhxmz5590DXpAFu2bOGxxx6rFGnKZDLMmjWLVCqFUop8Ps/3v/99RkZGSCaTDA0NVc61LIt58+aRy+XYtWsX9fX1LFmyBKUUvu9jWRaZTIbm5mbq6+tnzHq+Wnx9g9rstwS4g5AfiNpRi/2uxT5DbfZbApyoNjMlwOnyIOmtX6JQ/yqGW95+3J5nx283sn6LS9bUo/FpU90syj9Jcvhl1IbnMEqj/+KTqNPPOarrl0ol1q9fz/DwML7vEwQBixYtYs6cOUd0ncAYdmdLbNzRy+Ydu+jdvZuhwUGUVyBOCccvgDEYpSlGm7DjdTTU15FprGdWuol5LU0kow4PP/wwGzZsoLGxkVgsRm9vL+VyWCYtkUjQ1tbGli1bSCQSXHLJJbS1tTE8PExXVxeWZbFgwQJc1w03VN+6lccee4yenh4gDHdBEFSKqEWjURYsWMCCBQuYP3/+EW3vc6LV4usb1Ga/T+hG3kIIIYQQtSJwGsk3vIbYnsfA+IT1lRVeZBal+GJ8J3NEWw0cyOxzFzHr1YY9Az5dW0ps2zKXHdG5zF7scPY7IPvvX8Lcdhv28o3E25qgXAJtoV5zASoWP+T1XdfljDPOeMXt1ErRWhehdckcXrskDH9lP+DBLUP8+Pl+tg/mSXkDtDNAXXkABnYw0ldiBNgKPDZ6HaM0dvtpNC89G8exiJR8csPD2CO7CfaEhe5OOeUUXvva11bW3tXV1U3YP1gpVQlnvu+jtUYphed59Pb2snv3bnbs2MGWLVt44YUXAEgmkzQ2NlJfX08kEsF1XRzHqdRo0FoTj8dJJBIkEgni8fiMGcETtUlG4KpALfYZarPftdhnqM1+ywicqDYzZQQOQHlZGnf8OzrIh3cYD8vPAuDbjXhuK4FdT2DVU47OphRbBPqVFSUrFQNeWl9k84Yivjf+sQUv38spG76PNj6kW9Dv/yRq8alh04yBXTugvgEVP7GF4gJj2D1SJhVzcKy9gWekUGLTrgG279zN7mefZs+eYbqjs3mp/iTyevJplgpIJ1waI5p03KYxatMQtWiM2qRiNq1Jh9akQ8I9vHVvQRCwc+dOurq6GBwcZHBwkKGhIUqlEp7nHfRcx3FIpVKkUina2tpob2+noaHhsEPd0NBQ5ed90aJFB10zWIuvb1Cb/ZYROCGEEEKI48TYSQbmjd8ySZf7cXMbcHMbsbx+7OIOtJ9FYTBYlGILKdadQSF51lGFOTeiWXpmjIUnRyiMxBgeHkZr6O0aZgtvZvCMN7Nszk7sO7/GyDf+L4VXX0y61IX97G9gsD+8SLoF2k9Cdb4u/DO69s0YA5vWhwVVmtLQ1Iw6BtMKtVK0Jif2NRF1OT3Yw6k/+Rrs3om66G1gduE/+zN6h8Ipl7FEHDeVoq9vDy9bDbzcMJfeulb6dIydTpIXnATDVoxAjd/PNoJP3NEkoi4NMZvZdS6z61zaGyIsaY5RHwn7rLVm9uzZk74JDoKAcrlM91CB7z7Zw3O7srimRHssYG7Mpz1Sojyyh61bt/L8888D4WhgIpHAGIMxhiAI8DwP3/cr+x47jkM2myWbzVae68EHH+TUU09lyZIlNDQ04LqujO6JV0xG4KpALfYZarPftdhnqM1+ywicqDYzaQTusBkPJ7+FSG497sjz2OU+Ah0jX985uhVBw1Fddv8+79hW4uk1OQIfgmDvcbaXZ573AifNCwhyeQZ6SgxmbdyhnTSoPTSedxZurh+z+n7YvXP8kyTrIdOKyrRCYwqiMYjGoViA7m2Y7m0QjaHf8zHUrLlhd30fc/f3ML97BHVmJ+q1b0LN7xj/Ldm1A/OzuzCPPwCNKfRVn0QtOX3v4/27IZaoTAM1XhleeBbzzG+JeGWKng+2DcUC3tAehkcK9AU2u+x6euw6BnDJ2VFyTpyBuha6I03sYe+oXnu9y0lNUQIMZd/gBYaiF1D0DcZAc8JhVp2DHxh+/uIgtlb8yWlpvMDw3O4cL+zO4weGty5p4orT05Rzw2zbto2uri6KxWJlyqbWGsuysCwLYwzlcplyuUwkEqkUdSkWizzzzDNs2rSJYPQfznEcIpEIvu/jeR5KKZqamipFXerr66mrqyOZTGLbNpZlHffAZ17eFAbtc5Yf1+fZ17T+f32cSBGTg5AfiNpRi/2uxT5DbfZbApyoNlUZ4PZlDE5hC7HB1URG1hFYCQbmfojASR3xpSbr80jWZ/OLRdyIJlmvcYrDvLzLZcd2H/Z5J6et8Xt066CMwqBtjWODS5FIMEKq0MW83Y9i7e6C4T1QyIMx4fq+TCv+rPmwZSNWcQT1Zx9BnXImwTdvhhd/D4tOhS0bwCvDrPYwCNY3QKGAefI3YNuoCy5Bve1dRzSt83D+rc3IMGx4DrP+95gN62DbJka0y5bEbJ5vmM8LDSexPdGCbQJsAhwMrq1wHQfluvSYCLs8C88oXp/I8V7/BVJ92zGj81b36Aj/0fQaVpXT1Ecs3jAvwSnWCCePbCe9eyvs3A67tod9j8XD0Ou6YNlgWahoHBqaoCEFyTqU45ANYMdInqxRjPgBRT/Adhxs28Z1Xbq6uujt7aVYLE7a57GwOLZeb1+JRIKmpiaamppIJBLEYjFisRiO46CUQilFNBolkUhUgqAxhnw+j+/7RHZswfra30Mxj/qzq9FvuGTi99wrY/77PzCPP4i+8kOos8497H/TA5kx/6+PIQlwByE/ELWjFvtdi32G2uy3BDhRbao+wO3DKu6kafu3MDrCwNwPHvFI3JH0eSTrs21ziWhM05S2qW/QlD3Dnn6fwU27KOsoJpIgCAzlkqFYNBTyAdmhgEhUsXhplNY5NvkRn8JwieFh6Os3DPb5aG04Y8fdzHrmxxCLY3yPHX/8WXoTi1m8MCCx7mHMM2tgaACG9kC5hFp+IerNl6MajnwLhqP5tzaFPGx+MRwxLJegWAynipaK9HhpNujTWbb1e0R3vBjeD/go8naUpJcHywqnnjqjU0HLZejZwUvJOfy/RW9hXd0CSlY4wqeNTzTwiKqABB5Jv0jCz2P7Hh4KD4XyfSKlHBGviG18DAqjFE7g0Zrvoy3fR6Y8jJ1IYCWTxFNpjKWxolFKToQ9aPYEkAsMkYiDFXEJnAiB1vgoAoAgCKfuej7DQ3sY2LOH4XyBg72h1wqSkWgYKHM5fH9vyrdNQARwSnncdAt2fUNlqijlUrjGslhAWTZuKU9k1lzckxaPC5XJZLIyerh/yNw3SEYiEZRSx/z/tSkWYcdW1EknH7NrTngOY17RaKgEuIOYib/oX6la7DPUZr9rsc9Qm/3+/+3de5BU5Z3w8e9zzunL9Ny7m2HkpjCAF9QgjAoYQWFe33fXZNel3t1stpIqV3MTiy3i5g/XbG25f1jFxiJYImasCuDWxn2NVXm13mQ3sYKI6zpBh5sKKkIAZWRwLj3MrW/nnOd5/zg9DaMgBAYm0/37VDV097k9v35m+jm/eZ7zHEngRKkppwQOwMl2UPfJT9FOLX3Tvo2xx7Yn6mL1dnt88G6GVLc/eoGC2jqbxCSHVI/HyZTPVeow04++zPs3foue/hAosCy47sYKrpozdtd0jWXc+Zxm+28GyWUNk6c4NN8WQw0PwfAgpIfwM1msZAMq2VC8VnCEGRyAA+9gPtyPW1HF0WQTH0YaOOlUktWQcTVp12cwrxnO+/ja4FgKx1IYgnvqZV0fz9dYGBSQ9QyD/h/+OUX9HIlcP472sIxBYQhrl6ifJ+LnsQqn8QpNzEtT6w5RGTKEc0PYnhvcv08ZfDSubWMbTbWjqK2PYx87TLayhtwty8j5mvy+3bi5LP7Uq8D3UZlhGDiJURZqynR0rIr8iU/IZTLkw1GMUvjGoOFz1yqejeM4VFVVUVlZWXw9Mix1ZGjqyGNkiOrI85EhpSPDSkfWDw0P4vz2JZyeE1jzb8Fa8VWccIRYLEYsFhuTG76bE5+gW9dCVQ3Wt39wWf5AIQlciSvHmKE84y7HmKE845YETpSackvgAEKZI9Qd3wyAtqvRTjXarkLbMbQVw1jR09bWWH4GpTNEo1H6nbnkY3PgPE+ML4Qxht5uj+FBTbTCoiJmEau0cEJBoqF9w3tvZzhyMA+AE4Jrb6xg8pQQ7+xM09XpURe3qa23CYUVtqPIZTTZjCGf10yaHGLaVWFilWeOQWuDUhQTwHPVdTajMQYqYqP357kGzzNEK069v+fNYT75yGXaVWGOHcmzcHGMKTOCXrajB3Ps25PBtqGy2qaqxmLuvChV1Rd/ov9FhvM+J4Zc+jIeng6uz6uorKKvfyC4Xs/XRJQmjMbyPPoGhukeyNKbdvF1MHGK1oa8ssjhkMXCWDZYwf+DeU2/d35JojIGx/jYoRCOrbCUQhkD6UGMNvjKwrccjGURiYSIhmzCthXcQWNoEIb6cVSQgIXQRAa6iOgc4coIluOgjA6OoQxhpQjZCsu4GN9F+3lQ4PkabQxgiokuFCaJMUFdGwy6MGnMhaYs0Wi0OPGMMaZ4HeLILSVGHpFIhIqKCiKRCJZlndrmk4/wd7yKtuzgOtBQJLidRzyJ4zjFh23b2MODWG4ek5xcPP6sWbMAmYVSCCGEEOKPnlsxk76p3yYytA/bH8TyBrHdFE62A8sfRjG690urMMaugLRLnd+G79SSqbmZTN2XMdbFzRpp506AcvDDyeJ7SimSDSGSDWfexrIV1y+IkZwcovuEy5zrosUk6ZbbKzl2JM/hAzk6O1zcfDBJiBOCigoLy1Yc2JflwL4siUk2ldU2jqOwbEgPawZO+gwPapSCSIVFtEKRnOQTjXnU1ttUVQeJpFKKwX6fQx9k+eSj4MbfM2aFmTsvSiis+OhQjoPv58jnDLPmRrj6hii93R4dR13mXBdh7rwoAyd93t2dITnZ4ePDed5/J0tyskN1jcXQoObT4y7dJzwWLauitv78kzjfN/z+gxyhkDqvnsjKsM20mKLOd0hMCk7Bg5P6syfpnR153t2V4Zr5UWbMOvfPgOsbTmY9Mq7G0wZXGzKuZijvM5T3yXoa1zfkPY1nwC8kktoULqXMR6C/D7u6BruyEkupoEexMBEMALURjEngaYrHSCcb6TvZTy6TRXvBff98yyKvHLJ2GHfk9hEXkSMro1HoQq9j0BtpGYONj208wmhC+Dj5LGHjETM5oiZH2ssHdWPZGGVhaR877WINpbEYLOzXx2gfjD7zwZMzR78+cBA4eO4yK8WDq1ZhjUEv4OkkgRNCCCGEuES86Ay86IzPLzAGRiVwClRwkpeM1zHw8etEB9qpSm2lYmAXAw0rcWOzL6gMdu5T4h0bUcYjF7uadN1tuBWzz/uG5I1TQzROHX3/NqUUM2ZFiklF0FsB9mn3g0sP+3Qcdek8lufT4y6eZ/A9qIgpaupsGqeGMCboWcumNR8fGSaXPXUCrSwIhxW5rMGy4arZhR603+fpOJonFFZkM4bkZIdYpcXhD3N8etzF9w1VNRZzrotiWYov3Rzj9d8O8t9bhxge0kyZEeKmW2NYVlDWwQGfHduHaHt1kFuXVhFPnvv0eOCkz54dwwz0B+Xt6faYf0uMUOjMn6kxho6jefbvzeLmDVNnhLh+YcUXHuPY0Txvv5XGsuDt9uCehOdK4kK2YlLlme+1d/6uvMjtRzPG4OXz5F2fvBdM4hKvqWGwtxvbd8l7mqG8ZsjVeBpQCt+30HkX3CG8dBrt+xCOQDiKjyI/lCafTpOzw/hXzsFD4frBzKNufz+5Y0fJ6BhZqhnCxmgNWmOMRmPh2zaeY5NTDhk7TMaO4FlBz2HIuChjMCoYEhv0DwblCtLGoI6DBFJj4WMbXXiuUUZjlAIUltYoNwd2bEw/U0nghBBCCCEuN6U462mY5ZCruoFc1Q2EMkep7voF9cc3kam5mWz1fNzItPO/15zOU/vp/8FYUdI1txAdeIv645vRVhQ/lCw8EvihOH4ojhduwFzAyaZSis92MsQqbeZep7hudgovlAQr/IUTQSQSCY593MXJlE8mrcnnDLmsIVZpceXsMJFI0FM1c26EA/uy5DKG+bdEmNQYJCxTZ4R4uz1DNmv48pLKYjJZW28z+9oIB9/LMWNmmBubK1DWqTJU19jctqKaHduH2LF9KBgSag1zTW0bJ7Jz6PNmFnsPLUthDHzyUZBA3vzlSoaHfN5/O8vrvx3k6nlRfN+Qzxu0H8wKatuKE5+49HzqUZ8Mri/8/Qc5ers9ltwRQxsf2w56PCHI7U90uOzbkyHZ4LBgSYw9O9LnncRdKM819HR55LKahitCnxuqeqGUUoQiEUIRqCy8l0wm6TktzxzpBDbacORQngMfZNAGrr1xKjMX/aHXWU4Gzn8yE6M15HNoz8XzNK7nY4VCONEKnHDwO6oLvZUj/3vGBP/7Pn4uh68cfMs+rVdSk09n8bpOBDOTjjG5Bq4ElGPMUJ5xl2PMUJ5xyzVwotSU4zVwF+pzMWuXytRWYidfL9w43MILT8atmEU+Nod8xcyzJnTVXS9SMfAWfVPuw43NAeMRHXwHJ/sxjtuD7fZief2o0+Yw9MKTyUevwg8lsHQayx8G46OdOvxQPX4ogRe5YvQ1fNrF8geDGTcLPYlO9hjV3b8klDuG79QxmPwK+crrztrzNxZ17XnBLJufvZ7NaENfyqc+cfb7quWymn27M9SpD7kp/h9E7WG0sdjV/Sf8/uSNaD/oZdQaJk12uH5BBZFokOT0dHnsahsmnzvzafXI9YNXNgXJyMmUx54daYYGzzJkD5g8xWFhIRH1fUP7fw/TfcLDsoHCkEfLAscJrj+0VNBrORJeYaQhygqSSMtWWBaFh0JZFLZRZNKaVLc36j6DdXGbSY0OSgX70joYYRjMUBkcR1nBPoNrGUdmnAyOoSwV9FUVyjOyjmVBdU01w0NDFDqqoLD/wx/m6O/zi8ft6vSIT7K5+voKbCtIpEYyl5F9j8QUTGoy8hkojD5VX8V1CuUdScaDD+pUzMU4LD7/c6LdwsIL6/+Sa+CEEEIIcUns3buXLVu2oLVmxYoV3HPPPaOWu67LU089xeHDh6murmbNmjU0NJzlIioxNqwQw8k/IV2/lFD2WOHxERUDbxLrfwODhbarMHYF2orhhxN44SvA+FQMvMVw3bIgeQNQDtmaBVCz4NT+tYvtncR2e3FynYSyR4kO7cXSuWD4mB3DYGH5g8VEz6AKvXdxbDeF7fai0BgVwo1MxdgxwsPvo+1KhhL/k+jgXupO/Ix8xWxysbkYKxxc16dsKA5LqyDa34PSueD6wJEMBAtjhTBWGLBQxgXjBcstB6NCKJ0jlD2GkzuG7Q3iDkzHjc7EjU4luPDK0FhhMBkHlI1RNmAVJ4mxvAEq3D7unPUR0aG3ccON9E36BpWpV7i54T+47uosw/EVo5NPo0HnURiSk2yW/0k16bQmFLYIh1Xxnny+b7AdheOc2rYu7rD0rmrcXIxUqh/fA+17VPExdRyiUp1A1V1F3r8B356MbQe9fYc/zOHmTDHx0T6FoamF69gKCRYKVPBPMZHxfYObH0nEdJDcmGB5KKy4ak6EyVc4RKIWJz5x6exwOfhecOuF0xMbSwXJn9HBRDTFpOoP6hLKnPHdSFSxYHGMKdOD7rlPjqTpOvh7Onbn6RycgafPs+d5DBSTXaW5JrmLL01+A0+H2Nm5nKP91xaT1c8mryMJ6UiSu/zumjEvmyRwQgghhABAa82mTZv4x3/8RxKJBP/wD/9Ac3Mz06ZNK66zbds2Kisr2bBhA2+88QbPPfcc3//+98ex1OXD2JXkK68hX3lN8IbOE84eJZQ5guUNoXQGyx8mMvQeFXonAG5kOsOJ//HFO7ZC+OFJ+OFJp/ZtNErnCklWYSid8bC8AZx8F07uE0LZT7C9FF64gVzVDfhOLU7+U0K5DpzMR6Trvkw6vjwYvll3OxX9O6hMvUI4c+isRbmYU13frsGNTicfm0so+zGxvm2jehbPh1EhhuuWMZxoAeVwcsq9VHf9Xyr7XiHWtx2UFUyrb3SQSH52eyxGdTkV51Yc6RqyTz1HYdkOU30X0CiVxTJ5DBZ+KIndtw3V9wpeKIG2q0FZJGoK8zUWE0mDMppT2ZMq7J/CsRVBolpIkpV12nsUJu04rVtLA2nDtLo8qsYF42OsCMauwKjwabOiqtPKcSoxNWYkGVejn4+sY4IEMxqtIJPJFt4vxKBMMFTVUtALjtvNJPN7rKZcoWgOw/ZMMvYMTOFzNCb4PIxRaGMwWhVmrwSlgtsToAplMQptQJugd85oTovBKhROA7qwXAEe00O/o8ruoddrImSlWTrj/3GD9zbHcs1oYxWTV8NpvZ6Fj0UpC5j/B/0Mng9J4IQQQggBwKFDh2hsbGTy5GAK7CVLltDe3j4qgdu5cyd/+Zd/CcCiRYvYvHnzRd/gVlwgK0w+Npd87DPX+xiD5Q/g5D4NeqDUBcyAp6xgRsxR7znoUJx8KH4q0Tvv/dlk6m4jU7sYZdygl03nwPiMzChYV58k1Z8OEgblnDoLNhpl8igdJDqoEEYF96NDuyjjgbLRzuj0T/lZbLfrVFcIoIwPxg+2KZywKwy+U4N26tF25ehbNyibwYb/jVsxEzvfE9xK2/iF8oWCnkEUqrhPfSoZYmS2RIqJQXD8wnM0kUiEfM4tJIZh8hWzcGNNGCuK5Q0QGdpPOH0QZXKFz8EtpoTF3kl1WtJYmFjjVEJXGBNZiPNUOYLtg23twudTzHwwqtDjqRwsnUN5/SiTL2YoI9N7nOp6Oy1mQ2GdkWObQjlO+44YNkSgMCR4JNs57XM3Bu1Uk6v+UqHHNkJk+AMq0u9TnT/37I/Fj+hsrMLjPPhOnJOTvokfuxYfAwPt1Pa+TL3zi/MogkW3JHBCCCGEuFRSqRSJRKL4OpFIcPDgwbOuY9s2sViMwcFBampGnzxv3bqVrVu3ArB27VqSySQXwnGcC952ohqbmCcBTWNRnMvGcRziMW+M9zrt3Kucj0n/a2z28xm24xDxTsUcHbU0Ccy6JMcdcSn/7PJF+ZPjOHie94XrKCBSeAQWAaB1vjBWVBf+AFA4mvlsIjmSZOrT3jv9msPCuiP7Uqd6RovjIAEVSVJjnZYyTbobrrwTnTvX9WzB9snKZDHmsfoukwROCCGEEGOupaWFlpaW4usLnZxCJjEpH+UYdznGDJc7bnXa/xcws+bwybMsOM/ZJTNBnGM5icnYzA8qhBBCiAkvHo/T29tbfN3b20s8Hj/rOr7vk06nqa6uvqzlFEKIciYJnBBCCCEAaGpqorOzk66uLjzPo62tjebm5lHrLFy4kO3btwOwY8cO5s2bJ9e/CSHEZSRDKIUQQggBBNe03XfffTz22GNorbnzzjuZPn06P//5z2lqaqK5uZnly5fz1FNPsXr1aqqqqlizZs14F1sIIcqKJHBCCCGEKFqwYAELFiwY9d7Xvva14vNwOMxDDz10uYslhBCiQIZQCiGEEEIIIcQEIQmcEEIIIYQQQkwQ5zWEcu/evWzZsgWtNStWrOCee+4Ztdx1XZ566ikOHz5MdXU1a9asoaGhAYAXX3yRbdu2YVkWf/u3f8v8+fPHOgYhhBBCCCGEKAvn7IHTWrNp0yYeeeQR1q9fzxtvvEFHR8eodbZt20ZlZSUbNmzg7rvv5rnnngOgo6ODtrY2fvzjH/PDH/6QTZs2obU+02GEEEIIIYQQQpzDORO4Q4cO0djYyOTJk3EchyVLltDe3j5qnZ07d3LHHXcAsGjRIvbt24cxhvb2dpYsWUIoFKKhoYHGxkYOHTp0SQIRQgghhBBCiFJ3zgQulUqRSCSKrxOJBKlU6qzr2LZNLBZjcHDwc9vG4/HPbSuEEEIIIYQQ4vz8UdxGYOvWrWzduhWAtWvXMmXKlIva38VuPxGVY8xQnnGXY8xQnnGXY8yidF3Mz3M5/i6UY8xQnnGXY8xQnnGPVczn7IGLx+P09vYWX/f29hKPx8+6ju/7pNNpqqurP7dtKpX63LYALS0trF27lrVr115wICMefvjhi97HRFOOMUN5xl2OMUN5xl2OMQtxJuX4u1COMUN5xl2OMUN5xj2WMZ8zgWtqaqKzs5Ouri48z6OtrY3m5uZR6yxcuJDt27cDsGPHDubNm4dSiubmZtra2nBdl66uLjo7O5k9e/aYFV4IIYQQQgghysk5h1Dats19993HY489htaaO++8k+nTp/Pzn/+cpqYmmpubWb58OU899RSrV6+mqqqKNWvWADB9+nQWL17MQw89hGVZ3H///ViW3HpOCCGEEEIIIS7EeV0Dt2DBAhYsWDDqva997WvF5+FwmIceeuiM265cuZKVK1deRBH/MC0tLZftWH8syjFmKM+4yzFmKM+4yzFmIc6kHH8XyjFmKM+4yzFmKM+4xzJmZYwxY7Y3IYQQQgghhBCXjIxnFEIIIYQQQogJ4o/iNgJjYe/evWzZsgWtNStWrOCee+4Z7yJdEj09PWzcuJGTJ0+ilKKlpYU//dM/ZWhoiPXr19Pd3c2kSZP4/ve/T1VV1XgXd0xprXn44YeJx+M8/PDDdHV18cQTTzA4OMisWbNYvXo1jlMyP9IADA8P09rayrFjx1BK8cADDzBlypSSrutf/epXbNu2DaUU06dPZ9WqVZw8ebLk6vrpp59m9+7d1NbWsm7dOoCz/h4bY9iyZQt79uwhEomwatUqZs2aNc4RCHFpSbsu7XopfNd/lrTr0q6PRbteEj1wWms2bdrEI488wvr163njjTfo6OgY72JdErZt881vfpP169fz2GOP8fLLL9PR0cFLL73EDTfcwJNPPskNN9zASy+9NN5FHXP/+Z//ydSpU4uvf/azn3H33XezYcMGKisr2bZt2ziW7tLYsmUL8+fP54knnuDxxx9n6tSpJV3XqVSKX//616xdu5Z169ahtaatra0k6/qOO+7gkUceGfXe2ep2z549nDhxgieffJLvfOc7/PSnPx2HEgtx+Ui7Lu16qXzXf5a069Kuw8W36yWRwB06dIjGxkYmT56M4zgsWbKE9vb28S7WJVFfX1/M0CsqKpg6dSqpVIr29naWLVsGwLJly0ou/t7eXnbv3s2KFSsAMMawf/9+Fi1aBAS/NKUWczqd5v3332f58uUAOI5DZWVlyde11pp8Po/v++Tzeerq6kqyrq+77rrP/YX1bHW7c+dOli5dilKKuXPnMjw8TF9f32UvsxCXi7Tr0q6Xynf96aRdl3Z9rNr1id1XWZBKpUgkEsXXiUSCgwcPjmOJLo+uri6OHDnC7Nmz6e/vp76+HoC6ujr6+/vHuXRj69lnn+Ub3/gGmUwGgMHBQWKxGLZtA8HN5FOp1HgWccx1dXVRU1PD008/zUcffcSsWbO49957S7qu4/E4X/3qV3nggQcIh8N86UtfYtasWSVf1yPOVrepVIpkMllcL5FIkEqliusKUWqkXZd2vRS/66Vdl3Z9rNr1kuiBK0fZbJZ169Zx7733EovFRi1TSqGUGqeSjb1du3ZRW1tbdtf8+L7PkSNHuOuuu/jRj35EJBL53LCKUqvroaEh2tvb2bhxI8888wzZbJa9e/eOd7HGRanVrRDii0m7XvqkXZd2fazqtiR64OLxOL29vcXXvb29xOPxcSzRpeV5HuvWreP222/n1ltvBaC2tpa+vj7q6+vp6+ujpqZmnEs5dg4cOMDOnTvZs2cP+XyeTCbDs88+Szqdxvd9bNsmlUqVXJ0nEgkSiQRz5swBYNGiRbz00kslXdfvvvsuDQ0NxZhuvfVWDhw4UPJ1PeJsdRuPx+np6SmuV+rfcUJIuy7teil+10u7Lu36WLXrJdED19TURGdnJ11dXXieR1tbG83NzeNdrEvCGENraytTp07lK1/5SvH95uZmXnvtNQBee+01br755vEq4pj7m7/5G1pbW9m4cSNr1qzh+uuv5+/+7u+YN28eO3bsAGD79u0lV+d1dXUkEgmOHz8OBF+C06ZNK+m6TiaTHDx4kFwuhzGmGHOp1/WIs9Vtc3Mz//Vf/4Uxhg8//JBYLCbDJ0VJk3Zd2vVS/K6Xdl3a9bFq10vmRt67d+/mX//1X9Fac+edd7Jy5crxLtIl8cEHH/BP//RPzJgxo9gN+/Wvf505c+awfv16enp6SnIK2hH79+/nl7/8JQ8//DCffvopTzzxBENDQ8ycOZPVq1cTCoXGu4hj6ujRo7S2tuJ5Hg0NDaxatQpjTEnX9QsvvEBbWxu2bXPVVVfxve99j1QqVXJ1/cQTT/Dee+8xODhIbW0tf/VXf8XNN998xro1xrBp0ybefvttwuEwq1atoqmpabxDEOKSknZd2vVS+K7/LGnXpV0fi3a9ZBI4IYQQQgghhCh1JTGEUgghhBBCCCHKgSRwQgghhBBCCDFBSAInhBBCCCGEEBOEJHBCCCGEEEIIMUFIAieEEEIIIYQQE4QkcEJcgIceeoj9+/df0LYbN27k+eefH+MSCSGEEOJCSbsuJhJJ4MSE8eCDD/LOO+9c8uO88MILPPnkk1+4zo9//GPmzZt3ycsihBBClCpp14W4MJLACSGEEEIIIcQE4Yx3AYS4ENu3b+eVV15hzpw5vPrqq8RiMb71rW9x0003AfDoo48yd+5c3n33XY4fP868efNYtWoVVVVV7N+/nw0bNtDa2lrc34MPPsh3v/tdtNa8+OKLALS3t9PY2Mjjjz/+ueOPrH/jjTfywgsv0NHRQTgc5q233iKZTPLggw/S1NQEwJEjR2htbaWzs5ObbroJpdSofe3atYvnn3+e7u5upk2bxre//W2uvPJK2traeO6553j88ceJxWLs2bOHp59+mnXr1lFTU3OpPlohhBDispN2Xdp1cf6kB05MWIcOHWLKlCls2rSJP//zP6e1tRVjTHH5a6+9xgMPPMAzzzyDZVls3rz5nPucP38+f/EXf8HixYv5t3/7tzN+yZ/Jrl27WLJkCc8++yzNzc3FY3mex+OPP87tt9/O5s2bWbx4MW+++WZxuyNHjvCTn/yE73znO2zevJmWlhZ+9KMf4bouS5Ys4eqrr2bLli0MDg7S2trK9773PfmSF0IIUZKkXRfi/EgCJyasZDJJS0sLlmWxbNky+vr66O/vLy5funQpM2bMIBqN8td//df87ne/Q2t9ScpyzTXXsGDBAizLYunSpRw9ehSADz/8EN/3ufvuu3Ech0WLFhX/ggewdetWWlpamDNnDpZlcccdd+A4DgcPHgTg/vvvZ9++fTz66KMsXLiQhQsXXpLyCyGEEONN2nUhzo8MoRQTVl1dXfF5JBIBIJvNFt9LJBLF58lkEt/3GRgYuCRlqa2tLT4Ph8O4rovv+/T19RGPx0cNr0gmk8XnPT09vPbaa/zmN78pvud5HqlUCoDKykoWL17Mr371K/7+7//+kpRdCCGE+GMg7boQ50cSOFGyent7i897enqwbZuamhp6enrI5XLFZVrrUQ3AZ8eyX4z6+npSqRTGmOJ+e3t7aWxsBILGaOXKlaxcufKM2x89epRXX32V2267jS1btvDDH/5wzMomhBBCTCTSrgsRkCGUomS9/vrrdHR0kMvleOGFF1i0aBGWZTFlyhRc12X37t14nscvfvELXNctbldbW0t3d/eYDMuYO3culmXx61//Gs/zePPNNzl06FBx+YoVK/jtb3/LwYMHMcaQzWbZvXs3mUyGfD7Phg0b+PrXv86qVatIpVK8/PLLF10mIYQQYiKSdl2IgPTAiZK1dOlSNm7cyPHjx7n22mtZtWoVQHFmq9bWVrTW/Nmf/dmoYRmLFy/m9ddf5/7776ehoYF/+Zd/ueAyOI7DD37wA5555hmef/55brrpJm655Zbi8qamJr773e+yefNmOjs7CYfDXHPNNVx77bX8+7//O4lEgrvuuguA1atX88///M/ceOONXHHFFRdcJiGEEGIiknZdiIAyp0/vI0SJePTRR7n99ttZsWLFeBdFCCGEEBdJ2nUhTpEhlEIIIYQQQggxQUgCJ4QQQgghhBAThAyhFEIIIYQQQogJQnrghBBCCCGEEGKCkAROCCGEEEIIISYISeCEEEIIIYQQYoKQBE4IIYQQQgghJghJ4IQQQgghhBBigpAETgghhBBCCCEmiP8PRaAx9KbumF4AAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 1080x360 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(15,5))\n",
    "\n",
    "# create grid for different subplots\n",
    "spec = gridspec.GridSpec(ncols=2, nrows=1,\n",
    "                         width_ratios=[1, 1], wspace=0.5,\n",
    "                         hspace=0.5, height_ratios=[1])\n",
    "\n",
    "ax1 = fig.add_subplot(spec[0])    \n",
    "ax2 = fig.add_subplot(spec[1])\n",
    "\n",
    "for rep in range(repetitions):\n",
    "    ax1 = plot_one_variable(ax1, lengthscale_model1[rep], 'Length scale')\n",
    "    ax2 = plot_one_variable(ax2, noise_model1[rep], 'Noise')\n",
    "ax1.set_ylim(0,.4)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABIEAAAFRCAYAAADjML1JAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAEAAElEQVR4nOz9eZxcdZX4/7/e9966tXdXd/WWlZDOQlgChMgSZJMIDKMjzigoo4KAqIwiOuog4g/9OjiMigt+UEeJOKOjgyuuIER2ApgQwhYg+95J793Vtd97378/qrvSle5Op5NeUt3n+Xj0I91V73vv+ybpqrrnnvc5SmutEUIIIYQQQgghhBCTmjHRExBCCCGEEEIIIYQQY0+CQEIIIYQQQgghhBBTgASBhBBCCCGEEEIIIaYACQIJIYQQQgghhBBCTAESBBJCCCGEEEIIIYSYAiQIJIQQQgghhBBCCDEFSBBICCGEEGIEuru7eec730llZSVKKbZt2zbRUxJCCCEGGO/3q/PPP5/rrrtuTI8hjpwEgcSYuvrqq1FK8dnPfrbk8V27dqGU4rHHHgNAKYVSit///vcD9vHOd74TpVTJC8rVV1/N8uXLhzyuvAAJIcTE63sPUEphmiYzZ87kAx/4ALt37y4Zd/7556OU4lOf+tSAfXz7299GKcW8efNKHr/33ns57bTTqKioIBqNsmjRIj70oQ8Vn3/ssceKxz7w61e/+tURndf3vvc9nnnmGZ566imampqYNWvWEe1PCCHExJL3q6Fdd911nH/++Uc0D3F0kSCQGHOBQIC77rqL7du3H3Tc7Nmzueeee0oe27NnD3/605/kA7YQQpSpc845h6amJnbs2MHPfvYzXnjhBd797ncPGDd79mx+8pOfkMvlSh7/wQ9+wDHHHFPy2I9//GM++tGP8sEPfpA1a9bw/PPPc8cdd+C67oD9rl27lqamppKvt7/97Ud0Ths3buSEE07gpJNOoqGhAdM0j2h/QgghJp68X4mpQoJAYswtW7aMk08+mVtuueWg46655hoefPDBkoj7j370I8455xzmzp071tMUQggxBmzbpqGhgRkzZnDuuedy/fXX88wzz9Dd3V0y7sILLyQSifDb3/62+NhTTz3Fzp07B3wIv//++3nb297Gxz72MRYsWMCCBQt4xzvewY9+9KMBx6+traWhoaHky+/3DznffD7PzTffzIwZM7Btm+OPP56f/exnxefnzJnDihUreOSRR1BKDXl3tO/O7p///GfOOussgsEgp512Gq+++iqvvvoqb37zmwmFQpx++umsX7++ZNvnn3+eiy66iEgkQm1tLf/4j/9YciNl69at/OM//iPTp08nFApx0kkn8ZOf/KRkH30ZsV/+8pdpaGigurqaD3zgA/T09Ax57kIIMZVN1ferfD7Ppz71KWbOnInf72fatGm85z3vAeCLX/wiK1as4PHHHy9mJ/34xz8GYPv27VxyySUEg0FmzZrFd77znYP+/YqjhwSBxJhTSvH1r3+dn//856xZs2bIcY2NjZx77rnce++9AHiex4oVK0rSJYUQQpSvPXv28Ktf/QrTNAfcjTQMg2uvvZYf/vCHxcd+8IMfcOWVVxIOh0vGTps2jTVr1rBhw4ZRn+Mtt9zCD3/4Q771rW/xyiuv8L73vY/3ve99/PWvfwVg9erVXH755cU7xr/5zW8Our/Pf/7z3H777Tz//PPYts173/tePvrRj/KlL32p+NgHP/jB4vj169dz3nnncdZZZ7FmzRoeeeQRTNPkrW99K5lMBoCenh7e8pa38MADD/Dyyy9z/fXX88EPfpBHH3205Ni/+tWvaG9v57HHHuP//u//+OMf/8h//ud/jvLfmBBCTD5T6f3qO9/5Dr/4xS/46U9/ysaNG/n973/PmWeeCcCnP/1prrzySs4666xidtIVV1yB1pp3vvOdtLW18dhjj/GHP/yB3//+96xdu3bUz1OMAS3EGLrqqqv0hRdeqLXW+rLLLtPnnXee1lrrnTt3akA/+uijWmutAf2Tn/xE33fffXrOnDna8zz9wAMP6JqaGp3NZvV5552nr7322kH3O5gDxwshhBh/V111lTZNU4fDYR0MBjWgAf2v//qvJeP6XrN3796tfT6f3rx5s25vb9fBYFA///zz+rbbbtONjY3F8U1NTfrss8/WgD7mmGP05Zdfrv/rv/5L9/T0FMc8+uijGtChUEiHw+GSr927dw8632QyqW3b1nfffXfJ45dddpm+4IILSs7rYO9B/Y//29/+tvjYL37xCw3oX/3qV8XHfvOb32hAJxKJ4r6vuOKKkn1lMhkdDAZL9nWgf/iHf9DXXXdd8efzzjtPL168uGTMRz7yEX3mmWcedN5CCDEVTeX3qxtvvFFfcMEF2vO8QZ+/9tpri9dwfR5++GEN6DfeeKP4WHNzsw4EAnINVgYkE0iMm//8z//k6aefHrT4c5/LLruMZDLJww8/zA9+8AM+8IEPYNv2OM5SCCHEaDrjjDNYt24df/vb3/jCF77AWWedxb//+78POnb69Olceuml3HPPPfzkJz9h0aJFLFmyZMC4hoYGnnrqKdavX8/nPvc5wuEwn/3sZznxxBNpbm4uGfuXv/yFdevWlXzV19cPevxNmzaRy+U499xzSx4/77zzePXVVw/r/E8++eSSeQMsXrx4wGN98169ejW//e1viUQixa94PE4mk2Hjxo0ApFIpbr75Zk444QSqq6uJRCL8+c9/HlB7r/+xofD3u2/fvsM6DyGEmOym6vvVBz/4QV5++WXmzZvHRz7yEX79618PqHd0oPXr11NTU8OCBQuKj9XW1rJw4cIRHVtMDGuiJyCmjgULFvDhD3+Yf/u3f+OBBx4YdIxt21x99dXcfvvtPPPMM7z00kvjPEshhBCjKRgMFjulnHjiiWzevJmPf/zjJWn0/V1//fVce+21VFdXc+ONNx5034sWLWLRokV8+MMf5gtf+AILFizge9/7HrfddltxzJw5c5g5c+bondAI+Xy+4vdKqSEf8zyv+Of73/9+br755gH7isfjAHzmM5/hd7/7Hd/4xjdYuHAh4XCYf/3Xf6Wrq6tk/IE3UZRSxeMIIYQoNVXfr0455RS2bt3Kww8/zKOPPsonPvEJvvCFL/Dss89SUVEx7vMRY08ygcS4uu2229izZw8/+MEPhhxz/fXX8+STT3LmmWdy3HHHjePshBBCjLUvfvGL3HvvvUPWiLvkkkuwbZvt27dz5ZVXHvJ+58yZQygUGnBndSTmzZuH3+/niSeeKHn88ccf58QTTzzs/Y7E0qVLeemll2hsbGTevHklX1VVVQA88cQT/PM//zOXX345J598MnPnzh2TehNCCDGVTaX3q0gkwjvf+U7uuusu1qxZw2uvvcbjjz8OFG4oHNjN7Pjjj6e1tbWYoQrQ2trKG2+8cRhnI8abZAKJcVVbW8vNN9/Ml7/85SHHzJs3j9bWVgKBwEH31dPTw7p160oeCwQCxcBRe3v7gOcrKiqk05gQQkyg+fPn8/a3v53Pf/7z/OUvfxnwvGEYvPLKK3ieRzQaHXQfH/3oR2loaOAtb3kLs2fPprW1lW9/+9t0d3dz2WWXlYxtaWnBsko/7lRUVBAKhQbsNxQKceONN/KFL3yB2tpaTj75ZH71q1/xu9/9jocffvjwT3oEbrnlFk4//XTe97738YlPfILa2lq2bdvG/fffzyc+8Qnmzp3LwoUL+d3vfsc//dM/EYlE+MY3vsGePXuGXDYghBBi5KbK+9XXvvY1pk+fzimnnEIoFOLnP/85pmkWl3ode+yx/PKXv+TVV1+lvr6eaDTKhRdeyMknn8z73vc+vvOd72DbNv/2b/9Wkukqjl4SBBLj7pOf/CTf+9732Llz55Bjqqurh93Pc889x6mnnlry2MKFC3n99dcB+O1vf1vSuhHg4osv5sEHHzyMWQshhBgtn/nMZzj77LN57LHHBm1ZO9SH6T5vfetb+fGPf8wPf/hDWlpaiMViLF68mD//+c+89a1vLRk7WI2Gr33ta3z6058edN+33347hmFw00030dLSwrx58/jpT3/KhRdeeOgneAQWLVrEqlWruPXWW7n44ovJZDLMmDGDt7zlLcRiMQC++c1vct1113HBBRdQUVHB9ddfz7ve9S42b948LnMUQoipYiq8X1VUVPCNb3yDjRs34nkeixYt4te//nWxvs+1117Lo48+yrJly+ju7ubee+/l6quv5v777+f666/n3HPPpaamhs985jNks9kRHVtMDKW11hM9CSGEEEIIIYQQQggxtqQmkBBCCCGEEEIIIcQUIEEgIYQQQgghhBBCiClAgkBCCCGEEEIIIYQQU4AEgYQQQgghhBBCCCGmAAkCCSGEEEIIIYQQQkwBEgQSQgghhBBCCCGEmAKsiTz4nj17RjS+pqaG1tbWMZrN+JJzOXpNpvOZiucyffr0cZiNmExG8l40mX6nYHKdj5zL0WkynQvIe5EYG3JNJOdyNJpM5zMVz+Vg70MTGgQSQgghhBBCiHKwbt067r33XjzP48ILL+Syyy4ref7HP/4xr776KgC5XI6uri5+/OMfj/9EhRDiICQIJIQQQgghhBAH4XkeK1as4NZbbyUej/O5z32OpUuXMnPmzOKYq6++uvj9Aw88wNatWydgpkIIcXDDBoFaW1u5++676ezsRCnF8uXLufTSS0vGvPrqq3z1q1+lrq4OgDPOOIN3vetdYzNjIYQQQgghhBhHmzZtoqGhgfr6egCWLVvG6tWrS4JA/T39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\n",
      "text/plain": [
       "<Figure size 1440x360 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(20,5))\n",
    "\n",
    "# create grid for different subplots\n",
    "spec = gridspec.GridSpec(ncols=3, nrows=1,\n",
    "                         width_ratios=[1, 1, 1], wspace=0.5,\n",
    "                         hspace=0.5, height_ratios=[1])\n",
    "\n",
    "ax1 = fig.add_subplot(spec[0])    \n",
    "ax2 = fig.add_subplot(spec[1])\n",
    "ax3 = fig.add_subplot(spec[2])\n",
    "\n",
    "for rep in range(repetitions):\n",
    "    ax1 = plot_one_variable(ax1, nmll_losses_valid_model1[rep], 'NMLL')\n",
    "    ax2 = plot_one_variable(ax2, rmse_losses_valid_model1[rep], 'RMSE of mean')\n",
    "    ax3 = plot_one_variable(ax3, rmse_std_losses_valid_model1[rep], 'RMSE of std')\n",
    "    #ax1 = plot_one_variable(ax1, nmll_losses_valid_model1_mode[rep], 'NMLL')\n",
    "    #ax2 = plot_one_variable(ax2, rmse_losses_valid_model1_mode[rep], 'RMSE of mean')\n",
    "    #ax3 = plot_one_variable(ax3, rmse_std_losses_valid_model1_mode[rep], 'RMSE of std')\n",
    "#ax1.set_ylim(-0.1,1.6)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Evaluation of the models\n",
      "Average validation values after 100 iterations\n",
      "----------------------\n",
      "Baseline model with ALM\n",
      "-- NMLL          1.207 (±0.519)\n",
      "-- RMSE of mean  0.686 (±0.307)\n",
      "-- RMSE of std   0.248 (±0.126)\n",
      "----------------------\n",
      "Fully Bayesian GP model new AL strategy\n",
      "-- NMLL          0.905 (±0.779)\n",
      "-- RMSE of mean  0.214 (±0.132)\n",
      "-- RMSE of std   0.091 (±0.032)\n"
     ]
    }
   ],
   "source": [
    "iteration = args.active_learning_steps-1\n",
    "print(\"Evaluation of the models\")\n",
    "print(f\"Average validation values after {args.active_learning_steps} iterations\")\n",
    "print(\"----------------------\")\n",
    "print(\"Baseline model with ALM\")\n",
    "print(u\"-- NMLL         % .3f (\\u00B1%.3f)\" % (np.mean(nmll_losses_valid_baseline, axis=0)[iteration], \n",
    "                                               np.std(nmll_losses_valid_baseline, axis=0)[iteration]))\n",
    "print(u\"-- RMSE of mean % .3f (\\u00B1%.3f)\" % (np.mean(rmse_losses_valid_baseline, axis=0)[iteration],\n",
    "                                               np.std(rmse_losses_valid_baseline, axis=0)[iteration]))\n",
    "print(u\"-- RMSE of std  % .3f (\\u00B1%.3f)\" % (np.mean(rmse_std_losses_valid_baseline, axis=0)[iteration],\n",
    "                                               np.std(rmse_std_losses_valid_baseline, axis=0)[iteration]))\n",
    "print(\"----------------------\")\n",
    "print(\"Fully Bayesian GP model new AL strategy\")\n",
    "print(u\"-- NMLL         % .3f (\\u00B1%.3f)\" % (np.mean(nmll_losses_valid_model1, axis=0)[iteration], \n",
    "                                               np.std(nmll_losses_valid_model1, axis=0)[iteration]))\n",
    "print(u\"-- RMSE of mean % .3f (\\u00B1%.3f)\" % (np.mean(rmse_losses_valid_model1, axis=0)[iteration],\n",
    "                                               np.std(rmse_losses_valid_model1, axis=0)[iteration]))\n",
    "print(u\"-- RMSE of std  % .3f (\\u00B1%.3f)\" % (np.mean(rmse_std_losses_valid_model1, axis=0)[iteration],\n",
    "                                               np.std(rmse_std_losses_valid_model1, axis=0)[iteration]))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "**(iii) MCMC: FBGP with ALM**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.49      0.32      0.45      0.03      0.92    516.92      1.00\n",
      "               noise      1.11      0.59      1.00      0.26      1.87    670.85      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  9.432512044906616\n",
      "Iteration 1/100: train NMLL: 1.652, valid NMLL 1.524, valid RMSE of mean 0.717, valid RMSE of std 0.576\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.49      0.31      0.45      0.02      0.91    503.28      1.01\n",
      "               noise      1.07      0.54      0.96      0.31      1.84    578.18      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  8.834140062332153\n",
      "Iteration 2/100: train NMLL: 1.619, valid NMLL 1.527, valid RMSE of mean 0.716, valid RMSE of std 0.521\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.48      0.32      0.43      0.02      0.90    446.67      1.00\n",
      "               noise      1.04      0.55      0.95      0.11      1.72    327.34      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  9.63274598121643\n",
      "Iteration 3/100: train NMLL: 1.610, valid NMLL 1.547, valid RMSE of mean 0.715, valid RMSE of std 0.494\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.40      0.33      0.35      0.01      0.85    191.35      1.03\n",
      "               noise      0.83      0.50      0.77      0.06      1.46    203.60      1.03\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  10.073615074157715\n",
      "Iteration 4/100: train NMLL: 1.553, valid NMLL 1.546, valid RMSE of mean 0.720, valid RMSE of std 0.426\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.33      0.32      0.25      0.01      0.80    115.85      1.05\n",
      "               noise      0.77      0.57      0.71      0.02      1.47    158.23      1.03\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  11.093455791473389\n",
      "Iteration 5/100: train NMLL: 1.504, valid NMLL 1.449, valid RMSE of mean 0.752, valid RMSE of std 0.304\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.41      0.31      0.39      0.02      0.81    106.51      1.03\n",
      "               noise      0.85      0.49      0.79      0.07      1.44    120.97      1.03\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  10.127626895904541\n",
      "Iteration 6/100: train NMLL: 1.563, valid NMLL 1.608, valid RMSE of mean 0.716, valid RMSE of std 0.401\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.34      0.33      0.27      0.01      0.79    111.57      1.02\n",
      "               noise      0.70      0.52      0.68      0.01      1.35    102.57      1.02\n",
      "\n",
      "Number of divergences: 4\n",
      "Validation using full posterior took  11.515855073928833\n",
      "Iteration 7/100: train NMLL: 1.408, valid NMLL 0.738, valid RMSE of mean 0.597, valid RMSE of std 0.250\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.09      0.16      0.04      0.01      0.16     69.00      1.09\n",
      "               noise      0.26      0.40      0.13      0.01      0.65     92.43      1.07\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.238890886306763\n",
      "Iteration 8/100: train NMLL: 1.274, valid NMLL 0.527, valid RMSE of mean 0.478, valid RMSE of std 0.315\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.05      0.07      0.04      0.02      0.06    198.59      1.02\n",
      "               noise      0.11      0.15      0.07      0.00      0.22    195.44      1.03\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  15.38237714767456\n",
      "Iteration 9/100: train NMLL: 1.165, valid NMLL 0.376, valid RMSE of mean 0.456, valid RMSE of std 0.322\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.04      0.03      0.04      0.02      0.06    147.29      1.03\n",
      "               noise      0.07      0.10      0.05      0.00      0.15    169.86      1.02\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.34074115753174\n",
      "Iteration 10/100: train NMLL: 1.067, valid NMLL 0.272, valid RMSE of mean 0.445, valid RMSE of std 0.329\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.04      0.01      0.04      0.02      0.06    598.96      1.01\n",
      "               noise      0.05      0.06      0.03      0.00      0.10    675.73      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.817804098129272\n",
      "Iteration 11/100: train NMLL: 0.980, valid NMLL 0.209, valid RMSE of mean 0.442, valid RMSE of std 0.335\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.04      0.01      0.04      0.02      0.05    787.04      1.00\n",
      "               noise      0.03      0.03      0.02      0.00      0.06    786.19      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.091899871826172\n",
      "Iteration 12/100: train NMLL: 0.883, valid NMLL 0.188, valid RMSE of mean 0.447, valid RMSE of std 0.342\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.04      0.01      0.04      0.02      0.06    857.04      1.00\n",
      "               noise      0.03      0.03      0.02      0.00      0.06    679.89      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  16.85565209388733\n",
      "Iteration 13/100: train NMLL: 0.838, valid NMLL 0.174, valid RMSE of mean 0.431, valid RMSE of std 0.324\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.04      0.01      0.04      0.02      0.05    623.08      1.00\n",
      "               noise      0.02      0.02      0.01      0.00      0.04    714.20      1.00\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  17.692743062973022\n",
      "Iteration 14/100: train NMLL: 0.753, valid NMLL 0.240, valid RMSE of mean 0.448, valid RMSE of std 0.336\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.04      0.01      0.03      0.02      0.05    325.83      1.02\n",
      "               noise      0.01      0.01      0.01      0.00      0.03    748.87      1.00\n",
      "\n",
      "Number of divergences: 1\n",
      "Validation using full posterior took  19.23545503616333\n",
      "Iteration 15/100: train NMLL: 0.670, valid NMLL 0.431, valid RMSE of mean 0.471, valid RMSE of std 0.348\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.03      0.01      0.03      0.02      0.05    712.85      1.00\n",
      "               noise      0.01      0.01      0.01      0.00      0.02    751.33      1.01\n",
      "\n",
      "Number of divergences: 1\n",
      "Validation using full posterior took  19.6962628364563\n",
      "Iteration 16/100: train NMLL: 0.594, valid NMLL 0.678, valid RMSE of mean 0.488, valid RMSE of std 0.354\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.03      0.01      0.03      0.02      0.05    522.54      1.01\n",
      "               noise      0.01      0.01      0.00      0.00      0.01    633.73      1.01\n",
      "\n",
      "Number of divergences: 0\n",
      "Validation using full posterior took  22.263839960098267\n",
      "Iteration 17/100: train NMLL: 0.504, valid NMLL 1.504, valid RMSE of mean 0.519, valid RMSE of std 0.368\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.03      0.01      0.03      0.02      0.04    629.35      1.01\n",
      "               noise      0.00      0.00      0.00      0.00      0.01    686.11      1.00\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "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-05 to the diagonal\n",
      "  warnings.warn(f\"A not p.d., added jitter of {jitter_new:.1e} to the diagonal\", NumericalWarning)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  28.856853008270264\n",
      "Iteration 18/100: train NMLL: 0.416, valid NMLL 2.862, valid RMSE of mean 0.545, valid RMSE of std 0.381\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.03      0.01      0.03      0.02      0.04    626.02      1.01\n",
      "               noise      0.00      0.00      0.00      0.00      0.00    665.31      1.01\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "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-04 to the diagonal\n",
      "  warnings.warn(f\"A not p.d., added jitter of {jitter_new:.1e} to the diagonal\", NumericalWarning)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  28.24318218231201\n",
      "Iteration 19/100: train NMLL: 0.325, valid NMLL 5.035, valid RMSE of mean 0.565, valid RMSE of std 0.389\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.03      0.01      0.03      0.02      0.04    719.72      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.00    699.01      1.00\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "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-04 to the diagonal\n",
      "  warnings.warn(f\"A not p.d., added jitter of {jitter_new:.1e} to the diagonal\", NumericalWarning)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation using full posterior took  30.02123475074768\n",
      "Iteration 20/100: train NMLL: 0.213, valid NMLL 12.033, valid RMSE of mean 0.581, valid RMSE of std 0.394\n",
      "\n",
      "                          mean       std    median      5.0%     95.0%     n_eff     r_hat\n",
      "  kernel.lengthscale      0.03      0.01      0.03      0.02      0.03    838.15      1.00\n",
      "               noise      0.00      0.00      0.00      0.00      0.00    604.64      1.00\n",
      "\n",
      "Number of divergences: 0\n"
     ]
    },
    {
     "ename": "NotPSDError",
     "evalue": "Matrix not positive definite after repeatedly adding jitter up to 1.0e-04. Original error on first attempt: cholesky_cpu: For batch 158: U(417,417) is zero, singular U.",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mRuntimeError\u001b[0m                              Traceback (most recent call last)",
      "\u001b[0;32m~/envs/mbml/lib/python3.9/site-packages/gpytorch/utils/cholesky.py\u001b[0m in \u001b[0;36mpsd_safe_cholesky\u001b[0;34m(A, upper, out, jitter, max_tries)\u001b[0m\n\u001b[1;32m     31\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---> 32\u001b[0;31m         \u001b[0mL\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcholesky\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mA\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mupper\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mupper\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mout\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mout\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     33\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mL\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mRuntimeError\u001b[0m: cholesky_cpu: For batch 158: U(417,417) is zero, singular U.",
      "\nDuring handling of the above exception, another exception occurred:\n",
      "\u001b[0;31mNotPSDError\u001b[0m                               Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-25-3132c84972b7>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m    102\u001b[0m             \u001b[0moutput\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mmodel\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mexpanded_test_x\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    103\u001b[0m             \u001b[0mmll\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mgpytorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmlls\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mExactMarginalLogLikelihood\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmodel\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlikelihood\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmodel\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 104\u001b[0;31m             \u001b[0mnmll_loss\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmean\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0mmll\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0moutput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtest_y_trans\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    105\u001b[0m             \u001b[0mnmll_losses_valid_mode\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnmll_loss\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mitem\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    106\u001b[0m             \u001b[0;31m#output_mean = output.mean * sigma_y + mu_y\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/mbml/lib/python3.9/site-packages/gpytorch/module.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *inputs, **kwargs)\u001b[0m\n\u001b[1;32m     26\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     27\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[0minputs\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---> 28\u001b[0;31m         \u001b[0moutputs\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[0minputs\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     29\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0misinstance\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0moutputs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlist\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     30\u001b[0m             \u001b[0;32mreturn\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0m_validate_module_outputs\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0moutput\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0moutput\u001b[0m \u001b[0;32min\u001b[0m \u001b[0moutputs\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/mbml/lib/python3.9/site-packages/gpytorch/mlls/exact_marginal_log_likelihood.py\u001b[0m in \u001b[0;36mforward\u001b[0;34m(self, function_dist, target, *params)\u001b[0m\n\u001b[1;32m     60\u001b[0m         \u001b[0;31m# Get the log prob of the marginal distribution\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     61\u001b[0m         \u001b[0moutput\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlikelihood\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfunction_dist\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0mparams\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 62\u001b[0;31m         \u001b[0mres\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0moutput\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlog_prob\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtarget\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     63\u001b[0m         \u001b[0mres\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_add_other_terms\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mres\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mparams\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     64\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/mbml/lib/python3.9/site-packages/gpytorch/distributions/multivariate_normal.py\u001b[0m in \u001b[0;36mlog_prob\u001b[0;34m(self, value)\u001b[0m\n\u001b[1;32m    167\u001b[0m         \u001b[0;31m# Get log determininant and first part of quadratic form\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    168\u001b[0m         \u001b[0mcovar\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mcovar\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mevaluate_kernel\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--> 169\u001b[0;31m         \u001b[0minv_quad\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlogdet\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mcovar\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0minv_quad_logdet\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0minv_quad_rhs\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mdiff\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0munsqueeze\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[0mlogdet\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\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    170\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    171\u001b[0m         \u001b[0mres\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m-\u001b[0m\u001b[0;36m0.5\u001b[0m \u001b[0;34m*\u001b[0m \u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0minv_quad\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlogdet\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdiff\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msize\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[0mmath\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlog\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m2\u001b[0m \u001b[0;34m*\u001b[0m \u001b[0mmath\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpi\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/mbml/lib/python3.9/site-packages/gpytorch/lazy/lazy_tensor.py\u001b[0m in \u001b[0;36minv_quad_logdet\u001b[0;34m(self, inv_quad_rhs, logdet, reduce_inv_quad)\u001b[0m\n\u001b[1;32m   1246\u001b[0m                     \u001b[0mwill_need_cholesky\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mFalse\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1247\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0mwill_need_cholesky\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1248\u001b[0;31m                 \u001b[0mcholesky\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mCholLazyTensor\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mTriangularLazyTensor\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcholesky\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   1249\u001b[0m             \u001b[0;32mreturn\u001b[0m \u001b[0mcholesky\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0minv_quad_logdet\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0minv_quad_rhs\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0minv_quad_rhs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlogdet\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mlogdet\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mreduce_inv_quad\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mreduce_inv_quad\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1250\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/mbml/lib/python3.9/site-packages/gpytorch/lazy/lazy_tensor.py\u001b[0m in \u001b[0;36mcholesky\u001b[0;34m(self, upper)\u001b[0m\n\u001b[1;32m    965\u001b[0m             \u001b[0;34m(\u001b[0m\u001b[0mLazyTensor\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0mCholesky\u001b[0m \u001b[0mfactor\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mtriangular\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mupper\u001b[0m\u001b[0;34m/\u001b[0m\u001b[0mlower\u001b[0m \u001b[0mdepending\u001b[0m \u001b[0mon\u001b[0m \u001b[0;34m\"upper\"\u001b[0m \u001b[0marg\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    966\u001b[0m         \"\"\"\n\u001b[0;32m--> 967\u001b[0;31m         \u001b[0mchol\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_cholesky\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mupper\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mFalse\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    968\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mupper\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    969\u001b[0m             \u001b[0mchol\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mchol\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_transpose_nonbatch\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/mbml/lib/python3.9/site-packages/gpytorch/utils/memoize.py\u001b[0m in \u001b[0;36mg\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m     57\u001b[0m         \u001b[0mkwargs_pkl\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mpickle\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdumps\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     58\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0m_is_in_cache\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcache_name\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkwargs_pkl\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mkwargs_pkl\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---> 59\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0m_add_to_cache\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcache_name\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmethod\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[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkwargs_pkl\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mkwargs_pkl\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     60\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0m_get_from_cache\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcache_name\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkwargs_pkl\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mkwargs_pkl\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     61\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/mbml/lib/python3.9/site-packages/gpytorch/lazy/lazy_tensor.py\u001b[0m in \u001b[0;36m_cholesky\u001b[0;34m(self, upper)\u001b[0m\n\u001b[1;32m    427\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    428\u001b[0m         \u001b[0;31m# contiguous call is necessary here\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 429\u001b[0;31m         \u001b[0mcholesky\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mpsd_safe_cholesky\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mevaluated_mat\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mupper\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mupper\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcontiguous\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    430\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mTriangularLazyTensor\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mcholesky\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mupper\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mupper\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    431\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/envs/mbml/lib/python3.9/site-packages/gpytorch/utils/cholesky.py\u001b[0m in \u001b[0;36mpsd_safe_cholesky\u001b[0;34m(A, upper, out, jitter, max_tries)\u001b[0m\n\u001b[1;32m     53\u001b[0m             \u001b[0;32mexcept\u001b[0m \u001b[0mRuntimeError\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     54\u001b[0m                 \u001b[0;32mcontinue\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 55\u001b[0;31m         raise NotPSDError(\n\u001b[0m\u001b[1;32m     56\u001b[0m             \u001b[0;34mf\"Matrix not positive definite after repeatedly adding jitter up to {jitter_new:.1e}. \"\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     57\u001b[0m             \u001b[0;34mf\"Original error on first attempt: {e}\"\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mNotPSDError\u001b[0m: Matrix not positive definite after repeatedly adding jitter up to 1.0e-04. Original error on first attempt: cholesky_cpu: For batch 158: U(417,417) is zero, singular U."
     ]
    }
   ],
   "source": [
    "#### \n",
    "tic_all = time.time()\n",
    "nmll_losses_model2 = []\n",
    "nmll_losses_valid_model2 = []\n",
    "rmse_losses_valid_model2 = []\n",
    "rmse_std_losses_valid_model2 = []\n",
    "nmll_losses_valid_model2_mode = []\n",
    "rmse_losses_valid_model2_mode = []\n",
    "rmse_std_losses_valid_model2_mode = []\n",
    "lengthscale_model2 = []\n",
    "noise_model2 = []\n",
    "for rep in range(repetitions):\n",
    "\n",
    "    # Load data\n",
    "    search_space = get_search_space(simulator=args.simulator)\n",
    "\n",
    "    # We don't need the oracle labels since we just call the simulator, likewise, don't need pool_labeled\n",
    "    oracle_labels = None\n",
    "    pool_labeled = None\n",
    "\n",
    "    # We do need to sample a training set\n",
    "    train_x, train_y = sample_dataset_from_simulator(args, search_space, n_samples=args.initial_samples, seed=rep)\n",
    "    test_x, test_y = sample_dataset_from_simulator(args, search_space, n_samples=args.test_samples, seed=4242)\n",
    "\n",
    "    # A simulator where we can access the true mean and stddev\n",
    "    _, true_mean, true_std = oracle_simulator(args, torch.Tensor(search_space))\n",
    "    true_mean, true_std = torch.Tensor(true_mean), torch.Tensor(true_std)\n",
    "\n",
    "    # Remove any seed that may appear\n",
    "    np.random.seed()\n",
    "\n",
    "    # Active learning scheme\n",
    "    nmll_losses = []\n",
    "    nmll_losses_valid = []\n",
    "    rmse_losses_valid = []\n",
    "    rmse_std_losses_valid = []\n",
    "    nmll_losses_valid_mode = []\n",
    "    rmse_losses_valid_mode = []\n",
    "    rmse_std_losses_valid_mode = []\n",
    "    lst_lengthscales = []\n",
    "    lst_noises = []\n",
    "    tic = time.time()\n",
    "\n",
    "    # Initial priors\n",
    "    length_scale_prior = GammaPrior(3, 6)\n",
    "    noise_prior = LogNormalPrior(loc=0, scale=1)\n",
    "    for i in range(args.active_learning_steps):\n",
    "\n",
    "        # Prepare data\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",
    "        test_x_trans = (test_x - min_x) / max_x\n",
    "        test_y_trans = (test_y - mu_y) / sigma_y\n",
    "\n",
    "        # Setup model and do inference\n",
    "        pyro.clear_param_store() \n",
    "        pyro.set_rng_seed(rep)\n",
    "        nuts_gpr = gp_pyro(train_x_trans, train_y_trans, length_scale_prior, noise_prior)\n",
    "        nuts_kernel = NUTS(nuts_gpr.model, target_accept_prob=0.8)\n",
    "        mcmc_run = MCMC(nuts_kernel, num_samples=num_samples, warmup_steps=warmup_steps, num_chains=num_chains,\n",
    "                       disable_progbar=True)\n",
    "        mcmc_run.run()\n",
    "\n",
    "        # Look at summary\n",
    "        mcmc_run.summary()\n",
    "\n",
    "        # Extract samples and mode from posterior\n",
    "        posterior_samples = mcmc_run.get_samples()\n",
    "        mode_l, mode_n = get_mode_from_kde2d(pd.DataFrame(posterior_samples))\n",
    "        posterior_samples[\"covar_module.base_kernel.lengthscale_prior\"] = posterior_samples['kernel.lengthscale'].view(-1, 1, 1)\n",
    "        posterior_samples[\"likelihood.noise_prior\"] = posterior_samples['noise'].view(-1,1)\n",
    "        del posterior_samples['kernel.lengthscale']\n",
    "        del posterior_samples['noise']\n",
    "        \n",
    "\n",
    "        # Turn model into batch model in order to draw mean functions\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.likelihood.register_prior(\"noise_prior\", noise_prior, \"noise\")\n",
    "        mll = gpytorch.mlls.ExactMarginalLogLikelihood(model.likelihood, model)\n",
    "        model.pyro_load_from_samples(posterior_samples)\n",
    "        \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",
    "        model.eval()\n",
    "        \n",
    "        # Validation using the full posterior\n",
    "        tacos = time.time()\n",
    "        with torch.no_grad():\n",
    "            expanded_test_x = test_x_trans.view(-1,1).unsqueeze(0).repeat(num_samples*num_chains, 1, 1)\n",
    "            output = model(expanded_test_x)\n",
    "            mll = gpytorch.mlls.ExactMarginalLogLikelihood(model.likelihood, model)\n",
    "            nmll_loss = torch.mean(-mll(output, test_y_trans))\n",
    "            nmll_losses_valid_mode.append(nmll_loss.item())\n",
    "            #output_mean = output.mean * sigma_y + mu_y\n",
    "            #output_std = output.stddev.detach() * sigma_y\n",
    "            #rmse_losses_valid_mode.append(torch.sqrt(torch.mean(torch.pow(output_mean - test_y, 2))))\n",
    "            #rmse_std_losses_valid_mode.append(torch.sqrt(torch.mean(torch.pow(output_std - test_y, 2))))\n",
    "            \n",
    "        # Validation using the first and second order moments of the predictive posteriors\n",
    "        pp_mean, pp_std = predictive_posterior_moments(output)\n",
    "        pp_mean = pp_mean * sigma_y + mu_y\n",
    "        pp_std = pp_std.detach() * sigma_y\n",
    "        rmse_losses_valid_mode.append(torch.sqrt(torch.mean(torch.pow(pp_mean - test_y, 2))))\n",
    "        rmse_std_losses_valid_mode.append(torch.sqrt(torch.mean(torch.pow(pp_std - test_y, 2))))\n",
    "        print(\"Validation using full posterior took \", time.time()-tacos)\n",
    "    \n",
    "        # Make predictions on search space for plotting and querying\n",
    "        ss_trans = (torch.FloatTensor(search_space) - min_x) / max_x\n",
    "        expanded_test_x = ss_trans.view(-1,1).unsqueeze(0).repeat(num_samples*num_chains, 1, 1)\n",
    "        output = model(expanded_test_x)\n",
    "    \n",
    "        # Validation using the mode of the posterior\n",
    "        # Make ExactGP with modes of hyperparameters\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.likelihood.register_prior(\"noise_prior\", noise_prior, \"noise\")\n",
    "        model.covar_module.base_kernel.lengthscale = torch.tensor(mode_l)\n",
    "        model.likelihood.noise = torch.tensor(mode_n)\n",
    "        lst_lengthscales.append(mode_l)\n",
    "        lst_noises.append(mode_n)\n",
    "        #print(\"lengthscale:\", model.covar_module.base_kernel.lengthscale.item())\n",
    "        #print(\"noise\", model.likelihood.noise.item())\n",
    "        mll = gpytorch.mlls.ExactMarginalLogLikelihood(model.likelihood, model)\n",
    "        \n",
    "        model.train()\n",
    "        # Train NMLL\n",
    "        with torch.no_grad():\n",
    "            preds = model.likelihood(model(train_x_trans))\n",
    "            nmll_loss = torch.mean(-mll(preds, train_y_trans))\n",
    "            nmll_losses.append(nmll_loss.item())\n",
    "        \n",
    "        model.eval()\n",
    "        # Valid NMLL\n",
    "        with torch.no_grad():\n",
    "            preds = model.likelihood(model(test_x_trans))\n",
    "            nmll_loss = torch.mean(-mll(preds, test_y_trans))\n",
    "            nmll_losses_valid.append(nmll_loss.item())\n",
    "        \n",
    "        # Search_space to get predictions of true mean and std\n",
    "        with torch.no_grad():\n",
    "            preds = model.likelihood(model(ss_trans))\n",
    "\n",
    "        # Compute loses\n",
    "        pred_mean = preds.mean * sigma_y + mu_y\n",
    "        pred_std = preds.stddev.detach() * sigma_y\n",
    "        losses = compute_loss(args, dataloader=(None, true_mean), predictions=pred_mean, lst_metrics=['rmse'])\n",
    "        rmse_losses_valid.append(losses['rmse'].item())\n",
    "        losses = compute_loss(args, dataloader=(None, true_std), predictions=pred_std, lst_metrics=['rmse'])\n",
    "        rmse_std_losses_valid.append(losses['rmse'].item())\n",
    "        \n",
    "        # Querying\n",
    "        # AL, where is stddev of the mean is highest\n",
    "        #idx = np.argmax(torch.std(output.mean, axis=0).detach().numpy())\n",
    "        # AL, where the stddev is the highest of the mode GP\n",
    "        idx = np.argmax(pred_mean)\n",
    "        \n",
    "        # Get new point\n",
    "        new_x = search_space[idx]\n",
    "        new_y, _, _ = oracle_simulator(args, new_x)\n",
    "\n",
    "        # Add to data set\n",
    "        train_x = torch.FloatTensor(np.concatenate([train_x, [new_x]]))\n",
    "        train_y = torch.FloatTensor(np.concatenate([train_y, new_y]))\n",
    "\n",
    "        \n",
    "        print(\"Iteration %d/%d: train NMLL: %.3f, valid NMLL %.3f, valid RMSE of mean %.3f, valid RMSE of std %.3f\"\n",
    "              % (i+1, args.active_learning_steps, nmll_losses[-1], nmll_losses_valid[-1],\n",
    "                 rmse_losses_valid[-1], rmse_std_losses_valid[-1]))\n",
    "\n",
    "        # Plot results\n",
    "        if args.plot:\n",
    "            f, ax = plt.subplots(1, 3, figsize=(20, 6))\n",
    "            plot_mean_functions(ax[0], train_x[:-1], train_y[:-1], torch.FloatTensor(search_space), output,\n",
    "                               mu_y, sigma_y)\n",
    "            ax[0].plot(search_space, pred_mean, 'r--',lw=2, label=\"Mean w/ mode parameters\")\n",
    "            ax[0].plot(train_x[-1].numpy(), train_y[-1].numpy(), 'g*', ms=10, label=\"New point to add\")\n",
    "            ax[0].legend()\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.show()\n",
    "    \n",
    "    nmll_losses_model2.append(nmll_losses)\n",
    "    nmll_losses_valid_model2.append(nmll_losses_valid)\n",
    "    rmse_losses_valid_model2.append(rmse_losses_valid)\n",
    "    rmse_std_losses_valid_model2.append(rmse_std_losses_valid)\n",
    "    nmll_losses_valid_model2_mode.append(nmll_losses_valid_mode)\n",
    "    rmse_losses_valid_model2_mode.append(rmse_losses_valid_mode)\n",
    "    rmse_std_losses_valid_model2_mode.append(rmse_std_losses_valid_mode)\n",
    "    lengthscale_model2.append(lst_lengthscales)\n",
    "    noise_model2.append(lst_noises)\n",
    "    print(f\"Repetition {rep+1} took {time.time()- tic} sec.\\n\")\n",
    "print(f\"The experiment took {time.time()- tic_all} sec.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "fig = plt.figure(figsize=(20,5))\n",
    "\n",
    "# create grid for different subplots\n",
    "spec = gridspec.GridSpec(ncols=3, nrows=1,\n",
    "                         width_ratios=[1, 1, 1], wspace=0.5,\n",
    "                         hspace=0.5, height_ratios=[1])\n",
    "\n",
    "ax1 = fig.add_subplot(spec[0])    \n",
    "ax2 = fig.add_subplot(spec[1])\n",
    "ax3 = fig.add_subplot(spec[2])\n",
    "\n",
    "for rep in range(repetitions):\n",
    "    ax1 = plot_one_variable(ax1, nmll_losses_valid_model2[rep], 'NMLL')\n",
    "    ax2 = plot_one_variable(ax2, rmse_losses_valid_model2[rep], 'RMSE of mean')\n",
    "    ax3 = plot_one_variable(ax3, rmse_std_losses_valid_model2[rep], 'RMSE of std')\n",
    "    ax1 = plot_one_variable(ax1, nmll_losses_valid_model2_mode[rep], 'NMLL')\n",
    "    ax2 = plot_one_variable(ax2, rmse_losses_valid_model2_mode[rep], 'RMSE of mean')\n",
    "    ax3 = plot_one_variable(ax3, rmse_std_losses_valid_model2_mode[rep], 'RMSE of std')\n",
    "#ax1.set_ylim(-0.1,1.6)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "iteration = args.active_learning_steps-1\n",
    "print(\"Evaluation of the models\")\n",
    "print(f\"Average validation values after {args.active_learning_steps} iterations\")\n",
    "print(\"----------------------\")\n",
    "print(\"Baseline model with ALM\")\n",
    "print(u\"-- NMLL         % .3f (\\u00B1%.3f)\" % (np.mean(nmll_losses_valid_baseline, axis=0)[iteration], \n",
    "                                               np.std(nmll_losses_valid_baseline, axis=0)[iteration]))\n",
    "print(u\"-- RMSE of mean % .3f (\\u00B1%.3f)\" % (np.mean(rmse_losses_valid_baseline, axis=0)[iteration],\n",
    "                                               np.std(rmse_losses_valid_baseline, axis=0)[iteration]))\n",
    "print(u\"-- RMSE of std  % .3f (\\u00B1%.3f)\" % (np.mean(rmse_std_losses_valid_baseline, axis=0)[iteration],\n",
    "                                               np.std(rmse_std_losses_valid_baseline, axis=0)[iteration]))\n",
    "print(\"----------------------\")\n",
    "print(\"Fully Bayesian GP model with ALM\")\n",
    "print(u\"-- NMLL         % .3f (\\u00B1%.3f)\" % (np.mean(nmll_losses_valid_model2, axis=0)[iteration], \n",
    "                                               np.std(nmll_losses_valid_model2, axis=0)[iteration]))\n",
    "print(u\"-- RMSE of mean % .3f (\\u00B1%.3f)\" % (np.mean(rmse_losses_valid_model2, axis=0)[iteration],\n",
    "                                               np.std(rmse_losses_valid_model2, axis=0)[iteration]))\n",
    "print(u\"-- RMSE of std  % .3f (\\u00B1%.3f)\" % (np.mean(rmse_std_losses_valid_model2, axis=0)[iteration],\n",
    "                                               np.std(rmse_std_losses_valid_model2, axis=0)[iteration]))\n",
    "print(\"----------------------\")\n",
    "print(\"Fully Bayesian GP model with new AL strategy\")\n",
    "print(u\"-- NMLL         % .3f (\\u00B1%.3f)\" % (np.mean(nmll_losses_valid_model1, axis=0)[iteration], \n",
    "                                               np.std(nmll_losses_valid_model1, axis=0)[iteration]))\n",
    "print(u\"-- RMSE of mean % .3f (\\u00B1%.3f)\" % (np.mean(rmse_losses_valid_model1, axis=0)[iteration],\n",
    "                                               np.std(rmse_losses_valid_model1, axis=0)[iteration]))\n",
    "print(u\"-- RMSE of std  % .3f (\\u00B1%.3f)\" % (np.mean(rmse_std_losses_valid_model1, axis=0)[iteration],\n",
    "                                               np.std(rmse_std_losses_valid_model1, axis=0)[iteration]))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "**(iv) MCMC: GP with variance between mean functions**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "#### \n",
    "tic_all = time.time()\n",
    "nmll_losses_model3 = []\n",
    "nmll_losses_valid_model3 = []\n",
    "rmse_losses_valid_model3 = []\n",
    "rmse_std_losses_valid_model3 = []\n",
    "nmll_losses_valid_model3_mode = []\n",
    "rmse_losses_valid_model3_mode = []\n",
    "rmse_std_losses_valid_model3_mode = []\n",
    "lengthscale_model3 = []\n",
    "noise_model3 = []\n",
    "for rep in range(repetitions):\n",
    "\n",
    "    # Load data\n",
    "    search_space = get_search_space(simulator=args.simulator)\n",
    "\n",
    "    # We don't need the oracle labels since we just call the simulator, likewise, don't need pool_labeled\n",
    "    oracle_labels = None\n",
    "    pool_labeled = None\n",
    "\n",
    "    # We do need to sample a training set\n",
    "    train_x, train_y = sample_dataset_from_simulator(args, search_space, n_samples=args.initial_samples, seed=rep)\n",
    "    test_x, test_y = sample_dataset_from_simulator(args, search_space, n_samples=args.test_samples, seed=4242)\n",
    "\n",
    "    # A simulator where we can access the true mean and stddev\n",
    "    _, true_mean, true_std = oracle_simulator(args, torch.Tensor(search_space))\n",
    "    true_mean, true_std = torch.Tensor(true_mean), torch.Tensor(true_std)\n",
    "\n",
    "    # Remove any seed that may appear\n",
    "    np.random.seed()\n",
    "\n",
    "    # Active learning scheme\n",
    "    nmll_losses = []\n",
    "    nmll_losses_valid = []\n",
    "    rmse_losses_valid = []\n",
    "    rmse_std_losses_valid = []\n",
    "    nmll_losses_valid_mode = []\n",
    "    rmse_losses_valid_mode = []\n",
    "    rmse_std_losses_valid_mode = []\n",
    "    lst_lengthscales = []\n",
    "    lst_noises = []\n",
    "    tic = time.time()\n",
    "\n",
    "    # Initial priors\n",
    "    length_scale_prior = GammaPrior(3, 6)\n",
    "    noise_prior = LogNormalPrior(loc=0, scale=1)\n",
    "    for i in range(args.active_learning_steps):\n",
    "\n",
    "        # Prepare data\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",
    "        test_x_trans = (test_x - min_x) / max_x\n",
    "        test_y_trans = (test_y - mu_y) / sigma_y\n",
    "        ###############\n",
    "        gp_train_loader = (train_x_trans, train_y_trans)\n",
    "        gp_test_loader = (test_x_trans, test_y_trans)\n",
    "\n",
    "        # Setup model\n",
    "        likelihood = gpytorch.likelihoods.GaussianLikelihood(\n",
    "                noise_constraint=gpytorch.constraints.GreaterThan(1e-6),\n",
    "                noise_prior=gpytorch.priors.LogNormalPrior(0, 1)\n",
    "            )\n",
    "        model = FancyGPWithPriors(train_x_trans, train_y_trans, likelihood)\n",
    "\n",
    "        # Fit model\n",
    "        mll = gpytorch.mlls.ExactMarginalLogLikelihood(model.likelihood, model)\n",
    "        nmll_loss, fit_losses = model.fit(gp_train_loader, args)\n",
    "        nmll_losses.append(nmll_loss)\n",
    "        lst_lengthscales.append(model.covar_module.base_kernel.lengthscale.item())\n",
    "        lst_noises.append(model.likelihood.noise.item())\n",
    "\n",
    "\n",
    "        # Make predictions on the test set\n",
    "        # Validate with: marginal log likelihood (MLL)\n",
    "        predict_output = model.predict(gp_test_loader)\n",
    "        predictions_mll = predict_output['predictions']\n",
    "        losses = compute_loss(args, gp_test_loader, predictions_mll, lst_metrics=['mll'], mll=mll)\n",
    "        nmll_losses_valid.append(losses['nmll'])\n",
    "\n",
    "        # Make predictions for validation, querying and plotting\n",
    "        # Make predictions on the search space\n",
    "        # Also predictions for PLOTTING and for QUERYING the next label\n",
    "        # Validation: RMSE(mean), RMSE(std)\n",
    "        # Get the unique values to query and transform them according to the input transformation\n",
    "        ss_unique = np.unique(search_space, axis=0)\n",
    "        pred_x = torch.Tensor(ss_unique)\n",
    "        pred_x_trans = (pred_x - min_x) / max_x\n",
    "        predict_output = model.predict(dataloader=(pred_x_trans, None))\n",
    "        predict_output_querying = predict_output\n",
    "\n",
    "        # Transform pred_x, mean and standard deviation back\n",
    "        pred_mean = predict_output['mean'] * sigma_y + mu_y\n",
    "        pred_std = predict_output['stddev'] * sigma_y\n",
    "        # Compute loses\n",
    "        losses = compute_loss(args, dataloader=(None, true_mean), predictions=pred_mean, lst_metrics=['rmse'])\n",
    "        rmse_losses_valid.append(losses['rmse'])\n",
    "        losses = compute_loss(args, dataloader=(None, true_std), predictions=pred_std, lst_metrics=['rmse'])\n",
    "        rmse_std_losses_valid.append(losses['rmse'])\n",
    "        #################\n",
    "        \n",
    "        # Setup model and do inference\n",
    "        pyro.clear_param_store() \n",
    "        pyro.set_rng_seed(rep)\n",
    "        nuts_gpr = gp_pyro(train_x_trans, train_y_trans, length_scale_prior, noise_prior)\n",
    "        nuts_kernel = NUTS(nuts_gpr.model, target_accept_prob=0.8)\n",
    "        mcmc_run = MCMC(nuts_kernel, num_samples=num_samples, warmup_steps=warmup_steps, num_chains=num_chains,\n",
    "                       disable_progbar=True)\n",
    "        mcmc_run.run()\n",
    "\n",
    "        # Look at summary\n",
    "        mcmc_run.summary()\n",
    "\n",
    "        # Extract samples and mode from posterior\n",
    "        posterior_samples = mcmc_run.get_samples()\n",
    "        mode_l, mode_n = get_mode_from_kde2d(pd.DataFrame(posterior_samples))\n",
    "        posterior_samples[\"covar_module.base_kernel.lengthscale_prior\"] = posterior_samples['kernel.lengthscale'].view(-1, 1, 1)\n",
    "        posterior_samples[\"likelihood.noise_prior\"] = posterior_samples['noise'].view(-1,1)\n",
    "        del posterior_samples['kernel.lengthscale']\n",
    "        del posterior_samples['noise']\n",
    "        \n",
    "        # Turn model into batch model in order to draw mean functions\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.likelihood.register_prior(\"noise_prior\", noise_prior, \"noise\")\n",
    "        mll = gpytorch.mlls.ExactMarginalLogLikelihood(model.likelihood, model)\n",
    "        model.pyro_load_from_samples(posterior_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",
    "        model.eval()\n",
    "        # Make predictions on search space for plotting and querying\n",
    "        ss_trans = (torch.FloatTensor(search_space) - min_x) / max_x\n",
    "        expanded_test_x = ss_trans.view(-1,1).unsqueeze(0).repeat(num_samples*num_chains, 1, 1)\n",
    "        output = model(expanded_test_x)\n",
    "    \n",
    "        # Querying\n",
    "        # AL, where is stddev of the mean is highest\n",
    "        idx = np.argmax(torch.std(output.mean, axis=0).detach().numpy())\n",
    "        \n",
    "        # Get new point\n",
    "        new_x = search_space[idx]\n",
    "        new_y, _, _ = oracle_simulator(args, new_x)\n",
    "\n",
    "        # Add to data set\n",
    "        train_x = torch.FloatTensor(np.concatenate([train_x, [new_x]]))\n",
    "        train_y = torch.FloatTensor(np.concatenate([train_y, new_y]))\n",
    "\n",
    "        \n",
    "        print(\"Iteration %d/%d: train NMLL: %.3f, valid NMLL %.3f, valid RMSE of mean %.3f, valid RMSE of std %.3f\"\n",
    "              % (i+1, args.active_learning_steps, nmll_losses[-1], nmll_losses_valid[-1],\n",
    "                 rmse_losses_valid[-1], rmse_std_losses_valid[-1]))\n",
    "\n",
    "        # Plot results\n",
    "        if args.plot:\n",
    "            f, ax = plt.subplots(1, 3, figsize=(20, 6))\n",
    "            plot_mean_functions(ax[0], train_x[:-1], train_y[:-1], torch.FloatTensor(search_space), output,\n",
    "                               mu_y, sigma_y)\n",
    "            ax[0].plot(search_space, pred_mean, 'r--',lw=2, label=\"Mean w/ mode parameters\")\n",
    "            ax[0].plot(train_x[-1].numpy(), train_y[-1].numpy(), 'g*', ms=10, label=\"New point to add\")\n",
    "            ax[0].legend()\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.show()\n",
    "    \n",
    "    nmll_losses_model3.append(nmll_losses)\n",
    "    nmll_losses_valid_model3.append(nmll_losses_valid)\n",
    "    rmse_losses_valid_model3.append(rmse_losses_valid)\n",
    "    rmse_std_losses_valid_model3.append(rmse_std_losses_valid)\n",
    "    nmll_losses_valid_model3_mode.append(nmll_losses_valid_mode)\n",
    "    rmse_losses_valid_model3_mode.append(rmse_losses_valid_mode)\n",
    "    rmse_std_losses_valid_model3_mode.append(rmse_std_losses_valid_mode)\n",
    "    lengthscale_model3.append(lst_lengthscales)\n",
    "    noise_model3.append(lst_noises)\n",
    "    print(f\"Repetition {rep+1} took {time.time()- tic} sec.\\n\")\n",
    "print(f\"The experiment took {time.time()- tic_all} sec.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "fig = plt.figure(figsize=(20,5))\n",
    "\n",
    "# create grid for different subplots\n",
    "spec = gridspec.GridSpec(ncols=3, nrows=1,\n",
    "                         width_ratios=[1, 1, 1], wspace=0.5,\n",
    "                         hspace=0.5, height_ratios=[1])\n",
    "\n",
    "ax1 = fig.add_subplot(spec[0])    \n",
    "ax2 = fig.add_subplot(spec[1])\n",
    "ax3 = fig.add_subplot(spec[2])\n",
    "\n",
    "for rep in range(repetitions):\n",
    "    ax1 = plot_one_variable(ax1, nmll_losses_valid_model3[rep], 'NMLL')\n",
    "    ax2 = plot_one_variable(ax2, rmse_losses_valid_model3[rep], 'RMSE of mean')\n",
    "    ax3 = plot_one_variable(ax3, rmse_std_losses_valid_model3[rep], 'RMSE of std')\n",
    "    ax1 = plot_one_variable(ax1, nmll_losses_valid_model3_mode[rep], 'NMLL')\n",
    "    ax2 = plot_one_variable(ax2, rmse_losses_valid_model3_mode[rep], 'RMSE of mean')\n",
    "    ax3 = plot_one_variable(ax3, rmse_std_losses_valid_model3_mode[rep], 'RMSE of std')\n",
    "#ax1.set_ylim(-0.1,1.6)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "iteration = args.active_learning_steps-1\n",
    "print(\"Evaluation of the models\")\n",
    "print(f\"Average validation values after {args.active_learning_steps} iterations\")\n",
    "print(\"----------------------\")\n",
    "print(\"Baseline model with ALM\")\n",
    "print(u\"-- NMLL         % .3f (\\u00B1%.3f)\" % (np.mean(nmll_losses_valid_baseline, axis=0)[iteration], \n",
    "                                               np.std(nmll_losses_valid_baseline, axis=0)[iteration]))\n",
    "print(u\"-- RMSE of mean % .3f (\\u00B1%.3f)\" % (np.mean(rmse_losses_valid_baseline, axis=0)[iteration],\n",
    "                                               np.std(rmse_losses_valid_baseline, axis=0)[iteration]))\n",
    "print(u\"-- RMSE of std  % .3f (\\u00B1%.3f)\" % (np.mean(rmse_std_losses_valid_baseline, axis=0)[iteration],\n",
    "                                               np.std(rmse_std_losses_valid_baseline, axis=0)[iteration]))\n",
    "print(\"----------------------\")\n",
    "print(\"GP model with new AL strategy\")\n",
    "print(u\"-- NMLL         % .3f (\\u00B1%.3f)\" % (np.mean(nmll_losses_valid_model3, axis=0)[iteration], \n",
    "                                               np.std(nmll_losses_valid_model3, axis=0)[iteration]))\n",
    "print(u\"-- RMSE of mean % .3f (\\u00B1%.3f)\" % (np.mean(rmse_losses_valid_model3, axis=0)[iteration],\n",
    "                                               np.std(rmse_losses_valid_model3, axis=0)[iteration]))\n",
    "print(u\"-- RMSE of std  % .3f (\\u00B1%.3f)\" % (np.mean(rmse_std_losses_valid_model3, axis=0)[iteration],\n",
    "                                               np.std(rmse_std_losses_valid_model3, axis=0)[iteration]))\n",
    "print(\"----------------------\")\n",
    "print(\"Fully Bayesian GP model with ALM\")\n",
    "print(u\"-- NMLL         % .3f (\\u00B1%.3f)\" % (np.mean(nmll_losses_valid_model2, axis=0)[iteration], \n",
    "                                               np.std(nmll_losses_valid_model2, axis=0)[iteration]))\n",
    "print(u\"-- RMSE of mean % .3f (\\u00B1%.3f)\" % (np.mean(rmse_losses_valid_model2, axis=0)[iteration],\n",
    "                                               np.std(rmse_losses_valid_model2, axis=0)[iteration]))\n",
    "print(u\"-- RMSE of std  % .3f (\\u00B1%.3f)\" % (np.mean(rmse_std_losses_valid_model2, axis=0)[iteration],\n",
    "                                               np.std(rmse_std_losses_valid_model2, axis=0)[iteration]))\n",
    "print(\"----------------------\")\n",
    "print(\"Fully Bayesian GP model with new AL strategy\")\n",
    "print(u\"-- NMLL         % .3f (\\u00B1%.3f)\" % (np.mean(nmll_losses_valid_model1, axis=0)[iteration], \n",
    "                                               np.std(nmll_losses_valid_model1, axis=0)[iteration]))\n",
    "print(u\"-- RMSE of mean % .3f (\\u00B1%.3f)\" % (np.mean(rmse_losses_valid_model1, axis=0)[iteration],\n",
    "                                               np.std(rmse_losses_valid_model1, axis=0)[iteration]))\n",
    "print(u\"-- RMSE of std  % .3f (\\u00B1%.3f)\" % (np.mean(rmse_std_losses_valid_model1, axis=0)[iteration],\n",
    "                                               np.std(rmse_std_losses_valid_model1, axis=0)[iteration]))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Plots of loss functions in experiment 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "sns.set_style(\"darkgrid\")\n",
    "sns.set_context(\"paper\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "fig, ax = plt.subplots(3,1, figsize=(6,12))\n",
    "\n",
    "xx = np.arange(args.active_learning_steps) + args.initial_samples\n",
    "\n",
    "colors=['tab:blue', 'tab:purple', 'k', 'tab:green']\n",
    "ls = ['dotted', 'dashed', 'solid', 'dashdot']\n",
    "lw = 2\n",
    "\n",
    "# NMLL\n",
    "ax[0].plot(xx, np.mean(nmll_losses_valid_baseline, axis=0), c=colors[0], linestyle=ls[0], linewidth=lw, label=\"Baseline (ALM)\")\n",
    "ax[0].plot(xx, np.mean(nmll_losses_valid_model3, axis=0), c=colors[1], linestyle=ls[1], linewidth=lw, label=\"Baseline: New AL\")\n",
    "ax[0].plot(xx, np.mean(nmll_losses_valid_model1, axis=0), c=colors[2], linestyle=ls[2], linewidth=lw, label=\"FBGP MCMC (proposed)\")\n",
    "ax[0].plot(xx, np.mean(nmll_losses_valid_model2, axis=0), c=colors[3], linestyle=ls[3], linewidth=lw, label=\"FBGP MCMC (ALM)\")\n",
    "#ax[0].plot(xx, np.mean(nmll_losses_valid_model1_mode, axis=0), 'g-', label=\"FBGP MCMC (full posterior)\")\n",
    "#ax[0].plot(xx, np.median(nmll_losses_valid_model1_mode, axis=0), 'g--', label=\"FBGP MCMC (full posterior)\")\n",
    "ax[0].set_ylim(0.2,1.65)\n",
    "#ax[0].set_xlabel(\"#data points\")\n",
    "ax[0].set_ylabel(\"Negative MLL\")\n",
    "#ax[0].set_title(\"Losses\")\n",
    "#ax[0].legend()\n",
    "\n",
    "# RMSE of mean\n",
    "ax[1].plot(xx, np.mean(rmse_losses_valid_baseline, axis=0),c=colors[0], linestyle=ls[0], linewidth=lw, label=\"Baseline (ALM)\")\n",
    "ax[1].plot(xx, np.mean(rmse_losses_valid_model3, axis=0), c=colors[1], linestyle=ls[1], linewidth=lw, label=\"Baseline: New AL\")\n",
    "ax[1].plot(xx, np.mean(rmse_losses_valid_model1, axis=0),c=colors[2], linestyle=ls[2], linewidth=lw, label=\"FBGP MCMC (proposed)\")\n",
    "ax[1].plot(xx, np.mean(rmse_losses_valid_model2, axis=0), c=colors[3], linestyle=ls[3], linewidth=lw, label=\"FBGP MCMC (ALM)\")\n",
    "#ax[1].plot(xx, np.mean(rmse_losses_valid_model1, axis=0),'g-', label=\"FBGP MCMC (full posterior)\")\n",
    "#ax[1].plot(xx, np.median(rmse_losses_valid_model1, axis=0),'g--', label=\"FBGP MCMCM (full posterior)\")\n",
    "#ax[1].set_ylim(-1,2)\n",
    "#ax[1].set_xlabel(\"#data points\")\n",
    "ax[1].set_ylabel(\"RMSE of the mean\")\n",
    "#ax[1].set_title(\"RMSE of the mean\")\n",
    "#ax[1].legend()\n",
    "\n",
    "# RMSE of std\n",
    "ax[2].plot(xx, np.mean(rmse_std_losses_valid_baseline, axis=0),c=colors[0], linestyle=ls[0], linewidth=lw, label=\"Baseline (ALM)\")\n",
    "ax[2].plot(xx, np.mean(rmse_std_losses_valid_model3, axis=0), c=colors[1], linestyle=ls[1], linewidth=lw, label=\"Baseline: New AL\")\n",
    "ax[2].plot(xx, np.mean(rmse_std_losses_valid_model1, axis=0),c=colors[2], linestyle=ls[2], linewidth=lw, label=\"FBGP MCMC (proposed)\")\n",
    "ax[2].plot(xx, np.mean(rmse_std_losses_valid_model2, axis=0), c=colors[3], linestyle=ls[3], linewidth=lw, label=\"FBGP MCMC (ALM)\")\n",
    "#ax[2].plot(xx, np.mean(rmse_std_losses_valid_model1_mode, axis=0),'g-', label=\"FBGP MCMC (full posterior)\")\n",
    "#ax[2].plot(xx, np.median(rmse_std_losses_valid_model1_mode, axis=0),'g--', label=\"FBGP MCMC (full posterior)\")\n",
    "#ax[2].set_ylim(.2,0.)\n",
    "ax[2].set_xlabel(\"#data points\")\n",
    "ax[2].set_ylabel(\"RMSE of the std. deviation\")\n",
    "#ax[2].set_title(\"RMSE of the std. deviation\")\n",
    "#ax[2].legend()\n",
    "\n",
    "if False:\n",
    "    ax[0].plot(xx, np.median(nmll_losses_valid_baseline, axis=0), 'r--', label=\"Baseline (ALM)\")\n",
    "    ax[0].plot(xx, np.median(nmll_losses_valid_model3, axis=0), 'y--', label=\"Baselin: New AL\")\n",
    "    ax[0].plot(xx, np.median(nmll_losses_valid_model1, axis=0), 'b--', label=\"FBGP MCMC (proposed)\")\n",
    "    ax[0].plot(xx, np.median(nmll_losses_valid_model2, axis=0), 'g--', label=\"FBGP MCMC (ALM)\")\n",
    "    ax[1].plot(xx, np.median(rmse_losses_valid_baseline, axis=0),'r--', label=\"Baseline (ALM)\")\n",
    "    ax[1].plot(xx, np.median(rmse_losses_valid_model3, axis=0), 'y--', label=\"Baselin: New AL\")\n",
    "    ax[1].plot(xx, np.median(rmse_losses_valid_model1, axis=0),'b--', label=\"FBGP MCMCM (proposed)\")\n",
    "    ax[1].plot(xx, np.median(rmse_losses_valid_model2, axis=0), 'g--', label=\"FBGP MCMC (ALM)\")\n",
    "    ax[2].plot(xx, np.median(rmse_std_losses_valid_baseline, axis=0),'r--', label=\"Baseline (ALM)\")\n",
    "    ax[2].plot(xx, np.median(rmse_std_losses_valid_model3, axis=0), 'y--', label=\"Baselin: New AL\")\n",
    "    ax[2].plot(xx, np.median(rmse_std_losses_valid_model1, axis=0),'b--', label=\"FBGP MCMC (proposed)\")\n",
    "    ax[2].plot(xx, np.median(rmse_std_losses_valid_model2, axis=0), 'g--', label=\"FBGP MCMC (ALM)\")\n",
    "\n",
    "\n",
    "fig.subplots_adjust(bottom=0.3, wspace=0.33)\n",
    "\n",
    "ax[2].legend(loc='upper center', \n",
    "             bbox_to_anchor=(0.5, -0.2),fancybox=False, shadow=False, ncol=2)\n",
    "plt.savefig(\"losses.pdf\", bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "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": 4
}
