{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Plots with confidence interval"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "import warnings\n",
    "warnings.simplefilter(action='ignore', category=FutureWarning)\n",
    "import os\n",
    "import json\n",
    "import numpy as np\n",
    "from pbo.utils.confidence_interval import confidence_interval\n",
    "\n",
    "\n",
    "parameters = json.load(open(\"parameters.json\"))\n",
    "\n",
    "n_omegas = parameters[\"n_omegas\"]\n",
    "n_thetas = parameters[\"n_thetas\"]\n",
    "n_simulations = parameters[\"n_simulations\"]\n",
    "max_bellman_iterations = 8\n",
    "max_bellman_iterations_validation = max_bellman_iterations + 10\n",
    "seeds = range(1, 2)\n",
    "n_seeds = len(seeds)\n",
    "ticks_freq = 2 if max_bellman_iterations == 8 else 5\n",
    "dt = 0.01"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## General case"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Extract data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "fqi_metrics = np.zeros((n_seeds, max_bellman_iterations + 1, n_simulations, 2))\n",
    "\n",
    "for idx_seed, seed in enumerate(seeds):\n",
    "    fqi_metrics[idx_seed] = np.load(f\"figures/data/FQI/{max_bellman_iterations}_metrics_{seed}.npy\")\n",
    "\n",
    "pbo_linear_metrics = np.zeros((n_seeds, max_bellman_iterations_validation + 2, n_simulations, 2))\n",
    "\n",
    "for idx_seed, seed in enumerate(seeds):\n",
    "    pbo_linear_metrics[idx_seed] = np.load(f\"figures/data/PBO_linear/{max_bellman_iterations}_metrics_{seed}.npy\")\n",
    "\n",
    "pbo_linear_max_linear_metrics = np.zeros((n_seeds, max_bellman_iterations_validation + 1, n_simulations, 2))\n",
    "\n",
    "for idx_seed, seed in enumerate(seeds):\n",
    "    pbo_linear_max_linear_metrics[idx_seed] = np.load(f\"figures/data/PBO_linear_max_linear/{max_bellman_iterations}_metrics_{seed}.npy\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Number of seconds archieved"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "fqi_seconds_mean = (fqi_metrics[:, :, :, 0] * dt).mean(axis=2).mean(axis=0)\n",
    "fqi_seconds_std = (fqi_metrics[:, :, :, 0] * dt).mean(axis=2).std(axis=0)\n",
    "fqi_seconds_confidence_interval = confidence_interval(fqi_seconds_mean, fqi_seconds_std, n_seeds)\n",
    "\n",
    "pbo_linear_seconds_mean = (pbo_linear_metrics[:, :, :, 0] * dt).mean(axis=2).mean(axis=0)\n",
    "pbo_linear_seconds_std = (pbo_linear_metrics[:, :, :, 0] * dt).mean(axis=2).std(axis=0)\n",
    "pbo_linear_seconds_confidence_interval = confidence_interval(pbo_linear_seconds_mean, pbo_linear_seconds_std, n_seeds)\n",
    "\n",
    "pbo_linear_max_linear_seconds_mean = (pbo_linear_max_linear_metrics[:, :, :, 0] * dt).mean(axis=2).mean(axis=0)\n",
    "pbo_linear_max_linear_seconds_std = (pbo_linear_max_linear_metrics[:, :, :, 0] * dt).mean(axis=2).std(axis=0)\n",
    "pbo_linear_max_linear_seconds_confidence_interval = confidence_interval(pbo_linear_max_linear_seconds_mean, pbo_linear_max_linear_seconds_std, n_seeds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt \n",
    "\n",
    "plt.rc(\"font\", size=15)\n",
    "plt.rc(\"lines\", linewidth=3)\n",
    "\n",
    "iterations = range(max_bellman_iterations + 1)\n",
    "iterations_validation = range(max_bellman_iterations_validation + 1)\n",
    "\n",
    "plt.plot(iterations_validation, pbo_linear_seconds_mean[:-1], label=\"PBO linear\", color=\"blue\", zorder=7)\n",
    "plt.fill_between(iterations_validation, pbo_linear_seconds_confidence_interval[0, :-1], pbo_linear_seconds_confidence_interval[1, :-1], color=\"blue\", alpha=0.3)\n",
    "\n",
    "plt.hlines(pbo_linear_seconds_mean[-1], 0, max_bellman_iterations_validation, color=\"blue\", linestyle=\"--\", label=\"PBO linear fixed point\", zorder=3)\n",
    "plt.fill_between(iterations_validation, pbo_linear_seconds_confidence_interval[0, -1], pbo_linear_seconds_confidence_interval[1, -1], color=\"blue\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations_validation, pbo_linear_max_linear_seconds_mean, label=\"PBO deep\", color=\"green\", zorder=8)\n",
    "plt.fill_between(iterations_validation, pbo_linear_max_linear_seconds_confidence_interval[0], pbo_linear_max_linear_seconds_confidence_interval[1], color=\"green\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations, fqi_seconds_mean, label=\"FQI\", color=\"red\", zorder=6)\n",
    "plt.fill_between(iterations, fqi_seconds_confidence_interval[0], fqi_seconds_confidence_interval[1], color=\"red\", alpha=0.3)\n",
    "\n",
    "plt.axvline(max_bellman_iterations, color=\"black\", linestyle=\"--\", zorder=2)\n",
    "plt.xticks(range(0, max_bellman_iterations_validation + 1, ticks_freq))\n",
    "plt.xlabel(\"#Iterations\")\n",
    "plt.title(\"Balancing time in seconds\")\n",
    "# plt.legend().set_zorder(9)\n",
    "plt.grid(zorder=0)\n",
    "_ = plt.savefig(f\"figures/seconds_{max_bellman_iterations}.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Performances"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "fqi_performances_mean = (fqi_metrics[:, :, :, 1]).mean(axis=2).mean(axis=0)\n",
    "fqi_performances_std = (fqi_metrics[:, :, :, 1]).mean(axis=2).std(axis=0)\n",
    "fqi_performances_confidence_interval = confidence_interval(fqi_performances_mean, fqi_performances_std, n_seeds)\n",
    "\n",
    "pbo_linear_performances_mean = (pbo_linear_metrics[:, :, :, 1]).mean(axis=2).mean(axis=0)\n",
    "pbo_linear_performances_std = (pbo_linear_metrics[:, :, :, 1]).mean(axis=2).std(axis=0)\n",
    "pbo_linear_performances_confidence_interval = confidence_interval(pbo_linear_performances_mean, pbo_linear_performances_std, n_seeds)\n",
    "\n",
    "pbo_linear_max_linear_performances_mean = (pbo_linear_max_linear_metrics[:, :, :, 1]).mean(axis=2).mean(axis=0)\n",
    "pbo_linear_max_linear_performances_std = (pbo_linear_max_linear_metrics[:, :, :, 1]).mean(axis=2).std(axis=0)\n",
    "pbo_linear_max_linear_performances_confidence_interval = confidence_interval(pbo_linear_max_linear_performances_mean, pbo_linear_max_linear_performances_std, n_seeds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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O+7z8pxf7ZgYvQRVUbCuXHhSLHaFYs+zYqegoICCggKysrL48MMPWbBgAZdffrnj/k8//eSwrbgTGRnJJZdcwq+//uqSh95fhg0bxuDBg/nqq69o3bo1Q4cOdeS8B/jss8+44oor6NatGzNnzmT8+PFMmTKFcePGOers2rWLtm3b8uabb/LNN98wcuRIxo8fz/PPP19svFtuuYXOnTszc+ZMbrnllmL3u3TpwqJFiwC4//77WbRokUtmSjs1atTg9ddf54MPPnBk23zvvfeYPXs277//PvHx8eTm5tK/f3/mzp3LCy+8wPTp06lduzb9+/dnr+XX30033cS3337LSy+9xKRJk/j++++9TlS2fft2HnnkER5//HE++ugjMjMzGThwoCP1M8DIkSN57733ePTRR/nqq69o3LgxF198MQsXLiy175MnTzJ8+HBuu+02vvjiC2JjY7niiiscSvOrr74iOTmZW265hUWLFjF37ly6dPFvA3KJKKVO+SMtLU35y/z5810Lnn/evnyu1M03e2yzd69S0dHOavbjhhv8FqO4HGEiEHLU/3d9xQQUE1Br9q8psd6aNZ7vjR9f/LMt6Rg5snj7kSO9bz9+vGfZVqxYof744w+1YsWKYve2bFFq6VJ9PPjgeJWamqry8/NVfn6+Wr9+verTp4+qXr262r17t+39jLcnwHM57rrrLpd+Y2Nj1T333FNsvKysLKWUUi+99JIC1N69e0v8TJs2baruv/9+x/Xw4cOV9f/jvffeU4D63//+5yg7ePCgioyMVG+99ZZSSqmioiLVpEkTNWLECJe+33jjDRUXF6cOHjxYbNyioiKVn5+vnn76adW8eXNH+fz58xXg8X15AlCvvfZaqe8pKytLjRo1StWpU0f9/vvvKjk5WT300EOO+5MnT1bR0dFqw4YNjrL8/HzVokUL9cADDyillFq1apUC1CeffOKoc+zYMVWzZk3VtGnTUmUcPny4AtQPP/zgKNu2bZvLZ7hmzRolImrKlCmOOoWFhapjx47q/PPPd5T17t1bXXnllY5r+3dl3rx5jrI//vhDAerbb791lKWmpqrxti+v/fvhiZL+x+wAy5SHZ6qZsQQaL4JPvvuuc7UsJcVZ/t13viV/qorsObaHPcd1Yvi4qDjapLYJs0T+kZ+fT0FBgcvSjx3rjKWwEA4dOkR0dDTR0dG0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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt \n",
    "\n",
    "plt.rc(\"font\", size=15)\n",
    "plt.rc(\"lines\", linewidth=3)\n",
    "\n",
    "iterations = range(max_bellman_iterations + 1)\n",
    "iterations_validation = range(max_bellman_iterations_validation + 1)\n",
    "\n",
    "plt.plot(iterations_validation, pbo_linear_performances_mean[:-1], label=\"PBO linear\", color=\"blue\", zorder=7)\n",
    "plt.fill_between(iterations_validation, pbo_linear_performances_confidence_interval[0, :-1], pbo_linear_performances_confidence_interval[1, :-1], color=\"blue\", alpha=0.3)\n",
    "\n",
    "plt.hlines(pbo_linear_performances_mean[-1], 0, max_bellman_iterations_validation, color=\"blue\", linestyle=\"--\", label=\"PBO linear fixed point\", zorder=3)\n",
    "plt.fill_between(iterations_validation, pbo_linear_performances_confidence_interval[0, -1], pbo_linear_performances_confidence_interval[1, -1], color=\"blue\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations_validation, pbo_linear_max_linear_performances_mean, label=\"PBO deep\", color=\"green\", zorder=8)\n",
    "plt.fill_between(iterations_validation, pbo_linear_max_linear_performances_confidence_interval[0], pbo_linear_max_linear_performances_confidence_interval[1], color=\"green\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations, fqi_performances_mean, label=\"FQI\", color=\"red\", zorder=6)\n",
    "plt.fill_between(iterations, fqi_performances_confidence_interval[0], fqi_performances_confidence_interval[1], color=\"red\", alpha=0.3)\n",
    "\n",
    "plt.axvline(max_bellman_iterations, color=\"black\", linestyle=\"--\", zorder=2)\n",
    "plt.xticks(range(0, max_bellman_iterations_validation + 1, ticks_freq))\n",
    "plt.xlabel(\"#Iterations\")\n",
    "plt.title(\"Performances\")\n",
    "plt.legend().set_zorder(9)\n",
    "plt.grid(zorder=0)\n",
    "_ = plt.savefig(f\"figures/performances_{max_bellman_iterations}.pdf\", bbox_inches='tight')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.8.10 ('env_cpu': venv)",
   "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.10"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "af5525a3273d35d601ae265c5d3634806dd61a1c4d085ae098611a6832982bdb"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
