{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "90151c0b",
   "metadata": {},
   "source": [
    "### RESCUE Algorithm Demo: Multi-Objective Multi-Fidelity Hyperparameter Optimization\n",
    "\n",
    "**Problem**: We are tuning XGBoost hyperparameters using the [YAHPO Gym](https://github.com/slds-lmu/yahpo_gym) [1] benchmark.\n",
    "\n",
    "**Design Variables** (12 hyperparameters + 1 fidelity parameter):\n",
    "- `alpha`, `colsample_bylevel`, `colsample_bytree`, `eta`, `gamma`, `lambda`, `max_depth`, `min_child_weight`, `nrounds`, `rate_drop`, `skip_drop`, `subsample`\n",
    "- `trainsize` (fidelity parameter)\n",
    "\n",
    "**Objectives** (minimize both):\n",
    "1. `mmce`: mean misclassification erro\n",
    "2. `rammodel`: model memory footprint\n",
    "\n",
    "**Cost Function**: The evaluation cost depends exponentially on the fidelity level:\n",
    "$$\\text{cost}(s) = \\exp(4.8 \\times s)$$\n",
    "where $s = 1.0$ represents the highest fidelity (full training set).\n",
    "\n",
    "**Goal**: Find Pareto-optimal hyperparameter configurations that minimize both classification error and memory usage, while efficiently utilizing the multi-fidelity setting (smaller `trainsize` = cheaper evaluations).\n",
    "\n",
    "For convenience, we wrap the benchmark instance using the `HPOXGBoost` 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": "dc2f579d",
   "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": "code",
   "execution_count": 1,
   "id": "c21fc57e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "\n",
    "SEED_LIST = [0, 1, 2]\n",
    "INI_BUDGET = 1.05\n",
    "BUDGET = 10.0"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d8584fb6",
   "metadata": {},
   "source": [
    "#### Setup device and data type"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "900fc046",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "\n",
    "tkwargs = {\n",
    "    \"device\": torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\"),\n",
    "    \"dtype\": torch.double,\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "06c8fc21",
   "metadata": {},
   "outputs": [],
   "source": [
    "from rescue.problems.hpo.multi_objective import HPOXGBoost\n",
    "\n",
    "problem = HPOXGBoost(negate=True).to(**tkwargs)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b79b46a1",
   "metadata": {},
   "source": [
    "#### Utility for the cost function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "a5ae421e",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch import Tensor\n",
    "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": "9cd6a481",
   "metadata": {},
   "source": [
    "#### Load the observational data\n",
    "We have given an exmaple observational data. When the Directed acyclic graph (DAG) is unkown, we learn the Causal Performance Model (CPM) using causal discovery methods such as using DirectLiNGAM [2] using 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)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "087f06e8",
   "metadata": {},
   "outputs": [],
   "source": [
    "from data import load_observational_data\n",
    "\n",
    "obs_data = load_observational_data(sample_seed=1, problem=problem)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "9db2d3ee",
   "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>alpha</th>\n",
       "      <th>colsample_bylevel</th>\n",
       "      <th>colsample_bytree</th>\n",
       "      <th>eta</th>\n",
       "      <th>gamma</th>\n",
       "      <th>lambda</th>\n",
       "      <th>max_depth</th>\n",
       "      <th>min_child_weight</th>\n",
       "      <th>nrounds</th>\n",
       "      <th>rate_drop</th>\n",
       "      <th>skip_drop</th>\n",
       "      <th>subsample</th>\n",
       "      <th>trainsize</th>\n",
       "      <th>mmce</th>\n",
       "      <th>rammodel</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.894737</td>\n",
       "      <td>0.274606</td>\n",
       "      <td>0.554998</td>\n",
       "      <td>0.862961</td>\n",
       "      <td>0.440440</td>\n",
       "      <td>0.890738</td>\n",
       "      <td>11.881252</td>\n",
       "      <td>48.918311</td>\n",
       "      <td>1007.400464</td>\n",
       "      <td>0.739329</td>\n",
       "      <td>0.747917</td>\n",
       "      <td>0.447700</td>\n",
       "      <td>0.229049</td>\n",
       "      <td>-0.097604</td>\n",
       "      <td>-0.449033</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.874175</td>\n",
       "      <td>0.939861</td>\n",
       "      <td>0.856985</td>\n",
       "      <td>0.727051</td>\n",
       "      <td>0.257924</td>\n",
       "      <td>0.612742</td>\n",
       "      <td>8.910086</td>\n",
       "      <td>97.985417</td>\n",
       "      <td>1998.909181</td>\n",
       "      <td>0.755874</td>\n",
       "      <td>0.397386</td>\n",
       "      <td>0.197231</td>\n",
       "      <td>0.118358</td>\n",
       "      <td>-0.501016</td>\n",
       "      <td>-0.974403</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.556722</td>\n",
       "      <td>0.669715</td>\n",
       "      <td>0.360062</td>\n",
       "      <td>0.318551</td>\n",
       "      <td>0.099601</td>\n",
       "      <td>0.245975</td>\n",
       "      <td>14.118438</td>\n",
       "      <td>36.487352</td>\n",
       "      <td>931.451351</td>\n",
       "      <td>0.284308</td>\n",
       "      <td>0.244554</td>\n",
       "      <td>0.666712</td>\n",
       "      <td>0.105736</td>\n",
       "      <td>-0.132631</td>\n",
       "      <td>-0.469880</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.037025</td>\n",
       "      <td>0.735373</td>\n",
       "      <td>0.405404</td>\n",
       "      <td>0.446674</td>\n",
       "      <td>0.546228</td>\n",
       "      <td>0.747630</td>\n",
       "      <td>13.999994</td>\n",
       "      <td>19.269077</td>\n",
       "      <td>1409.230710</td>\n",
       "      <td>0.309686</td>\n",
       "      <td>0.693730</td>\n",
       "      <td>0.877194</td>\n",
       "      <td>0.665986</td>\n",
       "      <td>-0.069466</td>\n",
       "      <td>-1.888857</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.663442</td>\n",
       "      <td>0.593069</td>\n",
       "      <td>0.208033</td>\n",
       "      <td>0.106833</td>\n",
       "      <td>0.701988</td>\n",
       "      <td>0.679203</td>\n",
       "      <td>10.157363</td>\n",
       "      <td>56.098568</td>\n",
       "      <td>633.799233</td>\n",
       "      <td>0.543770</td>\n",
       "      <td>0.803507</td>\n",
       "      <td>0.938953</td>\n",
       "      <td>0.272743</td>\n",
       "      <td>-0.086945</td>\n",
       "      <td>-0.399370</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",
       "      <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>556</th>\n",
       "      <td>0.195489</td>\n",
       "      <td>0.899176</td>\n",
       "      <td>0.639845</td>\n",
       "      <td>0.856553</td>\n",
       "      <td>0.398047</td>\n",
       "      <td>0.450351</td>\n",
       "      <td>2.860143</td>\n",
       "      <td>74.136581</td>\n",
       "      <td>86.399376</td>\n",
       "      <td>0.896441</td>\n",
       "      <td>0.100214</td>\n",
       "      <td>0.281047</td>\n",
       "      <td>0.150400</td>\n",
       "      <td>-0.497613</td>\n",
       "      <td>-0.201297</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>557</th>\n",
       "      <td>0.794955</td>\n",
       "      <td>0.820768</td>\n",
       "      <td>0.925278</td>\n",
       "      <td>0.110255</td>\n",
       "      <td>0.642179</td>\n",
       "      <td>0.259249</td>\n",
       "      <td>8.529811</td>\n",
       "      <td>102.655791</td>\n",
       "      <td>1980.599880</td>\n",
       "      <td>0.750367</td>\n",
       "      <td>0.171390</td>\n",
       "      <td>0.950320</td>\n",
       "      <td>0.520340</td>\n",
       "      <td>-0.087726</td>\n",
       "      <td>-1.362312</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>558</th>\n",
       "      <td>0.338276</td>\n",
       "      <td>0.872903</td>\n",
       "      <td>0.556074</td>\n",
       "      <td>0.113861</td>\n",
       "      <td>0.526470</td>\n",
       "      <td>0.412450</td>\n",
       "      <td>7.095758</td>\n",
       "      <td>42.916452</td>\n",
       "      <td>1040.964076</td>\n",
       "      <td>0.487290</td>\n",
       "      <td>0.753198</td>\n",
       "      <td>0.648533</td>\n",
       "      <td>0.424214</td>\n",
       "      <td>-0.084430</td>\n",
       "      <td>-0.672272</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>559</th>\n",
       "      <td>0.010664</td>\n",
       "      <td>0.206336</td>\n",
       "      <td>0.178534</td>\n",
       "      <td>0.925141</td>\n",
       "      <td>0.097187</td>\n",
       "      <td>0.474382</td>\n",
       "      <td>11.898851</td>\n",
       "      <td>16.496240</td>\n",
       "      <td>1564.513104</td>\n",
       "      <td>0.978272</td>\n",
       "      <td>0.815646</td>\n",
       "      <td>0.207048</td>\n",
       "      <td>0.069810</td>\n",
       "      <td>-0.494963</td>\n",
       "      <td>-0.716667</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>560</th>\n",
       "      <td>0.931027</td>\n",
       "      <td>0.088883</td>\n",
       "      <td>0.999396</td>\n",
       "      <td>0.813759</td>\n",
       "      <td>0.888284</td>\n",
       "      <td>0.190319</td>\n",
       "      <td>14.297694</td>\n",
       "      <td>3.061191</td>\n",
       "      <td>133.081141</td>\n",
       "      <td>0.986310</td>\n",
       "      <td>0.847211</td>\n",
       "      <td>0.861616</td>\n",
       "      <td>0.189239</td>\n",
       "      <td>-0.086977</td>\n",
       "      <td>-0.356960</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>561 rows × 15 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "        alpha  colsample_bylevel  colsample_bytree       eta     gamma  \\\n",
       "0    0.894737           0.274606          0.554998  0.862961  0.440440   \n",
       "1    0.874175           0.939861          0.856985  0.727051  0.257924   \n",
       "2    0.556722           0.669715          0.360062  0.318551  0.099601   \n",
       "3    0.037025           0.735373          0.405404  0.446674  0.546228   \n",
       "4    0.663442           0.593069          0.208033  0.106833  0.701988   \n",
       "..        ...                ...               ...       ...       ...   \n",
       "556  0.195489           0.899176          0.639845  0.856553  0.398047   \n",
       "557  0.794955           0.820768          0.925278  0.110255  0.642179   \n",
       "558  0.338276           0.872903          0.556074  0.113861  0.526470   \n",
       "559  0.010664           0.206336          0.178534  0.925141  0.097187   \n",
       "560  0.931027           0.088883          0.999396  0.813759  0.888284   \n",
       "\n",
       "       lambda  max_depth  min_child_weight      nrounds  rate_drop  skip_drop  \\\n",
       "0    0.890738  11.881252         48.918311  1007.400464   0.739329   0.747917   \n",
       "1    0.612742   8.910086         97.985417  1998.909181   0.755874   0.397386   \n",
       "2    0.245975  14.118438         36.487352   931.451351   0.284308   0.244554   \n",
       "3    0.747630  13.999994         19.269077  1409.230710   0.309686   0.693730   \n",
       "4    0.679203  10.157363         56.098568   633.799233   0.543770   0.803507   \n",
       "..        ...        ...               ...          ...        ...        ...   \n",
       "556  0.450351   2.860143         74.136581    86.399376   0.896441   0.100214   \n",
       "557  0.259249   8.529811        102.655791  1980.599880   0.750367   0.171390   \n",
       "558  0.412450   7.095758         42.916452  1040.964076   0.487290   0.753198   \n",
       "559  0.474382  11.898851         16.496240  1564.513104   0.978272   0.815646   \n",
       "560  0.190319  14.297694          3.061191   133.081141   0.986310   0.847211   \n",
       "\n",
       "     subsample  trainsize      mmce  rammodel  \n",
       "0     0.447700   0.229049 -0.097604 -0.449033  \n",
       "1     0.197231   0.118358 -0.501016 -0.974403  \n",
       "2     0.666712   0.105736 -0.132631 -0.469880  \n",
       "3     0.877194   0.665986 -0.069466 -1.888857  \n",
       "4     0.938953   0.272743 -0.086945 -0.399370  \n",
       "..         ...        ...       ...       ...  \n",
       "556   0.281047   0.150400 -0.497613 -0.201297  \n",
       "557   0.950320   0.520340 -0.087726 -1.362312  \n",
       "558   0.648533   0.424214 -0.084430 -0.672272  \n",
       "559   0.207048   0.069810 -0.494963 -0.716667  \n",
       "560   0.861616   0.189239 -0.086977 -0.356960  \n",
       "\n",
       "[561 rows x 15 columns]"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "obs_data"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "206baa69",
   "metadata": {},
   "source": [
    "#### Run the RESCUE algoritm\n",
    "We running the algorithm for 3-independt seeds to get a distribution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "28af33aa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running RESCUE with SEED=0\n",
      "Initial cumulative cost: 132.59646790088328\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1.2</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-1.015</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-1.015</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.336</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m1.2\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-1.015\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-1.015\u001b[0m  obs_rgrt: \u001b[1;36m-0.336\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m1\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2.3</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-1.018</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-1.018</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.336</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m2.3\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-1.018\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-1.018\u001b[0m  obs_rgrt: \u001b[1;36m-0.336\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m2\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3.5</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-1.129</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-1.129</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.338</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.031</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m3.5\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-1.129\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-1.129\u001b[0m  obs_rgrt: \u001b[1;36m-0.338\u001b[0m  new_fid: \u001b[1;36m0.031\u001b[0m  Iter: \u001b[1;36m3\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">4.6</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-1.134</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-1.134</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.338</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">4</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m4.6\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-1.134\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-1.134\u001b[0m  obs_rgrt: \u001b[1;36m-0.338\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m4\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">5.8</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-1.134</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.955</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.338</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">5</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m5.8\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-1.134\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.955\u001b[0m  obs_rgrt: \u001b[1;36m-0.338\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m5\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">6.9</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-1.134</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.926</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.385</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">6</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m6.9\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-1.134\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.926\u001b[0m  obs_rgrt: \u001b[1;36m-0.385\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m6\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">8.1</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-1.191</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-1.191</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.385</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">7</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m8.1\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-1.191\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-1.191\u001b[0m  obs_rgrt: \u001b[1;36m-0.385\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m7\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">9.2</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-1.191</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-1.155</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.385</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">8</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m9.2\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-1.191\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-1.155\u001b[0m  obs_rgrt: \u001b[1;36m-0.385\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m8\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.4</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-1.191</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.932</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.385</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">9</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m10.4\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-1.191\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.932\u001b[0m  obs_rgrt: \u001b[1;36m-0.385\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m9\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running RESCUE with SEED=1\n",
      "Initial cumulative cost: 131.94900796114825\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1.2</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.222</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.222</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.441</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m1.2\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.222\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.222\u001b[0m  obs_rgrt: \u001b[1;36m-0.441\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m1\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2.3</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.222</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.067</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.441</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m2.3\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.222\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.067\u001b[0m  obs_rgrt: \u001b[1;36m-0.441\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m2\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3.5</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.222</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.041</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.446</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m3.5\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.222\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.041\u001b[0m  obs_rgrt: \u001b[1;36m-0.446\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m3\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">4.6</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.222</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.121</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.446</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">4</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m4.6\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.222\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.121\u001b[0m  obs_rgrt: \u001b[1;36m-0.446\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m4\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">5.8</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.790</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.790</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.446</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">5</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m5.8\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.790\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.790\u001b[0m  obs_rgrt: \u001b[1;36m-0.446\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m5\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">6.9</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.790</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.158</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.457</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">6</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m6.9\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.790\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.158\u001b[0m  obs_rgrt: \u001b[1;36m-0.457\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m6\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">8.1</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.790</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.159</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.457</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">7</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m8.1\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.790\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.159\u001b[0m  obs_rgrt: \u001b[1;36m-0.457\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m7\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">9.2</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.790</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.165</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.457</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">8</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m9.2\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.790\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.165\u001b[0m  obs_rgrt: \u001b[1;36m-0.457\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m8\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.4</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.790</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.139</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.457</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">9</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m10.4\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.790\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.139\u001b[0m  obs_rgrt: \u001b[1;36m-0.457\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m9\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running RESCUE with SEED=2\n",
      "Initial cumulative cost: 135.6645870414021\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1.2</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.026</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.026</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.359</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m1.2\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m0.026\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m0.026\u001b[0m  obs_rgrt: \u001b[1;36m-0.359\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m1\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2.3</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.188</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.188</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.359</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m2.3\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.188\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.188\u001b[0m  obs_rgrt: \u001b[1;36m-0.359\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m2\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3.5</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.246</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.246</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.359</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m3.5\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.246\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.246\u001b[0m  obs_rgrt: \u001b[1;36m-0.359\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m3\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">4.6</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.246</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.196</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.360</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.031</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">4</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m4.6\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.246\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.196\u001b[0m  obs_rgrt: \u001b[1;36m-0.360\u001b[0m  new_fid: \u001b[1;36m0.031\u001b[0m  Iter: \u001b[1;36m4\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">5.8</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.246</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.111</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.360</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.031</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">5</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m5.8\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.246\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.111\u001b[0m  obs_rgrt: \u001b[1;36m-0.360\u001b[0m  new_fid: \u001b[1;36m0.031\u001b[0m  Iter: \u001b[1;36m5\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">6.9</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.246</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.061</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.360</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">6</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m6.9\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.246\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m0.061\u001b[0m  obs_rgrt: \u001b[1;36m-0.360\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m6\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">8.1</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.246</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.130</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.360</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">7</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m8.1\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.246\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.130\u001b[0m  obs_rgrt: \u001b[1;36m-0.360\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m7\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">9.2</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.246</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.002</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.360</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">8</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m9.2\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.246\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.002\u001b[0m  obs_rgrt: \u001b[1;36m-0.360\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m8\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.4</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.246</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.273</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.360</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">9</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m10.4\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.246\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m0.273\u001b[0m  obs_rgrt: \u001b[1;36m-0.360\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m9\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from rescue.algorithms import RescueAlgorithmMultifidelity\n",
    "\n",
    "target_fidelities = {len(problem.design_var_names) - 1: 1.0}\n",
    "\n",
    "rescue_results = []\n",
    "\n",
    "for SEED in SEED_LIST:\n",
    "    print(f\"Running RESCUE with SEED={SEED}\")\n",
    "    rescue = RescueAlgorithmMultifidelity(\n",
    "        problem=problem,\n",
    "        design_variables=problem.design_var_names,\n",
    "        objective_variables=problem.objective_var_names,\n",
    "        fidelity_param_name=problem.fidelity_param_name,\n",
    "        bounds=problem.bounds,\n",
    "        is_discrete_fidelities=False,\n",
    "        # RESCUE assumes fidelity is in the \n",
    "        # last dimension of the design space\n",
    "        target_fidelities=target_fidelities,\n",
    "        cost_fn=cost_fn,\n",
    "        status_spinner=False,\n",
    "        **tkwargs,\n",
    "    )\n",
    "    res_rescue = rescue.run(\n",
    "        init_budget=INI_BUDGET,\n",
    "        budget=BUDGET,\n",
    "        include_initcost_to_budget=False,\n",
    "        ref_point=problem.ref_point,\n",
    "        objective_indices=[0, 1],\n",
    "        causal_observational_data=obs_data,\n",
    "        causal_discovery=\"DirectLiNGAM\",\n",
    "        causal_net_epochs=200,\n",
    "        causal_intervention_samples=500,    \n",
    "        compute_metrics=True,\n",
    "        max_hv=problem.max_hv,\n",
    "        seed=SEED\n",
    "    )\n",
    "    rescue_results.append(res_rescue)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "602d3b0d",
   "metadata": {},
   "source": [
    "#### Compare against some baselines\n",
    "In this example we comapre with the follwings:\n",
    "- Hypervolume Knowledge-Gradient (HVKG) [1], and \n",
    "- Multi-objective Multi-fidelity Optimization (MOMF) [2].\n",
    "\n",
    "For convenience we provide a `baselines` package which implements the baselines motivated from the [BoTorch tutorials](https://botorch.org/docs/tutorials/Multi_objective_multi_fidelity_BO/).\n",
    "\n",
    "1. [Daulton, M. Balandat, and E. Bakshy. Hypervolume Knowledge Gradient for Multi-Objective Bayesian Optimization with Partial Information. ICML, 2023.](https://proceedings.mlr.press/v202/daulton23a.html)\n",
    "2. [Irshad, Faran, Stefan Karsch, and Andreas Döpp. \"Leveraging trust for joint multi-objective and multi-fidelity optimization.\" Machine Learning: Science and Technology 5.1 (2024): 015056.](https://arxiv.org/abs/2112.13901)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b44444fd",
   "metadata": {},
   "source": [
    "#### Run HVKG"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "5c155f66",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running HVKG with SEED=0\n",
      "Initial cumulative cost: 132.59646790088328\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1.2</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.372</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.372</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.336</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m1.2\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m0.372\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m0.372\u001b[0m  obs_rgrt: \u001b[1;36m-0.336\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m1\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2.3</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.331</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.331</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.337</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m2.3\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m0.331\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m0.331\u001b[0m  obs_rgrt: \u001b[1;36m-0.337\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m2\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3.5</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.252</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.252</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.337</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m3.5\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m0.252\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m0.252\u001b[0m  obs_rgrt: \u001b[1;36m-0.337\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m3\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">4.6</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.197</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.197</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.357</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">4</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m4.6\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m0.197\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m0.197\u001b[0m  obs_rgrt: \u001b[1;36m-0.357\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m4\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">5.8</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.197</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.231</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.357</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">5</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m5.8\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m0.197\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m0.231\u001b[0m  obs_rgrt: \u001b[1;36m-0.357\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m5\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">6.9</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.158</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.158</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.357</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">6</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m6.9\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m0.158\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m0.158\u001b[0m  obs_rgrt: \u001b[1;36m-0.357\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m6\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">52.4</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.124</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.124</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.357</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.795</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">7</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m52.4\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m0.124\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m0.124\u001b[0m  obs_rgrt: \u001b[1;36m-0.357\u001b[0m  new_fid: \u001b[1;36m0.795\u001b[0m  Iter: \u001b[1;36m7\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running HVKG with SEED=1\n",
      "Initial cumulative cost: 131.94900796114825\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1.2</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.516</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.516</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.442</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m1.2\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.516\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.516\u001b[0m  obs_rgrt: \u001b[1;36m-0.442\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m1\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2.3</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.516</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.217</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.442</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m2.3\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.516\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.217\u001b[0m  obs_rgrt: \u001b[1;36m-0.442\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m2\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3.5</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.516</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.079</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.442</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m3.5\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.516\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.079\u001b[0m  obs_rgrt: \u001b[1;36m-0.442\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m3\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">4.6</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.516</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.102</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.442</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">4</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m4.6\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.516\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.102\u001b[0m  obs_rgrt: \u001b[1;36m-0.442\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m4\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">5.8</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.516</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.154</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.442</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">5</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m5.8\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.516\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.154\u001b[0m  obs_rgrt: \u001b[1;36m-0.442\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m5\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">6.9</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.516</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.184</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.442</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">6</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m6.9\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.516\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.184\u001b[0m  obs_rgrt: \u001b[1;36m-0.442\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m6\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">8.1</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.516</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.159</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.442</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">7</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m8.1\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.516\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.159\u001b[0m  obs_rgrt: \u001b[1;36m-0.442\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m7\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">9.2</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.516</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.210</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.442</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">8</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m9.2\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.516\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.210\u001b[0m  obs_rgrt: \u001b[1;36m-0.442\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m8\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.4</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.516</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.200</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.442</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">9</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m10.4\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.516\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.200\u001b[0m  obs_rgrt: \u001b[1;36m-0.442\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m9\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running HVKG with SEED=2\n",
      "Initial cumulative cost: 135.6645870414021\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1.2</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.519</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.519</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.357</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m1.2\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.519\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.519\u001b[0m  obs_rgrt: \u001b[1;36m-0.357\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m1\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2.3</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.519</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.080</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.618</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m2.3\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.519\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.080\u001b[0m  obs_rgrt: \u001b[1;36m-0.618\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m2\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3.5</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.519</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.068</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.618</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">3</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m3.5\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.519\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.068\u001b[0m  obs_rgrt: \u001b[1;36m-0.618\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m3\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">4.6</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.519</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.067</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.618</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">4</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m4.6\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.519\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.067\u001b[0m  obs_rgrt: \u001b[1;36m-0.618\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m4\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">5.8</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.519</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.111</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.618</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">5</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m5.8\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.519\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.111\u001b[0m  obs_rgrt: \u001b[1;36m-0.618\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m5\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">6.9</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.519</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.034</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.618</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">6</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m6.9\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.519\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.034\u001b[0m  obs_rgrt: \u001b[1;36m-0.618\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m6\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">8.1</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.519</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.026</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.636</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">7</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m8.1\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.519\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.026\u001b[0m  obs_rgrt: \u001b[1;36m-0.636\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m7\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">9.2</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.519</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.003</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.636</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">8</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m9.2\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.519\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.003\u001b[0m  obs_rgrt: \u001b[1;36m-0.636\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m8\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.4</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.519</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.036</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.636</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">9</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m10.4\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.519\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m0.036\u001b[0m  obs_rgrt: \u001b[1;36m-0.636\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m9\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from baselines.multiobjective_multifidelity_hvkg import BaselineMOMFHVKG\n",
    "\n",
    "hvkg_results = []\n",
    "\n",
    "for SEED in SEED_LIST:\n",
    "    print(f\"Running HVKG with SEED={SEED}\")\n",
    "    hvkg = BaselineMOMFHVKG(\n",
    "        problem=problem,\n",
    "        cost_fn=cost_fn,\n",
    "        bounds=problem.bounds,\n",
    "        has_constraints=False,\n",
    "        is_discrete_fidelities=False,\n",
    "        target_fidelities=target_fidelities,\n",
    "        status_spinner=False,\n",
    "        **tkwargs\n",
    "    )\n",
    "    res_hvkg = hvkg.run(\n",
    "        init_budget=INI_BUDGET,\n",
    "        budget=BUDGET,\n",
    "        include_initcost_to_budget=False,\n",
    "        ref_point=problem.ref_point,\n",
    "        objective_indices=[0, 1],  \n",
    "        compute_metrics=True,\n",
    "        max_hv=problem.max_hv,\n",
    "        seed=SEED\n",
    "    )\n",
    "    hvkg_results.append(res_hvkg)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c17cf6f9",
   "metadata": {},
   "source": [
    "#### Run MOMF"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "417a1609",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running MOMF with SEED=0\n",
      "Initial cumulative cost: 132.59646790088328\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2.8</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.693</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.693</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.336</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.215</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m2.8\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.693\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.693\u001b[0m  obs_rgrt: \u001b[1;36m-0.336\u001b[0m  new_fid: \u001b[1;36m0.215\u001b[0m  Iter: \u001b[1;36m1\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">23.5</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.693</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.797</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.336</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.631</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m23.5\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.693\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m0.797\u001b[0m  obs_rgrt: \u001b[1;36m-0.336\u001b[0m  new_fid: \u001b[1;36m0.631\u001b[0m  Iter: \u001b[1;36m2\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running MOMF with SEED=1\n",
      "Initial cumulative cost: 131.94900796114825\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1.8</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.321</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.321</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.454</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.127</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m1.8\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m0.321\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m0.321\u001b[0m  obs_rgrt: \u001b[1;36m-0.454\u001b[0m  new_fid: \u001b[1;36m0.127\u001b[0m  Iter: \u001b[1;36m1\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.393</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.393</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.454</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.437</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m10.0\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.393\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.393\u001b[0m  obs_rgrt: \u001b[1;36m-0.454\u001b[0m  new_fid: \u001b[1;36m0.437\u001b[0m  Iter: \u001b[1;36m2\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running MOMF with SEED=2\n",
      "Initial cumulative cost: 135.6645870414021\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1.2</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.905</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.905</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.357</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">1</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m1.2\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.905\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.905\u001b[0m  obs_rgrt: \u001b[1;36m-0.357\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  Iter: \u001b[1;36m1\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">Budget: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">12.4</span>/<span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">10.0</span>  best_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.905</span>  curr_nsga2_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.706</span>  obs_rgrt: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">-0.357</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.503</span>  Iter: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">2</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "Budget: \u001b[1;36m12.4\u001b[0m/\u001b[1;36m10.0\u001b[0m  best_nsga2_rgrt: \u001b[1;36m-0.905\u001b[0m  curr_nsga2_rgrt: \u001b[1;36m-0.706\u001b[0m  obs_rgrt: \u001b[1;36m-0.357\u001b[0m  new_fid: \u001b[1;36m0.503\u001b[0m  Iter: \u001b[1;36m2\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from baselines.multiobjective_multifidelity import BaselineMOMF\n",
    "\n",
    "# Since MOMF an additional fidelity objective, we need to\n",
    "# augment the reference point accordingly\n",
    "momf_ref_point = torch.cat([problem.ref_point, torch.tensor([0.0], **tkwargs)])\n",
    "\n",
    "momf_results = []\n",
    "\n",
    "for SEED in SEED_LIST:\n",
    "    print(f\"Running MOMF with SEED={SEED}\")\n",
    "    momf = BaselineMOMF(\n",
    "        problem=problem,\n",
    "        cost_fn=cost_fn,\n",
    "        bounds=problem.bounds,\n",
    "        target_fidelities=target_fidelities,\n",
    "        has_constraints=False,\n",
    "        is_discrete_fidelities=False,\n",
    "        status_spinner=False,\n",
    "        **tkwargs\n",
    "    )\n",
    "    res_momf = momf.run(\n",
    "        init_budget=INI_BUDGET,\n",
    "        budget=BUDGET,\n",
    "        include_initcost_to_budget=False,\n",
    "        ref_point=momf_ref_point,\n",
    "        objective_indices=[0, 1],  \n",
    "        compute_metrics=True,\n",
    "        max_hv=problem.max_hv,\n",
    "        seed=SEED\n",
    "    )\n",
    "    momf_results.append(res_momf)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4a5889ca",
   "metadata": {},
   "source": [
    "#### Plot the regret achieved by each method\n",
    "Please make sure, `rescue_log` directory is empty as the following script will consider all `.JSON` files inside this directory."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "c960132e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Warning: HPOXGBoost_BaselineMOMF_run.0: only 1 point ≤ effective budget 10.0; padding.\n",
      "Warning: HPOXGBoost_BaselineMOMF_run.1: only 1 point ≤ effective budget 10.0; padding.\n",
      "Warning: HPOXGBoost_BaselineMOMF_run.2: only 1 point ≤ effective budget 10.0; padding.\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAk0AAAHqCAYAAAAZC3qTAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjYsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvq6yFwwAAAAlwSFlzAAAPYQAAD2EBqD+naQAAtQ5JREFUeJzsnQd8U9UXx3/ZnVDKnrL3BkFw4EBBAVGRJUMBEQcuFMWJOMCF27+ICxEQcSMiioALEdkCgigoe0PpTrP+n99NXpqkaUlL2ibt+fq5Nnnv5b2bd0PuL+ece47O5XK5IAiCIAiCIBSIvuDdgiAIgiAIAhHRJAiCIAiCEAIimgRBEARBEEJARJMgCIIgCEIIiGgSBEEQBEEIARFNgiAIgiAIISCiSRAEQRAEIQRENAmCIAiCIISAiCZBEARBEIQQENEkCIIgCIIQAiKaBKEY2LlzJ8aNG4eGDRsiJiYGFSpUwLnnnouXX34ZWVlZYb9eZmYmHnvsMfzwww+IBGbNmgWdTufXqlWrhosuugjffPNNsV23sPeBx2n9W7duXZ79N9xwAxISEvy2OZ1OzJ49G127dkVycjISExPRtGlTjBw5Er/99luecxw5cgSTJk1CmzZt1Ln4eWjcuDFGjRqFX375Jd++/e9//1P94nUKA98/X3fs2LEC30dBr9WayWRC/fr1cccddyAlJQWRzoEDB9R72LhxY2l3RSijGEu7A4JQ1vj6668xcOBAWCwWNZG2bt0aOTk5aoKcOHEitm7dipkzZ4ZdLEyZMkU9vvDCCxEpPP7442jQoAFY4vLw4cNKTF1xxRX46quv0Ldv37Bf70zuAydb9ut0UEC8/vrr6N+/P4YNGwaj0Yi//vpLiUGK5HPOOcd77O+//44+ffogLS0NQ4YMwc0336w+F//++y+++OILdT9+/PFHXHDBBXmuM3fuXCVYeI5//vlHCa2S4o033lAiKyMjA8uWLcOrr76K9evXFyjyIkU0cfx539q3b1/a3RHKICKaBCGMcDLk5HjWWWdh+fLlqFmzpnffbbfdpiY/iqrywuWXX47OnTt7n48ZMwbVq1fHhx9+WCyiqahwgl20aJESBh07dsz3OAo/WoDGjh2bR/i+9NJLOHr0qPf5yZMncdVVVylRRctH8+bN/Y5/8sknMX/+fMTGxgb9HP3666/47LPPlMWSAmry5MkoKa699lpUqVJFPeb1+Zn+6KOPlIDr0qVLifWDVj3+4KB1ThAiAXHPCUIYefbZZ5Geno533nnHTzBp0Fpw5513ep/b7XY88cQTaNSokbJA8Bfygw8+CKvV6ve6tWvXolevXmoi4yRL683o0aPVvv/++w9Vq1ZVj/krW3Ot0HISDJ6L+99///08+7799lu1jwKC0EJy1113qX6xf3SxXXrppUpcFIWkpCTVfwqJwMmRoqNVq1ZqgqSw4mRN4VFc98GX22+/HZUqVTrtsRQztJrR1RqI5oLUmDFjBg4ePKjeV6Bg0o4fOnQozj777Dz7KJLYH1qpKGD4vDQ5//zzvW5nX1avXo3evXujYsWKiIuLQ48ePbBy5cqgblCKZ44tP+tvvvmm1xXoC5+PHz9evV9+FviZW7Jkidq3f/9+Ndb8bHA797/77rt+19DuJV2f2vjTmicI4UIsTYIQRujeoYume/fuIR1/4403KvHCifGee+5Rk9C0adOwbds2fP75596YmMsuu0wJAsbGUHhQINAKQbid7pRbbrkFV199Na655hq1vW3btkGvycmLfVywYAGuv/56v320JnCypjAhdCd98sknaiJr2bIljh8/rlw07F9BFhmNU6dOqdgaCg2+D7p5KCqHDx/udxwFEic3TnZ0f1GcvPbaa9iwYYOahBlbE+774Atjzu6++248+uijBVqbaEEkH3/8sXLBUigU9FmgsNP6URgoGvg6s9mshBXf15o1a4IKrJKA95nws6FBSyotiZ06dVJWML1ej/feew8XX3wxfv75Z69FimNIYcUfERSzDodDuW01gRsIz8vPJj9zFMcU7LTw0e2piSq+lu5QWi5TU1OVsG/RooU6L8fwpptu8gq9UP8tCkJIuARBCAunTp1y8Z9U//79Qzp+48aN6vgbb7zRb/u9996rti9fvlw9//zzz9XzNWvW5Huuo0ePqmMmT54c0rUfeOABl8lkcp04ccK7zWq1upKSklyjR4/2bqtYsaLrtttucxWW9957T/UnsFksFtesWbP8jv3555/Vvrlz5/ptX7Jkid/24rgPK1asUMd//PHHrpSUFFelSpVcV155pXf/9ddf74qPj/d7zciRI9VreOzVV1/tev75513btm3Lc27ub9++fZ7tqampqp9aS09P99u/du1adf6lS5eq506n01WnTh3XnXfe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",
      "text/plain": [
       "<Figure size 600x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from rescue.utils.viz import plot_regret_vs_cost_from_json\n",
    "from pathlib import Path\n",
    "\n",
    "# Get all JSON files from rescue_log directory\n",
    "rescue_log_dir = Path(\"rescue_log\")\n",
    "json_files = [str(f) for f in rescue_log_dir.glob(\"*.json\")]\n",
    "\n",
    "# Plot regret comparison\n",
    "results = plot_regret_vs_cost_from_json(\n",
    "    json_files=json_files,\n",
    "    problem_name=\"HPOXGBoost\",\n",
    "    methods_list=[\"RescueAlgorithmMultifidelity\", \"BaselineMOMFHVKG\", \"BaselineMOMF\"],\n",
    "    seed_list=SEED_LIST,\n",
    "    regret_key=\"best_nsga2_regret\",\n",
    "    title=\"Cost vs Best NSGA-II Regret\",\n",
    "    figsize=(6, 5)\n",
    ")"
   ]
  }
 ],
 "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
}
