{
  "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": "a0534c61-7c52-41ec-bd7a-c4c617eb6d4d",
        "showInput": false
      },
      "source": [
        "## Bayesian optimization with pairwise comparison data\n",
        "\n",
        "In many real-world problems, people are faced with making multi-objective decisions. While it is often hard write down the exact utility function over those objectives, it is much easier for people to make pairwise comparisons. Drawing from utility theory and discrete choice models in economics, one can assume the user makes comparisons based on some intrinsic utility function and model the latent utility function using only the observed attributes and pairwise comparisons. \n",
        "In machine learning terms, we are concerned with [object ranking](https://en.wikipedia.org/wiki/Preference_learning) here.\n",
        "This [book](https://link.springer.com/book/10.1007/978-3-642-14125-6) has some more general discussions on this topic.\n",
        "\n",
        "In this tutorial, we illustrate how to implement a simple Bayesian Optimization (BO) closed loop in BoTorch when we only observe (noisy) pairwise comparisons of the latent function values."
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "originalKey": "e61ee00b-9faf-470b-884e-f992b02b95e9",
        "showInput": false
      },
      "source": [
        "### Data generation\n",
        "\n",
        "Let's first generate some data that we are going to model.\n",
        "\n",
        "In this tutorial, the latent function we aim to fit is the weighted sum of the input vector, where for dimension $i$, the weight is $\\sqrt{i}$.\n",
        "The input tensor X is randomly sampled within the d-dimensional unit cube.\n",
        "\n",
        "\n",
        "Specifically,\n",
        "$$\n",
        "y = f(X) = \\sum_{i=1}^{d} \\sqrt{i} X_i ~~\\text{where}~~X \\in [0, 1]^d\n",
        "$$\n",
        "\n",
        "This function is monotonically increasing in each individual dimension and has different weights for each input dimension, which are some properties that many real-world utility functions possess.\n",
        "\n",
        "We generate the data using following code:"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "originalKey": "013712e9-4f68-4a2f-9131-3ab91a8ca7a9",
        "showInput": true,
        "customInput": null,
        "collapsed": false,
        "requestMsgId": "c92bd897-ca7f-4e28-9859-2dd038cb1a23",
        "executionStartTime": 1679377439060,
        "executionStopTime": 1679377484945,
        "customOutput": null
      },
      "source": [
        "%local-changes"
      ],
      "execution_count": 1,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "I0320 224401.118 local_changes_provider.py:31] Initializing local changes support for repo_base_path='/home/zylin/fbsource'\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "W0320 224444.580 local_changes_magic.py:243] enabling autoreload (level 2)\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "I0320 224444.584 magics.py:84] %autoreload was called with parameter_s='2'\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "originalKey": "3a0316c5-1648-4839-a717-59cd65c96a96",
        "showInput": true,
        "customInput": null,
        "collapsed": false,
        "requestMsgId": "548b0126-7321-403b-bb01-d3f26ab165a0",
        "executionStartTime": 1679377485172,
        "executionStopTime": 1679377496184,
        "customOutput": null
      },
      "source": [
        "import os\n",
        "import warnings\n",
        "from itertools import combinations\n",
        "\n",
        "import numpy as np\n",
        "import torch\n",
        "\n",
        "# Suppress potential optimization warnings for cleaner notebook\n",
        "warnings.filterwarnings(\"ignore\")\n",
        "\n",
        "SMOKE_TEST = os.environ.get(\"SMOKE_TEST\")"
      ],
      "execution_count": 2,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "I0320 224445.146 _utils_internal.py:179] NCCL_DEBUG env var is set to None\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "I0320 224445.149 _utils_internal.py:197] NCCL_DEBUG is forced to WARN from None\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "originalKey": "bdd3d4a5-2e45-4048-88c3-b008aab65179",
        "collapsed": false,
        "requestMsgId": "5c82b088-2071-455b-a563-c3586ef4d476",
        "executionStartTime": 1679377496266,
        "executionStopTime": 1679377496271,
        "customOutput": null
      },
      "source": [
        "# data generating helper functions\n",
        "def utility(X):\n",
        "    \"\"\"Given X, output corresponding utility (i.e., the latent function)\"\"\"\n",
        "    # y is weighted sum of X, with weight sqrt(i) imposed on dimension i\n",
        "    weighted_X = X * torch.sqrt(torch.arange(X.size(-1), dtype=torch.float) + 1)\n",
        "    y = torch.sum(weighted_X, dim=-1)\n",
        "    return y\n",
        "\n",
        "\n",
        "def generate_data(n, dim=2):\n",
        "    \"\"\"Generate data X and y\"\"\"\n",
        "    # X is randomly sampled from dim-dimentional unit cube\n",
        "    # we recommend using double as opposed to float tensor here for\n",
        "    # better numerical stability\n",
        "    X = torch.rand(n, dim, dtype=torch.float64)\n",
        "    y = utility(X)\n",
        "    return X, y\n",
        "\n",
        "\n",
        "def generate_comparisons(y, n_comp, noise=0.1, replace=False):\n",
        "    \"\"\"Create pairwise comparisons with noise\"\"\"\n",
        "    # generate all possible pairs of elements in y\n",
        "    all_pairs = np.array(list(combinations(range(y.shape[0]), 2)))\n",
        "    # randomly select n_comp pairs from all_pairs\n",
        "    comp_pairs = all_pairs[\n",
        "        np.random.choice(range(len(all_pairs)), n_comp, replace=replace)\n",
        "    ]\n",
        "    # add gaussian noise to the latent y values\n",
        "    c0 = y[comp_pairs[:, 0]] + np.random.standard_normal(len(comp_pairs)) * noise\n",
        "    c1 = y[comp_pairs[:, 1]] + np.random.standard_normal(len(comp_pairs)) * noise\n",
        "    reverse_comp = (c0 < c1).numpy()\n",
        "    comp_pairs[reverse_comp, :] = np.flip(comp_pairs[reverse_comp, :], 1)\n",
        "    comp_pairs = torch.tensor(comp_pairs).long()\n",
        "\n",
        "    return comp_pairs\n",
        "\n",
        "\n",
        "torch.manual_seed(123)\n",
        "n = 50 if not SMOKE_TEST else 5\n",
        "m = 100 if not SMOKE_TEST else 10\n",
        "dim = 4\n",
        "noise = 0.1\n",
        "train_X, train_y = generate_data(n, dim=dim)\n",
        "train_comp = generate_comparisons(train_y, m, noise=noise)"
      ],
      "execution_count": 3,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "originalKey": "ccf32bac-a38d-4b26-b18f-0cfaf21cd5cd",
        "showInput": false
      },
      "source": [
        "`train_X` is a `n x dim` tensor;\n",
        "\n",
        "`train_y` is a `n`-dimensional vector, representing the noise-free latent function value $y$;\n",
        "\n",
        "`train_comp` is a `m x 2` tensor, representing the noisy comparisons based on $\\tilde{y} = y + N(0, \\sigma^2)$, where `train_comp[k, :] = (i, j)` indicates $\\tilde{y_i} > \\tilde{y_j}$.\n",
        "\n",
        "If y is the utility function value for a set of `n` items for a specific user, $\\tilde{y_i} > \\tilde{y_j}$ indicates (with some noise) the user prefers item i over item j.\n",
        ""
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "originalKey": "b00d6851-2ef7-4897-b77b-f33d81aacc40",
        "showInput": false
      },
      "source": [
        "### PairwiseGP model fitting\n",
        "\n",
        "In this problem setting, we never observe the actual function value.\n",
        "Therefore, instead of fitting the model  using (`train_X`, `train_y`) pair, we will fit the model with (`train_X`, `train_comp`).\n",
        "\n",
        "`PairwiseGP` from BoTorch is designed to work with such pairwise comparison input.\n",
        "We use `PairwiseLaplaceMarginalLogLikelihood` as the marginal log likelihood that we aim to maximize for optimizing the hyperparameters."
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "originalKey": "a41e5119-e06c-488b-b6e1-91431b399b11",
        "collapsed": false,
        "requestMsgId": "1efc0e48-14cf-4d74-8c40-6d83785429b5",
        "executionStartTime": 1679377496379,
        "executionStopTime": 1679377503021,
        "code_folding": [],
        "hidden_ranges": [],
        "customOutput": null
      },
      "source": [
        "from botorch.fit import fit_gpytorch_mll\n",
        "from botorch.models.pairwise_gp import PairwiseGP, PairwiseLaplaceMarginalLogLikelihood\n",
        "from botorch.models.transforms.input import Normalize\n",
        "\n",
        "\n",
        "model = PairwiseGP(\n",
        "    train_X,\n",
        "    train_comp,\n",
        "    input_transform=Normalize(d=train_X.shape[-1]),\n",
        ")\n",
        "mll = PairwiseLaplaceMarginalLogLikelihood(model.likelihood, model)\n",
        "mll = fit_gpytorch_mll(mll)"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "originalKey": "368a5c39-3fd4-4840-86bd-2fa6ae17694b",
        "showInput": false
      },
      "source": [
        "Because the we never observe the latent function value, output values from the model are only meaningful on a relative scale.\n",
        "Hence, given a test pair (`test_X`, `test_y`), we can evaluate the model using Kendall-Tau rank correlation."
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "originalKey": "9aae3cd3-7e35-4250-84d2-64c08d198535",
        "collapsed": false,
        "requestMsgId": "a680776e-3541-47aa-9f8c-cd5496f23039",
        "executionStartTime": 1679377503118,
        "executionStopTime": 1679377503474,
        "customOutput": null
      },
      "source": [
        "from scipy.stats import kendalltau\n",
        "\n",
        "\n",
        "# Kendall-Tau rank correlation\n",
        "def eval_kt_cor(model, test_X, test_y):\n",
        "    pred_y = model.posterior(test_X).mean.squeeze().detach().numpy()\n",
        "    return kendalltau(pred_y, test_y).correlation\n",
        "\n",
        "\n",
        "n_kendall = 1000 if not SMOKE_TEST else 10\n",
        "\n",
        "test_X, test_y = generate_data(n_kendall, dim=dim)\n",
        "kt_correlation = eval_kt_cor(model, test_X, test_y)\n",
        "\n",
        "print(f\"Test Kendall-Tau rank correlation: {kt_correlation:.4f}\")"
      ],
      "execution_count": 5,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Test Kendall-Tau rank correlation: 0.9082\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "originalKey": "c0b823a5-6f8e-4a0e-b700-80dc4e0e4f27",
        "showInput": false,
        "code_folding": [],
        "hidden_ranges": []
      },
      "source": [
        "### Perform Bayesian Optimization loop with EUBO\n",
        "\n",
        "Now, we demonstrate how to implement a full Bayesian optimization with `AnalyticExpectedUtilityOfBestOption` (EUBO) acquisition function [4, 5].\n",
        "\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_{next} = \\{x_1, x_2, ..., x_q\\}$\n",
        "2. observe `q_comp` randomly selected pairs of (noisy) comparisons between elements in $X_{next}$\n",
        "3. update the surrogate model with $X_{next}$ and the observed pairwise comparisons\n",
        "\n",
        "We start off by defining a few helper functions."
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "originalKey": "e11ce86a-39a5-4155-a5c3-6caf75037c13",
        "collapsed": false,
        "requestMsgId": "0119bb16-7952-4a66-b5ff-c0c53a009533",
        "executionStartTime": 1679377503538,
        "executionStopTime": 1679377503567,
        "customOutput": null,
        "code_folding": [],
        "hidden_ranges": []
      },
      "source": [
        "from botorch.acquisition.preference import AnalyticExpectedUtilityOfBestOption\n",
        "from botorch.optim import optimize_acqf\n",
        "\n",
        "\n",
        "def init_and_fit_model(X, comp):\n",
        "    \"\"\"Model fitting helper function\"\"\"\n",
        "    model = PairwiseGP(\n",
        "        X,\n",
        "        comp,\n",
        "        input_transform=Normalize(d=X.shape[-1]),\n",
        "    )\n",
        "    mll = PairwiseLaplaceMarginalLogLikelihood(model.likelihood, model)\n",
        "    fit_gpytorch_mll(mll)\n",
        "    return mll, model\n",
        "\n",
        "\n",
        "def make_new_data(X, next_X, comps, q_comp):\n",
        "    \"\"\"Given X and next_X,\n",
        "    generate q_comp new comparisons between next_X\n",
        "    and return the concatenated X and comparisons\n",
        "    \"\"\"\n",
        "    # next_X is float by default; cast it to the dtype of X (i.e., double)\n",
        "    next_X = next_X.to(X)\n",
        "    next_y = utility(next_X)\n",
        "    next_comps = generate_comparisons(next_y, n_comp=q_comp, noise=noise)\n",
        "    comps = torch.cat([comps, next_comps + X.shape[-2]])\n",
        "    X = torch.cat([X, next_X])\n",
        "    return X, comps"
      ],
      "execution_count": 6,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "originalKey": "71133aee-de87-4329-986b-6e43b964b4fc",
        "showInput": false
      },
      "source": [
        "The Bayesian optimization loop is as follows (running the code may take a while)."
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "originalKey": "520ac886-fb13-4148-839c-2f1197d97628",
        "collapsed": false,
        "requestMsgId": "d044bdc0-0516-4138-991d-7f7f5c6e597a",
        "executionStartTime": 1679377503648,
        "executionStopTime": 1679377735278,
        "customOutput": null,
        "code_folding": [],
        "hidden_ranges": []
      },
      "source": [
        "algos = [\"EUBO\", \"rand\"]\n",
        "\n",
        "NUM_TRIALS = 3 if not SMOKE_TEST else 2\n",
        "NUM_BATCHES = 30 if not SMOKE_TEST else 2\n",
        "\n",
        "dim = 4\n",
        "NUM_RESTARTS = 3\n",
        "RAW_SAMPLES = 512 if not SMOKE_TEST else 8\n",
        "q = 2  # number of points per query\n",
        "q_comp = 1  # number of comparisons per query\n",
        "\n",
        "# initial evals\n",
        "best_vals = {}  # best observed values\n",
        "for algo in algos:\n",
        "    best_vals[algo] = []\n",
        "\n",
        "# average over multiple trials\n",
        "for i in range(NUM_TRIALS):\n",
        "    torch.manual_seed(i)\n",
        "    np.random.seed(i)\n",
        "    data = {}\n",
        "    models = {}\n",
        "\n",
        "    # Create initial data\n",
        "    init_X, init_y = generate_data(q, dim=dim)\n",
        "    comparisons = generate_comparisons(init_y, q_comp, noise=noise)\n",
        "    # X are within the unit cube\n",
        "    bounds = torch.stack([torch.zeros(dim), torch.ones(dim)])\n",
        "\n",
        "    for algo in algos:\n",
        "        best_vals[algo].append([])\n",
        "        data[algo] = (init_X, comparisons)\n",
        "        _, models[algo] = init_and_fit_model(init_X, comparisons)\n",
        "\n",
        "        best_next_y = utility(init_X).max().item()\n",
        "        best_vals[algo][-1].append(best_next_y)\n",
        "\n",
        "    # we make additional NUM_BATCHES comparison queries after the initial observation\n",
        "    for j in range(1, NUM_BATCHES + 1):\n",
        "        for algo in algos:\n",
        "            model = models[algo]\n",
        "            if algo == \"EUBO\":\n",
        "                # create the acquisition function object\n",
        "                acq_func = AnalyticExpectedUtilityOfBestOption(pref_model=model)\n",
        "                # optimize and get new observation\n",
        "                next_X, acq_val = optimize_acqf(\n",
        "                    acq_function=acq_func,\n",
        "                    bounds=bounds,\n",
        "                    q=q,\n",
        "                    num_restarts=NUM_RESTARTS,\n",
        "                    raw_samples=RAW_SAMPLES,\n",
        "                )\n",
        "            else:\n",
        "                # randomly sample data\n",
        "                next_X, _ = generate_data(q, dim=dim)\n",
        "\n",
        "            # update data\n",
        "            X, comps = data[algo]\n",
        "            X, comps = make_new_data(X, next_X, comps, q_comp)\n",
        "            data[algo] = (X, comps)\n",
        "\n",
        "            # refit models\n",
        "            _, models[algo] = init_and_fit_model(X, comps)\n",
        "\n",
        "            # record the best observed values so far\n",
        "            max_val = utility(X).max().item()\n",
        "            best_vals[algo][-1].append(max_val)"
      ],
      "execution_count": 7,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "originalKey": "91928bb9-e627-42dc-93b5-446944a9532d",
        "showInput": false
      },
      "source": [
        "### Plot the results\n",
        "\n",
        "The plot below shows the best objective value observed at each step of the optimization for each of the acquisition functions. The error bars represent the 95% confidence intervals for the sample mean at that step in the optimization across the trial runs."
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "originalKey": "55da8504-af9b-4e88-a69e-2253ea614ce0",
        "showInput": true,
        "customInput": null,
        "collapsed": false,
        "requestMsgId": "640b62b5-042f-44fd-a6ad-14f2a7129067",
        "customOutput": null,
        "executionStartTime": 1679377735395,
        "executionStopTime": 1679377738125
      },
      "source": [
        "from matplotlib import pyplot as plt\n",
        "\n",
        "\n",
        "%matplotlib inline\n",
        "\n",
        "plt.rcParams.update({\"font.size\": 14})\n",
        "\n",
        "algo_labels = {\n",
        "    \"rand\": \"Random Exploration\",\n",
        "    \"EUBO\": \"EUBO\",\n",
        "}\n",
        "\n",
        "\n",
        "def ci(y):\n",
        "    return 1.96 * y.std(axis=0) / np.sqrt(y.shape[0])\n",
        "\n",
        "\n",
        "# the utility function is maximized at the full vector of 1\n",
        "optimal_val = utility(torch.tensor([[1] * dim])).item()\n",
        "iters = list(range(NUM_BATCHES + 1))\n",
        "\n",
        "fig, ax = plt.subplots(1, 1, figsize=(8, 6))\n",
        "# plot the optimal value\n",
        "ax.plot(\n",
        "    iters,\n",
        "    [optimal_val] * len(iters),\n",
        "    label=\"Optimal Function Value\",\n",
        "    color=\"black\",\n",
        "    linewidth=1.5,\n",
        ")\n",
        "\n",
        "# plot the the best observed value from each algorithm\n",
        "for algo in algos:\n",
        "    ys = np.vstack(best_vals[algo])\n",
        "    ax.errorbar(\n",
        "        iters, ys.mean(axis=0), yerr=ci(ys), label=algo_labels[algo], linewidth=1.5\n",
        "    )\n",
        "\n",
        "ax.set(\n",
        "    xlabel=f\"Number of queries (q = {q}, num_comparisons = {q_comp})\",\n",
        "    ylabel=\"Best observed value\",\n",
        "    title=f\"{dim}-dim weighted vector sum\",\n",
        ")\n",
        "ax.legend(loc=\"best\")"
      ],
      "execution_count": 8,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": "<matplotlib.legend.Legend at 0x7faa22beb3a0>"
          },
          "metadata": {
            "bento_obj_id": "140368704091040"
          },
          "execution_count": 8
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": "<Figure size 576x432 with 1 Axes>",
            "image/png": "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\n"
          },
          "metadata": {
            "bento_obj_id": "140368725957120",
            "needs_background": "light"
          }
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "originalKey": "37fbe9bf-e19b-43bb-9ada-5dbcd40a46e5",
        "showInput": false,
        "code_folding": [],
        "hidden_ranges": []
      },
      "source": [
        "### References\n",
        "\n",
        "[1] Wei Chu, and Zoubin Ghahramani. 2005. “Preference Learning with Gaussian Processes.” In Proceedings of the 22Nd International Conference on Machine Learning, 137–44. ICML ’05. New York, NY, USA: ACM.\n",
        "\n",
        "[2] Eric Brochu, Vlad M. Cora, and Nando de Freitas. 2010. “A Tutorial on Bayesian Optimization of Expensive Cost Functions, with Application to Active User Modeling and Hierarchical Reinforcement Learning.” arXiv [cs.LG]. arXiv.\n",
        "\n",
        "[3] Javier González, Zhenwen Dai, Andreas Damianou, and Neil D. Lawrence. 2017. “Preferential Bayesian Optimization.” In Proceedings of the 34th International Conference on Machine Learning, edited by Doina Precup and Yee Whye Teh, 70:1282–91. Proceedings of Machine Learning Research. International Convention Centre, Sydney, Australia: PMLR.\n",
        "\n",
        "[4] Zhiyuan Jerry Lin, Raul Astudillo, Peter I. Frazier, and Eytan Bakshy, Preference Exploration for Efficient Bayesian Optimization with Multiple Outcomes. AISTATS, 2022. https://arxiv.org/abs/2203.11382\n",
        "\n",
        "[5] Raul Astudillo, Zhiyuan Jerry Lin, Eytan Bakshy, and Peter I. Frazier, qEUBO: A Decision-Theoretic Acquisition Function for Preferential Bayesian Optimization. AISTATS, 2023.\n",
        ""
      ]
    }
  ]
}
