{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "0d056263",
   "metadata": {},
   "source": [
    "# analyze the performance over the problem with randomly sampled instances"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4c52706e",
   "metadata": {},
   "source": [
    "## import packages and set some parameter configurations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "354da889",
   "metadata": {
    "scrolled": true,
    "tags": []
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import config\n",
    "import matplotlib.pyplot as plt\n",
    "import os\n",
    "import pickle\n",
    "from copy import deepcopy\n",
    "from copy import copy\n",
    "import configrey\n",
    "os.environ['KMP_DUPLICATE_LIB_OK']='True'\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"] = \"0\"\n",
    "\n",
    "plt.rcParams.update({\n",
    "    \"text.usetex\": True,\n",
    "    \"font.family\": \"serif\",\n",
    "    \"font.serif\": [\"Palatino\"],\n",
    "})\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "60ad07eb",
   "metadata": {},
   "outputs": [],
   "source": [
    "file_path = './result/sample_09_01_18-Sep_08_2023.pkl'\n",
    "with open(file_path, 'rb') as pickle_file:\n",
    "    raw_content = pickle.load(pickle_file)\n",
    "    \n",
    "\n",
    "content = []\n",
    "for content_list in raw_content:\n",
    "    new_content_list = [[x[0] if len(x)==1 else np.squeeze(x) for x in y] for y in content_list]\n",
    "    content.append(new_content_list)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "c1d8d343",
   "metadata": {},
   "outputs": [],
   "source": [
    "dmabo_regret_list, dmabo_constr_1_list, dmabo_constr_2_list = content"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "ef1b1dd5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7fe35842c1c0>]"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(dmabo_regret_arr[7,:])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "3102b0f4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 215.065x132.92 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "MARKERSIZE = 1.5 * 0.4 * 0.1\n",
    "colors = ['red','purple', 'orange', 'green', 'blue', 'black', 'blue']\n",
    "marksCur = ['o','s', '*', 'v', '^','+']\n",
    "my_color = 'black' #'c'\n",
    "MS_ratio = 0.1\n",
    "from fig_hp import *\n",
    "def plot_with_shade_area(ax, x, y, yerr, **kwargs):\n",
    "    y = np.squeeze(y)\n",
    "    yerr = np.squeeze(yerr)\n",
    "    aver_line, = ax.plot(x, y,markersize=MARKERSIZE*MS_ratio, linewidth=LINEWIDTH, color=kwargs['color'], marker=kwargs['marker'], markerfacecolor='None')\n",
    "    aver_region = ax.fill_between(x, y-yerr, y+yerr, alpha=0.3,color=kwargs['color'])\n",
    "    return aver_line, aver_region\n",
    "\n",
    "\n",
    "dmabo_regret_arr = np.array(dmabo_regret_list)\n",
    "dmabo_constr1_arr = np.array(dmabo_constr_1_list)\n",
    "dmabo_constr2_arr = np.array(dmabo_constr_2_list)\n",
    "\n",
    "dmabo_cumu_r_arr = np.cumsum(dmabo_regret_arr, axis=1)\n",
    "dmabo_cumu_constr1_arr = np.cumsum(dmabo_constr1_arr, axis=1)\n",
    "dmabo_cumu_constr2_arr = np.cumsum(dmabo_constr2_arr, axis=1)\n",
    "\n",
    "if True:\n",
    "    total_steps = 201\n",
    "    step_arr = np.arange(total_steps)\n",
    "    \n",
    "    %matplotlib inline\n",
    "    #from matplotlib import rc\n",
    "    #plt.rc('text',usetex=False)\n",
    "   \n",
    "\n",
    "    \n",
    "    fig, axes = plt.subplots(1, 1)\n",
    "    fig.set_size_inches(WIDTH * 1.0, HEIGHT * 1.0)\n",
    "\n",
    "    fig.subplots_adjust(left=.22, bottom=.20, right=.99, top=.97, hspace=0.33, wspace=0.4) \n",
    "   \n",
    "    ax = axes\n",
    "    BETA1 = 0.03\n",
    "    dmabo_line, _ = plot_with_shade_area(ax, step_arr, np.mean(dmabo_cumu_r_arr, axis=0), BETA1*np.std(dmabo_cumu_r_arr, axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[0], marker=marksCur[0], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    plt.xticks(fontsize=LABELSIZE)\n",
    "    plt.yticks(fontsize=LABELSIZE)\n",
    "    ax.tick_params(axis='x', colors=my_color)\n",
    "    ax.tick_params(axis='y', colors=my_color)\n",
    "    ax.set_xlabel('Step', fontsize=LABELSIZE, color=my_color)\n",
    "    ax.set_ylabel('Cumulative Regret (Averaged over 100 instances)', fontsize=LABELSIZE, color=my_color)  \n",
    "    plt.xlim((0, total_steps))\n",
    "    plt.legend([dmabo_line], ['DMABO'])\n",
    "\n",
    "    #ax.legend(['CEI', 'Safe BO', 'Primal-Dual', 'LCB2'])\n",
    "    \n",
    "    \n",
    "    \n",
    "\n",
    "    import tikzplotlib\n",
    "    tikzplotlib.clean_figure()\n",
    "    tikzplotlib.save('./figs/ri_cumu_regret.tex')\n",
    "    plt.savefig('./figs/ri_cumu_regret.pdf', format='pdf', bbox_inches='tight')\n",
    "    \n",
    "    plt.show()  \n",
    "   \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1c4d8853",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 215.065x132.92 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "MARKERSIZE = 1.5 * 0.4 * 0.1\n",
    "colors = ['red','purple', 'orange', 'green', 'blue', 'black', 'blue']\n",
    "marksCur = ['o','s', '*', 'v', '^','+']\n",
    "my_color = 'black' #'c'\n",
    "MS_ratio = 0.1\n",
    "from fig_hp import *\n",
    "def plot_with_shade_area(ax, x, y, yerr, **kwargs):\n",
    "    y = np.squeeze(y)\n",
    "    yerr = np.squeeze(yerr)\n",
    "    aver_line, = ax.plot(x, y,markersize=MARKERSIZE*MS_ratio, linewidth=LINEWIDTH, color=kwargs['color'], marker=kwargs['marker'], markerfacecolor='None')\n",
    "    aver_region = ax.fill_between(x, y-yerr, y+yerr, alpha=0.3,color=kwargs['color'])\n",
    "    return aver_line, aver_region\n",
    "\n",
    "\n",
    "dmabo_regret_arr = np.array(dmabo_regret_list)\n",
    "dmabo_constr1_arr = np.array(dmabo_constr_1_list)\n",
    "dmabo_constr2_arr = np.array(dmabo_constr_2_list)\n",
    "\n",
    "dmabo_cumu_r_arr = np.cumsum(dmabo_regret_arr, axis=1)\n",
    "dmabo_cumu_constr1_arr = np.cumsum(dmabo_constr1_arr, axis=1)\n",
    "dmabo_cumu_constr2_arr = np.cumsum(dmabo_constr2_arr, axis=1)\n",
    "\n",
    "if True:\n",
    "    total_steps = 201\n",
    "    step_arr = np.arange(total_steps)\n",
    "    \n",
    "    %matplotlib inline\n",
    "    #from matplotlib import rc\n",
    "    #plt.rc('text',usetex=False)\n",
    "   \n",
    "\n",
    "    \n",
    "    fig, axes = plt.subplots(1, 1)\n",
    "    fig.set_size_inches(WIDTH * 1.0, HEIGHT * 1.0)\n",
    "\n",
    "    fig.subplots_adjust(left=.22, bottom=.20, right=.99, top=.97, hspace=0.33, wspace=0.4) \n",
    "   \n",
    "    ax = axes\n",
    "    BETA1 = 0.03\n",
    "    dmabo_line, _ = plot_with_shade_area(ax, step_arr, np.mean(dmabo_cumu_constr1_arr, axis=0), BETA1*np.std(dmabo_cumu_constr1_arr, axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[0], marker=marksCur[0], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    plt.xticks(fontsize=LABELSIZE)\n",
    "    plt.yticks(fontsize=LABELSIZE)\n",
    "    ax.tick_params(axis='x', colors=my_color)\n",
    "    ax.tick_params(axis='y', colors=my_color)\n",
    "    ax.set_xlabel('Step', fontsize=LABELSIZE, color=my_color)\n",
    "    ax.set_ylabel('Cumulative Constraint Violations (Averaged over 100 instances)', fontsize=LABELSIZE, color=my_color)  \n",
    "    plt.xlim((0, total_steps))\n",
    "    plt.legend([dmabo_line], ['DMABO'])\n",
    "\n",
    "    #ax.legend(['CEI', 'Safe BO', 'Primal-Dual', 'LCB2'])\n",
    "    \n",
    "    \n",
    "    \n",
    "\n",
    "    import tikzplotlib\n",
    "    tikzplotlib.clean_figure()\n",
    "    tikzplotlib.save('./figs/ri_cumu_constr1_vio.tex')\n",
    "    plt.savefig('./figs/ri_cumu_constr1_vio.pdf', format='pdf', bbox_inches='tight')\n",
    "    \n",
    "    plt.show()  \n",
    "   \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "7596f832",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 215.065x132.92 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "MARKERSIZE = 1.5 * 0.4 * 0.1\n",
    "colors = ['red','purple', 'orange', 'green', 'blue', 'black', 'blue']\n",
    "marksCur = ['o','s', '*', 'v', '^','+']\n",
    "my_color = 'black' #'c'\n",
    "MS_ratio = 0.1\n",
    "from fig_hp import *\n",
    "def plot_with_shade_area(ax, x, y, yerr, **kwargs):\n",
    "    y = np.squeeze(y)\n",
    "    yerr = np.squeeze(yerr)\n",
    "    aver_line, = ax.plot(x, y,markersize=MARKERSIZE*MS_ratio, linewidth=LINEWIDTH, color=kwargs['color'], marker=kwargs['marker'], markerfacecolor='None')\n",
    "    aver_region = ax.fill_between(x, y-yerr, y+yerr, alpha=0.3,color=kwargs['color'])\n",
    "    return aver_line, aver_region\n",
    "\n",
    "\n",
    "dmabo_regret_arr = np.array(dmabo_regret_list)\n",
    "dmabo_constr1_arr = np.array(dmabo_constr_1_list)\n",
    "dmabo_constr2_arr = np.array(dmabo_constr_2_list)\n",
    "\n",
    "dmabo_cumu_r_arr = np.cumsum(dmabo_regret_arr, axis=1)\n",
    "dmabo_cumu_constr1_arr = np.cumsum(dmabo_constr1_arr, axis=1)\n",
    "dmabo_cumu_constr2_arr = np.cumsum(dmabo_constr2_arr, axis=1)\n",
    "\n",
    "if True:\n",
    "    total_steps = 201\n",
    "    step_arr = np.arange(total_steps)\n",
    "    \n",
    "    %matplotlib inline\n",
    "    #from matplotlib import rc\n",
    "    #plt.rc('text',usetex=False)\n",
    "   \n",
    "\n",
    "    \n",
    "    fig, axes = plt.subplots(1, 1)\n",
    "    fig.set_size_inches(WIDTH * 1.0, HEIGHT * 1.0)\n",
    "\n",
    "    fig.subplots_adjust(left=.22, bottom=.20, right=.99, top=.97, hspace=0.33, wspace=0.4) \n",
    "   \n",
    "    ax = axes\n",
    "    BETA1 = 0.03\n",
    "    dmabo_line, _ = plot_with_shade_area(ax, step_arr, np.mean(dmabo_cumu_constr2_arr, axis=0), BETA1*np.std(dmabo_cumu_constr2_arr, axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[0], marker=marksCur[0], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    plt.xticks(fontsize=LABELSIZE)\n",
    "    plt.yticks(fontsize=LABELSIZE)\n",
    "    ax.tick_params(axis='x', colors=my_color)\n",
    "    ax.tick_params(axis='y', colors=my_color)\n",
    "    ax.set_xlabel('Step', fontsize=LABELSIZE, color=my_color)\n",
    "    ax.set_ylabel('Cumulative Constraint Violations (Averaged over 100 instances)', fontsize=LABELSIZE, color=my_color)  \n",
    "    plt.xlim((0, total_steps))\n",
    "    plt.legend([dmabo_line], ['DMABO'])\n",
    "\n",
    "    #ax.legend(['CEI', 'Safe BO', 'Primal-Dual', 'LCB2'])\n",
    "    \n",
    "    \n",
    "    \n",
    "\n",
    "    import tikzplotlib\n",
    "    tikzplotlib.clean_figure()\n",
    "    tikzplotlib.save('./figs/ri_cumu_constr2_vio.tex')\n",
    "    plt.savefig('./figs/ri_cumu_constr2_vio.pdf', format='pdf', bbox_inches='tight')\n",
    "    \n",
    "    plt.show()  \n",
    "   \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "deaa9e2a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 215.065x132.92 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "configrey_cumu_constr_vio_arr = np.array(configrey_cumu_constr_vio_list_list)\n",
    "config_cumu_constr_vio_arr = np.array(config_cumu_constr_vio_list_list)\n",
    "#plt.plot(np.mean(configrey_cumu_constr_vio_arr[:, :, 0], axis=0))\n",
    "#plt.plot(np.mean(config_cumu_constr_vio_arr[:, :, 0], axis=0))\n",
    "\n",
    "\n",
    "\n",
    "MARKERSIZE = 1.5 * 0.4 * 0.1\n",
    "colors = ['red','purple', 'orange', 'green', 'blue', 'black', 'blue']\n",
    "marksCur = ['o','s', '*', 'v', '^','+']\n",
    "my_color = 'black' #'c'\n",
    "MS_ratio = 0.1\n",
    "from fig_hp import *\n",
    "def plot_with_shade_area(ax, x, y, yerr, **kwargs):\n",
    "    y = np.squeeze(y)\n",
    "    yerr = np.squeeze(yerr)\n",
    "    aver_line, = ax.plot(x, y,markersize=MARKERSIZE*MS_ratio, linewidth=LINEWIDTH, color=kwargs['color'], marker=kwargs['marker'], markerfacecolor='None')\n",
    "    aver_region = ax.fill_between(x, y-yerr, y+yerr, alpha=0.3,color=kwargs['color'])\n",
    "    return aver_line, aver_region\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "if True:\n",
    "    total_steps = 21\n",
    "    step_arr = np.arange(total_steps)\n",
    "    \n",
    "    %matplotlib inline\n",
    "    #from matplotlib import rc\n",
    "    #plt.rc('text',usetex=False)\n",
    "   \n",
    "\n",
    "    \n",
    "    fig, axes = plt.subplots(1, 1)\n",
    "    fig.set_size_inches(WIDTH * 1.0, HEIGHT * 1.0)\n",
    "\n",
    "    fig.subplots_adjust(left=.22, bottom=.20, right=.99, top=.97, hspace=0.33, wspace=0.4) \n",
    "   \n",
    "    ax = axes\n",
    "    BETA1 = 0.3\n",
    "    configrey_line, _ = plot_with_shade_area(ax, step_arr,np.mean(configrey_cumu_constr_vio_arr[:, :, 1], axis=0), BETA1*np.std(configrey_cumu_constr_vio_arr[:, :, 1], axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[0], marker=marksCur[0], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    config_line, _ = plot_with_shade_area(ax, step_arr, np.mean(config_cumu_constr_vio_arr[:, :, 1], axis=0), BETA1*np.std(config_cumu_constr_vio_arr[:, :, 1], axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[1], marker=marksCur[1], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    cei_line, _ = plot_with_shade_area(ax, step_arr, np.mean(cei_cumu_constr_vio_arr[:, :, 1], axis=0), BETA1*np.std(cei_cumu_constr_vio_arr[:, :, 1], axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[2], marker=marksCur[2], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    ceicf_line, _ = plot_with_shade_area(ax, step_arr, np.mean(ceicf_cumu_constr_vio_arr[:, :, 1], axis=0), BETA1*np.std(ceicf_cumu_constr_vio_arr[:, :, 1], axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[3], marker=marksCur[3], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    \n",
    "    plt.xticks(fontsize=LABELSIZE)\n",
    "    plt.yticks(fontsize=LABELSIZE)\n",
    "    ax.tick_params(axis='x', colors=my_color)\n",
    "    ax.tick_params(axis='y', colors=my_color)\n",
    "    ax.set_xlabel('Step', fontsize=LABELSIZE, color=my_color)\n",
    "    ax.set_ylabel('Cumulative Constraint Violation 2 (Averaged over 30 instances)', fontsize=LABELSIZE, color=my_color)  \n",
    "    plt.xlim((0, total_steps))\n",
    "    plt.legend([configrey_line, config_line], ['CONFIGREY', 'CONFIG'])\n",
    "\n",
    "    #ax.legend(['CEI', 'Safe BO', 'Primal-Dual', 'LCB2'])\n",
    "    \n",
    "    \n",
    "    \n",
    "\n",
    "    import tikzplotlib\n",
    "    tikzplotlib.clean_figure()\n",
    "    tikzplotlib.save('./figs/cumu_vio_2.tex')\n",
    "    plt.savefig('./figs/cumu_vio_2.pdf', format='pdf', bbox_inches='tight')\n",
    "    # plt.savefig(f'./fig/sample_funcs_r_and_v.pdf', format='pdf', bbox_inches='tight')\n",
    "    \n",
    "    plt.show()  \n",
    "   \n",
    "#plot_cumu_result(con_bo_regret_lists, safe_regret_lists, pdbo_regret_lists, lcb2_regret_lists,\n",
    "#                    con_bo_constrs_lists, safe_constrs_lists, pdbo_constrs_lists, lcb2_constrs_lists,\n",
    "#                epbo_regret_lists_2, epbo_constrs_lists_2, epbo_regret_lists_3, epbo_constrs_lists_3)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5410b77a",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
