{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Demo for Bi-fidelity Stochastic Subspace Descent"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "                  N=100           N=1000          N=10000          N=20000  \\\n",
      "GD      2.4752 ± 0.0000  2.4752 ± 0.0000  0.6182 ± 0.0000  0.4255 ± 0.0000   \n",
      "CD      1.4752 ± 0.0000  1.4752 ± 0.0000  0.6975 ± 0.0000  0.4926 ± 0.0000   \n",
      "NAG     2.4752 ± 0.0000  2.4752 ± 0.0000  0.3271 ± 0.0000  0.1636 ± 0.0000   \n",
      "FS-SSD  2.4731 ± 0.0004  2.4518 ± 0.0011  2.2571 ± 0.0011  2.0787 ± 0.0013   \n",
      "SPSA    1.9291 ± 0.0000  0.6555 ± 0.0000  0.2002 ± 0.0000  0.1485 ± 0.0000   \n",
      "GS      2.4739 ± 0.0001  2.4631 ± 0.0008  2.3578 ± 0.0016  2.2479 ± 0.0025   \n",
      "HF-SSD  1.9942 ± 0.0466  0.7472 ± 0.0127  0.3983 ± 0.2097  0.3696 ± 0.2109   \n",
      "BF-SSD  1.9953 ± 0.0756  0.6842 ± 0.0187  0.1726 ± 0.0010  0.1143 ± 0.0005   \n",
      "VR-SSD  2.4690 ± 0.0006  2.0904 ± 0.0081  0.6225 ± 0.0039  0.4309 ± 0.0025   \n",
      "\n",
      "                N=30000  \n",
      "GD      0.3417 ± 0.0000  \n",
      "CD      0.4008 ± 0.0000  \n",
      "NAG     0.1094 ± 0.0000  \n",
      "FS-SSD  1.9284 ± 0.0015  \n",
      "SPSA    0.1245 ± 0.0000  \n",
      "GS      2.1493 ± 0.0038  \n",
      "HF-SSD  0.2011 ± 0.0630  \n",
      "BF-SSD  0.0881 ± 0.0006  \n",
      "VR-SSD  0.3472 ± 0.0020  \n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "from configs.configs import *\n",
    "\n",
    "# Parameters\n",
    "d = 1000\n",
    "r1 = 100\n",
    "r2 = 2\n",
    "lmda = 20.0\n",
    "ell = 20\n",
    "c = 0.9\n",
    "\n",
    "# File path\n",
    "path = f'results/worst/worst-d{d}-rH{r1}-rL{r2}-lmda{lmda}-ell{ell}-c{c}.npz'\n",
    "file = np.load(path, allow_pickle=True)\n",
    "\n",
    "# Methods to analyze\n",
    "methods = ['gd', 'cd', 'ngd', 'ssd', 'spsa', 'rgfm', 'ssd_hf', 'ssd_bf', 'ssd_sag']\n",
    "\n",
    "# HF call counts\n",
    "hf_calls = [100, 1000, 10000, 20000, 30000]\n",
    "\n",
    "# Initialize results dictionary\n",
    "results = {}\n",
    "\n",
    "# Compute mean and std for each method at specified HF call counts\n",
    "for method in methods:\n",
    "    if method in file['res'].item():  # Ensure the method exists in the file\n",
    "        method_data = file['res'].item()[method]  # Extract method data\n",
    "        mean_values = []\n",
    "        std_values = []\n",
    "        for N in hf_calls:\n",
    "            mean_values.append(np.mean(method_data[:, N-1]))\n",
    "            std_values.append(np.std(method_data[:, N-1]))\n",
    "        results[names[method]] = [f\"{mean:.4f} ± {std:.4f}\" for mean, std in zip(mean_values, std_values)]\n",
    "\n",
    "# Create a Pandas DataFrame\n",
    "df = pd.DataFrame(results, index=[f\"N={N}\" for N in hf_calls]).T\n",
    "\n",
    "# Print the DataFrame\n",
    "print(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "                  ell=20           ell=50          ell=100          ell=200\n",
      "FS-SSD   2.0787 ± 0.0013  1.6621 ± 0.0003  1.2942 ± 0.0022  0.9473 ± 0.0027\n",
      "HF-SSD   0.3696 ± 0.2109  0.1482 ± 0.0098  0.1574 ± 0.0157  0.3696 ± 0.2368\n",
      "BF-SSD   0.1143 ± 0.0005  0.1226 ± 0.0015  0.1260 ± 0.0032  0.1298 ± 0.0013\n",
      "SAG-SSD  0.4309 ± 0.0025  0.4281 ± 0.0013  0.4238 ± 0.0009  0.4226 ± 0.0013\n"
     ]
    }
   ],
   "source": [
    "# Parameters\n",
    "d = 1000\n",
    "r1 = 100\n",
    "r2 = 2\n",
    "lmda = 20.0\n",
    "c = 0.9\n",
    "\n",
    "# Methods to analyze\n",
    "methods = ['ssd', 'ssd_hf', 'ssd_bf', 'ssd_sag']\n",
    "\n",
    "# Names for methods\n",
    "names = {\n",
    "    'ssd': 'FS-SSD',\n",
    "    'ssd_hf': 'HF-SSD',\n",
    "    'ssd_bf': 'BF-SSD',\n",
    "    'ssd_sag': 'SAG-SSD',\n",
    "}\n",
    "\n",
    "# ell values to compare\n",
    "ell_values = [20, 50, 100, 200]\n",
    "\n",
    "# Fixed HF call count\n",
    "N = 20000\n",
    "\n",
    "# Initialize results dictionary\n",
    "results = {}\n",
    "\n",
    "# Iterate over ell values\n",
    "for ell in ell_values:\n",
    "    # File path for the current ell value\n",
    "    path = f'results/worst/worst-d{d}-rH{r1}-rL{r2}-lmda{lmda}-ell{ell}-c{c}.npz'\n",
    "    file = np.load(path, allow_pickle=True)\n",
    "\n",
    "    # Compute mean and std for each method at N=20000\n",
    "    for method in methods:\n",
    "        if method in file['res'].item():  # Ensure the method exists in the file\n",
    "            method_data = file['res'].item()[method]  # Extract method data\n",
    "            mean_value = np.mean(method_data[:, N - 1])\n",
    "            std_value = np.std(method_data[:, N - 1])\n",
    "            results.setdefault(names[method], []).append(f\"{mean_value:.4f} ± {std_value:.4f}\")\n",
    "\n",
    "# Create a Pandas DataFrame\n",
    "df = pd.DataFrame(results, index=[f\"ell={ell}\" for ell in ell_values])\n",
    "\n",
    "# Print the DataFrame\n",
    "print(df.T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "                                 ssd            ssd_hf           ssd_bf  \\\n",
      "c=0.9, ell=10     3500.9129 ± 5.7405   9.4851 ± 0.2123  8.1755 ± 0.5951   \n",
      "c=0.9, ell=50     1015.8167 ± 5.8954   4.0073 ± 0.1346  6.1251 ± 0.2193   \n",
      "c=0.9, ell=100     270.9464 ± 7.0662   5.4891 ± 0.1840  6.2204 ± 0.2524   \n",
      "c=0.95, ell=10   3493.8840 ± 11.2749  18.3873 ± 0.2777  2.9420 ± 0.4870   \n",
      "c=0.95, ell=50    1013.2150 ± 8.7558   5.3333 ± 0.3489  2.2194 ± 0.2142   \n",
      "c=0.95, ell=100    270.3627 ± 2.6174   6.1539 ± 0.1652  2.2791 ± 0.0952   \n",
      "c=0.99, ell=10    3503.9903 ± 3.7705  29.5467 ± 0.0528  1.3963 ± 0.2919   \n",
      "c=0.99, ell=50    1010.9162 ± 7.1720   6.9506 ± 0.1854  0.7489 ± 0.1196   \n",
      "c=0.99, ell=100    273.6397 ± 3.4127   6.2644 ± 0.0793  0.7860 ± 0.2387   \n",
      "\n",
      "                          ssd_sag  \n",
      "c=0.9, ell=10    23.3101 ± 0.8269  \n",
      "c=0.9, ell=50    20.8666 ± 0.5519  \n",
      "c=0.9, ell=100   21.5552 ± 0.6920  \n",
      "c=0.95, ell=10   23.1976 ± 0.2976  \n",
      "c=0.95, ell=50   21.4447 ± 1.3672  \n",
      "c=0.95, ell=100  21.0245 ± 0.9838  \n",
      "c=0.99, ell=10   23.3450 ± 0.3819  \n",
      "c=0.99, ell=50   20.8989 ± 0.3139  \n",
      "c=0.99, ell=100  21.3795 ± 0.4628  \n"
     ]
    }
   ],
   "source": [
    "# Parameters\n",
    "methods = ['ssd', 'ssd_hf', 'ssd_bf', 'ssd_sag']\n",
    "c_values = [0.9, 0.95, 0.99]\n",
    "ell_values = [10, 50, 100]\n",
    "N = 50000  # Fixed HF call count\n",
    "\n",
    "# Initialize results dictionary\n",
    "results = {}\n",
    "\n",
    "# Iterate over combinations of c and ell\n",
    "for c in c_values:\n",
    "    for ell in ell_values:\n",
    "        # File path for the current combination of c and ell\n",
    "        path = f'./results/kernel/kernel-d1000-lr10-L01.0-tau0.001-ell{ell}-c{c}.npz'\n",
    "        file = np.load(path, allow_pickle=True)\n",
    "\n",
    "        # Compute mean and std for each method at N=50000\n",
    "        row_key = f\"c={c}, ell={ell}\"  # Row identifier\n",
    "        results[row_key] = []\n",
    "        for method in methods:\n",
    "            if method in file['res'].item():  # Ensure the method exists in the file\n",
    "                method_data = file['res'].item()[method]  # Extract method data\n",
    "                mean_value = np.mean(method_data[:, N - 1])\n",
    "                std_value = np.std(method_data[:, N - 1])\n",
    "                results[row_key].append(f\"{mean_value:.4f} ± {std_value:.4f}\")\n",
    "\n",
    "# Create a Pandas DataFrame\n",
    "df = pd.DataFrame(results, index=methods).T\n",
    "\n",
    "# Print the DataFrame\n",
    "print(df)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "botorchEnv2",
   "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.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
