{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9bbab539",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "23720b09",
   "metadata": {},
   "outputs": [],
   "source": [
    "NUM_SEEDS = 20\n",
    "\n",
    "METHODS = ['les_250_8','mes',  'logei', 'turbo','hci_gibo_09','sobol'] #'grad', 'nograd', 'gibo',\n",
    "LABEL_NAMES = {'les_250_8':'LES (ours)',\n",
    "'mes':'MES',\n",
    "'turbo':'TuRBO',\n",
    "'sobol':'Sobol random', \n",
    "'logei':'logEI',\n",
    "'hci_gibo':'HCI-GIBO',\n",
    "'hci_gibo_09':'HCI-GIBO'}\n",
    "\n",
    "\n",
    "CUM_REGRET = True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "ce27539f",
   "metadata": {},
   "outputs": [],
   "source": [
    "def decompress_gibo(df):\n",
    "    data = df[['y','n']].to_numpy(dtype=float)\n",
    "    repeats = np.diff(data[:,-1].astype(int))\n",
    "    repeats = np.insert(repeats, 0, data[0,-1])\n",
    "    repeated = np.repeat(data[:, :-1], repeats, axis=0)\n",
    "    return np.minimum.accumulate(repeated)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f1756acd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00011_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00012_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00013_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00014_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00015_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00016_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00017_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00018_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00019_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00020_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00011_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00012_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00013_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00014_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00015_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00016_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00017_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00018_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00019_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00020_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00011_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00012_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00013_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00014_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00015_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00016_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00017_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00018_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00019_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00020_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00011_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00012_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00013_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00014_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00015_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00016_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00017_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00018_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00019_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00020_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00011_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00012_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00013_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00014_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00015_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00016_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00017_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00018_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00019_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00020_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00011_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00012_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00013_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00014_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00015_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00016_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00017_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00018_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00019_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00020_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00011_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00012_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00013_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00014_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00015_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00016_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00017_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00018_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00019_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00020_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00011_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00012_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00013_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00014_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00015_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00016_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00017_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00018_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00019_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00020_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00011_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00012_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00013_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00014_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00015_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00016_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00017_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00018_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00019_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00020_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00011_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00012_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00013_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00014_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00015_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00016_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00017_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00018_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00019_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00020_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00011_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00012_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00013_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00014_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00015_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00016_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00017_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00018_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00019_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00020_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00011_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00012_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00013_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00014_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00015_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00016_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00017_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00018_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00019_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/square/sampled_data/sampled_data_history_00020_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00011_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00012_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00013_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00014_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00015_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00016_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00017_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00018_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00019_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00020_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00011_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00012_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00013_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00014_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00015_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00016_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00017_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00018_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00019_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00020_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00011_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00012_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00013_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00014_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00015_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00016_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00017_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00018_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00019_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00020_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00011_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00012_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00013_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00014_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00015_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00016_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00017_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00018_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00019_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00020_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00011_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00012_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00013_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00014_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00015_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00016_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00017_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00018_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00019_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00020_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00011_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00012_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00013_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00014_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00015_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00016_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00017_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00018_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00019_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00020_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00011_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00012_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00013_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00014_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00015_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00016_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00017_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00018_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00019_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00020_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00011_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00012_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00013_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00014_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00015_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00016_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00017_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00018_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00019_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00020_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00011_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00012_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00013_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00014_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00015_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00016_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00017_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00018_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00019_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00020_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00011_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00012_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00013_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00014_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00015_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00016_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00017_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00018_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00019_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00020_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00011_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00012_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00013_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00014_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00015_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00016_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00017_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00018_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00019_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00020_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00011_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00012_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00013_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00014_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00015_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00016_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00017_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00018_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00019_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/dixonprice/sampled_data/sampled_data_history_00020_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00011_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00012_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00013_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00014_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00015_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00016_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00017_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00018_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00019_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00020_5_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00011_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00012_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00013_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00014_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00015_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00016_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00017_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00018_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00019_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00020_5_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00011_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00012_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00013_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00014_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00015_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00016_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00017_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00018_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00019_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00020_5_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00011_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00012_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00013_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00014_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00015_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00016_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00017_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00018_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00019_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00020_5_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00011_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00012_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00013_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00014_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00015_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00016_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00017_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00018_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00019_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00020_5_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00011_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00012_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00013_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00014_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00015_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00016_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00017_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00018_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00019_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00020_5_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00011_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00012_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00013_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00014_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00015_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00016_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00017_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00018_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00019_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00020_30_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00011_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00012_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00013_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00014_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00015_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00016_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00017_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00018_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00019_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00020_30_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00011_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00012_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00013_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00014_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00015_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00016_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00017_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00018_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00019_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00020_30_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00011_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00012_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00013_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00014_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00015_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00016_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00017_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00018_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00019_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00020_30_turbo.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00011_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00012_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00013_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00014_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00015_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00016_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00017_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00018_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00019_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00020_30_hci_gibo_09.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00011_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00012_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00013_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00014_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00015_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00016_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00017_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00018_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00019_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/ackley/sampled_data/sampled_data_history_00020_30_sobol.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/mopta08/sampled_data/sampled_data_history_00001_124_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/mopta08/sampled_data/sampled_data_history_00014_124_les_250_8.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/mopta08/sampled_data/sampled_data_history_00002_124_mes.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/mopta08/sampled_data/sampled_data_history_00001_124_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/mopta08/sampled_data/sampled_data_history_00005_124_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/mopta08/sampled_data/sampled_data_history_00012_124_logei.csv.\n",
      "Unable to find file ./Data/other_functions_non_informative_no_noise/mopta08/sampled_data/sampled_data_history_00006_124_turbo.csv.\n"
     ]
    }
   ],
   "source": [
    "DIMS = {'square': [5,30],\n",
    "        'dixonprice': [5, 30],\n",
    "        'ackley': [5, 30],\n",
    "        'lunar_noise': [12],\n",
    "        'lunar': [12],\n",
    "        'rover': [200],\n",
    "        'rover_trajectory': [60],\n",
    "        'mopta08':[124]}\n",
    "\n",
    "experiment_data = {}\n",
    "\n",
    "## Import analytic functions ## \n",
    "for experiment in ['square', 'dixonprice', 'ackley', 'rover_trajectory', 'lunar','mopta08']: # ackley\n",
    "    BEST_HIST_PATH = f\"./Data/other_functions_non_informative_no_noise/{experiment}/optimizer_history/list_of_bests_\"\n",
    "    SAMPLED_POINTS_PATH = f\"./Data/other_functions_non_informative_no_noise/{experiment}/sampled_data/sampled_data_history_\"\n",
    "    name = \"no_noise\"\n",
    "\n",
    "    if CUM_REGRET:\n",
    "        path = SAMPLED_POINTS_PATH\n",
    "    else:\n",
    "        path = BEST_HIST_PATH  \n",
    "\n",
    "\n",
    "    avrg_best_history = []\n",
    "    std_best_history = []\n",
    "    lower_quantiles_history = []\n",
    "    upper_quantiles_history = []\n",
    "\n",
    "    for dim in DIMS[experiment]: \n",
    "        data_mean = []\n",
    "        stds = []\n",
    "        lower_quantile = []\n",
    "        upper_quantile = []\n",
    "        data_mean_normalized = []\n",
    "        stds_normalized = []\n",
    "        num_opjective_calls = min(20*dim, 400)\n",
    "        if experiment == 'rover':\n",
    "            num_opjective_calls = min(20*dim, 300)\n",
    "        for method in range(len(METHODS)):\n",
    "            y_data = np.zeros((0,0))\n",
    "            for seed in range(NUM_SEEDS):\n",
    "                file_identifier = f'{(seed+1):05d}_{dim}_{METHODS[method]}.csv'\n",
    "                try: \n",
    "                    table = pd.read_csv(path + file_identifier) \n",
    "                except: \n",
    "                    print(f'Unable to find file {path+file_identifier}.')\n",
    "                    continue\n",
    "\n",
    "                if 'gibo' in METHODS[method] and not CUM_REGRET:\n",
    "                    new_data = decompress_gibo(table.dropna())\n",
    "                else:\n",
    "                    new_data = np.reshape(table['y'].to_numpy(), [-1,1])\n",
    "\n",
    "                if CUM_REGRET:\n",
    "                    if y_data.shape[0] == 0:\n",
    "                        y_data = np.expand_dims(np.cumsum(new_data[:num_opjective_calls, :]),axis = 1)\n",
    "                    else: \n",
    "                        new_data = np.expand_dims(np.cumsum(new_data[:num_opjective_calls, :]),axis = 1)\n",
    "                        y_data = np.concatenate([y_data, new_data], axis=1)\n",
    "                else:\n",
    "                    if y_data.shape[0] == 0:\n",
    "                        y_data = new_data[:num_opjective_calls, :]\n",
    "                    else: \n",
    "                        new_data = new_data[:num_opjective_calls, :]\n",
    "                        y_data = np.concatenate([y_data, new_data], axis=1)\n",
    "\n",
    "            data_mean.append(np.median(y_data, axis=1))\n",
    "            stds.append(np.std(y_data, axis=1))\n",
    "            lower_quantile.append(np.quantile(y_data, 0.25, axis=1))\n",
    "            upper_quantile.append(np.quantile(y_data, 0.75, axis=1))\n",
    "\n",
    "        avrg_best_history.append(data_mean)\n",
    "        std_best_history.append(stds)\n",
    "        lower_quantiles_history.append(lower_quantile)\n",
    "        upper_quantiles_history.append(upper_quantile)\n",
    "    experiment_data[experiment] = {'avrg': avrg_best_history,\n",
    "                                   'std' : std_best_history,\n",
    "                                   'lower' : lower_quantiles_history,\n",
    "                                   'upper' : upper_quantiles_history}\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "45f03d41",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib as mpl\n",
    "from matplotlib.ticker import MaxNLocator\n",
    "from matplotlib.ticker import MultipleLocator, LinearLocator\n",
    "from matplotlib.lines import Line2D\n",
    "\n",
    "# Change font to Computer Modern\n",
    "mpl.rcParams.update({\n",
    "    \"text.usetex\": True,\n",
    "    \"font.family\": \"serif\",  # LaTeX default is Computer Modern\n",
    "    \"font.serif\": [\"Computer Modern Roman\"],\n",
    "    \"axes.unicode_minus\": False  # to handle minus signs correctly\n",
    "})\n",
    "\n",
    "\n",
    "\n",
    "colors =anonymized\n",
    "\n",
    "\n",
    "width = 397.48 /72.27 # pt to in"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "575fbca3",
   "metadata": {},
   "outputs": [],
   "source": [
    "if not CUM_REGRET:\n",
    "\n",
    "    aspect_ratio = 0.25\n",
    "    fontsize = 8\n",
    "    linewidth = 0.8\n",
    "    fig, axs = plt.subplots(1,4, figsize=(width,width*aspect_ratio))\n",
    "\n",
    "    #############################\n",
    "    ### SQUARE                ###\n",
    "    #############################\n",
    "    experiment = 'square'\n",
    "    indices = [0]\n",
    "    avrg_best_history = experiment_data[experiment]['avrg']\n",
    "    upper_quantiles_history = experiment_data[experiment]['upper']\n",
    "    lower_quantiles_history = experiment_data[experiment]['lower']\n",
    "\n",
    "\n",
    "    for dim, index in enumerate(indices):\n",
    "        dim=dim+1\n",
    "        ax = axs.flat[index]\n",
    "\n",
    "        all_y_values = []\n",
    "\n",
    "        for method in range(len(METHODS)):\n",
    "            all_y_values.append(avrg_best_history[dim][method])\n",
    "            all_y_values.append(upper_quantiles_history[dim][method])\n",
    "            all_y_values.append(lower_quantiles_history[dim][method])\n",
    "\n",
    "        # Flatten and stack all y-data for this subplot\n",
    "        all_y_values = np.concatenate([y.flatten() for y in all_y_values])\n",
    "        y_min, y_max = all_y_values.min(), all_y_values.max()\n",
    "        y_range = y_max - y_min if y_max != y_min else 1  # avoid divide by zero\n",
    "\n",
    "        for method in range(len(METHODS)):\n",
    "            # Normalize line\n",
    "            y_line = avrg_best_history[dim][method]\n",
    "            y_line_norm = (y_line - y_min) / y_range\n",
    "            ax.plot(y_line_norm, color=colors[method], linestyle='-', linewidth=linewidth, zorder=len(METHODS)-method+1)\n",
    "\n",
    "            # Normalize fill-between area\n",
    "            x = np.arange(1, upper_quantiles_history[dim][method].shape[0]+1)\n",
    "            y_upper = (upper_quantiles_history[dim][method] - y_min) / y_range\n",
    "            y_lower = (lower_quantiles_history[dim][method] - y_min) / y_range\n",
    "            ax.fill_between(x, y_upper, y_lower, color=colors[method], alpha=0.2)\n",
    "        \n",
    "        ax.set_xlabel('')\n",
    "        ax.set_title(fr'Square: $d = {DIMS[experiment][dim]}$', fontsize=fontsize)\n",
    "        ax.set_xlim(0, len(avrg_best_history[dim][0]))\n",
    "        ax.set_ylim(-0.05,1)\n",
    "        \n",
    "        #ax.yaxis.set_major_locator(MaxNLocator(nbins=2))  # Adjust number of x-axis gridlines\n",
    "        ax.set_yticks([0.0, 0.5, 1.0])\n",
    "        ax.xaxis.set_minor_locator(MaxNLocator(integer=True, nbins=4))  # Adjust number of y-axis gridlines\n",
    "        ax.yaxis.set_minor_locator(MaxNLocator(nbins=5))\n",
    "        ax.set_xticks([0,np.ceil(len(avrg_best_history[dim][0])/100)*50,np.ceil(len(avrg_best_history[dim][0])/100)*100])\n",
    "\n",
    "        #ax.minorticks_on()\n",
    "        ax.tick_params(axis='both', which='both', size=0)\n",
    "        ax.grid(which='major', linestyle='-', linewidth=0.5, alpha=0.7) \n",
    "        ax.grid(which='minor', linestyle='--', linewidth=0.3, alpha=0.7) \n",
    "        ax.tick_params(axis='both', which='major', labelsize=fontsize)\n",
    "\n",
    "        for spine in ax.spines.values():\n",
    "            spine.set_zorder(100)\n",
    "\n",
    "    #fig.text(0.19, 0.9, \"Square\", ha='center', va='center', fontsize=fontsize+1)\n",
    "\n",
    "    #############################\n",
    "    ### Ackley                ###\n",
    "    #############################\n",
    "    experiment = 'ackley'#'ackley'\n",
    "    indices = [1] #1\n",
    "    avrg_best_history = experiment_data[experiment]['avrg']\n",
    "    upper_quantiles_history = experiment_data[experiment]['upper']\n",
    "    lower_quantiles_history = experiment_data[experiment]['lower']\n",
    "\n",
    "\n",
    "    for dim, index in enumerate(indices):\n",
    "        dim=dim+1\n",
    "        dim = 1\n",
    "        ax = axs.flat[index]\n",
    "        all_y_values = []\n",
    "\n",
    "        for method in range(len(METHODS)):\n",
    "            all_y_values.append(avrg_best_history[dim][method])\n",
    "            all_y_values.append(upper_quantiles_history[dim][method])\n",
    "            all_y_values.append(lower_quantiles_history[dim][method])\n",
    "\n",
    "        # Flatten and stack all y-data for this subplot\n",
    "        all_y_values = np.concatenate([y.flatten() for y in all_y_values])\n",
    "        y_min, y_max = all_y_values.min(), all_y_values.max()\n",
    "        y_range = y_max - y_min if y_max != y_min else 1  # avoid divide by zero\n",
    "\n",
    "        for method in range(len(METHODS)):\n",
    "            # Normalize line\n",
    "            y_line = avrg_best_history[dim][method]\n",
    "            y_line_norm = (y_line - y_min) / y_range\n",
    "            ax.plot(y_line_norm, color=colors[method], linestyle='-', linewidth=linewidth, zorder=len(METHODS)-method+1)\n",
    "\n",
    "            # Normalize fill-between area\n",
    "            x = np.arange(1, upper_quantiles_history[dim][method].shape[0]+1)\n",
    "            y_upper = (upper_quantiles_history[dim][method] - y_min) / y_range\n",
    "            y_lower = (lower_quantiles_history[dim][method] - y_min) / y_range\n",
    "            ax.fill_between(x, y_upper, y_lower, color=colors[method], alpha=0.2)\n",
    "        \n",
    "        ax.set_xlabel('')\n",
    "        ax.set_title(fr'Ackley: $d = {DIMS[experiment][dim]}$', fontsize=fontsize)\n",
    "        ax.set_xlim(0, len(avrg_best_history[dim][0]))\n",
    "        ax.set_ylim(-0.05,1)\n",
    "        ax.set_yticklabels([])\n",
    "        \n",
    "        ax.set_yticks([0.0, 0.5, 1.0])\n",
    "        ax.xaxis.set_minor_locator(MaxNLocator(integer=True, nbins=4))  # Adjust number of y-axis gridlines\n",
    "        ax.yaxis.set_minor_locator(MaxNLocator(nbins=5))\n",
    "        ax.set_xticks([0,np.ceil(len(avrg_best_history[dim][0])/100)*50,np.ceil(len(avrg_best_history[dim][0])/100)*100])\n",
    "\n",
    "        #ax.minorticks_on()\n",
    "        ax.tick_params(axis='both', which='both', size=0)\n",
    "        ax.grid(which='major', linestyle='-', linewidth=0.5, alpha=0.7) \n",
    "        ax.grid(which='minor', linestyle='--', linewidth=0.3, alpha=0.7) \n",
    "        ax.tick_params(axis='both', which='major', labelsize=fontsize)\n",
    "\n",
    "        for spine in ax.spines.values():\n",
    "            spine.set_zorder(100)\n",
    "\n",
    "    #fig.text(0.41, 0.9, \"Ackley\", ha='center', va='center', fontsize=fontsize+1) \n",
    "\n",
    "    #############################\n",
    "    ### Lunar                ###\n",
    "    #############################\n",
    "    experiment = 'rover_trajectory'\n",
    "    indices = [2]\n",
    "    avrg_best_history = experiment_data[experiment]['avrg']\n",
    "    upper_quantiles_history = experiment_data[experiment]['upper']\n",
    "    lower_quantiles_history = experiment_data[experiment]['lower']\n",
    "\n",
    "\n",
    "    for dim, index in enumerate(indices):\n",
    "        ax = axs.flat[index]\n",
    "        all_y_values = []\n",
    "\n",
    "        for method in range(len(METHODS)):\n",
    "            all_y_values.append(avrg_best_history[dim][method])\n",
    "            all_y_values.append(upper_quantiles_history[dim][method])\n",
    "            all_y_values.append(lower_quantiles_history[dim][method])\n",
    "\n",
    "        # Flatten and stack all y-data for this subplot\n",
    "        all_y_values = np.concatenate([y.flatten() for y in all_y_values])\n",
    "        y_min, y_max = all_y_values.min(), all_y_values.max()\n",
    "        y_range = y_max - y_min if y_max != y_min else 1  # avoid divide by zero\n",
    "\n",
    "        for method in range(len(METHODS)):\n",
    "            # Normalize line\n",
    "            y_line = avrg_best_history[dim][method]\n",
    "            y_line_norm = (y_line - y_min) / y_range\n",
    "            ax.plot(y_line_norm, color=colors[method], linestyle='-', linewidth=linewidth, zorder=len(METHODS)-method+1)\n",
    "\n",
    "            # Normalize fill-between area\n",
    "            x = np.arange(1, upper_quantiles_history[dim][method].shape[0]+1)\n",
    "            y_upper = (upper_quantiles_history[dim][method] - y_min) / y_range\n",
    "            y_lower = (lower_quantiles_history[dim][method] - y_min) / y_range\n",
    "            ax.fill_between(x, y_upper, y_lower, color=colors[method], alpha=0.2)\n",
    "        \n",
    "        ax.set_xlabel('')\n",
    "        ax.set_title(fr'Rover: $d = {DIMS[experiment][dim]}$', fontsize=fontsize)\n",
    "        ax.set_xlim(0, 240)\n",
    "        ax.set_ylim(-0.05,1)\n",
    "        \n",
    "        #ax.yaxis.set_major_locator(MaxNLocator(nbins=4))  # Adjust number of x-axis gridlines\n",
    "        ax.set_yticks([0.0, 0.5, 1.0])\n",
    "        ax.xaxis.set_minor_locator(MaxNLocator(integer=True, nbins=4))  # Adjust number of y-axis gridlines\n",
    "        ax.yaxis.set_minor_locator(MaxNLocator(nbins=5))\n",
    "        ax.set_xticks([0,120,240])\n",
    "        ax.set_yticklabels([])\n",
    "\n",
    "        #ax.minorticks_on()\n",
    "        ax.tick_params(axis='both', which='both', size=0)\n",
    "        ax.grid(which='major', linestyle='-', linewidth=0.5, alpha=0.7) \n",
    "        ax.grid(which='minor', linestyle='--', linewidth=0.3, alpha=0.7) \n",
    "        ax.tick_params(axis='both', which='major', labelsize=fontsize)\n",
    "        ax.yaxis.get_offset_text().set_fontsize(fontsize-2)\n",
    "\n",
    "        for spine in ax.spines.values():\n",
    "            spine.set_zorder(100)\n",
    "\n",
    "    #fig.text(0.643, 0.9, \"Lunar\", ha='center', va='center', fontsize=fontsize+1) \n",
    "\n",
    "\n",
    "    #############################\n",
    "    ### Rover                ###\n",
    "    #############################\n",
    "    experiment = 'mopta08'\n",
    "    indices = [3]\n",
    "    avrg_best_history = experiment_data[experiment]['avrg']\n",
    "    upper_quantiles_history = experiment_data[experiment]['upper']\n",
    "    lower_quantiles_history = experiment_data[experiment]['lower']\n",
    "\n",
    "\n",
    "    for dim, index in enumerate(indices):\n",
    "        ax = axs.flat[index]\n",
    "        all_y_values = []\n",
    "\n",
    "        for method in range(len(METHODS)):\n",
    "            all_y_values.append(avrg_best_history[dim][method])\n",
    "            all_y_values.append(upper_quantiles_history[dim][method])\n",
    "            all_y_values.append(lower_quantiles_history[dim][method])\n",
    "\n",
    "        # Flatten and stack all y-data for this subplot\n",
    "        all_y_values = np.concatenate([y.flatten() for y in all_y_values])\n",
    "        y_min, y_max = all_y_values.min(), all_y_values.max()\n",
    "        y_range = y_max - y_min if y_max != y_min else 1  # avoid divide by zero\n",
    "\n",
    "        for method in range(len(METHODS)):\n",
    "            # Normalize line\n",
    "            y_line = avrg_best_history[dim][method]\n",
    "            y_line_norm = (y_line - y_min) / y_range\n",
    "            ax.plot(y_line_norm, color=colors[method], linestyle='-', linewidth=linewidth, zorder=len(METHODS)-method+1)\n",
    "\n",
    "            # Normalize fill-between area\n",
    "            x = np.arange(1, upper_quantiles_history[dim][method].shape[0]+1)\n",
    "            y_upper = (upper_quantiles_history[dim][method] - y_min) / y_range\n",
    "            y_lower = (lower_quantiles_history[dim][method] - y_min) / y_range\n",
    "            ax.fill_between(x, y_upper, y_lower, color=colors[method], alpha=0.2)\n",
    "        \n",
    "        ax.set_xlabel('')\n",
    "        ax.set_title(fr'Mopta08: $d = {DIMS[experiment][dim]}$', fontsize=fontsize)\n",
    "        ax.set_xlim(0, len(avrg_best_history[dim][1]))\n",
    "        ax.set_ylim(-0.05, 1)\n",
    "        \n",
    "\n",
    "        ax.xaxis.set_minor_locator(MaxNLocator(nbins=4))  \n",
    "        ax.yaxis.set_minor_locator(MaxNLocator(nbins=5))\n",
    "        ax.set_xticks([0,np.ceil(len(avrg_best_history[dim][1])/100)*50,np.ceil(len(avrg_best_history[dim][1])/100)*100])\n",
    "        ax.set_yticks([0.0, 0.5, 1.0])\n",
    "        ax.set_yticklabels([])\n",
    "\n",
    "        #ax.minorticks_on()\n",
    "        ax.tick_params(axis='both', which='both', size=0)\n",
    "        ax.grid(which='major', linestyle='-', linewidth=0.5, alpha=0.7) \n",
    "        ax.grid(which='minor', linestyle='--', linewidth=0.3, alpha=0.7) \n",
    "        ax.tick_params(axis='both', which='major', labelsize=fontsize)\n",
    "        #ax.ticklabel_format(style='sci', axis='y', scilimits=(0,0))\n",
    "        ax.yaxis.get_offset_text().set_fontsize(fontsize-2)\n",
    "\n",
    "        for spine in ax.spines.values():\n",
    "            spine.set_zorder(100)\n",
    "\n",
    "    #fig.text(0.864, 0.9, \"Rover\", ha='center', va='center', fontsize=fontsize+1)\n",
    "\n",
    "\n",
    "    #############################\n",
    "    ### GENERAL               ###\n",
    "    #############################\n",
    "\n",
    "    #axs[0][0].set_yticks([x for x in range(-10,1,2)])\n",
    "    #axs.flat[0].set_yticks(np.linspace(0, -2, 3))\n",
    "    axs.flat[0].set_ylabel(r'$\\overline{f}(\\hat{\\mathbf{x}}^*)$', fontsize=fontsize)\n",
    "    fig.text(0.5, 0.01, r'Evaluations \\#', ha='center', fontsize=fontsize)\n",
    "    legend_elements = [Line2D([0], [0], color=colors[i], lw=linewidth*1.2, linestyle='-', label=LABEL_NAMES[METHODS[i]]) for i in range(len(METHODS))]\n",
    "\n",
    "    fig.tight_layout(rect=[0, 0, 1, 0.93], h_pad=1.)  # adjust layout to leave space below\n",
    "    fig.legend(\n",
    "        handles=legend_elements,\n",
    "        loc='lower center',\n",
    "        bbox_to_anchor=(0.5, -0.3),\n",
    "        ncol=3,\n",
    "        fontsize=fontsize,\n",
    "        frameon=False,\n",
    "    )\n",
    "    plt.subplots_adjust(wspace=0.15)\n",
    "    fig.savefig(name + \"analytic_comparisons_short.pdf\", bbox_inches='tight', pad_inches=0.0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "26a04550",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 549.993x420.745 with 9 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "aspect_ratio = 0.45\n",
    "fontsize = 8\n",
    "linewidth = 0.8\n",
    "\n",
    "LAYOUT_3by3 = True\n",
    "\n",
    "if LAYOUT_3by3:\n",
    "    fig, axs = plt.subplots(3,3, figsize=(width,width*aspect_ratio*1.7))\n",
    "else:\n",
    "    fig, axs = plt.subplots(2,4, figsize=(width,width*aspect_ratio))\n",
    "\n",
    "#############################\n",
    "### SQUARE                ###\n",
    "#############################\n",
    "experiment = 'square'\n",
    "if LAYOUT_3by3:\n",
    "    indices = [0,3]\n",
    "else:\n",
    "    indices = [0,4]\n",
    "avrg_best_history = experiment_data[experiment]['avrg']\n",
    "upper_quantiles_history = experiment_data[experiment]['upper']\n",
    "lower_quantiles_history = experiment_data[experiment]['lower']\n",
    "\n",
    "\n",
    "for dim, index in enumerate(indices):\n",
    "    ax = axs.flat[index]\n",
    "    for method in range(len(METHODS)):\n",
    "        ax.plot(avrg_best_history[dim][method], color=colors[method], linestyle='-', linewidth=linewidth, zorder=len(METHODS)-method+1)\n",
    "        x = np.arange(1, upper_quantiles_history[dim][method].shape[0]+1)\n",
    "        ax.fill_between(x, upper_quantiles_history[dim][method], lower_quantiles_history[dim][method], \n",
    "                           color=colors[method], alpha=0.2)\n",
    "    \n",
    "    ax.set_xlabel('')\n",
    "    ax.set_title(fr'Square $d = {DIMS[experiment][dim]}$', fontsize=fontsize)\n",
    "    ax.set_xlim(0, len(avrg_best_history[dim][0]))\n",
    "    \n",
    "    ax.yaxis.set_major_locator(MaxNLocator(nbins=4))  # Adjust number of x-axis gridlines\n",
    "    ax.xaxis.set_minor_locator(MaxNLocator(integer=True, nbins=4))  # Adjust number of y-axis gridlines\n",
    "    #ax.yaxis.set_minor_locator(MaxNLocator(integer=True, nbins=4))\n",
    "    ax.set_xticks([0,np.ceil(len(avrg_best_history[dim][0])/100)*50,np.ceil(len(avrg_best_history[dim][0])/100)*100])\n",
    "\n",
    "    #ax.minorticks_on()\n",
    "    ax.tick_params(axis='both', which='both', size=0)\n",
    "    ax.grid(which='major', linestyle='-', linewidth=0.5, alpha=0.7) \n",
    "    ax.grid(which='minor', linestyle='--', linewidth=0.3, alpha=0.7) \n",
    "    ax.tick_params(axis='both', which='major', labelsize=fontsize)\n",
    "\n",
    "    for spine in ax.spines.values():\n",
    "        spine.set_zorder(100)\n",
    "\n",
    "#fig.text(0.195, 0.92, \"Square\", ha='center', va='center', fontsize=fontsize+1)\n",
    "\n",
    "#############################\n",
    "### DIXONPRICE            ###\n",
    "#############################\n",
    "experiment = 'dixonprice'\n",
    "if LAYOUT_3by3:\n",
    "    indices = [1,4]\n",
    "else:\n",
    "    indices = [1,5]\n",
    "avrg_best_history = experiment_data[experiment]['avrg']\n",
    "upper_quantiles_history = experiment_data[experiment]['upper']\n",
    "lower_quantiles_history = experiment_data[experiment]['lower']\n",
    "\n",
    "\n",
    "for dim, index in enumerate(indices):\n",
    "    ax = axs.flat[index]\n",
    "    for method in range(len(METHODS)):\n",
    "        ax.plot(avrg_best_history[dim][method], color=colors[method], linestyle='-', linewidth=linewidth, zorder=len(METHODS)-method+1)\n",
    "        x = np.arange(1, upper_quantiles_history[dim][method].shape[0]+1)\n",
    "        ax.fill_between(x, upper_quantiles_history[dim][method], lower_quantiles_history[dim][method], \n",
    "                           color=colors[method], alpha=0.2)\n",
    "    \n",
    "    ax.set_xlabel('')\n",
    "    ax.set_title(fr'Dixon-P. $d = {DIMS[experiment][dim]}$', fontsize=fontsize)\n",
    "    ax.set_xlim(0, len(avrg_best_history[dim][0]))\n",
    "    \n",
    "    ax.yaxis.set_major_locator(MaxNLocator(nbins=4))  # Adjust number of x-axis gridlines\n",
    "    ax.xaxis.set_minor_locator(MaxNLocator(integer=True, nbins=4))  # Adjust number of y-axis gridlines\n",
    "    #ax.yaxis.set_minor_locator(MaxNLocator(integer=True, nbins=4))\n",
    "    ax.set_xticks([0,np.ceil(len(avrg_best_history[dim][0])/100)*50,np.ceil(len(avrg_best_history[dim][0])/100)*100])\n",
    "\n",
    "    #ax.minorticks_on()\n",
    "    ax.tick_params(axis='both', which='both', size=0)\n",
    "    ax.grid(which='major', linestyle='-', linewidth=0.5, alpha=0.7) \n",
    "    ax.grid(which='minor', linestyle='--', linewidth=0.3, alpha=0.7) \n",
    "\n",
    "    ax.tick_params(axis='both', which='major', labelsize=fontsize)\n",
    "    ax.yaxis.get_offset_text().set_fontsize(fontsize-2)\n",
    "\n",
    "    ax.ticklabel_format(style='sci', axis='y', scilimits=(0,0))\n",
    "\n",
    "    for spine in ax.spines.values():\n",
    "        spine.set_zorder(100)\n",
    "\n",
    "#fig.text(0.42, 0.92, \"Dixon-Price\", ha='center', va='center', fontsize=fontsize+1)\n",
    "\n",
    "#############################\n",
    "### Ackley                ###\n",
    "#############################\n",
    "experiment = 'ackley'\n",
    "if LAYOUT_3by3:\n",
    "    indices = [2,5]\n",
    "else:\n",
    "    indices = [2,6]\n",
    "avrg_best_history = experiment_data[experiment]['avrg']\n",
    "upper_quantiles_history = experiment_data[experiment]['upper']\n",
    "lower_quantiles_history = experiment_data[experiment]['lower']\n",
    "\n",
    "\n",
    "for dim, index in enumerate(indices):\n",
    "    ax = axs.flat[index]\n",
    "    for method in range(len(METHODS)):\n",
    "        ax.plot(avrg_best_history[dim][method], color=colors[method], linestyle='-', linewidth=linewidth, zorder=len(METHODS)-method+1)\n",
    "        x = np.arange(1, upper_quantiles_history[dim][method].shape[0]+1)\n",
    "        ax.fill_between(x, upper_quantiles_history[dim][method], lower_quantiles_history[dim][method], \n",
    "                           color=colors[method], alpha=0.2)\n",
    "    \n",
    "    ax.set_xlabel('')\n",
    "    ax.set_title(fr'Ackley $d = {DIMS[experiment][dim]}$', fontsize=fontsize)\n",
    "    ax.set_xlim(0, len(avrg_best_history[dim][0]))\n",
    "    \n",
    "    ax.yaxis.set_major_locator(MaxNLocator(nbins=4))  # Adjust number of x-axis gridlines\n",
    "    ax.xaxis.set_minor_locator(MaxNLocator(integer=True, nbins=4))  # Adjust number of y-axis gridlines\n",
    "    #ax.yaxis.set_minor_locator(MaxNLocator(integer=True, nbins=4))\n",
    "    ax.set_xticks([0,np.ceil(len(avrg_best_history[dim][0])/100)*50,np.ceil(len(avrg_best_history[dim][0])/100)*100])\n",
    "\n",
    "    #ax.minorticks_on()\n",
    "    ax.tick_params(axis='both', which='both', size=0)\n",
    "    ax.grid(which='major', linestyle='-', linewidth=0.5, alpha=0.7) \n",
    "    ax.grid(which='minor', linestyle='--', linewidth=0.3, alpha=0.7) \n",
    "    ax.tick_params(axis='both', which='major', labelsize=fontsize)\n",
    "\n",
    "    for spine in ax.spines.values():\n",
    "        spine.set_zorder(100)\n",
    "\n",
    "#fig.text(0.643, 0.92, \"Ackley\", ha='center', va='center', fontsize=fontsize+1)\n",
    "\n",
    "#############################\n",
    "### Lunar                ###\n",
    "#############################\n",
    "experiment = 'lunar'\n",
    "indices = [6]\n",
    "avrg_best_history = experiment_data[experiment]['avrg']\n",
    "upper_quantiles_history = experiment_data[experiment]['upper']\n",
    "lower_quantiles_history = experiment_data[experiment]['lower']\n",
    "\n",
    "\n",
    "for dim, index in enumerate(indices):\n",
    "    ax = axs.flat[index]\n",
    "    for method in range(len(METHODS)):\n",
    "        ax.plot(avrg_best_history[dim][method], color=colors[method], linestyle='-', linewidth=linewidth, zorder=len(METHODS)-method+1)\n",
    "        x = np.arange(1, upper_quantiles_history[dim][method].shape[0]+1)\n",
    "        ax.fill_between(x, upper_quantiles_history[dim][method], lower_quantiles_history[dim][method], \n",
    "                           color=colors[method], alpha=0.2)\n",
    "    \n",
    "    ax.set_xlabel('')\n",
    "    ax.set_title(fr'Lunar $d = {DIMS[experiment][dim]}$', fontsize=fontsize)\n",
    "    ax.set_xlim(0, 240)\n",
    "    \n",
    "    ax.yaxis.set_major_locator(MaxNLocator(nbins=4))  # Adjust number of x-axis gridlines\n",
    "    ax.xaxis.set_minor_locator(MaxNLocator(integer=True, nbins=4))  # Adjust number of y-axis gridlines\n",
    "    #ax.yaxis.set_minor_locator(MaxNLocator(integer=True, nbins=4))\n",
    "    ax.set_xticks([0,120,240])\n",
    "\n",
    "    #ax.minorticks_on()\n",
    "    ax.tick_params(axis='both', which='both', size=0)\n",
    "    ax.grid(which='major', linestyle='-', linewidth=0.5, alpha=0.7) \n",
    "    ax.grid(which='minor', linestyle='--', linewidth=0.3, alpha=0.7) \n",
    "    ax.tick_params(axis='both', which='major', labelsize=fontsize)\n",
    "    ax.ticklabel_format(style='sci', axis='y', scilimits=(0,0))\n",
    "    ax.yaxis.get_offset_text().set_fontsize(fontsize-2)\n",
    "\n",
    "    for spine in ax.spines.values():\n",
    "        spine.set_zorder(100)\n",
    "\n",
    "#fig.text(0.87, 0.92, \"Lunar\", ha='center', va='center', fontsize=fontsize+1)\n",
    "\n",
    "\n",
    "#############################\n",
    "### Rover                ###\n",
    "#############################\n",
    "experiment = 'rover_trajectory'\n",
    "indices = [7]\n",
    "avrg_best_history = experiment_data[experiment]['avrg']\n",
    "upper_quantiles_history = experiment_data[experiment]['upper']\n",
    "lower_quantiles_history = experiment_data[experiment]['lower']\n",
    "\n",
    "\n",
    "for dim, index in enumerate(indices):\n",
    "    ax = axs.flat[index]\n",
    "    for method in range(len(METHODS)):\n",
    "        ax.plot(avrg_best_history[dim][method], color=colors[method], linestyle='-', linewidth=linewidth, zorder=len(METHODS)-method+1)\n",
    "        x = np.arange(1, upper_quantiles_history[dim][method].shape[0]+1)\n",
    "        ax.fill_between(x, upper_quantiles_history[dim][method], lower_quantiles_history[dim][method], \n",
    "                           color=colors[method], alpha=0.2)\n",
    "    \n",
    "    ax.set_xlabel('')\n",
    "    ax.set_title(fr'Rover $d = {DIMS[experiment][dim]}$', fontsize=fontsize)\n",
    "    ax.set_xlim(0, len(avrg_best_history[dim][1]))\n",
    "    \n",
    "    ax.yaxis.set_major_locator(MaxNLocator(nbins=4))  # Adjust number of x-axis gridlines\n",
    "    ax.xaxis.set_minor_locator(MaxNLocator(nbins=4))  # Adjust number of y-axis gridlines\n",
    "    #ax.yaxis.set_minor_locator(MaxNLocator(integer=True, nbins=4))\n",
    "    ax.set_xticks([0,np.ceil(len(avrg_best_history[dim][1])/100)*50,np.ceil(len(avrg_best_history[dim][1])/100)*100])\n",
    "\n",
    "    #ax.minorticks_on()\n",
    "    ax.tick_params(axis='both', which='both', size=0)\n",
    "    ax.grid(which='major', linestyle='-', linewidth=0.5, alpha=0.7) \n",
    "    ax.grid(which='minor', linestyle='--', linewidth=0.3, alpha=0.7) \n",
    "    ax.tick_params(axis='both', which='major', labelsize=fontsize)\n",
    "    ax.ticklabel_format(style='sci', axis='y', scilimits=(0,0))\n",
    "    ax.yaxis.get_offset_text().set_fontsize(fontsize-2)\n",
    "\n",
    "    for spine in ax.spines.values():\n",
    "        spine.set_zorder(100)\n",
    "\n",
    "#fig.text(0.87, 0.45, \"Rover\", ha='center', va='center', fontsize=fontsize+1)\n",
    "\n",
    "\n",
    "experiment = 'mopta08'\n",
    "indices = [8]\n",
    "avrg_best_history = experiment_data[experiment]['avrg']\n",
    "upper_quantiles_history = experiment_data[experiment]['upper']\n",
    "lower_quantiles_history = experiment_data[experiment]['lower']\n",
    "\n",
    "\n",
    "for dim, index in enumerate(indices):\n",
    "    ax = axs.flat[index]\n",
    "    for method in range(len(METHODS)):\n",
    "        ax.plot(avrg_best_history[dim][method], color=colors[method], linestyle='-', linewidth=linewidth, zorder=len(METHODS)-method+1)\n",
    "        x = np.arange(1, upper_quantiles_history[dim][method].shape[0]+1)\n",
    "        ax.fill_between(x, upper_quantiles_history[dim][method], lower_quantiles_history[dim][method], \n",
    "                           color=colors[method], alpha=0.2)\n",
    "    \n",
    "    ax.set_xlabel('')\n",
    "    ax.set_title(fr'Mopta $d = {DIMS[experiment][dim]}$', fontsize=fontsize)\n",
    "    ax.set_xlim(0, len(avrg_best_history[dim][1]))\n",
    "    \n",
    "    ax.yaxis.set_major_locator(MaxNLocator(nbins=4))  # Adjust number of x-axis gridlines\n",
    "    ax.xaxis.set_minor_locator(MaxNLocator(nbins=4))  # Adjust number of y-axis gridlines\n",
    "    #ax.yaxis.set_minor_locator(MaxNLocator(integer=True, nbins=4))\n",
    "    ax.set_xticks([0,np.ceil(len(avrg_best_history[dim][1])/100)*50,np.ceil(len(avrg_best_history[dim][1])/100)*100])\n",
    "\n",
    "    #ax.minorticks_on()\n",
    "    ax.tick_params(axis='both', which='both', size=0)\n",
    "    ax.grid(which='major', linestyle='-', linewidth=0.5, alpha=0.7) \n",
    "    ax.grid(which='minor', linestyle='--', linewidth=0.3, alpha=0.7) \n",
    "    ax.tick_params(axis='both', which='major', labelsize=fontsize)\n",
    "    ax.ticklabel_format(style='sci', axis='y', scilimits=(0,0))\n",
    "    ax.yaxis.get_offset_text().set_fontsize(fontsize-2)\n",
    "\n",
    "    for spine in ax.spines.values():\n",
    "        spine.set_zorder(100)\n",
    "\n",
    "#fig.text(0.87, 0.45, \"Mopta08\", ha='center', va='center', fontsize=fontsize+1)\n",
    "\n",
    "\n",
    "#############################\n",
    "### GENERAL               ###\n",
    "#############################\n",
    "\n",
    "#axs[0][0].set_yticks([x for x in range(-10,1,2)])\n",
    "#axs.flat[0].set_yticks(np.linspace(0, -2, 3))\n",
    "if LAYOUT_3by3:\n",
    "    axs.flat[0].set_ylabel(r'$f(\\hat{\\mathbf{x}}^*)$', fontsize=fontsize)\n",
    "    axs.flat[3].set_ylabel(r'$f(\\hat{\\mathbf{x}}^*)$', fontsize=fontsize)\n",
    "    axs.flat[6].set_ylabel(r'$f(\\hat{\\mathbf{x}}^*)$', fontsize=fontsize)\n",
    "else:\n",
    "    axs.flat[0].set_ylabel(r'$f(\\hat{\\mathbf{x}}^*)$', fontsize=fontsize)\n",
    "    axs.flat[4].set_ylabel(r'$f(\\hat{\\mathbf{x}}^*)$', fontsize=fontsize)\n",
    "fig.text(0.5, 0.01, r'Evaluations \\#', ha='center', fontsize=fontsize)\n",
    "legend_elements = [Line2D([0], [0], color=colors[i], lw=linewidth*1.2, linestyle='-', label=LABEL_NAMES[METHODS[i]]) for i in range(len(METHODS))]\n",
    "\n",
    "#fig.tight_layout(rect=[0, 0, 1, 0.93], h_pad=1.8)  # adjust layout to leave space below\n",
    "fig.tight_layout(rect=[0, 0, 1, 0.93])  # adjust layout to leave space below\n",
    "fig.legend(\n",
    "    handles=legend_elements,\n",
    "    loc='lower center',\n",
    "    bbox_to_anchor=(0.5, -0.1),\n",
    "    ncol=3,\n",
    "    fontsize=fontsize,\n",
    "    frameon=False,\n",
    ")\n",
    "plt.subplots_adjust(wspace=0.3)\n",
    "if CUM_REGRET:\n",
    "    fig.savefig(name + \"analytic_comparisons_cum.pdf\", bbox_inches='tight', pad_inches=0.0)\n",
    "else:\n",
    "    fig.savefig(name + \"analytic_comparisons.pdf\", bbox_inches='tight', pad_inches=0.0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d5bd3a47",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "50f43168",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "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.12.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
