{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "68c8e3a5",
   "metadata": {},
   "source": [
    "# analyze the performance over the problem with randomly sampled instances"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "de9ca1d4",
   "metadata": {},
   "source": [
    "## import packages and set some parameter configurations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "a8c8240e",
   "metadata": {
    "scrolled": true,
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "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": 10,
   "id": "a6b95c12",
   "metadata": {},
   "outputs": [],
   "source": [
    "file_path = './result/sample_00_22_32-Sep_29_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[:6]:\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": 11,
   "id": "18cb453f",
   "metadata": {},
   "outputs": [],
   "source": [
    "dmabo_regret_list, dmabo_constr_1_list, dmabo_constr_2_list, cei_regret_list, cei_constr_1_list, cei_constr_2_list = content\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "506048d1",
   "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_constr1_arr_pos = np.maximum(dmabo_constr1_arr, 0)\n",
    "dmabo_constr2_arr_pos = np.maximum(dmabo_constr2_arr, 0)\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",
    "dmabo_cumu_constr1_arr_pos = np.cumsum(dmabo_constr1_arr_pos, axis=1)\n",
    "dmabo_cumu_constr2_arr_pos = np.cumsum(dmabo_constr2_arr_pos, axis=1)\n",
    "\n",
    "\n",
    "cei_regret_arr = np.array(cei_regret_list)\n",
    "cei_constr1_arr = np.array(cei_constr_1_list)\n",
    "cei_constr2_arr = np.array(cei_constr_2_list)\n",
    "\n",
    "cei_constr1_arr_pos = np.maximum(cei_constr1_arr, 0)\n",
    "cei_constr2_arr_pos = np.maximum(cei_constr2_arr, 0)\n",
    "\n",
    "cei_cumu_r_arr = np.cumsum(cei_regret_arr, axis=1)\n",
    "cei_cumu_constr1_arr = np.cumsum(cei_constr1_arr, axis=1)\n",
    "cei_cumu_constr2_arr = np.cumsum(cei_constr2_arr, axis=1)\n",
    "\n",
    "cei_cumu_constr1_arr_pos = np.cumsum(cei_constr1_arr_pos, axis=1)\n",
    "cei_cumu_constr2_arr_pos = np.cumsum(cei_constr2_arr_pos, axis=1)\n",
    "\n",
    "\n",
    "\n",
    "if True:\n",
    "    total_steps = 101\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.2\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[3], marker=marksCur[3], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    cei_line, _ = plot_with_shade_area(ax, step_arr, np.mean(cei_cumu_r_arr, axis=0), BETA1*np.std(cei_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', fontsize=LABELSIZE, color=my_color)  \n",
    "    plt.xlim((0, total_steps))\n",
    "    plt.legend([dmabo_line, cei_line], ['DMABO', 'DCEI'], fontsize=LABELSIZE)\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": 19,
   "id": "7100f599",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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QGGuxhNNFOwZbe7zaCqo8SlgXaruxGjmU7qorKys0xY2NgNRW1sb6L8vEAhEtdZTs9Ge0SAVwP0VJDPHeiQL89pU0OcTZFIi3YEEgW5Ofac+B7JuT2hsgZP7NPQqftSKBKAuT6XgqEmVJXhYKVWYel+tlHpiGKUKHOMhbNasWVN09dVXz/31r3+dv2bNmqL7779/WnNzs3PVqlWlCxcuvLD3sY899tjUm266qU9anNra2sCqVatK+59v1apVpVdfffVca/+qVatK16xZU7Rq1arSj33sYzObm5udY/3bRkou3JPm5mbnwoULL6yrq/NYxz722GNnFCaprA3q3H599lBK1Witt6Qmcael+9dar+s1yYNMrkIGOt5m6NgCJ8eZLLOxK664IlxdXR2/9dZbu+6+++62u+66q+3Tn/709JtvvrnzyJEj3l//+tf51rG/+tWviqurq2O9v79hw4bAf/3XfxX1P99DDz3UXF1dHa+rq/OsWrWqdM6cObG777677aGHHmp+4IEHmv76r/965nj+zuGQC/ektLTUWLx4cWTBggVxgPb2dufjjz9+sq6uzlNbWxvYsGFDoLa2NpDLgnsErEjVSlqJ9K0GZBJXg+Sfez41kStMHX9f6tgt2S5kN9Gx13ByHGs2huQEW97/773Tx/SqxGeRM51jypQpRu/P1157beSjH/1oPnDi05/+9InVq1eX3XrrrV1r1qwp+tCHPtT7N9Dc3OycM2dOzBpEFyxYEJ8yZYpx8OBBz6pVq0pramqiCxYsiN9zzz1Fb7zxxr7e19i1a9dpJqFcIVfuSSgUSjY3NztPnTrlXLZsWQQgJYDi1nfG6h5kg0ESYFq1bxroVdgvpc2tHues55MWW8PJfXJmNtYSaRnVWW5VVVUM4MYbb+w6fPiwt66uzlNfX++58cYbu3of98wzzxS1tbW5ampqoo8//niFtb+6ujr+8Y9/vG3z5s3BX//61/kdHR2u/jPxgoKCPoN6rpONezJ79uzYO++8433hhRcKbr311j7XmWzCZgQsAS7LdiMmC7aGk+OM52xM/bNaevajzoz+R715KMetWbOm6N577222Pv/Lv/zL0XvuuWfmk08+eWyg4+++++42gN5rEyAmoeuuu65z//793g996EOt3/jGN0off/zxkwB1dXWe/prBSFCKc78vmrPel2zdkzlz5sS+/e1vlz322GMnRvLbJjNZLp0w6bAFzuRiCVCCZLMeNkMVFiOhtrY2sH379sCaNWuKWlpEU3rooYeaV61aVWqtGzz33HPF1157beSxxx6bunnz5mBzc7PzmWeeKWpvb0/P0EOhkHH//fdPu+GGGzqt89XX13u/853vHAO4//77pz322GNTly1bFmlra3NZA+25cDZh0dKCs6SEYWtSuXJP5s2bF4O0Gc3GZsywAz/Pc7Zv335w8eLFzWc/0sYmw/bt20sXL15cne122Ews7DUcGxsbG5txwRY4NjY2Njbjgi1wbGxsbGzGBVvg2NjY2NiMC7bAsbE5zxgoP5qNzXhgCxybcWGwvGHW3/rvX7NmTdHChQsvXLNmTdFjjz021Tpm4cKFF06WNCtjcU9GkhvNxma8sONwbMaFK664Irx27dp0JPvcuXNjn/70p6cvX768E8Daf8stt3Ra788991yRFdxoDaihUChZWlo6obIHDMZY3JPBcqOBBH22tra6NmzYEAC44IILYpPlXtpMDGyBYzMuDJY37ODBg57f/OY36RQ8vQfAw4cPe1NBjB5r0AyFQpNmgByrezJQbjSY3PnRbCYGtknNZugcPz6qExQrb9hghEKh5N13393We9Cc7IzGPTlTbjSwhY1N9rA1HJsM6txzqaGHl0utpaXF+aUvfancSsNi0dzc7LRm7rfeemtXNtdt1CjcFz2E+zJa98TOjWaTq9gCxybD2QbF48ddVFYmR3LqwfKGgRQXu//++6fNnj07VlJSYtxyyy2dtbW1Act8BNDS0uKcM2dObNeuXYHm5mbneK49DEVYjISxuid2bjSbXMXOpXaeY+dSsxkJdi41m5Fgr+HY2NjY2IwLtsCxsbGxsRkXbIFjY2NjYzMu2ALHxjRNU2W7ETYTh9S6r734azNsbIFjs6upqSlkCx2boRKJRHxKqXOupGpz/mG7RZ/nJJPJexobG7/X2Nh4EfYExGZoGIZhPJbtRthMPGy3aBsbGxubccGe0drY2NjYjAu2wLGxsbGxGRdsgWNjY2NjMy7YAsfGxsbGZlywBY6NjY2Nzbjw/wNpZDAPQZJ2JQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 473.142x132.92 with 2 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_cumu_constr_vio_arr = np.sqrt( np.maximum(dmabo_cumu_constr1_arr, 0) ** 2 + np.maximum(dmabo_cumu_constr2_arr, 0) ** 2)\n",
    "cei_cumu_constr_vio_arr = np.sqrt( np.maximum(cei_cumu_constr1_arr, 0) ** 2 + np.maximum(cei_cumu_constr2_arr, 0) ** 2)\n",
    "\n",
    "dmabo_cumu_constr_vio_arr_pos = np.sqrt( np.maximum(dmabo_cumu_constr1_arr_pos, 0) ** 2 + np.maximum(dmabo_cumu_constr2_arr_pos, 0) ** 2)\n",
    "cei_cumu_constr_vio_arr_pos = np.sqrt( np.maximum(cei_cumu_constr1_arr_pos, 0) ** 2 + np.maximum(cei_cumu_constr2_arr_pos, 0) ** 2)\n",
    "\n",
    "if True:\n",
    "    total_steps = 101\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, 2)\n",
    "    fig.set_size_inches(WIDTH * 2.2, 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[0]\n",
    "    BETA1 = 0.2\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[3], marker=marksCur[3], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    cei_line, _ = plot_with_shade_area(ax, step_arr, np.mean(cei_cumu_r_arr, axis=0), BETA1*np.std(cei_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', fontsize=LABELSIZE, color=my_color)  \n",
    "    plt.xlim((0, total_steps))\n",
    "    plt.legend([dmabo_line, cei_line], ['DMABO', 'DCEI'], fontsize=LABELSIZE)\n",
    "\n",
    "    #ax.legend(['CEI', 'Safe BO', 'Primal-Dual', 'LCB2'])\n",
    "    \n",
    "    ax = axes[1]\n",
    "    BETA1 = 0.1\n",
    "    dmabo_line, _ = plot_with_shade_area(ax, step_arr, np.mean(dmabo_cumu_constr_vio_arr, axis=0), BETA1*np.std(dmabo_cumu_constr_vio_arr, axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[3], marker=marksCur[3], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    cei_line, _ = plot_with_shade_area(ax, step_arr, np.mean(cei_cumu_constr_vio_arr, axis=0), BETA1*np.std(cei_cumu_constr_vio_arr, axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[0], marker=marksCur[0], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    dmabo_line_pos, _ = plot_with_shade_area(ax, step_arr, np.mean(dmabo_cumu_constr_vio_arr_pos, axis=0), BETA1*np.std(dmabo_cumu_constr_vio_arr_pos, axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[4], marker=marksCur[4], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    cei_line_pos, _ = plot_with_shade_area(ax, step_arr, np.mean(cei_cumu_constr_vio_arr_pos, axis=0), BETA1*np.std(cei_cumu_constr_vio_arr_pos, axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[5], marker=marksCur[5], 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', fontsize=LABELSIZE, color=my_color)  \n",
    "    plt.xlim((0, total_steps))\n",
    "    plt.legend([dmabo_line, cei_line, dmabo_line_pos, cei_line_pos], ['DMABO', 'DCEI', 'DMABO $V^+$', 'DCEI $V^+$'], fontsize=LABELSIZE, loc='lower right', bbox_to_anchor=(0.17, -0.5), ncol=2)\n",
    "    \n",
    "\n",
    "    import tikzplotlib\n",
    "    tikzplotlib.clean_figure()\n",
    "    tikzplotlib.save('./figs/ri_cumu_r_vio.tex')\n",
    "    plt.savefig('./figs/ri_cumu_r_vio.pdf', format='pdf', bbox_inches='tight')\n",
    "    \n",
    "    plt.show()  \n",
    "   \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f7bb726b",
   "metadata": {},
   "outputs": [],
   "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",
    "if True:\n",
    "    total_steps = 101\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, 2)\n",
    "    fig.set_size_inches(WIDTH * 2.2, 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[0]\n",
    "    BETA1 = 0.05\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[3], marker=marksCur[3], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    cei_line, _ = plot_with_shade_area(ax, step_arr, np.mean(cei_cumu_constr1_arr, axis=0), BETA1*np.std(cei_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 Value 1', fontsize=LABELSIZE, color=my_color)  \n",
    "    plt.xlim((0, total_steps))\n",
    "    plt.legend([dmabo_line, cei_line], ['DMABO', 'DCEI'], fontsize=LABELSIZE)\n",
    "\n",
    "    #ax.legend(['CEI', 'Safe BO', 'Primal-Dual', 'LCB2'])\n",
    "    \n",
    "    ax = axes[1]\n",
    "    BETA1 = 0.05\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[3], marker=marksCur[3], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    cei_line, _ = plot_with_shade_area(ax, step_arr, np.mean(cei_cumu_constr2_arr, axis=0), BETA1*np.std(cei_cumu_constr2_arr, axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[0], marker=marksCur[0], 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 Value 2', fontsize=LABELSIZE, color=my_color)  \n",
    "    plt.xlim((0, total_steps))\n",
    "    plt.legend([dmabo_line, cei_line], ['DMABO', 'DCEI'], fontsize=LABELSIZE, loc='lower right', bbox_to_anchor=(0.17, -0.5), ncol=2)\n",
    "    \n",
    "\n",
    "    import tikzplotlib\n",
    "    tikzplotlib.clean_figure()\n",
    "    tikzplotlib.save('./figs/ri_cumu_constr_vio.tex')\n",
    "    plt.savefig('./figs/ri_cumu_constr_vio.pdf', format='pdf', bbox_inches='tight')\n",
    "    \n",
    "    plt.show()  \n",
    "   \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "7c3e27a9",
   "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",
    "if True:\n",
    "    total_steps = 101\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.05\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[3], marker=marksCur[3], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    cei_line, _ = plot_with_shade_area(ax, step_arr, np.mean(cei_cumu_constr2_arr, axis=0), BETA1*np.std(cei_cumu_constr2_arr, axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[0], marker=marksCur[0], 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 Value 2', fontsize=LABELSIZE, color=my_color)  \n",
    "    plt.xlim((0, total_steps))\n",
    "    plt.legend([dmabo_line, cei_line], ['DMABO', 'DCEI'], fontsize=LABELSIZE)\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": "f3f671b6",
   "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": "2b307f39",
   "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
}
