{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "94b2ae21",
   "metadata": {},
   "source": [
    "# analyze the performance over the problem with randomly sampled instances"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "699d4d1f",
   "metadata": {},
   "source": [
    "## import packages and set some parameter configurations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "9c234004",
   "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": "6e6de086",
   "metadata": {},
   "outputs": [],
   "source": [
    "file_path = './result/pa_sample_14_20_36-Sep_16_2023_5.pkl'\n",
    "with open(file_path, 'rb') as pickle_file:\n",
    "    raw_content = pickle.load(pickle_file)\n",
    "\n",
    "content = []\n",
    "for content_list in raw_content[:4]:\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",
    "\n",
    "content.append(raw_content[4])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "51f1ab84",
   "metadata": {},
   "outputs": [],
   "source": [
    "file_path_10 = './result/pa_sample_04_56_43-Sep_15_2023_20.pkl'\n",
    "\n",
    "with open(file_path_10, 'rb') as pickle_file:\n",
    "    raw_content = pickle.load(pickle_file)\n",
    "\n",
    "content_10 = []\n",
    "for content_list in raw_content[:4]:\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_10.append(new_content_list)\n",
    "\n",
    "content_10.append(raw_content[4])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "ef886d26",
   "metadata": {},
   "outputs": [],
   "source": [
    "file_path_N = './result/pa_sample_04_24_28-Sep_27_2023_5_10.pkl'\n",
    "\n",
    "with open(file_path_N, 'rb') as pickle_file:\n",
    "    raw_content_N = pickle.load(pickle_file)\n",
    "\n",
    "content_N = []\n",
    "for content_list in raw_content_N[:4]:\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_N.append(new_content_list)\n",
    "\n",
    "content_N.append(raw_content_N[4])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "ede364e2",
   "metadata": {},
   "outputs": [],
   "source": [
    "dmabo_regret_list, dmabo_constr_1_list, pen_regret_list, pen_constr_1_list = content[:4]\n",
    "if True:\n",
    "    obj_avg_list = content[4]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "b9552ee9",
   "metadata": {},
   "outputs": [],
   "source": [
    "dmabo_regret_list_10, dmabo_constr_1_list_10, pen_regret_list_10, pen_constr_1_list_10 = content_10[:4]\n",
    "if True:\n",
    "    obj_avg_list = content[4]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "7398a02e",
   "metadata": {},
   "outputs": [],
   "source": [
    "dmabo_regret_list_N, dmabo_constr_1_list_N, pen_regret_list_N, pen_constr_1_list_N = content_N[:4]\n",
    "if True:\n",
    "    obj_avg_list = content[4]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "f2377c3b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7fb49e5cfaf0>"
      ]
     },
     "execution_count": 12,
     "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"
    },
    {
     "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": [
    "instance_id = 50\n",
    "plt.plot(dmabo_constr1_arr[instance_id,:])\n",
    "plt.plot(dmabo_regret_arr[instance_id,:])\n",
    "plt.figure()\n",
    "plt.scatter(dmabo_constr1_arr[instance_id, :], - dmabo_regret_arr[instance_id, :])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "bec5d79a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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axagprROP/10ysvLaW3V8f80o4ekGfJa4GqGeUpMSkljYyNvvPEGP/3pT3UYJc2wkdWay+bNm1mwYAHhcJiDBw+Sn5/PggULePzxx7n55puPakoZjUZTU2ahUIh4PE4sFkudN9NmeAarV6t5zhpSwfTMlVKmwiVYF/czy7Cu5VjPZ16HdFymzPUfq+FA5rmeDAsy142shgA9HfeU10rmZ/qaNzN/X/MerT2ZeU855RSWL1/eY74s4gmgciQq7urqIhqNsmXLFuLxOBUVFUyfPn0kmqL5nJG1wiUajfLJJ5/wN3/zN9TW1nL22WezZcsWbrjhBm6//Xbef/99IpFISgjE43Hsdnsq/AR071BzcnJS6zE2m42CggJaW1ux2WyMHz+euro6QK2pTJo0ierqaoQQTJ06lX379qXWWmbOnMnOnTtTazVz585l+/btCCGYP38+n3zySeo7LFy4kA8++CBV7mmnncZ77yl3hzPOOIPNmzen8n7xi1/knXfeQQjBkiVLePvtt1PXzj77bN56663U8TnnnMObb74JwHnnncfrr6cdvpcuXcprr72WqnPZsmW8+uqrCCE4//zzefnll1PXLrjgAl566aXU8YUXXsiLL74IwEUXXcT69etT177yla/wwgsvIITg4osv5oUXXkjVeckll/CnP/0pldd6fNlll/H888+n8l522WX88Y9/TB1fccUVPPfccwBcfvnlqTTAlVdeyR/+8IdUPjMNcNVVV/HMM89QUVHBKKBCSvmhEOJ2oHA4K25vb6e5uZnGxkYuvvhiNm7cqIWLZlgQI6kmL1q0SPa2sVFVVRVlZWX827/9G5MmTeLSSy9lx44dvPnmm4wbN4777ruPm2++md/97neAWri/4YYbeOyxx7DZbNx888088sgjfOtb3xrOr6QZZqqqqli+fHmP1lBCiK1SykUj0CxrG0wnSlDWYmVSyiFzosx8piorK/nhD39IbW0tl112Gffeey+//OUvU4EPNZqjYYZ/+eY3v9mv5ylrNZdQKERBQQEdHR3MmjULIQTm9q1CCP7pn/4JgG9/+9vdPnfbbbel0lqwaLKALUBZ8j2IMkUeNhobG9m2bRsXXXQRU6dOpaCggGuvvRbDMFi2bBlf+tKXOPHEE7UVpGbQGRLhIoRYClwtpVwx0DJCoRAOhwO73c7YsWMBcLvdTJ48maam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ep999tmCzPJWrVrVUFpaGikvL3euWbMmMH369PCNN97YvGrVqoZbb721/vrrr58ynN9To9EcX2jhkuWMGTMmbj1esmRJ51/+8pc8gNtuu+3Q2rVri0FpJFdccUVTUVFRzMzb0NBgTJ8+PWwKEbO8vXv3OtesWRMoKysLzZ49O/Lss88WXH755W3WOrZt2+Ydnm/Yf9atW1cwZ86cWevWrSu47rrrppjfbSDlrFu3ruDoOeG5557LmzNnzixTozM1v2zQ8MwBwpo1awIbN27Uv5uFbP/dVq5cOdH6XcrLy50DvS/ZhhYuw0BjZ+Og/pEnT54cBrjgggva9u/f7yovL3dWVFQ4L7jggjZrvscee6ygubnZXlZWFrr77rvHm+dLS0sjN9xwQ/PWrVtznnvuubyWlhZ75sOWn5/fTagNBR31HQO6L5dccklrSUlJ+MYbb2xetmxZ6+OPP96njiaTGTNmhCsqKpxm53ykvEuWLOn0+XyxQCAQB7joootaS0tLI+Zxf2hoaDCsGiekBURv14/Epk2bcs4444zOM844o3PmzJnho3/iGEjEjp6nF/Tv1p3169fn//SnP6158sknCzZu3Oh97rnn8pqamuzr16/P70852Yq2FhsExF1i4bGWIX8st/Yl37p16wpuvvnmBvP4nnvuOXjTTTdNuf/++6t6yn/jjTc2A1jXVwACgUD8vPPOa929e7friiuuaHrggQcCd999dy2oB+aKK65o6qm8/nCXuOuY78uP5Y8Puy/WjuHVV1/NX7169aHy8nLnpk2bcioqKpzf/va3G370ox+NmzZtWhhUhzJ79uzIxo0bvbt27XI9+eSTBS+++GJlYWFhDNRD/tprr+WfccYZnS+99FIewN133127cuXKiT/96U9rAoFAPBAIxFtaWuzmKLOioiI1usys+7HHHisAuOGGG5rPPvvsE7Zv3/7pypUrJ5r5p02bFg4GgynBunv3bheA2YZ3333XGwwGjSVLlnT+6U9/yje/486dO11m/lWrVqX+AwC7du1ygepMj+mGP37s/2Wu6/m/rH+37r+bmV64cGEHwJNPPln4+OOP75s5c2b4tttum2SdTRiNaOEyCPRVMAyEjRs3ej/66CPvunXrChoblQa0atWqhjVr1gSCwaBx99131z755JOFS5Ys6Vy9evXYrVu35jQ0NBiPPfZYgfVB8Pl88ZUrV048//zzW83yKioqXL/5zW+qAFauXDlx9erVYxctWtTZ3NxsNwXNsdCTYLDSUd9h5BTnDFhD2rhxo/cXv/jFwUAgEL/wwgvLVqxYUe/3+43HHnus4LTTTuvcvHmz96c//WnN9ddfP+XFF1+sNDvelpYWwzr1cMYZZ3SC6pjNBxvg/PPPb7V2iD6fL2YK6/LycqepDX7ve9+bZK3b7GgCgUC8pKQkDPD1r3+9+de//nXx6tWrDzU1NdlfeumlvCeffLKwrKwsZNU4zTa+9NJLebfddtukxx9/fJ9Z59133z0+Mz+odbQxY8bEH3jggcCaNWsCmYKnX/QiGFLIBIhjm/DQv9vhLFmypPOee+4xoLsQHs1o4ZLlXH755W2XX375p5nnrR3I448/vg/UqK2n6wAvvvhiKiS/WZ755wcwhcxwMlDBYk7hZY7SkyO9NlBz7aeddlqn9UFdvXr12AsuuKDt3HPPbe2tbDN/Zifd0NBg+Hy+XttrrXvjxo1eU7C3tLQYAIWFhTFzjau8vByAX/ziFwc3btzo/f73vz/RqnmaI/Pm5majoaHBMNtkzX/uuee2VlZWum+99db6mTNnhgOBQPy6665rHuhUU585BsGif7fuv9uSJUs616xZk5oxKCgoiJttLisrCx31hmY5es1FM+rYuHGjd9u2bV7rOtGKFSvqL7zwwrJ169YVNDQ0GC+//HL+5s2bvaA6ioaGBqOxsdH+0ksv5W3dujVn06ZNOevXr8+vrKx0z5w5M/zaa6/lm6PiW2+9td6q9fVU5/r16/P37t3rbGhoMDLrnjlzZvj111/PX7NmTaClpcVeXl7uXL9+ff7WrVtzzM9WVla6H3jggQDAzTff3GBtg3n9hz/8Yc2ll15atmbNmkBDQ4NhzX/33XfXPv744/uWLFnS+dhjjxWsW7euYNOmTTmDoXEOFfp36/67XXfddVOeffbZggsvvLBs9erVY2+99db6NWvWBB577LGCb3/72wPXPrMEHRV5gHz00Ud758+fP+r/AJrDee655/KWLFnSebxMT3xeOF5/t48++igwf/780pFuR3/RmotGY2HNmjWB5uZm+/HWQR3v6N8t+9CaywD56KOPKufNm6fjimk0miEjkUiITz75pGD+/PllR8+dXWjNZeBsq6+v9yUSCTHSDdFoNMcfycCVPmDbSLdlIGhrsQESi8VuqqmpeaSmpkaH3NdoNENBKuT+SDdkIOhpMY1Go9EMOnrErdFoNJpBRwsXjUaj0Qw6WrhoNBqNZtDRwkWj0Wg0g44WLhqNRqMZdP5/hwYZKr9XsZEAAAAASUVORK5CYII=\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_regret_arr = np.array(dmabo_regret_list)\n",
    "dmabo_constr1_arr = np.array(dmabo_constr_1_list)\n",
    "dmabo_cumu_r_arr = np.cumsum(dmabo_regret_arr, axis=1)\n",
    "num_steps = dmabo_cumu_r_arr.shape[1]\n",
    "dmabo_cumu_constr1_arr = np.cumsum(dmabo_constr1_arr, axis=1)\n",
    "\n",
    "pen_regret_arr = np.array(pen_regret_list)\n",
    "pen_constr1_arr = np.array(pen_constr_1_list)\n",
    "pen_cumu_r_arr = np.cumsum(pen_regret_arr, axis=1)\n",
    "pen_cumu_constr1_arr = np.cumsum(pen_constr1_arr, axis=1)\n",
    "\n",
    "dmabo_avg_r_arr = dmabo_cumu_r_arr / (np.arange(num_steps) + 1)\n",
    "pen_avg_r_arr = pen_cumu_r_arr / (np.arange(num_steps) + 1)\n",
    "\n",
    "dmabo_avg_constr1_arr = np.abs(dmabo_cumu_constr1_arr) / (np.arange(num_steps) + 1)\n",
    "pen_avg_constr1_arr = np.abs(pen_cumu_constr1_arr) / (np.arange(num_steps) + 1)\n",
    "\n",
    "\n",
    "pen_regret_arr_10 = np.array(pen_regret_list_10)\n",
    "pen_constr1_arr_10 = np.array(pen_constr_1_list_10)\n",
    "pen_cumu_r_arr_10 = np.cumsum(pen_regret_arr_10, axis=1)\n",
    "pen_cumu_constr1_arr_10 = np.cumsum(pen_constr1_arr_10, axis=1)\n",
    "pen_avg_r_arr_10 = pen_cumu_r_arr_10 / (np.arange(num_steps) + 1)\n",
    "pen_avg_constr1_arr_10 = np.abs(pen_cumu_constr1_arr_10) / (np.arange(num_steps) + 1)\n",
    "\n",
    "\n",
    "pen_regret_arr_N = np.array(pen_regret_list_N)\n",
    "pen_constr1_arr_N = np.array(pen_constr_1_list_N)\n",
    "pen_cumu_r_arr_N = np.cumsum(pen_regret_arr_N, axis=1)\n",
    "pen_cumu_constr1_arr_N = np.cumsum(pen_constr1_arr_N, axis=1)\n",
    "pen_avg_r_arr_N = pen_cumu_r_arr_N / (np.arange(num_steps) + 1)\n",
    "pen_avg_constr1_arr_N = np.abs(pen_cumu_constr1_arr_N) / (np.arange(num_steps) + 1)\n",
    "\n",
    "\n",
    "dmabo_regret_arr_N = np.array(dmabo_regret_list_N)\n",
    "dmabo_constr1_arr_N = np.array(dmabo_constr_1_list_N)\n",
    "dmabo_cumu_r_arr_N = np.cumsum(dmabo_regret_arr_N, axis=1)\n",
    "num_steps_N = dmabo_cumu_r_arr_N.shape[1]\n",
    "dmabo_cumu_constr1_arr_N = np.cumsum(dmabo_constr1_arr_N, axis=1)\n",
    "dmabo_avg_r_arr_N = dmabo_cumu_r_arr_N / (np.arange(num_steps) + 1)\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.2\n",
    "    dmabo_line, _ = plot_with_shade_area(ax, step_arr, -np.mean(dmabo_avg_r_arr, axis=0), BETA1*np.std(dmabo_avg_r_arr, axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[3], marker=marksCur[3], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    pen_line, _ = plot_with_shade_area(ax, step_arr, -np.mean(pen_avg_r_arr, axis=0), BETA1*np.std(pen_avg_r_arr, axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[1], marker=marksCur[1], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    pen_line_2, _ = plot_with_shade_area(ax, step_arr, -np.mean(pen_avg_r_arr_10, axis=0), BETA1*np.std(pen_avg_r_arr_10, axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[2], marker=marksCur[2], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    pen_line_3, _ = plot_with_shade_area(ax, step_arr, -np.mean(pen_avg_r_arr_N, axis=0), BETA1*np.std(pen_avg_r_arr_N, axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[4], marker=marksCur[4], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    dmabo_line_N, _ = plot_with_shade_area(ax, step_arr, -np.mean(dmabo_avg_r_arr_N, axis=0), BETA1*np.std(dmabo_avg_r_arr_N, axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[5], marker=marksCur[5], 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('Average Utility', fontsize=LABELSIZE, color=my_color)  \n",
    "    plt.xlim((0, total_steps))\n",
    "    #plt.legend([dmabo_line, pen_line], ['DMABO', 'Penalty Heuristics'], fontsize=LABELSIZE)\n",
    "\n",
    "    #ax.legend(['CEI', 'Safe BO', 'Primal-Dual', 'LCB2'])\n",
    "    \n",
    "    ax = axes[1]\n",
    "    BETA1 = 1\n",
    "    dmabo_line, _ = plot_with_shade_area(ax, step_arr, np.mean(np.abs(dmabo_cumu_constr1_arr), axis=0), BETA1*np.std(np.abs(dmabo_cumu_constr1_arr), axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[3], marker=marksCur[3], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    pen_line, _ = plot_with_shade_area(ax, step_arr, np.mean(np.abs(pen_cumu_constr1_arr), axis=0), BETA1*np.std(np.abs(pen_cumu_constr1_arr), axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[1], marker=marksCur[1], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    pen_line_2, _ = plot_with_shade_area(ax, step_arr, np.mean(np.abs(pen_cumu_constr1_arr_10), axis=0), BETA1*np.std(np.abs(pen_cumu_constr1_arr_10), axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[2], marker=marksCur[2], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    pen_line_3, _ = plot_with_shade_area(ax, step_arr, np.mean(np.abs(pen_cumu_constr1_arr_N), axis=0), BETA1*np.std(np.abs(pen_cumu_constr1_arr_N), axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[4], marker=marksCur[4], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    dmabo_line_N, _ = plot_with_shade_area(ax, step_arr, np.mean(np.abs(dmabo_cumu_constr1_arr_N), axis=0), BETA1*np.std(np.abs(dmabo_cumu_constr1_arr_N), 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 Power Deviation', fontsize=LABELSIZE, color=my_color)  \n",
    "    plt.xlim((0, total_steps))\n",
    "    plt.legend([dmabo_line, pen_line, pen_line_2], ['DMABO', 'Penalty Heuristics-5', 'Penalty Heuristics-20'], fontsize=LABELSIZE, loc='lower right', bbox_to_anchor=(0.8, -0.5), ncol=3)\n",
    "\n",
    "    \n",
    "   \n",
    "    \n",
    "    \n",
    "\n",
    "    import tikzplotlib\n",
    "    tikzplotlib.clean_figure()\n",
    "    tikzplotlib.save('./figs/pa_avg_util_cumu_vio.tex')\n",
    "    plt.savefig('./figs/pa_avg_util_cumu_vio.pdf', format='pdf', bbox_inches='tight')\n",
    "    \n",
    "    plt.show()  \n",
    "   \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c8a50e81",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "899be2ec",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.08406303234499439\n",
      "0.05796276623847344\n"
     ]
    }
   ],
   "source": [
    "dmabo_util = -np.mean(dmabo_avg_r_arr, axis=0)\n",
    "pen_util = -np.mean(pen_avg_r_arr, axis=0)\n",
    "obj_avg_u = -np.mean(obj_avg_list)\n",
    "print((dmabo_util[-1]-pen_util[-1])/pen_util[-1])\n",
    "print((dmabo_util[-1]-obj_avg_u)/obj_avg_u)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "5f3bc268",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.6265800466091747"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dmabo_util[-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "cddf2d8a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.780926379212956\n",
      "0.7654233870967755\n"
     ]
    }
   ],
   "source": [
    "dmabo_vio = np.mean(np.abs(dmabo_cumu_constr1_arr), axis=0)\n",
    "pen_vio = np.mean(np.abs(pen_cumu_constr1_arr), axis=0)\n",
    "pen_vio_2 = np.mean(np.abs(pen_cumu_constr1_arr_10), axis=0)\n",
    "print((pen_vio[-1]-dmabo_vio[-1])/pen_vio[-1])\n",
    "print((pen_vio_2[-1]-dmabo_vio[-1])/pen_vio_2[-1])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "5dc40765",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\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_error_bar(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",
    "    \n",
    "    ax.grid(axis='y', linestyle='--')\n",
    "\n",
    "    # discomfort_thr_arr = [5] * 75 + [10] * 75 + [15] * 75 + [20] * 75   \n",
    "    \n",
    "    ax.bar(x, y, tick_label=['Average', 'Penalty', 'DMABO'], yerr=yerr)\n",
    "    for k in range(4):\n",
    "        #plt.text(k-x_gap, avg_d_list[k]+std_d_list[k]*0.55+y_gap, f'{truncate(avg_d_list[k], 1)}')\n",
    "        pass\n",
    "    #ax.set_title(f'Average Discomfort', fontsize=LABELSIZE)\n",
    "\n",
    "    #plt.savefig(f'./fig/discomfort_constrained_e_{discomfort}.pdf', format='pdf', bbox_inches='tight')\n",
    "    #plt.show()  \n",
    "    #plt.xlabel('Period', fontsize=LABELSIZE)\n",
    "    #plt.ylabel('Kh', fontsize=LABELSIZE)\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_cumu_r_arr = np.cumsum(dmabo_regret_arr, axis=1)\n",
    "num_steps = dmabo_cumu_r_arr.shape[1]\n",
    "dmabo_cumu_constr1_arr = np.cumsum(dmabo_constr1_arr, axis=1)\n",
    "\n",
    "pen_regret_arr = np.array(pen_regret_list)\n",
    "pen_constr1_arr = np.array(pen_constr_1_list)\n",
    "pen_cumu_r_arr = np.cumsum(pen_regret_arr, axis=1)\n",
    "pen_cumu_constr1_arr = np.cumsum(pen_constr1_arr, axis=1)\n",
    "\n",
    "dmabo_avg_r_arr = dmabo_cumu_r_arr / (np.arange(num_steps) + 1)\n",
    "pen_avg_r_arr = pen_cumu_r_arr / (np.arange(num_steps) + 1)\n",
    "\n",
    "dmabo_avg_constr1_arr = dmabo_cumu_constr1_arr / (np.arange(num_steps) + 1)\n",
    "pen_avg_constr1_arr = pen_cumu_constr1_arr / (np.arange(num_steps) + 1)\n",
    "\n",
    "dmabo_util = -np.mean(dmabo_avg_r_arr[:,-1])\n",
    "dmabo_util_std = np.std(dmabo_avg_r_arr[:,-1])\n",
    "\n",
    "pen_util = -np.mean(pen_avg_r_arr[:, -1])\n",
    "pen_util_std = np.std(pen_avg_r_arr[:, -1])\n",
    "\n",
    "avg_sol_util = -np.mean(obj_avg_list)\n",
    "avg_sol_util_std = np.std(obj_avg_list)\n",
    "\n",
    "dmabo_dev = np.mean(np.abs(dmabo_avg_constr1_arr[:, -1]))\n",
    "dmabo_dev_std = np.std(np.abs(dmabo_avg_constr1_arr[:, -1]))\n",
    "\n",
    "pen_dev = np.mean(np.abs(pen_avg_constr1_arr[:, -1]))\n",
    "pen_dev_std = np.std(np.abs(pen_avg_constr1_arr[:, -1]))\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",
    "    \n",
    "    scale = 1.0\n",
    "    fig.set_size_inches(WIDTH * scale , HEIGHT * scale)\n",
    "    fig.subplots_adjust(left=.22, bottom=.20, right=.99, top=.97, hspace=0.5, wspace=0.4) \n",
    "    \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",
    "    \n",
    "    plot_with_error_bar(ax, [0, 1, 2], [avg_sol_util, pen_util, dmabo_util], [avg_sol_util_std, pen_util_std, dmabo_util_std])\n",
    "    ax.set_ylim((0.4, 0.8))\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",
    "   \n",
    "    #plt.xlim((0, total_steps))\n",
    "    #plt.legend([dmabo_line, pen_line], ['DMABO', 'Penalty Heuristics'], fontsize=LABELSIZE)\n",
    "\n",
    "    #ax.legend(['CEI', 'Safe BO', 'Primal-Dual', 'LCB2'])\n",
    "    \n",
    "    ax = axes[1]\n",
    "    BETA1 = 3\n",
    "    plot_with_error_bar(ax, [0, 1, 2], [0, pen_dev, dmabo_dev], [0, pen_dev_std, dmabo_dev_std])\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('Average Constraint Value', fontsize=LABELSIZE, color=my_color)  \n",
    "    #plt.xlim((0, total_steps))\n",
    "    #plt.legend([dmabo_line, pen_line], ['DMABO', 'Penalty Heuristics'], fontsize=LABELSIZE, loc='lower right', bbox_to_anchor=(0.27, -0.5), ncol=2)\n",
    "\n",
    "    \n",
    "    \n",
    "\n",
    "    import tikzplotlib\n",
    "    tikzplotlib.clean_figure()\n",
    "    tikzplotlib.save('./figs/pa_avg_util.tex')\n",
    "    plt.savefig('./figs/pa_avg_util.pdf', format='pdf', bbox_inches='tight')\n",
    "    \n",
    "    plt.show()  \n",
    "   \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "d782d566",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0723879799481538"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dmabo_util = -np.mean(dmabo_avg_r_arr, axis=0)[-1]\n",
    "pen_util = -np.mean(pen_avg_r_arr, axis=0)[-1]\n",
    "(dmabo_util-pen_util)/pen_util"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "465efb77",
   "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",
    "\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",
    "\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 = 3\n",
    "    dmabo_line, _ = plot_with_shade_area(ax, step_arr, np.mean(dmabo_avg_constr1_arr, axis=0), BETA1*np.std(dmabo_avg_constr1_arr, axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[3], marker=marksCur[3], markerfacecolor='None', markersize=MARKERSIZE)\n",
    "    \n",
    "    pen_line, _ = plot_with_shade_area(ax, step_arr, np.mean(pen_avg_constr1_arr, axis=0), BETA1*np.std(pen_avg_constr1_arr, axis=0),\n",
    "                         linewidth=LINEWIDTH, color=colors[1], marker=marksCur[1], 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('Average Constraint Value', fontsize=LABELSIZE, color=my_color)  \n",
    "    plt.xlim((0, total_steps))\n",
    "    plt.legend([dmabo_line, pen_line], ['DMABO', 'Penalty Heuristics'], 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_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": "09045cce",
   "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": null,
   "id": "b1fc1c41",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "771add14",
   "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": "da9184d4",
   "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
}
