{
 "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",
    "max_bellman_iterations = 5\n",
    "max_bellman_iterations_validation = max_bellman_iterations + 20\n",
    "seeds = range(1, 2)\n",
    "n_states = parameters[\"n_states\"]\n",
    "n_actions = 2\n",
    "n_weights = parameters[\"n_weights\"]\n",
    "n_repetitions = parameters[\"n_repetitions\"]\n",
    "ticks_freqs = {\"2\": 2, \"5\": 5, \"15\":5}\n",
    "ticks_freq = ticks_freqs[str(max_bellman_iterations)]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## General case"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Extract data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "fqi_q = np.zeros((len(seeds), max_bellman_iterations + 1, n_states, n_actions))\n",
    "fqi_bi = np.zeros((len(seeds), max_bellman_iterations + 1, n_states, n_actions))\n",
    "fqi_v = np.zeros((len(seeds), max_bellman_iterations + 1, n_states))\n",
    "\n",
    "for idx_seed, seed in enumerate(seeds):\n",
    "    fqi_q[idx_seed] = np.load(f\"figures/data/FQI/{max_bellman_iterations}_Q_{seed}.npy\")\n",
    "    fqi_bi[idx_seed] = np.load(f\"figures/data/FQI/{max_bellman_iterations}_BI_{seed}.npy\")\n",
    "    fqi_v[idx_seed] = np.load(f\"figures/data/FQI/{max_bellman_iterations}_V_{seed}.npy\")\n",
    "\n",
    "lspi_q = np.load(f\"figures/data/LSPI/{max_bellman_iterations}_Q.npy\")\n",
    "lspi_bi = np.load(f\"figures/data/LSPI/{max_bellman_iterations}_BI.npy\")\n",
    "lspi_v = np.load(f\"figures/data/LSPI/{max_bellman_iterations}_V.npy\")\n",
    "\n",
    "optimal_q = np.load(f\"figures/data/optimal/Q.npy\")\n",
    "optimal_v = np.load(f\"figures/data/optimal/V.npy\")\n",
    "\n",
    "pbo_linear_q = np.zeros((len(seeds), max_bellman_iterations_validation + 2, n_states, n_actions))\n",
    "pbo_linear_bi = np.zeros((len(seeds), max_bellman_iterations_validation + 2, n_states, n_actions))\n",
    "pbo_linear_v = np.zeros((len(seeds), max_bellman_iterations_validation + 2, n_states))\n",
    "\n",
    "for idx_seed, seed in enumerate(seeds):\n",
    "    pbo_linear_q[idx_seed] = np.load(f\"figures/data/PBO_linear/{max_bellman_iterations}_Q_{n_weights}_{seed}.npy\")\n",
    "    pbo_linear_bi[idx_seed] = np.load(f\"figures/data/PBO_linear/{max_bellman_iterations}_BI_{n_weights}_{seed}.npy\")\n",
    "    pbo_linear_v[idx_seed] = np.load(f\"figures/data/PBO_linear/{max_bellman_iterations}_V_{n_weights}_{seed}.npy\")\n",
    "\n",
    "pbo_max_linear_q = np.zeros((len(seeds), max_bellman_iterations_validation + 1, n_states, n_actions))\n",
    "pbo_max_linear_bi = np.zeros((len(seeds), max_bellman_iterations_validation + 1, n_states, n_actions))\n",
    "pbo_max_linear_v = np.zeros((len(seeds), max_bellman_iterations_validation + 1, n_states))\n",
    "\n",
    "for idx_seed, seed in enumerate(seeds):\n",
    "    pbo_max_linear_q[idx_seed] = np.load(f\"figures/data/PBO_max_linear/{max_bellman_iterations}_Q_{n_repetitions}_{seed}.npy\")\n",
    "    pbo_max_linear_bi[idx_seed] = np.load(f\"figures/data/PBO_max_linear/{max_bellman_iterations}_BI_{n_repetitions}_{seed}.npy\")\n",
    "    pbo_max_linear_v[idx_seed] = np.load(f\"figures/data/PBO_max_linear/{max_bellman_iterations}_V_{n_repetitions}_{seed}.npy\")\n",
    "\n",
    "pbo_optimal_q = np.load(f\"figures/data/PBO_optimal/{max_bellman_iterations}_Q.npy\")\n",
    "pbo_optimal_bi = np.load(f\"figures/data/PBO_optimal/{max_bellman_iterations}_BI.npy\")\n",
    "pbo_optimal_v = np.load(f\"figures/data/PBO_optimal/{max_bellman_iterations}_V.npy\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Distances with the optimal Q function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "fqi_q_mean = np.sqrt(np.mean(np.square(fqi_q - optimal_q), axis=(2, 3))).mean(axis=0)\n",
    "fqi_q_std = np.sqrt(np.mean(np.square(fqi_q - optimal_q), axis=(2, 3))).std(axis=0)\n",
    "fqi_q_confidence_interval = confidence_interval(fqi_q_mean, fqi_q_std, len(seeds))\n",
    "\n",
    "lspi_q_mean = np.sqrt(np.mean(np.square(lspi_q - optimal_q), axis=(1, 2)))\n",
    "\n",
    "pbo_linear_q_mean = np.sqrt(np.mean(np.square(pbo_linear_q - optimal_q), axis=(2, 3))).mean(axis=0)\n",
    "pbo_linear_q_std = np.sqrt(np.mean(np.square(pbo_linear_q - optimal_q), axis=(2, 3))).std(axis=0)\n",
    "pbo_linear_q_confidence_interval = confidence_interval(pbo_linear_q_mean, pbo_linear_q_std, len(seeds))\n",
    "\n",
    "pbo_max_linear_q_mean = np.sqrt(np.mean(np.square(pbo_max_linear_q - optimal_q), axis=(2, 3))).mean(axis=0)\n",
    "pbo_max_linear_q_std = np.sqrt(np.mean(np.square(pbo_max_linear_q - optimal_q), axis=(2, 3))).std(axis=0)\n",
    "pbo_max_linear_q_confidence_interval = confidence_interval(pbo_max_linear_q_mean, pbo_max_linear_q_std, len(seeds))\n",
    "\n",
    "pbo_optimal_q_mean = np.sqrt(np.mean(np.square(pbo_optimal_q - optimal_q), axis=(1, 2)))"
   ]
  },
  {
   "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_optimal_q_mean, label=\"PBO optimal\", color=\"black\")\n",
    "\n",
    "plt.plot(iterations_validation, pbo_linear_q_mean[:-1], label=\"PBO linear\", color=\"blue\")\n",
    "plt.fill_between(iterations_validation, pbo_linear_q_confidence_interval[0, :-1], pbo_linear_q_confidence_interval[1, :-1], color=\"blue\", alpha=0.3)\n",
    "\n",
    "plt.hlines(pbo_linear_q_mean[-1], 0, max_bellman_iterations_validation, color=\"blue\", linestyle=\"--\", label=\"PBO linear fixed point\")\n",
    "plt.fill_between(iterations_validation, pbo_linear_q_confidence_interval[0, -1], pbo_linear_q_confidence_interval[1, -1], color=\"blue\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations_validation, pbo_max_linear_q_mean, label=\"PBO max-linear\", color=\"green\")\n",
    "plt.fill_between(iterations_validation, pbo_max_linear_q_confidence_interval[0], pbo_max_linear_q_confidence_interval[1], color=\"green\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations, fqi_q_mean, label=\"FQI\", color=\"red\")\n",
    "plt.fill_between(iterations, fqi_q_confidence_interval[0], fqi_q_confidence_interval[1], color=\"red\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations, lspi_q_mean, label=\"LSPI\", color=\"purple\")\n",
    "\n",
    "plt.axvline(max_bellman_iterations, color=\"black\", linestyle=\"--\")\n",
    "plt.xticks(range(0, max_bellman_iterations_validation + 1, ticks_freq))\n",
    "plt.xlabel(\"#Iterations\")\n",
    "\n",
    "plt.title(r\"$|| Q^* - Q_i ||_2$\")\n",
    "plt.legend()\n",
    "plt.grid(zorder=0)\n",
    "_ = plt.savefig(f\"figures/distance_to_optimal_Q_{max_bellman_iterations}.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Distances with the optimal V function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "fqi_v_mean = np.sqrt(np.mean(np.square(fqi_v - optimal_v), axis=2)).mean(axis=0)\n",
    "fqi_v_std = np.sqrt(np.mean(np.square(fqi_v - optimal_v), axis=2)).std(axis=0)\n",
    "fqi_v_confidence_interval = confidence_interval(fqi_v_mean, fqi_v_std, len(seeds))\n",
    "\n",
    "lspi_v_mean = np.sqrt(np.mean(np.square(lspi_v - optimal_v), axis=1))\n",
    "\n",
    "pbo_linear_v_mean = np.sqrt(np.mean(np.square(pbo_linear_v - optimal_v), axis=2)).mean(axis=0)\n",
    "pbo_linear_v_std = np.sqrt(np.mean(np.square(pbo_linear_v - optimal_v), axis=2)).std(axis=0)\n",
    "pbo_linear_v_confidence_interval = confidence_interval(pbo_linear_v_mean, pbo_linear_v_std, len(seeds))\n",
    "\n",
    "pbo_max_linear_v_mean = np.sqrt(np.mean(np.square(pbo_max_linear_v - optimal_v), axis=2)).mean(axis=0)\n",
    "pbo_max_linear_v_std = np.sqrt(np.mean(np.square(pbo_max_linear_v - optimal_v), axis=2)).std(axis=0)\n",
    "pbo_max_linear_v_confidence_interval = confidence_interval(pbo_max_linear_v_mean, pbo_max_linear_v_std, len(seeds))\n",
    "\n",
    "pbo_optimal_v_mean = np.sqrt(np.mean(np.square(pbo_optimal_v - optimal_v), axis=1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "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_v_mean[:-1], label=\"PBO linear\", color=\"blue\", zorder=7)\n",
    "plt.fill_between(iterations_validation, pbo_linear_v_confidence_interval[0, :-1], pbo_linear_v_confidence_interval[1, :-1], color=\"blue\", alpha=0.3)\n",
    "\n",
    "plt.hlines(pbo_linear_v_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_v_confidence_interval[0, -1], pbo_linear_v_confidence_interval[1, -1], color=\"blue\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations_validation, pbo_max_linear_v_mean, label=\"PBO deep\", color=\"green\", zorder=8)\n",
    "plt.fill_between(iterations_validation, pbo_max_linear_v_confidence_interval[0], pbo_max_linear_v_confidence_interval[1], color=\"green\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations, fqi_v_mean, label=\"FQI\", color=\"red\", zorder=6)\n",
    "plt.fill_between(iterations, fqi_v_confidence_interval[0], fqi_v_confidence_interval[1], color=\"red\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations, lspi_v_mean, label=\"LSPI\", color=\"purple\", zorder=5)\n",
    "\n",
    "plt.plot(iterations_validation, pbo_optimal_v_mean, label=\"PBO optimal\", color=\"black\", zorder=4)\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",
    "\n",
    "plt.title(r\"$ || V^* - V^{\\pi_i} ||_2 $\")\n",
    "plt.legend()\n",
    "plt.grid(zorder=0)\n",
    "_ = plt.savefig(f\"figures/distance_to_optimal_V_{max_bellman_iterations}.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Distance to the optimal Bellman iteration"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "fqi_bi_mean = np.sqrt(np.mean(np.square(fqi_bi[:, :-1] - fqi_q[:, 1:]), axis=(2, 3))).mean(axis=0)\n",
    "fqi_bi_std = np.sqrt(np.mean(np.square(fqi_bi[:, :-1] - fqi_q[:, 1:]), axis=(2, 3))).std(axis=0)\n",
    "fqi_bi_confidence_interval = confidence_interval(fqi_bi_mean, fqi_bi_std, len(seeds))\n",
    "\n",
    "lspi_bi_mean = np.sqrt(np.mean(np.square(lspi_bi[:-1] - lspi_q[1:]), axis=(1, 2)))\n",
    "\n",
    "pbo_linear_bi_mean = np.sqrt(np.mean(np.square(pbo_linear_bi[:, :-2] - pbo_linear_q[:, 1:-1]), axis=(2, 3))).mean(axis=0)\n",
    "pbo_linear_bi_std = np.sqrt(np.mean(np.square(pbo_linear_bi[:, :-2] - pbo_linear_q[:, 1:-1]), axis=(2, 3))).std(axis=0)\n",
    "pbo_linear_bi_confidence_interval = confidence_interval(pbo_linear_bi_mean, pbo_linear_bi_std, len(seeds))\n",
    "\n",
    "pbo_linear_bi_fixed_point_mean = np.sqrt(np.mean(np.square(pbo_linear_bi[:, -1] - pbo_linear_q[:, -1]), axis=(1, 2))).mean(axis=0)\n",
    "pbo_linear_bi_fixed_point_std = np.sqrt(np.mean(np.square(pbo_linear_bi[:, -1] - pbo_linear_q[:, -1]), axis=(1, 2))).std(axis=0)\n",
    "pbo_linear_bi_fixed_point_confidence_interval = confidence_interval([pbo_linear_bi_fixed_point_mean], [pbo_linear_bi_fixed_point_std], len(seeds))\n",
    "\n",
    "pbo_max_linear_bi_mean = np.sqrt(np.mean(np.square(pbo_max_linear_bi[:, :-1] - pbo_max_linear_q[:, 1:]), axis=(2, 3))).mean(axis=0)\n",
    "pbo_max_linear_bi_std = np.sqrt(np.mean(np.square(pbo_max_linear_bi[:, :-1] - pbo_max_linear_q[:, 1:]), axis=(2, 3))).std(axis=0)\n",
    "pbo_max_linear_bi_confidence_interval = confidence_interval(pbo_max_linear_bi_mean, pbo_max_linear_bi_std, len(seeds))\n",
    "\n",
    "pbo_optimal_bi_mean = np.sqrt(np.mean(np.square(pbo_optimal_bi[:-1] - pbo_optimal_q[1:]), axis=(1, 2)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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(1, max_bellman_iterations + 1)\n",
    "iterations_validation = range(1, max_bellman_iterations_validation + 1)\n",
    "\n",
    "plt.plot(iterations_validation, pbo_optimal_bi_mean, label=\"PBO optimal\", color=\"black\")\n",
    "\n",
    "plt.plot(iterations_validation, pbo_linear_bi_mean, label=\"PBO linear\", color=\"blue\")\n",
    "plt.fill_between(iterations_validation, pbo_linear_bi_confidence_interval[0], pbo_linear_bi_confidence_interval[1], color=\"blue\", alpha=0.3)\n",
    "\n",
    "plt.hlines(pbo_linear_bi_fixed_point_mean, 1, max_bellman_iterations_validation, color=\"blue\", linestyle=\"--\", label=\"PBO linear fixed point\")\n",
    "plt.fill_between(iterations_validation, pbo_linear_bi_fixed_point_confidence_interval[0], pbo_linear_bi_fixed_point_confidence_interval[1], color=\"blue\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations_validation, pbo_max_linear_bi_mean, label=\"PBO max-linear\", color=\"green\")\n",
    "plt.fill_between(iterations_validation, pbo_max_linear_bi_confidence_interval[0], pbo_max_linear_bi_confidence_interval[1], color=\"green\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations, fqi_bi_mean, label=\"FQI\", color=\"red\")\n",
    "plt.fill_between(iterations, fqi_bi_confidence_interval[0], fqi_bi_confidence_interval[1], color=\"red\", alpha=0.3)\n",
    "\n",
    "# plt.plot(iterations, lspi_bi_mean, label=\"LSPI\", color=\"purple\")\n",
    "\n",
    "plt.axvline(max_bellman_iterations, color=\"black\", linestyle=\"--\")\n",
    "plt.xticks(range(0, max_bellman_iterations_validation + 1, ticks_freq))\n",
    "plt.xlabel(\"#Iterations\")\n",
    "\n",
    "plt.title(r\"$|| \\Gamma^*Q_{i-1} - Q_i ||_2$\")\n",
    "plt.legend()\n",
    "plt.grid(zorder=0)\n",
    "_ = plt.savefig(f\"figures/distance_to_optimal_BI_{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
}
