{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "f9488384-3238-49cb-ae5d-0d5011219bda",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "62.0\n"
     ]
    },
    {
     "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>algorithm</th>\n",
       "      <th>final_best_mean</th>\n",
       "      <th>final_best_std</th>\n",
       "      <th>auc_best_so_far_mean</th>\n",
       "      <th>auc_best_so_far_std</th>\n",
       "      <th>final_simple_regret_mean</th>\n",
       "      <th>final_simple_regret_std</th>\n",
       "      <th>evals_to_threshold_mean</th>\n",
       "      <th>evals_to_threshold_std</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>pl_botorch_mallows_EI_30</td>\n",
       "      <td>68.05</td>\n",
       "      <td>3.040970</td>\n",
       "      <td>5350.500</td>\n",
       "      <td>910.120116</td>\n",
       "      <td>6.05</td>\n",
       "      <td>3.040970</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>pl_botorch_merge_EI_30</td>\n",
       "      <td>68.05</td>\n",
       "      <td>2.268810</td>\n",
       "      <td>5495.650</td>\n",
       "      <td>687.715168</td>\n",
       "      <td>6.05</td>\n",
       "      <td>2.268810</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>pl_botorch_merge_EI_30_pairwise_pattern</td>\n",
       "      <td>68.35</td>\n",
       "      <td>3.691544</td>\n",
       "      <td>5590.600</td>\n",
       "      <td>1040.549081</td>\n",
       "      <td>6.35</td>\n",
       "      <td>3.691544</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>pl_botorch_merge_EI_30_shift_pairwise</td>\n",
       "      <td>68.05</td>\n",
       "      <td>2.418160</td>\n",
       "      <td>5390.300</td>\n",
       "      <td>952.258452</td>\n",
       "      <td>6.05</td>\n",
       "      <td>2.418160</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>pl_botorch_merge_EI_30_shift_pairwise_pattern</td>\n",
       "      <td>68.10</td>\n",
       "      <td>2.142429</td>\n",
       "      <td>5371.025</td>\n",
       "      <td>792.776064</td>\n",
       "      <td>6.10</td>\n",
       "      <td>2.142429</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>pl_botorch_merge_EI_30_shift_pattern</td>\n",
       "      <td>67.15</td>\n",
       "      <td>2.127792</td>\n",
       "      <td>5553.150</td>\n",
       "      <td>1096.469004</td>\n",
       "      <td>5.15</td>\n",
       "      <td>2.127792</td>\n",
       "      <td>None</td>\n",
       "      <td>None</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                       algorithm  final_best_mean  \\\n",
       "0                       pl_botorch_mallows_EI_30            68.05   \n",
       "1                         pl_botorch_merge_EI_30            68.05   \n",
       "2        pl_botorch_merge_EI_30_pairwise_pattern            68.35   \n",
       "3          pl_botorch_merge_EI_30_shift_pairwise            68.05   \n",
       "4  pl_botorch_merge_EI_30_shift_pairwise_pattern            68.10   \n",
       "5           pl_botorch_merge_EI_30_shift_pattern            67.15   \n",
       "\n",
       "   final_best_std  auc_best_so_far_mean  auc_best_so_far_std  \\\n",
       "0        3.040970              5350.500           910.120116   \n",
       "1        2.268810              5495.650           687.715168   \n",
       "2        3.691544              5590.600          1040.549081   \n",
       "3        2.418160              5390.300           952.258452   \n",
       "4        2.142429              5371.025           792.776064   \n",
       "5        2.127792              5553.150          1096.469004   \n",
       "\n",
       "   final_simple_regret_mean  final_simple_regret_std evals_to_threshold_mean  \\\n",
       "0                      6.05                 3.040970                    None   \n",
       "1                      6.05                 2.268810                    None   \n",
       "2                      6.35                 3.691544                    None   \n",
       "3                      6.05                 2.418160                    None   \n",
       "4                      6.10                 2.142429                    None   \n",
       "5                      5.15                 2.127792                    None   \n",
       "\n",
       "  evals_to_threshold_std  \n",
       "0                   None  \n",
       "1                   None  \n",
       "2                   None  \n",
       "3                   None  \n",
       "4                   None  \n",
       "5                   None  "
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "from copy import deepcopy\n",
    "\n",
    "def read_file(kernel_type, dim, benchmark_index, nruns):\n",
    "    file_name = 'tsp_botorch_'+kernel_type+'_EI_dim_'+str(dim)+'benchmark_index_'+str(benchmark_index)+'_nrun_'+str(nruns)+'.pkl'\n",
    "    data = torch.load(file_name, weights_only=False)\n",
    "    l = data['outputs']\n",
    "    l = [float(i) for i in l]\n",
    "    return l\n",
    "\n",
    "\n",
    "def read_file_filename(file_name):\n",
    "    data = torch.load(file_name, weights_only=False)\n",
    "    l = data['outputs']\n",
    "    l = [float(i) for i in l]\n",
    "    return l\n",
    "\n",
    "\n",
    "def read_file_no_anchor(kernel_type, dim, benchmark_index, nruns):\n",
    "    file_name = 'tsp_botorch_'+kernel_type+'_EI_dim_'+str(dim)+'benchmark_index_no_anchor_'+str(benchmark_index)+'_nrun_'+str(nruns)+'.pkl'\n",
    "    data = torch.load(file_name, weights_only=False)\n",
    "    l = data['outputs']\n",
    "    l = [float(i) for i in l]\n",
    "    return l\n",
    "\n",
    "\n",
    "import os\n",
    "\n",
    "def analyse_trial(dim=10, benchmark_index=0):\n",
    "    folders = os.listdir('./results')\n",
    "    nruns = 20\n",
    "    results_dict = {}\n",
    "\n",
    "    for folder in folders:\n",
    "        if '.' in folder:\n",
    "            continue\n",
    "        results_dict[folder] = []\n",
    "        for nrun in range(nruns):\n",
    "            results_dict[folder].append(read_file_filename(os.path.join('./results', folder, folder+f'_nrun_{nrun}.pkl')))\n",
    "\n",
    "    all_results = []\n",
    "    for key in results_dict.keys():\n",
    "        results_dict[key] = np.array(results_dict[key])\n",
    "        all_results.append(results_dict[key])\n",
    "    # print(all_results[0].shape)\n",
    "    # return all_results\n",
    "    global_minimum = np.min(all_results)\n",
    "    print(global_minimum)\n",
    "    best_so_far = [np.minimum.accumulate(res, axis=1) for res in all_results]\n",
    "    regrets = [bfs - global_minimum for bfs in best_so_far]\n",
    "    for i, key in enumerate(results_dict.keys()):\n",
    "        # results_dict[key] = regrets[i]\n",
    "        results_dict[key] = all_results[i]\n",
    "    return results_dict\n",
    "\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from sklearn.metrics import auc\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from sklearn.metrics import auc\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from sklearn.metrics import auc\n",
    "\n",
    "def evaluate_algorithms(r: dict, f_opt=None, threshold=None):\n",
    "    \"\"\"\n",
    "    r: dict of {algorithm_name: np.ndarray of shape (n_repeats, n_iterations)}\n",
    "    f_opt: known global minimum value (float)\n",
    "    threshold: optional regret threshold to measure how many iterations are needed\n",
    "    \n",
    "    Returns:\n",
    "        pd.DataFrame with aggregated metrics for each algorithm\n",
    "    \"\"\"\n",
    "    results = []\n",
    "\n",
    "    for algo, outputs in r.items():\n",
    "        outputs = np.array(outputs)  # shape: (n_repeats, n_iterations)\n",
    "        n_repeats, n_iterations = outputs.shape\n",
    "\n",
    "        best_so_far = np.minimum.accumulate(outputs, axis=1)\n",
    "        \n",
    "        final_best = best_so_far[:, -1]\n",
    "        auc_vals = np.array([\n",
    "            auc(np.arange(1, n_iterations+1), best_so_far[i] - f_opt)\n",
    "            for i in range(n_repeats)\n",
    "        ])\n",
    "\n",
    "        metrics = {\n",
    "            \"algorithm\": algo,\n",
    "            \"final_best_mean\": np.mean(final_best),\n",
    "            \"final_best_std\": np.std(final_best),\n",
    "            \"auc_best_so_far_mean\": np.mean(auc_vals),\n",
    "            \"auc_best_so_far_std\": np.std(auc_vals),\n",
    "        }\n",
    "\n",
    "        if f_opt is not None:\n",
    "            simple_regrets       = best_so_far - f_opt       # ← 修正\n",
    "            instantaneous_regret = outputs - f_opt           # (可选) 如需两者都存\n",
    "            final_simple         = simple_regrets[:, -1]\n",
    "\n",
    "            metrics.update({\n",
    "                \"final_simple_regret_mean\": np.mean(final_simple),\n",
    "                \"final_simple_regret_std\": np.std(final_simple),\n",
    "            })\n",
    "        else:\n",
    "            metrics.update({\n",
    "                \"final_simple_regret_mean\": None,\n",
    "                \"final_simple_regret_std\": None,\n",
    "            })\n",
    "\n",
    "        if threshold is not None:\n",
    "            evals_to_threshold = []\n",
    "            for i in range(n_repeats):\n",
    "                for j in range(n_iterations):\n",
    "                    if best_so_far[i, j] <= threshold:\n",
    "                        evals_to_threshold.append(j + 1)\n",
    "                        break\n",
    "                else:\n",
    "                    evals_to_threshold.append(n_iterations)\n",
    "            evals_to_threshold = np.array(evals_to_threshold)\n",
    "            metrics.update({\n",
    "                \"evals_to_threshold_mean\": np.mean(evals_to_threshold),\n",
    "                \"evals_to_threshold_std\": np.std(evals_to_threshold),\n",
    "            })\n",
    "        else:\n",
    "            metrics.update({\n",
    "                \"evals_to_threshold_mean\": None,\n",
    "                \"evals_to_threshold_std\": None,\n",
    "            })\n",
    "\n",
    "        results.append(metrics)\n",
    "\n",
    "    return pd.DataFrame(results)\n",
    "\n",
    "\n",
    "r = analyse_trial()\n",
    "k = evaluate_algorithms(r, 62)\n",
    "k"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bf27d10f-649f-4c0a-b787-0159e05fd95e",
   "metadata": {},
   "source": [
    "## Analyse results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "1b9bf255-d3d8-4e79-92a8-c920d8cb983d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "62.0\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAeoAAAGGCAYAAAC0W8IbAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAAB75ElEQVR4nO3deXhU5dnA4d85s2aykj2BQAIKiCyyCOIGClXQqnWpilRFra0WbQWpSuu+4dLaaq212gq21VL71WprqxVRQBARWQQFkT0sCSF7JrPPeb8/JhkYkkkyyYQk8NzXdTRztnkyGeaZd9eUUgohhBBCdEt6VwcghBBCiOgkUQshhBDdmCRqIYQQohuTRC2EEEJ0Y5KohRBCiG5MErUQQgjRjUmiFkIIIboxSdRCCCFEN2bu6gC6A8Mw2L9/P8nJyWia1tXhCCGEOMYppairqyM/Px9db7nMLIka2L9/PwUFBV0dhhBCiOPMnj176NOnT4vnSKIGkpOTgdALlpKS0sXRCCGEONbV1tZSUFAQzj8tkUQN4erulJQUSdRCCCGOmrY0t0pnMiGEEKIb69JEvWzZMi666CLy8/PRNI233nor4rimac1uTz/9dPicwsLCJsefeOKJo/ybCCGEEJ2jSxN1fX09I0aM4Le//W2zx0tKSiK2V155BU3TuPzyyyPOe/jhhyPOu/32249G+EIIIUSn69I26qlTpzJ16tSox3NzcyMev/3225xzzjn0798/Yn9ycnKTc4UQ4nhgGAY+n6+rwxBHsFgsmEymuNyrx3QmO3DgAP/5z3949dVXmxx74okneOSRR+jbty/XXHMNs2bNwmzuMb+aEEK0i8/nY+fOnRiG0dWhiGakpaWRm5vb4fk5ekw2e/XVV0lOTuayyy6L2P/jH/+YUaNGkZ6ezieffMLcuXMpKSnhmWeeiXovr9eL1+sNP66tre20uIUQojMopSgpKcFkMlFQUNDqpBni6FFK4XK5KCsrAyAvL69D9+sxifqVV15h+vTp2O32iP2zZ88O/zx8+HCsVis//OEPmTdvHjabrdl7zZs3j4ceeqhT4xVCiM4UCARwuVzk5+fjcDi6OhxxhISEBADKysrIzs7uUDV4j/gK9vHHH7Nlyxa+//3vt3ruuHHjCAQC7Nq1K+o5c+fOpaamJrzt2bMnjtEKIUTnCwaDAFit1i6ORETT+AXK7/d36D49okT9xz/+kdGjRzNixIhWz12/fj26rpOdnR31HJvNFrW0LYQQPYmsT9B9xetv06WJ2ul0sm3btvDjnTt3sn79etLT0+nbty8Qaj/++9//zi9/+csm169cuZJVq1ZxzjnnkJyczMqVK5k1axbf+9736NWr11H7PYQQQojO0qVV359//jkjR45k5MiRQKi9eeTIkdx///3hcxYuXIhSimnTpjW53mazsXDhQiZMmMDJJ5/MY489xqxZs3jppZeO2u8ghBCia+zatQtN01i/fj0AS5YsQdM0qquruzSueOvSRD1x4kSUUk22BQsWhM/5wQ9+gMvlIjU1tcn1o0aN4tNPP6W6uhq3282mTZuYO3euVGsLIUQ3NWPGDDRN45ZbbmlybObMmWiaxowZM45+YN1Yj+hM1pMYDR08hBBCNK+goICFCxfidrvD+zweD6+//nq42VMcIok6zgxDErUQQrRk1KhRFBQU8Oabb4b3vfnmm/Tt2zfcFArw3nvvceaZZ5KWlkZGRgbf/va32b59e0zP9Y9//IOTTz4Zm81GYWFhRH+n559/nqFDh4Yfv/XWW2iaxosvvhjeN3nyZO69914Avvjii3CfqJSUFEaPHs3nn38e8+8fK0nUcRYMBro6BCHEcUgphcsX6JJNKRVzvDfeeCPz588PP37llVe44YYbIs6pr69n9uzZfP755yxevBhd17n00kvbPBPbmjVruPLKK7n66qvZuHEjDz74IPfdd1+4eXXChAls2rSJgwcPArB06VIyMzNZsmQJEBpWtXLlSiZOnAjA9OnT6dOnD6tXr2bNmjXcc889WCyWmH/3WPWI4Vk9iVR9CyG6gtsfZMj9/+uS59708Pk4rLGlk+9973vMnTuX3bt3A7BixQoWLlwYTpJAkwWYXnnlFbKysti0aVNESTiaZ555hkmTJnHfffcBMHDgQDZt2sTTTz/NjBkzGDp0KOnp6SxdupQrrriCJUuWcOedd/Lss88C8Nlnn+H3+zn99NMBKC4u5qc//SmDBw8G4MQTT4zpd24vKVHHmVR9CyFE67KysrjwwgtZsGAB8+fP58ILLyQzMzPinK1btzJt2jT69+9PSkoKhYWFQChhtsXmzZs544wzIvadccYZbN26lWAwiKZpnH322SxZsoTq6mo2bdrEj370I7xeL19//TVLly7l1FNP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ohZCCCG6MUnUQgghRDcmiToOfvvb31JYWIjdbmfcuHF89tlnXR1SE/PmzePUU08lOTmZ7OxsvvOd77Bly5aIcyZOnIimaRHbLbfc0kURR3rwwQebxDZ48ODwcY/Hw8yZM8nIyCApKYnLL7+cAwcOdGHEhxQWFjaJXdM0Zs6cCXSv133ZsmVcdNFF5Ofno2kab731VsRxpRT3338/eXl5JCQkMHnyZLZu3RpxTmVlJdOnTyclJYW0tDRuuukmnE5nl8fv9/u5++67GTZsGImJieTn53Pdddexf//+iHs09/d64oknujR2gBkzZjSJa8qUKRHndNVr31rszb3/NU3j6aefDp/TVa97Wz4b2/L5UlxczIUXXojD4SA7O5uf/vSnBAKBuMQoibqD/va3vzF79mweeOAB1q5dy4gRIzj//PMpKyvr6tAiLF26lJkzZ/Lpp5+yaNEi/H4/5513HvX19RHn3XzzzZSUlIS3p556qosiburkk0+OiG358uXhY7NmzeLf//43f//731m6dCn79+/nsssu68JoD1m9enVE3IsWLQLgu9/9bvic7vK619fXM2LECH772982e/ypp57iueee48UXX2TVqlUkJiZy/vnn4/F4wudMnz6dr776ikWLFvHOO++wbNkyfvCDH3R5/C6Xi7Vr13Lfffexdu1a3nzzTbZs2cLFF1/c5NyHH3444u9x++23d2nsjaZMmRIR11//+teI41312rcW++Exl5SU8Morr6BpGpdffnnEeV3xurfls7G1z5dgMMiFF16Iz+fjk08+4dVXX2XBggXcf//98QlSiQ4ZO3asmjlzZvhxMBhU+fn5at68eV0YVevKysoUoJYuXRreN2HCBPWTn/yk64JqwQMPPKBGjBjR7LHq6mplsVjU3//+9/C+zZs3K0CtXLnyKEXYdj/5yU/UgAEDlGEYSqnu+7oD6p///Gf4sWEYKjc3Vz399NPhfdXV1cpms6m//vWvSimlNm3apAC1evXq8Dnvvvuu0jRN7du376jFrlTT+Jvz2WefKUDt3r07vK9fv37qV7/6VecG14rmYr/++uvVJZdcEvWa7vLat+V1v+SSS9S5554bsa87vO5KNf1sbMvny3//+1+l67oqLS0Nn/O73/1OpaSkKK/X2+GYpETdAT6fjzVr1jB58uTwPl3XmTx5MitXruzCyFpXU1MDQHp6esT+1157jczMTIYOHcrcuXNxuVxdEV6ztm7dSn5+Pv3792f69OkUFxcDsGbNGvx+f8TfYfDgwfTt27fb/R18Ph9/+ctfuPHGGyPmle/Or3ujnTt3UlpaGvE6p6amMm7cuPDrvHLlStLS0hgzZkz4nMmTJ6PrOqtWrTrqMbempqYGTdNIS0uL2P/EE0+QkZHByJEjefrpp+NWhdlRS5YsITs7m0GDBnHrrbdSUVERPtZTXvsDBw7wn//8h5tuuqnJse7wuh/52diWz5eVK1cybNgwcnJywuecf/751NbW8tVXX3U4JpnruwPKy8sJBoMRfxyAnJwcvv766y6KqnWGYXDHHXdwxhlnMHTo0PD+a665hn79+pGfn8+GDRu4++672bJlC2+++WYXRhsybtw4FixYwKBBgygpKeGhhx7irLPO4ssvv6S0tBSr1drkwzYnJ4fS0tKuCTiKt956i+rqambMmBHe151f98M1vpbNvd8bj5WWlpKdnR1x3Gw2k56e3u3+Fh6Ph7vvvptp06ZFzNv84x//mFGjRpGens4nn3zC3LlzKSkp4ZlnnunCaEPV3pdddhlFRUVs376dn/3sZ0ydOpWVK1diMpl6zGv/6quvkpyc3KRpqju87s19Nrbl86W0tLTZfxeNxzpKEvVxaObMmXz55ZcRbbxARFvWsGHDyMvLY9KkSWzfvp0BAwYc7TAjTJ06Nfzz8OHDGTduHP369eONN94gISGhCyOLzR//+EemTp1Kfn5+eF93ft2PVX6/nyuvvBKlFL/73e8ijs2ePTv88/Dhw7Farfzwhz9k3rx5XTqb1tVXXx3+ediwYQwfPpwBAwawZMkSJk2a1GVxxeqVV15h+vTp2O32iP3d4XWP9tnY1aTquwMyMzMxmUxNev8dOHCA3NzcLoqqZbfddhvvvPMOH330Uasrho0bNw6Abdu2HY3QYpKWlsbAgQPZtm0bubm5+Hw+qqurI87pbn+H3bt388EHH/D973+/xfO66+ve+Fq29H7Pzc1t0pEyEAhQWVnZbf4WjUl69+7dLFq0qNVVkMaNG0cgEGDXrl1HJ8A26t+/P5mZmeH3SU947T/++GO2bNnS6r8BOPqve7TPxrZ8vuTm5jb776LxWEdJou4Aq9XK6NGjWbx4cXifYRgsXryY8ePHd2FkTSmluO222/jnP//Jhx9+SFFRUavXrF+/HoC8vLxOji52TqeT7du3k5eXx+jRo7FYLBF/hy1btlBcXNyt/g7z588nOzubCy+8sMXzuuvrXlRURG5ubsTrXFtby6pVq8Kv8/jx46murmbNmjXhcz788EMMwwh/AelKjUl669atfPDBB2RkZLR6zfr169F1vUm1clfbu3cvFRUV4fdJd3/tIVSjNHr0aEaMGNHquUfrdW/ts7Etny/jx49n48aNEV+UGr8EDhkyJC5Big5YuHChstlsasGCBWrTpk3qBz/4gUpLS4vo/dcd3HrrrSo1NVUtWbJElZSUhDeXy6WUUmrbtm3q4YcfVp9//rnauXOnevvtt1X//v3V2Wef3cWRh9x5551qyZIlaufOnWrFihVq8uTJKjMzU5WVlSmllLrllltU37591Ycffqg+//xzNX78eDV+/PgujvqQYDCo+vbtq+6+++6I/d3tda+rq1Pr1q1T69atU4B65pln1Lp168K9op944gmVlpam3n77bbVhwwZ1ySWXqKKiIuV2u8P3mDJliho5cqRatWqVWr58uTrxxBPVtGnTujx+n8+nLr74YtWnTx+1fv36iH8HjT1zP/nkE/WrX/1KrV+/Xm3fvl395S9/UVlZWeq6667r0tjr6urUnDlz1MqVK9XOnTvVBx98oEaNGqVOPPFE5fF4wvfoqte+tfeNUkrV1NQoh8Ohfve73zW5vitf99Y+G5Vq/fMlEAiooUOHqvPOO0+tX79evffeeyorK0vNnTs3LjFKoo6D3/zmN6pv377KarWqsWPHqk8//bSrQ2oCaHabP3++Ukqp4uJidfbZZ6v09HRls9nUCSecoH7605+qmpqarg28wVVXXaXy8vKU1WpVvXv3VldddZXatm1b+Ljb7VY/+tGPVK9evZTD4VCXXnqpKikp6cKII/3vf/9TgNqyZUvE/u72un/00UfNvk+uv/56pVRoiNZ9992ncnJylM1mU5MmTWryO1VUVKhp06appKQklZKSom644QZVV1fX5fHv3Lkz6r+Djz76SCml1Jo1a9S4ceNUamqqstvt6qSTTlKPP/54RDLsithdLpc677zzVFZWlrJYLKpfv37q5ptvblIg6KrXvrX3jVJK/f73v1cJCQmqurq6yfVd+bq39tmoVNs+X3bt2qWmTp2qEhISVGZmprrzzjuV3++PS4yyepYQQgjRjUkbtRBCCNGNSaIWQgghujFJ1EIIIUQ3JolaCCGE6MYkUQshhBDdmCRqIYQQohuTRC2EEEJ0Y5KohRBCiG5MErUQotMVFhby61//uqvDEKJHkkQtxDFmxowZfOc73wFg4sSJ3HHHHUftuRcsWNBk3V6A1atXRyznKYRoO1mPWgjRKp/Ph9Vqbff1WVlZcYxGiOOLlKiFOEbNmDGDpUuX8uyzz6JpGpqmhdf2/fLLL5k6dSpJSUnk5ORw7bXXUl5eHr524sSJ3Hbbbdxxxx1kZmZy/vnnA/DMM88wbNgwEhMTKSgo4Ec/+hFOpxOAJUuWcMMNN1BTUxN+vgcffBBoWvVdXFzMJZdcQlJSEikpKVx55ZUR6/k++OCDnHLKKfz5z3+msLCQ1NRUrr76aurq6jr3RROiG5JELcQx6tlnn2X8+PHcfPPNlJSUUFJSQkFBAdXV1Zx77rmMHDmSzz//nPfee48DBw5w5ZVXRlz/6quvYrVaWbFiBS+++CIAuq7z3HPP8dVXX/Hqq6/y4YcfctdddwFw+umn8+tf/5qUlJTw882ZM6dJXIZhcMkll1BZWcnSpUtZtGgRO3bs4Kqrroo4b/v27bz11lu88847vPPOOyxdupQnnniik14tIbovqfoW4hiVmpqK1WrF4XCQm5sb3v/8888zcuRIHn/88fC+V155hYKCAr755hsGDhwIwIknnshTTz0Vcc/D27sLCwt59NFHueWWW3jhhRewWq2kpqaiaVrE8x1p8eLFbNy4kZ07d1JQUADAn/70J04++WRWr17NqaeeCoQS+oIFC0hOTgbg2muvZfHixTz22GMde2GE6GGkRC3EceaLL77go48+IikpKbwNHjwYCJViG40ePbrJtR988AGTJk2id+/eJCcnc+2111JRUYHL5Wrz82/evJmCgoJwkgYYMmQIaWlpbN68ObyvsLAwnKQB8vLyKCsri+l3FeJYICVqIY4zTqeTiy66iCeffLLJsby8vPDPiYmJEcd27drFt7/9bW699VYee+wx0tPTWb58OTfddBM+nw+HwxHXOC0WS8RjTdMwDCOuzyFETyCJWohjmNVqJRgMRuwbNWoU//jHPygsLMRsbvtHwJo1azAMg1/+8pfoeqgy7o033mj1+Y500kknsWfPHvbs2RMuVW/atInq6mqGDBnS5niEOF5I1bcQx7DCwkJWrVrFrl27KC8vxzAMZs6cSWVlJdOmTWP16tVs376d//3vf9xwww0tJtkTTjgBv9/Pb37zG3bs2MGf//zncCezw5/P6XSyePFiysvLm60Snzx5MsOGDWP69OmsXbuWzz77jOuuu44JEyYwZsyYuL8GQvR0kqiFOIbNmTMHk8nEkCFDyMrKori4mPz8fFasWEEwGOS8885j2LBh3HHHHaSlpYVLys0ZMWIEzzzzDE8++SRDhw7ltddeY968eRHnnH766dxyyy1cddVVZGVlNemMBqEq7LfffptevXpx9tlnM3nyZPr378/f/va3uP/+QhwLNKWU6uoghBBCCNE8KVELIYQQ3ZgkaiGEEKIbk0QthBBCdGOSqIUQQohuTBK1EEII0Y1JohZCCCG6MUnUQgghRDcmiVoIIYToxiRRCyGEEN2YJGohhBCiG5NELYQQQnRjkqiFEEKIbuz/Ac7bpoi4xgISAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# ---------- 1. 读取并整理数据 ----------\n",
    "cut        = 200     # 要展示的最大迭代步数\n",
    "trial_cut  = 20      # 每个算法取前 trial_cut 条独立运行\n",
    "r    = analyse_trial(cut=cut, trial_cut=trial_cut)   # 你的函数\n",
    "results = {}\n",
    "results['Mallows'] = r['pl_botorch_mallows_EI_30']\n",
    "results['Merge'] = r['pl_botorch_merge_EI_30_shift_pairwise_pattern']\n",
    "\n",
    "# 计算全局最优值（所有算法、所有运行、到 cut 步为止的最小值）\n",
    "global_min = np.inf\n",
    "for arr in results.values():\n",
    "    global_min = min(global_min, arr[:, :cut].min())\n",
    "\n",
    "# 把每个算法的 simple regret（best‑so‑far – global_min）整理成均值±std\n",
    "mean_regret = {}\n",
    "std_regret  = {}\n",
    "\n",
    "for algo, outputs in results.items():\n",
    "    outputs        = outputs[:, :cut]                          # shape = (n_runs, cut)\n",
    "    best_so_far    = np.minimum.accumulate(outputs, axis=1)    # shape = (n_runs, cut)\n",
    "    regrets        = best_so_far - global_min                  # simple regret\n",
    "    mean_regret[algo] = regrets.mean(axis=0)                   # (cut,)\n",
    "    std_regret[algo]  = regrets.std(axis=0)\n",
    "\n",
    "# ---------- 2. 画图 ----------\n",
    "iters = np.arange(1, cut + 1)\n",
    "\n",
    "plt.figure(figsize=(5, 4))\n",
    "\n",
    "for algo in mean_regret:\n",
    "    mean = mean_regret[algo]\n",
    "    std  = std_regret[algo]\n",
    "    plt.plot(iters, mean, label=algo)\n",
    "    plt.fill_between(iters, mean - std, mean + std, alpha=0.2)\n",
    "\n",
    "plt.xlabel(\"Iteration\")\n",
    "plt.ylabel(\"Simple Regret (mean ± 1 std)\")\n",
    "# plt.yscale(\"log\")           # 若差距跨数量级，建议用对数轴；可去掉\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"cp_curve.pdf\", dpi=600, bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.11.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
