{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "f20d0d33",
   "metadata": {},
   "source": [
    "# run CONFIGREY and other algorithms on a test instance of LP embedded with GP"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e3ce6e68",
   "metadata": {},
   "source": [
    "## import packages and set some parameter configurations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "dd344e56",
   "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": 20,
   "id": "6e5f3d58",
   "metadata": {},
   "outputs": [],
   "source": [
    "old_file_name = 'GPLP_18_58_39-May_09_2023.pkl'\n",
    "file_name = 'GPLP_20_55_15-Aug_21_2023.pkl'\n",
    "with open('./result/' + file_name, 'rb') as pickle_file:\n",
    "    raw_content = pickle.load(pickle_file)\n",
    "\n",
    "content = []\n",
    "for content_list in raw_content:\n",
    "    new_content_list = [[x[0] if type(x) == np.ndarray and len(x)==1 else x for x in y] for y in content_list]\n",
    "    content.append(new_content_list)\n",
    "    \n",
    "    \n",
    "configrey_obj_list_list, \\\n",
    "configrey_constr_list_list, \\\n",
    "configrey_cumu_pos_regret_list_list, \\\n",
    "configrey_cumu_constr_vio_list_list, \\\n",
    "configrey_best_constr_regret_list_list, \\\n",
    "config_obj_list_list, \\\n",
    "config_constr_list_list, \\\n",
    "config_cumu_pos_regret_list_list, \\\n",
    "config_cumu_constr_vio_list_list, \\\n",
    "config_best_constr_regret_list_list = content[:10]\n",
    "\n",
    "cei_obj_list_list, \\\n",
    "cei_constr_list_list, \\\n",
    "cei_cumu_pos_regret_list_list, \\\n",
    "cei_cumu_constr_vio_list_list, \\\n",
    "cei_best_constr_regret_list_list, \\\n",
    "ceicf_obj_list_list, \\\n",
    "ceicf_constr_list_list, \\\n",
    "ceicf_cumu_pos_regret_list_list, \\\n",
    "ceicf_cumu_constr_vio_list_list, \\\n",
    "ceicf_best_constr_regret_list_list = content[10:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "6cbe4b87",
   "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",
    "configrey_best_constr_regret_arr = np.array(configrey_best_constr_regret_list_list)\n",
    "config_best_constr_regret_arr = np.array(config_best_constr_regret_list_list)\n",
    "\n",
    "cei_best_constr_regret_arr = np.array(cei_best_constr_regret_list_list)\n",
    "ceicf_best_constr_regret_arr = np.array(ceicf_best_constr_regret_list_list)\n",
    "\n",
    "if True:\n",
    "    total_steps = 20\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_best_constr_regret_arr, axis=0), BETA1*np.std(configrey_best_constr_regret_arr, 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_best_constr_regret_arr, axis=0), BETA1*np.std(config_best_constr_regret_arr, 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_best_constr_regret_arr, axis=0), BETA1*np.std(cei_best_constr_regret_arr, 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_best_constr_regret_arr, axis=0), BETA1*np.std(ceicf_best_constr_regret_arr, 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('Constrained Regret (Averaged over 30 instances)', fontsize=LABELSIZE, color=my_color)  \n",
    "    plt.xlim((0, total_steps))\n",
    "    plt.legend([configrey_line, config_line, cei_line, ceicf_line], ['CONFIGREY', 'CONFIG', 'CEI', 'CEICF'])\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/constrained_regret.tex')\n",
    "    plt.savefig('./figs/constrained_regret.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": 28,
   "id": "6f0a5d56",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f1f55e2b190>"
      ]
     },
     "execution_count": 28,
     "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": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "f752eb1d",
   "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",
    "configrey_cumu_pos_regret_arr = np.array(configrey_cumu_pos_regret_list_list)\n",
    "config_cumu_pos_regret_arr = np.array(config_cumu_pos_regret_list_list)\n",
    "cei_cumu_pos_regret_arr = np.array(cei_cumu_pos_regret_list_list)\n",
    "ceicf_cumu_pos_regret_arr = np.array(ceicf_cumu_pos_regret_list_list)\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_pos_regret_arr, axis=0), BETA1*np.std(configrey_cumu_pos_regret_arr, 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_pos_regret_arr, axis=0), BETA1*np.std(config_cumu_pos_regret_arr, 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_pos_regret_arr, axis=0), BETA1*np.std(cei_cumu_pos_regret_arr, 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_pos_regret_arr, axis=0), BETA1*np.std(ceicf_cumu_pos_regret_arr, axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[3], marker=marksCur[3], 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 Positive Regret (Averaged over 30 instances)', fontsize=LABELSIZE, color=my_color)  \n",
    "    plt.xlim((0, total_steps))\n",
    "    plt.legend([configrey_line, config_line, cei_line, ceicf_line], ['CONFIGREY', 'CONFIG', 'CEI', 'CEICF'])\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_pos_regret.tex')\n",
    "    plt.savefig('./figs/cumu_pos_regret_regret.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": 22,
   "id": "43293f42",
   "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",
    "\n",
    "cei_cumu_constr_vio_arr = np.array(cei_cumu_constr_vio_list_list)\n",
    "ceicf_cumu_constr_vio_list_list = [[[x[0] if type(x)==np.ndarray else x for x in vio_list] for vio_list in vio_list_list]for vio_list_list in ceicf_cumu_constr_vio_list_list]\n",
    "ceicf_cumu_constr_vio_arr = np.array(ceicf_cumu_constr_vio_list_list)\n",
    "\n",
    "\n",
    "\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",
    "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[:, :, 0], axis=0), BETA1*np.std(configrey_cumu_constr_vio_arr[:, :, 0], 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[:, :, 0], axis=0), BETA1*np.std(config_cumu_constr_vio_arr[:, :, 0], 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[:, :, 0], axis=0), BETA1*np.std(cei_cumu_constr_vio_arr[:, :, 0], 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[:, :, 0], axis=0), BETA1*np.std(ceicf_cumu_constr_vio_arr[:, :, 0], axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[3], marker=marksCur[3], 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 Violation 1 (Averaged over 30 instances)', fontsize=LABELSIZE, color=my_color)  \n",
    "    plt.xlim((0, total_steps))\n",
    "    plt.legend([configrey_line, config_line, cei_line, ceicf_line], ['CONFIGREY', 'CONFIG', 'CEI', 'CEICF'])\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_1.tex')\n",
    "    plt.savefig('./figs/cumu_vio_1.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": 19,
   "id": "6928761b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(30, 21, 2)"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ceicf_cumu_constr_vio_arr.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "b284d34e",
   "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": "bf88fb0b",
   "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
}
