{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "hidden_ranges": [],
    "originalKey": "501041cc-0473-4971-bff9-fd6e92e1eae4",
    "showInput": false
   },
   "source": [
    "## High-Dimensional sample-efficient Bayesian Optimization with SAASBO\n",
    "\n",
    "This tutorial shows how to use the Sparse Axis-Aligned Subspace Bayesian Optimization (SAASBO) \n",
    "method for high-dimensional Bayesian optimization [1]. SAASBO places strong priors on the \n",
    "inverse lengthscales to avoid overfitting in high-dimensional spaces. Specifically, SAASBO \n",
    "uses a hierarchical sparsity prior consisting of a global shrinkage parameter \n",
    "$\\tau \\sim \\mathcal{HC}(\\beta)$ and inverse lengthscales $\\rho_d \\sim \\mathcal{HC}(\\tau)$ \n",
    "for $d=1, \\ldots, D$, where $\\mathcal{HC}$ is the half-Cauchy distribution. \n",
    "While half-Cauchy priors favor values near zero they also have heavy tails, which allows the \n",
    "inverse lengthscales of the most important parameters to escape zero. To perform inference in the \n",
    "SAAS model we use Hamiltonian Monte Carlo (HMC) as we found that to outperform MAP inference.\n",
    "\n",
    "We find that SAASBO performs well on problems with hundreds of dimensions. As we rely on HMC \n",
    "and in particular the No-U-Turn-Sampler (NUTS) for inference, the overhead of SAASBO scales \n",
    "cubically with the number of datapoints. Depending on the problem, using more than a few hundred\n",
    "evaluations may not be feasible as SAASBO is designed for problems with a limited evaluation budget.\n",
    "\n",
    "In general, we recommend using [Ax](https://ax.dev) for a simple BO setup like this one. See [here](https://ax.dev/tutorials/saasbo.html) for a SAASBO tutorial in Ax, which uses the Noisy Expected Improvement acquisition function. To customize the acquisition function used with SAASBO in Ax, see the [custom acquisition tutorial](./custom_acquisition), where adding `\\\"surrogate\\\": Surrogate(SaasFullyBayesianSingleTaskGP),` to the `model_kwargs` of `BOTORCH_MODULAR` step is sufficient to enable the SAAS model.\n",
    "\n",
    "[1]: [D. Eriksson, M. Jankowiak. High-Dimensional Bayesian Optimization with Sparse Axis-Aligned Subspaces. Proceedings of the Thirty-Seventh Conference on Uncertainty in Artificial Intelligence, 2021.](https://proceedings.mlr.press/v161/eriksson21a.html)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "code_folding": [],
    "customOutput": null,
    "executionStartTime": 1668653404823,
    "executionStopTime": 1668653404909,
    "hidden_ranges": [],
    "originalKey": "26933c08-82d6-439d-9fcb-6e358b080ab6",
    "requestMsgId": "1806f0c7-d668-4248-a390-14add9bcb451"
   },
   "outputs": [],
   "source": [
    "import os\n",
    "\n",
    "import torch\n",
    "from torch.quasirandom import SobolEngine\n",
    "\n",
    "from botorch import fit_fully_bayesian_model_nuts\n",
    "from botorch.acquisition import qExpectedImprovement\n",
    "from botorch.models.fully_bayesian import SaasFullyBayesianSingleTaskGP\n",
    "from botorch.models.transforms import Standardize\n",
    "from botorch.optim import optimize_acqf\n",
    "from botorch.test_functions import Branin\n",
    "\n",
    "SMOKE_TEST = os.environ.get(\"SMOKE_TEST\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "customOutput": null,
    "executionStartTime": 1668653405125,
    "executionStopTime": 1668653405130,
    "hidden_ranges": [],
    "originalKey": "f1e3c7f0-1afc-42e2-af59-5f5fae755ce5",
    "requestMsgId": "068ddee5-939e-4f5b-8210-2f6a490f6c4e",
    "showInput": true
   },
   "outputs": [],
   "source": [
    "tkwargs = {\n",
    "    \"device\": torch.device(\"cuda:1\" if torch.cuda.is_available() else \"cpu\"),\n",
    "    \"dtype\": torch.double,\n",
    "}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "hidden_ranges": [],
    "originalKey": "08a3d790-52a5-4821-af21-1040f1a037f0",
    "showInput": false
   },
   "source": [
    "The time to fit the SAAS model can be decreased by lowering\n",
    "`WARMUP_STEPS` and `NUM_SAMPLES`. \n",
    "\n",
    "We recommend using 512 warmup steps and 256 samples when\n",
    "possible and to not use fewer than 256 warmup steps and 128 samples. By default, we only\n",
    "keep each 16th sample which with 256 samples results in 32 hyperparameter samples.\n",
    "\n",
    "To make this tutorial run faster we use 256 warmup steps and 128 samples. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "customInput": null,
    "customOutput": null,
    "executionStartTime": 1668653405353,
    "executionStopTime": 1668653405445,
    "originalKey": "363224de-347c-46a7-9c84-970cbb8e825d",
    "requestMsgId": "09e1ff1f-9c11-4053-8123-08aa3397dfc1",
    "showInput": true
   },
   "outputs": [],
   "source": [
    "WARMUP_STEPS = 256 if not SMOKE_TEST else 32\n",
    "NUM_SAMPLES = 128 if not SMOKE_TEST else 16\n",
    "THINNING = 16"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "hidden_ranges": [],
    "originalKey": "af8beafd-352c-421d-8797-7660ddfa39f3",
    "showInput": false
   },
   "source": [
    "## Simple model fitting\n",
    "We generate a simple function that only depends on the first parameter and show that the SAAS\n",
    "model sets all other lengthscales to large values."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "customOutput": null,
    "executionStartTime": 1668653405681,
    "executionStopTime": 1668653405771,
    "hidden_ranges": [],
    "originalKey": "f506aa6b-904c-4a7e-8a38-0443e983df06",
    "requestMsgId": "a6b6bfcd-c30c-4339-a342-02dd398a8274",
    "showInput": true
   },
   "outputs": [],
   "source": [
    "train_X = torch.rand(10, 4, **tkwargs)\n",
    "test_X = torch.rand(5, 4, **tkwargs)\n",
    "train_Y = torch.sin(train_X[:, :1])\n",
    "test_Y = torch.sin(test_X[:, :1])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "hidden_ranges": [],
    "originalKey": "cc9314b1-f255-4f7d-9f6d-eb349b34805e",
    "showInput": false
   },
   "source": [
    "By default, we infer the unknown noise variance in the data. You can also pass in a known \n",
    "noise variance (`train_Yvar`) for each observation, which may be useful in cases where you for example\n",
    "know that the problem is noise-free and can then set the noise variance to a small value such as `1e-6`.\n",
    "\n",
    "In this case you can construct a model as follows:\n",
    "```\n",
    "gp = SaasFullyBayesianSingleTaskGP(train_X=train_X, train_Y=train_Y, train_Yvar=torch.full_like(train_Y, 1e-6))\n",
    "```"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "customOutput": null,
    "executionStartTime": 1668653406085,
    "executionStopTime": 1668653471282,
    "hidden_ranges": [],
    "originalKey": "148855fb-cf0c-4fc5-8431-06a5e61c5da5",
    "requestMsgId": "0c13f0b6-28b9-43ea-8d1b-00871e5e4f02",
    "showInput": true
   },
   "outputs": [],
   "source": [
    "gp = SaasFullyBayesianSingleTaskGP(\n",
    "    train_X=train_X, \n",
    "    train_Y=train_Y, \n",
    "    outcome_transform=Standardize(m=1)\n",
    ")\n",
    "fit_fully_bayesian_model_nuts(\n",
    "    gp,\n",
    "    warmup_steps=WARMUP_STEPS,\n",
    "    num_samples=NUM_SAMPLES,\n",
    "    thinning=THINNING,\n",
    "    disable_progbar=True,\n",
    ")\n",
    "with torch.no_grad():\n",
    "    posterior = gp.posterior(test_X)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "hidden_ranges": [],
    "originalKey": "5f4fa168-2662-499b-ac82-3ab122dfe2ad",
    "showInput": false
   },
   "source": [
    "Computing the median lengthscales over the MCMC dimensions makes it clear that the first feature has the smallest lengthscale\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "customOutput": null,
    "executionStartTime": 1668653471605,
    "executionStopTime": 1668653471693,
    "hidden_ranges": [],
    "originalKey": "44a1f7c0-9649-4d89-8226-0405fdf88518",
    "requestMsgId": "e815926b-5a2d-4b78-8b89-3c0720e45592",
    "showInput": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([ 1.2600, 22.0002, 19.5355, 21.7929], dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "print(gp.median_lengthscale.detach())"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "hidden_ranges": [],
    "originalKey": "cf15a6ca-3377-40d1-9821-fad8f6600657",
    "showInput": false
   },
   "source": [
    "### Make predictions with the model\n",
    "\n",
    "In the next cell we show how to make predictions with the SAAS model. You compute the mean\n",
    "and variance for test points just like for any other BoTorch posteriors. Note that the mean \n",
    "and posterior will have an extra batch dimension at -3 that corresponds to the number of MCMC\n",
    "samples (which is 8 in this tutorial)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "customOutput": null,
    "executionStartTime": 1668653471916,
    "executionStopTime": 1668653472023,
    "hidden_ranges": [],
    "originalKey": "898039a4-6ec8-46bd-a583-5a1614a3ccf6",
    "requestMsgId": "4328636f-fb02-44ee-8c48-842c3845297f",
    "showInput": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([8, 5, 1])\n",
      "torch.Size([8, 5, 1])\n"
     ]
    }
   ],
   "source": [
    "print(posterior.mean.shape)\n",
    "print(posterior.variance.shape)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "hidden_ranges": [],
    "originalKey": "02b33f7f-4f31-432a-bac7-8cad1831e9a1",
    "showInput": false
   },
   "source": [
    "We also provide several convenience methods for computing different statistics over the MCMC samples:\n",
    "```\n",
    "mixture_mean = posterior.mixture_mean\n",
    "mixture_variance = posterior.mixture_variance\n",
    "mixture_quantile = posterior.quantile(q=0.95)\n",
    "```"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "customOutput": null,
    "executionStartTime": 1668653472240,
    "executionStopTime": 1668653472326,
    "hidden_ranges": [],
    "originalKey": "b387d057-a497-401b-bfc2-ab427669c451",
    "requestMsgId": "64e0ee73-6ffd-4ad5-b9b2-bd9ea4e637ee",
    "showInput": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Ground truth:     tensor([0.7808, 0.8300, 0.1289, 0.7994, 0.2237], dtype=torch.float64)\n",
      "Mixture mean:     tensor([0.7808, 0.8298, 0.1427, 0.7994, 0.2242], dtype=torch.float64)\n"
     ]
    }
   ],
   "source": [
    "print(f\"Ground truth:     {test_Y.squeeze(-1)}\")\n",
    "print(f\"Mixture mean:     {posterior.mixture_mean.squeeze(-1)}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "executionStartTime": 1644277314184,
    "executionStopTime": 1644277314189,
    "hidden_ranges": [],
    "originalKey": "d9bec8be-2acd-40b8-aebb-612b62bbdfc3",
    "requestMsgId": "d9bec8be-2acd-40b8-aebb-612b62bbdfc3",
    "showInput": false
   },
   "source": [
    "## Optimize Branin embedded in a 30D space\n",
    "We take the standard 2D Branin problem and embed it in a 30D space. In particular,\n",
    "we let dimensions 0 and 1 correspond to the true dimensions. We will show that\n",
    "SAASBO is able to identify the important dimensions and efficiently optimize this function.\n",
    "We work with the domain $[0, 1]^d$ and unnormalize the inputs to the true domain of Branin \n",
    "before evaluating the function."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "customOutput": null,
    "executionStartTime": 1668653472540,
    "executionStopTime": 1668653472545,
    "hidden_ranges": [],
    "originalKey": "15baa08e-ca35-4da7-a495-c63fe5d5779d",
    "requestMsgId": "6c3f8d91-9139-4c07-986f-77629b1887e5",
    "showInput": true
   },
   "outputs": [],
   "source": [
    "branin = Branin().to(**tkwargs)\n",
    "\n",
    "\n",
    "def branin_emb(x):\n",
    "    \"\"\"x is assumed to be in [0, 1]^d\"\"\"\n",
    "    lb, ub = branin.bounds\n",
    "    return branin(lb + (ub - lb) * x[..., :2])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "customOutput": null,
    "executionStartTime": 1668653472768,
    "executionStopTime": 1668653472776,
    "hidden_ranges": [],
    "originalKey": "98b6936b-2f06-4d1f-82c0-2f1bd660d0b2",
    "requestMsgId": "1b5baaf2-e690-4b4d-9011-b6124e083410",
    "showInput": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using a total of 50 function evaluations\n"
     ]
    }
   ],
   "source": [
    "DIM = 30 if not SMOKE_TEST else 10\n",
    "\n",
    "# Evaluation budget\n",
    "N_INIT = 10\n",
    "N_ITERATIONS = 8 if not SMOKE_TEST else 1\n",
    "BATCH_SIZE = 5 if not SMOKE_TEST else 1\n",
    "print(f\"Using a total of {N_INIT + BATCH_SIZE * N_ITERATIONS} function evaluations\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "hidden_ranges": [],
    "originalKey": "27fd793f-18ee-49cb-9aa5-c8cd78b0b807",
    "showInput": false
   },
   "source": [
    "### Run the optimization\n",
    "We use 10 initial Sobol points followed by 8 iterations of BO using a batch size of 5, \n",
    "which results in a total of 50 function evaluations. As our goal is to minimize Branin, we flip\n",
    "the sign of the function values before fitting the SAAS model as the BoTorch acquisition\n",
    "functions assume maximization."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "customOutput": null,
    "executionStartTime": 1668653473096,
    "executionStopTime": 1668655621405,
    "hidden_ranges": [],
    "originalKey": "269287e0-500f-474d-891a-5439487e9a77",
    "requestMsgId": "5117b535-1fe7-40be-9f68-361db9d9b51b",
    "showInput": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Best initial point: 5.322\n",
      "3) New best: 1.960 @ [1.000, 0.209]\n",
      "4) New best: 1.145 @ [0.532, 0.213]\n",
      "5) New best: 0.712 @ [0.136, 0.763]\n",
      "6) New best: 0.445 @ [0.539, 0.143]\n",
      "7) New best: 0.399 @ [0.542, 0.150]\n",
      "8) New best: 0.398 @ [0.962, 0.164]\n"
     ]
    }
   ],
   "source": [
    "X = SobolEngine(dimension=DIM, scramble=True, seed=0).draw(N_INIT).to(**tkwargs)\n",
    "Y = branin_emb(X).unsqueeze(-1)\n",
    "print(f\"Best initial point: {Y.min().item():.3f}\")\n",
    "\n",
    "for i in range(N_ITERATIONS):\n",
    "    train_Y = -1 * Y  # Flip the sign since we want to minimize f(x)\n",
    "    gp = SaasFullyBayesianSingleTaskGP(\n",
    "        train_X=X,\n",
    "        train_Y=train_Y,\n",
    "        train_Yvar=torch.full_like(train_Y, 1e-6),\n",
    "        outcome_transform=Standardize(m=1),\n",
    "    )\n",
    "    fit_fully_bayesian_model_nuts(\n",
    "        gp,\n",
    "        warmup_steps=WARMUP_STEPS,\n",
    "        num_samples=NUM_SAMPLES,\n",
    "        thinning=THINNING,\n",
    "        disable_progbar=True,\n",
    "    )\n",
    "\n",
    "    EI = qExpectedImprovement(model=gp, best_f=train_Y.max())\n",
    "    candidates, acq_values = optimize_acqf(\n",
    "        EI,\n",
    "        bounds=torch.cat((torch.zeros(1, DIM), torch.ones(1, DIM))).to(**tkwargs),\n",
    "        q=BATCH_SIZE,\n",
    "        num_restarts=10,\n",
    "        raw_samples=1024,\n",
    "    )\n",
    "\n",
    "    Y_next = torch.cat([branin_emb(x).unsqueeze(-1) for x in candidates]).unsqueeze(-1)\n",
    "    if Y_next.min() < Y.min():\n",
    "        ind_best = Y_next.argmin()\n",
    "        x0, x1 = candidates[ind_best, :2].tolist()\n",
    "        print(\n",
    "            f\"{i + 1}) New best: {Y_next[ind_best].item():.3f} @ \"\n",
    "            f\"[{x0:.3f}, {x1:.3f}]\"\n",
    "        )\n",
    "    X = torch.cat((X, candidates))\n",
    "    Y = torch.cat((Y, Y_next))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "hidden_ranges": [],
    "originalKey": "a9704a99-0712-40bb-a263-6798e0925291",
    "showInput": false
   },
   "source": [
    "## Plot the results\n",
    "\n",
    "We can see that we were able to get close to the global optimium of $\\approx 0.398$ after 50 function evaluations.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "customOutput": null,
    "executionStartTime": 1668655621761,
    "executionStopTime": 1668655621936,
    "hidden_ranges": [],
    "originalKey": "fd0d7aa7-8d55-4942-adc2-de356666ac84",
    "requestMsgId": "4024717d-fc5c-4939-90ce-fb24b3e06ea3",
    "showInput": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "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luPtDXToAATUBxYsLn47n34KIE7HDlcA7xe/3W++Br4pLEeMKH67kauAyNhCdk4DoHuS1qBffgF+OVDIznEAipmj790D7N1VyM5hAMKK125pYsJLREREVq1JE8CnesHtOQ7AYRPafaYBEBike99+E9qtVRuo7Kl73yFHoHgFAkBoGFC1veb5v6siYt2A4hXlAEHBQM22BdsUAvjDCyh+8UzpYcJLREREVu1//wPahxXc/jgdCPhv8dud+THQv2CVFgBAKl6FCwDg3XeA8c1176vwFZBQzMx02FAgor3uffUXAZeLWXbcpzewsKfufe0jgYO3itduaZJEcSujrVhKSgq8vLzw162/4Oun+wIFfVhsrmEtF6QolUrs278P3bp0Q6AnL1oDyv9Fa/v270PnTp150ZqRrPkzQqlUYteuXejRowccHBx40dr/K6+fEYW9v3nRmkZ5+4x4GP8QdULrIDk5GZ6ehUyJG8mmZ3j93fzh5+Zn3jYL+VAzVWEfwqYqLLE0VWE/wKbycPIo9E1XGKVSCS97L73fQzdHt0I/JEzh4uBS6IeaKZzsnVDBXvd/dKZwVDgW+h+oKezt7EukXTvJrkC72vGu4FbBYMKrT0nEC/AzQqssfUYYg58RGpb+jCjq+1vXZ4S58DNCoyQ/I3Ldcs3WHu+0RkRERETlGhNeIiIiIirXmPASERERUbnGhJeIiIiIyjUmvERERERUrjHhJSIiIqJyjQkvEREREZVrTHiJiIiIqFxjwktERERE5RoTXiIiIiIq15jwEhEREVG5xoSXiIiIiMo1JrxEREREVK4x4SUiIiKico0JLxERERGVa1ad8C5cuBBhYWFwdnZGixYtcPLkSUuHRERERERljNUmvD///DOmTJmC8PBwnDlzBg0bNkS3bt0QHx9v6dCIiIiIqAyx2oR33rx5eOuttzB8+HDUq1cPS5YsgaurK1auXGnp0IiIiIioDLG3dADFkZOTg9OnT2P69OnyNjs7O3Tu3BnHjh0rcHx2djays7Plr5OTkwEAT548KflgyeKUSiUyMjKQmJgIBwcHS4dDJYzjbVs43raF421btHmaEMLktqwy4U1ISIBKpUJgYGC+7YGBgfjrr78KHD9nzhzMmjWrwPZatWqVWIxEREREZLrExER4eXmZ1IZVJrxFNX36dEyZMkX++unTpwgNDcXt27dN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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "%matplotlib inline\n",
    "\n",
    "Y_np = Y.cpu().numpy()\n",
    "fig, ax = plt.subplots(figsize=(8, 6))\n",
    "ax.plot(np.minimum.accumulate(Y_np), color=\"b\", label=\"SAASBO\")\n",
    "ax.plot([0, len(Y_np)], [0.398, 0.398], \"--\", c=\"g\", lw=3, label=\"Optimal value\")\n",
    "ax.grid(True)\n",
    "ax.set_title(f\"Branin, D = {DIM}\", fontsize=20)\n",
    "ax.set_xlabel(\"Number of evaluations\", fontsize=20)\n",
    "ax.set_xlim([0, len(Y_np)])\n",
    "ax.set_ylabel(\"Best value found\", fontsize=20)\n",
    "ax.set_ylim([0, 8])\n",
    "ax.legend(fontsize=18)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "hidden_ranges": [],
    "originalKey": "d81134ff-cec6-45cb-92bf-4170f428af40",
    "showInput": false
   },
   "source": [
    "## Predict on some test points\n",
    "We fit a model using the 50 datapoints collected by SAASBO and predict on 50 test \n",
    "points in order to see how well the SAAS model predicts out-of-sample.\n",
    "The plot shows the mean and a 95% confidence interval for each test point."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "customOutput": null,
    "executionStartTime": 1668655622271,
    "executionStopTime": 1668655822584,
    "hidden_ranges": [],
    "originalKey": "970977ea-ee5e-46eb-b500-683673ce723e",
    "requestMsgId": "2ae0c053-022f-4902-8bc5-b904bd85f90d",
    "showInput": true
   },
   "outputs": [],
   "source": [
    "train_X = SobolEngine(dimension=DIM, scramble=True, seed=0).draw(50).to(**tkwargs)\n",
    "test_X = SobolEngine(dimension=DIM, scramble=True, seed=1).draw(50).to(**tkwargs)\n",
    "train_Y = branin_emb(train_X).unsqueeze(-1)\n",
    "test_Y = branin_emb(test_X).unsqueeze(-1)\n",
    "\n",
    "gp = SaasFullyBayesianSingleTaskGP(\n",
    "    train_X=train_X,\n",
    "    train_Y=train_Y,\n",
    "    train_Yvar=torch.full_like(train_Y, 1e-6),\n",
    "    outcome_transform=Standardize(m=1),\n",
    ")\n",
    "fit_fully_bayesian_model_nuts(\n",
    "    gp,\n",
    "    warmup_steps=WARMUP_STEPS,\n",
    "    num_samples=NUM_SAMPLES,\n",
    "    thinning=THINNING,\n",
    "    disable_progbar=True,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "customOutput": null,
    "executionStartTime": 1668655921184,
    "executionStopTime": 1668655921625,
    "hidden_ranges": [],
    "originalKey": "25139c91-a34c-4fa8-808f-70c1cf6952fd",
    "requestMsgId": "ad9413e7-09aa-47f5-b435-bf37cf0180d1",
    "showInput": true
   },
   "outputs": [],
   "source": [
    "with torch.no_grad():\n",
    "    posterior = gp.posterior(test_X)\n",
    "median = posterior.quantile(value=torch.tensor([0.5], **tkwargs))\n",
    "q1 = posterior.quantile(value=torch.tensor([0.025], **tkwargs))\n",
    "q2 = posterior.quantile(value=torch.tensor([0.975], **tkwargs))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "customOutput": null,
    "executionStartTime": 1668655923525,
    "executionStopTime": 1668655923743,
    "hidden_ranges": [],
    "originalKey": "39163b27-e252-4244-9712-f52503e00f74",
    "requestMsgId": "7c819fcc-5f74-48b1-9fd4-286839fdd0b6",
    "showInput": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "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e++t/DODSeBh+XoiIvJK//sfoFAA/foxmAQahhMiInK78vJylJeX13qN0WhERUUFiouLERISAqVSBUGwv+bhhxuxkeS1GE6IiMjtjh49itzcXLtjOp0OoihCEAQolUqIogitVov169ejS5dbMXduHB5/HLjrLg81mryGz845+euvv5CUlITw8HAolUp069YNBw4csJ0XRREvvPACIiMjoVQqMXToUJw4ccKDLSYiChzR0dEYP3683VfLli0hl8vRsmVLjB8/HmPHjkWHDh2QkDAWTz8djV27gIkTgQ0bPN168jSfHDm5dOkSbrvtNgwePBibN29G69atceLECYSFhdmuWbx4Md5++22sWLECnTp1wvPPP48RI0bg559/RnBwsAdbT0Tk/1QqFVQqld0xuVwOo9EIuVwOtVoNo9EIs7k5pkyJQE5O5e/KoaFAx45N317yLj4ZTl599VW0b98eqamptmOdOnWy/VkURaSkpOC5557DXf+MD3766aeIiIjAunXrMHny5CZvMxFRoLNYLNDr9VAqlQAq65jMm9cPJ05UBhOuyiErnwwn69evx4gRI3D33Xdj586duOaaa/DII4/goYceAgCcPHkSBQUFGDp0qO01ISEh6NOnD/bs2eMwnOj1euj1etv3paWlAConbBmNxkbukedY+8Y++j7207/4Uz/z8vLwzjvvICMjAyaTCTKZDJs2fYvDh2fhxIlbAABqtYitW03o3Lmyxok/8afPsjbu7J8giqLotndrItbHMrNnz8bdd9+NnJwczJo1C8uWLcPUqVPxww8/4LbbbsPZs2cRGRlpe90999wDQRCwatWqau85b948zJ8/v9rxjIyMakOTRETknOzsbKSkpACoHDm5QgZABJCGli3HY8GC3ejY8W8PtJDcpby8HPfeey+0Wi1atmzp0nv5ZDiRy+W49dZb8cMPP9iO/e9//0NOTg727NnToHDiaOSkffv2OHfuHMLDwxu3Qx5kNBqxbds2DBs2DEFBQZ5uTqMIhD4C7Ke/8Yd+5uXloW/fvjCbzbVcJUVa2m5MmnRLk7WrqfnDZ+mMCxcuIDIy0i3hxCcf60RGRiImJsbuWHR0NL744gsAQNu2bQEAhYWFduGksLAQPXr0cPieCoUCCoWi2vGgoCC//stkFQj9DIQ+Auynv/Hlfi5ZsgTC1YVLriKRAN9+uxRJ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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 1, figsize=(8, 6))\n",
    "ax.plot([0, 80], [0, 80], \"b--\", lw=2)\n",
    "\n",
    "yerr1, yerr2 = median - q1, q2 - median\n",
    "yerr = torch.cat((yerr1.unsqueeze(0), yerr2.unsqueeze(0)), dim=0).squeeze(-1)\n",
    "markers, caps, bars = ax.errorbar(\n",
    "    test_Y.squeeze(-1).cpu(),\n",
    "    median.squeeze(-1).cpu(),\n",
    "    yerr=yerr.cpu(),\n",
    "    fmt=\".\",\n",
    "    capsize=4,\n",
    "    elinewidth=2.0,\n",
    "    ms=14,\n",
    "    c=\"k\",\n",
    "    ecolor=\"gray\",\n",
    ")\n",
    "ax.set_xlim([0, 80])\n",
    "ax.set_ylim([0, 80])\n",
    "[bar.set_alpha(0.8) for bar in bars]\n",
    "[cap.set_alpha(0.8) for cap in caps]\n",
    "ax.set_xlabel(\"True value\", fontsize=20)\n",
    "ax.set_ylabel(\"Predicted value\", fontsize=20)\n",
    "ax.set_aspect(\"equal\")\n",
    "ax.grid(True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "hidden_ranges": [],
    "originalKey": "34e976cd-7d09-40d2-8987-aecdefa7c0fd",
    "requestMsgId": "34e976cd-7d09-40d2-8987-aecdefa7c0fd",
    "showInput": false
   },
   "source": [
    "## Look a the lengthscales from the final model\n",
    "\n",
    "As SAASBO places strong priors on the inverse lengthscales, we only expect parameters \n",
    "0 and 1 to be identified as important by the model since the other parameters have no effect.\n",
    "We can confirm that this is the case below as the lengthscales of parameters 0 and 1 are \n",
    "small with all other lengthscales being large."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "customOutput": null,
    "executionStartTime": 1668655927129,
    "executionStopTime": 1668655927142,
    "hidden_ranges": [],
    "originalKey": "33147b57-ea6b-4c67-9c7d-796bb54d5c84",
    "requestMsgId": "b32e63df-16ee-45f1-af94-7f6f4bb78173",
    "showInput": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Parameter  0) Median lengthscale = 7.57e-01\n",
      "Parameter  1) Median lengthscale = 2.65e+00\n",
      "Parameter 24) Median lengthscale = 6.28e+02\n",
      "Parameter  7) Median lengthscale = 6.77e+02\n",
      "Parameter 29) Median lengthscale = 7.54e+02\n",
      "Parameter 19) Median lengthscale = 7.65e+02\n",
      "Parameter 16) Median lengthscale = 7.94e+02\n",
      "Parameter 27) Median lengthscale = 8.03e+02\n",
      "Parameter 15) Median lengthscale = 8.32e+02\n",
      "Parameter 26) Median lengthscale = 8.35e+02\n"
     ]
    }
   ],
   "source": [
    "median_lengthscales = gp.median_lengthscale\n",
    "for i in median_lengthscales.argsort()[:10]:\n",
    "    print(f\"Parameter {i:2}) Median lengthscale = {median_lengthscales[i].item():.2e}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "captumWidgetMessage": {},
  "dataExplorerConfig": {},
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.13"
  },
  "outputWidgetContext": {}
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
