{
 "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.7.11"
  },
  "outputWidgetContext": {}
 },
 "nbformat": 4,
 "nbformat_minor": 2,
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "originalKey": "20bce0d3-6ea0-4db3-bc3b-2569027a0e3b",
    "showInput": false
   },
   "source": [
    "## Constrained, Parallel, Multi-Objective BO in BoTorch with qNEHVI, and qParEGO\n",
    "\n",
    "In this tutorial, we illustrate how to implement a constrained multi-objective (MO) Bayesian Optimization (BO) closed loop in BoTorch.\n",
    "\n",
    "In general, we recommend using [Ax](https://ax.dev) for a simple BO setup like this one, since this will simplify your setup (including the amount of code you need to write) considerably. See [here](https://ax.dev/tutorials/multiobjective_optimization.html) for an Ax tutorial on MOBO. If desired, you can use a custom BoTorch model in Ax, following the [Using BoTorch with Ax](./custom_botorch_model_in_ax) tutorial. Given a `MultiObjective`, Ax will default to the $q$NEHVI acquisiton function. If desired, this can also be customized by adding `\"botorch_acqf_class\": <desired_botorch_acquisition_function_class>,` to the `model_kwargs`.\n",
    "\n",
    "We use the parallel ParEGO ($q$ParEGO) [1] and parallel Noisy Expected Hypervolume Improvement ($q$NEHVI) [2]  acquisition functions to optimize a synthetic C2-DTLZ2 test function with $M=2$ objectives, $V=1$ constraint, and $d=4$ parameters. The two objectives are\n",
    "$$f_1(\\mathbf x) = (1+ g(\\mathbf x_M))\\cos\\big(\\frac{\\pi}{2}x_1\\big)$$\n",
    "$$f_2(\\mathbf x) = (1+ g(\\mathbf x_M))\\sin\\big(\\frac{\\pi}{2}x_1\\big)$$\n",
    "where $g(\\mathbf x) = \\sum_{x_i \\in \\mathbf x_M} (x_i - 0.5)^2, \\mathbf x \\in [0,1]^d,$ and $\\mathbf x_M$ represents the last $d - M +1$ elements of $\\mathbf x$. Additionally, the C2-DTLZ2 problem uses the following constraint:\n",
    "\n",
    "$$c(\\mathbf x) = - \\min \\bigg[\\min_{i=1}^M\\bigg((f_i(\\mathbf x) -1 )^2 + \\sum_{j=1, j=i}^M (f_j^2 - r^2) \\bigg), \\bigg(\\sum_{i=1}^M \\big((f_i(\\mathbf x) - \\frac{1}{\\sqrt{M}})^2 - r^2\\big)\\bigg)\\bigg]\\geq 0$$\n",
    "\n",
    "where $\\mathbf x \\in [0,1]^d$ and $r=0.2$. \n",
    "\n",
    "The goal here is to *minimize* both objectives. Since BoTorch assumes maximization, we maximize the negative of each objective. Since there typically is no single best solution in multi-objective optimization problems, we seek to find the pareto frontier, the set of optimal trade-offs where improving one metric means deteriorating another.\n",
    "\n",
    "[1] [S. Daulton, M. Balandat, and E. Bakshy. Differentiable Expected Hypervolume Improvement for Parallel Multi-Objective Bayesian Optimization. Advances in Neural Information Processing Systems 33, 2020.](https://arxiv.org/abs/2006.05078)\n",
    "\n",
    "[2] [S. Daulton, M. Balandat, and E. Bakshy. Parallel Bayesian Optimization of Multiple Noisy Objectives with Expected Hypervolume Improvement. Advances in Neural Information Processing Systems 34, 2021.](https://arxiv.org/abs/2105.08195)\n",
    "\n",
    "**For batch optimization (or in noisy settings), we strongly recommend using $q$NEHVI rather than $q$EHVI [1] because it is far more efficient than $q$EHVI and mathematically equivalent in the noiseless setting.**"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "originalKey": "00d9f0ef-fab6-463e-a54d-a548581bc7f4",
    "showInput": false
   },
   "source": [
    "### Set dtype and device\n",
    "Note: $q$EHVI aggressively exploits parallel hardware and is much faster when run on a GPU. See [1] for details."
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "executionStartTime": 1668651350300,
    "executionStopTime": 1668651350308,
    "originalKey": "f27224aa-b567-4a6d-b6b3-74f2ecbfe319",
    "requestMsgId": "df1b7814-2d71-4421-b832-e10d0c1e7743",
    "collapsed": false,
    "customOutput": null
   },
   "source": [
    "import os\n",
    "import torch\n",
    "\n",
    "\n",
    "tkwargs = {\n",
    "    \"dtype\": torch.double,\n",
    "    \"device\": torch.device(\"cuda:3\" if torch.cuda.is_available() else \"cpu\"),\n",
    "}\n",
    "SMOKE_TEST = os.environ.get(\"SMOKE_TEST\")"
   ],
   "execution_count": 1,
   "outputs": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "originalKey": "89f8b99f-5cb2-45c9-9df6-7e1d18d4f8c6",
    "showInput": false
   },
   "source": [
    "### Problem setup\n",
    ""
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "executionStartTime": 1668651350608,
    "executionStopTime": 1668651354486,
    "originalKey": "4227f250-60b5-4c97-b04c-3cfe7a1c410a",
    "requestMsgId": "83e67907-72c3-4bb8-8468-7eb99e616730",
    "collapsed": false,
    "customOutput": null
   },
   "source": [
    "from botorch.test_functions.multi_objective import C2DTLZ2\n",
    "\n",
    "\n",
    "d = 4\n",
    "M = 2\n",
    "problem = C2DTLZ2(dim=d, num_objectives=M, negate=True).to(**tkwargs)"
   ],
   "execution_count": 2,
   "outputs": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "hidden_ranges": [],
    "originalKey": "2de9fbab-9d15-4410-8371-d3b1f730e3d7",
    "showInput": false
   },
   "source": [
    "#### Model initialization\n",
    "\n",
    "We use a multi-output `SingleTaskGP` to model the two objectives with a homoskedastic Gaussian likelihood with an inferred noise level.\n",
    "\n",
    "The models are initialized with $2(d+1)=10$ points drawn randomly from $[0,1]^{4}$."
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "code_folding": [],
    "executionStartTime": 1668651354720,
    "executionStopTime": 1668651354729,
    "hidden_ranges": [],
    "originalKey": "192b8d87-b2e3-4223-b193-6399b8643391",
    "requestMsgId": "55d97599-5be9-4a7a-857c-18a9b56bf07d",
    "collapsed": false,
    "customOutput": null
   },
   "source": [
    "from botorch.models.gp_regression import SingleTaskGP\n",
    "from botorch.models.model_list_gp_regression import ModelListGP\n",
    "from botorch.models.transforms.outcome import Standardize\n",
    "from botorch.utils.sampling import draw_sobol_samples\n",
    "from botorch.utils.transforms import normalize, unnormalize\n",
    "from gpytorch.mlls.sum_marginal_log_likelihood import SumMarginalLogLikelihood\n",
    "\n",
    "\n",
    "def generate_initial_data(n):\n",
    "    # generate training data\n",
    "    train_x = draw_sobol_samples(bounds=problem.bounds, n=n, q=1).squeeze(1)\n",
    "    train_obj = problem(train_x)\n",
    "    # negative values imply feasibility in botorch\n",
    "    train_con = -problem.evaluate_slack(train_x)\n",
    "    return train_x, train_obj, train_con\n",
    "\n",
    "\n",
    "def initialize_model(train_x, train_obj, train_con):\n",
    "    # define models for objective and constraint\n",
    "    train_x = normalize(train_x, problem.bounds)\n",
    "    train_y = torch.cat([train_obj, train_con], dim=-1)\n",
    "    models = []\n",
    "    for i in range(train_y.shape[-1]):\n",
    "        models.append(\n",
    "            SingleTaskGP(\n",
    "                train_x, train_y[..., i : i + 1], outcome_transform=Standardize(m=1)\n",
    "            )\n",
    "        )\n",
    "    model = ModelListGP(*models)\n",
    "    mll = SumMarginalLogLikelihood(model.likelihood, model)\n",
    "    return mll, model"
   ],
   "execution_count": 3,
   "outputs": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "hidden_ranges": [],
    "originalKey": "a0f6fa02-0843-4c45-8a19-8654226c1edc",
    "showInput": false
   },
   "source": [
    "#### Define a helper function that performs the essential BO step for $q$NEHVI\n",
    "The helper function below initializes the $q$NEHVI acquisition function, optimizes it, and returns the batch $\\{x_1, x_2, \\ldots x_q\\}$ along with the observed function values. \n",
    "\n",
    "For this example, we'll use a small batch of $q=2$. Passing the keyword argument `sequential=True` to the function `optimize_acqf`specifies that candidates should be optimized in a sequential greedy fashion (see [1] for details why this is important). A simple initialization heuristic is used to select the 10 restart initial locations from a set of 512 random points. Multi-start optimization of the acquisition function is performed using LBFGS-B with exact gradients computed via auto-differentiation.\n",
    "\n",
    "**Reference Point**\n",
    "\n",
    "$q$NEHVI requires specifying a reference point, which is the lower bound on the objectives used for computing hypervolume. In this tutorial, we assume the reference point is known. In practice the reference point can be set 1) using domain knowledge to be slightly worse than the lower bound of objective values, where the lower bound is the minimum acceptable value of interest for each objective, or 2) using a dynamic reference point selection strategy.\n",
    "\n",
    "**Integrating over function values at in-sample designs**\n",
    "\n",
    "$q$NEHVI integrates over the unknown function values at the previously evaluated designs (see [2] for details). Therefore, we need to provide the previously evaluated designs (`train_x`, *normalized* to be within $[0,1]^d$) to the acquisition function.\n",
    "\n",
    "**Pruning baseline designs**\n",
    "To speed up integration over the function values at the previously evaluated designs, we prune the set of previously evaluated designs (by setting `prune_baseline=True`) to only include those which have positive probability of being on the current in-sample Pareto frontier."
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "code_folding": [],
    "executionStartTime": 1668651354970,
    "executionStopTime": 1668651355060,
    "hidden_ranges": [],
    "originalKey": "65dcfbb2-f1e9-40a1-9807-8cdc1cc3fdc8",
    "requestMsgId": "68a072df-7e90-4c7f-9915-520ca48c5e0a",
    "collapsed": false,
    "customOutput": null
   },
   "source": [
    "from botorch.acquisition.multi_objective.monte_carlo import (\n",
    "    qNoisyExpectedHypervolumeImprovement,\n",
    ")\n",
    "from botorch.acquisition.multi_objective.objective import IdentityMCMultiOutputObjective\n",
    "from botorch.optim.optimize import optimize_acqf, optimize_acqf_list\n",
    "from botorch.utils.multi_objective.scalarization import get_chebyshev_scalarization\n",
    "from botorch.utils.sampling import sample_simplex\n",
    "\n",
    "\n",
    "BATCH_SIZE = 2\n",
    "NUM_RESTARTS = 10 if not SMOKE_TEST else 2\n",
    "RAW_SAMPLES = 512 if not SMOKE_TEST else 4\n",
    "\n",
    "standard_bounds = torch.zeros(2, problem.dim, **tkwargs)\n",
    "standard_bounds[1] = 1\n",
    "\n",
    "\n",
    "def optimize_qnehvi_and_get_observation(model, train_x, train_obj, train_con, sampler):\n",
    "    \"\"\"Optimizes the qNEHVI acquisition function, and returns a new candidate and observation.\"\"\"\n",
    "    train_x = normalize(train_x, problem.bounds)\n",
    "    acq_func = qNoisyExpectedHypervolumeImprovement(\n",
    "        model=model,\n",
    "        ref_point=problem.ref_point.tolist(),  # use known reference point\n",
    "        X_baseline=train_x,\n",
    "        sampler=sampler,\n",
    "        prune_baseline=True,\n",
    "        # define an objective that specifies which outcomes are the objectives\n",
    "        objective=IdentityMCMultiOutputObjective(outcomes=[0, 1]),\n",
    "        # specify that the constraint is on the last outcome\n",
    "        constraints=[lambda Z: Z[..., -1]],\n",
    "    )\n",
    "    # optimize\n",
    "    candidates, _ = optimize_acqf(\n",
    "        acq_function=acq_func,\n",
    "        bounds=standard_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",
    "        sequential=True,\n",
    "    )\n",
    "    # observe new values\n",
    "    new_x = unnormalize(candidates.detach(), bounds=problem.bounds)\n",
    "    new_obj = problem(new_x)\n",
    "    # negative values imply feasibility in botorch\n",
    "    new_con = -problem.evaluate_slack(new_x)\n",
    "    return new_x, new_obj, new_con"
   ],
   "execution_count": 4,
   "outputs": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "originalKey": "9b4277b1-fc2a-467f-ae21-cb30d6823bd9",
    "showInput": false
   },
   "source": [
    "#### Define a helper function for creating constrained objectives for $q$ParEGO\n",
    "The helper function below initializes a ConstrainedMCObjective for $q$ParEGO. It creates the `objective` which fetches the outcomes required for the scalarized objective and applies the scalarization and the constraints, which are modeled outcomes.\n",
    ""
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "executionStartTime": 1668651355275,
    "executionStopTime": 1668651355359,
    "originalKey": "daf2cfd6-47f7-467c-a4d2-e1837a0249b5",
    "requestMsgId": "49a9283d-99a5-4e03-b3ba-a352a321d4ef",
    "collapsed": false,
    "customOutput": null
   },
   "source": [
    "from botorch.acquisition.objective import ConstrainedMCObjective\n",
    "\n",
    "\n",
    "def get_constrained_mc_objective(train_obj, train_con, scalarization):\n",
    "    \"\"\"Initialize a ConstrainedMCObjective for qParEGO\"\"\"\n",
    "    n_obj = train_obj.shape[-1]\n",
    "    # assume first outcomes of the model are the objectives, the rest constraints\n",
    "    def objective(Z):\n",
    "        return scalarization(Z[..., :n_obj])\n",
    "\n",
    "    constrained_obj = ConstrainedMCObjective(\n",
    "        objective=objective,\n",
    "        constraints=[lambda Z: Z[..., -1]],  # index the constraint\n",
    "    )\n",
    "    return constrained_obj"
   ],
   "execution_count": 5,
   "outputs": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "originalKey": "ae9e19c2-327f-486e-bee3-11f1b71b0dfe",
    "showInput": false
   },
   "source": [
    "#### Define a helper function that performs the essential BO step for $q$ParEGO\n",
    "The helper function below similarly initializes $q$ParEGO, optimizes it, and returns the batch $\\{x_1, x_2, \\ldots x_q\\}$ along with the observed function values. \n",
    "\n",
    "$q$ParEGO uses random augmented chebyshev scalarization with the `qExpectedImprovement` acquisition function. In the parallel setting ($q>1$), each candidate is optimized in sequential greedy fashion using a different random scalarization (see [1] for details).\n",
    "\n",
    "To do this, we create a list of `qExpectedImprovement` acquisition functions, each with different random scalarization weights. The `optimize_acqf_list` method sequentially generates one candidate per acquisition function and conditions the next candidate (and acquisition function) on the previously selected pending candidates."
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "code_folding": [],
    "executionStartTime": 1668651355591,
    "executionStopTime": 1668651355682,
    "hidden_ranges": [],
    "originalKey": "a4a23da4-64de-4948-ad92-76b57c023f62",
    "requestMsgId": "f38f70dd-4857-484f-963c-cdfec7d8fc67",
    "collapsed": false,
    "customOutput": null
   },
   "source": [
    "from botorch.acquisition.monte_carlo import qExpectedImprovement\n",
    "\n",
    "\n",
    "def optimize_qparego_and_get_observation(model, train_obj, train_con, sampler):\n",
    "    \"\"\"Samples a set of random weights for each candidate in the batch, performs sequential greedy optimization\n",
    "    of the qParEGO acquisition function, and returns a new candidate and observation.\"\"\"\n",
    "    acq_func_list = []\n",
    "    for _ in range(BATCH_SIZE):\n",
    "        # sample random weights\n",
    "        weights = sample_simplex(problem.num_objectives, **tkwargs).squeeze()\n",
    "        # construct augmented Chebyshev scalarization\n",
    "        scalarization = get_chebyshev_scalarization(weights=weights, Y=train_obj)\n",
    "        # initialize ConstrainedMCObjective\n",
    "        constrained_objective = get_constrained_mc_objective(\n",
    "            train_obj=train_obj,\n",
    "            train_con=train_con,\n",
    "            scalarization=scalarization,\n",
    "        )\n",
    "        train_y = torch.cat([train_obj, train_con], dim=-1)\n",
    "        acq_func = qExpectedImprovement(  # pyre-ignore: [28]\n",
    "            model=model,\n",
    "            objective=constrained_objective,\n",
    "            best_f=constrained_objective(train_y).max(),\n",
    "            sampler=sampler,\n",
    "        )\n",
    "        acq_func_list.append(acq_func)\n",
    "    # optimize\n",
    "    candidates, _ = optimize_acqf_list(\n",
    "        acq_function_list=acq_func_list,\n",
    "        bounds=standard_bounds,\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 = unnormalize(candidates.detach(), bounds=problem.bounds)\n",
    "    new_obj = problem(new_x)\n",
    "    # negative values imply feasibility in botorch\n",
    "    new_con = -problem.evaluate_slack(new_x)\n",
    "    return new_x, new_obj, new_con"
   ],
   "execution_count": 6,
   "outputs": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "originalKey": "d4487ba0-4fad-41dd-a2ae-e0b95094dba1",
    "showInput": false
   },
   "source": [
    "### Perform Bayesian Optimization loop with $q$EHVI and $q$ParEGO\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 one trial with `N_BATCH=20` rounds of optimization. The acquisition function is approximated using `MC_SAMPLES=128` samples.\n",
    "\n",
    "*Note*: Running this may take a little while."
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "code_folding": [],
    "executionStartTime": 1668651356028,
    "executionStopTime": 1668651959470,
    "hidden_ranges": [],
    "originalKey": "4c225d99-6425-4201-ac4a-a042a351c1d3",
    "requestMsgId": "be831f3c-ff7c-4c00-a215-fb021f0c5770",
    "collapsed": false,
    "customOutput": null
   },
   "source": [
    "import time\n",
    "import warnings\n",
    "\n",
    "from botorch import fit_gpytorch_mll\n",
    "from botorch.exceptions import BadInitialCandidatesWarning\n",
    "from botorch.sampling.normal import SobolQMCNormalSampler\n",
    "from botorch.utils.multi_objective.hypervolume import Hypervolume\n",
    "from botorch.utils.multi_objective.pareto import is_non_dominated\n",
    "\n",
    "\n",
    "warnings.filterwarnings(\"ignore\", category=BadInitialCandidatesWarning)\n",
    "warnings.filterwarnings(\"ignore\", category=RuntimeWarning)\n",
    "\n",
    "N_BATCH = 20 if not SMOKE_TEST else 5\n",
    "MC_SAMPLES = 128 if not SMOKE_TEST else 16\n",
    "verbose = True\n",
    "\n",
    "hv = Hypervolume(ref_point=problem.ref_point)\n",
    "hvs_qparego, hvs_qnehvi, hvs_random = [], [], []\n",
    "\n",
    "# call helper functions to generate initial training data and initialize model\n",
    "train_x_qparego, train_obj_qparego, train_con_qparego = generate_initial_data(\n",
    "    n=2 * (d + 1)\n",
    ")\n",
    "mll_qparego, model_qparego = initialize_model(\n",
    "    train_x_qparego, train_obj_qparego, train_con_qparego\n",
    ")\n",
    "\n",
    "train_x_qnehvi, train_obj_qnehvi, train_con_qnehvi = (\n",
    "    train_x_qparego,\n",
    "    train_obj_qparego,\n",
    "    train_con_qparego,\n",
    ")\n",
    "train_x_random, train_obj_random, train_con_random = (\n",
    "    train_x_qparego,\n",
    "    train_obj_qparego,\n",
    "    train_con_qparego,\n",
    ")\n",
    "\n",
    "mll_qnehvi, model_qnehvi = initialize_model(\n",
    "    train_x_qnehvi, train_obj_qnehvi, train_con_qnehvi\n",
    ")\n",
    "\n",
    "# compute pareto front\n",
    "is_feas = (train_con_qparego <= 0).all(dim=-1)\n",
    "feas_train_obj = train_obj_qparego[is_feas]\n",
    "if feas_train_obj.shape[0] > 0:\n",
    "    pareto_mask = is_non_dominated(feas_train_obj)\n",
    "    pareto_y = feas_train_obj[pareto_mask]\n",
    "    # compute hypervolume\n",
    "    volume = hv.compute(pareto_y)\n",
    "else:\n",
    "    volume = 0.0\n",
    "\n",
    "hvs_qparego.append(volume)\n",
    "hvs_qnehvi.append(volume)\n",
    "hvs_random.append(volume)\n",
    "\n",
    "# run N_BATCH rounds of BayesOpt after the initial random batch\n",
    "for iteration in range(1, N_BATCH + 1):\n",
    "    t0 = time.monotonic()\n",
    "\n",
    "    # fit the models\n",
    "    fit_gpytorch_mll(mll_qparego)\n",
    "    fit_gpytorch_mll(mll_qnehvi)\n",
    "\n",
    "    # define the qParEGO and qNEHVI acquisition modules using a QMC sampler\n",
    "    qparego_sampler = SobolQMCNormalSampler(sample_shape=torch.Size([MC_SAMPLES]))\n",
    "    qnehvi_sampler = SobolQMCNormalSampler(sample_shape=torch.Size([MC_SAMPLES]))\n",
    "\n",
    "    # optimize acquisition functions and get new observations\n",
    "    (\n",
    "        new_x_qparego,\n",
    "        new_obj_qparego,\n",
    "        new_con_qparego,\n",
    "    ) = optimize_qparego_and_get_observation(\n",
    "        model_qparego, train_obj_qparego, train_con_qparego, qparego_sampler\n",
    "    )\n",
    "    new_x_qnehvi, new_obj_qnehvi, new_con_qnehvi = optimize_qnehvi_and_get_observation(\n",
    "        model_qnehvi, train_x_qnehvi, train_obj_qnehvi, train_con_qnehvi, qnehvi_sampler\n",
    "    )\n",
    "    new_x_random, new_obj_random, new_con_random = generate_initial_data(n=BATCH_SIZE)\n",
    "\n",
    "    # update training points\n",
    "    train_x_qparego = torch.cat([train_x_qparego, new_x_qparego])\n",
    "    train_obj_qparego = torch.cat([train_obj_qparego, new_obj_qparego])\n",
    "    train_con_qparego = torch.cat([train_con_qparego, new_con_qparego])\n",
    "\n",
    "    train_x_qnehvi = torch.cat([train_x_qnehvi, new_x_qnehvi])\n",
    "    train_obj_qnehvi = torch.cat([train_obj_qnehvi, new_obj_qnehvi])\n",
    "    train_con_qnehvi = torch.cat([train_con_qnehvi, new_con_qnehvi])\n",
    "\n",
    "    train_x_random = torch.cat([train_x_random, new_x_random])\n",
    "    train_obj_random = torch.cat([train_obj_random, new_obj_random])\n",
    "    train_con_random = torch.cat([train_con_random, new_con_random])\n",
    "\n",
    "    # update progress\n",
    "    for hvs_list, train_obj, train_con in zip(\n",
    "        (hvs_random, hvs_qparego, hvs_qnehvi),\n",
    "        (train_obj_random, train_obj_qparego, train_obj_qnehvi),\n",
    "        (train_con_random, train_con_qparego, train_con_qnehvi),\n",
    "    ):\n",
    "        # compute pareto front\n",
    "        is_feas = (train_con <= 0).all(dim=-1)\n",
    "        feas_train_obj = train_obj[is_feas]\n",
    "        if feas_train_obj.shape[0] > 0:\n",
    "            pareto_mask = is_non_dominated(feas_train_obj)\n",
    "            pareto_y = feas_train_obj[pareto_mask]\n",
    "            # compute feasible hypervolume\n",
    "            volume = hv.compute(pareto_y)\n",
    "        else:\n",
    "            volume = 0.0\n",
    "        hvs_list.append(volume)\n",
    "\n",
    "    # reinitialize the models so they are ready for fitting on next iteration\n",
    "    # Note: we find improved performance from not warm starting the model hyperparameters\n",
    "    # using the hyperparameters from the previous iteration\n",
    "    mll_qparego, model_qparego = initialize_model(\n",
    "        train_x_qparego, train_obj_qparego, train_con_qparego\n",
    "    )\n",
    "    mll_qnehvi, model_qnehvi = initialize_model(\n",
    "        train_x_qnehvi, train_obj_qnehvi, train_con_qnehvi\n",
    "    )\n",
    "\n",
    "    t1 = time.monotonic()\n",
    "\n",
    "    if verbose:\n",
    "        print(\n",
    "            f\"\\nBatch {iteration:>2}: Hypervolume (random, qParEGO, qNEHVI) = \"\n",
    "            f\"({hvs_random[-1]:>4.2f}, {hvs_qparego[-1]:>4.2f}, {hvs_qnehvi[-1]:>4.2f}), \"\n",
    "            f\"time = {t1-t0:>4.2f}.\",\n",
    "            end=\"\",\n",
    "        )\n",
    "    else:\n",
    "        print(\".\", end=\"\")"
   ],
   "execution_count": 7,
   "outputs": [
    {
     "output_type": "stream",
     "name": "stdout",
     "text": [
      "\nBatch  1: Hypervolume (random, qParEGO, qNEHVI) = (0.11, 0.16, 0.12), time = 26.54.",
      "\nBatch  2: Hypervolume (random, qParEGO, qNEHVI) = (0.11, 0.17, 0.12), time = 22.82.",
      "\nBatch  3: Hypervolume (random, qParEGO, qNEHVI) = (0.14, 0.17, 0.12), time = 31.00.",
      "\nBatch  4: Hypervolume (random, qParEGO, qNEHVI) = (0.14, 0.19, 0.20), time = 37.75.",
      "\nBatch  5: Hypervolume (random, qParEGO, qNEHVI) = (0.14, 0.19, 0.23), time = 24.39.",
      "\nBatch  6: Hypervolume (random, qParEGO, qNEHVI) = (0.14, 0.19, 0.24), time = 17.80.",
      "\nBatch  7: Hypervolume (random, qParEGO, qNEHVI) = (0.14, 0.20, 0.29), time = 36.37.",
      "\nBatch  8: Hypervolume (random, qParEGO, qNEHVI) = (0.14, 0.22, 0.30), time = 19.08.",
      "\nBatch  9: Hypervolume (random, qParEGO, qNEHVI) = (0.14, 0.22, 0.31), time = 22.62.",
      "\nBatch 10: Hypervolume (random, qParEGO, qNEHVI) = (0.16, 0.28, 0.31), time = 36.75.",
      "\nBatch 11: Hypervolume (random, qParEGO, qNEHVI) = (0.16, 0.28, 0.33), time = 33.04.",
      "\nBatch 12: Hypervolume (random, qParEGO, qNEHVI) = (0.16, 0.30, 0.33), time = 35.87.",
      "\nBatch 13: Hypervolume (random, qParEGO, qNEHVI) = (0.17, 0.31, 0.35), time = 27.45.",
      "\nBatch 14: Hypervolume (random, qParEGO, qNEHVI) = (0.17, 0.33, 0.37), time = 43.02.",
      "\nBatch 15: Hypervolume (random, qParEGO, qNEHVI) = (0.17, 0.34, 0.37), time = 42.38.",
      "\nBatch 16: Hypervolume (random, qParEGO, qNEHVI) = (0.17, 0.34, 0.37), time = 24.79.",
      "\nBatch 17: Hypervolume (random, qParEGO, qNEHVI) = (0.17, 0.34, 0.38), time = 21.14.",
      "\nBatch 18: Hypervolume (random, qParEGO, qNEHVI) = (0.20, 0.34, 0.38), time = 22.72.",
      "\nBatch 19: Hypervolume (random, qParEGO, qNEHVI) = (0.20, 0.35, 0.38), time = 35.07.",
      "\nBatch 20: Hypervolume (random, qParEGO, qNEHVI) = (0.20, 0.35, 0.38), time = 41.90."
     ]
    }
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "originalKey": "3132af99-128f-41fc-9e6c-d1eaf6083f81",
    "showInput": false
   },
   "source": [
    "#### Plot the results\n",
    "The plot below shows the log feasible hypervolume difference: the log difference between the hypervolume of the true feasible pareto front and the hypervolume of the observed (feasible) pareto front identified by each algorithm. The log feasible hypervolume difference is plotted at each step of the optimization for each of the algorithms.\n",
    "\n",
    "The plot show that $q$NEHVI vastly outperforms the $q$ParEGO and Sobol baselines."
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "code_folding": [],
    "executionStartTime": 1668651959825,
    "executionStopTime": 1668651960985,
    "hidden_ranges": [],
    "originalKey": "38f5ce01-264f-43bd-8bdb-edf756f7c0dc",
    "requestMsgId": "ec2a65b4-0cdb-4487-b6f4-da16df97ce18",
    "collapsed": false,
    "customOutput": null
   },
   "source": [
    "import numpy as np\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "\n",
    "%matplotlib inline\n",
    "\n",
    "\n",
    "iters = np.arange(N_BATCH + 1) * BATCH_SIZE\n",
    "log_hv_difference_qparego = np.log10(problem.max_hv - np.asarray(hvs_qparego))\n",
    "log_hv_difference_qnehvi = np.log10(problem.max_hv - np.asarray(hvs_qnehvi))\n",
    "log_hv_difference_rnd = np.log10(problem.max_hv - np.asarray(hvs_random))\n",
    "\n",
    "fig, ax = plt.subplots(1, 1, figsize=(8, 6))\n",
    "ax.plot(\n",
    "    iters,\n",
    "    log_hv_difference_rnd,\n",
    "    label=\"Sobol\",\n",
    "    linewidth=1.5,\n",
    "    color=\"gray\",\n",
    ")\n",
    "ax.plot(\n",
    "    iters,\n",
    "    log_hv_difference_qparego,\n",
    "    label=\"qParEGO\",\n",
    "    linewidth=1.5,\n",
    "    color=\"red\",\n",
    ")\n",
    "ax.plot(\n",
    "    iters,\n",
    "    log_hv_difference_qnehvi,\n",
    "    label=\"qNEHVI\",\n",
    "    linewidth=1.5,\n",
    "    color=\"blue\",\n",
    ")\n",
    "ax.set(\n",
    "    xlabel=\"number of observations (beyond initial points)\",\n",
    "    ylabel=\"Log Hypervolume Difference\",\n",
    ")\n",
    "ax.legend(loc=\"lower right\")"
   ],
   "execution_count": 8,
   "outputs": [
    {
     "output_type": "execute_result",
     "data": {
      "text/plain": "<matplotlib.legend.Legend at 0x7fbeb2a12d90>"
     },
     "metadata": {
      "bento_obj_id": "140457017421200"
     },
     "execution_count": 8
    },
    {
     "output_type": "display_data",
     "data": {
      "text/plain": "<Figure size 576x432 with 1 Axes>",
      "image/png": "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5ctDf/n52wyDFi0y5w2EmqLGgKIoipK1BAJQUBD669gxFNfg559Df+vWwZo1IUOgefNtxsG9f53M/PkLadGiORUVFbRu1YprR15BYWFBwuutXLWaS/5wJb179dzu+PhxY2jRvDmffPYFTz71LAClpaUcfNABnDfsTHJzcwF44cVXePPf/6Fp0yYEAgHOPvN0Djxgv1q3gxoDiqIoiiLk54cWGrZtGwqHvGlTyDAIew4Aft4A7tBhDD7iQAoKYNozz/LCi68w7KzTqy27srISgM6dOjHpjlt3SF+5ajUPPvwYE269kXZt21JSsoUJd97LdPs2zhDDjJmz+OzzL/nLpAk0bdqUtevWc93Ym2hT1Joe3YtrJbcaA4qiKIoSg5wcyMvfwv0PTeTXX39l3336Yd96m149+rJuPcyeHTIeilr15vMv36WyEqY8NpXZ382lvLycE5xjcYYYJt49mbzcXDZu3MRll1wQ93qvvPYG7u9OoF3btgDk5eVx4w2jycsLddXPv/gK144cQVMJx9i2TRG/P83lVX86V1x+aa1kVWNAURRFyQyuugq++CJhttxgMPnVfwMGwL33xk1+6+2Z9OxRzCUXns+MmbOYMTNAy1ahVxSLi0Megw8//oS2bXrx+efl7FLYmnvvup2ysjLOu+gPOEMMENqGeOSVl7Ny1eq411q6dBmHDTxou2NhQwBg1erVdOncabv0nj2688abbyUnazWoMaAoiqIocVjyw4/077cvAP3771t1/Iknp9GixUtUVlayR+/enH7KsaxYkceSHzZx+ZU3UFCQu11kwz322BacaOmyZYwaM67qe5fOnbhqxHAqKiqqphJWrFzFnXdPprKykubNm3PL+BvYWr51h0iIlZU7RkasCWoMKIqiKJlBNSP4SCrKy8ipxZ7+kUTG7wlWbvv/wvOHccjBB26Xd8kPX/Pj0m/533NuoWXLHK65/qyqtPyIEX68NQPFxV2ZN38h++7Th44dduOO28azbv0Gbr5tYui8zruzaPESevXsXnXOwkWLKe7WtdZyNvKXJRRFURSl5nTt0pm5c+cD8NkXX1abd/PmX+japR09euTxwYcfUFERZP1P5UlfyxliePnV11m2fEXVsQ8++oSmTUOGzUknHs9DjzxOSWkpAGvXredfL7zEiccPqaF021DPgKIoiqLE4egjBzP+lglcdc31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\n"
     },
     "metadata": {
      "bento_obj_id": "140457030284336",
      "needs_background": "light"
     }
    }
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "collapsed": true,
    "hidden_ranges": [],
    "originalKey": "a926c260-dcc2-4ce9-9c53-7b75456c6c0c",
    "showInput": false
   },
   "source": [
    "#### Plot the observations colored by iteration\n",
    "\n",
    "To examine optimization process from another perspective, we plot the collected observations under each algorithm where the color corresponds to the BO iteration at which the point was collected. The plot on the right for $q$NEHVI shows that the $q$NEHVI quickly identifies the pareto front and most of its evaluations are very close to the pareto front. $q$ParEGO also identifies has many observations close to the pareto front, but relies on optimizing random scalarizations, which is a less principled way of optimizing the pareto front compared to $q$NEHVI, which explicitly attempts focuses on improving the pareto front. Sobol generates random points and has few points close to the pareto front"
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "executionStartTime": 1668651961290,
    "executionStopTime": 1668651961935,
    "originalKey": "75cb7f30-5ed2-4a02-bf46-b5c660af6494",
    "requestMsgId": "fa568aad-a7cb-43e7-b7ec-eff622a5edc9",
    "collapsed": false,
    "customOutput": null
   },
   "source": [
    "from matplotlib.cm import ScalarMappable\n",
    "\n",
    "\n",
    "fig, axes = plt.subplots(1, 3, figsize=(17, 5))\n",
    "algos = [\"Sobol\", \"qParEGO\", \"qNEHVI\"]\n",
    "cm = plt.cm.get_cmap(\"viridis\")\n",
    "\n",
    "batch_number = torch.cat(\n",
    "    [\n",
    "        torch.zeros(2 * (d + 1)),\n",
    "        torch.arange(1, N_BATCH + 1).repeat(BATCH_SIZE, 1).t().reshape(-1),\n",
    "    ]\n",
    ").numpy()\n",
    "\n",
    "for i, train_obj in enumerate((train_obj_random, train_obj_qparego, train_obj_qnehvi)):\n",
    "    sc = axes[i].scatter(\n",
    "        train_obj[:, 0].cpu().numpy(),\n",
    "        train_obj[:, 1].cpu().numpy(),\n",
    "        c=batch_number,\n",
    "        alpha=0.8,\n",
    "    )\n",
    "    axes[i].set_title(algos[i])\n",
    "    axes[i].set_xlabel(\"Objective 1\")\n",
    "    axes[i].set_xlim(-2.5, 0)\n",
    "    axes[i].set_ylim(-2.5, 0)\n",
    "axes[0].set_ylabel(\"Objective 2\")\n",
    "norm = plt.Normalize(batch_number.min(), batch_number.max())\n",
    "sm = ScalarMappable(norm=norm, cmap=cm)\n",
    "sm.set_array([])\n",
    "fig.subplots_adjust(right=0.9)\n",
    "cbar_ax = fig.add_axes([0.93, 0.15, 0.01, 0.7])\n",
    "cbar = fig.colorbar(sm, cax=cbar_ax)\n",
    "cbar.ax.set_title(\"Iteration\")"
   ],
   "execution_count": 9,
   "outputs": [
    {
     "output_type": "execute_result",
     "data": {
      "text/plain": "Text(0.5, 1.0, 'Iteration')"
     },
     "metadata": {
      "bento_obj_id": "140457009854256"
     },
     "execution_count": 9
    },
    {
     "output_type": "display_data",
     "data": {
      "text/plain": "<Figure size 1224x360 with 4 Axes>",
      "image/png": "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\n"
     },
     "metadata": {
      "bento_obj_id": "140457010573712",
      "needs_background": "light"
     }
    }
   ]
  }
 ]
}
