{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Plots with confidence interval"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "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_states_x = 17\n",
    "n_states_v = 17\n",
    "max_bellman_iterations = 9\n",
    "max_bellman_iterations_validation = max_bellman_iterations + 10\n",
    "seeds = range(1, 2)\n",
    "n_seeds = len(seeds)\n",
    "ticks_freq = 3 if max_bellman_iterations == 6 else 5"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## General case"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Extract data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "fqi_q = np.zeros((n_seeds, max_bellman_iterations + 1, n_states_x, n_states_v, 2))\n",
    "fqi_v = np.zeros((n_seeds, max_bellman_iterations + 1, n_states_x, n_states_v))\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_v[idx_seed] = np.load(f\"figures/data/FQI/{max_bellman_iterations}_V_{seed}.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((n_seeds, max_bellman_iterations_validation + 2, n_states_x, n_states_v, 2))\n",
    "pbo_linear_v = np.zeros((n_seeds, max_bellman_iterations_validation + 2, n_states_x, n_states_v))\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_{seed}.npy\")\n",
    "    pbo_linear_v[idx_seed] = np.load(f\"figures/data/PBO_linear/{max_bellman_iterations}_V_{seed}.npy\")\n",
    "\n",
    "PBO_linear_max_linear_q = np.zeros((n_seeds, max_bellman_iterations_validation + 1, n_states_x, n_states_v, 2))\n",
    "PBO_linear_max_linear_v = np.zeros((n_seeds, max_bellman_iterations_validation + 1, n_states_x, n_states_v))\n",
    "\n",
    "for idx_seed, seed in enumerate(seeds):\n",
    "    PBO_linear_max_linear_q[idx_seed] = np.load(f\"figures/data/PBO_linear_max_linear/{max_bellman_iterations}_Q_{seed}.npy\")\n",
    "    PBO_linear_max_linear_v[idx_seed] = np.load(f\"figures/data/PBO_linear_max_linear/{max_bellman_iterations}_V_{seed}.npy\")\n",
    "\n",
    "samples_count = np.load(f\"figures/data/samples_count.npy\")\n",
    "samples_mask = samples_count\n",
    "samples_count_q_format = np.repeat(samples_count[:, :, None], 2, axis=-1)\n",
    "samples_mask_q_format = samples_count_q_format"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Distances with the optimal Q function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "fqi_q_mean = np.sqrt(np.mean(np.square(fqi_q - optimal_q) * samples_mask_q_format, axis=(2, 3, 4))).mean(axis=0)\n",
    "fqi_q_std = np.sqrt(np.mean(np.square(fqi_q - optimal_q) * samples_mask_q_format, axis=(2, 3, 4))).std(axis=0)\n",
    "fqi_q_confidence_interval = confidence_interval(fqi_q_mean, fqi_q_std, n_seeds)\n",
    "\n",
    "pbo_linear_q_mean = np.sqrt(np.mean(np.square(pbo_linear_q - optimal_q) * samples_mask_q_format, axis=(2, 3, 4))).mean(axis=0)\n",
    "pbo_linear_q_std = np.sqrt(np.mean(np.square(pbo_linear_q - optimal_q) * samples_mask_q_format, axis=(2, 3, 4))).std(axis=0)\n",
    "pbo_linear_q_confidence_interval = confidence_interval(pbo_linear_q_mean, pbo_linear_q_std, n_seeds)\n",
    "\n",
    "PBO_linear_max_linear_q_mean = np.sqrt(np.mean(np.square(PBO_linear_max_linear_q - optimal_q) * samples_mask_q_format, axis=(2, 3, 4))).mean(axis=0)\n",
    "PBO_linear_max_linear_q_std = np.sqrt(np.mean(np.square(PBO_linear_max_linear_q - optimal_q) * samples_mask_q_format, axis=(2, 3, 4))).std(axis=0)\n",
    "PBO_linear_max_linear_q_confidence_interval = confidence_interval(PBO_linear_max_linear_q_mean, PBO_linear_max_linear_q_std, n_seeds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXwAAAEoCAYAAABb+EorAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAABSY0lEQVR4nO3dd3RURRvA4d+kJ0CCoRM6SEeFhI4C0qT3IggWJPAhRSwoNkCxIoiKoghioUmTXgRpIh1FQEQ6QkCQGkIIafP9MdvSSK/7Pufck71z596dXZZ3705VWmuEEELkfS7ZXQAhhBBZQwK+EEI4CQn4QgjhJCTgCyGEk5CAL4QQTkICvhBCOAkJ+EII4SQk4AunoZRqppQal93lECK7SMAXeZ5SaqBS6jGH/bpKqQ+ys0xCZAclI21FdlBKbQbQWjdLSXo6n8sVGAz0B+4BVgFva62vZtRzZKWsfO9E3iJ3+CJXUUp5K6VGKKV+UUr9p5S6o5Q6pZT6UilV7i6nOt7ZxFq2bJGO1yBEukjAF7mGUqoOcAiYDFwC3gNGAZuAgcDvSqm6iZz6BBAGjAHmAwuBV7KgyAmk4zUIkW5u2V0AIVJCKfUA8DNwE6irtf493vEfgLXAHKVUNa11jPWY1nqmJU8zy/5uYHeWFDxuGR8gja9BiIwgd/gix1NK+QALAE+gXfxACaC1Xoepm78XaJzYdbTWm7XW4zKxqEnKqNcgRHpIwBe5QTAmCH6ktT50l3zWIFot84uUannhNYhcTgK+yA0GAzHAtGTyhVv+5sSqyrzwGkQuJx8qkaMppUoCVYGdWutzyWSvZPl7NoOeuyDwbCpO+SSxrp7pfQ1Kqd3Am1rrlakoixAJSMAXOV1Zy98Td8uklHIBWgPRwPYMeu6CwNhU5J8NJNa3P12vQWtdLxVlcLyeJzAVaAEUAS4An2qtP03L9UTuJwFf5BY+yRzvAZQCFmmtL2fEE2qtTwMqI65lkdWvwQ34F/MlchK4D1inlLqotV6QAdcXuYzU4Yuc7m/MIKn7lFKJBl+lVBFgCnAb09c+p0nza1BKdVRKHUzLk2qtb2mtX9daH9dax2qt9wPLgSZpuZ7I/STgixzNUie+EqgIDI1/XClVGlgHFAMGaq2PZ20Jk5fO11AH+C0jyqGUcgceBA5kxPVE7iNVOiI3GIqpjpiqlHoY2Iq5Y64D9AYigJ5a6yXZV8RkpfU11MGMws0IUzGDvr7LoOuJXEYCvsjxtNYhSqlA4AWgC9AO8LIc/hYYrbW+lE3FS5F0vIbamGkY0kUpNRloCDystY5M7/VE7iRVOiJX0Fpf1Vq/orWurrX2BmoAt4AHgNBsLVwKpfY1KKUKYxpx96fneZVSU4BWQIuMatAWuZMEfJEraa0PA/8D7gc+y+bipEkKXkMd4JTW+kZan0Mp9QnQEnNn/19aryPyBqnSEbmW1vp74PvsLkd6JPMaamOfaiHVlFJlgeHAHeCUQwehX7TWbdN6XZF7ScAXIofSWr+fzvPPkLHjCEQuJyteCSGEk5A6fCGEcBI5tkqncOHCuly5cmk699atW+TLly9jC+RknPk9vHHD3kbq5+eXpms48/uXEeT9S7t9+/Zd1loXSexYjg345cqVY+/evWk6d/PmzTRr1ixjC+RknPk9dJz9IK1Vns78/mUEef/STil1JqljUqUjhBBOQgK+EEI4CQn4QgjhJCTgCyGEk5CAL4QQTkICvhBCOIkc2y0zrc6eOMfHn33FjoNnGTO8f3YXR4gMERoayqVLl4iKisruomQJPz8//vrrr+wuRo7j7u5O0aJF8fX1TdP5yQZ8pVRPoD8QCPhhlmv7UGs97y7nVAFGAA9jFnD+F1gBjNVaX09TSVPg1bGTeSf6dagZzpb9xxmDBHyR+4WGhnLx4kUCAgLw9vYmiVUS85SbN29SoECB7C5GjqK15vbt24SEhACkKeinpErnOSAMGAV0wqy+M1cpNfwu57QCGgPTMAs9TAB6Aj8ppTKtGqlr/drgFgHAtTK72TpjdmY9lRBZ5tKlSwQEBODj4+MUwV4kTimFj48PAQEBXLqUtvV+UlKl0zHeogkblVIlMV8EnyZxzjzgM20fprhZKXUOs27ng8CWNJU2GUHtmlNk0UP8V3YzAK+v+Jotj/cGd/fMeDqRR9WpUye7ixBHVFQU3t7e2V0MkUN4e3unuWov2bvtJFbI+R0oeZdzruiEY9Kt83oneV5GGFBriO3xr1X+4M4Xn2fm04k8aN++fbYtp5A7e2GVns9CWqtXGgJH03AOaTgvVV5/ujsqNACAmHxXmfztDLh2LTOfUgghcoVUB3ylVAvMIsyTUnGOD/A+sEVrnam3TX4F3KhwvZdt//MakfD225n5lEIIkSukagEUpVQ5YBewXWvdNYXnKGAu0Bqoq7U+eZe8wUAwQLFixQLnz5+f4rI5Wv3rdSZGdgeXWAAOTfUkbMpMbgcEpOl6zigsLIz8+fNndzFyrYx8//z8/KhUqVKGXCu7vPPOO7z33nu2/eLFi1OvXj3efPNNKlSokGgeb29vypcvz+DBg3nyyScTXHPNmjVMnTqV/fv3ExMTQ9WqVXn66afp169fstUeNWvWpHPnzrxtuRkcMmQIf/31F1u2ZErzYoY7fvx4nGm8HTVv3nyf1joosWMp7oevlPIH1gBngH6pKNv7QFeg1d2CPYDWejowHSAoKEindXrU2NjNfDqnHRFlVgLwxgOlWbx4MSxZkqbrOSNnnp52+vTptsfBwcFpukZGvn9//fVXru+i6OnpiZ+fH2vXrgXg5MmTvP7663Tu3Jk///yTfPnyxclz69YtAFasWMHIkSMpXLgwffv2tV3v/fff5+WXX+axxx7j5ZdfxsPDg5UrVzJ8+HAOHDjAtGnT7loepRQeHh629/XNN9/k9u3bueZ99vLyonbt2qk/UWud7Ab4ANuBE0DRlJxjOW8UEAv0Suk51i0wMFCn1aZNm3TPV5drxqEZh/Z8wU/fcUXrTZvSfE1ns8mJ3yvAtqVVRr5/hw8fzrBrZZexY8fqQoUKxUn75ZdfNKAXLFiQIE9oaKgtX926dXXPnj1t+3v37tUuLi76pZdeSvA8n3/+uQb0jz/+eNfylC1bVj///PNpfTlZIjw8PMljd/tMAHt1EnE12Tp8pZQbsBC4F3hEa52iDqBKqX6Yev7ntNYLUvc1lH5v9G0LN0oBcCf/DeZUyQejRkFMTFYXRQiRiMDAQABOnz5913wFChSI0w1x6tSp+Pr68sorryTIGxwcTMWKFfnkk09SVZYnnniCoCB7Lcg333yDUoqDBw/SqlUr8uXLR9WqVVmSSC3BsmXLCAoKwsvLi+LFizN69Og45T1y5Ah9+vShdOnS+Pj4UKNGDaZMmUJsbKwtz+bNm1FKsW7dOjp16kT+/PkZNmxYql5DSqSk0fZzzOCpt4BCSqkGDpsngFLqZ6XUz9YTlFJNgVnAT8DOeOeUyvBXkYia1d0oeWmgbf+DwIKwfz98/31WPL0QIhnWQF+8ePE46dHR0URHRxMaGsrs2bPZsmULXbvamwy3bt1K8+bNEx1p6urqSseOHdm+fTvR0dHpLmPfvn3p1KkTP/74I/feey99+vTh3LlztuMLFiygW7du1KtXj+XLlzN27FimT5/OmDFjbHlCQkKoUqUKn3/+OatXr2bQoEGMHTuW999/P8HzDRw4kPvvv5/ly5czcODABMfTKyV1+K0tfz9O5Fh54DTgGi+9OeAOtLFsjsYD41JcwnQYUncgb1x9C1xiOVIxhBP3QMUxY6BHD5AGSZGL5YRu+WlZ/dEahE+ePMnQoUMpUKAALVu2tB2/cuUK7vEGSo4YMYIBAwbY9kNCQujUqVOSz1G2bFnu3LnDlStXKFasWOoL6WDUqFE89dRTgPlFUqxYMVauXMmQIUPQWvPiiy8yYMAAPv/cPt7H09OTZ555hjFjxlCoUCFatGhBixYtAFOF3qRJE8LDw/nqq6/ifDEA9OzZk7feeitdZb6blAy8Kqe1Vklspy15mmmtmzmcM+4u54zLtFcTz//6lUYdb2fbfz+wIPz7L3zwQVYVQQhhYQ3m7u7uVKlShZMnT/LDDz9QokQJWx4/Pz/27NnD5s2b2bZtGx9//DHffvst48ePz5Yyt27d2va4UKFCFC1a1HaHf/ToUf755x969epl+1USHR3Nww8/TEREBIcOHQIgIiKCsWPHUqlSJTw9PXF3d+fVV1/l1KlTCX6FtG/fPlNfT56bLdNR4cJQzzWYXZjeOnMfiGLqJvCYOBEGDYLSpbO5hEI4Dz8/PzZs2IBSiuLFi1OyZMkE3Sfd3NwICgqyTZ7WuHFjoqOjGTNmDMOHD8ff35+AgADOnElynW7OnDmDp6cnhQoVSneZCxYsGGffw8ODiAgzX9fly2YSgnbt2sU/DYCzZ88C8NJLLzFjxgzGjh1LnTp1KFiwIMuWLWPChAlERETE6b6b3l8kycnTAR/g+c5t6bU9AHxDuJX/FkurQK/DETBmDMyWydVE7pSW6pTsZg3mqVWtWjUiIyM5ceIE/v7+PPTQQyxbtizRGTVjY2NZtWoVjRo1ws0tc8Obv78/YLrxJtZFsnz58gAsXLiQ4cOHM3r0aNuxVatWJXrNzJ5CI88vgNKpgxtef9kbPyYGFjQP5syB3buzp1BCiBSzVo2UtvwiHzZsGDdu3ODdd99NkHfGjBkcO3aMkSNHZnq5qlSpQkBAAKdPnyYoKCjBZv2Fcfv2bTw9PW3nxcTEkNZBpemV5+/wPT2hR4WBzI6dAC6x7K143TTeXsN009y2LWe0gAkhiI6OZufOndy6dQt3d3f27dvHhAkT6Ny5s603T2BgIG+//TZjxowhJCSEPn362AZeTZ06lSFDhtC5c+dML6uLiwuTJk2if//+hIaG0rZtWzw8PDh58iRLly5l0aJF+Pj40KpVKz777DMqVaqEv78/n332GXfu3Mn08iUmzwd8gGceK8PsT9tCZfMz6osgDyauj4Tt22HhQujVK5krCCGywo0bN2jY0Myz6O7uTtmyZRkyZAivvfZanHwvv/wyNWrUYNKkSfTq1YuYmBhq1qzJ9OnTeeKJJ7KsvL1798bX15d33nmHr7/+GldXVypUqECHDh3w8PAA4NNPP2XIkCE888wzeHt78/jjj9O1a9c0j+JOj1TNpZOVgoKC9N69e9N0bvxh7VpDwMPLudDMfOv7Rhbgv/dv4hEDlC0LR46Al1cGlDrvcOapFTp27Gh7vGLFijRdI6OnVqhWrVqGXCu3kBWv7u5unwmlVJJz6eT5OnwwNTaDH24HlmmTQz1usjzI8mE6cwamTMm+wokcZ8WKFbZNiLzEKQI+wOP93eA3e+Ptp+0cumS+/TZcvJgNpRJCiKzjNAG/XDmo7zEQYs1L3qoPczKoojkYFgZvvJF9hRNCiCzgNAEfYFCvMnC8rW1/xqBA+8EZM+DgwWwolRBCZA2nCvg9eoD7AXvL+BdXNhH1SCuzExsLzz2XO0e0iAw1btw42yZEXuJUAd/PD7rWtDfeXov8j+XPtgNXy9xvGzZAEiPghPMYP368bRMiL3GqgA/wxIC4jbdfXFwNjv1hn38eHOayFkKIvMLpAn6rVlD47EDQZnTthlPrOfnck+b2H+DoUfjii2wsoRBCZA6nC/hubjCgcxk45tB4e+ZHcBzJN3YsXLuWDaUTQojM43QBH2DAAGCfvRrnq30ziBo6BCpUMAnXroE02AmRYcaNG4dSyraVLFmS7t27c+LEiUTz+Pr64uPjQ61ateIsKu9oxYoVtpWv8uXLR7169Zg1axZpnT1g6tSpmT5bZXZzyoB///1Qy6s9hJYE4PLt/1hx5qe4C6N88gmsXJlNJRQi7/Hz82PHjh3s2LGDDz/8kP3799OiRQtu3bqVIM+GDRtYsWIFLVq0YPDgwcydOzfOtd5//306depEqVKlmD9/PsuWLaNRo0YMGjSIoUOHZvVLyzWcYvK0xDze340XVg2EpmY5sS/2fkG3x9ZBmzawbp3J9NhjsHcvVKqUjSUVIm9wc3OjQYMGADRo0IAyZcrw4IMPsnr1anr27Bknj3UunRYtWrB9+3aWLl1K3759Adi3bx+vvPIKL730Eu+9957t+i1btqRKlSoMHTqUNm3a0KVLlyx/jTmdU97hA/TtC2q/vfF2/cn1nLp+2iyKUqaMyXTjBnTvDuHh2VdQIfKowEAz8NG6mHlSChQoQJRDz7mpU6fi6+vLK6+8kiBvcHAwFStW5JNPPrnrNe/cucOwYcMoWLAg/v7+jBo1Ks5zWF29epXg4GCKFSuGl5cXjRo1YteuXXHyxMbG8t5779mWMKxcuTLffvttnDzNmjWjR48eTJ8+nXLlyuHt7U379u0JCQm5azkzmtMG/BIloE39snEbb3+bYdZFXLQILFObcuAADB4sA7KEyGDWQG+d597KujZsaGgos2fPZsuWLXTt2tV2fOvWrba6+/hcXV3p2LEj27dvT7BerKOXX36ZGTNm8PrrrzNnzhzOnDnDpEmT4uS5c+cOLVu2ZMOGDUycOJGlS5dSpEgRWrZsyb///mvLN3z4cCZMmEBwcDCrVq2ia9euPPXUU6yMVyW8Y8cOPv30UyZPnszMmTM5cOBAlv8KcdoqHYD+/WHtm8FQeTUAM36fwbhm43CvWxemTrX3z589Gxo2BKkbFDmEGp/9jYt6bOpvgqxB+OTJkwwdOpQCBQrQsmVL23HrQueORowYwYABA2z7ISEhdOrUKcnnKFu2LHfu3OHKlSuJrhF75coVvvjiC8aPH8/zzz8PQJs2bahevXqcfLNnz+bQoUP8+eef3HvvvYC92mjSpElMnDiR48ePM23aNGbNmsXjjz9uy3PhwgXGjx9Phw4dbNe7dOkSO3bsoIylBqFs2bI0adKEtWvX8sgjjyT/5mUAp73DB+jSBfKdtzfeXrp1iRVHLVPiPv00PPWUPfOzz8KOHVleRpH1Bg0aZNtExrEGc3d3d6pUqcLJkyf54YcfKFGihC2Pn58fe/bsYfPmzWzbto2PP/6Yb7/9NkNHPR88eJCIiIg4q2K5uLgkWCVrw4YNBAYGUr58eduvDoCmTZtiXavj559/xsXFha5du9ryREdH06JFC/bv309MTIztenXq1LEFe4DGjRtTtGhRdmfhUqtOfYfv4wO9ergx63d74+2X+76kW7VuZhL9qVNh/3747Tcz+rZHD/M4k1eWF9krqW6AIn38/PzYsGEDSimKFy9OyZIlE3SDtC50bm20bdy4MdHR0YwZM4bhw4fj7+9PQEAAZ86cSfJ5zpw5g6enp21N2fis1TFFixaNkx5///Lly+zcuTPBLw6AihUr2vLExMTgZx24Gc+FCxcoVapUote3pl24cCHJ15LRnDrgg+mTP6vLQHhoAijN+hPrOXXtFOXvKQ/e3rB4MQQGwtWrcP489OkD69ebEVxCZJO0VKdkN2swT61q1aoRGRnJiRMn8Pf356GHHmLZsmWJrooVGxvLqlWraNSoEW5J/B+1thlcunQJf39/W/qlS5fi5PP39ycoKIhp06YluIZ1UXJ/f3/c3Nz49ddfcXFJWGHiGOTjX9+a5vgLJ7M5dZUOwEMPQRm/snDc1KFptGm8tSpXDubMsS90vnkzJNI7QAiROQ4dOgRA6dJm0aJhw4Zx48YN3n333QR5Z8yYwbFjxxg5cmSS16tVqxZeXl4sW7bMlhYbGxtnH6BFixYcP36cMmXKEBQUFGerVasWAA8//DAxMTHcuHEjQZ6goCDburYAv/32G//8849t/9dff+XSpUvUq1cvDe9K2jj9baqLi2m8fXtxMNy7BnBovHW1/JR75BEYP96+SMrEiVC/vumyKYTIMNHR0ezcuZNbt27h7u7Ovn37mDBhAp07d7bdmQcGBvL2228zZswYQkJC6NOnDx4eHqxcuZKpU6cyZMiQBPXxjgoVKkRwcDBjx47Fzc2NGjVq8NVXXxEWFhYn34ABA/jiiy9o1qwZL7zwAhUqVODKlSvs3r2b4sWLM2rUKKpUqcKQIUPo06cPo0ePJigoiIiICP7880+OHj3KjBn2m8ciRYrQvn17xo8fT0REBC+99BJ16tTJsgZbALTWOXILDAzUabVp06ZU5T9yRGtcojTPl9CMQzMOveTwkriZYmK07tBBa9NBU+v8+bX+6680lzGnS+17mJcMGjTItqVVRr5/hw8fzrBrZZexY8fqQoUKJZsHsG3u7u66UqVKevTo0To0NDRB/uXLl+umTZvq/Pnza29vb123bl399ddf69jY2GTLExERof/3v/9pX19fXbBgQT1s2DA9adIkbUKi3fXr1/WIESN0qVKltLu7uw4ICNBdu3bV27Zts+WJjY3VH330ka5evbr28PDQhQsX1g899JD+9ttvbXmaNm2qu3fvrqdNm6ZLly6tvby89COPPKL/+eefZMuamLt9JoC9Oom4mu2BPaktKwO+1lrXr681zV+zBfxW37VKmOnaNa0rVrQH/apVtU7kg5gXOHPAdww6aSUBP30SC/C5mTXgZ5S0Bnynr8O3GjAA+O3pOCNv957fGzdTwYKmEdfb2+wfOWK6bsqgLCFELiAB36J3b3APLwuHetvS3tiUyMLm998Pjt32Fi2CyZOzoIRCCJE+EvAtChWCDh2ALW/Y7vLXHF/DznM7E2Z+7DF45hn7/ksvmd47QgiRiM2bN7No0aLsLoYEfEcDBgCXq8HBvra0sZvHJp558mSwzPxHTIz5iZDFEyEJIURqSMB30K4dlCyJucuPNW/NTyd+YvvZ7Qkze3jAwoVgHVhx6RL07AmRkVlXYCGESAUJ+A48POCbb4ArleHAY7b0ROvyAUqVgh9+AFdXs79jh1kEXQghciAJ+PG0amWq5Nn6OsSaQP7zqZ/ZemZr4ic0awYOizAwdaqZXVMIIXIYCfiJeOstqH9vJfjDPiXrqxuSqMsHc1fvOOo2ONjMoy+EEDmIBPxEuLvDvHmQ/7fXIMbMPrHt3GY2ntyU+AlKwaxZULWq2b99G7p2NROuCSFEDuH0c+kkpXx5mDGxAn3mPAGBZj6MIT+M5e+XmyW+sn2BArBkCdSrB2FhcPKkmVlz9WqZWTOXGTv2Lr/mhMjF5A7/Lnr3ht4lX4UYM4naschfmLVlY9InVKsGjmtZrl9vaRAQucm4ceNsm8gY48aNQymVYIu/2tWoUaMoV64chQsXJiAggKeffppz584luJ5SiqlTp2blS8gT5NYzGV9PLse6wU9xvdKXAAxf8gaP1n8Yb+8klpjr1s3Mqvnmm2Z/8mQzOtdhiTYhnJGfnx9r165NkAZw/vx5HnzwQSIjI3nllVcoV64c//33Hx988AGBgYFs3bqVKlWqZEex8xQJ+Mnw8YEfhr1Cm5WzwC2S8ELb6f3KepZ/1Drpk8aOhT/+AOv82sHB5u6/bt2sKbQQOZCbmxsNrIMV4xk6dCjXr1/nwIEDBAQE2BY36dKlC0FBQfTv3z9LlwLMq6RKJwVa1y/DQ/mftu2vCHuDH3+8y4RpLi7w/fdQo4bZv3PHNOI6rHQvhDBOnz7N8uXLGTlyJAEBAXGO+fr68uqrr7Jnzx62b09kAKRIFQn4KTR7yBhcYs2yZpTaxYC31nD27F1OKFAAli41M2yCmXahe3cT/EWO1rFjR9smMpbjQt/R0dForfnll1/QWtOlS5dEz7Gmb9myJesKmkdJwE+h0n6lGPhAsG0/LGgsfftpLAvZJ65SJTMS17rW5fbtMGyYTKecw61cudK25VhKZf+WSleuXMHd3T3O9vPPPxNimYOqbNmyiZ7n5+eHn59foo23InWSDfhKqZ5KqeVKqRClVJhSap9S6tEUnOeplJqklLqklLqllFqllCqXIaXOJuNavoyHi5fZCdjLtosrmTAhmZNat4YPPrDvz5gBiSyKLERe5+fnx549e+Js9evXT/H5iXaHFqmSkjv854AwYBTQCdgEzFVKDU/mvE+AJ4AXgB5AYWC9UsorzaXNZiULlGRo3SH2hOZjefMtTbK/NJ97zkypbDVypEynLJyOm5tbgkW+CxQoYKu3P3PmTKLn3bhxgxs3blCiRImsLG6elJKA31Fr3VdrvUBrvVFr/QIwD/NFkCilVClgIDBKa/2d1noN0A0oCzyW1Hm5wUtNXsLbzbLiVYnf0ZWX0a8fXLlyl5OUMoumBAWZ/ehoM7NmEh9wIZJlX2gz+7YM8uCDD6KUYvny5Yket6Y3atQow57TWSUb8LXWlxNJ/h0oeZfTrH0WlzhcJwTYBrRNTQFzmuL5izO07lB7QrNxhJyP5cknk/k/4O0NP/4IxYqZ/cuXoUsXuHUrM4srRI5Xrlw5OnXqxJQpU7hw4UKcY2FhYUyYMIEKFSrQtGnTbCph3pHWRtuGwNG7HK8KnNNah8VL/8tyLFcb3Xg0Pu4+Zqf4H1D1R1asMBNl3lWpUmZNXHczcpf9+2HgQGnEFU7v888/x8/PjwYNGvDFF1/w66+/8v3339OwYUNOnz7N999/j4uL9DFJr1QPvFJKtQC6AE/dJds9wPVE0q9ZjiV17WAgGKBYsWJsTmM9d1hYWJrPTanOxTsz7+w8s9NsHBzpyvPPg7f3b1SqFP97Lq4SI0ZQZdIks/PDD5z09eWfvn3vek5Wy4r3MDfICZ9BPz8/bt68mSHXyi537txBa53k6yhQoAA///wzEydO5N133yUkJISYmBiKFCnCpk2bqFWrVoJzIyIicv37klYRERFp+3xprVO8AeWAi8CPyeT7CtifSPoE4HxKniswMFCn1aZNm9J8bkr9d+s/nf+d/JpxmK3GDxq0rlxZ65s3U3CBoUPttaFKab1yZaaXOTWy4j3MqQDbllYZ+f4dPnw4w66VW4SGhuoZM2ZoQM+ePTu7i5Pj3O0zAezVScTVFP9GUkr5A2uAM0C/ZLJfA/wSSb/HcizXK+xTmBH1Rtj2VfNxoGI4ehSGJ9d/CWDKFHjoIfNYa+jbF44cyYyiCpErDRw4kBEjRjBw4EC2bduW3cXJE1IU8JVSPsBKwAPooLUOT+aUI0BppVS+eOlVLcfyhOcbPU8BjwIA6MJ/QY0FgFkm8bvvkjnZ3d2siVumjNkPDYXOneH69UwrrxC5zccff0xERARNmjTJ7qLkCSkZeOUGLATuBR7RWl9KwXV/svzt6nCdksCDmF8JeYK/tz/PNnjWtl+g03hQMQA88QSMHw+xsXe5QNGiZvoFb0s3z6NHoV8/iInJrCKLFPjyyy9tmxB5SUru8D8H2gFvAYWUUg0cNk8ApdTPSqmfrSdorc8BM4EpSqn+SqlHMF00zwB5asHXUQ1G4edpaq9uevxN8damIVdrGDcO2rdPpo9+7dpmtSyr1avh9dczr8AiWcHBwbZNiLwkJQHf2qf+Y2BHvM069M3VsjkaAXwHTAYWA1eB1lrriHSWOUe5x/seRjUYZdv3ajOOZg/bJ9hZuxYCA2Hv3rtcpHdvePll+/6775o5eISw0NJ1V1ik57OQkoFX5bTWKonttCVPM611s3jn3dFaP6e1LqK1zqe1bqe1PpXmkuZgzzZ4loJeBQE4HXqC/hNnM2aM/fiZM9C4sRlsm+S/1YQJ0NZhTNqTT5o59YXTc3d35/bt29ldDJFD3L59G3frWJ5UkpEMGcDPy4/nGz5v25/wy5uMfyuKpUvBsqAPkZEweLCJ4+GJNXm7usLcuVC5stm/fduMxL2c2EBn4UyKFi1KSEgI4eHhcqfvxLTWhIeHExISQtGiRdN0DVnxKoOMqD+Cj3Z+xNXbVzl1/RTf/fEdAzsPZO9eMw3+gQMm37ffmgG2ixdDxYrxLlKwoFklq149uHkTTp821T3r1slC6FkoMDDQ9njfvn3ZWBLD19cXMMsARkVFZXNpskZERAReXrl2nsVM4+7uTrFixWyfidSSKJJBfD19eaHhC7yy8RUAXlz/IrWK1aJepXrs2AFDh9rXN//jD1Ov/9130KlTvAtVrQqzZ5sumgAbN8Lo0WZtXJElfvvtt+wuQgK+vr5p/k+eG23evJnatWtndzHyHKnSyUDD6g2jWD4zOdq1iGu0+K4FG09txMfHdMT58kvw8DB5b9wwMf2VV0i4iEqnTqZPp9VHH5klE4UQIh0k4GegAp4FWNV3FYW8CwEQFhlG2zltWXpkKUqZtcx//RUcF/Z5911o0wYuxR/d8Nprpg7fKjgYckD1ghAi95KAn8ECSway9cmtBBQwizpExkTSY0EPvvvDDL0NCjJxu00b+zkbN0KdOrBjh8OFXFxMnU/16mY/IsIshJ7gm0EIIVJGAn4mqF6kOtue2kbFe0yrbIyO4fGlj/Pprk8BKFQIVq2CsWPtS4OGhJipdT791KHrpnUhdGtXn7NnzcIpTtJwJ4TIWBLwM0m5guXY9tQ27it2ny1txNoRvLnlTbTWuLqakbirVoG/vzkeHQ0jRpjZFWzrotx7r+muaf1m2LrVLJkohBCpJAE/ExXPX5zNj2+mYamGtrSxm8fy3LrniNVmkp22bU0Vj0NPQObNgwYN4ORJS0K7dvD22/YMU6fC119nwSsQQuQlEvAz2T3e97C+/3paV2xtS5uyawoDlw8kOtZ0zylXDrZtM+2yVocOmfr+DRssCS+/DD162DP873+wa1fmvwAhRJ4hAT8L5PPIx/I+y+lerbst7Zv939BrYS/uRN8BwMvLdNv8+mt7181r10zj7kcfgUaZvp21apmDkZHQrRv8+29WvxwhRC4lAT+LeLp5Mr/HfJ56wL4y5I9HfqTDvA6ERdqXRHzySVNNX8IyLV1srKmyf/xxuO2a3zTi3mNZJfL8eTOMNzIyC1+JECK3koCfhdxc3JjRaQbPNbA3um44uYFW37fi6u2rtrT69U29foMG9nO//9704jnnUQHmzzfdNgG2bzctvSLDLF++3LYJkZdIwM9iSik+bP0hE5pPsKXtPLeTpt805cLNC7a0EiVg82YYONB+7t69pl5/e/7W8P779gNffmk2kSE6duxo24TISyTgZwOlFK8+9CpT2061pR26dIgHZz3IqWv2GaQ9PeGrr0zffFfLagMXL0KzZvCV7/Pw6KP2iw4fbobxCiFEEiTgZ6Nn6j3D912/x1WZaH7i2gmazGrCn5f+tOVRCoYNM711Chc2aVFREDxYMTT/t0TeF2RP7N7djOASQohESMDPZo/d9xhLei/B09UTgPM3z/PQNw+xO2R3nHzNmsGePfDAA/a0aV+508rrFy7dU8UkXLxoeu5E5KlFxYQQGUQCfg7QqUon1vRbQ36P/ABcvX2V5t82Z9mRZXHylStnam1697anbd3tRZD7fn5zsdzp795t5mKWhTLSrGTJkrZNiLxEAn4O0bx8czYO2Ii/t5lnITwqnK4/dGXKzilxVjny8TEjcd991z7bwtlLXjRx3c48+piEWbNMxb9IkwsXLtg2IfISCfg5SN2Aumx/ajsV7qkAgEYzat0oRqwZYRuVCybQv/wyrFxpn1ftdpQ7fZnHaN4nBhcYOdIsoiuEEBYS8HOYKoWrsHPgzjjz70zdM5XO8ztz887NOHnbtTOzK1Stak+byGg6sJJrFDSL6E6blkUlF0LkdBLwc6Ai+Yqw8fGN9KrRy5a2+thqHpz1IOdCz8XJW6UK7NwJHTrY09bSlobs4AxlTH2+VO8IIZCAn2N5uXkxr/s8xjQZY0v74+If1J9Rn98v/B4nr5+fWfv81VftaX9TlUZs5yA1zUjcjz7KqqILIXIoCfg5mIty4Z0W7zCz00zcXMx68+dvnufBWQ+y8ujKuHldYMIEM+uCdfK18wTwIL+whYfMhDwffpjVL0EIkYNIwM8Fnqr9FGv7rcXP07TQ3oq6Ref5nZm6e2qCvL17w9q1ZrEsgBsUpA3rWEw3ePFFeO+9rCy6ECIHkYCfS7So0ILtA7dT1s+sgB6rYxm+Zjij1o4iJjYmTt7mzc2Mm8WLm/07eNGThUxjCIwZY34KCCGcjgT8XKR6kersenoX9QLq2dKm7JpCtwXduBV5K07eBx4wi6JXrmz2NS4MZRqv8yb69dfN+ooyOEsIpyIBP5cplr8Ymx7fRLdq3Wxpy/9ezkPfPMT5m+fj5LWupFXP/v3ABF5nEF8RPX4CvPGGBH0hnIgE/FzIx92HhT0X8mKjF21pv134jQYzGnDg4oE4eYsUgY0bzdq5VjN5mm4sIXzCJFPFI0E/jr1799o2IfISCfi5lIty4YNWH/BF+y9ss22eDT1Lk6+bsO74ujh58+Uz3TYff9yetoJOtGQDV97/yjTmStC3CQwMtG1C5CUS8HO5wUGDWdV3FQU8TLecm5E3aT+3PTN/mxknn7u7mWLn5ZftaTtoRBO28c+kBTBqlAR9IfI4Cfh5QJtKbfj1qV8p7VsagBgdw9Mrnua7P76Lk08pM+naxx+DUia4H6EaDdnBwY9/NouoSNAXIs+SgJ9H1CpWi11P76JOiTq2tCeXPcniw4sT5B0xAubNU7i7m+BuHaC19bMDZiqG2NgsK7cQIutIwM9DShQowfr+67mv2H2A6av/6OJHWXt8bYK8ZoCWokABE/RvUJDW/MSSLy6aSdecOOgrpWybEHmJBPw8xt/bn58e+4nKhUwH/KjYKLr+0JWtZ7YmyPvww7B1q6J4cRP07+BFDxYxbYYb1d5+G27dSnCOECL3koCfBxXLX4wN/TfYRuVGREfQYW4H9oTsSZD3gQdg+3bFvfeaoG8doPXVxoamA/9ff2Vl0YUQmUgCfh5V2q80GwZsoHh+M7/CzcibPDLnEQ5dOpQgb/ny8Ouvirp17Q22rzOBWYfrQVAQzJ6dZeUWQmQeCfh5WCX/Sqzvv962bOLV21dp+V1Ljl05liCvGaClaNnSnhbMdDaG14f+/SE4GG7fzqqiCyEygQT8PK5m0Zqse2ydrZ/+xVsXafl9S/658U+CvPnzw5IlcP/9Zj8ad7qzmCNUga++goYN4VjCLwshRO4gAd8JBJUMYlXfVXi7eQPwz41/aPldS/4N+zdB3gIFzFq5hQvfAeA699CO1fxHYfjjDwgMhAULsrT8QoiMIQHfSTxY9kF+7P0jHq5mdZRjV4/R+vvWXL19NUHeUqXg7bcP4uNj9k9RgS5qORF4ws2bpk/n8OFw505WvgQhRDpJwHcibSq1YX73+ba5dw5eOkjbOW0TLI4OULlyGPPmmdG5ANt1Q57Mv5BYLAlTp0KTJnDqVFYVXwiRThLwnUzXal35pss3tv3dIbvpOK8jt6MSNsh26gSTJ9v354d1ZGxVh+qcvXuhdm0zM5sQIseTgO+EHrvvMT5v97ltf8uZLXRf0J3ImMgEeUeONLMtWE040oNv+/1kZmMDuHEDunSB55+HqKhMLrkQIj1SFPCVUpWUUl8qpQ4opWKUUptTeF6QUuonpdRVy7ZBKVU/XSUWGeJ/df/HBy0/sO2vOb6Gfkv6ER0bHSefUmayNcf59ActaMXmj/+AsmXtiZMnw0MPwT8Je//kNiEhIbZNiLwkpXf4NYB2wN/A0ZScoJQqDWwA3ID+ls0NWK+UKnu3c0XWeLHxi7z24Gu2/UWHFzFoxSBiddx5dNzcYP58qFXL7EdFQbdXq/H3D/uhY0d7xp07TRXP6tVZUPrMU7JkSdsmRF6S0oC/QmtdWmvdE/gzhee0BwoAXbXWq7TWq4CuQD7Ml4fIAd5s/iYj64+07X+z/xtGrhmJjjdNsq+v6a5pXRj92jVo368gl2cug4kTwdU0BHP1KrRvD6NHSy8eIXKYFAV8rXVapk50B6IBxxm4wixpMg1hDqGU4qM2HzGw9kBb2tQ9U/n69NcJ8pYpAytWgLfpzs+JE9ClqyJi2AuwZQsEBNgzT5wIdeuavvtCiBwhMxttFwPhwCSlVFGlVFHgI+AasDATn1ekklKKLzt8Se8avW1ps/+ZzRd7v0iQNygI5s61d9f89VcYOBB0o8bw++/wyCP2zAcPmqD/3nsQE5PZLyPDnD9/3rYJkZeo+D/dkz1BqUVAYa11sxTkfQBYCVhv/S4AbbXWid72KaWCgWCAYsWKBc6fPz9VZbMKCwsjf/78aTrXmUXHRvP6n6+z8+pOAFxw4a0ab9GocKMEeRcsKMW0aZVs+wMGnObJJ09DbCwBy5ZR4csvcXWo0rlRowZ/jRlDhOOvgByqefPmtsebNm1K0zXkM5g+zvr+RUUpvv66PAULRtG799k0XaN58+b7tNZBiR7UWqdqAxYBm1OQrwRwDFgGPGLZVgDngDLJnR8YGKjTatOmTWk+19mF3QnTdafX1YxDMw7t87aP3n1ud4J8sbFaDx6stVkT0WzffeeQ4cgRrevVi5shXz6tv/jCnJyDAbYtreQzmD7O+P6dOGH/L+PmpvWuXWm7DrBXJxFXM7NK50VMPX4PrfVarfVaoDsQA7yQic8r0iGfRz5WPLqCEl4lAAiPCqfDvA6cvHYyTj6l4NNPoXVre9rAgbDVus5KlSqmvuett0w3HzALqgwZAu3agVSXCGEzf77p4LZ7t9mPjoaZMzP+eTIz4FcF/tRa20bjaK0jMb18Kmbi84p0Kpa/GO/Ves82rfKlW5doO6ctV8KvxMnn7m7mUatRw+xHRUHXrg4Tarq5wWuvwa5dUL26/cS1a6FmTfjhhyx4NULkXLdumRulRx+F0FCT5uoK48bBtGkZ/3yZGfDPADWVUh7WBKWUJ1ATOJ2JzysyQBmfMizvsxxPV08Ajl45Suf5nYmIjoiTz88PVq2CYsXM/tWr5gb+iuN3Q506sG8fPPecvbX32jXo0wf69jUnCeFk9u83k89+7dAhrnhx2LYNxo4Fl0yIzikdaeujlOqhlOqBaYAtYt1XSvlY8hxXSjn+CJkBlAR+VEq1V0p1AJZi6vanZ+irEJmicZnGzO42G2XpRfvr2V8Z8OOABAOzypaF5cvt3TWPH4emTU1PTRsvL5g0CTZujDtCd948M6Jr3bpMfjVC5Axam7kH69eHv/+2p7dvb/YbNMi8507pd0hRTFfKhUADoLrDflFLHjfA1XqC1nofpqG2APA98B3gA7TSSfTSETlPj+o9+LD1h7b9hYcX8uJPLybIV68efP+9ff/PP6FZM+jVC86cccjYrBkcOABPPWVPO3/edOccOlQWThd52pUrZuqp4cMh0jJ1lZeXqb5ZscIMcMxMKR14dVprrZLYTlvylNNaPxHvvJ+11g9prf0tW1Ot9eYMfxUiU41qMIoR9UbY9ifvnMwnuz5JkK97d7MwlnUefYCFC6FqVRg/HsLDLYm+vqZFatkyKFrUnnnaNLOq+o4dmfNChMhGW7aY1eSWL7enVaxohq8MGWKv7cxMMlumSJZSisltJtO1aldb2rNrn+XHv35MkPfpp83P0kcftadFRJhGqGrVzBeAbehHp05w6JBp6bU6ftzMsz96NISFZc4LEiILRUebz//DD4PjfHxPPGF+CVetmnVlkYAvUsTVxZU53ebQoJSpYNRo+i7py46zCe/GS5Uyo3F/+cV0NbP65x9TxdO8uanVAczq6YsXw7ff2n/PxsaaqRmqVjXdgFI5OFCInOLsWRPox483H2swy4guWgSzZoGnZ9aWRwK+SDFvd2+W91lOJX8zwjYiOoKO8zpy7EriC5s3aQJ79sD06VCokD19yxbzRTB0qKU3j1IwYICZiuHhh+0ZQ0LMcootW8Jff2XiKxMi4y1daqpwfvnFnla7tvkod++ePWWSgC9SpUi+Iqzpt4bCPoUBuHL7Cm3ntOW/W/8lmt/VFQYNMn3zR460T6oZG2uq7O+91/RYiI7GzM62YQN8913cuv2NG+G+++DFF82auplMxx0xLkSqRETAM8+Ymspr10yai4uppdyzJ+4cg1lNAr5ItUr+lVjx6Aq83Uw/zBPXTtBxXkfCo8KTPOeee2DKFFOV06qVPf3aNdNjoXZtE9dRCvr3h6NH435DREfDhx+aap7586WaR+RIO3ea7paf2xeUo0gR89l+/337xzm7SMAXadKgVAPmdp9r66O/K2QX/Zb0Iyb27rNiVq9uutwvXQrly9vTDx2CFi2gRw84fRozomvKFPjtN3jwQXvG8+dNi3CLFqbFS4gc4I8/TB+Ehg0d2qcwNZR//23GpeQEEvBFmnWp2oVP2tq7Zy49spRR60YlWxWiFHTuDIcPwzvvxO3GuXix6c3z3nuWRq777jOV/rNn24fzAmzaZLpwvvBCllTzCJGYv/82A8YfeMD0o7fy8DDjDDdsML9ucwoJ+CJdhtUbxvMNn7ftf7r7UybvmJyic728YMwYU3vz2GP29IgIk96tm1kjHaWgXz+TcdSouNU8kyaZidrmzs2wap59+/bZNiESc+aMGTtYvXrcKaGUMlOLHDoUdyaRnEICvki3D1p9QK8avWz7L6x/gXkH56X4/IAAM0r311/N3CJWy5aZEbyHD1sSfH3NYun795sF060uXDBfCM2bm/9p6RQUFGTbhHD077+mzenee023yliHWUaaNTMfzVWrzPGcSAK+SDcX5cK3Xb6lSZkmtrR+S/rx1pa3Esy7czeNGplGr+ftPxg4etQ0gi1e7JCxZk3YvBnmzLEvsgum6ueBB8yvgBs30vx6hIjvyhV46SWoUMH0KouKsh+rV88MDt+0ydRA5mQS8EWG8HLzYlmfZVQtbIYNajRvbH6DLvO7cD3ieoqv4+ZmOuPMm2ev2w8LM425L7/ssFKiUmamzb//Nr+drdU8MTGmsbdCBfjgA5mbR6RLaCi8+ab943T7tv1YzZqmjn7Xrsyd8CwjScAXGcbf25+tT2zl4fL2wVMrjq6g3lf1OHQpdVUtffqYu/2KDisnvP++mWPt8mWHjL6+ph7/jz/Mb2qrq1fNLVnFivDxx6ZhQIgUun3b3HhUqGCmKrbOVQ9QqZKpbjxwwHQWy00k4IsMVSRfEdY9to4XGtoXNTt29RgNZjRgwZ8LUnWtWrXMQJV27expGzaYhdR/+y1e5ho1TGfnefOgXDl7+sWL8Oyz5n/pF1/YpygUIhFhYaYPfcWKZpyf47oO1ilD/v7bdMHMaQ2yKSEBX2Q4Nxc3JraeyA89fiCfez4AbkXdovei3rz404tEx0an+Fr33GO6u40da087cwYaNzbT78ShlPlp8PffJrg7DmkMCYH//c/06Jk1yzK0Vwgzi+uiRdCzpxng/cwzph+AVdGi8OWXZnzIo49mzsIkWSUXF13kdL1q9GLn0zu519/eZeHDHR/S+vvWSU7FkBgXFzPb4PLl9vnVIiLMbIPDhiVy0+7hAYMHm5k3P/447jQNp0/b+9PNmePQKCCcSUSEGfz36KPm49Gzpwn6jnX0/v6mtvDsWQgOzv5RshlBAr7IVDWL1mT3oN10rNzRlrbp9CYCpweyJ2RPqq7VsSPs3WtfQxfgs89Mb8xE10T38oIRI+DUKTP7pr+//dixY6bz/333mS5AsSnvTSRyp8hI02VywAAzhq9rVzNLR/x2/fLl4e234dw50x/AwyPx6+VGEvBFpivoVZClfZbyZrM3bVMxnA09S5NZTZj528xkzo7r3ntNY24ve7d/tm83/fe3bUviJB8fMyL39GmYMMFM22B1+LDpAhQYaOqOZI6ePCU6Gn76ySwUXrw4dOhgxnw4NsIClC5tJjc7fBhOnoRXXrEv2ZmXSMAXWcJFufB609dZ2XclBb0KAhAZE8nTK55m8IrB3Im+k+Jr5c9v7swmTrTXp/77r7nT/+yzu8TsAgXg1VdN4H/9dciXz35s/37TEtegAa2SOF3kDjExpk/8kCFQogS0aWMWCrfOXGlVooRpz//jD9Mu9P77ZlqPvMwtuwsgnEu7e9uxd9Beuv7QlYOXDgIw/bfp7L+4n8W9FlPKt1SKrqOUuWmvU8dMmX/5srmbGzYMdu82bbZJ3qEVLGg6V48YYb41PvnE3m1z925+AnZ6eDCuQIF0v16RsWJi4L//TKPq+fMJ/54/b2rwHHvXOCpa1Pyge+op89nJjT1t0kMCvshyFf0rsmPgDgatGMS8Q2YKht0hu6nzZR0W9FxAs3LNUnythx+GffvMghJ795q0774z3Tk//zxu1/wEChc2t3WjRpnZ2qZNs7UAN4iMZO3ChWl7geKuoqNN42j8LTzc/nfr1hJs3ZowqP/7b+rb2QsVMvX1AweaUdvOFuQdScAX2SKfRz7mdJtDvYB6vPDTC8ToGP4L/4+W37VkYquJPNvgWVQK/2eWKWNWFRo61PS4BLOqUPPmZjDuhx+an+9JKl7cjM594QXTWjdzJtStay4guHPHzFRh3UJD4+7HPxYaahpC4wdy6+Y4LUHSqqSrzAULQpcuJsg3apS7u1JmJAn4ItsopXi2wbPULl6bXot6cenWJWJ0DM/99BwHLh1gZqeZuKiU/U/18jJxukEDMxePdf3zuXNh5UpTg/PMM2bqhiSVKmXu8l96KW7/vDwsNNTMV+S4nThhBipbA/udlDevZIkCBcyiIsWLm6EWZcqYLSDAfLGXKGH280I3yowmAV9ku6blmrIveB89FvRgV8guAL7Z/w3F8xXn3Zbvpvg6Spn+0u3bm6BvnbY2NNQ0zs2aZap5GjVK5kKOI3XzgDt3TBCPH9iPHjUDkbOaUqaro6en2by9zRe2l5d57O0N7u7/cv/9xSlTBkqWNEG8ZEkT5L28sr7MeYUEfJEjlPItxZYntjB45WC+/cMMoX3v1/cof095ggODU3WtgADTi2fQIFPNc/SoSf/jDzNC98knTdV9kSKJn7/CYSWLjh07Jp4phwkLMz1NTp82jZaOQf3MmfQNM3B1NR2a8uc3m6+vqTIpWNCMhPb3N5ufn33Ll88evL29Tc9Y62MPj+Tr0TdvPkKzZsXvnkmkmgR8kWN4unkyo9MMrty+wsqjKwEYumoopX1L0/betqm+XosWcPCgmUL/rbdMXTKYO/2lS81qW4MGJfzp36lTJ9vjnLKQeXi4Cebxt1OnzN84E8qlgpubqcmqWNEMPq5VCypXNgOTrMHb29u5GzrzEgn4Ikdxc3Fjfvf5NP2mKfsu7CNGx9BzYU9+efIXapeonerreXiYaZX79jXVOj/+aNKvXTNT68ycaap56tbN2NeRVkePmqn+T5yIG9gvXUr7NZUyAbxCBdPP/L77zJRClStLXbezkYAvcpx8HvlY2XclDWY04MyNM9yKukX7ue3Z9fQuSvuVTtM1y5SBJUtgzRrTV//kSZO+d6/pqhccbO74HWdfyAqRkbB1q2lYXrXKTP+TFm5uJqiXLm0Ce40aJrhXrmzu3qXeW4AEfJFDFc9fnFV9V9H468bcuHODC2EXaDe3Hdue3Iafl1/yF0hC27bw55+mDv/dd02DptZmNsTFi006KCDzqnIuXIDVq02AX7/e3qPoblxd4wb0ypXNjM/lypm5X4oXlzt1kTwJ+CLHqlG0Bj/2/pE2s9sQFRvFoUuH6LGwB6v7rsbd1T3N1/XyMtMtP/aYGWy7erVJv3zZ9NuGX4CZwFn++svUcadn0G1srBkItmqV2RLM5e/A0xMaNjRL9loDerlypoeKBHSRXhLwRY7WvHxzZnaayYClAwDYcHIDg1cOZmanmSkemJWUihVNVcqyZSbwnz1rPdLYspmGTDA9U0qXNsE/qc3Pz964GRbmysKFJsCvWXP3Ovjixc0iL716QdOmUv0iMo8EfJHj9b+/P6evn+aNzW8AMGv/LMoXLM/rTV9P97WVMiMyW7Uyg2w//DDxkaChoaYq6M8/k75Wvnwm8Pv6wm+/NU5yCgBXV7PWevfuZsh/lSrSC0ZkDQn4Ild47aHXOHn9JN/s/waANza/QbmC5eh/f/8MuX6+fKbR9oknoEqVCUB5oBSlSjXl4sWUTQdw65ZZbMuIO0LYz890E+3Vy6zL65f2Zggh0kwCvsgVlFJM7zCdc6Hn2HByAwADlw8kwDcgzqLp6VW5MoD9l8PZsxqtTf3+uXNxt9OnzaCmc+fMpF7xpyCoUsXMuNyjh1mHV+ZzEdlNAr7INdxd3VnUcxEPznqQg5cOEhUbRbcfurF94HaqF6meac+rlBmVW6QI1E5iKIDWcP26Cf7//QfXrm2ne/fk5nAQImvJPYfIVfy8/FjVdxUl8pvpL2/cuUG7Oe34N+zfDHuOOnXq2LaUUspMM1CrlpmyuVCh+AvtCpH9JOCLXKe0X2lW9V1Ffo/8AJy5cYYOczsQFpmCDu0psG/fPtsmRF4iAV/kSrVL1GZBjwW4KtM5fd+FfTy6+FFiYlO5OoYQTkQCvsi12t7bls/bf27bX3l0JSPXjswxE54JkdNIwBe5WnBgMC83ftm2/9mez5i8Y3I2lkiInEt66Yhc7+0Wb3P6xmnmH5oPwAvrX6CMXxl61uiZputNnz7d9jg4OHVz8QuRk0nAF7mei3JhVudZnAs9x7Z/tgHQb0k/gDQF/cGDB9seS8AXeYlU6Yg8wcvNi6W9l1K5UGUAomKj6LO4D1///nU2l0yInEMCvsgzCvkU4ucBP1O1cFUAYnUsA5cPZMrOKdlbMCFyiBQFfKVUJaXUl0qpA0qpGKXU5pQ+gVKqm1Jqj1LqtlLqilJqrVIqX5pLLMRdlPItxdYntlK7uH1I7Kh1oxi/ebz03hFOL6V3+DWAdsDfwNGUXlwp9TQwF1gDtAWeBo4hbQciExXJV4SNj2+kcenGtrRxW8bx/E/PS9AXTi2lAX+F1rq01roncJcJYu2UUoWBj4DhWus3tNabtdY/aq2Ha61vpLXAQqREQa+CrHtsHa0rtralfbTzIwatGCSDs4TTSlHA11rHpuHavSx/v03DuUKkWz6PfCzvs5xu1brZ0mb+PpO+S/oSGSNz3Qjnk5mNtvUxVUADlVLnlFJRSqldSimZQlBkGU83T37o8QNPPPCELW3BnwvoMr8L4VHh2VcwIbKBSm2dplJqEVBYa90smXzrgEZAKDAauGL5GwTcq7W+mMg5wUAwQLFixQLnz5+fqrJZhYWFkT9//jSdK4y89h7G6lg+O/EZS0KW2NLu87uPd2q+Qz63uH0Imjdvbnu8adOmND1fXnv/spq8f2nXvHnzfVrroMSOZWbA/wloBbTVWq+1pPkCZ4CpWuu7rk8XFBSk9+7dm6qyWW3evJlmze5aPJGMvPgeaq0Zu3ksb219y5YWVDKINf3WUNinsC3Nca3ctDby5sX3LyvJ+5d2SqkkA35m9pa5BmhgszVBax2qlNoHZN5qFUIkQSnFm83fxM/TjxfWvwDA3vN7afpNU9b3X0/JAiUB6NChQ3YWU4hMk5kB/y9AWTZHCkhLI7AQGeL5Rs/j6+nL4JWD0WgO/3eYJl83YcOADVS4pwIrVqzI7iIKkSkys9F2peWvrUJUKeUHBAJ/ZOLzCpGsQYGDmNt9Lm4u5p7n1PVTPDjrQQ7/dzibSyZE5knpSFsfpVQPpVQPIAAoYt1XSvlY8hxXSs20nqO13gssA2YqpR5XSrUHlgNRwGcZ/kqESKU+NfuwtPdSvNy8ADh/8zwPzXqIfedlpSuRN6X0Dr8osNCyNcDUwVv3i1ryuAGu8c57DFgKTAYWYYL9w1rra+kqtRAZpH3l9qzpt8a2XOKV21do/m1zNp1KW+8cIXKylA68Oq21Vklspy15ymmtn4h3XpjW+n9a60Jaa2+tdUut9cGMfxlCpF2zcs34ecDP+Hv7A3Az8iYPf/cwtcfVztDF0YXIbjJbphBAvYB6bHliC8XzF7el7Vf7qfxpZT7c/qGMzBV5ggR8ISxqFq3Jrqd3mf5lFjcjb/Li+hepNa0Wq4+tzr7CCZEBJOAL4aCMXxn4AfgO+M+efvTKUdrPbU+HuR04duVYdhVPiHSRgC9EYk4C02BKmyn4evraklcdW0WNz2swev1oQu+EZl/5hEgDCfhCJCUWRjYYybHhxxhUZxDKMoYwKjaKidsnUmVqFb7d/y2xaZpMVoisJwFfiGQUzVeU6R2ns2fQHhqVsk/2+m/Yvzyx7AkazmzI7pDd2VhCIVJGAr4QKRRYMpBtT21jTrc5lMhfwpa+O2Q39WfU58llT0o3TpGjScAXIhWUUvSt1Zejw4/ySpNX8HD1sB37Zv83VP60MhN/nUhkrHTjFDmPBHwh0iC/R37ebvE2h4cepnOVzrb0m5E3Gb1hNF22d6HTvE5M3T2Vvy//LWvpihxBFhMXIh0q+ldkaZ+l/HTiJ0auHcmRy0cAuB1zmxVHV7DiqJl5s4xfGVpVaEXriq1pUb4FhXwKZWexhZOSgC9EPIMGDUr1Oa0rtubAkAN8tuczPtr5Ef/c+CfO8X9u/MPM32cy8/eZKBSBJQNtXwCNSjeKUzUkRGaRgC9EPNOnT0/Tee6u7jzb4FlG1h/JnDVzuFH4ButOrGPjqY3cirply6fR7D2/l73n9/LutnfxcfehWblmti+AaoWrxVl1S4iMIgFfiAymlKKUTykeq/cYz9R7hqiYKHaH7OanEz+x5vga9l3YF6fvfnhUOKuPrbZN3RBQIIAqhatQ2Kcwhb0Lm78+hSnkU8j22Lr5uPtk18sUuZAEfCEymburO43LNKZxmcaMbz6e6xHX2Xhqo+0LIH71T8jNEEJuhqTo2t5u3gm+BAp5FyK/R3683Lzwdvc2f928U7zv7eaNm4sbLspFfmnkMRLwhchiBb0K0q1aN7pV6wbAiasnWH9yPetOrOPnkz9zM/Jmiq91O/o2Z0PPcjb0bKaU1c3FDTcXN1yVq+2xm4sbri7x9h2Ou7q44qpcbV8YLsrFtini7Sdx/PLlyxS9ZJbaUEqhULa/qUmzptseW/MmdzyJLzqVYMXWxPMmli8l5zl6pu4z1ChaI9nrpIYEfCHiCQ4Otj1Oa31+alT0r0hF/4oMCRpCdGw0h/87zMWwi1wOv2zbLt66yMWwi1wKv8Tl8Mtcu32N6xHXiYqNytSyRcdGEx0bnanPkaTL2fO0OUWnKp0k4AuR2b766ivb46wI+I7cXNy4r9h9UCz5vFprwiLDuBx+mSu3r8T5ggiPCiciOoJbUbcIjwznVtQtbkfdJjw6nIioCPM3OoKIqAhuR9/mTswd7kTfITImkjsxd7IvyItMJQFfiFxKKUUBzwIU8CxA+XvKZ/j1Y3UsMbExtrv86NhoYnS8/SSOx+pYYnUsWmv7Y+yPkzt28NBBatQwd7daazQ60b9AosesHAe8WdMTS3NMd0xzlNjgucTypmSQXVLP4ah6kerJ5kktCfhCiES5KBdcXF1wd3XP8uf2v+hPs+rNsvx58zqZWkEIIZyEBHwhhHASEvCFEMJJSMAXQggnIQFfCCGchAR8IYRwEhLwhRDCSaicuhKPUuo/4EwaTy+M0w/MTjd5D9NH3r/0kfcv7cpqrYskdiDHBvz0UErt1VoHZXc5cjN5D9NH3r/0kfcvc0iVjhBCOAkJ+EII4STyasDP2ikO8yZ5D9NH3r/0kfcvE+TJOnwhhBAJ5dU7fCGEEPFIwBdCCCeRpwK+Uqq6UupnpVS4Uuq8UupNpZRrdpcrN1BKPaGU0olsQ7K7bDmRUqqSUupLpdQBpVSMUmpzInmUUuoVpdRZpdRtpdRWpdQDWV/anCeF79/pRD6P/2ZDcfOMPLMAilLqHmADcBjoDFQEJmG+1F7LxqLlNg8Dtx32T2ZXQXK4GkA7YCeQ1AohLwOvAy8CR4DngA1KqZpaa2cPXCl5/wDmAp867EdmZqHyujwT8IEhgDfQTWsdCqxXSvkC45RSH1jSRPL2aK3DsrsQucAKrfUyAKXUIszIUBullBcm4L+rtZ5qSdsBnAaGITchd33/HFzQWu/MumLlbXmpSqctsC5eYJ+P+RJomj1FEnmV1jo2mSyNAF9ggcM5t4AVmM+qU0vB+ycyQV4K+FUxP5tttNb/AOGWYyJlTiilopVSfyulBmd3YXKxqkAMcCxe+l/I5zE1BiqlIpVSN5RSi5RSZbO7QLlZXqrSuQe4nkj6NcsxcXcXMPXNuwFXoA/whVLKR2v9UbaWLHe6BwjTWsfES78G+CilPLTWUh99d8swdfzngGrAWOAXpVQtrfWNbC1ZLpWXAr5IB631OmCdQ9IaSz30a0qpj+UnuMhqWuuRDru/KKW2A/uBJ4Ep2VGm3C4vVelcA/wSSb/Hckyk3iLAHyiXzeXIja4B+RPpFnwPEC5396mntT4E/A3Uye6y5FZ5KeAfIV7dqFKqNOBDvLp9kWI63l+RckcwVWOV4qUnaGsSqaKRz2Oa5aWAvwZoo5Qq4JDWG9OnfEv2FCnX64FZhCKtC9E4s+1AKNDTmqCU8gE6Yj6rIpWUUjUxX5j7srssuVVeqsP/AhgBLFFKvQ9UAMYBk6UPfvKUUosxDbYHMHemvS3bCKm/T8gSvNtZdgMAX6VUD8v+aq11uFLqPeB1pdQ17AOvXIg7kMgpJff+Ac2Bx4CVwHlMoH8N+Af4JksLm4fkqdkylVLVgalAQ0yPnRnAuER6Soh4lFLvAN2B0oDCjFieorX+PlsLlkMppcoBp5I4XF5rfVoppYBXgP8BhYC9mC/Q37OmlDlXcu8fZgzDR8B9QEHgCrAWeEVrfT4Lipgn5amAL4QQIml5qQ5fCCHEXUjAF0IIJyEBXwghnIQEfCGEcBIS8IUQwklIwBdCCCchAV/keEqp9UqpZy2Pn1VKrY13XCulhjnsByulumRtKUEpVVQpNc7Sx9wxvZmljDWzukxCOJKAL3KD+zGzJALUBv5IJn8w0CUTy5OUopgpfMvFS/8NMxjwRFYXSAhHEvBFjqaUKgEUIXUBPyOf31Up5ZGea2itQ7XWO7XWt5PPLUTmkYAvcrr7gTNa6+tKKU/MQhhJBnyl1GYgEHjcUo2ilVJPOBx/Win1p1LqjlLqjFJqdLzzv1FK7VVKdVFK/QlEAPWVUiWUUl8rpU4qpW4rpY4qpSZYvwws1TgHLZfZZH1uy7EEVTpKKR+l1CdKqX+VUhFKqT1KqdbxX4tllae+SqnjSqlQpdQapVSpePnGWI5HKKUuKqXWKqWKp+5tFs4gL02eJvIQa7BMYv+QmaaGJ7XW38Q7dSiwGDgJvGVJO2G5xovAO8AHwGbMF8NbSqlw60LjFuUsed4E/sXM+VIYuIqZAO0aUBkzOV8RYDBmxbB+wBzgGUw1zt18BXTCzLVzHBgErFJKNddab3PIVx8oCTyPWZ/5Y2A6lonHlFIDLNd4CfgTM2fPw0C+ZJ5fOCOttWyy5bgNeMCy7QHeszyeAvzicMzfklcDwxzO3Qt8E+96vkAYMDZeujWou1r2v7Fc74FkyucG9MX8AvCwpNW0nNssXt5mlvSalv1qQCzwuEMeF+AQsM4hbTNwA7jHIe1Zy7W8LftTgcXZ/e8lW+7YpEpH5Eha6/2Yqpt7geWW/eLAJq31fst2NRWXbIi5612olHKzbsBGoBjgWE0SYnk+G2U8q5Q6rJS6DURh7uY9gTKpfHl1MTOSLrQmaDMF9UKgSby8e7TWjiu2Hbb8DbD83Q+0U0qNV0rVS2SFLSFsJOCLHMfSUOoG1MCsWHbAsl8P2GMJ1qn97Ba2/P0TE6yt2yZLemmHvBcTOf9Z4EPgR6CzpSzPWI55pbIsJTALnIfHS7+IWeDc0yHterw81qURrc/5NaZKpxewC7hoaVuQwC8SkDp8kROdAMo67N90eLzc8nc8pg49pay/BjqQeED/2+FxYnOG9wQWaa1ftSZY1l9IiwuY9W594gX9Ypj1bu+k9EKWXwYfAR9ZlvTsB7wNnMMsCiSEjQR8kRN1xFSVWAPXNOARTJ35AEueuy2CEUnCu+4dmOUuS2qtV6WhTN5A/EDcL5HnJZHnjm8P5kulB/AdmCojy/62u5x3V1rrs8B7SqkngbR+GYk8TAK+yHG01gcBlFI1gEla671KqUHAWq313hRc4ghmfeM2mJWSTmmtryilxgEfK6XKAlsxVZqVgeZa667JXHM9MEIptQvzC6QfCRco/wfzpfK4UuoGEJVYebXWfyml5gFTLWswn8D00qmKWR0rxZRSX2J+vezENPA2x7R7vJSa6wjnIAFf5EiW6pLCmF45AK2AYUmfEccETEPqAkzvnCcxvXY+UEqdB0ZhujlGAEeBH1JwzTcxXTAnWPaXYNZQXmHNoLWOsHwxjQW2AO6YxtnEDALeB97ALOF3EOig43bJTIkdlmsNxvyyOA4M0lovTeV1hBOQJQ6FEMJJSC8dIYRwEhLwhRDCSUjAF0IIJyEBXwghnIQEfCGEcBIS8IUQwklIwBdCCCchAV8IIZzE/wE+5Ou7V4M4jAAAAABJRU5ErkJggg==",
      "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_q_mean[:-1], label=\"PBO linear\", color=\"blue\", zorder=7)\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\", zorder=3)\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_linear_max_linear_q_mean, label=\"PBO deep\", color=\"green\", zorder=8)\n",
    "plt.fill_between(iterations_validation, PBO_linear_max_linear_q_confidence_interval[0], PBO_linear_max_linear_q_confidence_interval[1], color=\"green\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations, fqi_q_mean, label=\"FQI\", color=\"red\", zorder=6)\n",
    "plt.fill_between(iterations, fqi_q_confidence_interval[0], fqi_q_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(r\"$|| Q^* - Q_i ||_2$\")\n",
    "plt.legend().set_zorder(9)\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": [
    "### Visualization of the policies at iteration max_bellman_iterations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from pbo.utils.two_dimesions_mesh import TwoDimesionsMesh\n",
    "\n",
    "max_pos = 1.0\n",
    "max_velocity = 3.0\n",
    "\n",
    "states_x = np.linspace(-max_pos, max_pos, n_states_x)\n",
    "states_v = np.linspace(-max_velocity, max_velocity, n_states_v)\n",
    "\n",
    "q_visu_mesh = TwoDimesionsMesh(states_x, states_v, sleeping_time=0, axis_equal=False, zero_centered=True)\n",
    "\n",
    "optimal_pi_weighted_average = (2 * ((optimal_q[:, :, 1] > optimal_q[:, :, 0])).astype(float) - 1) + (optimal_q[:, :, 1] == optimal_q[:, :, 0]).astype(float) / 2\n",
    "# optimal_pi_weighted_average *= samples_mask\n",
    "\n",
    "q_visu_mesh.set_values(optimal_pi_weighted_average)\n",
    "q_visu_mesh.show(\"\", xlabel=\"x\", ylabel=\"v\", plot=False, ticks_freq=2)\n",
    "_ = plt.savefig(f\"figures/optimal_pi.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fqi_left_q = fqi_q[:, -1, :, :, 0]\n",
    "fqi_right_q = fqi_q[:, -1, :, :, 1]\n",
    "fqi_pi_weighted_average = (2 * (fqi_right_q > fqi_left_q).mean(axis=0) - 1)\n",
    "# fqi_pi_weighted_average *= samples_mask\n",
    "\n",
    "q_visu_mesh.set_values(fqi_pi_weighted_average)\n",
    "q_visu_mesh.show(\"\", xlabel=\"x\", ylabel=\"v\", plot=False, ticks_freq=2)\n",
    "_ = plt.savefig(f\"figures/fqi_pi_{max_bellman_iterations}.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZwAAAEOCAYAAAC976FxAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAAlL0lEQVR4nO3deZxcVZn/8c+3swARAoGIgKJh0cngLkEFxATZBlBBBXFFcInr4M8FxJEluIyigsPAKDaguCMog7IJBEgAAcewiAJhERIFFAkmEIiEpPv5/XFuSaWorqpO1b11u+r75nVfnbr3nLpPN933qXPuuecoIjAzM8vbQLcDMDOz/uCEY2ZmhXDCMTOzQjjhmJlZIZxwzMysEE44ZmZWiFIkHEkHSLpW0sOSnpB0h6SjJE1sUm9DSd+VtFTSI5J+JGmTouI2MysDSdtK+rakWyQNSZrXYr1Cr6Hj83rjUdoEuAL4GrAMeCUwB9gM+FiDemcDLwDeDwwDxwPnAbvkFqmZWfm8ENgHuB6YMIp6hV5DVdYHPyV9CfgoMCXqBClpR+BaYGZEXJXteyXwG2CPiJhbZLxmZt0iaSAihrN//wyYGhGzmtQp/Bpaii61ETwMNOpS2xt4sPKDAoiI/wPuzY6ZmfWFSrIZpcKvoWXpUgNA0jhgHeAVwGHAt+q1bjLTgYV19t+eHTMzs5EVfg0tWwvn8Wy7GpgPHN6g7BTS/Z5aS7NjZmY2ssKvoaVq4QA7AZNIgwaOAU4BPtLJE0iaDcwGYJy2Z1LZfgRm1o71l08q5DyP8ciSiHhmO++hqesGTzbpDVu+6lbgiao9gxEx2M55u6VUV9uIuDH75zWSlgDfk3RCRPyxTvGlQL3/2VOyYyOdYxAYBNDkicGrNm0zajMrkxlzX1bIeeZx4eK232TVMNrxWQ2LxKX3PRERM9o+19Ot1TW0HWXrUqtWST5bjXB8IfX7GUfqlzQzKxkxMH6g4Zajwq+hZU44O2df7x3h+MXAZpJeU9khaQawdXbMzKzcBBpQwy1HhV9DS9GlJulXwFzgVmCIlGw+Bfy00p0m6W5gfkS8DyAirpN0KfB9SZ/mqYeWrvEzOGY2Fgg6klQkTSI9+AnwbGCypAOy1xdFxIoyXENLkXCA3wKHANOA1cA9wGeBU6vKjAfG1dQ7CPgG8B1Sa+0C0nBqM7PyE2igIx1NmwLn1OyrvN4KWEQJrqGlSDgRcTRwdJMy0+rsWwYcmm1mZmOL1JH7NBGxiNRgalRmWp19yyjwGlqKhGNm1o8EDOR7n6ZUnHDMzLoo54EBpeKEY2bWLR3qUhsrnHDMzLpFoHFu4ZiZWc46NSx6rHDCMTPrFomB8bUjlXuXE46ZWRe5hWNmZvmTE46ZmRVAwqPUzMysCLlP0FkqTjhmZl3UTwmnFG05SQdK+qWk+yU9JukGSW9vUudfJP2PpNslrZB0j6STJG1UUNhmZm2pdKl1aT2cwpWlhfNJ0ro3nwCWkKbZ/rGkqRFx8gh19iAtY/At4BbSGg5fBHaU9OqIaLJuq5lZl3nQQFe8ISKWVL2+QtIWpEQ0UsL5CfA/ERHZ63mS7gMuAXYB5ucWrZlZR4iBzixPMCaUIuHUJJuKm4C3NKjz8Ah1ALboRFxmZnmSYIIf/CyFHYE716IOa1HPzKxwQoxzC6e7JO0G7A+8dxR1JpGWR50fETfkFJqZWecIBjx5Z/dImgb8GPhFRJzZYh0BZ5CWWd23SdnZwGwA1u2fpqyZlY8kJowv3WU4N6X6TiVtDFwMLAbeOYqqxwNvAvaIiHsaFYyIQWAQQJMnRqOyZmZ5EjDOo9SKl3WJXQBMBF4fEStarPcJ4NPA2yLi6hxDNDPrOI9SK5ik8cA5wPOBnSLiby3WeydwAvDJiDg7xxDNzDpO8rDobvgm6WHPjwObSNqk6thNEbFS0uUAEbEbgKSZwHeBS4HrJb26qs59EXFfMaGbma0dD4vujj2zryfVObYVsAio/b+yKzAB2Cvbqh0HzOlceGZmefCw6MJFxLQWysyqeT0HJxUzG8PkYdFmZmPXvN1vbvs9Zs19Wdvv0QrhYdFmZlYEeVi0mZkVQJ6808zMiuBRamZmVgx5lJqZmRVAeJSamZkVwJN3mplZYTxKzczMcid58k4zMyuAJCaOn9DtMArjhGNm1iVCjJNbOGZmVoBxA34Op3CStgUOB3YEXghcXTthZ50604B76xz6aUS8rdMxmll/aGk+trntn6dTXWqStgNOJl0/lwGnA8dFxFCDOtMo+PpZmoRDSjL7ANeTlh0YjU8Dv656vaRTQZmZ5aUTXWqSppDS323AfsA2pIUpB4CjWniLwq6fZUo450fELwAk/QyYOoq6d0TE9fmEZWaWD6kjXWofAtYD3hwRjwKXSZoMzJH01WxfI4VdP0tztyoihrsdg5lZkUTqUmu0tWBv4JKaxHIWKQnNzCPutVWahNOm70oakvQXSSdKWq/bAZmZNaXUpdZoa8F0YGH1joj4E7AiO9ZMYdfPMnWprY2VwP8AlwKPArOAz5D6MPfrXlhmZs2JjnSpTSENFKi1NDs2ksKvn2M64UTEX4CPVe2aJ+lB4JuSXhoRv6utI2k2MBuAdftnOKKZlY9oabboqZIWVL0ejIjBds+9NtfPdvVKl1q1n2Vft693MCIGI2JGRMxgQi9++2Y2Vkhi4rgJDTdgSeWalW21yWYpsGGdt5+SHRuNhtfPdo3pFs4IouarmVlpdaBLbSE192okbQlMoubeTgtyvX724kf8A7KvN3Q1CjOzJpQtwNZoa8HFwF6SNqjadxDwD2D+KEPK9fpZmhaOpEmkBz8Bng1MllT55i+KiBWS7gbmR8T7sjpzgA1IDy09CryWNFvBuRFxS5Hxm5mNVodmGjgVOAw4V9LxwNbAHODE6qHSZbh+libhAJsC59Tsq7zeClhEire6/bmQ9JTs+0ljzv8EfA34Up6Bmpl1gqDtmQYiYqmk3YBTgPNJI9a+QUo61bp+/SxNwomIRaSff6My02pen0V6wMnMDIBZc19WyHnmcX8H3kUdmbwzIm4DXtekzLSa14VfP0uTcMzM+s2A18MxM7OieD0cMzPLXRql1j8PoDvhmJl1iRDjB/rnMtw/36mZWQkNuEvNzMzyJpxwzMysCHKXmpmZFUCIgZ6cYaw+Jxwzsy5yl5qZmeXOo9TMzKwYcgunKyRtB5wM7EiafO504LiIGGpSbwbwn8CMbNeNwOci4jf5Rdu6ouZ1ambe7jd3OwSzMaOlv5e57Z/H93C6QNIU0v++20hraW8DnEBar+eoBvW2zOrdCLw72304cJmkF0fE4jzjNjNrh8Bdal3wIdL02G/O1m+4TNJkYI6kr1av6VBjX9J6Dm+KiEcAJF0LLCGtrfOt/EM3M1tb6qsutbJ8p3sDl9QklrNISWhmg3oTgNXA41X7Hsv2NVzqwMysDAY00HDrJWX5bqZTs/Z2RPwJWEHNWt01fp6VOUHSppI2JS08tJSnL+ZmZlYqkvoq4ZSlS20KaaBAraXZsboi4gFJuwIXkJZYBfgLsFdEPNTpIM3MOknAeJXlMpy/MZ0+JW1OasncQOqW2zv794WSnjtCndmSFkhawKrh4oI1M3sat3C6YSmwYZ39U7JjIzmcdB/ngIhYBSDpCuAu0lrdh9VWiIhBYBBAkydGe2GbmbWn15JKI2VJOAupuVeTDXmeRM29nRrTgVsryQYgIp6UdCtpaLWZWWmpzybvLEtqvRjYS9IGVfsOAv4BzG9QbzHwIkkTKzskrQO8CFiUQ5xmZh0jYKDJf72kLN/NqcBK4FxJu0uaDcwBTqweKi3pbklnVNU7HdgC+F9J+0p6PXAesDlZt5mZWXn11z2cUnw3EbEU2A0YB5wPHEca3nxsTdHxWZlKvRuAfyM9/PkD4Pukbrg9IuJ3+UduZrb2BIzTuIZbLylN52FE3Aa8rkmZaXX2XQ5cnlNYZiPyPHmd14mf6dj6eQj1WCumkdIkHDOzfjTQR5OiOOGYmXVJmi26t7rNGnHCMTPrFqWh0f3CCcfMrItUjrFbhXDCMTPrEiHGuUvNzMyK4C41MzMrhLvUzMysAP214qcTjplZlwi3cMzMrCB+8NPMzAogBnpsvrRGSpNwJG0HnAzsSFpu+nTguIgYalJvQ+C/gP1Jk5FeABwWEQ+3G1NZ5soy6xdjax609qUutfZbOGW8ftZTioQjaQowF7gN2I+0eNoJpB/AUU2qnw28AHg/MAwcT1qiYJecwjUz6xC1fQ9nLF0/S5FwgA8B6wFvzta/uUzSZGCOpK9Wr4lTTdKOwJ7AzIi4Ktt3P/AbSbtHxNyC4jczWysduIczZq6fLadWSa9Tfk8o7Q1cUvODOYv0Q5zZpN6DlR8WQET8H3BvdszMrLSU3cNptLVgzFw/R9OWmwvcL+kkSTt1OI7pwMLqHRHxJ2BFdqzlepnbm9QzMysFNfmvBWPm+jmahPNi0o2ovYBrJC2W9DVJ23cgjimkG121lmbHOl3PzKz7BNJAw60FY+b62XLCiYhbI+KYiJgOvAL4MfAm4LeS7pb0xTwC7DRJsyUtkLSAVcPdDsfM+phCDMRAww2YWrlmZdvsbse9ttZqeERE3BwRn42IbYE3kvoKP9tGHEuBDevsn5Id61i9iBiMiBkRMYMJ/fOEr5mVTxBENN6AJZVrVrYN1rxNYdfPdq3VFVfSFEnvl3QZcC6wPqnFs7YWUtNnKGlLYBL1+xhHrJcZqW/SzKxUIhpvLRgz18/RjFKbLOk9ki4C/gqcRMqCbwOeFRHvbiOOi4G9JG1Qte8g4B/A/Cb1NpP0mqo4ZwBbZ8fMzMorIIaGG24tGDPXz9G0cB4CTgWeBA4BNo2It0bEuRHxRJtxnAqsBM6VtHvWRzkHOLF6qF92r+iMyuuIuA64FPi+pDdL2h/4EXCNn8ExszFhuMnW3Ji5fo7mwc/ZwHkR8Uing4iIpZJ2A04BzieNnPgG6YdWbTw8bXm8g7Ky36FqaoZOx2hmlodosd+sQf0xc/1sOeFExPfyCiJ7/9uA1zUpM63OvmXAodlmZjZ2BMRQewkHxs71syxT25iZ9Z3KKLV+4YRjZtZFfZRvnHDMzLqmQ11qY4UTjplZNw074ZiZWd6i/VFqY4kTjplZlwThLjUzMytGHzVwnHDMzLrGXWpmZlYUd6mZmVn+Ao9SMzOzYvRRj5oTjplZtwS+h1M4SSKtGPphYCrwW+CwiLi5Sb2JwJHAwcCzgftJ02v/Z0SsbHbe9ZdPYsbcl7UV+1gxqwPf57zdb277PXqJfx7WtuivYdFlWWP5SOBo4HjgDcBjwFxJmzWp95Ws7jeBfYBvAUcAX80vVDOzzonhaLj1kq63cCStS0oaX46IU7J91wGLgI8BRzWo/g7gWxFxYvb6SknPBt4JfDy3oM3MOmS4x5JKI2Vo4ewETAbOruyIiMdJCwnt3aTuBKB2QbhlgDoYn5lZLiJgaGi44dZLypBwpgNDwF01+2/PjjVyOvBBSTtLWl/SLqT7QKd0Pkwzs05r3J3mLrXOmwI8FhFDNfuXApMkTYyIJ0eoeySwHnBN1b5vRsTnc4jTzKyjIvqrS63QhJONRqteU7vdn/ThwLuAfwduAV4KfEHSwxFxzAgxzAZmA6zDem2e3sysDQFDq3ur26yRols4M4Erq17PJ927WV/SuJpWzhRgxUitG0lTgS8CH42I07LdV0l6EjhF0ikR8bfaehExCAwCbKCN+uejhZmVUq91mzVSdMK5Adih6vVy0vMz44BtgTuqjk0HFjZ4r61JgwZurtl/E+n7eh7wtIRjZlYWQTDsBz/zERHLgQXV+yQtBh4FDiS1WJA0ifQ8zmCDt1ucfX0F6UHRiu2zr4vaj9jMLEcBw+5SK05EPCHpK8DRkpaSWjWfJI2gO7lSTtLBwHeAbSJicUQ8KOk84PjsWZ5bgJcBc4BzIuKhQr8RM7NRCjxooBu+QkownwU2IbWC9oiIB6vKDJC63qqfsXkPcAxwGLAFaWqbbwNfKCBmM7P2hO/hFC7S7HVfyraRypwJnFmz71Hg09nWcZ2YK6sTc5iZWa+Knnu4s5FSJBwzs37k53DMzKww7lIzM7PcRYQf/DQzs2K4hWNmZvnzPRwzMytCgEepmZlZAaL3liBoxAnHzKyL3KVmZma5C880YGZmhYhg9eratSd7lxOOmVmXBG7hFE7SR4B9gVcDGwO7RsS8FuqdSZrAs9a/RkSjtXQAeGyDFcx71c2jinW0OjEfWyd4Tjezchoe7s4oNUkfAI4AtgRuBY6IiMub1JkDHFvn0N4R8atm5yxFwgEOJiX7S4C3j7LuQuDQmn2LOhCTmVmuIoKhVcV3qUl6O3AqaTmXa0jX0Ask7RARf2hS/RHg32r23d7KecuScHaKiGFJL2L0CefxiLg+j6DMzHLVvQc/5wDfi4gvAEiaD7wcOBJ4V5O6q9f2mjuwNpU6LSL658knM7MqMRwNt06TtDXwAuDsf8aQrsHnAHt3/IRVSpFw2rSdpEclrZR0jaSZ3Q7IzKwVafLOoYZbDqZnX2vvc98ObCzpmU3qbyRpiaRVkm6S9OZWTzzWE85NwKeANwDvJK0IepmkV3Y1KjOzFg0PDzfccjAl+7qsZv/SmuP13E0aaHAg8BbgAeDnrSadQu/hSBIpKVRERKx1Co+Ik2re/yLSaIv/APYfIYbZwGwA1h1Xr4iZWSFaXIBtqqQFVa8HI2KwuoCkDYHNm5+v+ejdJvV/WHPe84FrgWOAc5vVL3rQwEzgyqrX84FZnXrziFiRJZ03NCgzCAwCaPLE/hkAb2blk3WpNbEkImY0KXMgcFoLZxRPtWQ2ZM1WTqVls5QWRURIOhc4XtK4Zg2IohPODcAOVa+X53COyDYzs1ILOjNKLSJOB05vsXillTMdWFy1fzrw94h4aLSnp8VrbqEJJyKWAwuaFlxLktYjPUB6Q17nMDPrnCAKfvAzIu6RdCepVXQJgKSB7PXFo3mv7DbJW4DftXJ7pBTP4UiaAUwjPfEKMFPSVGBRRCzIyhwMfAfYJiIWZ32WFwA/JN3Imgp8AtiC9IMzMyu3oCsPfpKew/mhpEXAr0kztjwfeEelQDbi93Jgt4iYn+2bD/yc1Ep6BvAB4FWMcM+8VikSDvAx1pyiZk729XvAIdm/B0gDDpS9Xgk8BBwFbAo8AVwHzKwkKTOzMmtx0EAO542fSFof+AxwNGmw1etrZhmoDPJS1b67gf9HGqAwDNwI7BsRLbWMSpFwIuIQnkosI5U5Eziz6vUTQMvjv619nZiPrSxzy5mVQ3RtPZyIOI0GAw2y+SxVs+997ZyzFAnHzKwfRZDXw52l5IRjZtY1xQ8a6CYnHDOzLunWPZxuccIxM+uW7o1S6wonHDOzrgliyF1qZmaWswiIIXepmZlZ3gKG3cIxM7O8dWuJ6W5xwjEz6xrfwzEzsyL4Ho6ZmRUhPCy6WJI2Bz4J7AlsQ1r85wrgsxHxQJO6HwQOAF4CrAv8ATguIi7NNegxyHOYdV4n5pazsWse97f/JtFfXWoD3Q4A2B54E/AT0kqdh5Omu742m820kc8B9wKVxHM38CtJb8wvXDOzzhkeioZbL+l6Cwe4BpgeEasrOyTdCNxBWtjnew3qviIillS9vkzS80nr4vwyj2DNzDoljVJb3bxgj+h6CycillUnm2zfncAK0mJqjeouqbP7pmb1zMxKIRs00GjrJWVo4TyNpJcAk4A716L6jmtZz8yscP10D6d0CSdbW/sk4C5G2S0m6b3Ay4FP5RCamVlH+cHPHEmqLFlaERFR+9P+MqmVMjMiVo3ivbcHTgZOiogrG5SbDcwGYN1xIxUzM8tfnz2HU/Q9nJnAqqrt8uqDkj5CGqX2noj4TatvKmlr4MLs/Rq2biJiMCJmRMQMJnT9FpaZ9bMIhoeGG269pOgutRuAHapeL6/8Q9JbSC2UIyLip62+oaRNgUuAxcDb6rSYzMxKyQ9+5igilgMLavdLmgX8CDg5Ir7e6vtlz+lclL18fUSs6ECYZmYF6a8HP7s+aEDSvwLnAQuBn0p6ddXhhyLij1m5maQus90iYn52/FzSLAOHANtI2qZSMSKuzz96M7M29Nk9nK4nHNKsAhsCLwWurTn2PVIyAagMOFDV8T2yrz+q876qs8/MrDSCYPVQ/zz42fWEExFnAme2UG4eNUkkItpKKusvn8SMMTAfludB6zzPg2ZlEAHDw+5SMzOz3AXDwx40YGZmOYuAVe5SMzOz/IW71MzMLH8BDIcTjpmZ5S18D8fMzArgYdFmZlYMD4s2M7MiBE44ZmZWgIhg1VDLq7CMeU44ZmZd42HRZmZWAA+LLpikicAPgRnA5sBjpCUMjoqIG1qovx/wReD5wD3AcaNZT2cs6MS8X2WZj81zmJk9JSJY3YUuNUkHAQeRVlfeDDg0m9eylbo7AyeSJlz+C/CNiPjvVuqWYcnLcaRE/2VgX+ADwCTgimwlzxFJeg3wc+BKYG/Sqp8/kbRnrhGbmXVE6lJrtOXkAGAacMFoKknalrTg5b3APsC3gRMlvb+V+l1v4UTEP0iZ9p8kzQUeBvYnZdKRHA1cFRGHZa+vlPRC4Bjg0s5Ha2bWQd0bFn1QRAxni1i2lCwyhwMPAO+KiNWkhsFzgWMlnRERDRf3KUMLp57HgSeAiSMVkLQOsCtwds2hs4AdJW2YX3hmZu0LglVDqxtuuZw31vrG0d7AuVmyqTgLeA7womaVS5NwlIyXtBnwVWAI+EmDKtsAE0grhVa7nfR9vSCXQM3MOiSyqW0abWUh6RnAltS/5gJMb/YeXe9Sq/IZ0n0cgIeAfSJicYPyU7Kvy2r2L605bmZWWmNolNpG2ddlNftbvuYWmnAkVZaJroiIqKTwM4G5pJFqHwEukPTaiLitwzHMBmZnL1fO48I/dPL919JUYEmuZ5hbjjjmcX8p4miR41iT41jTv7T7Bst55JIrhs+f2qTYupIWVL0ejIjB6gLZLYTNm50vImpbJ4UquoUzkzSirGI+MAsgIv4K/BVA0sXArcCRwMEjvFclq9beq5lSc3wN2f+owew8CyJixqi+gxw4DsfhOMZmHO2+R0T8WydiAQ4ETmuhnNo4x7Ls66iuudWKTjg3ADtUvV5er1BErJb0e6DRsOg/AqtI/Ybzq/ZPB4aBO9sL1cxsbIiI04HTcz7H45L+zNPv1VReN209FTpoICKWR8SCqu2OeuUkrQu8gjTWe6T3WklqLR1Yc+gg4LqIeKRTcZuZGQAXA2+SVH1r5CDgz0DT2xNdHzQg6e2koXa/Io3vrtzD2ZyqZ3AkHQx8B9imajDBF4B5kv4LOI/0INI+QKvN1MHmRQrhONbkONbkONbkONokaTtgO2DdbNcMSY8BD0XE/KzMTOByYLfKPuBrwDuBH0g6jdRj9UHgw82ewQFQC2VyJenlpKlptif1Bf4F+A3w+Yi4tarcIcB3ga0iYlHV/v15amqbe4E5EXFWQeGbmY05kuYAx9Y5ND8iZmVlZpF6kXaNiHlVdV9Dagy8hHTf/cRWp7bpesIxM7P+UJoHP83MrLc54ZiZWSGccMzMrBBdH6VWFEkbkOZXq35I6c6IqPssUFEkTQWeByyKiIe7GUu/kvQ60kjJ6az5+7EQuCgirhypbofj2BLYAvhjRDztSfrsd2WfiPh+EfFUnffFpEE9AdwQEbnPzpH9LPYhPah4TkQ8LOk5wKdJ8yguIj1x//u8Y7EOioie3oDdgatID4kOkR4KrWyrsmO75RzDROAbpBF4fwU+l+0/DliZxVWZrPQZOcbxAmBizb4ZwLmkP+B7gXOAlxfw/+XlwBmkcf3/BTy/TpmXAffkGMPGpIeGh0kPEl8A/CDbLgDuzo7NAzbOMY51sp975fdgVfaz2bCm3KuAoRzj+DGwddXrdYH/rfm7GSLN0D4hxzheCTwCrCbNGv8A8GLSsx6LSOteLc7+dnbJ+3c1i+l1pCHB5wPXZNv52b5di4ihF7auB5DrNwdvzf5ALgTenV1ct8m2Gdm+C7Jf7ANzjGMOsAI4gbRWzwPAyaRP0bNJY9k/TJo64ss5xjEEvLLq9WuzP9p7gFOymO4B/gHskGMcM7ILyb3Zz/+B7Jz/XlMu7wvsD4E7Gn2vWawLgR/kGMcx2f/7D2TnOwx4ELiLqkRcwM9juOb344Ts9/ZDpPnLNsn+vQI4Nsc4LiMNx92INCP8KcB9wC8qiY6UpC8Grswrjuw8pfhQ0itb1wPI+ZflVuD4Fsp9FbgtxzjuAj5R9XqX7OL/0ZpynyB18+UVR+0F5Wrg18B6VfvWA64HLswxjkuyP9bKxWMi8HlS4v9vnhqun/cFdhmwXwvl9geW5RjHQuBjNfs2I7W+HwJ2LOjnUfv78QBwTJ1yn8/59/RhYO+q15tmse1ZU25fYElecWTnKMWHkl7Zen3QwNbARS2UuxDYKsc4ng3cWPX6RlLf9O9qyt2UlS3KDsAJkVZdBf65Aus3gJ1yPO/2wMkRsSo755MRcQywH3Ao8PNseqO8DdPaZIbKyuZlS+CW6h2RJrPdjfSk99zsAeeibUr65F5rPvDcnM8ddf5d+9BgEQ8Rvh44IiJ+O1KBiFhAmmj4DQXEM6b1esK5i/TptJn9s7J5uZ90P6LipdnXF9eUewnpU2Weqv9IV5I+Qdd6iKemvMjL0y70EXEhqa98Z9KCChvnHMMvgBMk7TxSAUk7kfrp/zfHOB4gzZSxhohYFRFvI03KeA5PLauRp50k7SNpH1JLY3KdMpNJXaB5WQB8WtL6kgaA/yD9DX24MoeXpPGkKbDyHsBQlg8lPaHXR6kdDfwsG2VzNqnZuyw7tiFpVNKBpCUSDsgxjh8AX5L0bOBR0txDJwNfkLSS1NJ5BeleT64zvgJnSno8+/c40nxKV9eU2Rb4W44x3Eb69P6r2gMR8VtJu2THfpRjDAAfJ13Ir5b0V+r/fmxGuqfwiRzjuJp0P/GMegcj4uNZfF8i/0/1J9a83pPU/VltZ/L9gPY50s98KambdQXpg8g5wF2SbiUtZ7wFrc+buLYqH0oeiohf1ytQ0IeSntDzU9tk8/4cTUoqE3jqD1ak0UBXAl8Y6ZepQzFMAI4H3p7FcHpEHCnpCNIEpOOzeM4DDo6Ix3KK47t1dt8YESfXlLsK+FtE5JKEJX2GtMLrVjHCrN6SNifdFH5xRIyrV6aD8exIunDVGxZ9cURcn/P5Z5Bm3P1yRPy9Qbl3AHtExKE5xfG8OrtXZt171eWOBRZGxE/ziCM7x3NI3VnjgZ9HxF+y5eePIC18tpj0d3Rjg7fpRByTSYluD9II00YfSt4aEY/mGc9Y1/MJp0LSRNLotOoLyh8j4snuRQWSNiHda1ocEXm2KlqW/ZGtjLQERB7vP0AanPCPiJHX183u4zwrGi81bpa7bn8o6RV9k3DMzKy7en3QQEskbSkp71E3jmPsxnGapLr3VxyH47DWuYUDSFoFDOR9r8BxjNk47s7iaLTkuePo0ziyWE7LYnlft2Mps14fpdaq99Ha0Me8OY41lSKOiNi22zGA46hVljgyu+Ieo6bcwjEzs0K4hdMl2YNrRMRqx9HdOCStD8yk/gik+XkNU3ccYyOOVmQjKjeNiD91O5ZS6/bcOmXYSFOtfCfnc2xKmoPqt8BynpoZeHm27zjgmQV8r47jqRiUxfAY6Snxx0gzEv+5Zt9xZL0BjqN/4hhlzG8hx3nuemVzCyeZBrwHeG8eby7ppaSpWoI0pflPSZ/UIH1ym06ahffDknaPiFvqvpHj6LQ5wCdJF66zIuLPNXE+B3gbcGwW6xzH0VdxWIf19D0cSa9tsegs0nTruYyGkjSf9InswIhYMUKZSaQnmp8REbMcRyFx3A8cFxGDTcrNJv1+5DKxquMoZxzZOa5osegzge3yuob0il5v4cwjfQJqZaRTnpl3B+D1I11cASJihaQTSJ/4HUcxcWxEWuOkmT9mZR1Hf8UBac2oO0jz/zVSxOzmY16vJ5y/kyaB/HKTcnsCX88xjiWk+Z+afVqaTpqh13EUE8f1wBGSro+Ix+sVkPQM0rxv1zmOvosD0ppaCyPioEaFJB1A6hq2Bno94VxPmiDy1kaFJE3POY5Tga9L2phsxtvI+jIliTQ784Gkadi/5DgKi+NjpHtJf5J0CfUnZtyLtIzDbo6j7+KAdA1pZUbqVntS+lu3Ry3kuZHWy7iuhXLbA9/NOZbPkv5ohoAnSa2vv2f/HsqOHVnAz8RxrBnHRlks80nLOj+ZbQ9m+44ENnIcfRvHNsAbWyi3HvC8vOMZ61tPDxooG0nrkFbSrPdcwbWR0+zMjsPMyqAvE042Pf5c4IMRkedCUo5jDMZhZvno17l/RBoKvYHjcBxmVox+TThmZlYwJxwzMytEXyaciBgiTSd+h+NwHGZWjL4cNGBmZsXryxaOmZkVzwnHzMwK4YRjZmaFcMIxM7NCOOGYmVkhnHDMMpI2knSfpO/X7P+lpDuzReHMbC054ZhlImIZ8D7g3ZL2A5B0KLAv8J5osGCcmTXn53DMakj6NrA/aR2UK4FvR8RnuhqUWQ9wwjGrIWl94BZgC+BuYHsvlWDWPnepmdWIiMeAC4B1gDOcbMw6wy0csxqSdgCuBX4PPA94YUT8tbtRmY19TjhmVSStC9wI3AO8FfgdcHtEvLGrgZn1AHepma3pi8BmwAeyUWmHAPtKOqSbQZn1ArdwzDKSdgauAt4dET+u2v814APAiyLivm7FZzbWOeGYmVkh3KVmZmaFcMIxM7NCOOGYmVkhnHDMzKwQTjhmZlYIJxwzMyuEE46ZmRXCCcfMzArhhGNmZoX4/wxqlmAQjAGNAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "pbo_linear_left_q = pbo_linear_q[:, max_bellman_iterations, :, :, 0]\n",
    "pbo_linear_right_q = pbo_linear_q[:, max_bellman_iterations, :, :, 1]\n",
    "pbo_linear_pi_weighted_average = (2 * (pbo_linear_right_q > pbo_linear_left_q).mean(axis=0) - 1)\n",
    "# pbo_linear_pi_weighted_average *= samples_mask\n",
    "\n",
    "q_visu_mesh.set_values(pbo_linear_pi_weighted_average)\n",
    "q_visu_mesh.show(\"\", xlabel=\"x\", ylabel=\"v\", plot=False, ticks_freq=2)\n",
    "_ = plt.savefig(f\"figures/PBO_linear_pi_{max_bellman_iterations}.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "PBO_linear_max_linear_left_q = PBO_linear_max_linear_q[:, max_bellman_iterations, :, :, 0]\n",
    "PBO_linear_max_linear_right_q = PBO_linear_max_linear_q[:, max_bellman_iterations, :, :, 1]\n",
    "PBO_linear_max_linear_pi_weighted_average = (2 * (PBO_linear_max_linear_right_q > PBO_linear_max_linear_left_q).mean(axis=0) - 1)\n",
    "# PBO_linear_max_linear_pi_weighted_average *= samples_mask\n",
    "\n",
    "q_visu_mesh.set_values(PBO_linear_max_linear_pi_weighted_average)\n",
    "q_visu_mesh.show(\"\", xlabel=\"x\", ylabel=\"v\", plot=False, ticks_freq=2)\n",
    "_ = plt.savefig(f\"figures/PBO_linear_max_linear_pi_{max_bellman_iterations}.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Distance to optimal value function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "fqi_v_mean = np.sqrt(np.mean(np.square(fqi_v - optimal_v) * samples_mask, axis=(2, 3))).mean(axis=0)\n",
    "fqi_v_std = np.sqrt(np.mean(np.square(fqi_v - optimal_v) * samples_mask, axis=(2, 3))).std(axis=0)\n",
    "fqi_v_confidence_interval = confidence_interval(fqi_v_mean, fqi_v_std, n_seeds)\n",
    "\n",
    "pbo_linear_v_mean = np.sqrt(np.mean(np.square(pbo_linear_v - optimal_v) * samples_mask, axis=(2, 3))).mean(axis=0)\n",
    "pbo_linear_v_std = np.sqrt(np.mean(np.square(pbo_linear_v - optimal_v) * samples_mask, axis=(2, 3))).std(axis=0)\n",
    "pbo_linear_v_confidence_interval = confidence_interval(pbo_linear_v_mean, pbo_linear_v_std, n_seeds)\n",
    "\n",
    "PBO_linear_max_linear_v_mean = np.sqrt(np.mean(np.square(PBO_linear_max_linear_v - optimal_v) * samples_mask, axis=(2, 3))).mean(axis=0)\n",
    "PBO_linear_max_linear_v_std = np.sqrt(np.mean(np.square(PBO_linear_max_linear_v - optimal_v) * samples_mask, axis=(2, 3))).std(axis=0)\n",
    "PBO_linear_max_linear_v_confidence_interval = confidence_interval(PBO_linear_max_linear_v_mean, PBO_linear_max_linear_v_std, n_seeds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "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_linear_max_linear_v_mean, label=\"PBO deep\", color=\"green\", zorder=8)\n",
    "plt.fill_between(iterations_validation, PBO_linear_max_linear_v_confidence_interval[0], PBO_linear_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.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(r\"$|| V^* - V^{\\pi_i} ||_2$\")\n",
    "plt.legend().set_zorder(9)\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": [
    "### Value functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "fqi_v_mean_performance = (fqi_v * samples_mask).mean(axis=(2, 3)).mean(axis=0)\n",
    "fqi_v_std_performance = (fqi_v * samples_mask).mean(axis=(2, 3)).std(axis=0)\n",
    "fqi_v_confidence_interval_performance = confidence_interval(fqi_v_mean_performance, fqi_v_std_performance, n_seeds)\n",
    "\n",
    "pbo_linear_v_mean_performance = (pbo_linear_v * samples_mask).mean(axis=(2, 3)).mean(axis=0)\n",
    "pbo_linear_v_std_performance = (pbo_linear_v * samples_mask).mean(axis=(2, 3)).std(axis=0)\n",
    "pbo_linear_v_confidence_interval_performance = confidence_interval(pbo_linear_v_mean_performance, pbo_linear_v_std_performance, n_seeds)\n",
    "\n",
    "PBO_linear_max_linear_v_mean_performance = (PBO_linear_max_linear_v * samples_mask).mean(axis=(2, 3)).mean(axis=0)\n",
    "PBO_linear_max_linear_v_std_performance = (PBO_linear_max_linear_v * samples_mask).mean(axis=(2, 3)).std(axis=0)\n",
    "PBO_linear_max_linear_v_confidence_interval_performance = confidence_interval(PBO_linear_max_linear_v_mean_performance, PBO_linear_max_linear_v_std_performance, n_seeds)\n",
    "\n",
    "optimal_v_performance = (optimal_v * samples_mask).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "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",
    "iterations = range(max_bellman_iterations + 1)\n",
    "iterations_validation = range(max_bellman_iterations_validation + 1)\n",
    "\n",
    "plt.hlines(optimal_v_performance, 0, max_bellman_iterations_validation, color=\"black\", linestyle=\"--\", label=\"Optimal\")\n",
    "\n",
    "plt.plot(iterations_validation, pbo_linear_v_mean_performance[:-1], label=\"PBO linear\", color=\"blue\")\n",
    "plt.fill_between(iterations_validation, pbo_linear_v_confidence_interval_performance[0, :-1], pbo_linear_v_confidence_interval_performance[1, :-1], color=\"blue\", alpha=0.3)\n",
    "\n",
    "plt.hlines(pbo_linear_v_mean_performance[-1], 0, max_bellman_iterations_validation, color=\"blue\", linestyle=\"--\", label=\"PBO linear fixed point\")\n",
    "plt.fill_between(iterations_validation, pbo_linear_v_confidence_interval_performance[0, -1], pbo_linear_v_confidence_interval_performance[1, -1], color=\"blue\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations_validation, PBO_linear_max_linear_v_mean_performance, label=\"PBO deep\", color=\"green\")\n",
    "plt.fill_between(iterations_validation, PBO_linear_max_linear_v_confidence_interval_performance[0], PBO_linear_max_linear_v_confidence_interval_performance[1], color=\"green\", alpha=0.3)\n",
    "\n",
    "plt.plot(iterations, fqi_v_mean_performance, label=\"FQI\", color=\"red\")\n",
    "plt.fill_between(iterations, fqi_v_confidence_interval_performance[0], fqi_v_confidence_interval_performance[1], color=\"red\", alpha=0.3)\n",
    "\n",
    "plt.axvline(max_bellman_iterations, color=\"black\", linestyle=\"--\")\n",
    "plt.xticks(iterations_validation)\n",
    "plt.xlabel(\"iterations\")\n",
    "plt.title(r\"$|| V^{\\pi_i} ||_2$\")\n",
    "plt.legend()\n",
    "_ = plt.savefig(f\"figures/V_{max_bellman_iterations}.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Visualization of the last value functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from pbo.utils.two_dimesions_mesh import TwoDimesionsMesh\n",
    "\n",
    "max_pos = 1.0\n",
    "max_velocity = 3.0\n",
    "\n",
    "states_x = np.linspace(-max_pos, max_pos, n_states_x)\n",
    "states_v = np.linspace(-max_velocity, max_velocity, n_states_v)\n",
    "\n",
    "q_visu_mesh = TwoDimesionsMesh(states_x, states_v, sleeping_time=0, axis_equal=False, zero_centered=True)\n",
    "\n",
    "optimal_v_weighted_average = optimal_v * samples_mask\n",
    "\n",
    "q_visu_mesh.set_values(optimal_v_weighted_average)\n",
    "q_visu_mesh.show(r\"$V^{\\pi^*}, \\mathbb{E}\\left[ V^{\\pi^*} \\right] =$\" + str(np.round(np.mean(optimal_v_weighted_average), 2)), xlabel=\"x\", ylabel=\"v\", plot=False)\n",
    "_ = plt.savefig(f\"figures/optimal_V_{max_bellman_iterations}.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fqi_v_weighted_average = fqi_v[:, -1].mean(axis=0) * samples_mask\n",
    "\n",
    "q_visu_mesh.set_values(fqi_v_weighted_average)\n",
    "q_visu_mesh.show(r\"$V^{\\pi_{fqi}}, \\mathbb{E}\\left[ V^{\\pi_{fqi}} \\right] =$\" + f\"{np.round(np.mean(fqi_v_weighted_average), 4)}\", xlabel=\"x\", ylabel=\"v\", plot=False)\n",
    "_ = plt.savefig(f\"figures/fqi_V_{max_bellman_iterations}.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "pbo_linear_v_weighted_average = pbo_linear_v[:, max_bellman_iterations + 1].mean(axis=0) * samples_mask\n",
    "\n",
    "q_visu_mesh.set_values(pbo_linear_v_weighted_average)\n",
    "q_visu_mesh.show(r\"$V^{\\pi_{pbo}}, \\mathbb{E}\\left[ V^{\\pi_{pbo\\_linear}} \\right] =$\" + str(np.round(np.mean(pbo_linear_v_weighted_average), 4)), xlabel=\"x\", ylabel=\"v\", plot=False)\n",
    "_ = plt.savefig(f\"figures/PBO_linear_V_{max_bellman_iterations}.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZoAAAEOCAYAAACw8dE2AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAA86klEQVR4nO2dd7xcVdW/n+9NDyEkEDCUAILSmxBUinQQEQFfQAFFEF6i2JEiTQwC0kRBkBcQBCyI6A8QRKoQqpRQpEsPUgJJSIAQSLl3/f7Ye8jJZObM3HvOzJyZrCef/ZnMPnuvs+bcmbPObt8tM8NxHMdxGkVXqx1wHMdxOhsPNI7jOE5D8UDjOI7jNBQPNI7jOE5D8UDjOI7jNBQPNI7jOE5D8UDjOI7jNBQPNI7jOE5D8UBTYCR1SZosySTNjGm2pLmSLmm1f2lIGh/9LqXNM9hq2+tQDUmfLrs+41vtk+M0Cg80TUTS8fGmsklKmf6SnpI0E1gOOAB4wcyGmdkw4LfAuWa2f3O8zswhwL7Af0oZi+h1KOc5wnU5pNknlrSkpJ9Lek7SB5KmSLpN0mfqrD9M0tGSHpP0rqSpku6RtL8klZW1KmlmBbsfkXSepP9KmiPpZUlnSRpRoexRkv4i6YVo76W+Xg+n8fRvtQOLGI/F13WAf1Up821gDeBYM3tF0teAfyeOfwI4P+0kkg4DXjGzyzP6W8n2ScBmwCBgdoUik81sr8T7q83spbIyTbkO0d9croWkTwJfM7PvZLFTwsymAn+QtDLwyzxs1oOklYAJwDDgIuAZYAlgPWD5Oup3AdcDmwKXAmcDQ4G9gYuBNYEflVW7E7igLG9umd1lgPsIDxXnA48Tvh8HA1tI2szMZiWq/Ax4C3gIGFHLb6e1eKBpLskb7EJIWhL4CfAicEbM3gB4JB7vR7gh/LtC9SQbAP/I5Gl1xprZVpL+aGZf6aONZl2HUr08rsW6pfO3OX8g/O7XM7PX+1D/U8DmwJlm9mFrTNK5wNPAN1g40LxgZn+oYfdoYCVgHzP7U8LuPcBlwA+BExPlVzWzF2KZxwmB0yko3nXWXJ4DPqDKDRYYD4wEDjWzD2Le+sy/wa1BuEk8Uaog6cHYhXC3pGviE+c6wEGS7pT0x0TZfSTdK+l+SQf31nlJawJPShoGTO9t/QTNug5Q4VrUex0k7RHL3QBsz/xAt4ukW+Oxw1LyqvnUEiRtQQgSp5nZ65IGSBraSzPD4+tryUwzmwNMBd6rcu6B8XtTja2B94HyluefCd+Vr5ed74Ve+Oy0GjPz1MQEPAi8USF/DUJ3ws2JvMWAbmCl+H4P4D+J4wOBaYSnO4C/E27IbwErx7xbgNWAtYEbY50uwtOneun7d4HPATsDu9UoOx6wkh8tug6DK1yL9eu5DsDHCS2hgYSuoRnR3mrADcDAWO5fVfIq+lThPCvH6zS+ynXqAkb1InWl/E1OiefaFbgWmBffPwN8tc7vwEjCQ8YUYE9gxfg3Ozn+jQ4qK2/AzMS53iR0ty1RVu5p4K0q53wr1h1V5fjjwEut/m17qp68RdN8HgWWkTSqLL/URfSDRN66wDtmNim+nwIsK6nUNbEWcK2ZPR/fdwMDWHBcZFZMewD/Z2ZzzKwHeN/ir7QXfAa4HdiScNPOQqOvw3uE1kz5tdiN+q7DvsCFFp7U5wHPW2hdfRUYA9wkaQJhfOPrFfLWr+JTb1kxft5604optlaPr78BlgT2I0yymAP8XtLXq1UsYWbTgV0IN/8rgEnAU4Qxtd3N7DdlVe4nPHTsEc93K/Ad4M6yFs4TwEhJGyQrx/cj49u0z+YUGB+jaT6l8Yl1gdsAJO0A7AT8ysw+7A4ys3uZ/yPDzG5nftcFhPEHRRtrEp64NyDcGJG0Sqhmr0gaSPx7S9oTuLc3TkvqDwwws1mStgY2Lptg9JSZ9aY7rqHXwcyek/S/lF0LQkujnuswJJYF+B7hZkrMO9rM/hZtDABOqJD3lUo+1XdpFmAyoduuN+WrsXh8fRfYOgZRJF0NvAD8TNKlMQCnMZPQirgGuIcQtL4NXCZpVzO7uVTQzD5VVvd3kh4FTgK+H18BziQ8BFwh6QfR/toxfy7hAaq33XxOUWh1k2pRS4SbhgHfje/7EX5UU4ARvbR1JnAOcDNwE2Ew9RzgXEJf99XAmFh2JeAO4G7gT8DivTzXpsCRwArAcXWUH09611lDr0PMX+ha1HsdCK2hJ6LN24HDYv7Ksf4EQqtuuyp5FX2qcJ6VSek6y/m7d20814kVjl0aj61Zw8a6hLGUb5blDyUEq5eAfjVsDCDMWLynLH9P4PXohxEeEs4Drozv16tiz7vOCp68RdN8ymdcjSM8uX3TzGb00tY6wM42f8AcQrfEQljodtqil/aTbEcYZ9ie2ALJSKOvA1Z9KnLN62BmpSfq8vyXqtRfIE/SkZV86i1xht3Svagyxcy6qxx7Jb5WavWUZqCNrHAsySGElvNfkpkWWrrXEb5/KwPPL1z1w7JzJb1GGFNK5v9F0pWEYLY4YRzuTUn3E4JOX1qETgHwQNNkzGyypCnAOpKWAH5KmM1U3rddD8Oy3sh6wXqELqJvAX+sUbYmRboOcTr1lWXZl5lZ+dqPpvmUYAxhmne9fJTQqqjE/cA3Ca3Sckp5b9awX1pr06/Csf5lrxWRNDieb6FuyxgkH0mUHU1YM3W7LbiOxmkjPNC0hseAjYDjCE91/2O1+8UXwsw+nbdjlZC0GKFfHmCQxb79HCjEdTCzt4CtstioYDOvv02eYzRXA2cBX5V0opnNBJC0LGF85BmL40hxnGlVYJaZvZyw8SSwA7A/cFopM67e35UwI61kYykzm1bBjxMI955r0z5InA7+K0JQOymtrFNsPNC0hseAbQiDoZeb2Z0t9oco4bGSmanC4S0J4w/rk1i7kgOFuw5FI7aKss7wK9maHtf4nA/cK+m3hMkNB8fX7yaKL0+YAHE7CwbhM4GvAadIWpcw1rUkcBCwLPDtRNfdsZI+TehqfZmwqHInwpqZ+wjTnIEga0NocV1FaMEtQVAb2Ag4xswW6K6VtC9hvA1C1+JAScfG95PM7Pe9vDxOAylEoJG0B2Hl7+qENROTgN8TFpZVfXqOXS5nEp7GughjCN+r8hRVJErjE7OBI1rpSIJhlC3CS7AdIdgMAXok7VihzD/M7LQK+WkU8Tp0NGZ2gaSphOt9AtBDWPezj5ndXUf9SVGO5zhgW2AvwuSARwgLbJNdkBMIU8/3A5YiTPF+FjgG+EVZ1+IcgtLDPoSANQt4ANjRzG6s4MqBhO9kkhPi6+2E+4dTEGTW26UUDXBC+gahL/pBwsK4TxJmLV2UMqCLpBsJi+UOI/xgTiUsAqxLHNAJSCrJuRxgZhfnZHM8QUZmQ+C/wAwzm5eH7U4gThcfQfjePwQcb2bjW+mT4zSKQrRozKxcHPE2ScOBb0v6rlWIhgrKvzsAW5rZHTHvVeA+SduZWS7dDYsInyUEmksbYPuh+PoZ4K4G2G9XxlJdUNRxOopCBJoqTGP+grlKfI7QermjlGFm90t6MR7zQFMnZnY6cHrOZn/HgoHlsWoFF1GeZMFBftfucjqWQgWauGZgEKG75XsEqZBqfXtrEPSRynkqHnNaiAXRQ795VsHM3sEfhpxFhEIFGoIW1KD4/98Bh6eUHUkYzylnOrBKvm45juM4faVogWZTgpRFaVbLOYQFgrkhaRxhFTqLLbbYRqutvlqe5h3HWQR5+KGHp5pZbxQcFkKjBhtzaiwje3fujWZWadZnoSlUoDGz0sDxXXEK5qWSzrD5CrhJplNZmqMkY17tHBcQd/vbcKMN7e67a87o7BiM7DMMRaVlNo6zaDN0yNBJtUvVYG4P2uQjqUXsplfK1c7bgiJvE1AKOh+tcvxpKo/FVBu7cRzHKTTqUmpqV4ocaDaLr9V0nq4HRkvavJQhaSxhfOb6BvvmOI6TLxJd/btSU7tSiK6zuFXuLQR5k25CkDkU+HOp20zScwRhvQMBzOxfkm4i7G+RXLB5l6+hcRyn3RC0dasljUIEGoLUxP4EefF5hGmxRxH2oijRn4UVY78M/BL4LQkJmsa66jiO0wAkuvpXEsVuf4oSaB4lCDaOJIjpGTDVzOaWCpjZyuWVzGyGpIsJ3WVjCYJ9y0vat0xxtu3JYyB/Zvc7mW0M0IDMNpRTj+3ArkG1C9XAJzc4hUHeomk0PySMxRwCTCUEjMskjTKzs6tViuKO1xBaPj8liD5uTtiYyXEcp20Q0K+Nx2HSKEqg+YKZTU28v1XScoQAVDHQxP0yfgOcbmbHJA79vXFuOo7jNIgObtEUInyWBZkSDwPLpVTbnrBL368b4pTjOE5TSZ/a3M5BqBCBpgqbAM+kHP8UQXjz05KelTRP0uOSvtAc9xzHcfJDgq4BXampXSmk55K2JWxmdkZKsdGETdIuAH4O7EhQxL0q7vznOI7TPsgXbDYNSSsDlwF/M7NL0ooSBv2PNbPz49qZvQmTCqru1ihpnKSJkiZOnVKpx85xHKcVhOnNaammBWl/SVYhfTNRRpKOlvRfSe9LukPSBo38ZEWZDACApCUJq/onAV+pUbykZ/bhXuJm1i3pduAT1SqVa51lcthxHCcv8p0MsA1hi+0SyS07jgR+TFDHf5ow6eoWSeuY2eS8HEhSmEAjaShhxthAYGczm1WjylOlquWmCCoBjuM4bYNEnjIzD5jZzIXPocGEQHOymZ0T8/4FvAR8Bzg2LweSFKLrLO6f/hfg48COZvZmHdVuJKgIbJOw0w/YkrAtseM4ThvRlFlnmwLDgStKGWb2HnAtYWfihlCUFs25hEWa3weWkrRU4tjDZjZb0j8BzGzb+Pq6pF8Dp0gS8Bxhn5kVgJOb6r3jOE4O5Nh19ny8jz4P/MLMzo/5axD0JJ8tK/8UQdKrIRQl0OwWX8+qcOyjhGbdAiNhklYn7MY5h7BBGsBkYPcq+9e0jJ5amxnVwVuqp5GXzgc9tXoja7P0gLSlTfUxz+ZktgEwyAUgnA4ip66z1wnjL/cT7pl7AedJGmpmvyTIfM00s+6yetOBoZIGmuX0A01QlEDzPEG9+WrmS9AcCnzPzF4CMLOtyupsT1hr81OCVtoqwInATyRdb2Y+TuM4TvtQ32SAUZImJt5fECc4AWBmNxKGFUpcH8dljpVU6UG+KRQl0PRaggb4E/BrMyvNHJsg6RXCRf4McHvDvHUcx8kZIQbUnsI81czG9tL0X4EvEdTxpwPDJPUra9WMBGY1ojUDBZkM0BcJGjOblggyyTqk1XMcxykkgq6urtTURyzx+jShS+1jZWUaujNxIQJNFWpJ0FSrQx/qOY7jtBRJDBjQLzX1kT0IQxKTgHuAd4A9E+cdCnyBBu5MXJSuswVISNAc0Is6Qwk7bN5uZg82yDXHcZyGIKBf31stwYb0/wgTAR4ltFy+HNP34rj1B5JOAX4saTrzF2x2UX2YIjOFCzS9kKBJ1hFwEbAM8PkaZccRpkEzZsyYLK46juPkh5Sle6zEfwgP6GMIsetJ4Gtm9vtEmVMIgeUoYClgIrC9mb2R9eTVKFSg6aUETZJTgS8SLtYLaQVdgsZxnCIiqGcyQCpmdjRwdI0yBpwUU1MoTKDpgwRNqd4hwGHAXmZ2ZwNddBzHaRjKp0VTSAoRaMokaDatU4IGSV8hbCXwQzO7olZ5x3GcoiJlb9EUlUIEGvogQSNpS+Bi4CbgXkmfTtR5xcxeaY7rjuM4eaDMkwGKSlECzQ7xtW4JGmBrYADw2ZiSnEyNfspmkod8zDybm9lGP2V/Wnqv+53MNgZ15SMd837Pe5ltDOlaLAdPnHKMYgx/zumZndlGXt/XWkhkmcJcaAoRPs1sZcJ05lcIq1ifJkxTVlKCJilDY2bjgRHAm8BdwC7A14EpwFrN8t1xHCcPhBq1YLPlFKVFA3Ctmf0NQNJfgVF11PkWMIQgYTMj1p0GXCNprJlNTKvsOI5TGAT92ni75jQKE2j6KIK5ATCxFGQiNxOkFj5PmB/uOI5TeKS6tM7aksIEmj4ymLBNQJJ5hB0212y+O47jOH1D0NbdY2m0e6B5DthH0gCzD0fLNyJMHFiydW45juP0jpLWWSfS7uHzN8DSwNmSRktamzBVupvQqlkISeMkTZQ0ceqUSqLRjuM4LUBB6ywttSvt6zlgZk8TdMv2Juws9yhBUO4Rwm6blepcYGZjzWzsqKXrmW/gOI7TeEr70aSldqXdu84ws99KuoygKvAmQQ57GnBhSx1zHMfpBZKP0RQaM/sAeAxA0n6ElppL0jiO00a4MkDDiaKaO8W3ywPDJe0R3//DzGZJeo6wkPPAWGc4cAxwB2G22dbAocBBZvZWUz+A4zhOBrokBvYb0Go3GkJhAg2wMUFYM0npfUmGpj8LStEsDxwRU5IdgUty99BxHKeB9Otq33GYNIoUaEYQJGjuBdYB3khKzsCHUjVJ3o+vhwF3J/JzmU5mc/PRa5r03ouZbXxkyEdy8CQ7c8iuHSXLZ/Wz9WT/+8yzeZltDOs3PLONTmNeT/nytt7TTXdmG8phvlMeOoP1IImB/b1F02j6IkFT4j9mdm9j3HIcx2k8QvSTj9E0lD5K0DiO43QEndyi6ZTwebGkbkmvS/qFpCGtdshxHKc3iDBGk5balcK0aPrIbODXhM3P3gG2An4ErArs2jq3HMdxeom866yQmNnrwHcSWRMkvQGcK2l9M/t3eR1J4whqAowZM6Y5jjqO49SgC+86ayf+Gl83qnTQJWgcxykk8q6zdsLKXh3HcQqP6NwFm53YoimpCTzYUi8cx3F6gaTM6s2S9pR0jaRXJc2U9KCkvcvKTJBkFdLgRn22wrRo+ihBMx5YnLBY8x1gC+Bw4Eoze7SZ/juO42Qhp+nNPwReBA4hLFzfCbhM0igzOztR7jbg6LK62VdjV6EwgYa+SdA8C5wBfD+RfwJwUsO8dBzHaQCCPGadfcHMksoot0pajhCAkoHmrWYuci9SoBlB7yVorgPOAf5J+CzbmNlxeTn0yKz7c7Ezc+7MzDaGDRiW2caM2TMy2+jKYfrlwH4DM9sA+Mjg0ZltDGZoZhv3TJuQ2cZ9/304s428+vc3Wm69zDZWWXzVzDb6KfvtqSuH0YEh/RbLbKMe8mjRlAWZEg8Du2cynJEijdFca2ZjzGxP4Il6KpjZDGBJM/sscFUjnXMcx2kkQo2adbYJ8ExZ3g6SZsV0o6TsTxcpFKZF01cJGjPz2WWO43QEeS/YlLQtsBtwQCL7duBS4DlgJcJWK3fGtYcv5epApDCBxnEcZ1FGEgNqd3+OkjQx8f4CM7ugir2VgcuAv5nZJaV8M/tJotidkm4BngZ+EFPueKBxHMcpAEL1jIFONbOxNW1JSwLXA5OAr6SVNbPJku4GNqzX196yyAUal6BxHKeICOjflf2WHJeK/B0YCOxsZrPqqGY0cJF7kSYDNAWXoHEcp5AotGjSUm0T6k9YFvJxYEcze7OOOqOBzWngIvdFrkXjOI5TRITon31K97mERZrfB5aStFTi2MPA6sDJhGA0CVgROAroAc7MevJqeKBxHMcpCDmsU9shvp5V4dhHgWmEXrqTgaWAd4EJwG5m9nLWk1ejMIGmLxI0sd7ngMWADeL7Up0HzGxSU5x3HMfJiMgeaCosaq/ETrWL5EthAg2wDL2XoAH4P8Jc8PI6XwcuydVDx3GcRiHlMhmgiBTpUw0FbiWsYp0BXAgcb2bdpQJVovUewM+A0pS/h4BjzOy+mmc0Qs9kFZ6a9nQ9ftfk7fdzkKBZPrsETU/f1sQuwLVP3ZLZxsYrrZPZBuTzeQYtll2wdqORn8ps42OLfzyzjVnd72W2kRczu9/NbGNov+zyQINy2NV9gPKRTKqFUC6SOUWkEIFG0kjgFuBJwhbMqxLEMruAY1PqjYn1HgL2jdmHAzdLWte7zhzHaRfymt5cRIryqb4JDAH+x8zeIQSK4cB4SafFvEp8nrBNwBfN7G0ASfcwXx77/xrvuuM4Th7UtWCzLSnKp/occGNZQLmcEHy2TKk3AJgHJPsMZsY85e2k4zhOo1Aco0lL7UpRAs0aBK2dD4lT7WbFY9X4f7HMGZKWkbQM8EtgOgtPLHAcxyk0XTX+tStFCZEjCRMAypkej1XEzF6TtDVBbuF7Mft14LNmNiVvJx3HcRpFHtObi0pbfypJyxJaLg8Sut8+F/9/naQVq9QZJ2mipIlTp1baI8hxHKcVeNdZo5kOLFEhf2Q8Vo3DCeM0e5jZDWZ2A2EnuW7gsEoVFtA6G+VaZ47jFIOSenMWrbOiUpQQ+TRlYzFx6vJQysZuylgDeMLM5pYyzGyOpCcIU6Qdx3HaAok8tM4KSVFC5PXAZyUtnsj7MvA+YTe4akwC1pHmr6iSNAhYh6Ak4DiO0yZ0boumKJ6fB8wGrpS0XdwzZjzwi+SUZ0nPSbooUe9CYDngKkmfl7QzcDWwLFBx1znHcZwiIqCf+qWmdqUQ7TQzmx6Dy6XAzQRhmLuB48uKLqB1ZmYPStoR+Anwe2B4PH60mf271nnnzJrLyw9Ornr8ZVU/1ht2X2vnzDZefje7sOqPrzgvs42zvnpEZhuTZ+VzXYf2zy5R8kFPPXtCpdM/B4mSYf2GZ7Zx8l2VBHt7z+S33sps4/QvHJ3ZxpCu7LJL/XLoiuqer4LVYITauNWSRiE+VZSgOZ8gJbMD8G1gI0IA+RAzW9nM9i/L+6eZbQEcSVAEAHis0T47juPkTRdKTe1KIVo09F2CBvgwUJ1ECDYXNtxbx3GcnAmimu3bPZZGIVo09F2CpsQJhK62fzbAN8dxnMajIEOTltqVogSavkrQIGk94ACqrJtxHMdpF7rol5ralaIEmj5J0ETOBs4xs+fydspxHKdZlPajca2zgiFpL2B14Au9qDMOGAew3EeWa5BnjuM4vaerjacwp1GUENlrCRpJA4DTgVOBLkkjCNObARYrW/z5IUkJmpEjlszsuOM4Tj6o5r92pSiBpi8SNIsBKwC/IASj6UBp7czlwMMN8dRxHKdBdOpkgKJ0nV0PHC5pcTMrbTZeS4JmJrB1Wd5o4E/A0cCtjXDUcRynEQjo18YD/mkUJdCcR9hP5kpJpwKrUEWCBrjdzA40s3nAhKQRSSvH/z5mZvc1wW/HcZycCNMBOpFCBJq+StAASFoCOBPYLXGs4vhMOfMGzWHKx1+senzmE9nlSQCmvp9935sPuj/IbOORm57MbGPSLpMy25g5O5/r+gzPZLaxyTKbZbaRx1NoN9llTn65zWmZbQA8+e4jmW0M1KBC2JjH3NqFatAsjbG8Nj6TtBZhNu4mhNm8FwLHmzVNS2chChE+s0jQAFcAWwH/C+wHPAt8q7EeO47j5I1qCNDUvl3He+ktgAG7Aj8FDmXhh/amUneLRtI2wG1mZg3wo08SNJI2IQSmLc3sjpj3KnCfpO3M7JYG+Oo4jpM7JfXmjGSS82oUvWnR3AK8KuksSZvm7EdfJWg+B7xRCjIAZnY/8GI85jiO0ybkMr05q5xXQ+hNoFmX0Nf3WeAuSZMknS5poxz86KsEzUL1Ik/VqOc4jlM4cgg0fZbzaiR1Bxoze8LMjjOzNYANgcuALwIPxA3JTszgR18laLJI1ziO4xQHBWWAtFQHhbwn9mkygJk9YmZHmdnHgF0IzbKjcvWsQUgaJ2mipIkzps1otTuO4zgAyFQzAaNK96+YxrXa73ro0/TmOLNhd8Kiyi0JCysvy+BHryVoEvWW7k09M7uAuM3zGuuv3oiJDY7jOL3GMHp6at6SpprZ2JTjfb2XNpTezDobTugq+zKwLTAPuA7YC/iHmWVZ6NEXCZpSvc9UyF8DuDqDP47jOM2ndqCpRV/vpQ2lN11nUwgr+OcA+wPLmNmXzOzKjEEGggTNZ8uEMGtJ0JTqjZa0eSlD0liCssD1GX1yHMdpHgbWbampDvp6L20ovQk044DRZrabmf3JzN7L0Y/zgNkECZrtYr/jeCpI0Ei6qPTezP4F3AT8TtL/SNoN+CNwl6+hcRyn3TCz1FQHdd1Lm03dXWdmdmkD/ZhBmOt9MLAdodV0KWXKAFSQoCFE618CvyMoOr8FZNcVcRzHaSYGWZfDRzmvbYFzgGsJ99ZfEoJNyyiE1hlwJGFF62GEfsQfAv8DHAdMLhUys5XLK5rZDEkHEyYlDAVeMbO6xMX6vT+QEY+NqXp86eH5zAZ8ZPLjmW1Mfie7Xto+39ohs40bnrw7s43t19wksw2AUYNHZbaRh45VHnpaeYgpvjL7hcw2AMYMXTmzjf4MyGwjj+s6SEMy2+in5twmDcO6e7LbMXsS2Ca7R/nRcq0zSYMJgeZkMzsndnntSdDq+U6dZg4HXgVuaIyXjuM4jccsPbUrLQ80wKaEnTGvKGXE8Z9rqUNGRtKKwBHA9xvloOM4TsPJZzJAISlCoFkD6CaoLiepV0bmDOAKM3sob8ccx3GaSo+lpzalCGM0I4GZFfZKmA4MlTTQzOZUqhgVpXcAVmuwj47jOA3FjHoWbLYlTQ00CpteJ0df+3xVJfUHfgWcZGZv9KLeOMJUbZZdZrm+nt5xHCdn2rvVkkazu862BOYm0j8JLZdh0kLTf0YCs6q1ZoCDCFILl0gaIWkEMBDoF99XnPZiZheY2VgzGztyiSWzfyLHcZyc6NTJAM3uOnsQ2Djx/l1geUIr52PAfxLHqm0BUGJ1YAWgUmtmOrAv8IcszjqO4zSNOBmgE2lqoDGzd4GJyTxJk4B3CFOaT4x5Q4EvEMUvq3AOC+uZHQl8FPgGYTKB4zhO29CYDYxbT8snA5jZB5JOAX4saTrzF2x2AWeXykn6GvBbYFUzm2RmzwHPJW1J2h8YZWYTmuS+4zhOPniLpuGcAmwNnEXoRnsHGFc2yN8Vj324zZykgYRWzNcIXXBzgZmSBpnZ7Cb57jiOkxnDWzSN5kiC3P8PmN+i+bWk281sMoCZXQJcUlbvFIJ0zbHAw4SdP08ETqOOBZw93T3MfDtFeHp4rz5DVZ6b8nJmGxMefCyzjQsO/HFmG8MHZr8oj0/LLskDMHro6Mw2uheaVd97hnYtXrtQDd7vya5Ru3i/EZltQD6yLf1zkG0ZyKDMNvKQj6lzC+XsWHsvykyj5YGmXIIm5v0LeIkgQXNsSvV9gP8zs1/E97dJWh74Cq4U4DhOm2E+vblhZJGgGQC8XZY3A5r1COI4jpMfPT2WmtqVIgSaLBI0FwLfkLSZpGGSPkPYauCc/N10HMdpHGbQ3d2TmtqVlnedkUGChtDlNgS4K5F3rpn9tAF+Oo7jNBDr2K6ztpWgiRwOfBX4LvAosD5wgqRpZnZcFR8+lKAZPWrZjKd3HMfJBzPonte+rZY02laCRtIowgyzH8V9bO4ws7OBHwFHSVqmUr2kBM2InDY2cxzHyYx17hhNO0vQrEKYDPBIWf7DhM+1EvBmNncdx3Gag2FtPQ6TRjtL0EyKrxsCDyTyN4qvL2X32HEcp0lY505vbvlkgAwSNG9Iuho4Na7FeRTYABgP/MXMpjT1gziO42TEA01jOYUQWI4CliK0eravJUED7AccB3wPWA54FTgfOKEJPjuO4+RGJ08GKEqgOZiwcHMIMBj4sZk9nCxQRYLmU8wf4xkM/MHMxtd70oGD+7PS6ktXPb7T8tvXayqVybMmZ7ax05pbZbYx9YOpmW289t5rmW2sssQqmW0ADO23WGYbPWSXoJk+L3vj2ch+gxmg7JItkI98TNdCc3t6T9OkXwpDew/4p1GEBZsQRDGXBG7sZb0dgfUIs9dm5e2U4zhOs+jkBZtFCTSbmtkmwM96We9wM1vbzA4E3m+AX47jOE3Deiw15Y2k4ZKOl3S/pLclTZZ0laTVysqtLMkqpMvrOU8hus7MrE+huq/1HMdxioaZtWKMZkXgIOAi4BhgKGGs/D5J65nZf8vKHwbcnXhfV398IQKN4ziO05JZZy8SZvJ+2CMk6U7gZeAA4Piy8v8xs3t7exIPNI7jOEUgKgM09ZRBKb887624vnG5vM7T1DEaBfonUvapKb33YZykiZImTps+rdmndxzHqYhRjMkAkpYmKLU8U+HwxZK6Jb0u6RdSfbvkFUHrrKkktc6WGrlUs0/vOI5TGUufCNDEbrUzgJksuJxkNvBr4EBgW8J6xYOBQk4GqKR15jiOs8hT54LNUZKSMl4XmNkCUl2SlgBqStOb2UJakpIOJiji725m0xJlXyfseFxigqQ3gHMlrW9m/047V8u1zhzHcZxAT0/NQDPVzMbWKLMn8Js6TrfAilhJuxBkv35kZlfVUf+vwLkEfcniBJpqSBoLrAyMiVlbxm0AXjKzibHMAlpnMW8l5reQBgJrSdoDeM/Mrm/iR3Acx8lEXtObzexCwu7DdSNpM0I32Hlmdnq9pyp7rUohAg0hin468X58fL0U2D/+v5LW2R+BzRLv94zpNYI0TSpd/boYPLK6bMebV+Uz+DZq11GZbczpqbbJaP28M+edzDZGDx2d2cbyQ8bULlQH/XKYSzLP5uXgR/ahzjxkXxbvNyKzDVgUpV+KQx0tmtyRtDZwLXADQTeyXvaIrw/WKliUQCPgXsKc7r2Brc1sQrJAFa2z5wginF8vy3+kAT46juM0DDOje2527b3eEDeIvIEw+P8r4JNhI2QA3jGzJ2O58cDihMWa7wBbEHY4vtLMHq11nqIEmk3NrEfSOoRA0xve68sCIsdxnELRgnU0wFrACvH/t5Udux3YKv7/aYIqwP8SxI9fBk4HTqrnJIUINC4l4ziO03xlgNhzVLOv1Mwup86pzJUoiqhmFtaS9I6k2ZLukrRlqx1yHMfpLWEyQHdqalcK0aLJwMPAfcCTwNLAocDNkjY3s/tb6pnjOE4vacVkgGbQ1ECjMMqUnCpkZtbnMG1mZ5XZ/wfwBHA0sFsVH8YB4wBWWH6FSkUcx3GaTovUm5tCR0nQmNks4B/AhillPpSgGbVk9mnHjuM4uWChRZOW2pVOlKAx6lhA5DiOUyQMa+txmDQ6SoImKol+njoWEDmO4xSK1kxvbgqFmAzQFwmaKBz3d+APhIWbo4BDCHso7NncT+A4jpMda9JWAM2mEIGGvknQzAamAKcCS8S8d4AjSsGpFhogBo8aXPX4EkstVo+ZmowYmF0qJQ8JmiUHLZnZRlcOsi8DNDCzDYDuHORj8mBoV/bvyaCuurb1SKUrpyHXPP7GTu8xM+b5ZICGUpKg+VN8v7WZycz2LxUws0ti3kvx/QfAA4RVqkcCOwLXAKdLSo4DOY7jFB4zsJ6e1NSuFKVF02sJGkkDgaOA08zs1Jh9o6S1gJ8AOzfGVcdxnEbQuZMBCtGi6aMEzaoEkbeby/JvAraPgchxHKctsDgZIC21K0Vp0fSF0uBK+eDFHMLeNKsQhOAcx3GKj9F09eZmUYgWTR95gbBepnw85pPxNfvIt+M4TtMwrLsnNbUrbStBY2ZvS/oTcIykxwlbiX4F2C4WqfhXSUrQjBmTzwZcjuM4WTED627f7rE02l2C5gcEQc1bgWmEjXhOjMcmV6qwgATN0i5B4zhOQYgbn6WldqWtJWjMbAqwjaQVCGtp/kMIPpNL06Adx3HaATPoaePusTQ6QoLGzF4BXpE0GDiAoCDgOI7TPpjRM6d9Wy1pFGLWWV8kaGLevsAAwsSAFQkSNN3AyU39AI7jODnQzgrNabQ80EhaFrgEWDuRPT6+pknQAGwDfAkYSpiB9ibwbTObmYdva2+/Sh5meO3fb2a2MXTd7MuCVHvH1prkIR8z17LL6UBQu83KoP8Oy2xjyHLZJWi6BrfzBFAnD6ync1s0Rfh2b0RYE3MUIXDsTRhrmQR8p1SoXIImsi3wR+CLwGeBG4G/SNqlOa47juPkR0+3paZ2peUtGuAuYA2z+QqJkh4iBJvdCa2aamxoZlMT72+W9HFCF9o1jXDWcRynIUSts06k5YHGzGZUyHtG0iyC5H9a3akVsh9m/loax3GctsDM6O7QrrOWB5pKSFqPMO7yTB+qb9LHeo7jOC2lnVf/p1GEMZoFkNQFnAU8Sy+7vyQdAHwC+EUDXHMcx2kY1qIFm5ImSLIKaXBZueUlXSXpXUlTJZ0jaWg95yiiBM3JhFbJlmY2txe2NyJsoHaWmd2WUs4laBzHKR6tlaC5DTi6LG926T+SBhAmW80B9gJGEB7oRwBfrWW82V1nWxI+UInbga1KbyR9iyAjs7eZ3VevUUmrANcRJG0OTStrZhcAFwBsuNGG7TuNw3GcjiK0aFq2a+xbZnZvyvE9gDWBj5nZiwCS5gKXSzrezJ5NM14YCRpJuxNaJEeY2Z/rNShpGUKknQTs1VeRTsdxnJZiFHkK8+eAB0pBJnI1oYWzI2GooyqFkKCRtBVhPczZZvbzeu1JGgb8I77d2cxm5eCm4zhOC7BWTgbYIc70BbgTONzMHk0cX4MgYPwhZjZH0vPxWCotn3UmaU1CZHwa+LOkTycOTzGz52O5LQldY9ua2e3x+JXAegT1gFUlrVqqWKMZ6DiOUyisdRuf3U5Yr/gcsBJwDHCnpPUTC+RHAjMq1J0ej6XS8kAD7EBQXl4fuKfsWFKCpjSRIKmjsn18/WMFu9n1VhzHcZqG0VN7V/tRkpK9QhfEcecPkbQEsGzNs5k9HV9/ksi+U9IthAf/H8SUmSIEmudjuhC4D/gIQetsMAtK0Exg4eDRn9DKGQ2cBPwXWBVYqsE+94pl18q+783bmpbZxkANymxjbv0TARvOkDeGZ7YxbJXsOmWOkwdmxrx5NX9fU81sbI0yewK/qeOUFR/GzWyypLuBDRPZ0wkNgnJGEjadTKUIgSaLBM1BhJbQ6mZWUq6c0CA/HcdxGoYB3bVbNLXtmF1IeHDP6k5yZsLTlI3FSBoIrAKcV8tYyxdsmtmMZJCJec8ANSVoCHvPXJEIMo7jOO2JGfPmzUtNzUDSaGBzwizhEtcDG0taKZG3CzAIuKGWzZYHmkrUI0ETo+knCBue/VHS+5LelnSxpOx9Ko7jOE3EgB7rSU15I2k9SddJ2l/S1pL2I/QK9QBnJor+ldCquVLSTpL2Bs4BLqu1hgaK0XW2AL2QoFmK4P8RhHGaXQibn50OLEbYp8ZxHKc9MKOnp+mzzqYRxmpOJtxT3yUEmt3M7OX5rtlcSTsSgssVBNWAywkL7GvSzhI0pYGs6cCepbJxteqlklYtTY0u88ElaBzHKRyGMa+7ucoAZvYqsFOdZV8BduvLeZrddbYlMDeR/pk8mJCg2a8OCZoZ8fXusoB0a3xdq1IlM7vAzMaa2dhRS2efDeY4jpMLFrZyTkvtSttK0JjZLEmTWHiKXul9+/5VHMdZ5DCMud3FWT6QJ20tQQP8HdhV0kCzDzei35YQZB7L5q3jOE7zsNii6URaPhkgowTN6QSJ6v8n6VxgDHAq8NvkQJbjOE7RacUYTbNoeaABNqWPEjRmNknST4ETgJ2BbuAm4LuNddlxHCdnzLxF00AuI+id3UKQohkOHAJsAPy0VKiSBI2kzYHTgHOBqwizJw4FtiAEnEyoX+0y9dnJPudixNzsExfmdM2uXagGXTlclEFT6tqUryYa7HJ2TucQ1tF05i4nLQ80ZvY+8OVkXhR1m0aYSpe2LfOPgTvM7Hvx/W2S1gaOI4dA4ziO0zSiMkAnUkhlAOA94ANgYLUCkgYBWxMWDyW5HNgkKpg6juO0BSWts7TUrrS8RVMisZhzFKH7qxv4U0qVVYEBhEkESZ4iBNDVgAfy99RxHCd/zHrqUW9uSwoTaIAfEVQBAKYAO5nZpJTypc12ZpTlTy877jiO0xY0Qs+sCBRJguYSwoSAZYFvAX+XtIWZPUmOJCVogNlDhwx9PKPJUcDUDrFRJF86yUaRfOkkG0XyZfWM9XmXt2+8tefaWrN+8rhmzcfMmpaArZi/z4EBE6qU60/Yj+Z3KbbWija2LMvfOOZvXIc/E3P4TB1jo0i+dJKNIvnSSTaK5Eten6dTU2EkaJKY2TxJjxE21anG8wS9tDUIe16XWIOgDFB1iwHHcRyneRRCgqYcSYMJ24jenWJrtqTbCNuWnp849GXgX2b2dkZ3HcdxnBxo+WSAuIHO5wi7tL3G/DGaZUmsoZH0NeC3wKo2f5LACcAESWcSZGx2imnHOk9/QfZP0FE28rLjNhpjx200xk5RbHQsiv2LrXNA+gRwIrARYabY68B9wE/N7IlEuf2Bi4GPmtlLifzdYv2PAy8C483s8ia57ziO49Sg5YHGcRzH6WyKqgzgOI7jdAgeaBzHcZyG4oHGcRzHaSgtn3XWLCQtTtA/K0nTTAeeiVOu67XRn7C2Z0nCWp3JlnGDNUmjgJWAl8xsWh9tDCZov/UAz5lZywST4jX6EnCzmU1plR99QdI2hBmQa7Dg9+Rp4B9mdlsO51gR2MrMfpdSZgywHPC8mS20Ejx+Z3ZKs1HF7jDgIeArZtYnHUBJ6xIm7hjwoJlVVdaQNATon/yNSVoa+A5hwXUP8AhwbtpyhHg9diJsE/IXM5smaQXgMML3/iXgAjNL3VVX0obA54E1SfyGgX9FuzPS6jsZaPWK0UYnYDvgDsLizm7Cl6uU5sZj29awsRFwDfB+tJFMrxL2zRmaUn8g8EvCjLrJwDEx/3hgdsLWn4DFUux8FTgg8b4/cAowK2HjXeDIFBurAQPL8sYCVxJ+sC8CfwE+0cfrvUT04zN1lP0EcBFwPXAm8PEKZTYAXsj4HdgxzQbhpnN7/E48T9gi/Pcx/R14Lh6bACyZ0Zfdge4qxwbFa1/6W86N12eJsnKfSrGxU0raM36OI0p5KX5eBqySeD+YsOdT8jfUTVBPH1DFxj+AsxLvNyFoE74F3EyQnJoOvAGsXcXGJ4G3gXkERffXgHWB/8bv63XApPg7qvidAxaL3++Sz3Pj/+cQhHenR7/2rfNvuA1hd99rgbtiujbmbZ3l+9GpqeUONPTDhSfr7vhl3JdwQ101prEx7+/xS7xnFRs7xC/xROBnwHjCjXEOYT+cQ4EnCE9mI6vYGE8IBmcQ9sp5DTg7fsHHEdQSDo5f9pNTPs+TwMGJ92dEuz8GNgM2j+d6Hzi6io1u4JOJ91vEz/cCcE7064Voo6KMD3B/Snow/oifKuVVsTE23jhejH+D1+I5v1tWrupNtRffg6o393j8DwTJo6qyRdHfp4HfN8qX+N2YARwUz/c9wk34WRJBOO2aMP9m2lMlLRAoUvzsKfuelL5r3yRogy0V/z8L+EkVG1OBXRPv7yVsx754Im8JQpC/sYqNm4HbgBEEtfZzgFeAvxEDHCFAXw/cVsXGufE67hzL9ovXcCLwa8IQwn7xd/CFlGvStAeSTkstd6ChHy4EgFPrKHca8GSVYw8Cl1bI/y7hiaqL8LT3EKELoJKNZ4FDEu8/E3/w3y4rdwihO6+an7NIaLsBbwLfr1DuMGBSFRvlN5A7CQoMQxJ5Q+JN4boUG68RFtBeXJb+GI9fX8qrYuPG+OMs3SwGElqG84BfMX/qfdpN9bg605+r2Yh2ZpC4IaaU2w2YUeVYeUs3NVWx8TTwnbK80YRW9xRgkzquyURCy/nrhC7ZZFov/m2+VMpL+azl35PXgOMqlPtpte9s/L5ukXg/B9ihQrnPA+9VsTEN+Fzi/TLRtx0q2JhaxcYU4GsV8tcmtG5GxfenAPelXJOmPZB0Wur0MZpVCM33WlxHCByVWAs4skL+H4CzgNXN7KmoTnAqQdWgnOUJgajEQ4T+5n+XlXs4lq3G24SnyRJLVLBBzFsmxU6SjYF9LOx0CoRdTyX9EjivSp0vElQbViUEukdKBySNAPYmtMzuSDnvRoSxgrnxnHOA4yTdR9i8bgVJ+9TwfTzzN8lLo+oGepEeyrYJr4Ji2UrMJgTsq2vY+AQhCFRiDPBoMsPMJkvalvDUfIukrxACSTU2JrSITiU8RBxmZi8CJDYDnGzpW3BUYhnCk3o5txO64irxOGFzwtL34A1Cq6CcpQhBqRpW4f/lCwDTFgQOpbLq8VRC6+Yj8f+3Uv0+AKFFtJ+ljG+Z2URJRxLU6J1Ip886e5bwFFqL3WLZSrwJrF8hf33Cl7s0iDmJcOOvxKuEsYZkXQh9zUnWIzw5VuMa4DBJpRvnLYSbejl7E1pz1Uj+KGcTnvjKmUJoqS1c2exvhAB8C3CHpAviAHW57VosdHM3s+sIfeCbRfuVbkwlJgGXm9nSaQk4sIYffwPOkLRZVUelTQl98FdVKTIRmGdmv05LhJZeNV4jKFwsgJnNNbO9gAsJYzjjysskypqZXUAYi3sdeEzSyZIWSzlvNTaVtJOknQgti+EVygwndHlW4hTgSEkHxEkiJwGnS9pe0kBJgyTtSNiHqnyn3BITCd/5YZK6gKMJv6eDJfWDDyegfIsQ2CpxN/CjOCGIWKcf4UHlbeb/9vunfBbI54Fk0aTVTapGJmBXQtP4FsKPcwvCzXw9QvfVQcBNhCb9LlVsHEP48o0njIF8Evg24aZwS6Lc14Gnq9g4DphJ6KI7ljCQeRbhKeoAwtP9QYRB0tNSPs+ShADyDOEp8puEH8rdhB/xzwgzaD4Atq9ioyfaKI2pzAS+UaHcOKp0v5WVW5Fw85tOGK8aFc+xRY16dwCnpxxfjTBW9BbVu4kuAx6rw8fdgZ6U48MJXXmlLsFbCYPHVxLGFF4ldHndAAyvYuN0YFodvuwIvFjl2G+psnVGosxR1BhfKSu/HqEl8hrw/fg5Uv82ie9JefpVhXI/p8o4XDz+v8A78Xt6f/x/N6GLtNSVeBVVJtMQuqKmE37H7xMC3vrxN/ACYRD+RcIDU8WBeMJD0WRCF+kthF6OV6PN/RPlTqHKWFE8fjFhbGazlDKbEsZqLqrn77OopJY70PAPGILDjfGLWBoMLQ2Izo43j6pfnGjjqPhDSQ6o/oHYtxvLfJUK/cDx2ABCV9PrhOBySsw/gvmzznrijW1YDV8Wjz+IyRVuBB/EH15aH3L5mMrFlA3Ax3J3AH/txXXeBniM0MqoeTMj7Kj6FmUzqsrKLEuYZFEt0GwH/LwO31YkdHnUKrcJYSbgnwkPIDfF/x8PfLpG3QFpn6XOaziWELBSB5KBfagy9pVSZy/gZep4CIjly8d3VgJGVyj3E+DLNWwtRWhxXBJ/bzcSukd/AmxUhy8rEB6qvgMsG/NGx9/UdYTB/g1r2Bgef8eXE7o3f07o9i7/baXNHs38QLKopkVG6yx2N63KgusjnrcwNlBP/QGx/mDCVNl3cvJrKcJY0iQze7OXdVcm/ODE/M+TyxoaScOB2WY2uxd1+hFaQqsBZ5vZCylluwiTDt43q75/bVwj9BHr/ZiCU0bsYloMmGnzd7Z1eomkTQgt00rrra43s3tb5VtRWWQCjeM4jtMaOn0yQF1IGhNXbLe9jSL50kk2op3fSLrIbRTPl6LYcCrjLRpA0lygy8z6tbuNIvnSSTaineeinbQtxhcZG0XypSg2op3fRDu1ZjsuMnT6Opp6OZD6pi22g40i+dJJNjCzj7mNYvpSFBuRrfHeogXwFo3jOI7TULxF0wfi7B3MbF4rbRTJl06wEdWNt6TybKLbzWzmomSjSL4UxUY9xJmSy1hGZfeOotXzq4uQCAsmf5tyfBmCptMDBHXkpFLyA4R1FkvXOEdmG0XypcNsKNqYSVgjMZOwqPa/ZXnHE3sBOtlGkXwpio1e3k9SRVwXxdRyB4qQ0r4YhFXIUwhSNBcRBCsPjOkwgizIG/H4eo2yUSRfOslGtHN8vNEcDoypcLy098m7wPhOt1EkX4piI6/7yaKaWu5AQz9ckJypJx1X7YtBEA28jvQVw0NjmQmNslEkXzrJRizzKjCuju/TOODVTrdRJF+KYiMev7XO9Fi1+8mimjp9jGYCQeSxnhlH1WZFbAzsbGZV1WXNbJakMwjyL42yUSRfOskGhL1Onk85XuL5WLbTbRTJl6LYgPBQ+h/CvlBpVBSjXZTp9Cl4bxF2rVy3Rjo0xcZUYPU6zrUGQfCvUTaK5Esn2YCw984RaQrH8diPCKKlnW6jSL4UxQYEMdrHzWzPtETQYHMSdHqL5l7go2aWJpmPpDVSDp8H/FzSkgSV4mcttqMlCfgYYYvcowkKyo2yUSRfOskGBLHGW4CXJd1ImIU0Ix5bghCoPksQQN12EbBRJF+KYgPC/WTHlOMl6u1FWXRodd9dIxNBMfZfdZTbiBQ1XILq6wzCbKY5hJbSW/H/3fHYkTXOkdlGkXzpJBvRzoho63bCBII5Mb0R844ERiwqNorkS4FsrEqV7UTKyg0hZffSRTH5gs06kTSIsNdEpTn491gdKsd52CiSL51kw3GcxrFIBhoFifpbCBt+VdtZsy1sFMmXTrLhOE5+dPpkgGoI2Iqw0VG72yiSL51kw3GcnFhUA43jOI7TJDzQOI7jOA1lkQw0Frax3Zqw+KqtbRTJl06y4ThOfiySkwEcx3Gc5rFItmgcx3Gc5uGBxnEcx2koHmgcx3GchuKBxnEcx2koHmgcx3GchuKBxnESSBoh6RVJvyvLv0bSM5KGtso3x2lXPNA4TgIzm0HYCnpfSbsCSPo68HlgP0vZZM1xnMr4OhrHqYCk84HdCPuP3Aacb2Y/aqlTjtOmeKBxnApIGgY8CiwHPAds5NsNOE7f8K4zx6mAmc0E/g4MAi7yIOM4fcdbNI5TAUkbA/cAjwErAWub2eTWeuU47YkHGscpQ9Jg4CHgBeBLwL+Bp8xsl5Y65jhtinedOc7CnAiMBg6Ks8z2Bz4vaf9WOuU47Yq3aBwngaTNgDuAfc3sskT+6cBBwDpm9kqr/HOcdsQDjeM4jtNQvOvMcRzHaSgeaBzHcZyG4oHGcRzHaSgeaBzHcZyG4oHGcRzHaSgeaBzHcZyG4oHGcRzHaSgeaBzHcZyG4oHGcRzHaSj/H9iyogJ7c970AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "PBO_linear_max_linear_v_weighted_average = PBO_linear_max_linear_v[:, max_bellman_iterations + 1].mean(axis=0) * samples_mask\n",
    "\n",
    "q_visu_mesh.set_values(PBO_linear_max_linear_v_weighted_average)\n",
    "q_visu_mesh.show(r\"$V^{\\pi_{pbo}}, \\mathbb{E}\\left[ V^{\\pi_{pbo\\_deep}} \\right] =$\" + str(np.round(np.mean(PBO_linear_max_linear_v_weighted_average), 4)), xlabel=\"x\", ylabel=\"v\", plot=False)\n",
    "_ = plt.savefig(f\"figures/PBO_linear_max_linear_V_{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
}
