{
 "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": "dba88ce0",
   "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": "06c8fc21",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from rescue.problems.hpo.multi_objective import HPOXGBoost\n",
    "\n",
    "problem = HPOXGBoost(negate=True).to(\"cuda\" if torch.cuda.is_available() else \"cpu\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b79b46a1",
   "metadata": {},
   "source": [
    "#### Utility for the cost function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "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": 3,
   "id": "087f06e8",
   "metadata": {},
   "outputs": [],
   "source": [
    "from data import load_observational_data\n",
    "obs_data = load_observational_data(sample_seed=1, problem=problem)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "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": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "obs_data"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "206baa69",
   "metadata": {},
   "source": [
    "#### Run the RESCUE algoritm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "28af33aa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Initial cumulative cost: 119.32584062034294\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\">2.05</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  causal_net_loss: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.010</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;36m2.05\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  causal_net_loss: \u001b[1;36m0.010\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\">2.05</span>  new_fid: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.030</span>  causal_net_loss: <span style=\"color: #008080; text-decoration-color: #008080; font-weight: bold\">0.010</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;36m2.05\u001b[0m  new_fid: \u001b[1;36m0.030\u001b[0m  causal_net_loss: \u001b[1;36m0.010\u001b[0m  Iter: \u001b[1;36m2\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from rescue.algorithms import RescueAlgorithmMultifidelity\n",
    "\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={len(problem.design_var_names) - 1: 1.0},\n",
    "    cost_fn=cost_fn,\n",
    "    status_spinner=False,\n",
    ")\n",
    "res = rescue.run(\n",
    "    init_budget=1.05,\n",
    "    budget=2.05,\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=False,\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "a7644c59",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[0.69039192, 0.63740056, 0.96793923, ..., 0.57332519, 0.75812881,\n",
       "        0.99686088],\n",
       "       [0.52868582, 0.92867314, 0.43169201, ..., 0.37180343, 0.96890572,\n",
       "        0.24811725],\n",
       "       [0.63565857, 0.64357059, 0.96092227, ..., 0.57138313, 0.77248841,\n",
       "        0.99716571],\n",
       "       ...,\n",
       "       [0.33186178, 0.22546076, 0.87731055, ..., 0.79193438, 0.55782837,\n",
       "        0.99977595],\n",
       "       [0.78327944, 0.54877377, 0.91973274, ..., 0.68881536, 0.74020982,\n",
       "        0.93994059],\n",
       "       [0.03089824, 0.24967242, 0.69727031, ..., 0.84929686, 0.56002384,\n",
       "        0.9968267 ]])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res['pareto_X']"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f995d72c",
   "metadata": {},
   "source": [
    "#### Plot the Pareto front"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "1ebf16f0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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F1xgyrdr107mzZtX6nmdHzB+/HhJSEiQmjVrSmpqqmzatEkChbfv9/bbbz/r77Jv374SjPe7du1a8/Oq5fU+pk6dWunXtMM9T5w48ay/Y/2ZCMb7nTlzplx66aXSoEEDc+jn88zydvoMz7Rwvz77DOtsKQSHvn37Ojp06OBYtmyZY8mSJY5WrVo5br75ZpfXPP/8847JkyebQ/+6f/nlF6+8blXwpF733HOPo1mzZo60tDTHf//7X0ePHj0cF198caky+ufw+uuvO/bt21d8nDhxwlHV5syZ44iIiHDMmjXLsXbtWsewYcMc9evXd+zfv7/M8kuXLnWEh4c7nnrqKce6descjzzyiKNGjRqO1atXF5eZMmWKo169eo6PP/7YsXLlSsd1113naNGihV/uryrud8iQIebnpOTf5eHDhx2BwN37zcjIcDz88MOOd9991xEfH28+u5V9TTvc84QJExwXXXRRqb/jgwcPOoLxfm+55RbH9OnTHT/99JNj/fr1jttvv918Xnfv3m3Lz/AtFu7XV59hwk2Q0H/c9Uv5xx9/LD735ZdfOsLCwhx79uyp8PpvvvmmzHBT2df1FU/qdeTIEfPl9/777xef0w+Uvk56enrxOX380UcfOfytW7dujvvuu6/4cWFhoaNJkyYmiJblxhtvdFx99dWlznXv3t1x9913m98XFRWZL4inn3661J9JZGSk+fKw2/06/2Hs37+/IxC5e78lNW/evMwv+sq8ZrDes4Yb/Z+cQFTZv4/Tp0876tSp43jzzTdt+Rmu6H59+RmmWypIpKenm66ZLl26FJ/TJj7dK+uHH34IuNetLE/qtXz5cjl16pQp56TN1+eee655vZK06yo2Nla6desms2bNMk3BVamgoMDUt2Rd9d708Zl1ddLzJcurPn36FJfftm2bZGVllSqj+7Bo03F5rxnM9+v07bffSuPGjeX888+X4cOHy6FDh8TfPLlff7ymN/myftoto5sltmzZ0nRV79y5U+xwv3l5eebfrJiYGFt+hiu6X19+hgk3QUJ/4PUvv6Tq1aubHxJ9LtBet7I8qZeej4iIMKGopLi4uFLXPProo/Lee+/JwoULTX//vffeKy+++KJUpezsbCksLDR1c1XXkvS8q/LOX915zWC+X6V982+99ZakpaXJk08+Kf/5z3/k97//vXmvYLtff7ymN/mq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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "ax.scatter(res['pareto_Y'][:, 0], res['pareto_Y'][:, 1])\n",
    "ax.set_xlabel('mmce')\n",
    "ax.set_ylabel('rammodel')\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "rescue",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
