{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c3149d24",
   "metadata": {},
   "outputs": [],
   "source": [
    "# imports\n",
    "import sys\n",
    "import numpy as np\n",
    "sys.path.append('../..')\n",
    "from env.gridworld import Gridworld\n",
    "from examples.safe_PCE import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "21e32374",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Generate samples\n",
    "N = 5000000\n",
    "samples = truncated_gaussian(size=N)\n",
    "\n",
    "# Plot the histogram with smoothing\n",
    "from scipy.ndimage import gaussian_filter1d\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.figure(figsize=(10, 5))\n",
    "\n",
    "# # Create histogram data\n",
    "# The `density=True` argument normalizes the histogram so the area sums to 1.\n",
    "counts, bins, _ = plt.hist(samples, bins=500, density=True, edgecolor='black', alpha=0.3)\n",
    "\n",
    "# Smooth the histogram counts\n",
    "sigma = 3  # Adjust for more/less smoothing\n",
    "smoothed_counts = gaussian_filter1d(counts, sigma)\n",
    "\n",
    "# Plot smoothed curve in same color as histogram\n",
    "bin_centers = (bins[:-1] + bins[1:]) / 2\n",
    "plt.plot(bin_centers, smoothed_counts, 'C0-', linewidth=2, label='Noise Distribution')\n",
    "\n",
    "plt.xlabel(\"noise\", fontsize=12)\n",
    "plt.ylabel(\"Density\", fontsize=12)\n",
    "plt.title(\"Truncated Gaussian Noise Distribution (mean=0.3, std=0.03)\", fontsize=14)\n",
    "plt.legend()\n",
    "plt.grid(alpha=0.3)\n",
    "plt.savefig(\"truncated_gaussian_histogram.png\", format='png', dpi=1200)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "ec4a1eb5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABHQAAAHqCAYAAABlWBkiAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAAC6HklEQVR4nOzdd3gU1foH8O9sS+8FQgsdpCMgVelFpSmCSrnXjnqxoP5Er4ACVsR2VcQCilJFOkgRCEgJShOkSA9CaAkQQvqW9/dH3CWbAptk6+T7eZ4897Jl5sw5O+e8vnPmjCIiAiIiIiIiIiIi8hkaTxeAiIiIiIiIiIhKhwkdIiIiIiIiIiIfw4QOEREREREREZGPYUKHiIiIiIiIiMjHMKFDRERERERERORjmNAhIiIiIiIiIvIxTOgQEREREREREfkYJnSIiIiIiIiIiHwMEzpERERERERERD6GCR0X+u6776AoCvz9/XHq1Kki73fp0gVNmjQp07a7dOmCLl26lLOEzjNv3jy0aNEC/v7+qFKlCp5//nlkZGQ49N2PP/4Y9957L2rVqgVFUdxyXA899BBq1qxp99rbb7+NJUuWFPmstR137tzp8nI5aurUqfjuu++KvJ6UlARFUYp9zx1q1qyJhx56yO379eT5ULNmTSiKUuTvySefLPLZ33//Hb1790ZISAiCg4PRtWtXbN261aH9dOnSpdj9WP/Onz9f7Peys7NRv359KIqCKVOmlOtYiYjIuzH2vHnsmZmZiQceeAANGjRASEgIgoKC0LhxY7z55pvIzMx0WXkZe7oGY8+SY89r167h5ZdfRq9evRATEwNFUfDGG2+Ual9r1qxBx44dERAQgLCwMPTr1w8HDhwo9rOZmZkYP3486tevDz8/P0RFRaFr1644evRoWQ+VHKDzdAEqgtzcXIwdOxY//PCD07Y5depUp22rvGbPno3hw4fjsccew0cffYQjR45gzJgxOHjwINauXXvT70+bNg1BQUHo1q0bli9f7oYSA+PGjcNzzz1n99rbb7+N++67DwMHDnRLGcpj6tSpiI6OLjKAxcXFITExEXXq1PFMwSqojh07FkmWVKpUye7fO3bswB133IHbbrsNP/zwA0QEkydPRvfu3ZGQkID27dvfcB9Tp05Fenq63WtZWVno06cPWrVqhcqVKxf7vXHjxrk0QCUiIu/D2LNkRqMRIoIXXngBtWrVgkajwa+//oqJEydi48aNWLdunUvKzNiTnMmR2PPSpUv46quv0Lx5cwwcOBDffPNNqfaxdOlS3HPPPRgwYAAWLlyIq1evYsKECbj99tuxY8cOuzbPyMhA165dcfbsWbzyyito1qwZrl69im3btiErK6vsB0o3xYSOG/Tp0wdz5szBSy+9hObNmztlm40aNXLKdsrLbDbj//7v/9CrVy98/fXXAICuXbsiJCQEw4YNw6pVq3DnnXfecBsHDx6ERpM/WaysV41KS62Djp+fH9q1a+fpYlQ44eHhN633cePGITw8HKtXr0ZgYCAAoEePHqhduzZeeumlm87UKe6cnzlzJoxGIx577LFiv/P777/j008/xezZszF48GAHj4aIiHwdY8+SY8/w8HDMnz/f7rUePXogNzcXkydPxokTJ1C7dm2nl5uxJzmTI7FnfHw8rly5AkVRkJqaWuqEzpgxY9C0aVMsWrQIiqIAADp06ID69etj/PjxmD17tu2zY8eOxaFDh7Bv3z6786d///6l2ieVHm+5coOXX34ZUVFRGDNmzE0/m5OTg1dffRW1atWCwWBA1apV8Z///AdpaWl2nytumt8XX3yB5s2bIzg4GCEhIWjYsCH++9//2n3m/PnzGDlyJKpVqwaDwYBatWphwoQJMJlMZTq27du349y5c3j44YftXh88eDCCg4OxePHim27DmswprfT0dOh0Orz//vu211JTU6HRaBAWFmZ3TM8++yxiYmIgIgCKTntVFAWZmZmYOXOmbdpi4fq9du0annrqKURHRyMqKgr33nsvzp4961BZly1bhvbt2yMwMBAhISHo2bMnEhMT7T7zxhtvQFEU7NmzB/feey9CQ0MRFhaG4cOHIyUlxfa5mjVr4sCBA9i0aZOtrNZjKW7aq3W7+/btw+DBgxEWFobIyEi88MILMJlMOHz4MPr06YOQkBDUrFkTkydPtitXTk4OXnzxRbRo0cL23fbt22Pp0qUOHXthLVu2xO23317kdbPZjKpVq+Lee++1vTZhwgS0bdsWkZGRCA0Nxa233orp06fb2rEkGzduhKIo2Lhxo93rJU0L3rlzJ/r374/IyEj4+/ujZcuW+PHHH8t0fCXZunUrunTpYkvmAEBISAjuuOMObNu2DefOnSv1NqdPn47g4GDcf//9Rd7Ly8vDI488gv/85z9o3bp1ucpORES+hbFn6cXExAAAdLqSr3cz9mTsWRJvjD2tbVUWly5dwuHDh3HnnXfabSM+Ph5NmjTBkiVLYDabAeTPGP/mm28wePBglyRD6caY0HGDkJAQjB07FmvWrMGGDRtK/JyIYODAgZgyZQpGjBiBlStX4oUXXsDMmTPRrVs35ObmlvjdefPm4emnn0bnzp2xePFiLFmyBKNHj7a71eL8+fO47bbbsGbNGowfPx6rVq3Co48+infeeQePP/643fYeeughKIqCpKSkGx7b/v37AQDNmjWze12v16Nhw4a2910hNDQUbdq0sZsau379evj5+eHatWv4/fffba+vW7cO3bp1K7FTS0xMREBAAO666y4kJiYiMTGxyNTixx57DHq9HnPmzMHkyZOxceNGDB8+/KblnDNnDgYMGIDQ0FDMnTsX06dPx5UrV9ClSxds2bKlyOfvuece1K1bFz/99BPeeOMNLFmyBL1794bRaAQALF68GLVr10bLli1tZXUkeBkyZAiaN2+OhQsX4vHHH8dHH32E0aNHY+DAgbj77ruxePFidOvWDWPGjMGiRYts38vNzcXly5fx0ksvYcmSJZg7dy46deqEe++9F99///1N91vYww8/jC1bthS5n3bt2rU4e/asXYCWlJSEkSNH4scff8SiRYtw77334plnnsGkSZNKvd+SJCQkoGPHjkhLS8O0adOwdOlStGjRAvfff7/D94P/+uuvCAkJgV6vR6NGjfDBBx/YBjmrvLw8+Pn5Ffmu9bU///yzVOU+evQoNm/ejAceeADBwcFF3p84cSIyMzOdWldEROQbGHvenIjAZDIhPT0dq1evxgcffIAHH3wQNWrUKPE7jD0ZezqDu2LP8sjLywOAEmPXrKwsHD9+HACwa9cuZGZmol69enjqqacQEREBg8GA1q1bY+XKlU4rE5VAyGW+/fZbASA7duyQ3NxcqV27trRu3VosFouIiHTu3FkaN25s+/zq1asFgEyePNluO/PnzxcA8tVXX9le69y5s3Tu3Nn271GjRkl4ePgNyzNy5EgJDg6WU6dO2b0+ZcoUASAHDhywvfbII4+IVquVpKSkG27zrbfeEgBy7ty5Iu/16tVL6tevf8PvF9a4cWO747qZsWPHSkBAgOTk5IiIyGOPPSZ9+vSRZs2ayYQJE0REJDk5uUj9/fvf/5b4+Hi7bQUFBcm///3vIvuwtuPTTz9t9/rkyZNLPHYrs9ksVapUkaZNm4rZbLa9fu3aNYmNjZUOHTrYXnv99dcFgIwePdpuG7NnzxYAMmvWLNtrJdXTyZMnBYB8++23Rbb7wQcf2H22RYsWAkAWLVpke81oNEpMTIzce++9JR6TyWQSo9Eojz76qLRs2dLuvfj4+GLrsKDU1FQxGAzy3//+1+71IUOGSKVKlcRoNBb7PbPZLEajUSZOnChRUVG280ik6PmQkJAgACQhIcFuG8XVT8OGDaVly5ZF9tu3b1+Ji4uza7fiPP300zJjxgzZtGmTLFmyRIYNGyYAZPjw4Xafa9GihdSvX99ue0ajUWrXri0AZM6cOTfcT2FjxowRAJKYmFjkvT179oher5fVq1fbHff7779fqn0QEZFvYezpeOw5d+5cAWD7e/jhh0uMQQpi7GmPsWc+b4w9C0pJSREA8vrrr99w21Zms1kiIyOle/fudq9fuXJFQkJCBIBs27ZNRK6fS6GhodKxY0dZtmyZrFixQrp27SqKotjiUXINztBxE4PBgDfffBM7d+4scTqd9QpK4cXGBg8ejKCgIKxfv77E7d92221IS0vDgw8+iKVLlyI1NbXIZ1asWIGuXbuiSpUqMJlMtj/rfcabNm2yfXb69OkwmUyIj4936PhKuvpQ1ml+jurevTuys7Oxbds2APlXQ3r27IkePXrgl19+sb0G5N8fXR6F7wG1Xhkq7ikSVocPH8bZs2cxYsQIu1vLgoODMWjQIGzfvr3IQmHDhg2z+/eQIUOg0+mQkJBQrvL37dvX7t+33HILFEWxu89cp9Ohbt26RY5pwYIF6NixI4KDg6HT6aDX6zF9+nQcOnSo1OWIiopCv379MHPmTFgsFgDAlStXsHTpUvzrX/+ym+q8YcMG9OjRA2FhYdBqtdDr9Rg/fjwuXbqEixcvlnrfhR07dgx//fWXrc4Lnhd33XUXzp07h8OHD99wG59//jkefvhh3HHHHRgwYABmzZqFUaNGYdasWdizZ4/tc8888wyOHDmCUaNGITk5GadPn8aTTz5pq+vS3HpoMpkwc+ZMNG7cuMj90yaTCY888gjuv/9+9O7d2+FtEhGRujD2vLHevXtjx44d2LBhA9566y0sXLgQgwYNssUmJWHs6TjGnkW5M/YsD41Gg//85z9Yv349Jk2ahIsXL+LYsWMYPny47fdj/X1Z69RgMGDVqlXo168f7r77bqxYsQJxcXGcLe5iTOi40QMPPIBbb70Vr732mm0KY0GXLl2CTqez3cNrpSgKKleujEuXLpW47REjRmDGjBk4deoUBg0ahNjYWLRt29Y2sADAhQsXsHz5cuj1eru/xo0bA0CxA/HNREVF2cpe2OXLlxEZGVnqbZZGhw4dEBgYiHXr1uHYsWNISkqyDaq//fYbMjIysG7dOtSuXRu1atUq176sx2plnYKYnZ1d4nes9RIXF1fkvSpVqsBiseDKlSt2rxd+WpFOp0NUVNQN298RhdvCYDAgMDAQ/v7+RV7Pycmx/XvRokUYMmQIqlatilmzZiExMRE7duzAI488Yve50njkkUeQnJxs+33OnTsXubm5dgHl77//jl69egEAvv76a2zduhU7duzAa6+9BuDG9e6oCxcuAABeeumlIufF008/DaBs54V1OvT27dttrz3yyCN499138cMPP6BatWqoUaMGDh48iJdeegkAULVqVYe3//PPP+P8+fPFLob88ccf48SJE3j99deRlpaGtLQ029OxcnJykJaW5tQpuURE5L0Ye5YsIiICrVu3RteuXfHf//4XX331FZYtW3bTdVoYezqOsWdR7ow9y2v8+PEYPXo03nzzTVSqVAn16tUDANstatbY1fo77dChA0JCQmzfDwwMROfOnbF7926nlYmK4lOu3EhRFLz33nvo2bMnvvrqqyLvR0VFwWQyISUlxW5gFRGcP38ebdq0ueH2H374YTz88MPIzMzEr7/+itdffx19+/bFkSNHEB8fj+joaDRr1gxvvfVWsd+vUqVKqY+padOmAPLX/yj49AOTyYS//voLDz74YKm3WRoGgwGdOnXCunXrUK1aNVSuXBlNmza1Lci1ceNGrF+/vsgVAnexdnDFLXh79uxZaDQaRERE2L1+/vx5u/+4N5lMuHTpUpFB3V1mzZqFWrVqYf78+XZXvW50X/3N9O7dG1WqVMG3336L3r1749tvv0Xbtm3tfkPz5s2DXq/HihUr7Ab+JUuW3HT71s8XLmPhATI6OhoA8Oqrr9otiFdQgwYNHDqmguSfhfMKz7oZM2YMnn/+eRw9ehQhISGIj4/HyJEjERQUhFatWjm8/enTp8NgMGDEiBFF3tu/fz+uXr1qG3QLGjdu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bdu2EhoaKn5+ftKkSROZMmWK5OXlFVu2zZs3S+fOnSUwMFACAwOlW7duRX5z5HyKSIG5eETkMW+88QYmTJiAlJQU2/21RERERESuwNiTyPdxDR0iIiIiIiIiIh/DhA4RERERERERkY/hLVdERERERERERD6GM3SIiIiIiIiIiHwMEzpERERERERERD6GCR0iIiIiIiIiIh/DhA4RERERERERkY9hQoeIiIiIiIiIyMcwoUNERERERERE5GOY0CEiIiIiIiIi8jFM6BARERERERER+RgmdIiIiIiIiIiIfAwTOkREREREREREPoYJHSIiIiIiIiIiH8OEDhERERERERGRj2FCh4iIiIiIiIjIxzChQ0RERERERETkY5jQISIiIiIiIiLyMUzoEBERERERERH5GCZ0iIiIiIiIiIh8DBM6REREREREREQ+hgkdIiIiIiIiIiIfw4QOEREREREREZGPYUKHiIiIiIiIiMjHMKFDRERERERERORjmNAhIiIiIiIiIvIxTOgQEREREREREfkYJnSIiIiIiIiIiHwMEzpERERERERERD6GCR0iIiIiIiIiIh/DhA4RERERERERkY9hQoeIiIiIiIiIyMcwoUNERERERERE5GOY0CEiIiIiIiIi8jFM6BARERERERER+Ridpwvg7UTE7t+KonioJOSI8rRXRWprXznWguX0xjL6Sj0SEZHv4NjiWxh7OsZXjpWxJ/kan0no5OXlISMjAwCg0+kQEhJS7A/YYrHg6tWrAIDQ0FBotdpy7ddiseCdd97BsWPHMGbMGNxyyy3l2p4niAjMZjPOnTuHlJQUGAwGVKlSBREREWXuBKydidlsRmZmJsxmM/R6PYKDgz3asRiNRkyYMAHnz5/HuHHjULNmTYe/m5eXZ/fdWrVqua6gHrZ06VIsWrQIffv2xeDBgz1dnGKJCBYsWIAVK1bgnnvuwcCBA71u0Lp69Spee+01KIqCN998E+Hh4Z4uUrFMJhPS09Nv+Bl/f38EBgYW+56IIDs7G8nJyUhPT0dgYCCqVatWpvPdYrEgPT0dFovlpp/18/NDUFDQDT8jIsjJyYHJZAIABAYGlrvfJyICGHuWh7NjTxGByWTC1atXcenSJWRkZECn0yE6OhqxsbHQ6XQeixEYezqGsadzVKTYEwBycnKQnZ0NAAgODobBYChzmUQEFosF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AJBXXnnFLgO/evVqOXz4sOTm5trV5+7du+WWW24RvV4vS5YssdtmSVdJUlNTpWrVqhIeHi5JSUlFymk2m+Wee+4RADJ37twivxe9Xi/16tWTzZs3S15enlgsFjGZTLJjxw6pV6+e+Pn5ydKlSx2+UmK9SqLVasXPz08URRFFUSQgIEBatWol8+bNK3KlLjc3Vzp06CAA5O233y6yL4vFIitXrhSNRiMAZNasWQ6VpSTp6enSokWLEtvOKiMjQ3r37i1hYWGydetWsVgscv78ec7QISKnY+zpfbFnamqqbNu2TbZu3SqrV6+WcePGSaVKlSQ8PFxmzpzp8LjI2JOxJ2NP+9+LN8SexXHGDB3rb6xGjRpy6dKlIu/n5ORI27ZtBYC0atXKNqus4Gz1KVOmyHPPPSeRkZGi0WhEURTx9/eX1q1by4oVKxyeyegKZbsh0wu0bNkSgwcPxuXLl/Hhhx/CbDbf8PPnzp3D3Llzodfr8c4776BJkybQaDRQFAVhYWEYP348mjVrhpMnT2LJkiU3XcDs3LlzMBqNaN68OWrVqmXblqIo8PPzQ6NGjeye0LJ3714sXboU1atXxyeffILq1avbvuPn54cRI0bgnnvuwalTp7By5Uq7/depUwcDBgywZasdYTabce3aNQD59/YVlzXUarW2THZaWppD23UFf39/dOzY0ZaZl3/uJ/3zzz+RkpKC+++/H7Vr18b27dttVz5ycnKwdetWGAwGdOrU6YZZUetVEutVAus9rta/4u6hHT58OIYMGQI/Pz/b9++++260bt0aly9fxh9//OHQseXk5OCrr76C2WzGiy++iB49etiu2Pj7++Pxxx9H//79kZ6ejhkzZhT7u6tbty4mTJhgmyWh0WjQvHlzTJgwARqNBjNnzkR6erqtnNbfiPXf1uMs6f7i4oSEhOC9995D1apVbb/TunXr4t5774XFYkFqaireffddVK5c2fa7b9CgAQYMGACTyWRrR6sqVaqgd+/eCA8PtztXwsLC8OKLL6JBgwbYuXMnTp065VD5SqLVajF06FBotVosWLCgyMyNixcvYvXq1QgKCsJ9991n916vXr1Qv359233l1vpr0aIFXnrpJZhMJixfvrxc5buZjIwM/O9//wMAvPfee+jYsaPtfmytVotWrVph3LhxMBqNmDFjRokLCxdmrevWrVtj8ODB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KyvLdsXHymw247vvvnN4oT9HKYqCfv36ISoqChs3bsSiRYuwf/9+1KlTxxZsFmS9CnL27NkiK98nJydj5syZpdp/YGAgqlevjuzsbPz+++9FtpmQkGBbTb+g2rVro0OHDrh8+TI++eSTEqczWywWh69oWCwWpKWlFftZi8WCn3/+GevXr4dWq0WPHj3s3rcucFlcMLhx40Z888038Pf3x6hRo+z+Q8QaiMydOxcbNmy4YSA7b948ZGdno23btmjUqFGJn+vWrRt++OGHYv8+++wzhIaGQqfTYfz48fjhhx/w4IMP3rRuiIjKirFnUa6KPXNycnDt2rUSy//bb78hISEBGo0G7dq1c6isVow9GXs6C2NP+8+WNfYsq5vFniXFs+np6Rg3bhxSU1PRo0cP2614AGz9aKVKlXDo0CFs3769SL2uWrUK58+fR2xsrMcuJvr0LVdWiqLgX//6F6ZPn46DBw8CuH5PslVoaCheeOEFjBw5Em+99RaCgoIwcOBA+Pv749ChQ3jppZdw7tw59OrVCz169Lhp9nH+/PlYv349Bg8ejGbNmiEsLAwigr///huTJk1CTk4O2rVrZ8t616pVCy+99BJee+01PPXUUzh9+rTt0W3WznX37t348ccf8cwzz9iygQCwatUqvPDCC7jlllvQpUsXh6/gxMXF4emnn8bYsWMxZswYBAcHo3379sjOzsZXX32FJUuWIDY2Fs8++2yR4/36668xffp09O3bt8iTGa5evYpZs2bZTnjrEwH+/vtvfPLJJ7Ypjb169ULjxo0dKisAxMTEoGnTpli7di3S09MxaNAg20CoKApuvfVWRERE4K+//rI9naA0WeI2bdpAo9Fg1qxZqFmzJqpXrw5FUVC9enWHF9ArLa1WixdeeAEbNmzA7NmzUblyZYwcORJhYWFITk7GhAkTsHPnTjRo0AAPPfRQsceTk5ODxx9/HB999BFuueUW5OTkYNGiRZgyZQr8/Pzw3HPP2U2PrF+/PsLDw7Fnzx68//77aNOmDXQ6HYKDg+2mEbpLdHQ0mjRpgk2bNuG///0v3nzzTcTFxeHq1auYN28e3n//fQQFBTllUbqCatasic6dO2PRokV47bXXkJubi4EDBxZ7S4/1EY3z589Hp06d0KtXL2i1Whw6dAhjx47FhQsXSvVbswbnv/76K9555x3Url0bzZo1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iy7Ss88+q9LSUi+nljBjjGpra5WVlSXHcWSM0aOPPqrJkydr8eLFysvL83qKCTPG6OOPP9att96qjh07Ki8vT88880ygCoOHHnpIS5Ys0QsvvNA471AoFKjPsH//fg0ZMkSXX365brvtNmVmZioej8sYE5ifvB26BUSjUY0cOVKnn366/vznPwcqHgCAetSe/kDt6S/Unv5A7ZlcPEMnBbp06aKePXsqJyfH66m0WnFxsYqLi+U4jhzHUefOnZWdna3q6mqvp5Ywx3GUnZ2tUOjgt70xRh06dFBGRoaHM2u5yspK3XvvvbrpppvUtWtXr6fTavv379eHH36olStXqqqqyuvptNjy5ctVVlam0aNHa/ny5froo49UVVUVqO+nhmu64X+ff/65VqxYoauvvtrrqQEAWona0x+oPf2H2tN71J7JFYw2HnwlHo/rhRdeUH5+vgYOHOj1dFps9erVmjx5srZt26avvvpKf/3rXwN1DDkej+vJJ59U586dNXz4cM2ZM8frKbVKOBzWhg0b9Nvf/lY7duxQp06dNGnSJA0YMCAwnfk1a9bIGKMbb7xRxhjt3btX+fn5euqpp9SnT5/AfI4Gxhj985//1CmnnKL+/fsHbv4AADtRe3qL2tM/qD1xKE7ooEWMMXrttdf06KOP6uGHH1aXLl28nlKL5efnq1+/fjr55JNVV1enhQsXKh6Pez2thBhjtGrVKk2bNk133XWXsrKyvJ5Sq11zzTVavHix5syZowULFuj444/Xb37zG9XU1Hg9tYRVV1dr69atGjFihGbOnKk333xTOTk5evDBB791nDQIKioq9Morr2jMmDEKh8NeTwcAAGpPj1F7+gu1Jw7FCR0kzBijN954Q3fccYcefPBBlZaWBrKLevzxx+vnP/+5jDEaNGiQrrvuOl111VXq2bOn11M7JmOMJk6cqKKiIs2cOVOStGrVKlVXV+uZZ57R1VdfHZif+DS9l7+kpETXX3+9xowZo927d6t79+4ezixxRUVFKigo0GWXXaZwOKysrCyNGDFCkydPVm1tbaCOuhtj9M477ygSiejSSy8N5LUNALALtaf3qD39hdoTh6Khg4QYYzRr1izdcsstGj9+vEaPHt3sfuAgaOhaN00WxcXFikajgbkf23EcnX322Vq5cqU+/fRTSdLu3btVW1urNWvWKBaLeTzDxBwuFhUVFcrMzAzMA90k6dRTT1U4HNaBAwcaP1MkElFOTk7gro9YLKbnnntOpaWl6tatm9fTAQCkOWpPf6D29BdqTxwqON+9AVZeXq4lS5Zo+fLlqq6u1pw5c1RSUqLzzz8/MB3tDz/8UD/72c80dOhQ5efna/bs2ZKk/v376/jjj/d4domJRqOaOnWqTj31VHXq1Ek7duzQn/70J/Xv3189evTwenoJGzduXLOvf/WrX2nfvn164IEHPJpRy9XV1WnatGk65ZRT1KlTJ3311Ve6//77NXToUHXs2NHr6SWsX79+OvfcczVx4kTdeeed2rlzp5577jldc801gTuSvGHDBr3//vt67rnn+AkJAAQctac/UHv6B7Wn/1B7JgcNnRT4+uuv9dhjjykej+vMM8/UlClT1LFjR33ve98LzKa6e/duDRgwQNu3b9djjz3W+PrNN98cmE3VcRytXr1akyZNUlVVlTIzMzVw4EBNnDhR7dq183p6CTk02Rlj1K9fv8an9AcpGS5btkwTJ05s/HWepaWluuOOOwL1lP5wOKxHHnlEd911l6688ko5jqMrrrhCv/zlLwMVC0natGmTrrjiCp199tmBmzsAoDlqT3+g9vQXak9/ofZMDscE8elJAWOM+daDz5r+qrYgONxnkKRQKBSoz2CMUU1Njaqrq5WVlaXc3NxAxeFQDZ9JUqA+R8O8q6urVVNTo3A4rNzcXEnBKgykg9dGJBJRRkaG8vLyAvcZJDV7kF4Q5w8AOIja0x+oPf2D2tN/qD2Tg4YOAAAAAABAwATryUkAAAAAAACgoQMAAAAAABA0NHQAAAAAAAAChoYOAAAAAABAwNDQAQAAAAAACBgaOgAAAAAAAAFDQwcAAAAAACBgaOgAAAAAAAAEDA0dAAAAAACAgKGhAwAAAAAAEDA0dAAAAAAAAAKGhg4AAAAAAEDA0NABAAAAAAAIGBo6AAAAAAAAAUNDBwAAAAAAIGBo6AAAAAAAAAQMDR0AAAAAAICAoaEDAAAAAAAQMDR0AAAAAAAAAoaGDgAAAAAAQMDQ0AEAAAAAAAgYGjoAAAAAAAABQ0MHAAAAAAAgYGjoAAAAAAAABAwNHQAAAAAAgIChoQMAAAAAABAwNHQAAAAAAAAChoYOAAAAAABAwNDQAQAAAAAACBgaOgAAAAAAAAFDQwcAAAAAACBgaOgAAAAAAAAEDA0dAAAAAACAgKGhAwAAAAAAEDA0dAAAAAAAAAKGhg4AAAAAAEDA0NABAAAAAAAIGBo6AAAAAAAAAUNDBwAAAAAAIGD+P557czUb0BzmAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1500x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from PIL import Image\n",
    "import visualization.gridworld_vis as gv\n",
    "policies = []\n",
    "noises = [0.1, 0.3]\n",
    "\n",
    "# Create a figure for plotting\n",
    "fig, axes = plt.subplots(1, len(noises), figsize=(15, 5))  # 2 subplots in one row\n",
    "\n",
    "for i, noise in enumerate(noises):\n",
    "    env = make_env(noise)\n",
    "    occ_measure, sol = env.lp_solve()\n",
    "    policy = env.occ2policy(occ_measure)\n",
    "    u = abs(sol.fun)\n",
    "\n",
    "    # Generate and save the figure for the current environment\n",
    "    constraint_patches = np.array([[[2,1],[1,4]], [[4,1],[1,4]]])\n",
    "    figure = gv.plot_gridworld(env, policy, f'Noise: {noises[i]} with optimal value {round(u,2)}', env.grid_width, env.grid_height, values=env.r[:,1], constraints=constraint_patches, logging=False)\n",
    "\n",
    "    figure_path = f\"gridworld_noise{noise}.png\"\n",
    "    figure.set_size_inches(5, 5)  # Set figure size\n",
    "    figure.savefig(figure_path, format='png', dpi=800)  # Increase dpi for higher resolution\n",
    "    plt.close(figure)  # Close the figure to free memory\n",
    "\n",
    "    # Display the figure in the subplot\n",
    "    axes[i].imshow(Image.open(figure_path))\n",
    "    axes[i].axis('off')  # Hide axes\n",
    "    axes[i].set_title(f'Noise: {noises[i]} with optimal value {round(u,2)}')\n",
    "\n",
    "plt.tight_layout()  # Adjust layout\n",
    "plt.savefig(\"twoplotsgridworld.png\", format='png', dpi=1200)\n",
    "plt.show()  # Show all plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6757a4d7",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('../..')\n",
    "import pickle\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.gridspec as gridspec\n",
    "import matplotlib.ticker as mticker\n",
    "from matplotlib.patches import Patch\n",
    "from matplotlib.lines import Line2D\n",
    "\n",
    "# Load the data from the pickle file\n",
    "with open(\"data/extracted_runs.pkl\", \"rb\") as f:\n",
    "    data = pickle.load(f)\n",
    "\n",
    "r_run_all = data[\"r_run_all\"]\n",
    "c_run_all = data[\"c_run_all\"]\n",
    "re_avg = np.mean(r_run_all, axis=0)\n",
    "re_max  = np.quantile(r_run_all, 0.9, axis=0)\n",
    "re_min = np.quantile(r_run_all, 0.1, axis=0)\n",
    "\n",
    "c_avg  = np.mean(c_run_all, axis=0)\n",
    "c_max  = np.quantile(c_run_all, 0.9, axis=0)\n",
    "c_min  = np.quantile(c_run_all, 0.1, axis=0)\n",
    "\n",
    "with open(\"data/r_c_history_log_barrier.pkl\", \"rb\") as f:\n",
    "    data = pickle.load(f)\n",
    "\n",
    "r_all_run_log_barrier = data[\"r_log\"]\n",
    "c_all_run_log_barrier = data[\"c_log\"]\n",
    "re_avg_log_barrier = np.mean(r_all_run_log_barrier, axis=0)\n",
    "re_max_log_barrier  = np.quantile(r_all_run_log_barrier, 0.9, axis=0)\n",
    "re_min_log_barrier = np.quantile(r_all_run_log_barrier, 0.1, axis=0)\n",
    "\n",
    "c_avg_log_barrier  = np.mean(c_all_run_log_barrier, axis=0)\n",
    "c_max_log_barrier  = np.quantile(c_all_run_log_barrier, 0.9, axis=0)\n",
    "c_min_log_barrier  = np.quantile(c_all_run_log_barrier, 0.1, axis=0)\n",
    "\n",
    "with open(\"data/r_c_history_dope_plus.pkl\", \"rb\") as f:\n",
    "    data = pickle.load(f)\n",
    "\n",
    "r_all_run_dope_plus = data[\"r_dope\"]\n",
    "c_all_run_dope_plus = data[\"c_dope\"]\n",
    "re_avg_dope_plus = np.mean(r_all_run_dope_plus, axis=0)\n",
    "re_max_dope_plus  = np.quantile(r_all_run_dope_plus, 0.9, axis=0)\n",
    "re_min_dope_plus = np.quantile(r_all_run_dope_plus, 0.1, axis=0)\n",
    "c_avg_dope_plus  = np.mean(c_all_run_dope_plus, axis=0)\n",
    "c_max_dope_plus  = np.quantile(c_all_run_dope_plus, 0.9, axis=0)\n",
    "c_min_dope_plus  = np.quantile(c_all_run_dope_plus, 0.1, axis=0)\n",
    "\n",
    "with open(\"data/r_c_history_meta_safe.pkl\", \"rb\") as f:\n",
    "    data = pickle.load(f)\n",
    "\n",
    "r_all_run_meta_safe = data[\"r\"]\n",
    "c_all_run_meta_safe = data[\"c\"]\n",
    "re_avg_meta_safe = np.mean(r_all_run_meta_safe, axis=0)\n",
    "re_max_meta_safe  = np.quantile(r_all_run_meta_safe, 0.9, axis=0)\n",
    "re_min_meta_safe = np.quantile(r_all_run_meta_safe, 0.1, axis=0)\n",
    "c_avg_meta_safe  = np.mean(c_all_run_meta_safe, axis=0)\n",
    "c_max_meta_safe  = np.quantile(c_all_run_meta_safe, 0.9, axis=0)\n",
    "c_min_meta_safe  = np.quantile(c_all_run_meta_safe, 0.1, axis=0)\n",
    "\n",
    "def thousands_formatter(x, pos):\n",
    "    \"\"\"Formats the tick labels to be in thousands.\"\"\"\n",
    "    return f'{x / 1000:.0f}'\n",
    "\n",
    "formatter = mticker.FuncFormatter(thousands_formatter)\n",
    "\n",
    "# Create figure with GridSpec for better control\n",
    "fig = plt.figure(figsize=(15, 14))\n",
    "gs = gridspec.GridSpec(2, 1, figure=fig, hspace=0.3)\n",
    "\n",
    "# --- First subplot: Reward Regret ---\n",
    "ax1 = plt.subplot(gs[0, 0])\n",
    "\n",
    "# Plot all algorithms without individual legends\n",
    "ax1.plot(range(np.size(re_avg[:])), re_avg[:], color='tab:green', linestyle='solid', linewidth=2)\n",
    "ax1.fill_between(range(np.size(re_avg[:])), re_min[:], re_max[:], alpha=0.3, facecolor='tab:green')\n",
    "\n",
    "ax1.plot(range(np.size(re_avg_log_barrier[:])), re_avg_log_barrier[:], color='tab:purple', linestyle='solid', linewidth=2)\n",
    "ax1.fill_between(range(np.size(re_avg_log_barrier[:])), re_min_log_barrier[:], re_max_log_barrier[:], alpha=0.3, facecolor='tab:purple')\n",
    "\n",
    "ax1.plot(range(np.size(re_avg_dope_plus[:])), re_avg_dope_plus[:], color='tab:orange', linestyle='solid', linewidth=2)\n",
    "ax1.fill_between(range(np.size(re_avg_dope_plus[:])), re_min_dope_plus[:], re_max_dope_plus[:], alpha=0.3, facecolor='tab:orange')\n",
    "\n",
    "ax1.plot(range(np.size(re_avg_meta_safe[:])), re_avg_meta_safe[:], color='tab:pink', linestyle='solid', linewidth=2)\n",
    "ax1.fill_between(range(np.size(re_avg_meta_safe[:])), re_min_meta_safe[:], re_max_meta_safe[:], alpha=0.3, facecolor='tab:pink')\n",
    "\n",
    "ax1.tick_params(labelsize=20)\n",
    "ax1.xaxis.set_major_formatter(formatter)\n",
    "ax1.yaxis.set_major_formatter(formatter)\n",
    "ax1.set_xlabel(\"Iteration number k ($\\\\times 10^3$)\", color='black', fontsize=22)\n",
    "ax1.set_ylabel(\"Reward regret ($\\\\times 10^3$)\", color='black', fontsize=22)\n",
    "ax1.set_title('Reward regret across different environments', fontsize=24)\n",
    "ax1.grid(alpha=0.3)\n",
    "\n",
    "# --- Second subplot: Constraint Values ---\n",
    "ax2 = plt.subplot(gs[1, 0])\n",
    "\n",
    "ax2.plot(range(np.size(c_avg[:])), c_avg[:], color='tab:green', linestyle='solid', linewidth=2)\n",
    "ax2.fill_between(range(np.size(c_avg[:])), c_min[:], c_max[:], alpha=0.3, facecolor='tab:green')\n",
    "\n",
    "ax2.plot(range(np.size(c_avg_log_barrier[:])), c_avg_log_barrier[:], color='tab:purple', linestyle='solid', linewidth=2)\n",
    "ax2.fill_between(range(np.size(c_avg_log_barrier[:])), c_min_log_barrier[:], c_max_log_barrier[:], alpha=0.3, facecolor='tab:purple')\n",
    "\n",
    "ax2.plot(range(np.size(c_avg_dope_plus[:])), c_avg_dope_plus[:], color='tab:orange', linestyle='solid', linewidth=2)\n",
    "ax2.fill_between(range(np.size(c_avg_dope_plus[:])), c_min_dope_plus[:], c_max_dope_plus[:], alpha=0.3, facecolor='tab:orange')\n",
    "\n",
    "ax2.plot(range(np.size(c_avg_meta_safe[:])), c_avg_meta_safe[:], color='tab:pink', linestyle='solid', linewidth=2)\n",
    "ax2.fill_between(range(np.size(c_avg_meta_safe[:])), c_min_meta_safe[:], c_max_meta_safe[:], alpha=0.3, facecolor='tab:pink')\n",
    "\n",
    "# Add threshold line (will show in subplot legend only)\n",
    "ax2.axhline(y=1.5, color='tab:red', linewidth=2, label='Threshold = 1.5')\n",
    "\n",
    "ax2.tick_params(labelsize=20)\n",
    "ax2.xaxis.set_major_formatter(formatter)\n",
    "ax2.set_xlabel(\"Iteration number k ($\\\\times 10^3$)\", color='black', fontsize=22)\n",
    "ax2.set_ylabel(\"Constraint value\", color='black', fontsize=22)\n",
    "ax2.set_title('Constraint values across different environments', fontsize=24)\n",
    "ax2.grid(alpha=0.3)\n",
    "\n",
    "# Add legend to the second subplot only\n",
    "ax2.legend(fontsize=20, loc='upper left')\n",
    "\n",
    "# --- Create a single shared legend at the top (without threshold) ---\n",
    "legend_elements = [\n",
    "    Patch(facecolor='tab:green', alpha=0.6, label='Our algorithm'),\n",
    "    Patch(facecolor='tab:pink', alpha=0.6, label='Safe Meta-RL'),\n",
    "    Patch(facecolor='tab:orange', alpha=0.6, label='DOPE+'),\n",
    "    Patch(facecolor='tab:purple', alpha=0.6, label='LB-SGD')\n",
    "]\n",
    "# Add legend above the plots\n",
    "fig.legend(handles=legend_elements, loc='upper center', ncol=4, \n",
    "           fontsize=20, frameon=True, bbox_to_anchor=(0.5, 0.98))\n",
    "\n",
    "plt.tight_layout(rect=[0, 0, 1, 0.96])  # Leave space for legend at top\n",
    "plt.savefig(\"plots/compare_safe_LB_SGD_dope_plus_vertical.png\", format='png', dpi=800, bbox_inches='tight')\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "safe",
   "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.11.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
