{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "3327fb28-61f4-49c6-b399-0b5ca24b8eaf",
   "metadata": {},
   "outputs": [],
   "source": [
    "import wandb\n",
    "from tqdm import tqdm\n",
    "import numpy as np\n",
    "\n",
    "api = wandb.Api()\n",
    "\n",
    "def load_bayesian_regret_variable_cost_runs(acq, dim, kernel, lengthscale):\n",
    "    runs = api.runs(path=\"ziv-scully-group/PandoraBayesOPT\", filters={\n",
    "        \"sweep\": \"y7ii5yks\", \n",
    "        \"config.amplitude\": 1,\n",
    "        \"config.dim\": dim,\n",
    "        \"config.kernel\": kernel,\n",
    "        \"config.lengthscale\": lengthscale,\n",
    "        \"config.policy\": acq})\n",
    "    \n",
    "    configs_and_metrics = []\n",
    "    for run in tqdm(runs):\n",
    "        metric_keys = [\"cumulative cost\",\"best observed\"]\n",
    "        history = run.scan_history(keys = metric_keys, page_size=1_000_000_000)\n",
    "        metrics = {k: [d[k] for d in history] for k in metric_keys}\n",
    "        summary_metric_keys = [\"global optimum value\"]\n",
    "        summary_history = run.scan_history(keys = summary_metric_keys, page_size=1_000_000_000)\n",
    "        metrics.update({k: [d[k] for d in summary_history] for k in summary_metric_keys})\n",
    "        configs_and_metrics.append((run.config, metrics))\n",
    "\n",
    "    return configs_and_metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c446c8e3-0d6b-45e3-b251-98a12a7c1528",
   "metadata": {},
   "outputs": [],
   "source": [
    "acquisition_functions = {\n",
    "      'BudgetedMultiStepLookaheadEI': 'BudgetedMultiStepLookaheadEI',\n",
    "    }\n",
    "dimensions = [4, 8, 16, 32]\n",
    "kernels = [\"Matern32\", \"Matern52\", \"RBF\"]\n",
    "lengthscales = [1.0, 0.1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "619da050-584b-403d-8342-1148dffddfc4",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 16/16 [00:17<00:00,  1.11s/it]\n",
      "100%|██████████| 16/16 [00:17<00:00,  1.10s/it]\n",
      "100%|██████████| 16/16 [00:17<00:00,  1.12s/it]\n",
      "100%|██████████| 16/16 [00:17<00:00,  1.12s/it]\n",
      "100%|██████████| 16/16 [00:18<00:00,  1.14s/it]\n",
      "100%|██████████| 16/16 [00:16<00:00,  1.06s/it]\n",
      "100%|██████████| 16/16 [00:17<00:00,  1.10s/it]\n",
      "100%|██████████| 16/16 [00:17<00:00,  1.10s/it]\n",
      "100%|██████████| 16/16 [00:16<00:00,  1.05s/it]\n",
      "100%|██████████| 16/16 [00:17<00:00,  1.07s/it]\n",
      "100%|██████████| 16/16 [00:17<00:00,  1.06s/it]\n",
      "100%|██████████| 16/16 [00:17<00:00,  1.06s/it]\n",
      "100%|██████████| 16/16 [00:17<00:00,  1.07s/it]\n",
      "100%|██████████| 16/16 [00:17<00:00,  1.11s/it]\n",
      "100%|██████████| 16/16 [00:17<00:00,  1.07s/it]\n",
      "100%|██████████| 16/16 [00:17<00:00,  1.10s/it]\n",
      "100%|██████████| 16/16 [00:18<00:00,  1.13s/it]\n",
      "100%|██████████| 16/16 [00:16<00:00,  1.03s/it]\n",
      "100%|██████████| 16/16 [00:15<00:00,  1.01it/s]\n",
      "100%|██████████| 16/16 [00:16<00:00,  1.01s/it]\n",
      "100%|██████████| 16/16 [00:16<00:00,  1.03s/it]\n",
      "100%|██████████| 16/16 [00:15<00:00,  1.05it/s]\n",
      "100%|██████████| 16/16 [00:13<00:00,  1.16it/s]\n",
      "100%|██████████| 16/16 [00:15<00:00,  1.05it/s]\n"
     ]
    }
   ],
   "source": [
    "grouped_runs = {(a,d,k,l): load_bayesian_regret_variable_cost_runs(a,d,k,l) for a in acquisition_functions.keys() for d in (dimensions) for k in (kernels) for l in (lengthscales)}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "fb3b1053-3fd6-4cec-8510-5723cf0037ef",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BudgetedMultiStepLookaheadEI 4 Matern32 1.0 (101, 16)\n",
      "BudgetedMultiStepLookaheadEI 4 Matern32 0.1 (201, 16)\n",
      "BudgetedMultiStepLookaheadEI 4 Matern52 1.0 (101, 16)\n",
      "BudgetedMultiStepLookaheadEI 4 Matern52 0.1 (201, 16)\n",
      "BudgetedMultiStepLookaheadEI 4 RBF 1.0 (101, 16)\n",
      "BudgetedMultiStepLookaheadEI 4 RBF 0.1 (201, 16)\n",
      "BudgetedMultiStepLookaheadEI 8 Matern32 1.0 (201, 16)\n",
      "BudgetedMultiStepLookaheadEI 8 Matern32 0.1 (401, 16)\n",
      "BudgetedMultiStepLookaheadEI 8 Matern52 1.0 (201, 16)\n",
      "BudgetedMultiStepLookaheadEI 8 Matern52 0.1 (401, 16)\n",
      "BudgetedMultiStepLookaheadEI 8 RBF 1.0 (201, 16)\n",
      "BudgetedMultiStepLookaheadEI 8 RBF 0.1 (401, 16)\n",
      "BudgetedMultiStepLookaheadEI 16 Matern32 1.0 (401, 16)\n",
      "BudgetedMultiStepLookaheadEI 16 Matern32 0.1 (801, 16)\n",
      "BudgetedMultiStepLookaheadEI 16 Matern52 1.0 (401, 16)\n",
      "BudgetedMultiStepLookaheadEI 16 Matern52 0.1 (801, 16)\n",
      "BudgetedMultiStepLookaheadEI 16 RBF 1.0 (401, 16)\n",
      "BudgetedMultiStepLookaheadEI 16 RBF 0.1 (801, 16)\n",
      "BudgetedMultiStepLookaheadEI 32 Matern32 1.0 (801, 16)\n",
      "BudgetedMultiStepLookaheadEI 32 Matern32 0.1 (801, 16)\n",
      "BudgetedMultiStepLookaheadEI 32 Matern52 1.0 (801, 16)\n",
      "BudgetedMultiStepLookaheadEI 32 Matern52 0.1 (801, 16)\n",
      "BudgetedMultiStepLookaheadEI 32 RBF 1.0 (801, 16)\n",
      "BudgetedMultiStepLookaheadEI 32 RBF 0.1 (801, 16)\n"
     ]
    }
   ],
   "source": [
    "for a in acquisition_functions.keys():\n",
    "    for d in dimensions:\n",
    "        for k in kernels:\n",
    "            for l in lengthscales:\n",
    "                config_and_metrics_per_seed = grouped_runs[a,d,k,l]\n",
    "        \n",
    "                cumulative_cost_per_seed = np.array([m['cumulative cost'] for (_,m) in config_and_metrics_per_seed if len(m['cumulative cost'])>0 and len(m['best observed'])>0]).T\n",
    "                best_observed_per_seed = np.array([m['best observed'] for (_,m) in config_and_metrics_per_seed if len(m['cumulative cost'])>0 and len(m['best observed'])>0]).T\n",
    "                # Handling potential empty arrays\n",
    "                if cumulative_cost_per_seed.size == 0 or best_observed_per_seed.size == 0:\n",
    "                    continue  # Skip this iteration if there's no data\n",
    "\n",
    "                global_optimum_per_seed = np.array([m['global optimum value'][0] for (_,m) in config_and_metrics_per_seed if len(m['cumulative cost'])>0 and len(m['best observed'])>0])\n",
    "        \n",
    "                regret_per_seed = global_optimum_per_seed - best_observed_per_seed\n",
    "                print(a, d, k, l, regret_per_seed.shape)\n",
    "        \n",
    "                regret_25 = np.quantile(regret_per_seed, 0.25, axis=1)\n",
    "                regret_50 = np.quantile(regret_per_seed, 0.5, axis=1)\n",
    "                regret_75 = np.quantile(regret_per_seed, 0.75, axis=1)\n",
    "        \n",
    "                output = np.stack((cumulative_cost_per_seed.mean(axis=1), regret_25, regret_50, regret_75),axis=-1)\n",
    "        \n",
    "                np.savetxt(f\"results/fixed_amplitude_cost_aware/BayesianRegret_VariableCost_d{d}_{k}_ls{l}_{acquisition_functions[a]}.csv\", output, header=\"cc, q25, q50, q75\", delimiter=', ', comments='')"
   ]
  }
 ],
 "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.9.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
