{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "collapsed": true
   },
   "source": [
    "## Application of batch-mode regression to cross-validation\n",
    "\n",
    "botorch provides a helper function `gen_loo_cv_folds` to easily perform leave-one-out (LOO) cross-validation (CV) by taking advantage of batch-mode regression and evaluation in GPyTorch. This tutorial illustrates the process on a noisy sinusoidal function, similar to the example from the batch-mode GP regression [tutorial](https://github.com/cornellius-gp/gpytorch/blob/master/examples/01_Simple_GP_Regression/Simple_Batch_Mode_GP_Regression.ipynb) from GPyTorch:\n",
    "\n",
    "$$y = \\sin(2\\pi x) + \\epsilon, ~\\epsilon \\sim \\mathcal N(0, 0.2).$$\n",
    "\n",
    "Note: this tutorial aims to introduce batch-mode regression and evaluation in GPyTorch with CV as an example application. For alternative, more user-friendly functions to perform CV in Ax, see [ax.modelbridge.cross_validation](https://github.com/facebook/Ax/blob/main/ax/modelbridge/cross_validation.py). However, for larger CV tasks, it may be useful to exploit GPyTorch batch-mode, as shown in this tutorial."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "import math\n",
    "\n",
    "device = torch.device(\"cpu\")\n",
    "dtype = torch.float\n",
    "torch.manual_seed(3);"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Initialize the CV dataset\n",
    "\n",
    "For our training data, we take 20 regularly spaced points on the interval $[0, 1]$ and generate noisy evaluations with an observed noise variance of 0.2. Remember that botorch requires an explicit output dimension."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "sigma = math.sqrt(0.2)\n",
    "train_X = torch.linspace(0, 1, 20, dtype=dtype, device=device).view(-1, 1)\n",
    "train_Y_noiseless = torch.sin(train_X * (2 * math.pi))\n",
    "train_Y = train_Y_noiseless + sigma * torch.randn_like(train_Y_noiseless)\n",
    "train_Yvar = torch.full_like(train_Y, 0.2)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The botorch function `gen_loo_cv_folds` takes our observed data `train_X`, `train_Y`, `train_Yvar` as input and returns the LOO CV folds in a `CVFolds` object."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "from botorch.cross_validation import gen_loo_cv_folds\n",
    "\n",
    "cv_folds = gen_loo_cv_folds(train_X=train_X, train_Y=train_Y, train_Yvar=train_Yvar)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The `cv_folds` object contains the data, stored as tensors of appropriate batch shape, necessary to perform 20 CVs of 19 training points and 1 test point. For example, we can check that the shapes of the training inputs and training targets are `b x n x d = 20 x 19 x 1` and `b x n x o = 20 x 19 x 1` respectively, where `o` is the number of outputs."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(torch.Size([20, 20, 1]), torch.Size([20, 20, 1]))"
      ]
     },
     "execution_count": 4,
     "metadata": {
      "bento_obj_id": "140675275377288"
     },
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cv_folds.train_X.shape, cv_folds.train_Y.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(torch.Size([20, 1, 1]), torch.Size([20, 1, 1]))"
      ]
     },
     "execution_count": 5,
     "metadata": {
      "bento_obj_id": "140676807470216"
     },
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cv_folds.test_X.shape, cv_folds.test_Y.shape"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Note that in a situation where the dataset is large, one may not want to perform LOO; in that case, a similar process can be used to perform $k$-fold CV."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Perform LOOCV\n",
    "\n",
    "We can use the `batch_cross_validation` function to perform LOOCV using batching (meaning that the `b = 20` sets of training data can be fit as `b = 20` separate GP models with separate hyperparameters in parallel through GPyTorch) and return a CVResult tuple with the batched `GPyTorchPosterior` object over the LOOCV test points and the observed targets. The `batch_cross_validation` requires a model class (`model_cls`) and a marginal log likelihood class (`mll_cls`). Since we have an observed and constant noise level, we will use the FixedNoiseGP as the `model_cls` and an ExactMarginalLogLikelihood as the `mll_cls`."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "from botorch.cross_validation import batch_cross_validation\n",
    "from botorch.models import FixedNoiseGP\n",
    "from gpytorch.mlls.exact_marginal_log_likelihood import ExactMarginalLogLikelihood\n",
    "\n",
    "# instantiate and fit model\n",
    "cv_results = batch_cross_validation(\n",
    "    model_cls=FixedNoiseGP,\n",
    "    mll_cls=ExactMarginalLogLikelihood,\n",
    "    cv_folds=cv_folds,\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Compute the cross-validation error and generate plots\n",
    "To compute the cross-validation error, we first evaluate the test points by computing the posterior in batch mode. Next, we compute the squared errors for each test point from the prediction and take an average across all cross-validation folds."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cross-validation error:  0.062\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "bento_obj_id": "140674656098008"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib import pyplot as plt\n",
    "\n",
    "%matplotlib inline\n",
    "\n",
    "posterior = cv_results.posterior\n",
    "mean = posterior.mean\n",
    "cv_error = ((cv_folds.test_Y.squeeze() - mean.squeeze()) ** 2).mean()\n",
    "print(f\"Cross-validation error: {cv_error : 4.2}\")\n",
    "\n",
    "# get lower and upper confidence bounds\n",
    "lower, upper = posterior.mvn.confidence_region()\n",
    "\n",
    "# scatterplot of predicted versus test\n",
    "_, axes = plt.subplots(1, 1, figsize=(6, 4))\n",
    "plt.plot([-1.5, 1.5], [-1.5, 1.5], \"k\", label=\"true objective\", linewidth=2)\n",
    "\n",
    "axes.set_xlabel(\"Actual\")\n",
    "axes.set_ylabel(\"Predicted\")\n",
    "\n",
    "axes.errorbar(\n",
    "    x=cv_folds.test_Y.numpy().flatten(),\n",
    "    y=mean.numpy().flatten(),\n",
    "    xerr=1.96 * sigma,\n",
    "    yerr=((upper - lower) / 2).numpy().flatten(),\n",
    "    fmt=\"*\",\n",
    ");"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Finally, we can visualize the fitted models. To do this, we again take advantage of batch-mode evaluation to obtain predictions, including lower and upper confidence regions, from each of the 20 models."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "model = cv_results.model\n",
    "with torch.no_grad():\n",
    "    # evaluate the models at a series of points for plotting\n",
    "    plot_x = (\n",
    "        torch.linspace(0, 1, 101).view(1, -1, 1).repeat(cv_folds.train_X.shape[0], 1, 1)\n",
    "    )\n",
    "    posterior = model.posterior(plot_x)\n",
    "    mean = posterior.mean\n",
    "\n",
    "    # get lower and upper confidence bounds\n",
    "    lower, upper = posterior.mvn.confidence_region()\n",
    "    plot_x.squeeze_()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The code snippet below plots the result for the 12th CV fold (by setting `num = 12`), but note that we have computed the results for all folds above (other plots can be obtained by iterating `num` from 1 to 20)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "bento_obj_id": "140674628290824"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "_, axes = plt.subplots(1, 1, figsize=(6, 4))\n",
    "\n",
    "# plot the 12th CV fold\n",
    "num = 12\n",
    "\n",
    "# plot the training data in black\n",
    "axes.plot(\n",
    "    cv_folds.train_X[num - 1].detach().numpy(),\n",
    "    cv_folds.train_Y[num - 1].detach().numpy(),\n",
    "    \"k*\",\n",
    ")\n",
    "\n",
    "# plot the test data in red\n",
    "axes.plot(\n",
    "    cv_folds.test_X[num - 1].detach().numpy(),\n",
    "    cv_folds.test_Y[num - 1].detach().numpy(),\n",
    "    \"r*\",\n",
    ")\n",
    "\n",
    "# plot posterior means as blue line\n",
    "axes.plot(plot_x[num - 1].numpy(), mean[num - 1].numpy(), \"b\")\n",
    "\n",
    "# shade between the lower and upper confidence bounds\n",
    "axes.fill_between(\n",
    "    plot_x[num - 1].numpy(), lower[num - 1].numpy(), upper[num - 1].numpy(), alpha=0.5\n",
    ");"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "python3",
   "language": "python",
   "name": "python3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
