{
 "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 = 2\n",
    "max_bellman_iterations_validation = max_bellman_iterations + 5\n",
    "seeds = range(1, 2)\n",
    "n_samples = parameters[\"n_discrete_states\"] * parameters[\"n_discrete_actions\"]\n",
    "n_weights = parameters[\"n_weights\"]\n",
    "initial_weight_std = parameters[\"initial_weight_std\"]\n",
    "ticks_freq = 2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## General case"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Extract data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "fqi_w = np.zeros((len(seeds), max_bellman_iterations + 1, 3))\n",
    "fqi_pi = np.zeros((len(seeds), max_bellman_iterations + 1))\n",
    "\n",
    "for idx_seed, seed in enumerate(range(1, len(seeds) + 1)):\n",
    "    fqi_w[idx_seed] = np.load(f\"figures/data/FQI/{max_bellman_iterations}_W_{seed}.npy\")\n",
    "    fqi_pi[idx_seed] = np.load(f\"figures/data/FQI/{max_bellman_iterations}_Pi_{seed}.npy\")\n",
    "\n",
    "lspi_w = np.zeros((len(seeds), max_bellman_iterations + 1, 3))\n",
    "lspi_pi = np.zeros((len(seeds), max_bellman_iterations + 1))\n",
    "\n",
    "for idx_seed, seed in enumerate(range(1, len(seeds) + 1)):\n",
    "    lspi_w[idx_seed] = np.load(f\"figures/data/LSPI/{max_bellman_iterations}_W_{seed}.npy\")\n",
    "    lspi_pi[idx_seed] = np.load(f\"figures/data/LSPI/{max_bellman_iterations}_Pi_{seed}.npy\")\n",
    "\n",
    "optimal_w = np.load(f\"figures/data/optimal/W.npy\")\n",
    "optimal_pi = np.load(f\"figures/data/optimal/Pi.npy\")\n",
    "\n",
    "pbo_linear_w = np.zeros((len(seeds), max_bellman_iterations_validation + 2, 3))\n",
    "pbo_linear_pi = np.zeros((len(seeds), max_bellman_iterations_validation + 2))\n",
    "\n",
    "for idx_seed, seed in enumerate(range(1, len(seeds) + 1)):\n",
    "    pbo_linear_w[idx_seed] = np.load(f\"figures/data/PBO_linear/{max_bellman_iterations}_W_{initial_weight_std}_{seed}.npy\")\n",
    "    pbo_linear_pi[idx_seed] = np.load(f\"figures/data/PBO_linear/{max_bellman_iterations}_Pi_{initial_weight_std}_{seed}.npy\")\n",
    "\n",
    "pbo_custom_linear_w = np.zeros((len(seeds), max_bellman_iterations_validation + 1, 3))\n",
    "pbo_custom_linear_pi = np.zeros((len(seeds), max_bellman_iterations_validation + 1))\n",
    "\n",
    "for idx_seed, seed in enumerate(range(1, len(seeds) + 1)):\n",
    "    pbo_custom_linear_w[idx_seed] = np.load(f\"figures/data/PBO_custom_linear/{max_bellman_iterations}_W_{n_samples}_{seed}.npy\")\n",
    "    pbo_custom_linear_pi[idx_seed] = np.load(f\"figures/data/PBO_custom_linear/{max_bellman_iterations}_Pi_{n_samples}_{seed}.npy\")\n",
    "\n",
    "pbo_optimal_w = np.load(f\"figures/data/PBO_optimal/{max_bellman_iterations}_W.npy\")\n",
    "pbo_optimal_pi = np.load(f\"figures/data/PBO_optimal/{max_bellman_iterations}_Pi.npy\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Distances with the optimal weights"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "fqi_w_mean = np.sqrt(np.mean(np.square(fqi_w - optimal_w), axis=2)).mean(axis=0)\n",
    "fqi_w_std = np.sqrt(np.mean(np.square(fqi_w - optimal_w), axis=2)).std(axis=0)\n",
    "fqi_w_confidence_interval = confidence_interval(fqi_w_mean, fqi_w_std, len(seeds))\n",
    "\n",
    "lspi_w_mean = np.sqrt(np.mean(np.square(lspi_w - optimal_w), axis=2)).mean(axis=0)\n",
    "lspi_w_std = np.sqrt(np.mean(np.square(lspi_w - optimal_w), axis=2)).std(axis=0)\n",
    "lspi_w_confidence_interval = confidence_interval(lspi_w_mean, lspi_w_std, len(seeds))\n",
    "\n",
    "pbo_linear_w_mean = np.sqrt(np.mean(np.square(pbo_linear_w - optimal_w), axis=2)).mean(axis=0)\n",
    "pbo_linear_w_std = np.sqrt(np.mean(np.square(pbo_linear_w - optimal_w), axis=2)).std(axis=0)\n",
    "pbo_linear_w_confidence_interval = confidence_interval(pbo_linear_w_mean, pbo_linear_w_std, len(seeds))\n",
    "\n",
    "pbo_custom_linear_w_mean = np.sqrt(np.mean(np.square(pbo_custom_linear_w - optimal_w), axis=2)).mean(axis=0)\n",
    "pbo_custom_linear_w_std = np.sqrt(np.mean(np.square(pbo_custom_linear_w - optimal_w), axis=2)).std(axis=0)\n",
    "pbo_custom_linear_w_confidence_interval = confidence_interval(pbo_custom_linear_w_mean, pbo_custom_linear_w_std, len(seeds))\n",
    "\n",
    "pbo_optimal_w_mean = np.sqrt(np.mean(np.square(pbo_optimal_w - optimal_w), axis=1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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S5k6daqxQ1EUg2nUqBErV67kwIED9O7dW1supWTZsmU0aNCAIUOGcP78eSNGaRgqQSiKopRAkyZNWL16NXv27OGJJ57QlmdnZ7N06VICAwMZNmwYUVFRRoyydFSCUBRFKYXg4GDWr1/Pzp076dq1q7Y8MzOThQsX8sADD/Daa69x+fJlI0ZZMipBKIqiGEDr1q35448/2Lp1q87zKRkZGSxYsICAgADefPNNrly5Yrwgi8nkE4TqxaQoSkXy8MMP888///D333/Trl07bXlaWhpz586lTp06vP3221y/ft2IURaNyScI1YtJUZSK6NFHH2Xbtm3ah+typaam8sknn+Dv78+ECROIjb3/RETGYvIJQlEUpaISQtCtWzd27tzJunXraNasmXZZcnIys2bNws/PjylTpnD79m0jRqqfShCKoihlTAjBk08+yd69e1m1ahUPPvigdlliYiLTp0/H39+fadOmUZGay1WCUBRFKSdCCPr06cOBAwdYsWIFDRs21C67c+cOoaGh+Pv7M3PmTBITE40YqYZKEIqiKOXMzMyMZ555hsOHD7Ns2TLq1aunXXb79m0mTZqEv78/s2fPJjk52XhxGm3PSqU3bNgwnnzySYYNG2bsUBSlQjI3N2fAgAEcO3aMpUuXUqdOHe2ymzdv8s4771CnTh0+//xzUlNTyz0+lSCUMhMeHs7YsWMJDw83diiKUqFZWFjw4osvcvLkSRYuXIivr6922bVr1xg9ejR169bliy++KDDrXVky+QShnoNQFKWysLS0ZOjQoZw+fZqvvvqKWrVqaZfFxMQwcuRIHnjgAcLDw8nIyCjzeEw+QajnIBRFqWysrKwYPnw4Z86cYd68eXh6emqXXbp0ieHDhxMYGMjixYsLzHpnSCafIBRFUSorGxsbRo4cyblz5/jkk09wd3fXLrtw4QIvv/wyDRo04PvvvycrK8vg+1cJQikzISEhzJ49m5CQEGOHoigmzdbWljFjxnD+/HlmzZqFm5ubdtnZs2d54YUXymRYfZUglDLzzTffsH79er755htjh6IolYK9vT3jxo3jwoULTJ8+nWrVqgGaJqmy6C1oYfAtKoqiKGXK0dGRyZMnM3LkSD777DPS0tLw8fEx+H5UglAURTFRzs7OhIaGltn2VROToiiKopdKEIqiKIpeKkEoiqIoeqkEoSiKouilEoSi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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_w_mean, label=\"PBO optimal\", color=\"black\")\n",
    "\n",
    "plt.plot(iterations_validation, pbo_linear_w_mean[:-1], label=\"PBO linear\", color=\"blue\")\n",
    "plt.fill_between(iterations_validation, pbo_linear_w_confidence_interval[0, :-1], pbo_linear_w_confidence_interval[1, :-1], color=\"blue\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations_validation, pbo_custom_linear_w_mean, label=\"PBO custom-linear\", color=\"green\")\n",
    "plt.fill_between(iterations_validation, pbo_custom_linear_w_confidence_interval[0], pbo_custom_linear_w_confidence_interval[1], color=\"green\", alpha=0.3)\n",
    "\n",
    "plt.hlines(pbo_linear_w_mean[-1], 0, max_bellman_iterations_validation, color=\"blue\", linestyle=\"--\", label=\"PBO linear fixed point\")\n",
    "plt.fill_between(iterations_validation, pbo_linear_w_confidence_interval[0, -1], pbo_linear_w_confidence_interval[1, -1], color=\"blue\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations, fqi_w_mean, label=\"FQI\", color=\"red\")\n",
    "plt.fill_between(iterations, fqi_w_confidence_interval[0], fqi_w_confidence_interval[1], color=\"red\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations, lspi_w_mean, label=\"LSPI\", color=\"purple\")\n",
    "plt.fill_between(iterations, lspi_w_confidence_interval[0], lspi_w_confidence_interval[1], color=\"purple\", alpha=0.3)\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",
    "plt.yscale(\"log\")\n",
    "plt.title(r\"$|| w^* - w_i ||_2$\")\n",
    "plt.legend().set_zorder(9)\n",
    "plt.grid(zorder=0)\n",
    "_ = plt.savefig(f\"figures/distance_to_optimal_W_{max_bellman_iterations}.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Distance to optimal value function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "fqi_pi_mean = np.abs(fqi_pi - optimal_pi).mean(axis=0)\n",
    "fqi_pi_std = np.abs(fqi_pi - optimal_pi).std(axis=0)\n",
    "fqi_pi_confidence_interval = confidence_interval(fqi_pi_mean, fqi_pi_std, len(seeds))\n",
    "\n",
    "lspi_pi_mean = np.abs(lspi_pi - optimal_pi).mean(axis=0)\n",
    "lspi_pi_std = np.abs(lspi_pi - optimal_pi).std(axis=0)\n",
    "lspi_pi_confidence_interval = confidence_interval(lspi_pi_mean, lspi_pi_std, len(seeds))\n",
    "\n",
    "pbo_linear_pi_mean = np.abs(pbo_linear_pi - optimal_pi).mean(axis=0)\n",
    "pbo_linear_pi_std = np.abs(pbo_linear_pi - optimal_pi).std(axis=0)\n",
    "pbo_linear_pi_confidence_interval = confidence_interval(pbo_linear_pi_mean, pbo_linear_pi_std, len(seeds))\n",
    "\n",
    "pbo_custom_linear_pi_mean = np.abs(pbo_custom_linear_pi - optimal_pi).mean(axis=0)\n",
    "pbo_custom_linear_pi_std = np.abs(pbo_custom_linear_pi - optimal_pi).std(axis=0)\n",
    "pbo_custom_linear_pi_confidence_interval = confidence_interval(pbo_custom_linear_pi_mean, pbo_custom_linear_pi_std, len(seeds))\n",
    "\n",
    "pbo_optimal_pi_mean = np.abs(pbo_optimal_pi - optimal_pi)"
   ]
  },
  {
   "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_pi_mean[:-1], label=\"PBO linear\", color=\"blue\", zorder=7)\n",
    "plt.fill_between(iterations_validation, pbo_linear_pi_confidence_interval[0, :-1], pbo_linear_pi_confidence_interval[1, :-1], color=\"blue\", alpha=0.3)\n",
    "\n",
    "plt.hlines(pbo_linear_pi_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_pi_confidence_interval[0, -1], pbo_linear_pi_confidence_interval[1, -1], color=\"blue\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations_validation, pbo_custom_linear_pi_mean, label=\"PBO deep\", color=\"green\", zorder=8)\n",
    "plt.fill_between(iterations_validation, pbo_custom_linear_pi_confidence_interval[0], pbo_custom_linear_pi_confidence_interval[1], color=\"green\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations, fqi_pi_mean, label=\"FQI\", color=\"red\", zorder=9)\n",
    "plt.fill_between(iterations, fqi_pi_confidence_interval[0], fqi_pi_confidence_interval[1], color=\"red\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations, lspi_pi_mean, label=\"LSPI\", color=\"purple\", zorder=5)\n",
    "plt.fill_between(iterations, lspi_pi_confidence_interval[0], lspi_pi_confidence_interval[1], color=\"purple\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations_validation, pbo_optimal_pi_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",
    "plt.yscale(\"log\")\n",
    "plt.title(r\"$|P - P^i| \\propto || V^* - V^{\\pi_i} ||_2$\")\n",
    "# plt.legend().set_zorder(10)\n",
    "plt.grid(zorder=0)\n",
    "_ = plt.savefig(f\"figures/distance_to_optimal_Pi_{max_bellman_iterations}.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Visualise"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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UNm4byPj/jeOysZKZ2Bprc5cR2VjJWP/O5aN+zb2WNmGDh0KwO7duztcLzo6GovF4nz80EMPERMTw9y5c9us+7e//Y38/HweeOCBTl//iSee4JhjjiEyMpKMjAymTp1KdXU10NycMnXqVJf1P//8c3Q6HVu2bHEuW7JkCQMGDHDu4/TTT+fAgQN8/vnnnH322QD069cPnU7nciO/n376ifHjxxMVFUViYiLTp0/n4MGDzud3796NVqvlpZdeYsaMGcTFxZGTk8P//vc/AJYuXUpWVhapqanMmTOnyyMzWzcPff7552i1Wj7//HOmTp1KTEwM/fr14+GHH26z7dq1aznttNOIiooiOTmZK6+8ktraWufz+/fv5/LLL6dfv35ERkYycOBAbr/9dufNPh3vLzw8nBdffJFp06aRkJDQayEzlGtaJLQIIYKGyWpi8ouTabA0eLR+g6WByS9O7pGmIvgjrKSlpbkst1qtWK1WampqeP755/nyyy+dAQCaT5qnnnoqMTExbfap1WqZPHky69evx2q1tvvad911F9dccw0nn3wyr732Gg8++CCxsbFdqnn473//y5IlS7j++ut57733ePDBB+nXrx/19fUcd9xx3HvvvQCsWrWKr776ilWrVgFQVlbGmDFjaGho4H//+x/3338/a9euZcqUKS4ndoC5c+eSnp7Oq6++yujRo7nsssv45z//yYYNG3jiiSf4xz/+wdKlS3nllVc8LndHrrrqKo4++mhee+01TjnlFGbOnMmGDRucz3/99ddMmDCB1NRUXnnlFZYtW8aaNWuYMWOGc53y8nISEhK47777eO+997jpppt45pln+Pvf/97m9W699Vaio6N5+eWXmTNnjk/eg/iDNA8JIYLGql9XYbaZO1+xBbPNzGu/vsbFR13slzI5gsTOnTuZOXMm0dHRjB071vl8RUUF4eHhLtvMmjWLSy+91Pl47969TJkypd3XyM3NxWQyUVFRQWpqapvnDx06xJIlS/j73//Ov//9b+fyc845p0vvZePGjYwfP55rrrnG7T769+8PwDHHHENeXp5z+bJlywBYs2aNM3jl5eVxyimn8NprrzmbwQBOO+007rrrLgBGjBjBa6+9xurVq/nll1/QarX8+c9/5u233+bNN9/kwgsv7FL53bnwwguZN28eAKeeeirvvPMOb7zxBscffzzQHDJOOOEEXnrpJec2mZmZjB8/ni1btnDkkUdy1FFHsXTpUufzJ554IpGRkVxxxRWsWLECg8HgfG748OGsXLnS63J7S2pahBCil9277t52m4TaU2eu45519/ilPI5AEh4ezuDBg9m1axcvvPAC6enpznViY2P55ptv+Oabb/jiiy9Yvnw5zz33HHfeeafPyrF+/XoaGxuZPn26V/s5+uijWbNmDQsWLGDDhg3YbJ6NxnKEnZY1Rccffzy5ubl8/fXXLuuOGTPG+f+YmBiSk5M5+eST0ba4aVR+fj779u3z6r04jB8/3vl/vV7PEUccQUlJCQANDQ2sX7+e8847z1kbZrVaGT16NHq9nu+//x5obm65//77OfLII4mMjCQsLIxLL70Uk8lEcXGxy+tNmjTJJ+X2RqCMNvMHqWkRQgQFm93GL2W/dGvbX8p+wWa3odX49m6KsbGxfPDBByiKQlpaGhkZGW2ucHU6HcOGDXM+PvHEE7FarcybN4+ZM2eSkJBAZmZmm5NfS0VFRYSFhZGYmOj2+crKSgCXsNQdl112GbW1tTzxxBMsWrSIxMRErrzyShYsWOASKlrbv38/gwcPbrM8JSXFWTaHuLg4l8cGg8Htsqampm6/j85ez7HvqqoqbDYbM2fOdDtCyxFu7r//fm655RZuueUWTj75ZOLj4/nuu++YOXNmm3IGyrDrUK1pkdAihAgKdeY69Bq9c5RQV+g0OurMdcSG+/auiq0DiacGDhyI2WymsLCQhIQETjrpJN5++21qa2uJjo52Wddut7NmzRpGjRqFTuf+kJ2QkAA0h4ekpCS364SHh7fpX9J66LJGo+H666/n+uuvZ8+ePbzwwgvcfvvtZGVlcdVVV7X7ftLT0yktLW2zvLS0tFufT0+Ji4tDURTmz5/vtoYkIyMDaO7D85e//IVFixY5n/vlF/cBOhDCQijXtEjzkBAiKEQZorDYLZ2v6IbVbiXKEOXjEnXf1q1bAcjOzgbg2muvpbq6miVLlrRZ98knn2T79u1uO306jBo1ioiICJ577rl218nKyuK3335zWfbRRx+1u352djazZ8+mX79+/PrrrwDOvhutaxeOP/54PvzwQ5cRN9999x1FRUWceOKJ7b5Gb4uMjGTkyJH89ttvDBs2rM2PI7Q0NjYSFhbmsu0LL7zQG0U+7ElNixAiKGg1WgYnD2Zr2dYubzs4ebDPm4Y8ZbVa+eabbwAwm8388MMP3H333Zx55pnOUUZDhw5l4cKFzJs3j3379jF16lQMBgPvvvsuDz30EFdddRVnnnlmu68RFxfHvHnzuP3227FYLPz5z3/GbDbz3nvvcfvtt5OZmclZZ53FU089xS233MLpp5/O2rVr+eCDD1z2c8011xAfH8/IkSOJiYnh888/Z/v27c65YwYMGADAY489xgUXXIDRaOSoo47ihhtu4JFHHmHSpEncfPPN1NXVMXfuXI488kj+8pe/+ONj9ZklS5Ywfvx4NBoNf/nLX4iOjqa4uJj33nuPRYsW0b9/f8aNG8cDDzzAiBEj6Nu3Ly+88ILLzMeBJpSHPEtoEUIEjVtOuIXr1lzXpc64UYYoZp8w24+l6lh1dTWjR48GmjuC5ubmcuWVVzpHtDjMnj2bwYMHs3z5ci666CJsNhtDhgzhkUceYdq0aZ2+zpw5c0hISOCBBx7gscceIz4+npNOOsnZ3DR58mQWLVrEww8/zLPPPsuZZ57J8uXLXUYHjRw5kieeeILHH3+cpqYm+vXrx6OPPuqcbyQ3N5d7772XlStX8uCDD5KVlUVhYSHJycl88skn3HzzzVxyySUYDAYmTpzIvffe6zKyJhCNHj2azz//nAULFjBt2jRsNhu5ublMnDjROVLr9ttvp6ysjNtvvx1oHlH1n//8J6An+wvV0KJ00vYVug1jPqCqKsceeyxr16716X43btzI8OH+m8VTtE8++55RXFzMwIEDAZz9LDw5uZmsJrLvz6aysbLTdR0SIhLY8489hOnCOl+5B7g75rZe5s/HNpsNRVFcTmqdbe8JrVaLVqtFp9Oh0Wi69Hv1pbq6OqKieqcp0B/vuaCgwGUSP09s3LiRo48+2m05HL/b1sPwA5Db1CU1LUKIgNX65KnX6HnngncY9/w4jyaYM+qNvHX+W2hUDRaLxeuTv6frdKb1VbC7q+LO1unocetQ0vp5jUbTplOvJ2Vqj6Io2Gw2bDYbTU1NztlsNRoNGo0GrVYbslf+omdJaPGC40sYyu2HIjioqordbkdVVZef1su6+rg763S2PkB8fLzzpoKOZS2ntW+p9XfrqMSjeG/qe5zz2jlYbBbqLG2biqL0Uei1et467y2Gpg11CRZdObl353Ggs1qtzjDhS46aFsfVvclkwm63Y7VaMZlMqKrqrInRarU+f33xh1A+J0loEYeV1idbdyfcurq6Xj/xtzzBe0pRFDQajfNE3PL/7S3z5LFOp+vSNp6sU1xcTGRkJNC9KvXRfUZTcn0Jr/36Gvesu4dfyn5Bp9FhtVsZkjyEW064hb8M+kvANAkdjhRFQafTodfrgT+CtdVqxWKxYLfbnbUwjp9QONGGwnsIZBJaRLt8dVJ2t74n63QlHHRFRydYxwyXHZ2Q3YUDX4eFlj/CvTBdGBcfdTEXH3UxNruNOnMdUYaoXhslJDqmKIoznDjY7XZsNhsWiwWTqfn+UC1DjNTGdI/UtIgOOa4eVFVFp9N5fTVusVjYt2+fT67gfX317ouTsuP/HZ3ou/MavrBx40a3M3uKwKbVaH0+cZzwP0fgb1kb4+gb07I2xtGk1NGsvOLwcFiEFlVVWbx4MQ8//DDl5eUMHz6cFStWcMwxx3S43fz583n99dcpKipynvxTUlJISEhwnvz37NnD8ccfj1ar5bTTTuOCCy7o9pW1Y5kjbHT1RC5X70KIQNGdq31Hk1LLTsKOi0Kz2ewc+dRypFIgHc8CpYYjUMrhD4dFaFmyZAkLFy5k6dKlDBw4kGXLljFu3Di2bNnS5hbyLdXU1DB9+nQGDx6MVqtl1apVPP744yxdupTzzjsPaL7b6ZdffunTP5CDBw+SlZXls/0JEdKsVti9G5qaIDwc8vKgnenuRfBN8a7RaFz6O7WsjWloaHB28JWamMNDyH+zm5qaWLJkCXPnznXeEGvUqFHk5eWxcuVKl3tJtLZ8+XKXxxMmTGDr1q0899xzztAihOgFFRUoTz+N8uyzUFgIej1otWCzgdkM/fqhTpuGOmMG/H5fHhEaWtbGOKbWd4QYs9mM3W6nvr7epUkpVGsd2tNZTUswfx4h38tp3bp11NTUMHXqVOeyyMhIzjjjDNasWdPl/SUmJra56ZgQooeYzSi33YYmNxfljjtQfv0VxWxGqa9Hqalp/tdiaV5+xx1ocnJQbrutOciIkOUYah0REYFGo8FoNKLRaLBarTQ0NFBXV0djY6Mz1IjgFfI1LQUFBWi1Wo444giX5YMGDeLll1/2aB9Wq5W6ujreffddPvzwQ1566SV/FFUI0ZHiYjQTJsC+fSitbtjnjtLY2PyfFStQVq3C/uGHkJPj50KKQKAoCnq93tnBF2gz+V0oDrduKdTej0PI17RUVVURFRXVpq0zPj6ehoaGTmtNvvnmG/R6PfHx8UyfPp3777+fs88+248lFkK0UVyMZsQI2LULpaHzmXBbUhoaYNeu5u2Li31WpDvuuMPZTNHyZ8KECc51KioquPHGG8nPz8doNJKTk8OVV15JSUlJm/3pdDoefPBBn5VPuHLUxhiNRqKioggPD3epjamvr6exsdE5aimYBVu/pa4IqZoWRwctB18kzaOOOoqNGzdy6NAh3n33XWbOnElMTAwXXXSR1/sWQnjAbG6uYamsRGnx/e4KxWZDraxEM3Ei9s2bm/vA+EBsbCzvvvtum2UA+/bt49RTT8VsNjNnzhwGDRpEcXEx9913H8cffzyfffaZ867Joud5Oty65f2Ugqn2IpjK2hUhFVq++OILTjvtNOfjU045halTp1JXV4fNZnOpbamqqsJoNHY6C2dkZCTDhg0DYNy4cVRXVzN79mwJLUL0EOXOO5ubhLoZWJz7sdlQ9+5FWbgQ9c47fVI2nU7HyJEj3T43c+ZMDh06xI8//khmZqZz+VlnncWIESOYNm0a33zzjU/KIbzX3nDrlh18QSa/620h9YkPHTqUjRs3On8effRRBg4ciM1mY8eOHS7rFhQUOO8y2xXHHXcce/bswWq1+qrYQoj2VFSg/Oc/XW4Sao/S0ICybBlUen6X6O7YvXs3q1evZtasWS6BBSAmJoa5c+fy3XffsW7dOr+Woz2hehXua46amIiICCIjIzEajeh0Oux2O01NTdTV1Tm7Gdi8DNXCMyEVWqKjoxk2bJjzZ8CAAZxwwgnExMTw6quvOtdraGhg9erVTJo0qcuv8fXXX5OVldXmDqlCCN9Tnn4afH2CVZTm/fqI1Wp1+VFVla+++gpVVTnrrLPcbuNY/uWXX/qsHML/HLUxYWFhLn1joPkeWmazGZPJRFNTk9u7igvvhfyZNzw8nDlz5rBw4ULi4+Odk8vZ7XZmzZrlXO+5555jxowZFBYWkpubS1FRETNmzODCCy8kPz+furo63njjDV566SUefvjhXnxHQhw+lGef/WMUkK/22dgIzz6LetNNXu+roqLCedJyeP/999m7dy8Aubm5breLjY0lNjbWuZ4IXi0nvzOZTM6+L+1NficT4Hkn5EMLwJw5c7Db7SxevJiKigqGDRvGRx99RGpqqnMdR9ulIxnHxcWRkZHB3Xffzf79+4mLi2Pw4MG8++67nH766b31VkQPCOUpsIOK1do8cZw/7NjRvH8va0xjY2P54IMPXJYNGDCA77//3qPt5e8s9HQ2+Z3jVgSH8+R33jgsQouiKMybN4958+a1u8706dOZPn2683FsbCz//e9/Pdq/P05ycuIUh73du5tH+fhjYji9vnn//fp5tRudTufsqN+Sox9LUVERf/rTn9o8X11dTXV1dYe3ERGho3UNi6qqzuZEk8nkUhvjGKkk3JNPxksajUbaLYXwh6am5qn5/UGjad6/n4wePRpFUVi9erXb5x3LR40a5bcyiJ7n6bnAMfldeHg4kZGRREVFOZuYWnbwNZlMzhtGimaHRU2LPymKgt1ul3ZKIXwtPLz5XkL+YLc3799P8vLyOOOMM1ixYgUzZswgPT3d+VxdXR133303ffv25ZRTTvFbGURwcdS0OMKLo8uCzWZj48aNQPPIs/j4eOLi4oiIiDgsa+MltHjJHzUtiqJI81Avks8+QOTlgcXin31bLM3796OVK1dy6qmncuKJJzJ79myXyeV2797Nxx9/HPLNAPI96r6Wk9+NGjUKm81GdXU1hw4doqCggIaGBoxGozPExMTEeHzxHMy/FwktXnLUtIjQEMxf5pCj00F+Pvz6q+/33a+f151wO5ORkcH69eu56667uPfeeykpKcFms5GSksL69es5+uij/fr6IrRotVoSEhJI+P2u5aqq0tjYSFVVFfv27aOgoABFUYiNjcVisdDU1NRmZFsoCO2Y3wOkT4sQ/qNOm4YaEeHbfUZEoE6b5vV+5s+fz8GDBztcJzExkWXLllFYWIjJZOKxxx6jtLSUrVu3tlnXarVy3XXXeV2uw93hcuGhKApGo5HMzEyGDBnCqFGjGDZsGMnJydjtdrZs2cLXX3/NTz/9xO7du6murg6JC2ypafGSRqPx+R+Co3lIiMOdOmMGyoIFPt6pinrZZb7dp4dmzJjBzz//zN/+9jdycnIYPXp0r5RDhCadTkdSUhJhYWEMGzYMVVWpr6+nqqqK4uJiamtr0Wq1HHXUUZ3ewiZQSWjxkjQPCeFHCQmo118PK1b4ZCp/1Whs3t/vVey9Yfny5SxfvrzXXr+nyIVX71MUhaioKKKiosjOzgaaJ8DT++iGob1Bmoe85K/mIfnCC9FM/de/ICMD1csReqpWC5mZqLff7qOSCRF8DAZDUI92ldDiJX/UtBwubbKBSgJjgDEYsH/4YXOtSzcPtqpWCwkJ2D/4oHliORGS5Lsb+iS0eEn6n4QWCYwBKicH+7ffQp8+qEZjlzZVjUbo27d5+5wcPxVQCNETJLR4yV81LRKEhGglJwf75s2o//gHanh4m1FFda1WV43G5vWuvx775s0SWESPCPQLn2A/t0ho8ZIMeRaiBxkMqAsXYi8uRl2wAHXwYFSDgX0REaQA+yIiUA2G5uXz5zevd+ed0iQkRIiQ0OIlfwx5FkJ0IiEB9aabsG/ejL2mhtdvvplG4I1bbsFeU9NcI3PTTb06SkgI4XsSWrwkzUNC9DKdjmfefReg+V8/z3QrRHuC5bgd6E1YHZHQ4iVpHgotEhiDT1lZGT///DMAmzdvpry8vJdL1HWPP/44b731Vpvl+fn53HzzzT1WjjFjxjB16tQee71A9uGHH3L//ff3djFEK0ERWhYsWICiKBxxxBFunz/iiCNQFIUFvp450wMy5FmI3vX22287J8vS6/W8/fbbvVyirnviiSfchpZVq1Yxa9Ysn76WhHLPfPTRRxJaAlBQhBaA8PBwdu3axXfffeeyfOPGjezevbvXbgwlk8sJ0bueffZZ6uvrAaivr+fZZ5/t5RL5zrHHHkvOYTTqqbGxsbeL4DdNTU29XYSQEDShJTIykjFjxvDSSy+5LH/ppZcYM2YMkZGRvVIumcZfiN5z6NAhtxcyhw4d6pHXf/XVVznmmGMwGo3k5eVx2223YbVanc8/++yz6HQ6Nm7cyCmnnEJUVBSDBg3izTffdK4zZswYvv/+e5577jl0Oh06nc4ZvFo3D82YMYMRI0bw7rvvctRRRxEdHc0ZZ5xBZWUlO3bsYOzYscTExDBixAg2b97sUtZly5YxcuRIMjMzyc7O5qyzzmLHjh1dfs+OJqTHH3+c/Px8oqKimDJlCnv37nVZ7/bbb+e4444jJiaGnJwc/u///o8DBw64rNO3b1/++c9/smjRInJycoiLiwNg/fr1nHXWWWRmZhIdHc1xxx3H888/77LtM888g1ar5YcffmDMmDFERUUxdOhQfvrpJ+rr65kxYwbx8fH069ePF198sc37eOuttzj++OMxGo1kZGQwe/ZsLBYLAHfccQfLli2jqKgIrVaLVqvlshb3q1q7di2nnXYaUVFRJCcnc+WVV1JbW9umbBs2bHCen+677z4AlixZQv/+/TEajaSnpzNp0qQ2n4toX1D1WLvwwgtZsGABS5cudfY9eOWVV7jzzjv5/vvve6VM/qhpkeYhIZr98MMPfPbZZ+0+X1BQgMFgwGw2O5cZDAZuueUWBgwY0O52p512Gscdd5xXZfvwww+56KKLuPTSS1myZAk///wz8+fPp7Kykoceeshl3Ysvvpirr76aOXPm8NRTT3HBBRewYcMGjj76aFauXMnUqVPp06cP8+bNA5rDSnuKi4u54447uPPOO2loaOAf//gHV199NUVFRVx++eX885//5LbbbuOSSy5h8+bNzuNJSUkJ1157LWlpaTQ0NPDEE09w0kknUVBQQGxsbJfe+zfffMO2bdu47777aGpqYu7cuZx77rl8++23znXKysqYPXs2WVlZlJWVsXz5csaNG8fmzZvRaP64Xn7xxRcZMmQIK1eudAa+oqIiTjzxRK666irCw8NZt24dl19+ORqNhosuusilLJdddhnXXnstN998M7feeit//etfOf7448nPz+eVV17h6aefZvr06Zx00klkZWUB8Morr3DJJZdw5ZVXsmjRIgoLC5k3bx52u52lS5dy+eWXs337dj777DNee+01AJKTkwH4+uuvmTBhAmeddRavvPIKFRUV3HrrrVRVVfHcc8+5lO2SSy7hmmuu4fbbbycuLo7nnnuOxYsXs2TJEgYPHkxFRQWfffaZs6ZQdC6oQsu5557LNddcw1dffcVJJ53E2rVrKSsr49xzz+3Rzmot+aumRZqHhID9+/c7ay/au19Ky5oNgLq6ujYnDwebzYZOp2PVqlVel23BggWccsopPP300wD8+c9/BmDevHnceuutzhMkNNeQ3HTTTQBMnDiRo446invuuYcXXniBwYMHExkZSXJyMiNHjuz0dSsrK/nqq6+cwWbz5s38+9//5umnn+bSSy8Fmo8fZ555JgUFBQwaNAhormmB5iYYrVbLxIkTSU9P5+2333Zu56nS0lK++uorZ9NVbm4uJ598Mu+//77zc3jkkUecNUc2m41Ro0aRk5PDV199xcknn+yyv7ffftulif/CCy90/l9VVU4++WRKSkp48skn24SWG2+8kWnTpgFgt9s588wzOfXUU1m0aBEAxx9/PK+99hqrV6/mmmuuQVVVZs+ezaWXXsqDDz7o3E9YWBizZs1izpw5ZGVlkZ6eTlhYWJvfya233soJJ5zgUuufmZnJ+PHjmT17Nscee6xz+axZs/j73//ufPzUU08xfvx4rrnmGueyc88915OPXPwuaJqHAOLi4vjzn//s/GN56aWX+POf/9zlqwRfktFDoUVGDwWWyZMn8/3335OXl4der8dqtbb5ccfdenq9nj59+vD9998zefJkr8pls9n48ccfOe+881yWT506FbvdzjfffOOy/Oyzz3b+X6PRcMYZZ7Bx48ZuvXZeXp5LTUy/fv2A5tqj1staNtl88803TJw4kZycHIxGI9HR0dTV1bFt27Yul6F1X5sTTzyRlJQUl/f0wQcfcMoppxAfH4/BYHCu3/r1xowZ06ZPYlVVFf/4xz/o06cPYWFhhIWF8fjjj7st69ixYzv8LGJjY0lOTmbfvn3O1y8uLub88893+fsYM2YMTU1NbNmypd333dDQwPr16znvvPNcth09ejR6vZ6ffvrJZf3TTz/d5fHRRx/NmjVrWLBgARs2bMBms7X7WsK9oAot0JzAV61ahclkYtWqVS6JvDf4q3lITpxCNBs8eDA///wzF198McYu3nfIISIigosvvpjNmzczePBgr8tUXl6OxWIhNTXVZbnjcWVlpcvylJSUNo/379/frdd29PtwMBgMbZY7ljk6fxYXFzNp0iRUVWXFihV88cUXfPPNN6SkpHSrg2jr9+NY5nhPGzduZOrUqWRmZvLss8/y9ddfs27dOgBMJpPLdq0/Q2hu8nnllVf45z//yfvvv8+3337LZZdd5ras7t63u8/Isa1jSPyUKVOcgSgsLMwZBPfs2dPu+66qqsJmszFz5kyXbSMiIrBYLJSUlHT43mbMmMFdd93Fq6++yqhRo0hPT+f222+X8NIFQdU8BHDmmWdyxRVXMG/ePOrr6znjjDN6tTzSEVcI/wsPD+fRRx9l8uTJTJs2jcbGxnZrWVrS6XRERETw3HPP+fRYkZSUhF6vp7S01GX5wYMHAUhoNRNvaWkpiYmJLo/T09N9Vp7OfPDBBzQ0NPDGG2+g0WgICwvDbre3CVeeav2+Hcsc7+nNN98kKSmJF154Ad3vk/0VFRW53VfrPnxNTU28++67PPDAA1x99dXO5b46zjp+N4888ohLU45Dnz592t02Li4ORVGYP38+kyZNcrvvlu+n9XvTaDRcf/31XH/99ezZs4cXXniB2267jczMTJf3KtoXdKElMjKSKVOmsHz5cs4///xeGzXkIM1DQvScM888k59//pm//OUvFBQUdNiBMTIykkGDBvHaa6+RmZnp03JotVqOO+44Vq1a5XKyefXVV9FoNG36Qbz55pvOviV2u53Vq1czfPhw5/N6vd6vQ2IbGxvRaDTodDrnyf/VV1/1KPi58+OPP1JcXOxs8vn6668pLS11vqfGxkb0er3LSfuFF17waN8mkwm73U5YWJhzWW1tLatXr+50kIInx+IBAwaQmZlJUVERf/vb39pdr2XtjENkZCQjR47kt99+4/bbb2+zTVeGbGdnZzN79myeeeYZfv31V4+3O9wFXWgBuOaaazCZTAGRTGUafyF6VlZWFrfeeivTp0/vcD2NRsOtt97q88DiMH/+fE4//XQuv/xypk6dypYtW5g/fz5XXHGFSydcaO6AaTAYGDJkCE899RQ7duzgf//7n/P5gQMH8uGHH/LBBx+QmJhInz59XGpmvHXaaadhs9m4/PLLueSSS9i+fTvLly9v04ziqeTkZM4880zmz5/vHD103HHHOTvhjhs3jvvvv5+bbrqJM844g/Xr17cZstye2NhYhg8fzqJFi4iJiUGj0XDvvfcSGxtLTU1Nt8rbkkajYenSpUybNo2amhr+/Oc/YzAY2LlzJ2+99RavvvoqRqORAQMGcPDgQZ555hmOPPJIkpKSyMvLY8mSJYwfPx6NRsNf/vIXoqOjKS4u5r333uO2227jyCOPbPe1r776ahISEhgxYgSxsbF8/vnnbN++ncWLF3v9vhxC/dwRdH1aAE499VTefPNNTj311N4uitS0CNEL/vvf/7rMi+FObW2tSzDwtQkTJvDCCy/w/fffc/bZZ7NixQpuuOEGVqxY0Wbd559/njfffJO//OUvbN68mRdffNGlaeLWW29l4MCBXHTRRYwcOZJ33nnHp2U96qijeOqpp9iwYQPnn38+L730Ei+99FK3BzGMGjWKa665hhtvvJG//e1vDBkyhNdff935/Omnn87ChQt54403OPvss/nyyy+7NFPx//73P/r27cv06dO54YYbOPfcc7s8wqkjF1xwAW+88QabNm3iggsu4LzzzuORRx7huOOOc/aLmTp1KtOmTWPOnDmMGDGCO+64A4DRo0fz+eefU1ZWxrRp0zjrrLO4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dus4wbsbvREREUFTUxP/+Mc/GDduHH/6058wGo3Ex8d7NHojIiLCZaSMhAkhhAhsElqE34wePZp169Yxa9YsoqKi2q2RaB0kWs794kmQKC0tpbCwkFGjRvnz7QghhOhlEloCUKjcORqam1oeffRRv75GSkoKKSkpfn0NIYTwN1VVWbx4MQ8//DDl5eUMHz6cFStWcMwxx7S7jc1m47777uOdd97hl19+AWDo0KHcddddDB8+vIdK3nOCY8auw0yo3TlaCCFE55YsWcLChQuZPXs2q1evJioqinHjxnHgwIF2t2lsbGTJkiUMHz6c//73v/zvf/9Dr9czevRovv/++x4sfc+QmpYANGnSJJYuXUptba1zwraXX36ZiIgITjnllF4unRBCCF9rampiyZIlzJ07l5kzZwIwatQo8vLyWLlyZbtzdEVERLBz506XWvixY8fSv39/Vq5cydNPP90j5e8pUtMSgK6++mrCwsI499xz+fjjj3nsscdYsGABN954o8scLf369ePyyy932XbNmjWsWrWKn376CWieT2XVqlVub8wohBAiMKxbt46amhqmTp3qXBYZGckZZ5zBmjVr2t1Oq9W26TZgMBgYMmQI+/bt81t5e4uElgAUHx/PJ598gs1m44wzzmD+/PnccMMN3HHHHS7rWa1WbDaby7JrrrmG888/nyeffBKA888/n/PPP5/PPvusx8ovhAhsqqpy9913k52dTUREBCeffLLzQqc9NpuNe+65h5NOOonExEQSExOZMGECGzdu7JlCh7iCggK0Wi1HHHGEy/JBgwa16S7QGZPJxA8//NDt6SYCmTQPBajBgwfz6aefdrjO7t27PVomhBAtOfpOLF26lIEDB7Js2TLGjRvHli1bSEtLc7uNo+/EZZddxty5c50zbztGCQ4dOrSH30Voqaqqct4ZvaX4+Hjn/bdaThzZkbvuuovKykpnM1MokdAihBCHEek70ftUVXWpJfflHFHvvvsud911F//+978ZMGCAz/YbKKR5SAghDiPSd6L3ffHFF+j1eufP2LFjiY+Pp66urk2Tf1VVVZu7j7dn48aNXHDBBVx99dVcf/31fip975LQcpj55ZdfGDt2LEajkYyMDP71r3+1+ZK0tnHjRi677DL69euH0WhkwIAB3HHHHTQ1NfVQqUWw6U6fCYCPPvqIiy66iLy8PBRFYcGCBX4v6+FG+k70vqFDh7Jx40bnz6OPPsrAgQOx2Wzs2LHDZd2CggKPprrYtm0bkydPZuzYsaxYscJfRe91EloOI1VVVYwbNw5FUXjrrbf417/+xb///W/mz5/f4XYvv/wyhYWFzJ49m/fee4/rrruOZcuWcckll/RQyUWw6c58EwDvv/8+mzdvdgZr4Xue9J3wVCj3nfCn6Ohohg0b5vwZMGAAJ5xwAjExMbz66qvO9RoaGli9ejWTJk3qcH/79+9n4sSJ5Ofn8+KLL7b53YYUxw3j2vkRIeTuu+9W4+Li1Orqaueye+65R42IiHBZ1lpZWVmbZY8++qgKqLt37/ZLWUXwamxsVGNiYtQ77rjDuayurk5NSkpS582b1+G2NpvN+f/ExER1/vz5/irmYcFut6sWi8X5Y7Va1UWLFqmxsbFt1n388cdVQDWZTB7t+5133lE1Go26fPly3xb6MHb33XerERER6sqVK9WPP/5YPf3009XExET1wIEDznWeffZZVavVOo+9DQ0N6tFHH63Gxsaq77zzjrp+/Xrnzw8//NBbb8UX3OYSqWk5jKxZs4aJEye6zPVy4YUX0tjYyBdffNHudklJSW2WHXvssQDSli3a6G6fCcDlBpbCe9J3IrjMmTOHefPmsXjxYqZMmUJNTQ0fffQRqampznXsdrvLTWUPHjzIpk2bqK6uZsqUKYwaNcr5c8455/TWW/EbOUIcRty1jebk5GA0Grvclr1+/Xo0Gg35+fm+LGK7utMXB6C6uprLLruM+Ph4YmNjueSSS6ioqOiBEh++fNlnQnhH+k4EF0VRmDdvHiUlJTQ2NrJ27VrnBaLD9OnTUVWVvLw8APLy8tptLQnFKTBkyPNhpKqqiri4uDbL4+Pjqaqq8ng/Bw4cYNGiRVx66aU9cqNCR1+cwYMH89Zbb1FYWMhNN92E3W5vd3imw9SpU9m2bRtPPPEEGo2G2bNnc/bZZ7N27Vq/l/tw5cv5JoR3HH0nWsrNzXX2nbjtttuAP/pOXHnllR3u77DqOyECkoQW0SVms5mpU6cSFRXF8uXLe+Q1H3nkERobG3n99deJiYlh/Pjx1NTUsGDBAm655RaX5q6W1q9fz4cffsgXX3zBySefDEBmZiYjRozg448/Zty4cT1S/lCm+nG+iWC0YMECVq5cSXl5uXOZ3W7n0ksv5bXXXuOtt95i4sSJvVhCCA8PZ86cOSxcuJD4+Hjn5HJ2u51Zs2Y513vuueeYMWMGhYWF5Obm0tjYyKRJk6iqqmLlypVs3rzZuW5YWFibGgEh/EGahw4j8fHxVP9/O3cTUtW6BnD8OVREgyBpECQYUYOaBUWQSEJEsSEhigYRbawIGjhIR5FQNtFR1KAgKkgk+nLTF2RYSQgRDZr2MRJEoigkDkGDKL2Di5vjzW7isXaP/n7gYL+uBe+e/XnXs9fff3+3/vHjx+/evzCR0dHRKBaL8eLFi+jp6ZnUPdNhqrM49+/fjyVLlpSDJSJi/fr1sXz58p/OVjA5v2pmYqYYHR2NgwcPRnd3d5RKpYoHyxizE2TlpGUWWbVq1XczBUNDQ/H58+dJPcs+fPhw3LlzJx4+fDip66fL69evY9OmTePW/jmL09DQ8MP7Jtqn2YrpMzYzMWbhwoXx5s2b8szEP9/IOdmZiZmkqakpurq64tq1a7Ft27ZKb6dsbHaitbX1h9c0NjZGY2Nj+fPY7ARUkpOWWaRQKERvb298+vSpvHb9+vVYsGBB1NfX/997Ozo64syZM3H58uWoq6v71VsdZ6qzONM1w8OPTff7JmaSlpaWOHfuXHR1dcXOnTsrvR2YEUTLLHLo0KGYP39+7NixIx49ehTnz5+Ptra2aGlpGffoZeXKlXHgwIHy5ytXrsTRo0ejWCxGdXV1PHv2rPz34cOHSnwV/mBjMxPt7e1x9uzZ6Ovri127dk04MzF37twYHBwsrw0ODkapVIpSqRRfvnyJly9fRqlUSvc4r7W1NU6fPh0XL16M3bt3V3o7MGN4PDSLVFVVRV9fXzQ1NUVDQ0MsWrQompubv3tV+tevX8fNIzx48CAiIjo7O6Ozs3PctZcuXRp3hPyr9j2VWZyqqqoJo2qyMzxM3ZEjR2JkZCQ6OjpieHg41q1b99OZiYiIx48fx759+8qfu7u7o7u7O5YtW5bm55vDw8PR3t4ezc3N474L8O/99ZNnlB5gUnEbN26M6urquHr1anltaGgoampq4u7duz+caTl27FhcuHAh3r59O259xYoVsX379jh58uQv3TezT1tbW5w6dSpWr14dr169iv7+/lizZk2ltwUZTfhTRI+H+ONNdRanUCjEu3fv4smTJ+W158+fx8DAwKyareD3mjdvXty7dy+WLl0ahUIhBgYGKr0lmDFEC3+8qc7ibNiwIbZs2RLFYjFu3rwZt2/fjj179kRdXZ13tPBLLV68OHp7e2POnDmxdevWeP/+faW3BDOCaOGPNzaL8+3bt2hoaIjjx49Hc3NznDhxYtx1/zuLE/HfE5n6+vrYv39/FIvFWLt2bdy6det3bp9ZqqamJnp7e2N4eDgKhcK4k0Jgasy0AEyTid6I+/Tp09i8eXPU1tZGT0/PrHq5HvwLZloAfrfa2tq4ceNG9Pf3x969e2NkZKTSW4K0nLQAAH8aJy0AQF6iBQBIQbQAACmIFgAgBdECAKQgWgCAFEQLAJCCaAEAUhAtAEAKogUASEG0AAApiBYAIAXRAgCkIFoAgBRECwCQgmgBAFIQLQBACqIFAEhBtAAAKYgWACAF0QIApCBaAIAURAsAkIJoAQBSEC0AQAqiBQBIQbQAACmIFgAgBdECAKQgWgCAFEQLAJCCaAEAUhAtAEAKogUASEG0AAApiBYAIAXRAgCkIFoAgBRECwCQgmgBAFIQLQBACqIFAEhBtAAAKYgWACAF0QIApCBaAIAURAsAkIJoAQBSEC0AQAqiBQBIQbQAACmIFgAgBdECAKQgWgCAFEQLAJCCaAEAUhAtAEAKogUASEG0AAApiBYAIAXRAgCkIFoAgBRECwCQgmgBAFIQLQBACqIFAEhBtAAAKYgWACAF0QIApCBaAIAURAsAkIJoAQBSEC0AQAqiBQBIQbQAACmIFgAgBdECAKQgWgCAFEQLAJCCaAEAUhAtAEAKogUASEG0AAApiBYAIAXRAgCkIFoAgBRECwCQgmgBAFIQLQBACqIFAEhBtAAAKcz9yf//+i27AAD4CSctAEAKogUASEG0AAApiBYAIAXRAgCkIFoAgBT+A9LEVtnzp19GAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 720x720 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",
    "\n",
    "fig = plt.figure(figsize=(10, 10))\n",
    "ax = fig.add_subplot(111, projection=\"3d\")\n",
    "\n",
    "ax.scatter(pbo_linear_w[0, :, 0], pbo_linear_w[0, :, 1], pbo_linear_w[0, :, 2], label='PBO linear', color=\"blue\", s=200, zorder=4)\n",
    "ax.scatter(pbo_custom_linear_w[0, :, 0], pbo_custom_linear_w[0, :, 1], pbo_custom_linear_w[0, :, 2], label='PBO custom linear', color=\"green\", s=200, zorder=5)\n",
    "ax.scatter(fqi_w[0, :, 0], fqi_w[0, :, 1], fqi_w[0, :, 2], label='FQI', color=\"red\", s=500, zorder=2)\n",
    "# ax.scatter(lspi_w[0, :, 0], lspi_w[0, :, 1], lspi_w[0, :, 2], label='LSPI', color=\"purple\", s=np.linspace(600, 60, max_bellman_iterations+ 1), zorder=3)\n",
    "# ax.scatter(pbo_optimal_w[:, 0], pbo_optimal_w[:, 1], pbo_optimal_w[:, 2], label='PBO optimal', color=\"black\", s=np.linspace(100, 10, max_bellman_iterations_validation + 1), zorder=1)\n",
    "ax.scatter(optimal_w[0], optimal_w[1], optimal_w[2], label='optimal parameters', color=\"black\", marker=\"*\", s=500, zorder=0)\n",
    "\n",
    "plt.legend(bbox_to_anchor=(0.9, 0.7))\n",
    "ax.view_init(5, 75)\n",
    "ax.set_xlabel(\"K\")\n",
    "ax.set_xticks(np.linspace(0, optimal_w[0], 4), labels=np.around(np.linspace(0, optimal_w[0], 4), 1))\n",
    "ax.set_ylabel(\"I\", labelpad=10)\n",
    "ax.set_yticks(np.linspace(0, optimal_w[1], 4), labels=np.around(np.linspace(0, optimal_w[1], 4), 1))\n",
    "ax.set_zlabel(\"M\")\n",
    "ax.set_zticks(np.linspace(0, optimal_w[2], 4), labels=np.around(np.linspace(0, optimal_w[2], 4), 1))\n",
    "_ = plt.savefig(f\"figures/visu_3D_{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
}
