{
 "metadata": {
  "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.8.5"
  },
  "outputWidgetContext": {}
 },
 "nbformat": 4,
 "nbformat_minor": 2,
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "originalKey": "00018e33-90ca-4f63-b741-fe1fd43ca7db",
    "showInput": false
   },
   "source": [
    "## Closed-loop batch, constrained BO in BoTorch with qEI and qNEI\n",
    "\n",
    "In this tutorial, we illustrate how to implement a simple Bayesian Optimization (BO) closed loop in BoTorch.\n",
    "\n",
    "In general, we recommend for a relatively simple setup (like this one) to use Ax, since this will simplify your setup (including the amount of code you need to write) considerably. See the [Using BoTorch with Ax](./custom_botorch_model_in_ax) tutorial.\n",
    "\n",
    "However, you may want to do things that are not easily supported in Ax at this time (like running high-dimensional BO using a VAE+GP model that you jointly train on high-dimensional input data). If you find yourself in such a situation, you will need to write your own optimization loop, as we do in this tutorial.\n",
    "\n",
    "\n",
    "We use the batch Expected Improvement (qEI) and batch Noisy Expected Improvement (qNEI) acquisition functions to optimize a constrained version of the synthetic Hartmann6 test function. The standard problem is\n",
    "\n",
    "$$f(x) = -\\sum_{i=1}^4 \\alpha_i \\exp \\left( -\\sum_{j=1}^6 A_{ij} (x_j - P_{ij})^2  \\right)$$\n",
    "\n",
    "over $x \\in [0,1]^6$ (parameter values can be found in `botorch/test_functions/hartmann6.py`).\n",
    "\n",
    "In real BO applications, the design $x$ can influence multiple metrics in unknown ways, and the decision-maker often wants to optimize one metric without sacrificing another. To illustrate this, we add a synthetic constraint of the form $\\|x\\|_1 - 3 \\le 0$. Both the objective and the constraint are observed with noise. \n",
    "\n",
    "Since botorch assumes a maximization problem, we will attempt to maximize $-f(x)$ to achieve $\\max_{x} -f(x) = 3.32237$."
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "originalKey": "2c0bfbc7-7e42-4601-83ed-4a77270803a8",
    "collapsed": false,
    "requestMsgId": "18ccce84-9f39-4c3d-89b1-1e9ed2540859",
    "customOutput": null,
    "executionStartTime": 1668649987115,
    "executionStopTime": 1668649987899
   },
   "source": [
    "import os\n",
    "import torch\n",
    "\n",
    "device = torch.device(\"cuda:3\" if torch.cuda.is_available() else \"cpu\")\n",
    "dtype = torch.double\n",
    "SMOKE_TEST = os.environ.get(\"SMOKE_TEST\")"
   ],
   "execution_count": 1,
   "outputs": [
    {
     "output_type": "stream",
     "name": "stderr",
     "text": [
      "I1116 175307.080 _utils_internal.py:179] NCCL_DEBUG env var is set to None\n"
     ]
    },
    {
     "output_type": "stream",
     "name": "stderr",
     "text": [
      "I1116 175307.081 _utils_internal.py:188] NCCL_DEBUG is INFO from /etc/nccl.conf\n"
     ]
    }
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "originalKey": "4ba4e568-0ef2-430e-aecb-dae8889d6664",
    "showInput": false
   },
   "source": [
    "### Problem setup\n",
    "\n",
    "First, we define the constraint used in the example in `outcome_constraint`. The second function `weighted_obj` is a \"feasibility-weighted objective,\" which returns zero when not feasible. "
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "originalKey": "b1c9de4d-a7ba-4782-ab68-2def8b562f7b",
    "collapsed": false,
    "requestMsgId": "96673081-cc25-4ca0-a40d-48756fde8647",
    "customOutput": null,
    "executionStartTime": 1668649988205,
    "executionStopTime": 1668649988602
   },
   "source": [
    "from botorch.test_functions import Hartmann\n",
    "\n",
    "\n",
    "neg_hartmann6 = Hartmann(negate=True)\n",
    "\n",
    "\n",
    "def outcome_constraint(X):\n",
    "    \"\"\"L1 constraint; feasible if less than or equal to zero.\"\"\"\n",
    "    return X.sum(dim=-1) - 3\n",
    "\n",
    "\n",
    "def weighted_obj(X):\n",
    "    \"\"\"Feasibility weighted objective; zero if not feasible.\"\"\"\n",
    "    return neg_hartmann6(X) * (outcome_constraint(X) <= 0).type_as(X)"
   ],
   "execution_count": 2,
   "outputs": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "originalKey": "c262e98f-924d-414e-889f-7e65a37d3689",
    "showInput": false
   },
   "source": [
    "#### Model initialization\n",
    "\n",
    "We use a `MultiOutputGP` to model the objective (output 0) and the constraint (output 1). We assume known homoskedastic observation noise on both the objective and constraint with standard error $\\sigma = 0.5$. \n",
    "\n",
    "Each component is a `FixedNoiseGP`. The models are initialized with 10 points drawn randomly from $[0,1]^6$."
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "originalKey": "41db1652-96c8-468d-9913-20a8e78f6fd6",
    "collapsed": false,
    "requestMsgId": "f83596cc-c30d-43ca-b9a1-fa3f5ad6b4ad",
    "customOutput": null,
    "executionStartTime": 1668649988934,
    "executionStopTime": 1668649992556
   },
   "source": [
    "from botorch.models import FixedNoiseGP, ModelListGP\n",
    "from gpytorch.mlls.sum_marginal_log_likelihood import SumMarginalLogLikelihood\n",
    "\n",
    "NOISE_SE = 0.5\n",
    "train_yvar = torch.tensor(NOISE_SE**2, device=device, dtype=dtype)\n",
    "\n",
    "\n",
    "def generate_initial_data(n=10):\n",
    "    # generate training data\n",
    "    train_x = torch.rand(10, 6, device=device, dtype=dtype)\n",
    "    exact_obj = neg_hartmann6(train_x).unsqueeze(-1)  # add output dimension\n",
    "    exact_con = outcome_constraint(train_x).unsqueeze(-1)  # add output dimension\n",
    "    train_obj = exact_obj + NOISE_SE * torch.randn_like(exact_obj)\n",
    "    train_con = exact_con + NOISE_SE * torch.randn_like(exact_con)\n",
    "    best_observed_value = weighted_obj(train_x).max().item()\n",
    "    return train_x, train_obj, train_con, best_observed_value\n",
    "\n",
    "\n",
    "def initialize_model(train_x, train_obj, train_con, state_dict=None):\n",
    "    # define models for objective and constraint\n",
    "    model_obj = FixedNoiseGP(train_x, train_obj, train_yvar.expand_as(train_obj)).to(\n",
    "        train_x\n",
    "    )\n",
    "    model_con = FixedNoiseGP(train_x, train_con, train_yvar.expand_as(train_con)).to(\n",
    "        train_x\n",
    "    )\n",
    "    # combine into a multi-output GP model\n",
    "    model = ModelListGP(model_obj, model_con)\n",
    "    mll = SumMarginalLogLikelihood(model.likelihood, model)\n",
    "    # load state dict if it is passed\n",
    "    if state_dict is not None:\n",
    "        model.load_state_dict(state_dict)\n",
    "    return mll, model"
   ],
   "execution_count": 3,
   "outputs": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "originalKey": "c34aa925-9abd-4bf2-9f1f-a4795be57b3b",
    "showInput": false
   },
   "source": [
    "#### Define a construct to extract the objective and constraint from the GP\n",
    "The methods below take the outputs of the GP and return the objective and the constraint. In general, these can be any `Callable`, but here we simply need to index the correct output."
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "originalKey": "6af5d96a-1b65-4551-bf7d-b125f9749c63",
    "collapsed": false,
    "requestMsgId": "ba2d1a49-04d4-4b3e-85ef-f40a51ed3945",
    "customOutput": null,
    "executionStartTime": 1668649992926,
    "executionStopTime": 1668649993022
   },
   "source": [
    "from botorch.acquisition.objective import ConstrainedMCObjective\n",
    "\n",
    "\n",
    "def obj_callable(Z):\n",
    "    return Z[..., 0]\n",
    "\n",
    "\n",
    "def constraint_callable(Z):\n",
    "    return Z[..., 1]\n",
    "\n",
    "\n",
    "# define a feasibility-weighted objective for optimization\n",
    "constrained_obj = ConstrainedMCObjective(\n",
    "    objective=obj_callable,\n",
    "    constraints=[constraint_callable],\n",
    ")"
   ],
   "execution_count": 4,
   "outputs": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "originalKey": "e45f8a78-36e4-4692-9ce3-7e883f7780cb",
    "showInput": false
   },
   "source": [
    "#### Define a helper function that performs the essential BO step\n",
    "The helper function below takes an acquisition function as an argument, optimizes it, and returns the batch $\\{x_1, x_2, \\ldots x_q\\}$ along with the observed function values. For this example, we'll use a small batch of $q=3$. The function `optimize_acqf` optimizes the $q$ points jointly. A simple initialization heuristic is used to select the 10 restart initial locations from a set of 50 random points. "
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "originalKey": "f450c171-6984-4114-bf99-99c3a4e68eb2",
    "collapsed": false,
    "requestMsgId": "57d29886-0a14-410b-aaba-596c8559f5a0",
    "customOutput": null,
    "executionStartTime": 1668649993442,
    "executionStopTime": 1668649993515
   },
   "source": [
    "from botorch.optim import optimize_acqf\n",
    "\n",
    "\n",
    "bounds = torch.tensor([[0.0] * 6, [1.0] * 6], device=device, dtype=dtype)\n",
    "\n",
    "BATCH_SIZE = 3 if not SMOKE_TEST else 2\n",
    "NUM_RESTARTS = 10 if not SMOKE_TEST else 2\n",
    "RAW_SAMPLES = 512 if not SMOKE_TEST else 32\n",
    "\n",
    "\n",
    "def optimize_acqf_and_get_observation(acq_func):\n",
    "    \"\"\"Optimizes the acquisition function, and returns a new candidate and a noisy observation.\"\"\"\n",
    "    # optimize\n",
    "    candidates, _ = optimize_acqf(\n",
    "        acq_function=acq_func,\n",
    "        bounds=bounds,\n",
    "        q=BATCH_SIZE,\n",
    "        num_restarts=NUM_RESTARTS,\n",
    "        raw_samples=RAW_SAMPLES,  # used for intialization heuristic\n",
    "        options={\"batch_limit\": 5, \"maxiter\": 200},\n",
    "    )\n",
    "    # observe new values\n",
    "    new_x = candidates.detach()\n",
    "    exact_obj = neg_hartmann6(new_x).unsqueeze(-1)  # add output dimension\n",
    "    exact_con = outcome_constraint(new_x).unsqueeze(-1)  # add output dimension\n",
    "    new_obj = exact_obj + NOISE_SE * torch.randn_like(exact_obj)\n",
    "    new_con = exact_con + NOISE_SE * torch.randn_like(exact_con)\n",
    "    return new_x, new_obj, new_con\n",
    "\n",
    "\n",
    "def update_random_observations(best_random):\n",
    "    \"\"\"Simulates a random policy by taking a the current list of best values observed randomly,\n",
    "    drawing a new random point, observing its value, and updating the list.\n",
    "    \"\"\"\n",
    "    rand_x = torch.rand(BATCH_SIZE, 6)\n",
    "    next_random_best = weighted_obj(rand_x).max().item()\n",
    "    best_random.append(max(best_random[-1], next_random_best))\n",
    "    return best_random"
   ],
   "execution_count": 5,
   "outputs": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "originalKey": "b9344aeb-149e-46a5-9c17-dfbd9ae4727c",
    "showInput": false
   },
   "source": [
    "### Perform Bayesian Optimization loop with qNEI\n",
    "The Bayesian optimization \"loop\" for a batch size of $q$ simply iterates the following steps:\n",
    "1. given a surrogate model, choose a batch of points $\\{x_1, x_2, \\ldots x_q\\}$\n",
    "2. observe $f(x)$ for each $x$ in the batch \n",
    "3. update the surrogate model. \n",
    "\n",
    "\n",
    "Just for illustration purposes, we run three trials each of which do `N_BATCH=20` rounds of optimization. The acquisition function is approximated using `MC_SAMPLES=256` samples.\n",
    "\n",
    "*Note*: Running this may take a little while."
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "originalKey": "f137bf2a-5d39-4c8c-bb24-84326d4ab5d7",
    "collapsed": false,
    "requestMsgId": "0b4d1d37-a9cf-4f69-a896-0836506ee521",
    "customOutput": null,
    "executionStartTime": 1668649993811,
    "executionStopTime": 1668650936026
   },
   "source": [
    "from botorch import fit_gpytorch_mll\n",
    "from botorch.acquisition.monte_carlo import (\n",
    "    qExpectedImprovement,\n",
    "    qNoisyExpectedImprovement,\n",
    ")\n",
    "from botorch.sampling.normal import SobolQMCNormalSampler\n",
    "from botorch.exceptions import BadInitialCandidatesWarning\n",
    "\n",
    "import time\n",
    "import warnings\n",
    "\n",
    "\n",
    "warnings.filterwarnings(\"ignore\", category=BadInitialCandidatesWarning)\n",
    "warnings.filterwarnings(\"ignore\", category=RuntimeWarning)\n",
    "\n",
    "\n",
    "N_TRIALS = 3 if not SMOKE_TEST else 2\n",
    "N_BATCH = 20 if not SMOKE_TEST else 2\n",
    "MC_SAMPLES = 256 if not SMOKE_TEST else 32\n",
    "\n",
    "verbose = False\n",
    "\n",
    "best_observed_all_ei, best_observed_all_nei, best_random_all = [], [], []\n",
    "\n",
    "\n",
    "# average over multiple trials\n",
    "for trial in range(1, N_TRIALS + 1):\n",
    "\n",
    "    print(f\"\\nTrial {trial:>2} of {N_TRIALS} \", end=\"\")\n",
    "    best_observed_ei, best_observed_nei, best_random = [], [], []\n",
    "\n",
    "    # call helper functions to generate initial training data and initialize model\n",
    "    (\n",
    "        train_x_ei,\n",
    "        train_obj_ei,\n",
    "        train_con_ei,\n",
    "        best_observed_value_ei,\n",
    "    ) = generate_initial_data(n=10)\n",
    "    mll_ei, model_ei = initialize_model(train_x_ei, train_obj_ei, train_con_ei)\n",
    "\n",
    "    train_x_nei, train_obj_nei, train_con_nei = train_x_ei, train_obj_ei, train_con_ei\n",
    "    best_observed_value_nei = best_observed_value_ei\n",
    "    mll_nei, model_nei = initialize_model(train_x_nei, train_obj_nei, train_con_nei)\n",
    "\n",
    "    best_observed_ei.append(best_observed_value_ei)\n",
    "    best_observed_nei.append(best_observed_value_nei)\n",
    "    best_random.append(best_observed_value_ei)\n",
    "\n",
    "    # run N_BATCH rounds of BayesOpt after the initial random batch\n",
    "    for iteration in range(1, N_BATCH + 1):\n",
    "\n",
    "        t0 = time.monotonic()\n",
    "\n",
    "        # fit the models\n",
    "        fit_gpytorch_mll(mll_ei)\n",
    "        fit_gpytorch_mll(mll_nei)\n",
    "\n",
    "        # define the qEI and qNEI acquisition modules using a QMC sampler\n",
    "        qmc_sampler = SobolQMCNormalSampler(sample_shape=torch.Size([MC_SAMPLES]))\n",
    "\n",
    "        # for best_f, we use the best observed noisy values as an approximation\n",
    "        qEI = qExpectedImprovement(\n",
    "            model=model_ei,\n",
    "            best_f=(train_obj_ei * (train_con_ei <= 0).to(train_obj_ei)).max(),\n",
    "            sampler=qmc_sampler,\n",
    "            objective=constrained_obj,\n",
    "        )\n",
    "\n",
    "        qNEI = qNoisyExpectedImprovement(\n",
    "            model=model_nei,\n",
    "            X_baseline=train_x_nei,\n",
    "            sampler=qmc_sampler,\n",
    "            objective=constrained_obj,\n",
    "        )\n",
    "\n",
    "        # optimize and get new observation\n",
    "        new_x_ei, new_obj_ei, new_con_ei = optimize_acqf_and_get_observation(qEI)\n",
    "        new_x_nei, new_obj_nei, new_con_nei = optimize_acqf_and_get_observation(qNEI)\n",
    "\n",
    "        # update training points\n",
    "        train_x_ei = torch.cat([train_x_ei, new_x_ei])\n",
    "        train_obj_ei = torch.cat([train_obj_ei, new_obj_ei])\n",
    "        train_con_ei = torch.cat([train_con_ei, new_con_ei])\n",
    "\n",
    "        train_x_nei = torch.cat([train_x_nei, new_x_nei])\n",
    "        train_obj_nei = torch.cat([train_obj_nei, new_obj_nei])\n",
    "        train_con_nei = torch.cat([train_con_nei, new_con_nei])\n",
    "\n",
    "        # update progress\n",
    "        best_random = update_random_observations(best_random)\n",
    "        best_value_ei = weighted_obj(train_x_ei).max().item()\n",
    "        best_value_nei = weighted_obj(train_x_nei).max().item()\n",
    "        best_observed_ei.append(best_value_ei)\n",
    "        best_observed_nei.append(best_value_nei)\n",
    "\n",
    "        # reinitialize the models so they are ready for fitting on next iteration\n",
    "        # use the current state dict to speed up fitting\n",
    "        mll_ei, model_ei = initialize_model(\n",
    "            train_x_ei,\n",
    "            train_obj_ei,\n",
    "            train_con_ei,\n",
    "            model_ei.state_dict(),\n",
    "        )\n",
    "        mll_nei, model_nei = initialize_model(\n",
    "            train_x_nei,\n",
    "            train_obj_nei,\n",
    "            train_con_nei,\n",
    "            model_nei.state_dict(),\n",
    "        )\n",
    "\n",
    "        t1 = time.monotonic()\n",
    "\n",
    "        if verbose:\n",
    "            print(\n",
    "                f\"\\nBatch {iteration:>2}: best_value (random, qEI, qNEI) = \"\n",
    "                f\"({max(best_random):>4.2f}, {best_value_ei:>4.2f}, {best_value_nei:>4.2f}), \"\n",
    "                f\"time = {t1-t0:>4.2f}.\",\n",
    "                end=\"\",\n",
    "            )\n",
    "        else:\n",
    "            print(\".\", end=\"\")\n",
    "\n",
    "    best_observed_all_ei.append(best_observed_ei)\n",
    "    best_observed_all_nei.append(best_observed_nei)\n",
    "    best_random_all.append(best_random)"
   ],
   "execution_count": 6,
   "outputs": [
    {
     "output_type": "stream",
     "name": "stdout",
     "text": [
      "\nTrial  1 of 3 ",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".\nTrial  2 of 3 ",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".\nTrial  3 of 3 ",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      ".",
      "."
     ]
    }
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "originalKey": "587be90e-69f5-4b33-ad40-1aafe38d305c",
    "showInput": false
   },
   "source": [
    "#### Plot the results\n",
    "The plot below shows the best objective value observed at each step of the optimization for each of the algorithms. The confidence intervals represent the variance at that step in the optimization across the trial runs. The variance across optimization runs is quite high, so in order to get a better estimate of the average performance one would have to run a much larger number of trials `N_TRIALS` (we avoid this here to limit the runtime of this tutorial). "
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "originalKey": "8729310f-7438-4d16-a2d5-5c46e5ef1c03",
    "collapsed": false,
    "requestMsgId": "3e10cd44-d4fa-4efc-941c-07dabdd6689c",
    "customOutput": null,
    "executionStartTime": 1668650936442,
    "executionStopTime": 1668650937028
   },
   "source": [
    "import numpy as np\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "%matplotlib inline\n",
    "\n",
    "\n",
    "def ci(y):\n",
    "    return 1.96 * y.std(axis=0) / np.sqrt(N_TRIALS)\n",
    "\n",
    "\n",
    "GLOBAL_MAXIMUM = neg_hartmann6.optimal_value\n",
    "\n",
    "\n",
    "iters = np.arange(N_BATCH + 1) * BATCH_SIZE\n",
    "y_ei = np.asarray(best_observed_all_ei)\n",
    "y_nei = np.asarray(best_observed_all_nei)\n",
    "y_rnd = np.asarray(best_random_all)\n",
    "\n",
    "fig, ax = plt.subplots(1, 1, figsize=(8, 6))\n",
    "ax.errorbar(iters, y_rnd.mean(axis=0), yerr=ci(y_rnd), label=\"random\", linewidth=1.5)\n",
    "ax.errorbar(iters, y_ei.mean(axis=0), yerr=ci(y_ei), label=\"qEI\", linewidth=1.5)\n",
    "ax.errorbar(iters, y_nei.mean(axis=0), yerr=ci(y_nei), label=\"qNEI\", linewidth=1.5)\n",
    "plt.plot(\n",
    "    [0, N_BATCH * BATCH_SIZE],\n",
    "    [GLOBAL_MAXIMUM] * 2,\n",
    "    \"k\",\n",
    "    label=\"true best objective\",\n",
    "    linewidth=2,\n",
    ")\n",
    "ax.set_ylim(bottom=0.5)\n",
    "ax.set(\n",
    "    xlabel=\"number of observations (beyond initial points)\",\n",
    "    ylabel=\"best objective value\",\n",
    ")\n",
    "ax.legend(loc=\"lower right\")"
   ],
   "execution_count": 7,
   "outputs": [
    {
     "output_type": "execute_result",
     "data": {
      "text/plain": "<matplotlib.legend.Legend at 0x7fa8e9094310>"
     },
     "metadata": {
      "bento_obj_id": "140363440931600"
     },
     "execution_count": 7
    },
    {
     "output_type": "display_data",
     "data": {
      "text/plain": "<Figure size 576x432 with 1 Axes>",
      "image/png": "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\n"
     },
     "metadata": {
      "bento_obj_id": "140363440931792",
      "needs_background": "light"
     }
    }
   ]
  }
 ]
}
