{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "from Experiments.experiment_utils import load_experiment\n",
    "import numpy as np\n",
    "from scipy.optimize import minimize\n",
    "import os"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pylab as pylab\n",
    "params = {'font.family':'serif', \n",
    "    'legend.fontsize': 'xx-large',\n",
    "         'axes.labelsize': 'xx-large',\n",
    "         'axes.titlesize':'xx-large',\n",
    "         'xtick.labelsize':'xx-large',\n",
    "         'ytick.labelsize':'xx-large'}\n",
    "pylab.rcParams.update(params)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def find_discrete_optimum(x, uncontrollables, objective_fun):\n",
    "    xx, yy = np.meshgrid(np.arange(x.shape[0], dtype='int'), np.arange(uncontrollables.shape[0], dtype='int'))\n",
    "    X = np.hstack((x[xx.flatten()], uncontrollables[yy.flatten()]))\n",
    "\n",
    "    vals = objective_fun(X)\n",
    "    vals_reshaped = vals.reshape(xx.shape)\n",
    "    f_max = np.max(vals_reshaped, axis=0)\n",
    "    return f_max"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Parameters for the synthetic experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "linestyles = ['-', '--', '-.', ':', '-', '--', '-.', '-', '-']\n",
    "colors = ['tab:orange', 'tab:orange', 'tab:orange', 'tab:orange', 'firebrick', 'firebrick', 'firebrick', 'cornflowerblue']\n",
    "alphas = [1., 0.8, 0.6, 0.4, 1., 0.7, 0.4, 1, 1]\n",
    "flags = ['immediate', 'immediate', 'immediate', 'immediate', 'immediate', 'immediate', 'immediate', 'inference']\n",
    "algorithms = ['MES', 'UCB', 'EI', 'KG', 'stableopt', 'stableopt', 'stableopt', 'RVES']\n",
    "samples_vec = [1, 1, 1, 1, 1, 2, 4, 1]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Hartmann 3D\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "model, input_scaler, output_scaler, func_on_normalized, space, iterations, uncontrollables, objective_fun = load_experiment('hartmann_3d', 'RVES', 10);\n",
    "\n",
    "# create a grid of the parameters\n",
    "xx, yy = np.meshgrid(np.arange(space[0]['values'].shape[0], dtype='int'), np.arange(space[1]['values'].shape[0], dtype='int'))\n",
    "X = np.hstack([space[0]['values'][xx.flatten()], space[1]['values'][yy.flatten()]])\n",
    "\n",
    "vals = objective_fun(X)\n",
    "vals_reshaped = vals.reshape(xx.shape)\n",
    "f_opt = np.min(np.max(vals_reshaped, axis=0))\n",
    "x_opt = X[(vals == f_opt).flatten(), :]\n",
    "print('f_opt', f_opt)\n",
    "print('x_opt', x_opt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "experiment = 'hartmann_3d'\n",
    "\n",
    "fig, axs = plt.subplots()\n",
    "\n",
    "for idx, algorithm in enumerate(algorithms):        \n",
    "    n_samples = samples_vec[idx]\n",
    "    robust_inference_regrets = []\n",
    "    robust_immediate_regrets = []\n",
    "\n",
    "    if algorithm == 'stableopt':\n",
    "        filepath = 'Results/' + experiment +'/' + algorithm  + '/exploration_' + str(n_samples) + '/'\n",
    "    else:\n",
    "        filepath = 'Results/' + experiment +'/' + algorithm + '/'\n",
    "\n",
    "    files = os.listdir(filepath)\n",
    "\n",
    "    for ini in range(50):\n",
    "        x_opt = x_opt\n",
    "        fx_opt = f_opt\n",
    "\n",
    "        filename = [file for file in files if (('init_' + str(ini) + '_') in file)]\n",
    "            \n",
    "        df = pd.read_csv(filepath + filename[0])\n",
    "\n",
    "        robust_immediate_regret = np.abs(find_discrete_optimum(df[['x_cand_0', 'x_cand_1']].to_numpy(), uncontrollables, objective_fun)-fx_opt.item())\n",
    "        robust_inference_regret = np.abs(find_discrete_optimum(df[['x_opt_0', 'x_opt_1']].to_numpy(), uncontrollables, objective_fun)-fx_opt.item())\n",
    "\n",
    "        robust_immediate_regrets.append(robust_immediate_regret)\n",
    "        robust_inference_regrets.append(robust_inference_regret)\n",
    "\n",
    "    df_robust_inference_regrets = pd.DataFrame(robust_inference_regrets)\n",
    "    df_robust_immediate_regrets = pd.DataFrame(robust_immediate_regrets)\n",
    "\n",
    "    if flags[idx] == 'inference':\n",
    "        axs.plot(df_robust_inference_regrets.median(), label=algorithm + str(n_samples), color=colors[idx], linestyle=linestyles[idx], alpha=alphas[idx])          \n",
    "        indices = np.append(np.arange(0, df_robust_inference_regrets.shape[1], 5), df_robust_immediate_regrets.shape[1]-1)\n",
    "        medians = df_robust_inference_regrets.median()[indices]\n",
    "        lowers = medians-df_robust_inference_regrets.quantile(0.25)[indices]\n",
    "        uppers = df_robust_inference_regrets.quantile(0.75)[indices]-medians\n",
    "        axs.errorbar(indices, medians, np.vstack((lowers, uppers)), color=colors[idx], linestyle='', capsize=4, alpha=alphas[idx])\n",
    "    else:\n",
    "        axs.plot(df_robust_immediate_regrets.median(), label=algorithm + str(n_samples), color=colors[idx], linestyle=linestyles[idx], alpha=alphas[idx])          \n",
    "        indices = np.append(np.arange(0, df_robust_immediate_regrets.shape[1], 5), df_robust_immediate_regrets.shape[1]-1)\n",
    "        medians = df_robust_immediate_regrets.median()[indices]\n",
    "        lowers = medians-df_robust_immediate_regrets.quantile(0.25)[indices]\n",
    "        uppers = df_robust_immediate_regrets.quantile(0.75)[indices]-medians\n",
    "        axs.errorbar(indices, medians, np.vstack((lowers, uppers)), color=colors[idx], linestyle='', capsize=4, alpha=alphas[idx])\n",
    "\n",
    "axs.set_ylabel('robust regret')\n",
    "axs.set_xlabel('iteration')\n",
    "axs.set_yscale('log')\n",
    "\n",
    "fig.savefig('Plots/hartmann_3d.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Sin plus linear"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "model, input_scaler, output_scaler, func_on_normalized, space, iterations, uncontrollables, objective_fun = load_experiment('sin_plus_linear', 'RVES', 10);\n",
    "# find the robust optimum\n",
    "\n",
    "def optimization_objective(x, fun, uncontrollables):\n",
    "    # combine the actual value of x with all uncontrollables\n",
    "    x = np.atleast_2d(x)\n",
    "    X = np.hstack((np.repeat(x, repeats=uncontrollables.shape[0], axis=0), uncontrollables))\n",
    "\n",
    "    vals = fun(X)\n",
    "    return np.max(vals, axis=0)\n",
    "\n",
    "num_restarts = 50\n",
    "restarts = np.random.rand(num_restarts, space[0]['dimensionality'])\n",
    "bounds = [(0, 1) for _ in range(space[0]['dimensionality'])]\n",
    "\n",
    "x_opts = np.zeros_like(restarts)\n",
    "fx_opts = np.zeros(num_restarts)\n",
    "for idx, restart in enumerate(restarts):\n",
    "    res = minimize(optimization_objective, x0=restart, args=(func_on_normalized, space[1]['values']), bounds=bounds)\n",
    "    x_opts[idx] = res.x\n",
    "    fx_opts[idx] = res.fun\n",
    "\n",
    "argmin_val = np.argmin(fx_opts)\n",
    "x_opt = x_opts[argmin_val]\n",
    "f_opt = fx_opts[argmin_val]\n",
    "\n",
    "print(x_opt, f_opt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "experiment = 'sin_plus_linear'\n",
    "\n",
    "fig, axs = plt.subplots()\n",
    "\n",
    "for idx, algorithm in enumerate(algorithms):        \n",
    "    n_samples = samples_vec[idx]\n",
    "    robust_inference_regrets = []\n",
    "    robust_immediate_regrets = []\n",
    "\n",
    "    if algorithm == 'stableopt':\n",
    "        filepath = 'Results/' + experiment +'/' + algorithm   +'/exploration_' + str(n_samples) + '/'\n",
    "    else:\n",
    "        filepath = 'Results/' + experiment +'/' + algorithm  + '/'\n",
    "\n",
    "    files = os.listdir(filepath)\n",
    "\n",
    "    for ini in range(50):\n",
    "        x_opt = x_opt\n",
    "        fx_opt = f_opt\n",
    "        \n",
    "        filename = [file for file in files if (('init_' + str(ini) + '_') in file)]            \n",
    "        df = pd.read_csv(filepath + filename[0])\n",
    "\n",
    "        robust_immediate_regret = np.abs(find_discrete_optimum(df.x_cand_0.to_numpy().reshape(-1, 1), uncontrollables, objective_fun)-fx_opt.item())\n",
    "        robust_inference_regret = np.abs(find_discrete_optimum(df.x_opt_0.to_numpy().reshape(-1, 1), uncontrollables, objective_fun)-fx_opt.item())\n",
    "\n",
    "        robust_immediate_regrets.append(robust_immediate_regret)\n",
    "        robust_inference_regrets.append(robust_inference_regret)\n",
    "\n",
    "    df_robust_inference_regrets = pd.DataFrame(robust_inference_regrets)\n",
    "    df_robust_immediate_regrets = pd.DataFrame(robust_immediate_regrets)\n",
    "\n",
    "    if flags[idx] == 'inference':\n",
    "        axs.plot(df_robust_inference_regrets.median(), label=algorithm + str(n_samples), color=colors[idx], linestyle=linestyles[idx], alpha=alphas[idx])          \n",
    "        indices = np.append(np.arange(0, df_robust_inference_regrets.shape[1], 5), df_robust_immediate_regrets.shape[1]-1)\n",
    "        medians = df_robust_inference_regrets.median()[indices]\n",
    "        lowers = medians-df_robust_inference_regrets.quantile(0.25)[indices]\n",
    "        uppers = df_robust_inference_regrets.quantile(0.75)[indices]-medians\n",
    "        axs.errorbar(indices, medians, np.vstack((lowers, uppers)), color=colors[idx], linestyle='', capsize=4, alpha=alphas[idx])\n",
    "    else:\n",
    "        axs.plot(df_robust_immediate_regrets.median(), label=algorithm + str(n_samples), color=colors[idx], linestyle=linestyles[idx], alpha=alphas[idx])          \n",
    "        indices = np.append(np.arange(0, df_robust_immediate_regrets.shape[1], 5), df_robust_immediate_regrets.shape[1]-1)\n",
    "        medians = df_robust_immediate_regrets.median()[indices]\n",
    "        lowers = medians-df_robust_immediate_regrets.quantile(0.25)[indices]\n",
    "        uppers = df_robust_immediate_regrets.quantile(0.75)[indices]-medians\n",
    "        axs.errorbar(indices, medians, np.vstack((lowers, uppers)), color=colors[idx], linestyle='', capsize=4, alpha=alphas[idx])\n",
    "\n",
    "axs.set_ylabel('robust regret')\n",
    "axs.set_xlabel('iteration')\n",
    "axs.set_yscale('log')\n",
    "\n",
    "fig.savefig('Plots/sin_plus_linear.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Eggholder"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "model, input_scaler, output_scaler, func_on_normalized, space, iterations, uncontrollables, objective_fun = load_experiment('eggholder', 'RVES', 10);\n",
    "# find the robust optimum\n",
    "\n",
    "def optimization_objective(x, fun, uncontrollables):\n",
    "    # combine the actual value of x with all uncontrollables\n",
    "    x = np.atleast_2d(x)\n",
    "    X = np.hstack((np.repeat(x, repeats=uncontrollables.shape[0], axis=0), uncontrollables))\n",
    "\n",
    "    vals = fun(X)\n",
    "    return np.max(vals, axis=0)\n",
    "\n",
    "num_restarts = 50\n",
    "restarts = np.random.rand(num_restarts, space[0]['dimensionality'])\n",
    "bounds = [(0, 1) for _ in range(space[0]['dimensionality'])]\n",
    "\n",
    "x_opts = np.zeros_like(restarts)\n",
    "fx_opts = np.zeros(num_restarts)\n",
    "for idx, restart in enumerate(restarts):\n",
    "    res = minimize(optimization_objective, x0=restart, args=(func_on_normalized, space[1]['values']), bounds=bounds)\n",
    "    x_opts[idx] = res.x\n",
    "    fx_opts[idx] = res.fun\n",
    "\n",
    "argmin_val = np.argmin(fx_opts)\n",
    "x_opt = x_opts[argmin_val]\n",
    "f_opt = fx_opts[argmin_val].reshape(1, -1)\n",
    "\n",
    "print(x_opt, f_opt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "experiment = 'eggholder'\n",
    "\n",
    "fig5, axs5 = plt.subplots()\n",
    "\n",
    "for idx, algorithm in enumerate(algorithms):        \n",
    "    n_samples = samples_vec[idx]\n",
    "    inference_regrets = []\n",
    "    immediate_regrets = []\n",
    "    robust_inference_regrets = []\n",
    "    robust_immediate_regrets = []\n",
    "\n",
    "    if algorithm == 'stableopt':\n",
    "        filepath = 'Results/' + experiment +'/' + algorithm  + '/exploration_' + str(n_samples) + '/'\n",
    "    else:\n",
    "        filepath = 'Results/' + experiment +'/' + algorithm + '/'\n",
    "\n",
    "\n",
    "    files = os.listdir(filepath)\n",
    "    for ini in range(50):\n",
    "        x_opt = x_opt\n",
    "        fx_opt = f_opt\n",
    "        \n",
    "        filename = [file for file in files if (('init_' + str(ini) + '_') in file)]\n",
    "            \n",
    "        df = pd.read_csv(filepath + filename[0])\n",
    "        x_cand = input_scaler.transform(np.array([df.x_cand_0, df.x_cand_1]).T)\n",
    "        x_opt = input_scaler.transform(np.array([df.x_opt_0, df.x_opt_1]).T)\n",
    "\n",
    "        robust_immediate_regret = np.abs(find_discrete_optimum(x_cand[:, [0]], uncontrollables, objective_fun=func_on_normalized)-fx_opt.item())\n",
    "        robust_inference_regret = np.abs(find_discrete_optimum(x_opt[:, [0]], uncontrollables, objective_fun=func_on_normalized)-fx_opt.item())\n",
    "\n",
    "        robust_immediate_regrets.append(robust_immediate_regret)\n",
    "        robust_inference_regrets.append(robust_inference_regret)\n",
    "\n",
    "    df_robust_inference_regrets = pd.DataFrame(robust_inference_regrets)\n",
    "    df_robust_immediate_regrets = pd.DataFrame(robust_immediate_regrets)\n",
    "\n",
    "    if flags[idx] == 'inference':\n",
    "        axs.plot(df_robust_inference_regrets.median(), label=algorithm + str(n_samples), color=colors[idx], linestyle=linestyles[idx], alpha=alphas[idx])          \n",
    "        indices = np.append(np.arange(0, df_robust_inference_regrets.shape[1], 10), df_robust_immediate_regrets.shape[1]-1)\n",
    "        medians = df_robust_inference_regrets.median()[indices]\n",
    "        lowers = medians-df_robust_inference_regrets.quantile(0.25)[indices]\n",
    "        uppers = df_robust_inference_regrets.quantile(0.75)[indices]-medians\n",
    "        axs.errorbar(indices, medians, np.vstack((lowers, uppers)), color=colors[idx], linestyle='', capsize=4, alpha=alphas[idx])\n",
    "    else:\n",
    "        axs.plot(df_robust_immediate_regrets.median(), label=algorithm + str(n_samples), color=colors[idx], linestyle=linestyles[idx], alpha=alphas[idx])          \n",
    "        indices = np.append(np.arange(0, df_robust_immediate_regrets.shape[1], 10), df_robust_immediate_regrets.shape[1]-1)\n",
    "        medians = df_robust_immediate_regrets.median()[indices]\n",
    "        lowers = medians-df_robust_immediate_regrets.quantile(0.25)[indices]\n",
    "        uppers = df_robust_immediate_regrets.quantile(0.75)[indices]-medians\n",
    "        axs.errorbar(indices, medians, np.vstack((lowers, uppers)), color=colors[idx], linestyle='', capsize=4, alpha=alphas[idx])\n",
    "\n",
    "axs.set_xlabel('iteration')\n",
    "axs.set_ylabel('robust regret')\n",
    "axs.set_yscale('log')\n",
    "fig5.savefig('Plots/eggholder.pdf', bbox_inches='tight')\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Branin"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "model, input_scaler, output_scaler, func_on_normalized, space, iterations, uncontrollables, objective_fun = load_experiment('branin', 'RVES', 10);\n",
    "\n",
    "def optimization_objective(x, fun, uncontrollables):\n",
    "    # combine the actual value of x with all uncontrollables\n",
    "    x = np.atleast_2d(x)\n",
    "    X = np.hstack((np.repeat(x, repeats=uncontrollables.shape[0], axis=0), uncontrollables))\n",
    "\n",
    "    vals = fun(X)\n",
    "    return np.max(vals, axis=0)\n",
    "\n",
    "num_restarts = 50\n",
    "restarts = np.random.rand(num_restarts, space[0]['dimensionality'])\n",
    "bounds = [(0, 1) for _ in range(space[0]['dimensionality'])]\n",
    "\n",
    "x_opts = np.zeros_like(restarts)\n",
    "fx_opts = np.zeros(num_restarts)\n",
    "for idx, restart in enumerate(restarts):\n",
    "    res = minimize(optimization_objective, x0=restart, args=(func_on_normalized, uncontrollables.reshape(-1, 1)), bounds=bounds)\n",
    "    x_opts[idx] = res.x\n",
    "    fx_opts[idx] = res.fun\n",
    "\n",
    "argmin_val = np.argmin(fx_opts)\n",
    "x_opt = x_opts[argmin_val]\n",
    "f_opt = fx_opts[argmin_val].reshape(1, -1)\n",
    "\n",
    "print(x_opt, f_opt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "experiment = 'branin'\n",
    "\n",
    "fig5, axs5 = plt.subplots()\n",
    "\n",
    "for idx, algorithm in enumerate(algorithms):        \n",
    "    n_samples = samples_vec[idx]\n",
    "    robust_inference_regrets = []\n",
    "    robust_immediate_regrets = []\n",
    "\n",
    "    if algorithm == 'stableopt':\n",
    "        filepath = 'Results/' + experiment +'/' + algorithm  + '/exploration_' + str(n_samples) + '/'\n",
    "    else:\n",
    "        filepath = 'Results/' + experiment +'/' + algorithm + '/'\n",
    "\n",
    "    files = os.listdir(filepath)\n",
    "\n",
    "    for ini in range(50):\n",
    "        x_opt = x_opt\n",
    "        fx_opt = f_opt\n",
    "        \n",
    "        filename = [file for file in files if (('init_' + str(ini) + '_') in file)]\n",
    "\n",
    "        df = pd.read_csv(filepath + filename[0])\n",
    "\n",
    "        x_cand = input_scaler.transform(np.array([df.x_cand_0, df.x_cand_1]).T)\n",
    "        x_opt = input_scaler.transform(np.array([df.x_opt_0, df.x_opt_1]).T)\n",
    "\n",
    "        robust_immediate_regret = np.abs(find_discrete_optimum(x_cand[:, [0]], uncontrollables, objective_fun=func_on_normalized)-fx_opt.item())\n",
    "        robust_inference_regret = np.abs(find_discrete_optimum(x_opt[:, [0]], uncontrollables, objective_fun=func_on_normalized)-fx_opt.item())\n",
    "\n",
    "        robust_immediate_regrets.append(robust_immediate_regret)\n",
    "        robust_inference_regrets.append(robust_inference_regret)\n",
    "\n",
    "    df_robust_inference_regrets = pd.DataFrame(robust_inference_regrets)\n",
    "    df_robust_immediate_regrets = pd.DataFrame(robust_immediate_regrets)\n",
    "\n",
    "    if flags[idx] == 'inference':\n",
    "        axs.plot(df_robust_inference_regrets.median(), label=algorithm + str(n_samples), color=colors[idx], linestyle=linestyles[idx], alpha=alphas[idx])          \n",
    "        indices = np.append(np.arange(1, df_robust_inference_regrets.shape[1], 5), df_robust_immediate_regrets.shape[1])\n",
    "        medians = df_robust_inference_regrets.median()[indices]\n",
    "        lowers = medians-df_robust_inference_regrets.quantile(0.25)[indices]\n",
    "        uppers = df_robust_inference_regrets.quantile(0.75)[indices]-medians\n",
    "        axs.errorbar(indices, medians, np.vstack((lowers, uppers)), color=colors[idx], linestyle='', capsize=4, alpha=alphas[idx])\n",
    "    else:\n",
    "        axs.plot(df_robust_immediate_regrets.median(), label=algorithm + str(n_samples), color=colors[idx], linestyle=linestyles[idx], alpha=alphas[idx])          \n",
    "        indices = np.append(np.arange(1, df_robust_inference_regrets.shape[1], 5), df_robust_immediate_regrets.shape[1])\n",
    "        medians = df_robust_immediate_regrets.median()[indices]\n",
    "        lowers = medians-df_robust_immediate_regrets.quantile(0.25)[indices]\n",
    "        uppers = df_robust_immediate_regrets.quantile(0.75)[indices]-medians\n",
    "        axs.errorbar(indices, medians, np.vstack((lowers, uppers)), color=colors[idx], linestyle='', capsize=4, alpha=alphas[idx])\n",
    "\n",
    "axs.set_ylabel('robust regret')\n",
    "axs.set_xlabel('iteration')\n",
    "axs.set_xticks(np.arange(51, step=10));\n",
    "\n",
    "axs.set_yscale('log')\n",
    "fig5.savefig('Plots/branin.pdf',  bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Synthetic Polynomial"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "model, input_scaler, output_scaler, func_on_normalized, space, iterations, uncontrollables, objective_fun = load_experiment('synthetic_polynomial', 'RVES', 10);\n",
    "# find the robust optimum\n",
    "\n",
    "def optimization_objective(x, fun, uncontrollables):\n",
    "    # combine the actual value of x with all uncontrollables\n",
    "    x = np.atleast_2d(x)\n",
    "    X = np.hstack((np.repeat(x, repeats=uncontrollables.shape[0], axis=0), uncontrollables))\n",
    "\n",
    "    vals = fun(X)\n",
    "    return np.max(vals, axis=0)\n",
    "\n",
    "num_restarts = 50\n",
    "restarts = np.random.rand(num_restarts, space[0]['dimensionality'])\n",
    "bounds = [(0, 1) for _ in range(space[0]['dimensionality'])]\n",
    "\n",
    "x_opts = np.zeros_like(restarts)\n",
    "fx_opts = np.zeros(num_restarts)\n",
    "for idx, restart in enumerate(restarts):\n",
    "    res = minimize(optimization_objective, x0=restart, args=(func_on_normalized, space[1]['values']), bounds=bounds, method='Nelder-Mead')\n",
    "    x_opts[idx] = res.x\n",
    "    fx_opts[idx] = res.fun\n",
    "\n",
    "argmin_val = np.argmin(fx_opts)\n",
    "x_opt = x_opts[argmin_val]\n",
    "f_opt = fx_opts[argmin_val]\n",
    "\n",
    "print(x_opt, f_opt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "experiment = 'synthetic_polynomial'\n",
    "\n",
    "fig5, axs5 = plt.subplots()\n",
    "\n",
    "for idx, algorithm in enumerate(algorithms):        \n",
    "    n_samples = samples_vec[idx]\n",
    "    robust_inference_regrets = []\n",
    "    robust_immediate_regrets = []\n",
    "\n",
    "    if algorithm == 'stableopt':\n",
    "        filepath = 'Results/' + experiment +'/' + algorithm  + '/exploration_' + str(n_samples) + '/'\n",
    "    else:\n",
    "        filepath = 'Results/' + experiment +'/' + algorithm + '/'\n",
    "\n",
    "    files = os.listdir(filepath)\n",
    "\n",
    "    for ini in range(50):\n",
    "        x_opt = x_opt\n",
    "        fx_opt = f_opt\n",
    "        \n",
    "        filename = [file for file in files if (('init_' + str(ini) + '_') in file)]\n",
    "\n",
    "        df = pd.read_csv(filepath + filename[0])\n",
    "\n",
    "        robust_immediate_regret = np.abs(find_discrete_optimum(df[['x_cand_0', 'x_cand_1']].to_numpy(), uncontrollables, func_on_normalized)-fx_opt.item())\n",
    "        robust_inference_regret = np.abs(find_discrete_optimum(df[['x_opt_0', 'x_opt_1']].to_numpy(), uncontrollables, func_on_normalized)-fx_opt.item())\n",
    "\n",
    "        robust_immediate_regrets.append(robust_immediate_regret)\n",
    "        robust_inference_regrets.append(robust_inference_regret)\n",
    "\n",
    "    df_robust_inference_regrets = pd.DataFrame(robust_inference_regrets)\n",
    "    df_robust_immediate_regrets = pd.DataFrame(robust_immediate_regrets)\n",
    "\n",
    "    if flags[idx] == 'inference':\n",
    "        axs.plot(df_robust_inference_regrets.median(), label=algorithm + str(n_samples), color=colors[idx], linestyle=linestyles[idx], alpha=alphas[idx])          \n",
    "        indices = np.append(np.arange(0, df_robust_inference_regrets.shape[1], 10), df_robust_immediate_regrets.shape[1]-1)\n",
    "        medians = df_robust_inference_regrets.median()[indices]\n",
    "        lowers = medians-df_robust_inference_regrets.quantile(0.25)[indices]\n",
    "        uppers = df_robust_inference_regrets.quantile(0.75)[indices]-medians\n",
    "        axs.errorbar(indices, medians, np.vstack((lowers, uppers)), color=colors[idx], linestyle='', capsize=4, alpha=alphas[idx])\n",
    "    else:\n",
    "        axs.plot(df_robust_immediate_regrets.median(), label=algorithm + str(n_samples), color=colors[idx], linestyle=linestyles[idx], alpha=alphas[idx])          \n",
    "        indices = np.append(np.arange(0, df_robust_immediate_regrets.shape[1], 10), df_robust_immediate_regrets.shape[1]-1)\n",
    "        medians = df_robust_immediate_regrets.median()[indices]\n",
    "        lowers = medians-df_robust_immediate_regrets.quantile(0.25)[indices]\n",
    "        uppers = df_robust_immediate_regrets.quantile(0.75)[indices]-medians\n",
    "        axs.errorbar(indices, medians, np.vstack((lowers, uppers)), color=colors[idx], linestyle='', capsize=4, alpha=alphas[idx])\n",
    "\n",
    "axs.set_ylabel('robust regret')\n",
    "axs.set_xlabel('iteration')\n",
    "axs.set_yscale('log')\n",
    "\n",
    "fig.savefig('Plots/synthetic_poly.pdf',  bbox_inches='tight')\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Robot Pushing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from Experiments.robot_pushing.robot_pushing_functions import robot_push_3d\n",
    "from Experiments.robot_pushing.find_optima_robot_pushing import find_optima_robot_pushing\n",
    "\n",
    "find_optima_robot_pushing()\n",
    "\n",
    "results = np.load('optima_robot_pushing.npz')\n",
    "x_opts = results['x_opts']\n",
    "f_opts = results['f_opts']\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def find_discrete_optimum_robot(x, uncontrollables, objective):\n",
    "    xx, yy = np.meshgrid(np.arange(x.shape[0], dtype='int'), np.arange(uncontrollables.shape[0], dtype='int'))\n",
    "    X = np.hstack((x[xx.flatten()], uncontrollables[yy.flatten()]))\n",
    "\n",
    "    vals = np.array([objective(xi[0], xi[1], xi[2], xi[3], xi[4]) for xi in X])\n",
    "    vals_reshaped = vals.reshape(xx.shape)\n",
    "    f_max = np.max(vals_reshaped, axis=0)\n",
    "    return f_max"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "experiment = 'robot_pushing'\n",
    "\n",
    "fig, axs = plt.subplots()\n",
    "\n",
    "for idx, algorithm in enumerate(algorithms):\n",
    "    for ini in range(30):   \n",
    "        x_opt = x_opts[ini]\n",
    "        fx_opt = f_opts[ini]\n",
    "    \n",
    "        filename = [file for file in files if (('init_' + str(ini) + '_') in file)]\n",
    "\n",
    "        df = pd.read_csv(filepath + filename[0])\n",
    "\n",
    "        cand_location = np.array([df.x_cand_0, df.x_cand_1, df.x_cand_2, df.x_cand_3, df.x_cand_4]).T\n",
    "        opt_location = np.array([df.x_opt_0, df.x_opt_1, df.x_opt_2, df.x_opt_3, df.x_opt_4]).T        \n",
    "\n",
    "        robust_immediate_regret = np.abs(find_discrete_optimum_robot(cand_location, uncontrollables, robot_push_3d)-fx_opt.item())\n",
    "        robust_inference_regret = np.abs(find_discrete_optimum_robot(opt_location, uncontrollables, robot_push_3d)-fx_opt.item())\n",
    "\n",
    "        robust_immediate_regrets.append(robust_immediate_regret)\n",
    "        robust_inference_regrets.append(robust_inference_regret)\n",
    "\n",
    "    df_robust_inference_regrets = pd.DataFrame(robust_inference_regrets)\n",
    "    df_robust_immediate_regrets = pd.DataFrame(robust_immediate_regrets)     \n",
    "    n_samples = samples_vec[idx]\n",
    "\n",
    "    robust_inference_regrets = []\n",
    "    robust_immediate_regrets = []\n",
    "\n",
    "    if algorithm == 'stableopt':\n",
    "        filepath = 'Results/' + experiment +'/' + algorithm  + '/exploration_' + str(n_samples) + '/'\n",
    "    else:\n",
    "        filepath = 'Results/' + experiment +'/' + algorithm + '/'\n",
    "\n",
    "    df_robust_inference_regrets = pd.read_csv('Results/robot_pushing/analysis/' +'robot_pushing_robust_inference_regret_' + algorithm + str(n_samples) + '.csv', index_col=0)\n",
    "    df_robust_immediate_regrets = pd.read_csv('Results/robot_pushing/analysis/' +'robot_pushing_robust_immediate_regret_' + algorithm + str(n_samples) + '.csv', index_col=0)\n",
    "\n",
    "    if flags[idx] == 'inference':\n",
    "        axs.plot(df_robust_inference_regrets.median(), color=colors[idx], linestyle=linestyles[idx], alpha=alphas[idx])          \n",
    "        indices = np.append(np.arange(0, df_robust_inference_regrets.shape[1], 10), df_robust_immediate_regrets.shape[1]-1)\n",
    "        medians = df_robust_inference_regrets.median()[indices]\n",
    "        lowers = medians-df_robust_inference_regrets.quantile(0.25)[indices]\n",
    "        uppers = df_robust_inference_regrets.quantile(0.75)[indices]-medians\n",
    "        axs.errorbar(indices, medians, np.vstack((lowers, uppers)), color=colors[idx], linestyle='', capsize=4, alpha=alphas[idx])\n",
    "    else:\n",
    "        axs.plot(df_robust_immediate_regrets.median(), color=colors[idx], linestyle=linestyles[idx], alpha=alphas[idx])          \n",
    "        indices = np.append(np.arange(0, df_robust_immediate_regrets.shape[1], 10), df_robust_immediate_regrets.shape[1]-1)\n",
    "        medians = df_robust_immediate_regrets.median()[indices]\n",
    "        lowers = medians-df_robust_immediate_regrets.quantile(0.25)[indices]\n",
    "        uppers = df_robust_immediate_regrets.quantile(0.75)[indices]-medians\n",
    "        axs.errorbar(indices, medians, np.vstack((lowers, uppers)), color=colors[idx], linestyle='', capsize=4, alpha=alphas[idx])\n",
    "\n",
    "axs.set_xticks(np.arange(0, 101, 10))\n",
    "axs.set_ylabel('robust regret')\n",
    "axs.set_xlabel('iteration')\n",
    "axs.legend(['MES', 'UCB', 'EI', 'KG', 'StableOpt1', 'StableOpt2', 'StableOpt4', 'RES'], bbox_to_anchor=(1.43, 1), loc='upper right'),\n",
    "\n",
    "axs.set_yscale('log')\n",
    "fig.savefig('Plots/robot_pushing.pdf', bbox_inches='tight')\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Within model comparison"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# find the optima of the functions used in the within model analysis\n",
    "from Experiments.within_model.find_optima_within_model import find_optima_within_model\n",
    "\n",
    "find_optima_within_model()\n",
    "\n",
    "# analyses the results\n",
    "from Experiments.within_model.within_model_analysis import analyse_within_model\n",
    "\n",
    "analyse_within_model()\n",
    "\n",
    "algorithms = ['MES', 'UCB', 'EI', 'KG', 'stableopt', 'stableopt', 'stableopt', 'RVES', 'RVES', 'RVES', 'RVES']\n",
    "experiment = 'within_model'\n",
    "samples_vec = [1, 1, 1, 1, 1, 2, 4, 1, 5, 10, 30] \n",
    "colors_within = ['tab:orange', 'tab:orange', 'tab:orange', 'tab:orange', 'firebrick', 'firebrick', 'firebrick', 'cornflowerblue', 'cornflowerblue', 'cornflowerblue', 'cornflowerblue']\n",
    "alphas_within = [1., 0.8, 0.6, 0.4, 1., 0.8, 0.6, 1., 0.8, 0.6, 0.4]\n",
    "linestyles_within = ['-', '--', '-.', ':', '-', '--', '-.', '-', '--', '-.', ':' ]\n",
    "subplot_idx = [ 0, 0, 0, 0, 2, 2, 2, 1, 1, 1, 1]\n",
    "flags = ['immediate', 'immediate', 'inference', 'immediate', 'immediate', 'immediate', 'immediate', 'inference', 'inference', 'inference', 'inference']\n",
    "labels = ['MES', 'UCB', 'EI', 'KG', 'StableOpt1', 'StableOpt2', 'StableOpt4', 'RES1', 'RES5', 'RES10', 'RES30']\n",
    "\n",
    "\n",
    "fig, axs = plt.subplots(1, 3, sharey=True, figsize=(20, 5))\n",
    "\n",
    "for idx, algorithm in enumerate(algorithms):\n",
    "    n_samples = samples_vec[idx]\n",
    "\n",
    "    df_inference_regrets = pd.read_csv('Results/within_model/analysis/within_model_inference_regret_' + algorithm + str(n_samples) + '.csv', index_col=0)\n",
    "    df_immediate_regrets = pd.read_csv('Results/within_model/analysis/within_model_immediate_regret_' + algorithm + str(n_samples) + '.csv', index_col=0)\n",
    "    df_robust_inference_regrets = pd.read_csv('Results/within_model/analysis/within_model_robust_inference_regret_' + algorithm + str(n_samples) + '.csv', index_col=0)\n",
    "    df_robust_immediate_regrets = pd.read_csv('Results/within_model/analysis/within_model_robust_immediate_regret_' + algorithm + str(n_samples) + '.csv', index_col=0)\n",
    "\n",
    "\n",
    "    if flags[idx] == 'inference':\n",
    "        axs[subplot_idx[idx]].plot(df_inference_regrets.median(), color=colors_within[idx], linestyle=linestyles_within[idx], alpha=alphas_within[idx])          \n",
    "        indices = np.append(np.arange(0, df_inference_regrets.shape[1], 10), df_inference_regrets.shape[1]-1)\n",
    "        medians = df_inference_regrets.median()[indices]\n",
    "        lowers = medians-df_inference_regrets.quantile(0.25)[indices]\n",
    "        uppers = df_inference_regrets.quantile(0.75)[indices]-medians\n",
    "        axs[subplot_idx[idx]].errorbar(indices, medians, np.vstack((lowers, uppers)), color=colors_within[idx], linestyle='', capsize=4, alpha=alphas_within[idx])\n",
    "        axs[subplot_idx[idx]].set_ylabel('inference regret')\n",
    "    else:\n",
    "        axs[subplot_idx[idx]].plot(df_immediate_regrets.median(), color=colors_within[idx], linestyle=linestyles_within[idx], alpha=alphas_within[idx])   \n",
    "        indices = np.append(np.arange(0, df_immediate_regrets.shape[1], 10), df_immediate_regrets.shape[1]-1)\n",
    "        medians = df_immediate_regrets.median()[indices]\n",
    "        lowers = medians-df_immediate_regrets.quantile(0.25)[indices]\n",
    "        uppers = df_immediate_regrets.quantile(0.75)[indices]-medians\n",
    "        axs[subplot_idx[idx]].errorbar(indices, medians, np.vstack((lowers, uppers)), color=colors_within[idx], linestyle='', capsize=4, alpha=alphas_within[idx])\n",
    "\n",
    "        axs[subplot_idx[idx]].set_ylabel('immediate regret')\n",
    "\n",
    "    axs[subplot_idx[idx]].set_xlabel('iteration')\n",
    "    axs[subplot_idx[idx]].set_yscale('log')\n",
    "    axs[subplot_idx[idx]].set_xticks(np.arange(76, step=10))\n",
    "\n",
    "    axs[1].legend(labels[-4:])\n",
    "    axs[0].legend(labels[:4])\n",
    "    axs[2].legend(labels[4:7])\n",
    "\n",
    "fig.savefig('Plots/within_model.pdf', bbox_inches='tight')\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "GPy_new",
   "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.8.15"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
