{
  "metadata": {
    "kernelspec": {
      "display_name": "python3",
      "language": "python",
      "name": "python3",
      "cinder_runtime": true,
      "ipyflow_runtime": false
    }
  },
  "nbformat": 4,
  "nbformat_minor": 2,
  "cells": [
    {
      "cell_type": "markdown",
      "metadata": {
        "originalKey": "6778d143-3808-45b3-bcbe-da7c7475280a",
        "showInput": false,
        "customInput": null,
        "code_folding": [],
        "hidden_ranges": []
      },
      "source": [
        "# Bayesian Optimization with Preference Exploration\n",
        "\n",
        "In this tutorial, we demonstrate how to implement a closed loop of Bayesian optimization with preference exploration, or BOPE [1].\n",
        "BOPE is designed for Bayesian optimization of expensive-to-evaluate experiments,\n",
        "where the response surface function of the experiment $f_\\mathrm{true}$ generates vector-valued outcomes over which a decision-maker (DM) has preferences.\n",
        "These preferences are encoded by a utility function $g_\\mathrm{true}$ that is not known in closed form but can be estimated by\n",
        "asking the DM to express preferences over pairs of outcome vectors.\n",
        "\n",
        "In other words, with BOPE, we wish to solve the following optimization problem:\n",
        "\n",
        "$$\n",
        " \\max_{x \\in \\mathcal{X}} g_\\mathrm{true}(f_\\mathrm{true}(x))\n",
        "$$\n",
        "\n",
        "Unlike many other Bayesian optimization setups where multiple consecutive batches of experiments are performed,\n",
        "in BOPE, we alternate between two stages: *preference exploration* and *experimentation*.\n",
        "\n",
        "In the preference exploration stage, we use an acquisition function (i.e., a preference exploratoin strategy, or PE strategy)\n",
        "to adaptively generate pairs of hypothetical outcome and ask the decision-maker’s preference within each pair.\n",
        "In the experimentation stage, we use a batch version of noisy expected improvement that integrates over our uncertainty in the\n",
        "utility function called $\\text{qNEIUU}$ to generate experimental candidates for evaluation.\n",
        "\n",
        "\n",
        "[1] [Z.J. Lin, R. Astudillo, P.I. Frazier, and E. Bakshy, Preference Exploration for Efficient Bayesian Optimization with Multiple Outcomes. AISTATS, 2022.](https://arxiv.org/abs/2203.11382)"
      ],
      "attachments": {}
    },
    {
      "cell_type": "code",
      "metadata": {
        "originalKey": "f4c4c433-22c1-432c-8b68-e994bcd1881b",
        "showInput": true,
        "customInput": null,
        "collapsed": false,
        "requestMsgId": "9aa7b0c4-ac2c-4e47-a067-7e0797bdd89d",
        "executionStartTime": 1679689485463,
        "executionStopTime": 1679689500450,
        "customOutput": null
      },
      "source": [
        "import os\n",
        "import warnings\n",
        "\n",
        "import matplotlib as mpl\n",
        "import matplotlib.pylab as plt\n",
        "import numpy as np\n",
        "import pandas as pd\n",
        "import torch\n",
        "from botorch.acquisition import GenericMCObjective, LearnedObjective\n",
        "from botorch.acquisition.monte_carlo import qNoisyExpectedImprovement, qSimpleRegret\n",
        "from botorch.acquisition.preference import AnalyticExpectedUtilityOfBestOption\n",
        "from botorch.fit import fit_gpytorch_mll\n",
        "from botorch.models.deterministic import FixedSingleSampleModel\n",
        "from botorch.models.gp_regression import SingleTaskGP\n",
        "from botorch.models.pairwise_gp import PairwiseGP, PairwiseLaplaceMarginalLogLikelihood\n",
        "from botorch.models.transforms.input import Normalize\n",
        "from botorch.models.transforms.outcome import Standardize\n",
        "from botorch.optim.optimize import optimize_acqf\n",
        "from botorch.sampling import SobolQMCNormalSampler\n",
        "from botorch.test_functions.multi_objective import DTLZ2\n",
        "from botorch.utils.sampling import draw_sobol_samples\n",
        "from gpytorch.mlls.exact_marginal_log_likelihood import ExactMarginalLogLikelihood\n",
        "\n",
        "\n",
        "%matplotlib inline\n",
        "# Suppress potential optimization warnings for cleaner notebook\n",
        "warnings.filterwarnings(\"ignore\")\n",
        "\n",
        "# Set plotting colors\n",
        "colors = [\"tab:blue\", \"tab:orange\", \"tab:green\", \"tab:red\"]\n",
        "mpl.rcParams[\"axes.prop_cycle\"] = mpl.cycler(color=colors)\n",
        "\n",
        "SMOKE_TEST = os.environ.get(\"SMOKE_TEST\")"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "originalKey": "7729000d-0661-4689-8f2b-f99e32c52b70",
        "showInput": false,
        "customInput": null,
        "code_folding": [],
        "hidden_ranges": []
      },
      "source": [
        "## Problem Setup\n",
        "\n",
        "In this tutorial, we use the DTLZ2 problem with d=5 inputs and k=4 outcomes as our test problem $f_\\mathrm{true}$.\n",
        "\n",
        "For the utility function $g_\\mathrm{true}$, we use the negative L1 distance from a Pareto-optimal point the outcome space:\n",
        "$Y^* = f(X^*)$ where $X^* = [0.5, 0.5, 0.5, 0.5, 0.5]$. "
      ],
      "attachments": {}
    },
    {
      "cell_type": "code",
      "metadata": {
        "originalKey": "470d8e92-e1ff-4ae7-8343-3423273900f8",
        "showInput": true,
        "customInput": null,
        "collapsed": false,
        "requestMsgId": "f8b170ce-5da8-40f6-aae4-1d637ea97e33",
        "executionStartTime": 1679689500531,
        "executionStopTime": 1679689500534,
        "code_folding": [],
        "hidden_ranges": [],
        "customOutput": null
      },
      "source": [
        "def neg_l1_dist(Y):\n",
        "    \"\"\"Negative L1 distance from a Pareto optimal points\"\"\"\n",
        "    if len(Y.shape) == 1:\n",
        "        Y = Y.unsqueeze(0)\n",
        "    dist = torch.cdist(\n",
        "        Y, torch.full(Y.shape[-1:], fill_value=0.5).unsqueeze(0), p=1\n",
        "    ).squeeze(-1)\n",
        "    return -dist\n",
        "\n",
        "\n",
        "if SMOKE_TEST:\n",
        "    NUM_RESTARTS = 2\n",
        "    NUM_PREF_SAMPLES = 1\n",
        "    NUM_OUTCOME_SAMPLES = 4\n",
        "    RAW_SAMPLES = 8\n",
        "    BATCH_LIMIT = 2\n",
        "else:\n",
        "    NUM_RESTARTS = 8\n",
        "    NUM_PREF_SAMPLES = 1\n",
        "    NUM_OUTCOME_SAMPLES = 64\n",
        "    RAW_SAMPLES = 64\n",
        "    BATCH_LIMIT = 4\n",
        "\n",
        "X_dim = 5\n",
        "Y_dim = 4\n",
        "problem = DTLZ2(dim=X_dim, num_objectives=Y_dim)\n",
        "util_func = neg_l1_dist"
      ],
      "execution_count": 3,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "originalKey": "bf98ebb8-36d5-423a-9eea-5ff99c44975b",
        "showInput": false,
        "customInput": null,
        "code_folding": [],
        "hidden_ranges": []
      },
      "source": [
        "Here we define a collection of helper functions for BOPE:"
      ],
      "attachments": {}
    },
    {
      "cell_type": "code",
      "metadata": {
        "originalKey": "8a6b9736-1ba8-4914-b295-7406bec5ece6",
        "showInput": true,
        "customInput": null,
        "collapsed": false,
        "requestMsgId": "43fea609-1909-4ba8-af8f-7ac3de4016dd",
        "executionStopTime": 1679689500838,
        "executionStartTime": 1679689500831,
        "code_folding": [],
        "hidden_ranges": [],
        "customOutput": null
      },
      "source": [
        "def fit_outcome_model(X, Y, X_bounds):\n",
        "    \"\"\"Fit the outcome model f\"\"\"\n",
        "    outcome_model = SingleTaskGP(\n",
        "        train_X=X,\n",
        "        train_Y=Y,\n",
        "        input_transform=Normalize(d=X.shape[-1]),\n",
        "        outcome_transform=Standardize(m=Y.shape[-1]),\n",
        "    )\n",
        "    mll = ExactMarginalLogLikelihood(outcome_model.likelihood, outcome_model)\n",
        "    fit_gpytorch_mll(mll)\n",
        "    return outcome_model\n",
        "\n",
        "\n",
        "def fit_pref_model(Y, comps):\n",
        "    \"\"\"Fit the preference model g\"\"\"\n",
        "    model = PairwiseGP(Y, comps, input_transform=Normalize(d=Y.shape[-1]))\n",
        "    mll = PairwiseLaplaceMarginalLogLikelihood(model.likelihood, model)\n",
        "    fit_gpytorch_mll(mll)\n",
        "    return model\n",
        "\n",
        "\n",
        "def gen_rand_X(problem, n):\n",
        "    \"\"\"Generate n quasi-random Sobol points in the design space\"\"\"\n",
        "    return draw_sobol_samples(bounds=problem.bounds, n=1, q=n).squeeze(0)\n",
        "\n",
        "\n",
        "def generate_random_exp_data(problem, n):\n",
        "    \"\"\"Generate n observations of (X, Y) Pairs\"\"\"\n",
        "    X = gen_rand_X(problem, n)\n",
        "    Y = problem(X)\n",
        "    return X, Y\n",
        "\n",
        "\n",
        "def generate_random_pref_data(outcome_model, n):\n",
        "    \"\"\"Generate n pairwise comparison data between 2n points\"\"\"\n",
        "    X = gen_rand_X(problem, 2 * n)\n",
        "    Y = outcome_model.posterior(X).sample().squeeze(0)\n",
        "    util = util_func(Y)\n",
        "    comps = gen_comps(util)\n",
        "    return Y, comps\n",
        "\n",
        "\n",
        "def gen_comps(util):\n",
        "    \"\"\"Given an 1-d tensor of utility, create pairwise comparisons between adjacent items\"\"\"\n",
        "    util = util.reshape(-1, 2)\n",
        "    comps = torch.arange(util.numel()).reshape(-1, 2)\n",
        "    flip = util[:, 0] < util[:, 1]\n",
        "    comps[flip, [0]], comps[flip, [1]] = comps[flip, [1]], comps[flip, [0]]\n",
        "\n",
        "    return comps\n",
        "\n",
        "\n",
        "def run_pref_learn(\n",
        "    outcome_model, train_Y, train_comps, n_comps, pe_strategy, verbose=False\n",
        "):\n",
        "    \"\"\"Perform preference exploration with a given PE strategy for n_comps rounds\"\"\"\n",
        "    for i in range(n_comps):\n",
        "        if verbose:\n",
        "            print(f\"Running {i+1}/{n_comps} preference learning using {pe_strategy}\")\n",
        "        pref_model = fit_pref_model(train_Y, train_comps)\n",
        "        if pe_strategy == \"EUBO-zeta\":\n",
        "            # EUBO-zeta\n",
        "            one_sample_outcome_model = FixedSingleSampleModel(model=outcome_model)\n",
        "            acqf = AnalyticExpectedUtilityOfBestOption(\n",
        "                pref_model=pref_model, outcome_model=one_sample_outcome_model\n",
        "            )\n",
        "            cand_X, acqf_val = optimize_acqf(\n",
        "                acq_function=acqf,\n",
        "                q=2,\n",
        "                bounds=problem.bounds,\n",
        "                num_restarts=NUM_RESTARTS,\n",
        "                raw_samples=RAW_SAMPLES,  # used for intialization heuristic\n",
        "                options={\"batch_limit\": BATCH_LIMIT},\n",
        "            )\n",
        "            cand_Y = one_sample_outcome_model(cand_X)\n",
        "        elif pe_strategy == \"Random-f\":\n",
        "            # Random-f\n",
        "            cand_X = gen_rand_X(problem, n=2)\n",
        "            cand_Y = outcome_model.posterior(cand_X).sample().squeeze(0)\n",
        "        else:\n",
        "            raise RuntimeError(\"Unknown preference exploration strategy!\")\n",
        "\n",
        "        cand_Y = cand_Y.detach().clone()\n",
        "        cand_comps = gen_comps(util_func(cand_Y))\n",
        "\n",
        "        train_comps = torch.cat((train_comps, cand_comps + train_Y.shape[0]))\n",
        "        train_Y = torch.cat((train_Y, cand_Y))\n",
        "\n",
        "    return train_Y, train_comps\n",
        "\n",
        "\n",
        "def gen_exp_cand(outcome_model, objective, q, acqf_name):\n",
        "    \"\"\"Given an outcome model and an objective, generate q experimental candidates\n",
        "    using specified acquisition function.\"\"\"\n",
        "    sampler = SobolQMCNormalSampler(sample_shape=torch.Size([NUM_OUTCOME_SAMPLES]))\n",
        "    if acqf_name == \"qNEI\":\n",
        "        # generate experimental candidates with qNEI/qNEIUU\n",
        "        acq_func = qNoisyExpectedImprovement(\n",
        "            model=outcome_model,\n",
        "            objective=objective,\n",
        "            X_baseline=X,\n",
        "            sampler=sampler,\n",
        "            prune_baseline=True,\n",
        "        )\n",
        "    elif acqf_name == \"posterior_mean\":\n",
        "        # generate experimental candidates with maximum posterior mean\n",
        "        acq_func = qSimpleRegret(\n",
        "            model=outcome_model,\n",
        "            sampler=sampler,\n",
        "            objective=objective,\n",
        "        )\n",
        "    else:\n",
        "        raise RuntimeError(\"Unknown acquisition function name!\")\n",
        "\n",
        "    # optimize the acquisition function\n",
        "    candidates, _ = optimize_acqf(\n",
        "        acq_function=acq_func,\n",
        "        q=q,\n",
        "        bounds=problem.bounds,\n",
        "        num_restarts=NUM_RESTARTS,\n",
        "        raw_samples=RAW_SAMPLES,\n",
        "        options={\"batch_limit\": BATCH_LIMIT},\n",
        "        sequential=True,\n",
        "    )\n",
        "    return candidates\n",
        "\n",
        "\n",
        "def find_max_posterior_mean(outcome_model, train_Y, train_comps, verbose=False):\n",
        "    \"\"\"Helper function that find the max posterior mean under current outcome and\n",
        "    preference model\"\"\"\n",
        "    pref_model = fit_pref_model(train_Y, train_comps)\n",
        "    sampler = SobolQMCNormalSampler(sample_shape=torch.Size([NUM_PREF_SAMPLES]))\n",
        "    pref_obj = LearnedObjective(pref_model=pref_model, sampler=sampler)\n",
        "    post_mean_cand_X = gen_exp_cand(\n",
        "        outcome_model, pref_obj, q=1, acqf_name=\"posterior_mean\"\n",
        "    )\n",
        "\n",
        "    post_mean_util = util_func(problem(post_mean_cand_X)).item()\n",
        "    if verbose:\n",
        "        print(f\"Max posterior mean utility: {post_mean_util:.3f}\")\n",
        "    within_result = {\n",
        "        \"n_comps\": train_comps.shape[0],\n",
        "        \"util\": post_mean_util,\n",
        "    }\n",
        "    return within_result"
      ],
      "execution_count": 4,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "originalKey": "7d9d4982-ca40-4744-88d5-775a5c306ddd",
        "showInput": false,
        "customInput": null,
        "code_folding": [],
        "hidden_ranges": []
      },
      "source": [
        "## Closed Loop BOPE\n",
        "\n",
        "### Setup\n",
        "The following cell shows the core part of this tutorial.\n",
        "In BOPE, we use two probablistic models (in this case, two Gaussian processes) $f$ and $g$\n",
        "to model $f_\\mathrm{true}$ and $g_\\mathrm{true}$ respectively.\n",
        "\n",
        "We start by initializing the outcome model $f$ with 16 quasi-random points (the initial experimentation stage).\n",
        "\n",
        "Next, we enter the preference exploration (PE) stage.\n",
        "A straightforward strategy of performing PE is to present the decision-maker with comparisons using outcomes estimated\n",
        "by sampling from the outcome model using random design points. We refer this method as $\\text{Random}\\mathrm{-}f$.\n",
        "\n",
        "Alternatively, we could initialize the preference model with $\\text{Random}\\mathrm{-}f$,\n",
        "then perform PE using the $\\text{EUBO}\\mathrm{-}\\zeta$ acquisition function as proposed in [1].\n",
        "<!-- \\tilde{f} somehow is not rendering --> \n",
        "\n",
        "In this tutorial, we examine both strategies by starting with initializating the preference model with 3 comparisons using $\\text{Random}\\mathrm{-}f$.\n",
        "After that, we perform 3 * 4 = 12 pairwise comparisons using either $\\text{EUBO}\\mathrm{-}\\zeta$ or $\\text{Random}\\mathrm{-}f$.\n",
        "Then we move on to the 2nd experimentation stage by generating a candidate using qNEIUU by\n",
        "leveraging both the outcome model and the learned preference model.\n",
        "\n",
        "We additionally examine two other experimental canadidate generation strategies:\n",
        "In the first one, we assume the true utility function is known and generate experiment candidate(s) using qNEI.\n",
        "This represents the performance upper bound of PE strategies.\n",
        "For the second experiment canadidate generation strategy, we use random design points to generate new candidates."
      ],
      "attachments": {}
    },
    {
      "cell_type": "code",
      "metadata": {
        "originalKey": "4067171b-e552-4ddf-a9e8-a40b53a5c368",
        "showInput": true,
        "customInput": null,
        "code_folding": [],
        "hidden_ranges": [],
        "collapsed": false,
        "requestMsgId": "b824d249-226a-497e-8764-fea353877527",
        "executionStartTime": 1679689500952,
        "executionStopTime": 1679689626563,
        "customOutput": null
      },
      "source": [
        "verbose = False\n",
        "# Number of pairwise comparisons performed before checking posterior mean\n",
        "every_n_comps = 3\n",
        "# Total number of checking the maximum posterior mean\n",
        "n_check_post_mean = 5\n",
        "n_reps = 1\n",
        "within_session_results = []\n",
        "exp_candidate_results = []\n",
        "\n",
        "for i in range(n_reps):\n",
        "    print(f\"Run {i}\")\n",
        "    # Experimentation stage: initial exploration batch\n",
        "    torch.manual_seed(i)\n",
        "    np.random.seed(i)\n",
        "    X, Y = generate_random_exp_data(problem, 8)\n",
        "    outcome_model = fit_outcome_model(X, Y, problem.bounds)\n",
        "\n",
        "    # Preference exploration stage: initialize the preference model with comparsions\n",
        "    # between pairs of outcomes estimated using random design points\n",
        "    init_train_Y, init_train_comps = generate_random_pref_data(outcome_model, n=1)\n",
        "\n",
        "    # Perform preference exploration using either Random-f or EUBO-zeta\n",
        "    for pe_strategy in [\"EUBO-zeta\", \"Random-f\"]:\n",
        "        train_Y, train_comps = init_train_Y.clone(), init_train_comps.clone()\n",
        "        within_result = find_max_posterior_mean(outcome_model, train_Y, train_comps)\n",
        "        within_result.update({\"run_id\": i, \"pe_strategy\": pe_strategy})\n",
        "        within_session_results.append(within_result)\n",
        "\n",
        "        for j in range(n_check_post_mean):\n",
        "            train_Y, train_comps = run_pref_learn(\n",
        "                outcome_model,\n",
        "                train_Y,\n",
        "                train_comps,\n",
        "                n_comps=every_n_comps,\n",
        "                pe_strategy=pe_strategy,\n",
        "                verbose=verbose,\n",
        "            )\n",
        "            if verbose:\n",
        "                print(\n",
        "                    f\"Checking posterior mean after {(j+1) * every_n_comps} comps using PE strategy {pe_strategy}\"\n",
        "                )\n",
        "            within_result = find_max_posterior_mean(\n",
        "                outcome_model, train_Y, train_comps, verbose=verbose\n",
        "            )\n",
        "            within_result.update({\"run_id\": i, \"pe_strategy\": pe_strategy})\n",
        "            within_session_results.append(within_result)\n",
        "\n",
        "        # Going back to the experimentation stage: generate an additional batch of experimental evaluations\n",
        "        # with the learned preference model and qNEIUU\n",
        "        pref_model = fit_pref_model(train_Y, train_comps)\n",
        "        sampler = SobolQMCNormalSampler(sample_shape=torch.Size([NUM_PREF_SAMPLES]))\n",
        "        pref_obj = LearnedObjective(pref_model=pref_model, sampler=sampler)\n",
        "        exp_cand_X = gen_exp_cand(outcome_model, pref_obj, q=1, acqf_name=\"qNEI\")\n",
        "        qneiuu_util = util_func(problem(exp_cand_X)).item()\n",
        "        print(f\"{pe_strategy} qNEIUU candidate utility: {qneiuu_util:.3f}\")\n",
        "        exp_result = {\n",
        "            \"util\": qneiuu_util,\n",
        "            \"strategy\": pe_strategy,\n",
        "            \"run_id\": i,\n",
        "        }\n",
        "        exp_candidate_results.append(exp_result)\n",
        "\n",
        "    # Generate a batch of experimental evaluations using oracle and random baselines\n",
        "    # True utility\n",
        "    true_obj = GenericMCObjective(util_func)\n",
        "    true_obj_cand_X = gen_exp_cand(outcome_model, true_obj, q=1, acqf_name=\"qNEI\")\n",
        "    true_obj_util = util_func(problem(true_obj_cand_X)).item()\n",
        "    print(f\"True objective utility: {true_obj_util:.3f}\")\n",
        "    exp_result = {\n",
        "        \"util\": true_obj_util,\n",
        "        \"strategy\": \"True Utility\",\n",
        "        \"run_id\": i,\n",
        "    }\n",
        "    exp_candidate_results.append(exp_result)\n",
        "\n",
        "    # Random experiment\n",
        "    _, random_Y = generate_random_exp_data(problem, 1)\n",
        "    random_util = util_func(random_Y).item()\n",
        "    print(f\"Random experiment utility: {random_util:.3f}\")\n",
        "    exp_result = {\n",
        "        \"util\": random_util,\n",
        "        \"strategy\": \"Random Experiment\",\n",
        "        \"run_id\": i,\n",
        "    }\n",
        "    exp_candidate_results.append(exp_result)"
      ],
      "execution_count": 5,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Run 0\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "EUBO-zeta qNEIUU candidate utility: -0.734\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Random-f qNEIUU candidate utility: -1.070\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "True objective utility: -0.433\nRandom experiment utility: -1.244\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "originalKey": "64f2fb33-46bc-47ac-b169-ea702e41f6cd",
        "showInput": false,
        "customInput": null,
        "code_folding": [],
        "hidden_ranges": []
      },
      "source": [
        "## Plot the Results\n",
        "\n",
        "We evaluate our results by creating two plots.\n",
        "\n",
        "In the first plot, we focus on comparing how $\\text{EUBO}\\mathrm{-}\\zeta$ can efficiently identify the maximizer \n",
        "of $g_\\mathrm{true}(f_\\mathrm{true}(x))$ within a preference exploration stage.\n",
        "We examine this by estimatig the maximum posterior mean after every 3 pairwise comparisons.\n",
        "\n",
        "Here, we plot the the max utility value identified using $\\text{EUBO}\\mathrm{-}\\zeta$ and $\\text{Random}\\mathrm{-}f$\n",
        "with increasing number of pairwise comparisons.\n",
        "As we can see in this plot, the preference model learned using $\\text{EUBO}\\mathrm{-}\\zeta$ is able to identify the maximum utility more efficiently."
      ],
      "attachments": {}
    },
    {
      "cell_type": "code",
      "metadata": {
        "originalKey": "ef016382-cca8-41f3-8115-5bf3af4569de",
        "showInput": true,
        "customInput": null,
        "code_folding": [],
        "hidden_ranges": [],
        "collapsed": false,
        "requestMsgId": "2cab5ce5-d9ec-4e38-bff4-2c1274bdcbe8",
        "executionStartTime": 1679689626764,
        "executionStopTime": 1679689627615,
        "customOutput": null
      },
      "source": [
        "# Prepare PE data for plots\n",
        "within_df = pd.DataFrame(within_session_results)\n",
        "within_df[\"pe_strategy\"] = within_df[\"pe_strategy\"].str.replace(\n",
        "    \"EUBO-zeta\", r\"$EUBO-\\zeta$\"\n",
        ")\n",
        "within_df = (\n",
        "    within_df.groupby([\"n_comps\", \"pe_strategy\"])\n",
        "    .agg({\"util\": [\"mean\", \"sem\"]})\n",
        "    .droplevel(level=0, axis=1)\n",
        "    .reset_index()\n",
        ")\n",
        "within_df\n",
        "\n",
        "# Plotting\n",
        "plt.figure(figsize=(8, 6))\n",
        "for name, group in within_df.groupby(\"pe_strategy\", sort=True):\n",
        "    yerr = 1.96 * group[\"sem\"]\n",
        "    if np.any(np.isnan(yerr)):\n",
        "        yerr = None\n",
        "    plt.errorbar(\n",
        "        x=group[\"n_comps\"],\n",
        "        y=group[\"mean\"],\n",
        "        yerr=yerr,\n",
        "        label=name,\n",
        "        linewidth=1.5,\n",
        "        capsize=3,\n",
        "        alpha=0.6,\n",
        "    )\n",
        "plt.xlabel(\"Number of comparisons\")\n",
        "plt.ylabel(\"Max value identified\")\n",
        "plt.legend(title=\"PE Strategy\")"
      ],
      "execution_count": 6,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": "<matplotlib.legend.Legend at 0x7f8c893f0b20>"
          },
          "metadata": {
            "bento_obj_id": "140241574759200"
          },
          "execution_count": 6
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": "<Figure size 576x432 with 1 Axes>",
            "image/png": "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\n"
          },
          "metadata": {
            "bento_obj_id": "140241574367440",
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "originalKey": "e407a6c3-0cf3-4ec2-886a-4973db669ceb",
        "showInput": false,
        "customInput": null,
        "code_folding": [],
        "hidden_ranges": []
      },
      "source": [
        "In the following cell, we show the average utility values achieved using different methods in the 2nd experimentation stage.\n",
        "\n",
        "We see that $\\text{EUBO}\\mathrm{-}\\zeta$, as a one-step Bayesian optimal PE strategy, performs very similarly to the true utility strategy.\n",
        "\n",
        "On the other hand, despite that $\\text{Random}\\mathrm{-}f$ is a relatively straightforward PE strategy,\n",
        "it is still able to suggest experimental candidates with generally higher utility values than the random experiment baseline."
      ],
      "attachments": {}
    },
    {
      "cell_type": "code",
      "metadata": {
        "originalKey": "0737e625-fe4a-47e5-bc4c-ffabb9511435",
        "showInput": true,
        "customInput": null,
        "code_folding": [],
        "hidden_ranges": [],
        "collapsed": false,
        "requestMsgId": "5791d879-9ccc-4be5-a671-b3ac431978f4",
        "executionStartTime": 1679689627689,
        "executionStopTime": 1679689628137,
        "customOutput": null
      },
      "source": [
        "# Prepare the 2nd experimentation batch data for plot\n",
        "exp_df = pd.DataFrame(exp_candidate_results)\n",
        "exp_df[\"strategy\"] = exp_df[\"strategy\"].str.replace(\"EUBO-zeta\", r\"$EUBO-\\\\zeta$\")\n",
        "exp_df[\"strategy\"] = pd.Categorical(\n",
        "    exp_df[\"strategy\"],\n",
        "    [\"True Utility\", \"$EUBO-\\zeta$\", \"Random-f\", \"Random Experiment\"],\n",
        ")\n",
        "exp_df = (\n",
        "    exp_df.groupby([\"strategy\"])\n",
        "    .agg({\"util\": [\"mean\", \"sem\"]})\n",
        "    .droplevel(level=0, axis=1)\n",
        "    .reset_index()\n",
        ")\n",
        "\n",
        "# Plotting\n",
        "plt.figure(figsize=(8, 6))\n",
        "for name, group in exp_df.groupby(\"strategy\", sort=True):\n",
        "    yerr = 1.96 * group[\"sem\"]\n",
        "    if np.any(np.isnan(yerr)):\n",
        "        yerr = None\n",
        "    plt.errorbar(\n",
        "        x=group[\"strategy\"],\n",
        "        y=group[\"mean\"],\n",
        "        yerr=yerr,\n",
        "        fmt=\"o\",\n",
        "        markersize=10,\n",
        "        label=name,\n",
        "        linewidth=1.5,\n",
        "        capsize=3,\n",
        "    )\n",
        "\n",
        "plt.xlabel(\"Experimentation Strategy\")\n",
        "plt.ylabel(\"Utility achieved in the 2nd experiment stage\")\n",
        "plt.legend(title=\"Experimentation Strategy\")"
      ],
      "execution_count": 7,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": "<matplotlib.legend.Legend at 0x7f8c89d7cfd0>"
          },
          "metadata": {
            "bento_obj_id": "140241584771024"
          },
          "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": "140241591722432",
            "needs_background": "light"
          }
        }
      ]
    }
  ]
}
