{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "9ff2e245",
   "metadata": {},
   "source": [
    "### RESCUE Modular Demo: Multi-Objective Multi-Fidelity Hyperparameter Optimization\n",
    "\n",
    "This notebook demonstrates the **modular functionalities** of the RESCUE (causal) algorithm for optimizing hyperparameters of a Random Forest model using the [YAHPO Gym](https://github.com/slds-lmu/yahpo_gym) [1] benchmark.\n",
    "\n",
    "**Problem**: We are tuning Random Forest hyperparameters to optimize multiple objectives simultaneously.\n",
    "\n",
    "**Design Variables** (4 hyperparameters + 1 fidelity parameter):\n",
    "- `min.node.size`: Minimum node size\n",
    "- `mtry.ratio`: Ratio of features to consider at each split\n",
    "- `num.trees`: Number of trees in the forest\n",
    "- `sample.fraction`: Fraction of samples to use\n",
    "- `trainsize`: Training set size (fidelity parameter)\n",
    "\n",
    "**Objectives** (minimize all three):\n",
    "1. `mmce`: Mean misclassification error (classification error)\n",
    "2. `nf`: Number of features used\n",
    "3. `ias`: Interaction strength of features\n",
    "\n",
    "**Fidelity Parameter:**\n",
    "- `trainsize`: Controls the fidelity level (larger training set = higher fidelity, more expensive)\n",
    "\n",
    "**Goal**: Find Pareto-optimal hyperparameter configurations that minimize all three objectives, while efficiently utilizing the multi-fidelity setting (smaller `trainsize` = cheaper evaluations).\n",
    "\n",
    "For convenience, we wrap the benchmark instance using the `HPORanger` class, which inherits from BoTorch's problem class and provides a standardized interface for the RESCUE algorithm.\n",
    "\n",
    "[1] [Pfisterer, Florian, et al. \"Yahpo gym-an efficient multi-objective multi-fidelity benchmark for hyperparameter optimization.\" International Conference on Automated Machine Learning. PMLR, 2022.](https://proceedings.mlr.press/v188/pfisterer22a/pfisterer22a.pdf)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ac1673ff",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "# Ensure we're in the rescue/ directory (where data/ and rescue/ folders are)\n",
    "if not os.path.exists('data'):\n",
    "    os.chdir('..')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "70228356",
   "metadata": {},
   "source": [
    "#### Device and data type setup"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "f3e759db",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from torch import Tensor\n",
    "\n",
    "tkwargs = {\n",
    "    \"device\": \"cuda\" if torch.cuda.is_available() else \"cpu\",\n",
    "    \"dtype\": torch.double,\n",
    "    }\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8c2e2c6e",
   "metadata": {},
   "source": [
    "#### Problem setup"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "2affbacc",
   "metadata": {},
   "outputs": [],
   "source": [
    "from rescue.problems.hpo.multi_objective import HPORanger\n",
    "\n",
    "problem = HPORanger(negate=True).to(**tkwargs)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b3383985",
   "metadata": {},
   "source": [
    "#### Define the cost function\n",
    "\n",
    "The evaluation cost depends exponentially on the fidelity level:where $s = 1.0$ represents the highest fidelity (full training set).\n",
    "$$\\text{cost}(s) = \\exp(4.8 \\times s)$$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "d62778ae",
   "metadata": {},
   "outputs": [],
   "source": [
    "def cost_fn(X: Tensor) -> Tensor:\n",
    "    \"\"\" cost(fidelity) = exp(4.8 * fidelity) \"\"\"\n",
    "    return torch.exp(torch.tensor(4.8) * X[..., -1:])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cef25c04",
   "metadata": {},
   "source": [
    "#### Load the observational data\n",
    "\n",
    "We have provided example observational data. When the Directed Acyclic Graph (DAG) is unknown, we learn the Causal Performance Model (CPM) using causal discovery methods such as DirectLiNGAM [2] with observational data.\n",
    "\n",
    "[2] [Shimizu, Shohei, et al. \"DirectLiNGAM: A direct method for learning a linear non-Gaussian structural equation model.\" Journal of Machine Learning Research-JMLR 12.Apr (2011): 1225-1248.](https://www.jmlr.org/papers/volume12/shimizu11a/shimizu11a.pdf)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "0fe12920",
   "metadata": {},
   "outputs": [],
   "source": [
    "from data import load_observational_data\n",
    "obs_data_df = load_observational_data(sample_seed=1, problem=problem)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "61737c77",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>min.node.size</th>\n",
       "      <th>mtry.ratio</th>\n",
       "      <th>num.trees</th>\n",
       "      <th>sample.fraction</th>\n",
       "      <th>trainsize</th>\n",
       "      <th>mmce</th>\n",
       "      <th>nf</th>\n",
       "      <th>ias</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>89.573757</td>\n",
       "      <td>0.259802</td>\n",
       "      <td>1101.455399</td>\n",
       "      <td>0.876603</td>\n",
       "      <td>0.145546</td>\n",
       "      <td>-0.192024</td>\n",
       "      <td>-5.0</td>\n",
       "      <td>-0.134001</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>87.537065</td>\n",
       "      <td>0.938634</td>\n",
       "      <td>1711.225718</td>\n",
       "      <td>0.754223</td>\n",
       "      <td>0.089229</td>\n",
       "      <td>-0.225335</td>\n",
       "      <td>-5.0</td>\n",
       "      <td>-0.436281</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>56.093528</td>\n",
       "      <td>0.662975</td>\n",
       "      <td>707.842062</td>\n",
       "      <td>0.386389</td>\n",
       "      <td>0.050390</td>\n",
       "      <td>-0.239471</td>\n",
       "      <td>-5.0</td>\n",
       "      <td>-0.073752</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>4.617802</td>\n",
       "      <td>0.729973</td>\n",
       "      <td>799.397464</td>\n",
       "      <td>0.501758</td>\n",
       "      <td>0.187297</td>\n",
       "      <td>-0.151939</td>\n",
       "      <td>-5.0</td>\n",
       "      <td>-0.978741</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>66.664095</td>\n",
       "      <td>0.584764</td>\n",
       "      <td>400.865689</td>\n",
       "      <td>0.195747</td>\n",
       "      <td>0.269830</td>\n",
       "      <td>-0.210201</td>\n",
       "      <td>-5.0</td>\n",
       "      <td>-0.244053</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>501</th>\n",
       "      <td>20.092210</td>\n",
       "      <td>0.998862</td>\n",
       "      <td>1418.760274</td>\n",
       "      <td>0.242146</td>\n",
       "      <td>0.069810</td>\n",
       "      <td>-0.222645</td>\n",
       "      <td>-5.0</td>\n",
       "      <td>-0.206671</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>502</th>\n",
       "      <td>79.536949</td>\n",
       "      <td>0.154846</td>\n",
       "      <td>317.027916</td>\n",
       "      <td>0.513449</td>\n",
       "      <td>0.063984</td>\n",
       "      <td>-0.243754</td>\n",
       "      <td>-5.0</td>\n",
       "      <td>-0.026319</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>503</th>\n",
       "      <td>24.079713</td>\n",
       "      <td>0.324062</td>\n",
       "      <td>213.074626</td>\n",
       "      <td>0.320226</td>\n",
       "      <td>0.107678</td>\n",
       "      <td>-0.194546</td>\n",
       "      <td>-5.0</td>\n",
       "      <td>-0.263299</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>504</th>\n",
       "      <td>23.271441</td>\n",
       "      <td>0.898440</td>\n",
       "      <td>484.663032</td>\n",
       "      <td>0.672361</td>\n",
       "      <td>0.076607</td>\n",
       "      <td>-0.201057</td>\n",
       "      <td>-5.0</td>\n",
       "      <td>-0.748941</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>505</th>\n",
       "      <td>13.143229</td>\n",
       "      <td>0.735045</td>\n",
       "      <td>1651.529203</td>\n",
       "      <td>0.540948</td>\n",
       "      <td>0.074665</td>\n",
       "      <td>-0.201054</td>\n",
       "      <td>-5.0</td>\n",
       "      <td>-0.862758</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>506 rows × 8 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     min.node.size  mtry.ratio    num.trees  sample.fraction  trainsize  \\\n",
       "0        89.573757    0.259802  1101.455399         0.876603   0.145546   \n",
       "1        87.537065    0.938634  1711.225718         0.754223   0.089229   \n",
       "2        56.093528    0.662975   707.842062         0.386389   0.050390   \n",
       "3         4.617802    0.729973   799.397464         0.501758   0.187297   \n",
       "4        66.664095    0.584764   400.865689         0.195747   0.269830   \n",
       "..             ...         ...          ...              ...        ...   \n",
       "501      20.092210    0.998862  1418.760274         0.242146   0.069810   \n",
       "502      79.536949    0.154846   317.027916         0.513449   0.063984   \n",
       "503      24.079713    0.324062   213.074626         0.320226   0.107678   \n",
       "504      23.271441    0.898440   484.663032         0.672361   0.076607   \n",
       "505      13.143229    0.735045  1651.529203         0.540948   0.074665   \n",
       "\n",
       "         mmce   nf       ias  \n",
       "0   -0.192024 -5.0 -0.134001  \n",
       "1   -0.225335 -5.0 -0.436281  \n",
       "2   -0.239471 -5.0 -0.073752  \n",
       "3   -0.151939 -5.0 -0.978741  \n",
       "4   -0.210201 -5.0 -0.244053  \n",
       "..        ...  ...       ...  \n",
       "501 -0.222645 -5.0 -0.206671  \n",
       "502 -0.243754 -5.0 -0.026319  \n",
       "503 -0.194546 -5.0 -0.263299  \n",
       "504 -0.201057 -5.0 -0.748941  \n",
       "505 -0.201054 -5.0 -0.862758  \n",
       "\n",
       "[506 rows x 8 columns]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "obs_data_df"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "26872e3e",
   "metadata": {},
   "source": [
    "#### Learn the causal performance model\n",
    "Users can use their causal discovery method of choice as long as it produces a Directed Acyclic Graph (DAG) and returns it as a `Networkx.DiGraph` object. Additionally, domain knowledge can be incorporated at this stage by simply drawing/manipulating the DAG. When the DAG is known, observational data is not required and causal discovery setup can be ignored."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "c32f27f7",
   "metadata": {},
   "outputs": [],
   "source": [
    "from rescue.models.causal_model import CausalPerformanceModel\n",
    "\n",
    "CPM = CausalPerformanceModel(\n",
    "        data=obs_data_df,\n",
    "        design_variables=problem.design_var_names,\n",
    "        objective_variables=problem.objective_var_names,\n",
    "        is_multifidelity=True,\n",
    "        is_design_var_independent=False,\n",
    "        fidelity_param_name='trainsize',\n",
    "        use_default_bk=True,\n",
    ")\n",
    "causal_graph = CPM.causal_model(causal_discovery='DirectLiNGAM')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9611a668",
   "metadata": {},
   "source": [
    "#### Optionally visualize the discovered DAG"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "7709dfb3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<IPython.core.display.Image object>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from networkx.drawing.nx_pydot import to_pydot\n",
    "import pydot\n",
    "from IPython.display import Image\n",
    "\n",
    "pydot_graph = to_pydot(causal_graph)\n",
    "\n",
    "dot_data = pydot_graph.to_string()\n",
    "(dot_graph,) = pydot.graph_from_dot_data(dot_data)\n",
    "png_data = dot_graph.create_png()\n",
    "Image(png_data)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ad97bfc3",
   "metadata": {},
   "source": [
    "#### Map the causal model to a PyTorch Neural Network (NN) to enable GPU support and retain gradients\n",
    "We sample from the interventional distribution $E[Y | do(X = x)]$, $\\sqrt{V[Y | do(X = x)]}$ of the causal model and train a neural network. Users can use their custom NN architecture as long as the NN returns a tuple of predicted mean and standard deviation of shape `num_sample x num_outcome` (objectives+constraints) or `batch_shape x num_sample x num_outcome`."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "f6255847",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Fitting causal mechanism of node ias: 100%|██████████| 8/8 [00:00<00:00, 49.74it/s]    \n",
      "Performing causal interventions: 100%|██████████| 30/30 [00:08<00:00,  3.38batch/s, interventions=300/300]\n",
      "Training CausalMeanVarSurrogateNN: 100%|██████████| 200/200 [00:00<00:00, 476.04epoch/s, loss=0.857]\n"
     ]
    }
   ],
   "source": [
    "from botorch.utils.sampling import draw_sobol_samples\n",
    "from botorch.utils.transforms import normalize\n",
    "from rescue.models.causal_model import CausalMeanVarSurrogateNN\n",
    "from rescue.models import fit_causal_model\n",
    "\n",
    "# Select some random intervention X values for performing causal inference\n",
    "x_intervention_val = draw_sobol_samples(\n",
    "    bounds=problem.bounds, \n",
    "    n=300, \n",
    "    q=1).squeeze(1)\n",
    "\n",
    "# Define the NN acrchitecture\n",
    "mapped_model = CausalMeanVarSurrogateNN(\n",
    "            input_dim=problem.dim, \n",
    "            output_dim = len(\n",
    "                problem.objective_var_names),\n",
    "        ).to(**tkwargs)\n",
    "\n",
    "# Train the NN\n",
    "causal_net, scm, causal_net_loss = fit_causal_model(\n",
    "    model=mapped_model,\n",
    "    observational_data=obs_data_df,\n",
    "    causal_graph=causal_graph, \n",
    "    design_variables=problem.design_var_names, \n",
    "    outcome_variables=problem.objective_var_names, \n",
    "    epochs=200,\n",
    "    x_intervention_val=x_intervention_val,                  \n",
    "    **tkwargs\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2a6ac959",
   "metadata": {},
   "source": [
    "#### Utility function for the multi-output Causal Gaussian Process (CGP) model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "002b021e",
   "metadata": {},
   "outputs": [],
   "source": [
    "from gpytorch.kernels import RBFKernel\n",
    "from gpytorch.mlls.exact_marginal_log_likelihood import ExactMarginalLogLikelihood\n",
    "from gpytorch.likelihoods import MultitaskGaussianLikelihood\n",
    "from botorch import fit_gpytorch_mll\n",
    "from rescue.models import CausalMultitaskMultifidelityGP\n",
    "\n",
    "def multioutput_multifidelity_causal_gp_model(\n",
    "    train_x: Tensor,\n",
    "    train_objectives: Tensor,\n",
    "    causal_net: torch.nn.Module,\n",
    "    train_constraints: None | Tensor = None,\n",
    "    state_dict: None | dict = None\n",
    "    ) -> tuple[ExactMarginalLogLikelihood, CausalMultitaskMultifidelityGP]:\n",
    "\n",
    "    has_constraints = train_constraints is not None\n",
    "    train_y = train_objectives.clone()\n",
    "    if has_constraints:\n",
    "        train_y = torch.cat([train_y, train_constraints], dim=-1)\n",
    "    likelihood = MultitaskGaussianLikelihood(\n",
    "        num_tasks=train_y.shape[-1]\n",
    "    )\n",
    "    model = CausalMultitaskMultifidelityGP( \n",
    "            train_X=train_x,\n",
    "            train_Y=train_y,\n",
    "            causal_net=causal_net,\n",
    "            likelihood=likelihood,\n",
    "            data_covar_module=RBFKernel(\n",
    "                # ignore fidelity dimension\n",
    "                ard_num_dims=train_x.shape[-1] - 1,\n",
    "            ),\n",
    "            fidelity_covar_module=RBFKernel(\n",
    "                ard_num_dims=1,\n",
    "            ),\n",
    "        )\n",
    "    mll = ExactMarginalLogLikelihood(likelihood, model)\n",
    "    if state_dict is not None:\n",
    "        model.load_state_dict(state_dict)          \n",
    "    # Freeze causal net parameters\n",
    "    # This is important otherwise, the causal \n",
    "    # net will be trained along with the GP\n",
    "    # which we don't want.\n",
    "    for param in model.mean_module.causal_net.parameters():\n",
    "        param.requires_grad = False\n",
    "    for param in model.covar_module.causal_net.parameters():\n",
    "        param.requires_grad = False\n",
    "    return mll, model"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d885514d",
   "metadata": {},
   "source": [
    "#### Perform initial interventions to fit the CGP model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "ca9e9ba8",
   "metadata": {},
   "outputs": [],
   "source": [
    "from rescue.algorithms.initial_sampling import GenerateInitialSample\n",
    "\n",
    "sampling = GenerateInitialSample(\n",
    "    problem=problem,\n",
    "    bounds=problem.bounds,\n",
    "    has_constraints=False\n",
    ")\n",
    "train_x, train_obj, _ = (\n",
    "    sampling.generate_initial_data_multifidelity(\n",
    "        n_full_fidelity_equiv=1.05,\n",
    "        cost_fn=cost_fn,\n",
    "        is_discrete=False,\n",
    "    )\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8f833dbf",
   "metadata": {},
   "source": [
    "#### Helper function for Causal Knowledge Gradient (C-HVKG) acquisition function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "08ae2b8e",
   "metadata": {},
   "outputs": [],
   "source": [
    "from botorch.acquisition.fixed_feature import FixedFeatureAcquisitionFunction\n",
    "from botorch.acquisition.multi_objective.objective import (\n",
    "    IdentityMCMultiOutputObjective\n",
    ")\n",
    "from botorch.optim import optimize_acqf\n",
    "from botorch.sampling.normal import SobolQMCNormalSampler\n",
    "from rescue.acquisition.causal_knowledge_gradient import causal_hv_value_function\n",
    "\n",
    "standard_bounds = torch.zeros(2, problem.bounds.shape[1], **tkwargs)\n",
    "standard_bounds[1] = 1\n",
    "\n",
    "target_fidelities = {problem.dim - 1: 1.0}\n",
    "normalized_target_fidelities = {}\n",
    "for idx, fidelity in target_fidelities.items():\n",
    "    lb = problem.bounds[0, idx].item()\n",
    "    ub = problem.bounds[1, idx].item()\n",
    "    normalized_target_fidelities[idx] = (fidelity - lb) / (ub - lb)\n",
    "\n",
    "fidelity_dims, fidelity_targets = zip(\n",
    "    *normalized_target_fidelities.items()\n",
    "    )\n",
    "non_fidelity_dims = list(set(range(problem.dim)) - set(fidelity_dims))\n",
    "\n",
    "sampler = SobolQMCNormalSampler(sample_shape=torch.Size([32]))\n",
    "objective = IdentityMCMultiOutputObjective(outcomes=[0, 1, 2])\n",
    "\n",
    "def causal_curr_value_function(model, causal_net):\n",
    "    curr_val_acqf = FixedFeatureAcquisitionFunction(\n",
    "        acq_function=causal_hv_value_function(\n",
    "            model=model,\n",
    "            causal_model=causal_net,\n",
    "            causal_weight=1.0,\n",
    "            ref_point=problem.ref_point,\n",
    "            sampler=sampler,\n",
    "            use_posterior_mean=True,\n",
    "            objective=objective,\n",
    "        ),\n",
    "        d=problem.dim,\n",
    "        columns=fidelity_dims,\n",
    "        values=fidelity_targets,\n",
    "    )\n",
    "\n",
    "    # optimize current value acqf\n",
    "    _, current_value = optimize_acqf(\n",
    "        acq_function=curr_val_acqf,\n",
    "        bounds=standard_bounds[:, non_fidelity_dims],\n",
    "        q=1,\n",
    "        num_restarts=1,\n",
    "        raw_samples=2*512,\n",
    "        return_best_only=True,\n",
    "        options={\n",
    "            \"nonnegative\": True, \n",
    "            \"maxiter\": 200\n",
    "        },\n",
    "    )\n",
    "    return current_value"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "32f958a3",
   "metadata": {},
   "outputs": [],
   "source": [
    "from botorch.models.deterministic import GenericDeterministicModel\n",
    "from botorch.acquisition.cost_aware import InverseCostWeightedUtility\n",
    "from botorch.acquisition.utils import project_to_target_fidelity\n",
    "from botorch.utils.transforms import unnormalize\n",
    "from rescue.acquisition.optim import gen_one_shot_hvkg_initial_conditions\n",
    "from rescue.acquisition.causal_knowledge_gradient import qMultiFidelityCausalHypervolumeKnowledgeGradient\n",
    "\n",
    "cost_model = GenericDeterministicModel(cost_fn)\n",
    "cost_aware_utility = InverseCostWeightedUtility(cost_model=cost_model)\n",
    "\n",
    "def _project_to_target_fidelity(X: Tensor) -> Tensor:\n",
    "    return project_to_target_fidelity(\n",
    "        X=X,\n",
    "        d=problem.dim,\n",
    "        target_fidelities=normalized_target_fidelities,\n",
    "    )  \n",
    "\n",
    "def optimize_causal_hvkg(model, causal_net):\n",
    "    # Compute current value function\n",
    "    current_value = causal_curr_value_function(\n",
    "        model=model,\n",
    "        causal_net=causal_net,\n",
    "    )\n",
    "    acq_func = qMultiFidelityCausalHypervolumeKnowledgeGradient(\n",
    "            model=model,\n",
    "            ref_point=problem.ref_point,\n",
    "            num_fantasies=4,\n",
    "            num_pareto=5,\n",
    "            current_value=current_value,\n",
    "            cost_aware_utility=cost_aware_utility,\n",
    "            target_fidelities=normalized_target_fidelities,\n",
    "            project=_project_to_target_fidelity,\n",
    "            objective=objective,\n",
    "        )\n",
    "\n",
    "    candidates, vals = optimize_acqf(\n",
    "        acq_function=acq_func,\n",
    "        bounds=standard_bounds,\n",
    "        q=1,\n",
    "        num_restarts=5,\n",
    "        raw_samples=2*512,\n",
    "        ic_generator=gen_one_shot_hvkg_initial_conditions,\n",
    "        options={\n",
    "            \"batch_limit\": 5,\n",
    "            \"maxiter\": 200\n",
    "        },\n",
    "        sequential=True\n",
    "    )\n",
    "    if vals.item() == 0.0:\n",
    "        # The problem will internally set to lowest fidelity\n",
    "        # even if we set it to 0.0 here.\n",
    "        candidates[:, -1] = 0.0\n",
    "    return unnormalize(candidates.detach(), bounds=problem.bounds)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "87765f54",
   "metadata": {},
   "source": [
    "#### Utility for evaluating the optimization performance\n",
    "Compute the Pareto front at the target fidelity using NSGA-II from the CGP posterior and evaluate it on the true objective values."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "20d32630",
   "metadata": {},
   "outputs": [],
   "source": [
    "from botorch.utils.multi_objective.pareto import (\n",
    "    is_non_dominated,\n",
    ") \n",
    "from botorch.utils.multi_objective.box_decompositions.non_dominated import (\n",
    "    FastNondominatedPartitioning,\n",
    ")\n",
    "import numpy as np\n",
    "from rescue.metrics.optimization_pref import nsga2_posterior_pareto\n",
    "\n",
    "\n",
    "def evaluate_regret(model) -> float:\n",
    "    res = nsga2_posterior_pareto(\n",
    "                model=model,\n",
    "                input_dim_without_fid=problem.dim - 1,\n",
    "                num_objectives=problem.num_objectives,\n",
    "                objective_indices=[0, 1, 2],\n",
    "                is_mf_model=True,\n",
    "                device=tkwargs['device'],\n",
    "                dtype=tkwargs['dtype'],\n",
    "                project_to_target_fidelity=_project_to_target_fidelity,\n",
    "            )\n",
    "    # These are the Pareto optimial points found by NSGA-II\n",
    "    # on the CGP posterior\n",
    "    X = torch.tensor(\n",
    "        res.X,\n",
    "        **tkwargs,\n",
    "    )\n",
    "\n",
    "    X = _project_to_target_fidelity(X)\n",
    "\n",
    "    # determine Pareto set of designs under model\n",
    "    with torch.no_grad():\n",
    "        preds = model.posterior(X.unsqueeze(-2)).mean.squeeze(-2)\n",
    "    X = unnormalize(X, problem.bounds)\n",
    "\n",
    "    pareto_mask = is_non_dominated(preds)\n",
    "    X = X[pareto_mask]            \n",
    "    Y = problem(X)\n",
    "    partitioning = FastNondominatedPartitioning(ref_point=problem.ref_point, Y=Y)\n",
    "    volume = partitioning.compute_hypervolume().item()\n",
    "    return np.log10(problem.max_hv - volume)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9feffba8",
   "metadata": {},
   "source": [
    "#### Main optimization loop\n",
    "Note that we could also update the causal performance model at runtime when the observational data is sparse."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "a5b1d1f5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Budget: 1.15/5.00, Regret: -0.0181\n",
      "Budget: 2.31/5.00, Regret: -0.0210\n",
      "Budget: 3.46/5.00, Regret: -0.1034\n",
      "Budget: 4.62/5.00, Regret: -0.0913\n",
      "Budget: 5.77/5.00, Regret: -0.1198\n"
     ]
    }
   ],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "\n",
    "curr_cost = 0.0\n",
    "budget = 5.0\n",
    "\n",
    "res = []\n",
    "\n",
    "while curr_cost < budget:\n",
    "    mll, model = multioutput_multifidelity_causal_gp_model(\n",
    "        train_x=train_x,\n",
    "        train_objectives=train_obj,\n",
    "        causal_net=causal_net,\n",
    "    )\n",
    "    fit_gpytorch_mll(mll)\n",
    "\n",
    "    # Optimize the Causal HVKG acquisition function\n",
    "    new_x = optimize_causal_hvkg(model, causal_net)\n",
    "\n",
    "    # Obtain new observations\n",
    "    new_objectives = problem(new_x)\n",
    "\n",
    "    # Update training data\n",
    "    train_x = torch.cat([train_x, new_x], dim=0)\n",
    "    train_obj = torch.cat([train_obj, new_objectives], dim=0)\n",
    "\n",
    "    # Update current cost\n",
    "    curr_cost += cost_fn(new_x).item()\n",
    "\n",
    "    # Evaluate regret at runtime\n",
    "    # NOTE: This will be costly since evaluations are performed\n",
    "    # at the target fidelity at runtime\n",
    "    regret = evaluate_regret(model)\n",
    "\n",
    "    res.append((curr_cost, regret))\n",
    "\n",
    "    print(\n",
    "        f\"Budget: {curr_cost:.2f}/{budget:.2f}, \"\n",
    "        f\"Regret: {regret:.4f}\"\n",
    "    )"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "87318574",
   "metadata": {},
   "source": [
    "#### Plot the results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "cbf787be",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "costs, regrets = zip(*res)\n",
    "\n",
    "plt.plot(costs, regrets, marker='o')\n",
    "plt.xlabel('Cost')\n",
    "plt.ylabel('Log Regret')\n",
    "plt.title('Regret vs Cost')\n",
    "plt.grid(True)\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "rescue",
   "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.10.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
