{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "hidden_ranges": [],
    "originalKey": "c31f62e6-7593-4975-ac72-c8d1a59fe3b7",
    "showInput": false
   },
   "source": [
    "## Constraint Active Search for Multiobjective Experimental Design\n",
    "\n",
    "In this tutorial we show how to implement the Expected Coverage Improvement (ECI) [1] acquisition function in BoTorch. For a number of outcome constraints, ECI tries to efficiently discover the feasible region and simultaneously sample diverse feasible configurations. Given a user-specified punchout radius $r$, we center a sphere with that radius around each evaluated configuration. The total coverage is now given by the volume of the union of these sphere intersected with the feasible region; see the paper and, in particular, Figure 2 for a full description of how ECI works.\n",
    "\n",
    "By design, ECI prefers candidates that are in unexplored regions since the candidate's corresponding sphere won't intersect with the spheres around the previously evaluated configurations. On the other hand, ECI also prefers configurations that are likely to satisfy the constraints and to give an improvement in the total coverage. This results in an exploitation-exploration trade-off similar to other acquisition functions.\n",
    "\n",
    "ECI may be estimated using the following equation:\n",
    "$$\n",
    "\\text{ECI}(x) = \\sum_{x' \\in \\mathbb{N}(x) \\setminus \\mathbb{N}_{r}(X)} p(Z(x') = 1 \\;|\\; \\mathcal{D}_t).\n",
    "$$\n",
    "\n",
    "where $\\mathbb{N}(x) \\setminus \\mathbb{N}_{r}(X)$ a set of points generated via Monte Carlo to be inside a sphere of radius $r$ around $x$, but sufficiently far from the set of known evaluations $X$ (where sufficiently far is defined by the punchout radius $r$). The function $p(Z(x') = 1 \\;|\\; \\mathcal{D}_t)$ is the probability that the GP at $x'$ satisfies a user-specified threshold value, or threshold values in the case of multiple objective functions. \n",
    "\n",
    "[1]: [Malkomes et al., Beyond the Pareto Efficient Frontier: Constraint Active Search for Multiobjective Experimental Design, Proceedings of the 38th International Conference on Machine Learning, 2021](http://proceedings.mlr.press/v139/malkomes21a/malkomes21a.pdf)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "code_folding": [],
    "executionStartTime": 1638489228284,
    "executionStopTime": 1638489229640,
    "hidden_ranges": [],
    "originalKey": "9896cb02-0d0e-498f-bdf7-86ea14baaf40",
    "requestMsgId": "9896cb02-0d0e-498f-bdf7-86ea14baaf40"
   },
   "outputs": [],
   "source": [
    "import os\n",
    "\n",
    "import torch\n",
    "from botorch.acquisition.monte_carlo import MCAcquisitionFunction\n",
    "from botorch.acquisition.objective import IdentityMCObjective\n",
    "from botorch.fit import fit_gpytorch_mll\n",
    "from botorch.models import ModelListGP, SingleTaskGP\n",
    "from botorch.models.transforms.outcome import Standardize\n",
    "from botorch.optim import optimize_acqf\n",
    "from botorch.utils.sampling import sample_hypersphere\n",
    "from botorch.utils.transforms import t_batch_mode_transform\n",
    "from gpytorch.constraints import Interval\n",
    "from gpytorch.likelihoods import GaussianLikelihood\n",
    "from gpytorch.mlls import ExactMarginalLogLikelihood\n",
    "from torch.quasirandom import SobolEngine\n",
    "\n",
    "\n",
    "SMOKE_TEST = os.environ.get(\"SMOKE_TEST\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "code_folding": [],
    "executionStartTime": 1638489229684,
    "executionStopTime": 1638489230490,
    "hidden_ranges": [],
    "originalKey": "b4b78cb1-b0d4-4203-a97b-7a293ea418d4",
    "requestMsgId": "b4b78cb1-b0d4-4203-a97b-7a293ea418d4"
   },
   "outputs": [],
   "source": [
    "tkwargs = {\n",
    "    \"device\": torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\"),\n",
    "    \"dtype\": torch.double,\n",
    "}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "hidden_ranges": [],
    "originalKey": "e9cecfd7-f548-4b66-8009-c97809afc144",
    "showInput": false
   },
   "source": [
    "To start, we need to be able to sample points in $\\mathbb{N}(x) \\setminus \\mathbb{N}_{r}(X)$. We can generate a pool of points and use standard rejection sampling to do so, but this leads to an acquisition function that isn't immediately differentiable; rejection sampling is essentially providing either a binary weight of either 0 or 1 to each point in the sample pool, which is not a differentiable function. \n",
    "\n",
    "\n",
    "In order to make the acquisition function differentiable, we rely on a differentiable approximation of this binary weight function. For example, `smooth_box_mask` is a continuous differentiable approximation of $a < x < b$ (see the plot below for a visualization). A larger value of eps will make the sigmoid less steep and result in a smoother (and easier to optimize) but less accurate acquisition function. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "executionStartTime": 1638489230493,
    "executionStopTime": 1638489230509,
    "originalKey": "63c0a300-c3a1-49bb-a6ba-41cf9dfa9632",
    "requestMsgId": "63c0a300-c3a1-49bb-a6ba-41cf9dfa9632"
   },
   "outputs": [],
   "source": [
    "def smooth_mask(x, a, eps=2e-3):\n",
    "    \"\"\"Returns 0ish for x < a and 1ish for x > a\"\"\"\n",
    "    return torch.nn.Sigmoid()((x - a) / eps)\n",
    "\n",
    "\n",
    "def smooth_box_mask(x, a, b, eps=2e-3):\n",
    "    \"\"\"Returns 1ish for a < x < b and 0ish otherwise\"\"\"\n",
    "    return smooth_mask(x, a, eps) - smooth_mask(x, b, eps)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "code_folding": [],
    "executionStartTime": 1638489230587,
    "executionStopTime": 1638489233802,
    "hidden_ranges": [],
    "originalKey": "7b49f71b-f131-4600-96fd-5aa581212202",
    "requestMsgId": "7b49f71b-f131-4600-96fd-5aa581212202"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 800x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "%matplotlib inline\n",
    "\n",
    "\n",
    "x = torch.linspace(-2, 2, 500, **tkwargs)\n",
    "\n",
    "fig, ax = plt.subplots(1, 2, figsize=(8, 4))\n",
    "ax[0].plot(x.cpu(), smooth_mask(x, -1).cpu(), \"b\")\n",
    "ax[1].plot(x.cpu(), smooth_box_mask(x, -1, 1).cpu(), \"b\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "hidden_ranges": [],
    "originalKey": "7ff5ed82-355b-45b8-91f9-823c41c46efc",
    "showInput": false
   },
   "source": [
    "## Implementation of ECI\n",
    "\n",
    "Once we have defined our smooth mask functions, we can compute a differentiable approximation of ECI in a straightforward manner using Monte Carlo (MC). We use the popular variance reduction technique of Common random numbers (CRN).\n",
    "\n",
    "We first use a low discrepancy sequence to generate a set of base samples. We integrate (sum) over these base samples to approximate the ECI acquisition function. Fixing these base samples makes the method deterministic and by using the smooth masks defined earlier, we can filter out infeasible points while still having a differentiable acquisition function.\n",
    "\n",
    "This implementation assumes that the GP models for the different outputs are independent and that each constraints only affects one output (simple box-constraints like f(x) <= 0.5)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "code_folding": [],
    "executionStartTime": 1638489233910,
    "executionStopTime": 1638489233950,
    "hidden_ranges": [],
    "originalKey": "5dd0a6af-0bde-4e57-8bdd-d53baea75075",
    "requestMsgId": "5dd0a6af-0bde-4e57-8bdd-d53baea75075"
   },
   "outputs": [],
   "source": [
    "class ExpectedCoverageImprovement(MCAcquisitionFunction):\n",
    "    def __init__(\n",
    "        self,\n",
    "        model,\n",
    "        constraints,\n",
    "        punchout_radius,\n",
    "        bounds,\n",
    "        num_samples=128,\n",
    "        **kwargs,\n",
    "    ):\n",
    "        \"\"\"Expected Coverage Improvement (q=1 required, analytic)\n",
    "\n",
    "        Right now, we assume that all the models in the ModelListGP have\n",
    "        the same training inputs.\n",
    "\n",
    "        Args:\n",
    "            model: A ModelListGP object containing models matching the corresponding constraints.\n",
    "                All models are assumed to have the same training data.\n",
    "            constraints: List containing 2-tuples with (direction, value), e.g.,\n",
    "                [('gt', 3), ('lt', 4)]. It is necessary that\n",
    "                len(constraints) == model.num_outputs.\n",
    "            punchout_radius: Positive value defining the desired minimum distance between points\n",
    "            bounds: torch.tensor whose first row is the lower bounds and second row is the upper bounds\n",
    "            num_samples: Number of samples for MC integration\n",
    "        \"\"\"\n",
    "        super().__init__(model=model, objective=IdentityMCObjective(), **kwargs)\n",
    "        assert len(constraints) == model.num_outputs\n",
    "        assert all(direction in (\"gt\", \"lt\") for direction, _ in constraints)\n",
    "        assert punchout_radius > 0\n",
    "        self.constraints = constraints\n",
    "        self.punchout_radius = punchout_radius\n",
    "        self.bounds = bounds\n",
    "        self.base_points = self.train_inputs\n",
    "        self.ball_of_points = self._generate_ball_of_points(\n",
    "            num_samples=num_samples,\n",
    "            radius=punchout_radius,\n",
    "            device=bounds.device,\n",
    "            dtype=bounds.dtype,\n",
    "        )\n",
    "        self._thresholds = torch.tensor(\n",
    "            [threshold for _, threshold in self.constraints]\n",
    "        ).to(bounds)\n",
    "        assert (\n",
    "            all(ub > lb for lb, ub in self.bounds.T) and len(self.bounds.T) == self.dim\n",
    "        )\n",
    "\n",
    "    @property\n",
    "    def num_outputs(self):\n",
    "        return self.model.num_outputs\n",
    "\n",
    "    @property\n",
    "    def dim(self):\n",
    "        return self.train_inputs.shape[-1]\n",
    "\n",
    "    @property\n",
    "    def train_inputs(self):\n",
    "        return self.model.models[0].train_inputs[0]\n",
    "\n",
    "    def _generate_ball_of_points(\n",
    "        self, num_samples, radius, device=None, dtype=torch.double\n",
    "    ):\n",
    "        \"\"\"Creates a ball of points to be used for MC.\"\"\"\n",
    "        tkwargs = {\"device\": device, \"dtype\": dtype}\n",
    "        z = sample_hypersphere(d=self.dim, n=num_samples, qmc=True, **tkwargs)\n",
    "        r = torch.rand(num_samples, 1, **tkwargs) ** (1 / self.dim)\n",
    "        return radius * r * z\n",
    "\n",
    "    def _get_base_point_mask(self, X):\n",
    "        distance_matrix = self.model.models[0].covar_module.base_kernel.covar_dist(\n",
    "            X, self.base_points\n",
    "        )\n",
    "        return smooth_mask(distance_matrix, self.punchout_radius)\n",
    "\n",
    "    def _estimate_probabilities_of_satisfaction_at_points(self, points):\n",
    "        \"\"\"Estimate the probability of satisfying the given constraints.\"\"\"\n",
    "        posterior = self.model.posterior(X=points)\n",
    "        mus, sigma2s = posterior.mean, posterior.variance\n",
    "        dist = torch.distributions.normal.Normal(mus, sigma2s.sqrt())\n",
    "        norm_cdf = dist.cdf(self._thresholds)\n",
    "        probs = torch.ones(points.shape[:-1]).to(points)\n",
    "        for i, (direction, _) in enumerate(self.constraints):\n",
    "            probs = probs * (\n",
    "                norm_cdf[..., i] if direction == \"lt\" else 1 - norm_cdf[..., i]\n",
    "            )\n",
    "        return probs\n",
    "\n",
    "    @t_batch_mode_transform(expected_q=1)\n",
    "    def forward(self, X):\n",
    "        \"\"\"Evaluate Expected Improvement on the candidate set X.\"\"\"\n",
    "        ball_around_X = self.ball_of_points + X\n",
    "        domain_mask = smooth_box_mask(\n",
    "            ball_around_X, self.bounds[0, :], self.bounds[1, :]\n",
    "        ).prod(dim=-1)\n",
    "        num_points_in_integral = domain_mask.sum(dim=-1)\n",
    "        base_point_mask = self._get_base_point_mask(ball_around_X).prod(dim=-1)\n",
    "        prob = self._estimate_probabilities_of_satisfaction_at_points(ball_around_X)\n",
    "        masked_prob = prob * domain_mask * base_point_mask\n",
    "        y = masked_prob.sum(dim=-1) / num_points_in_integral\n",
    "        return y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "code_folding": [],
    "executionStartTime": 1638489234035,
    "executionStopTime": 1638489234089,
    "hidden_ranges": [],
    "originalKey": "b56e4297-9927-4a5e-aa8f-f5e93181e44d",
    "requestMsgId": "b56e4297-9927-4a5e-aa8f-f5e93181e44d"
   },
   "outputs": [],
   "source": [
    "def get_and_fit_gp(X, Y):\n",
    "    \"\"\"Simple method for creating a GP with one output dimension.\n",
    "\n",
    "    X is assumed to be in [0, 1]^d.\n",
    "    \"\"\"\n",
    "    assert Y.ndim == 2 and Y.shape[-1] == 1\n",
    "    likelihood = GaussianLikelihood(noise_constraint=Interval(1e-6, 1e-3))  # Noise-free\n",
    "    octf = Standardize(m=1)\n",
    "    gp = SingleTaskGP(X, Y, likelihood=likelihood, outcome_transform=octf)\n",
    "    mll = ExactMarginalLogLikelihood(model=gp, likelihood=gp.likelihood)\n",
    "    fit_gpytorch_mll(mll)\n",
    "    return gp"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "hidden_ranges": [],
    "originalKey": "e7c7c1b3-249f-4e32-b8b7-3c7e737e82b2",
    "showInput": false
   },
   "source": [
    "### Simple 1D function\n",
    "\n",
    "To sanity check things, we consider the ECI acquisition function on a one-dimensional toy problem. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "executionStartTime": 1638489234145,
    "executionStopTime": 1638489234200,
    "originalKey": "cc435c3c-c65f-4446-a33e-fd5cda030962",
    "requestMsgId": "cc435c3c-c65f-4446-a33e-fd5cda030962"
   },
   "outputs": [],
   "source": [
    "def yf(x):\n",
    "    return (1 - torch.exp(-4 * (x[:, 0] - 0.4) ** 2)).unsqueeze(-1)\n",
    "\n",
    "\n",
    "x = torch.tensor([0, 0.15, 0.25, 0.4, 0.8, 1.0], **tkwargs).unsqueeze(-1)\n",
    "y = yf(x)\n",
    "xx = torch.linspace(0, 1, 200, **tkwargs).unsqueeze(-1)\n",
    "yy = yf(xx)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "originalKey": "8bbfe7b8-b758-424a-b6bc-f2c91f8b1e95",
    "showInput": false
   },
   "source": [
    "### Create an ECI acquisition function\n",
    "Our implementation assumes that the GP is passed in as a `ModelListGP` and that the GPs match the corresponding constraints. As an example, assume we have two outputs, represented by `gp1` and `gp2` and two constraints corresponding to output 1 and a third constraint corresponding to output 2. In that case we will create a model list GP as `ModelListGP(gp1, gp1, gp2)` so they match the constraints."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "code_folding": [],
    "executionStartTime": 1638489234253,
    "executionStopTime": 1638489235584,
    "hidden_ranges": [],
    "originalKey": "9efe991c-8256-4c7c-b61f-8abb5d258d40",
    "requestMsgId": "9efe991c-8256-4c7c-b61f-8abb5d258d40"
   },
   "outputs": [],
   "source": [
    "gp = get_and_fit_gp(x, y)\n",
    "model_list_gp = ModelListGP(gp, gp)\n",
    "constraints = [(\"lt\", 0.3), (\"gt\", 0.05)]\n",
    "punchout_radius = 0.03\n",
    "bounds = torch.tensor([(0, 1)], **tkwargs).T\n",
    "eci = ExpectedCoverageImprovement(\n",
    "    model=model_list_gp,\n",
    "    constraints=constraints,\n",
    "    punchout_radius=punchout_radius,\n",
    "    bounds=bounds,\n",
    "    num_samples=128 if not SMOKE_TEST else 4,\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "originalKey": "f1cfa2a0-db3f-49a2-b32f-6fad380b0c3e",
    "showInput": false
   },
   "source": [
    "### Optimize the acquisition function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "code_folding": [],
    "executionStartTime": 1638489235787,
    "executionStopTime": 1638489236864,
    "hidden_ranges": [],
    "originalKey": "1ae10691-8d4e-40e7-8c32-f15a35ddf590",
    "requestMsgId": "1ae10691-8d4e-40e7-8c32-f15a35ddf590",
    "showInput": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Best candidate: 0.617\n"
     ]
    }
   ],
   "source": [
    "best_candidate, best_eci_value = optimize_acqf(\n",
    "    acq_function=eci,\n",
    "    bounds=torch.tensor([[0.0], [1.0]], **tkwargs),\n",
    "    q=1,\n",
    "    num_restarts=10,\n",
    "    raw_samples=20,  # use a small number here to make sure the optimization works\n",
    ")\n",
    "print(f\"Best candidate: {best_candidate.cpu().item():.3f}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "originalKey": "15a4d7cf-be03-4e52-9792-e3a680f37bb7",
    "showInput": false
   },
   "source": [
    "### Plot the GP and the ECI acquisition function\n",
    "The left plot shows the GP posterior with a 95% confidence interval. The two horizontal lines indicate the feasible region defined by $0.05 \\leq f(x) \\leq 0.3$. These inequality constraints implicitly define a feasible region, outside which ECI has value zero. \n",
    "\n",
    "We can see in the right plot that ECI indeed has a nonzero value inside the feasible region and a zero value outside. We also optimize the acquisition function and mark its argmax with black star; the argmax is around $x=0.62$. This is reasonable because ECI seeks to select diverse points within the feasible region. $x=0.62$ is far away from other evaluations and thus has the highest diversity. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "code_folding": [],
    "executionStartTime": 1638489236964,
    "executionStopTime": 1638489237535,
    "hidden_ranges": [],
    "originalKey": "5f5b4b6a-4d53-4528-8420-53e4f9358f5c",
    "requestMsgId": "5f5b4b6a-4d53-4528-8420-53e4f9358f5c"
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA9UAAAHECAYAAAA3XwkIAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAACrP0lEQVR4nOzdeXxU9dU/8M8smZnsKwkBwuKOUqsGF7BYVyz6aCu1UqnyqFClWBVRq5TWClZRqwiioP6UUjdKXWo3HjV1A6WtgmhVcAVMCAkh60wms2Rm7u+PkzuTbZJZ7uyf9+s1LyYz9858o0lmzpzzPUenKIoCIiIiIiIiIgqbPtELICIiIiIiIkpVDKqJiIiIiIiIIsSgmoiIiIiIiChCDKqJiIiIiIiIIsSgmoiIiIiIiChCDKqJiIiIiIiIIsSgmoiIiIiIiChCDKqJiIiIiIiIIsSgmoiIiIiIiChCDKqJiIiIiIiIIsSgmoiIiIgoSe3duxc6nW7Iy3HHHTfgvPr6eixevBgnnHACioqKYDKZUFlZifPPPx/r16+H2+32H/vWW29Bp9Nh/vz5cfzOiNKHMdELICIiIiKioR166KG47LLLBr1v5MiRfb7esGED5s6dC4fDgerqalx22WUoLCxEY2Mj3njjDVx55ZV4+umn8frrr8dj6URpj0E1EREREVGSO+yww3DHHXcMe9wrr7yCyy67DEVFRfjLX/6Cc845p8/9iqLg5ZdfxhNPPBGjlRJlHgbVRERERERpwOv14tprr4XP58Of/vQnnHXWWQOO0el0uOiii3DeeeclYIVE6Yl7qomIiIiI0sCbb76J3bt3Y+rUqYMG1L2ZzeY4rYoo/TFTTURERESU5L766qug5d+nnHIKvve97+Hdd98FAJx55plxXBkRMagmIiIiIkpyX3/9NZYuXTrofTfccAO+973vobGxEQAwZsyYeC6NKOMxqCYiIiIiSnLnnnsuXnnllUQvg4gGwT3VRERERERpQB2tVV9fn+CVEGUWBtVERERERGng1FNPBQDOnyaKMwbVRERERERp4IwzzsAhhxyCrVu34s033xzyWJfLFadVEaU/BtVERERERGnAYDDgkUcegV6vxyWXXII33nhj0OP+9re/4eKLL47z6ojSFxuVEREREREluaFGagHw3/e9730PTz/9NObNm4ezzjoLkydPxpQpU5Cfn48DBw7grbfewtdff42zzz47PgsnygA6RVGURC+CiIiIiIgG2rt3LyZMmDDscf3f0tfX12P16tV47bXX8PXXX6OrqwulpaU4/vjjcckll+Cyyy5DVlYWAOCtt97CGWecgWuuuQaPPvpoTL4PonTGoJqIiIiIiIgoQtxTTURERERERBQhBtVEREREREREEWJQTURERERERBQhBtVEREREREREEYooqF6zZg0mTJgAi8WC6upqbNmyZcjjn332WXz7299GTk4OKisrceWVV6KlpSWiBRMREREREREli7CD6o0bN2LhwoVYsmQJduzYgWnTpmHGjBmora0d9Ph33nkHc+bMwdy5c/Hpp5/i+eefx/vvv4958+ZFvXgiIiIiIiKiRAp7pNbJJ5+ME044AWvXrvXfNnHiRPzgBz/A8uXLBxx///33Y+3atfj666/9t61evRr33Xcf6urqQnpOn8+H/fv3Iz8/HzqdLpzlEhERxYSiKLDZbBg1ahT0eu6mihZf64mIKNmE+lpvDOdB3W43tm/fjttuu63P7dOnT8fWrVsHPWfq1KlYsmQJNm3ahBkzZqCpqQkvvPACzj///KDP43K54HK5/F/X19fj6KOPDmepREREcVFXV4cxY8Ykehkpb//+/aiqqkr0MoiIiAYY7rU+rKC6ubkZXq8XFRUVfW6vqKhAY2PjoOdMnToVzz77LGbNmgWn0wmPx4MLL7wQq1evDvo8y5cvx9KlSwfcXldXh4KCgnCWTEREFBNWqxVVVVXIz89P9FLSgvrfka/1RESULEJ9rQ8rqFb1L8tSFCVoqdbOnTtx/fXX4/bbb8e5556LhoYG3HLLLZg/fz6efPLJQc9ZvHgxFi1a5P9a/WYKCgr4QktEREmFpcraUP878rWeiIiSzXCv9WEF1WVlZTAYDAOy0k1NTQOy16rly5fj1FNPxS233AIAOPbYY5Gbm4tp06bht7/9LSorKwecYzabYTabw1kaERERERERUdyF1VnFZDKhuroaNTU1fW6vqanB1KlTBz2nq6trwKZug8EAQDLcRERERERERKkq7HalixYtwhNPPIF169Zh165duPHGG1FbW4v58+cDkNLtOXPm+I+/4IIL8NJLL2Ht2rXYvXs33n33XVx//fU46aSTMGrUKO2+EyIiIiIiIqI4C3tP9axZs9DS0oJly5ahoaEB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\n",
      "text/plain": [
       "<Figure size 1200x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "with torch.no_grad():\n",
    "    posterior = gp.posterior(X=xx.unsqueeze(1))\n",
    "ymean, yvar = posterior.mean.squeeze(-1), posterior.variance.squeeze(-1)\n",
    "eci_vals = eci(xx.unsqueeze(1))\n",
    "\n",
    "fig, axes = plt.subplots(1, 2, figsize=(12, 5))\n",
    "ax = axes[0]\n",
    "ax.plot(xx[:, 0].cpu(), ymean[:, 0].cpu(), \"b\")\n",
    "ax.fill_between(\n",
    "    xx[:, 0].cpu(),\n",
    "    ymean[:, 0].cpu() - 1.96 * yvar[:, 0].sqrt().cpu(),\n",
    "    ymean[:, 0].cpu() + 1.96 * yvar[:, 0].sqrt().cpu(),\n",
    "    alpha=0.1,\n",
    "    color=\"b\",\n",
    ")\n",
    "ax.plot(x[:, 0].cpu(), y[:, 0].cpu(), \"or\")\n",
    "ax.axhline(0.05, 0, 1)\n",
    "ax.axhline(0.3, 0, 1)\n",
    "\n",
    "ax = axes[1]\n",
    "ax.plot(xx[:, 0].cpu(), eci_vals.detach().cpu())\n",
    "ax.plot(x[:, 0].cpu(), torch.zeros(len(x), **tkwargs).cpu(), \"or\")\n",
    "ax.plot(best_candidate.cpu(), best_eci_value.cpu(), \"*k\", ms=10)\n",
    "ax.set_title(\"ECI\", fontsize=14)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "hidden_ranges": [],
    "originalKey": "33ea647e-bdaf-4264-ab65-3e6df4ba8c6e",
    "showInput": false
   },
   "source": [
    "## Full 2D CAS-loop \n",
    "This creates a simple function with two outputs that we will consider under the two constraints $f_1(x) \\leq 0.75$ and $f_2(x) \\geq 0.55$. In this particular example, the $f_1(x)$ and $f_2(x)$ are same function for simplicity. \n",
    "\n",
    "The CAS loop follows the prototypical BO loop: \n",
    "1. Given a surrogate model, maximize ECI to select the next evaluation x.\n",
    "2. Observe f(x).\n",
    "3. Update the surrogate model. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "code_folding": [],
    "executionStartTime": 1638489237543,
    "executionStopTime": 1638489237685,
    "hidden_ranges": [],
    "originalKey": "691460ed-a2c8-45b5-8dc9-c6d8c87ee9d7",
    "requestMsgId": "691460ed-a2c8-45b5-8dc9-c6d8c87ee9d7"
   },
   "outputs": [],
   "source": [
    "def yf2d(x):\n",
    "    v = torch.exp(-2 * (x[:, 0] - 0.3) ** 2 - 4 * (x[:, 1] - 0.6) ** 2)\n",
    "    return torch.stack((v, v), dim=-1)\n",
    "\n",
    "\n",
    "bounds = torch.tensor([[0, 0], [1, 1]], **tkwargs)\n",
    "lb, ub = bounds\n",
    "dim = len(lb)\n",
    "constraints = [(\"lt\", 0.75), (\"gt\", 0.55)]\n",
    "punchout_radius = 0.1"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "originalKey": "6f354b25-8703-4156-908d-d53c1c2bbe4a",
    "showInput": false
   },
   "source": [
    "### CAS loop using 5 initial Sobol points and 15 ECI iterations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "code_folding": [],
    "executionStartTime": 1638489237803,
    "executionStopTime": 1638489266352,
    "hidden_ranges": [],
    "originalKey": "6d77353b-8dda-4835-9c6a-b0a53fddc67c",
    "requestMsgId": "6d77353b-8dda-4835-9c6a-b0a53fddc67c"
   },
   "outputs": [],
   "source": [
    "num_init_points = 5\n",
    "num_total_points = 15 if not SMOKE_TEST else 5\n",
    "\n",
    "X = lb + (ub - lb) * SobolEngine(dim, scramble=True).draw(num_init_points).to(**tkwargs)\n",
    "Y = yf2d(X)\n",
    "\n",
    "while len(X) < num_total_points:\n",
    "    # We don't have to normalize X since the domain is [0, 1]^2. Make sure to\n",
    "    # appropriately adjust the punchout radius if the domain is normalized.\n",
    "    gp_models = [get_and_fit_gp(X, Y[:, i : i + 1]) for i in range(Y.shape[-1])]\n",
    "    model_list_gp = ModelListGP(gp_models[0], gp_models[1])\n",
    "    eci = ExpectedCoverageImprovement(\n",
    "        model=model_list_gp,\n",
    "        constraints=constraints,\n",
    "        punchout_radius=punchout_radius,\n",
    "        bounds=bounds,\n",
    "        num_samples=128 if not SMOKE_TEST else 4,\n",
    "    )\n",
    "    x_next, _ = optimize_acqf(\n",
    "        acq_function=eci,\n",
    "        bounds=bounds,\n",
    "        q=1,\n",
    "        num_restarts=10 if not SMOKE_TEST else 2,\n",
    "        raw_samples=512 if not SMOKE_TEST else 4,\n",
    "    )\n",
    "    y_next = yf2d(x_next)\n",
    "    X = torch.cat((X, x_next))\n",
    "    Y = torch.cat((Y, y_next))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "code_folding": [],
    "hidden_ranges": [],
    "originalKey": "255bba4f-4d9a-46cc-aa66-16b90287824a",
    "showInput": false
   },
   "source": [
    "### Plot the selected points\n",
    "We plot the feasible region and the points selected by ECI below. The feasible region is outlined with a black ring, and points selected by ECI are marked in green (feasible) and red (infeasible). By design, observe that ECI selects a diverse i.e., well-spaced set of points inside the feasible region. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "code_folding": [],
    "customInput": null,
    "executionStartTime": 1638489266464,
    "executionStopTime": 1638489266516,
    "hidden_ranges": [],
    "originalKey": "6b62af84-01c0-4971-9122-bd5f01b9f31b",
    "requestMsgId": "6b62af84-01c0-4971-9122-bd5f01b9f31b",
    "showInput": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/deriksson/opt/anaconda3/lib/python3.9/site-packages/torch/functional.py:504: UserWarning: torch.meshgrid: in an upcoming release, it will be required to pass the indexing argument. (Triggered internally at /Users/runner/work/pytorch/pytorch/pytorch/aten/src/ATen/native/TensorShape.cpp:3191.)\n",
      "  return _VF.meshgrid(tensors, **kwargs)  # type: ignore[attr-defined]\n"
     ]
    }
   ],
   "source": [
    "N1, N2 = 30, 30\n",
    "Xplt, Yplt = torch.meshgrid(\n",
    "    torch.linspace(0, 1, N1, **tkwargs), torch.linspace(0, 1, N2, **tkwargs)\n",
    ")\n",
    "xplt = torch.stack(\n",
    "    (\n",
    "        torch.reshape(Xplt, (Xplt.shape[0] * Xplt.shape[1],)),\n",
    "        torch.reshape(Yplt, (Yplt.shape[0] * Yplt.shape[1],)),\n",
    "    ),\n",
    "    dim=1,\n",
    ")\n",
    "yplt = yf2d(xplt)\n",
    "Zplt = torch.reshape(yplt[:, 0], (N1, N2))  # Since f1(x) = f2(x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "code_folding": [],
    "executionStartTime": 1638489266564,
    "executionStopTime": 1638489267143,
    "hidden_ranges": [],
    "originalKey": "a44c258c-0373-4c68-9887-9ae7a57bcccc",
    "requestMsgId": "a44c258c-0373-4c68-9887-9ae7a57bcccc"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 800x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def identify_samples_which_satisfy_constraints(X, constraints):\n",
    "    \"\"\"\n",
    "    Takes in values (a1, ..., ak, o) and returns (a1, ..., ak, o)\n",
    "    True/False values, where o is the number of outputs.\n",
    "    \"\"\"\n",
    "    successful = torch.ones(X.shape).to(X)\n",
    "    for model_index in range(X.shape[-1]):\n",
    "        these_X = X[..., model_index]\n",
    "        direction, value = constraints[model_index]\n",
    "        successful[..., model_index] = (\n",
    "            these_X < value if direction == \"lt\" else these_X > value\n",
    "        )\n",
    "    return successful\n",
    "\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(8, 6))\n",
    "h1 = ax.contourf(Xplt.cpu(), Yplt.cpu(), Zplt.cpu(), 20, cmap=\"Blues\", alpha=0.6)\n",
    "fig.colorbar(h1)\n",
    "ax.contour(Xplt.cpu(), Yplt.cpu(), Zplt.cpu(), [0.55, 0.75], colors=\"k\")\n",
    "\n",
    "feasible_inds = (\n",
    "    identify_samples_which_satisfy_constraints(Y, constraints)\n",
    "    .prod(dim=-1)\n",
    "    .to(torch.bool)\n",
    ")\n",
    "ax.plot(X[feasible_inds, 0].cpu(), X[feasible_inds, 1].cpu(), \"sg\", label=\"Feasible\")\n",
    "ax.plot(\n",
    "    X[~feasible_inds, 0].cpu(), X[~feasible_inds, 1].cpu(), \"sr\", label=\"Infeasible\"\n",
    ")\n",
    "\n",
    "ax.legend(loc=[0.7, 0.05])\n",
    "ax.set_title(\"$f_1(x)$\")  # Recall that f1(x) = f2(x)\n",
    "ax.set_xlabel(\"$x_1$\")\n",
    "ax.set_ylabel(\"$x_2$\")\n",
    "ax.set_aspect(\"equal\", \"box\")\n",
    "ax.set_xlim([-0.05, 1.05])\n",
    "ax.set_ylim([-0.05, 1.05])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "executionStartTime": 1638489267152,
    "executionStopTime": 1638489267253,
    "originalKey": "0ff4a95d-b556-4a21-b794-184ba4181a49",
    "requestMsgId": "0ff4a95d-b556-4a21-b794-184ba4181a49"
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "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"
  },
  "last_base_url": "https://devbig817.ftw3.facebook.com:8090/",
  "last_kernel_id": "ba747f89-a0e6-4fdb-a721-148575d9f682",
  "last_msg_id": "9348e824-cc9a852b6869f3ed90e3b43a_20",
  "last_server_session_id": "bd522e7f-adef-4216-87c7-6d760f7f96ff",
  "outputWidgetContext": {}
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
