{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# FQI on Bicycle\n",
    "\n",
    "## Define parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-27T21:29:55.753578Z",
     "iopub.status.busy": "2022-09-27T21:29:55.752798Z",
     "iopub.status.idle": "2022-09-27T21:29:56.478538Z",
     "shell.execute_reply": "2022-09-27T21:29:56.478041Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:absl:No GPU/TPU found, falling back to CPU. (Set TF_CPP_MIN_LOG_LEVEL=0 and rerun for more info.)\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "import warnings\n",
    "warnings.simplefilter(action='ignore', category=FutureWarning)\n",
    "import jax\n",
    "import jax.numpy as jnp\n",
    "import os\n",
    "import json\n",
    "\n",
    "parameters = json.load(open(\"parameters.json\"))\n",
    "env_seed = parameters[\"env_seed\"]\n",
    "gamma = parameters[\"gamma\"]\n",
    "# Sample collection\n",
    "n_samples = parameters[\"n_samples\"]\n",
    "\n",
    "# Trainings\n",
    "layers_dimension = parameters[\"layers_dimension\"]\n",
    "max_bellman_iterations = parameters[\"max_bellman_iterations\"]\n",
    "batch_size_samples = n_samples\n",
    "fitting_steps = parameters[\"fitting_steps_fqi\"]\n",
    "learning_rate = {\"first\": parameters[\"starting_lr_fqi\"], \"last\": parameters[\"ending_lr_fqi\"], \"duration\": fitting_steps * n_samples // batch_size_samples}\n",
    "max_patience = parameters[\"patience\"]\n",
    "\n",
    "# Visualisation of errors and performances\n",
    "n_omegas = parameters[\"n_omegas\"]\n",
    "n_thetas = parameters[\"n_thetas\"]\n",
    "n_simulations = parameters[\"n_simulations\"]\n",
    "horizon = parameters[\"horizon\"]\n",
    "\n",
    "# Search for an unused seed\n",
    "max_used_seed = 0\n",
    "if not os.path.exists(\"figures/data/FQI/\"):\n",
    "    os.makedirs(\"figures/data/FQI/\")\n",
    "for file in os.listdir(\"figures/data/FQI/\"):\n",
    "    if int(file.split(\"_\")[0]) == max_bellman_iterations and int(file.split(\"_\")[2][:-4]) > max_used_seed:\n",
    "        max_used_seed = int(file.split(\"_\")[2][:-4])\n",
    "max_used_seed\n",
    "\n",
    "# keys\n",
    "seed = 2 # max_used_seed + 1\n",
    "env_key = jax.random.PRNGKey(env_seed)\n",
    "env_key, sample_key = jax.random.split(env_key)\n",
    "key = jax.random.PRNGKey(seed)\n",
    "shuffle_key, q_network_key, _ = jax.random.split(key, 3) # 3 keys are generated to be coherent with the other trainings"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Define environment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-27T21:29:56.480747Z",
     "iopub.status.busy": "2022-09-27T21:29:56.480565Z",
     "iopub.status.idle": "2022-09-27T21:29:56.750052Z",
     "shell.execute_reply": "2022-09-27T21:29:56.749537Z"
    }
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "from pbo.environments.bicycle import BicycleEnv\n",
    "\n",
    "\n",
    "env = BicycleEnv(env_key, gamma)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Collect samples"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Samples on the mesh and with a uniform policy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-27T21:29:56.752635Z",
     "iopub.status.busy": "2022-09-27T21:29:56.752500Z",
     "iopub.status.idle": "2022-09-27T21:31:24.593101Z",
     "shell.execute_reply": "2022-09-27T21:31:24.592629Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of episodes: 3500\n"
     ]
    }
   ],
   "source": [
    "from pbo.sample_collection.replay_buffer import ReplayBuffer\n",
    "\n",
    "\n",
    "replay_buffer = ReplayBuffer()\n",
    "\n",
    "env.reset()\n",
    "n_episodes = 0\n",
    "n_steps = 0\n",
    "positions = [[env.position]]\n",
    "\n",
    "for idx_sample in range(n_samples):\n",
    "    state = env.state\n",
    "    \n",
    "    sample_key, key = jax.random.split(sample_key)\n",
    "    action = jax.random.choice(key, env.actions_on_max)\n",
    "    \n",
    "    next_state, reward, absorbing, _ = env.step(action)\n",
    "    n_steps += 1\n",
    "    positions[n_episodes].append(env.position)\n",
    "\n",
    "    replay_buffer.add(state, action, reward, next_state, absorbing)\n",
    "\n",
    "    if absorbing[0] or n_steps >= 20:\n",
    "        sample_key, key = jax.random.split(sample_key)\n",
    "        env.reset(\n",
    "            jax.random.multivariate_normal(\n",
    "                key,\n",
    "                jnp.zeros(4),\n",
    "                jnp.array([[1e-4, -1e-4, 0, 0], [-1e-4, 1e-3, 0, 0], [0, 0, 1e-3, -1e-4], [0, 0, -1e-4, 1e-2]]),\n",
    "            )\n",
    "            / 10\n",
    "        )      \n",
    "        positions[n_episodes] = np.array(positions[n_episodes])\n",
    "        positions.append([])\n",
    "        n_episodes += 1\n",
    "        n_steps = 0\n",
    "\n",
    "replay_buffer.cast_to_jax_array()\n",
    "# assert sum(replay_buffer.rewards == -1) > 0, \"No negative reward has been sampled, please do something!\"\n",
    "print(f\"Number of episodes: {n_episodes}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Visualize samples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-27T21:31:24.596432Z",
     "iopub.status.busy": "2022-09-27T21:31:24.596289Z",
     "iopub.status.idle": "2022-09-27T21:31:29.400815Z",
     "shell.execute_reply": "2022-09-27T21:31:29.400341Z"
    }
   },
   "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": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "fig, (ax1, ax2) = plt.subplots(2, 1, sharex=True)\n",
    "\n",
    "for episode in range(n_episodes // 10):\n",
    "    ax1.plot(positions[episode][:, 0], positions[episode][:, 1], color=\"black\")\n",
    "\n",
    "    for step in range(len(positions[episode])):\n",
    "        ax2.plot(positions[episode][step, [0, 2]], positions[episode][step, [1, 3]], color=\"black\")\n",
    "\n",
    "\n",
    "ax1.get_xaxis().set_visible(False)\n",
    "ax1.spines[\"bottom\"].set_visible(False)\n",
    "ax1.set_ylabel(\"y\")\n",
    "ax1.set_title(f\"Back tire\")\n",
    "ax2.set_xlabel(\"x\")\n",
    "ax2.set_ylabel(\"y\")\n",
    "ax2.set_title(f\"Bicycle\", y=0, pad=-30, verticalalignment=\"top\")\n",
    "\n",
    "plt.subplots_adjust(hspace=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-27T21:31:29.402660Z",
     "iopub.status.busy": "2022-09-27T21:31:29.402472Z",
     "iopub.status.idle": "2022-09-27T21:31:30.063951Z",
     "shell.execute_reply": "2022-09-27T21:31:30.063501Z"
    }
   },
   "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": [
    "omegas = jnp.linspace(-replay_buffer.states[:, 0].max(), replay_buffer.states[:, 0].max(), n_omegas)\n",
    "omega_dots = jnp.linspace(-replay_buffer.states[:, 1].max() / 2, replay_buffer.states[:, 1].max() / 2, n_omegas)\n",
    "\n",
    "sample_key, key = jax.random.split(sample_key)\n",
    "sample_omegas_omega_dots = jax.random.choice(key, replay_buffer.states[:, :2], shape=(min(n_samples // 100, 50),), replace=False) / 10\n",
    "\n",
    "thetas = jnp.linspace(-replay_buffer.states[:, 2].max() / 2, replay_buffer.states[:, 2].max() / 2, n_thetas)\n",
    "theta_dots = jnp.linspace(-replay_buffer.states[:, 3].max() / 2, replay_buffer.states[:, 3].max() / 2, n_thetas)\n",
    "\n",
    "sample_key, key = jax.random.split(sample_key)\n",
    "sample_thetas_theta_dots = jax.random.choice(key, replay_buffer.states[:, 2:5], shape=(min(n_samples // 100, 50),), replace=False) / 10\n",
    "\n",
    "_ = plt.hist(np.array(replay_buffer.rewards.flatten()), 100)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Train FQI"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-27T21:31:30.065903Z",
     "iopub.status.busy": "2022-09-27T21:31:30.065767Z",
     "iopub.status.idle": "2022-09-27T21:39:42.335264Z",
     "shell.execute_reply": "2022-09-27T21:39:42.334807Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAacAAAEYCAYAAAD4czk4AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAAvl0lEQVR4nO3debwcVZ338c/3JhBkERKCbIZVUEHHEMLig6MIqMg4gIAKw0BwwLjAIyOPCojjzgwu86A8ohgRQQYFxIWgKLLKiIBEiazKGgbCGnYMhOTe3/NHnQ6dTvet6lu93v6+86pXuqvOqTrd977qd+vUqd9RRGBmZtZLhrrdADMzs1oOTmZm1nMcnMzMrOc4OJmZWc9xcDIzs57j4GRmZj3HwcnMzHqOg5OZ9TVJn5J0erfbYa0lP4Rr1p8kLQCOiIjLxlD3TOCBiPh0q9vVCr3ePms/XzlZYZKeq1pGJD1f9f7gbrfPzMaPid1ugPWPiFiz8rrMX+1mZnl85WRtI+m1kq6S9JSkWyXtXbVtgaSPS7pJ0tOSzpO0WoP9HCtpoaRnJf1V0u5NHOMT6Rh/k/Q9SetL+lXa12WSJleV30jSTyQ9JuleSR8d5bPVbZOk4yTdndbfJundJdqzQNLxaT9PSvr+KN/RqG2XtJ2kP6XjnAfU3U8qu5akByTtWrP+lZJC0roN6uV99oY/7060z/pMRHjx0vQCLAD2GGX7KsBdwKeAVYHdgGeBV1fV/wOwETAFuB34UJ39vBq4H9govd8M2LKJY1wHrA9sDDwK/AnYjuzkdwXw2VR2CPgj8Jm0ry2Ae4B3NNmm96TPNAS8D/gbsGGz7akqfwswLX1H1wBfqv0Z5LU9rbsP+Fj6zg4Allbvq+bzfQ64pM56Ac8Buzaol/fZ6/68O9U+L/21+MrJ2mVnYE3gpIh4MSKuAH4BHFRV5pSIeDAingAuAqbX2c8wMAnYRtIqEbEgIu5u4hj/LyIeiYiFwH8D10fEjRHxAvAzssAAsAOwXkR8Ie3rHuC7wIHNtCkifpw+00hEnAfcCew4hvZUfDMi7k/f0Yk1n60ir+07k530vx4RSyPiAuCGOvtB0gTgw8Dp6f16krZIny2AZcDL6tUt8Nkb/bw70j7rLw5O1i4bAfdHxEjVuvvIrhgqHq56vZgs0KwgIu4C/pXsr+VHJZ0raaMmjvFI1evn67yvHHNTYKPUPfiUpKfIrsjWb6ZNkg6VNL9qH68Dpo6hPRX313y2jVhZXts3Ahamk3f1vup5HfAK4JL0/hhgdvpsLwPWIrviW0mBz97o592R9ll/cXCydnkQmCap+ndsE2BhszuKiB9GxJvITsIBfLnVxyALAvdGxDpVy1oRsVfRNknalOyK5Shg3YhYh6xbTmNoT8W0qtebkH3mZtv+ELCxpOp2bNLgeBsDT0bEM+n9nrx0sn8L8CRwY22lkp+97e2z/uPgZO1yPdlfx5+UtEq6ef2PwLnN7ETSqyXtJmkS8ALZ1UXlSqklx0j+ADybBjq8TNIESa+TtEMTbVqDLFA9lsq9n+wv/TKOTDf6pwAnAOeNoe3XknV3fTR9T/uxYndbtSeAl0vaXNJBZPeDtpG0DtmV4tdrrlQrynz2TrTP+oyDk7VFRLxIFijeCSwCvgUcGhF/aXJXk4CT0j4eJuvSOb7FxyAihoF3kd0HuTft73Rg7aJtiojbgP8kO9k+AryebBBDGT8EfkM2wOFu4EvNtj19T/sBh5Gd3N8H/LTB8W4gC+7zgcOBvYH/RXb/6HpeumqtbcOYP3sn2mf9xxkizHqU/CyZDTBfOZmZWc9xcDIzs57jbj0zM+s5vnIyM7Oe4+BkZmY9x8HJzMx6joOTmZn1HAcnMzPrOQ5O1naSjpI0T9ISZdNvNyr3mTQfzx5V6yZJOkPSM5IelnRMzrE+lso9k+pNGkN7r5J0RLP1WknSXyT9S531R0ua14Hjz5B0tbJZjh+RdHTVtgVacRbk31RtO1DZ/FZPS3pU0lmSXt7gGH+vFWdXfi79/Pdv9+ez3ufgZJ3wIFnanTMaFZC0Jdl8QA/VbPocsBVZgtW3kuXR27PBPt4BHAfsnspvAXy+ZNu75Szg0DrrD0nb2kbSVODXwHeAdYFXkaVQqvaPEbFmWt5etf4aYJeIWJvs+59InZRLABHx31X7WJMsBdNz6dg24BycrO0i4qcR8XPg8VGKnQocC7xYs34W8MWIeDIibifLfH1Yg33MAr4XEbdGxJPAFxuVlbSapP+S9Hia4uEGZbPSngj8PfDN9Jf8N1P510i6VNIT6crgvVX7OlPSaWn7s5J+m7J0o8zJ6SriGUk3SyqSEPVs4E2V/aR9bQP8HfCjAvXLOIZsMr9zImJJRDybvvtcae6pRVWrhsmCWxGzgAsi4m9NttfGIQcn6zpJ7wGWRMTFNesnAxsCf65a/Wdg2wa72rZO2fVVf9ruWWSJUaeRXR18CHg+Ik4gmwTwqPQX/VGS1gAuJUvC+gqySfy+lYJFxcFkwXAqWVLSc9L6twNvBrZOx3svowdpACLiAeBKsiulikOAi2tO/stJ+oWq5nSqWX6Rd8wqOwNPSPp9CqoXSaqdwuIcZVPC/0bSG2ra8SZJT5PNSrw/8PW8A6bv+ADafFVo/cPBybpK0lrAvwNH19lcmYzu6ap1T5NNKFfPmnXK0qD8UlKXVUQMR8Qfq+YIqvUuYEFEfD8ilkXEjcBPyLohK34ZEVdHxBKyqS3eKGlaOs5awGvIMrLcHhG1XZeNnEUKTsrmrDqYUU7eEfGumjmdqpd3FTwmwCvJgvfRZPMq3cuKV2sHk01NvylZAL0kTVlRacfvUrfeK4Gvkk3Rnmc/smzqv22inTaOOThZt30OODsiFtTZ9lz6v/qG+svJ/iKv57k6ZWlQ/myy2VTPlfSgpK9IWqXBfjcFdtKKM80eDGxQVWb5jLUR8RzZ1A8bRTZ1/DfJui0flTSn0QCBOn4KbChpZ2BXYHXglwXrFiLpU1WDEU5Lq58HfhYRN6Tp4z8P/C9JlSk4romI5yNicUT8B/AUWVfoCtJU9L+m2Pxas4Af1MyGawPMwcm6bXeySeYelvQwWTfb+ZKOTfeNHgKqu43eANzaYF+31in7SESs1I0WEUsj4vMRsQ3ZfEDv4qUBCLUnyPuB39ZciawZER+uKrN8xlpJawJTSLPWRsQpEbE9sA1Z994nGn4bK7ZxMXBBatchwLlp7qO6JP2qzui3yvKrBsf496pBCR9Kq2+q+Q7yAkbQeMbbicCWo1VOV5i7Aj/IOY4NEAcnaztJEyWtBkwAJqTBCBPT5t3JZkydnpYHgQ+SXWlAdsL6tKTJkl4DfAA4s8GhfgAcLqkyM+qnG5WV9FZJr5c0AXiGrPutMoPqI2QjzSp+AWwt6RBlM7WuImkHSa+tKrNXuteyKtm9p+si4v5Ubqd0VfY3splzR1IbDlM2Z9NoziKbfG9/cu7HRMQ7q0e/1SzvzDlOte8D75Y0PbX734DfRcTTkjaRtIukVdPP8RNk99muSZ/p4Mr9qTSY40Tg8pzjHQL8PiLubqKNNt5FhBcvbV3Iuu6iZvlcg7ILgD2q3k8iG4L+DFnQOKZq2yZkXXmbVK07JpV7huwkO6nBcQ4C/koWMB4BTgEmpm1vBO4AngROSeteTdal9hjZgIYrgOlp25nAaWSDJp4DrgY2T9t2J7sSeY7snso5wJpp278B5+R8dyKbBfe2Dv/MPgwsTN/BRcC0tH7b9Hn+lr6Hy4GZVfVOBB5I2x8A5gDrVm3/FfCpmmP9BTi8ThsOBm7t9u+vl+4snjLDrCRlDxY/EBGfbrLeb4Cjo+AwbbNBMjG/iJm1Q6z48KqZVfE9pyYoS4fzqKRbGmyXpFMk3SXpJkkzOt1GM7OxKHN+kzRL0p1pmdWS9rhbrzhJbya7d/CDiFjpKX9JewH/G9gL2An4RkTs1NlWmpk1b6znN0lTgHnATLL7yX8Eto9stO2Y+cqpCRFxNdnzK43sQ3pWIyKuA9aRtGFnWmdmNnYlzm/vAC6NiCdSQLoUqJv/shm+59RaG1P1MCbZaKWNWTmZKZJmA7MB1lhjje23fvXWHWlgV5S9OB/JLzKa4WXldvDgHUUTOtS3ZOmSUvXdt1HOhKEJpeqv98r1StVfa93VR91+4403LoqIMR9EU1cLXizwO/7s0lvJHmWomBMRc5o4VKPzW6P1pTg4dUn6pZgDMGP7GXHNNdd0uUXtE8Pl6g8vKbeDxY8uLlX/02/7j1L1Fzx0b6n6y4aXlao/6NZefe1S9T947EdK1X/LrNFvPa+x5ur3lTrA0hGGdtkgt9jIr+9/ISJmljpWB7lbr7UWUpUpgCy32MIutcXMBoLQUP7SAo3Ob2057zk4tdZc4NA0qmVn4OkonuTTzKx5olPBqdH57RLg7SmLy2SyTPyXlD2Yu/WaIOlHZDnApkp6APgssApARJwGXEw2kuUuYDHw/u601MwGhQRDE8vdV8v2M7bzW0Q8IemLwA1pV1+IiNEGVhTi4NSEiDgoZ3sAR3aoOWZmVLr1yipzfouIMxhlpuuxcHCyXGUHNHTbU4+Vm1j16eeezi80Cg9oKGfihHKnqdVXW6NU/U1evX6p+m2XuvXGGwcnM7M+JmDCxPE3fKDrn0jSnpL+mlJiHFdn+6aSLk/pMq6S9MqqbXVTZkjaXtLNaZ+nSFJaP0XSpan8penm3ZjScjQ6RtX2/yMpJE1t7TdmZlalcwMiOqqrwSnNpXMq8E6yidgOkrRNTbGvkT2V/HfAF4D/SHWnkN2w2wnYEfhsJdgA3yab92ertFSeVj4OuDwitiJL9V8Jhu+sKjs71R/rMSqTp70d+J8xfjVmZsVIDK0ylLv0m263eEfgroi4J7IZPs8lS5FRbRuyuXMArqzaXjdlRkqn8fKIuC7dwPsBsG+qsw8vTdh2Vs36wmk5co4BcDLwSfxwv5m1mfCVUzsUSXvxZ2C/9PrdwFqS1h2l7sbpdb19rl/13NHDQOVOZ7NpORoeQ9I+wMKI+HPdT2xm1krjtFuvHwZEfBz4pqTDyGYYXQiUHj8WESGppVc2klYHPkXWpZdXdnluvWnTpuWUNjNrRC15zqnXdPvKKTftRUQ8GBH7RcR2wAlp3VOj1F2YXtfb5yOVLOHp/0dz2tHsMbYENgf+LGlBWv8nSSslvoqIORExMyJmTl3PYybMbIzG6ZVTt4PTDcBWkjaXtCpwIFmKjOUkTZVUaefxvPSgV92UGanb7hlJO6cRdIcCF6Y6c4HKiLtZNesLp+VodIyIuDkiXhERm0XEZmTdfTMi4uEWfV9mZisYr/ecutqtFxHLJB1FFgQmAGdExK2SvgDMi4i5ZOk0/iN1wV1NekI5J2XGR4AzgZcBv0oLwEnA+ZIOB+4D3pvWjyUtR6NjmJl1jsTQOHzOqev3nCLiYrLgUL3uM1WvLwAuaFC3bsqMiJgHrDSTY0Q8DuxeZ33TaTkaHaOmzGajbTcza4V+vDLK0/XgZGZmJTh9kQ0qlRwI1O3cfEsWLy1V/8Vl5WayLWvtNctNllc2N2C/m7TKpFL1N9hySota0h5ZVnJ365mZWU8RQ0PjLziNv0/URgXyAG4i6UpJN6YcfXt1o51mNjgkWGXihNwlfz+557eTJc1Pyx2SnqraNly1bW5t3bHwlVNBVXkA30Y2RPwGSXMj4raqYp8Gzo+Ib6ccgRcDm3W8sWY2MISYUPLKqcj5LSI+VlX+fwPbVe3i+YiYXqoRNXzlVFyRPIABvDy9Xht4sIPtM7NBJBiaoNwlR5HzW7WDgB+16BPU5Sun4url2duppszngN+kvyrWAPZotDOnLzKzVpDEKhMLncqnSppX9X5ORMxJr4uc3yrH25QsE84VVatXS/teBpwUET8v2PyGHJxa6yDgzIj4T0lvBM6W9LqIGKktmH4p5gDM2H6Gs5eb2ZgImFBsKPmiiJjZgkMeCFwQscI43E0jYqGkLYArJN0cEXeXOYi79YrLzQMIHA6cDxAR1wKrAU6cZ2ZtNTQ0lLvkKHJ+qziQmi69iFiY/r8HuIoV70eNiYNTcbl5AMkmF9wdQNJryYLTYx1tpZkNlKxbr/RovSLnNyS9BpgMXFu1brKkSen1VGAX4Lbaus1yt15BBfMA/h/gu5I+RjY44rCUGsnMrC0kSj/nVPD8BlnQOrfmvPZa4DuSRsgueE6qGcU8Jg5OTSiQB/A2sr8azMw6pPxQcsg/v6X3n6tT7/fA60s3oIaDk7Vd2fRHZW263UrTaTXlmNM+Xqr+N4/6f6XqP/nsE/mFxrFlw8tK1V/w0L2l6h+w+aGl6rebBKusMv4mG3RwMjPrYxqn6YscnMzM+pkKDyXvK+Mv3LZRXu6pVOa9km6TdKukH3a6jWY2WFo0Wq/n+MqpoCK5pyRtRTaV/C4R8aSkV3SntWY2KET50Xq9yMGpuOW5pwAkVXJPVQ+Z/ABwakQ8CRARj3a8lWY2UCSNywER4y/ctk+93FMb15TZGtha0jWSrpO0Z6OdSZotaZ6keYseW9SG5prZQBBMGBrKXfqNr5xaayKwFbArWfqPqyW9PiKeqi3o3Hpm1goerWdFck89AFwfEUuBeyXdQRasbuhME81s0FQmGxxvxl+4bZ8iuad+TnbVVMkxtTVwTwfbaGYDR+7WG2QFc09dArxd0m3AMPCJiHi8e602s/FOgglD4+/KycGpCQVy6wVwTFrMzNpOiFUnrNLtZrScg5PlWmFKsbHUX7rSXItNmTCp3F+FQyWfnn9h8ZJS9ctab3K5x+U+8LXZpervdMC2perfckmpOec4dv+6z7tbIrUm8WuvcXAyM+tz7tYzM7OeMqTx2a03/q4F2ygvt56kwyQ9Jml+Wo7oRjvNbJC0ZrRemfObpFmS7kzLrFZ8Kl85FVQkt15yXkQc1fEGmtlAEuW79cqc3yRNAT4LzCSbAfyPqe6TZdrkK6filufWi4gXgUpuPTOzrlHq1stbcpQ5v70DuDQinkgB6VKgYeq2ohyciiuSWw9gf0k3SbpA0rQ62wHn1jOz1lDxbr2plXNOWqqHcZY5vxWt2xR367XWRcCPImKJpA8CZwG71Svo3Hpm1goqPiBiUUTMLHGowue3VvCVU3G5ufUi4vGIqDwUczqwfYfaZmYDbMLQhNwlR5nzW5G8o01zcCouN7eepA2r3u4N3N7B9pnZAKo8hFtytF6Z81slbdtkSZOBt6d1pbhbr6CCufU+KmlvYBnwBHBY1xpsZgNBEqtOLPecU5nzW0Q8IemLvDT7whci4olSDcLBqSkFcusdTzZNu5lZRwiYoPKdYGXObxFxBnBG6UZUcXCyXCqZGUUTutt7XPb4f3/IG0rWP7VU/Tt/e39+oVFsvsNGpeqX/fm/fq8tS9W/+Pkfl2tAj1v9ZauX3IOcvsjMzHrLUAu69XqRg5OZWZ9rRbderxl/n6iN8nJPVZXbX1JIKvNMgZlZrmy0Xumh5D3HV04FFc09JWkt4Gjg+s630swGjRATh8bfqdxXTsUVzT31ReDLwAudbJyZDa4hDeUu/ab/Wtw9ufmjJM0ApkXEL/N25tx6ZtYKYnwGp/F3LdglkoaA/0vBB2+dW8/MWkLjs1tv/H2i9snLH7UW8DrgKkkAGwBzJe0dEfM61kozGyhCDI3DTjAHp+KW554iC0oHAv9U2RgRTwNTK+8lXQV83IHJzNpJ4CunQVYw95SZWYepL+8p5XFwakJe7qma9bt2ok1mNuCEg5OZdd5Wb2k4obJZ9pyTxt+pfPx9IjOzAVIZSj7ejL9P1EZ56YskfUjSzZLmS/qdpG260U4zGyRqyXNOBc5vx0i6TdJNki6XtGnVtuF03psvqSX3333lVFDB9EU/jIjTUvm9yZ572rPjjTWzgaEWPOdU8Px2IzAzIhZL+jDwFeB9advzETG9VCNq+MqpuNz0RRHxTNXbNQA/XGtmbTdU4F+OIue3KyNicXp7Hdmznm3j4FRcbvoiAElHSrqb7K+Kj3aobWY2oFqUvqjQ+a3K4cCvqt6vltKxXSdp37F8jlru1muxiDgVOFXSPwGfBmbVKydpNjAbYNo0j8Yys7Eq3K03VVJ1UoA5KY1ac0eT/hmYCbylavWmEbFQ0hbAFZJujoi7m913NQen4vLSF9U6F/h2o43OrWdmraDiD+EuiohGc8wVOr9J2gM4AXhLRCyprI+Ihen/e1J2nO2AUsHJ3XrFLU9fJGlVsvRFK4xKkbRV1dt/AO7sYPvMbABJMFETc5ccRc5v2wHfAfaOiEer1k+WNCm9ngrsAqwwz91Y+MqpoILpi45Kf1ksBZ6kQZeemVnrlE9fVPD89lVgTeDHKbn1/0TE3sBrge9IGiG74DmpdhLWsXBwakJe+qKIOLrjjTKzgdeKh3ALnN/2aFDv98DrSzeghoOTtd3ICyOl6i/440Ol6p944FdK1d9z9j+Wqv/2f9qxVP21Nl6zVP2h1Ur+VT1cqjqaUK6+jS675zT+vmQHJzOzPjeEut2ElnNwMjPrcxqHY9vG3ydqowK5p94s6U+Slkk6oBttNLPBIrUmt16v6b8Wd0lV7ql3AtsAB9VJ7Po/wGHADzvbOjMbZGIod+k37tYrbnnuKQBJldxTy4dMRsSCtK3cCAAzsybI95wGWr3cUzuNdWdOX2RmrSDEhHE4Wq//rvXGiYiYExEzI2Lm1PWmdrs5ZtbH3K032JrNrWdm1gFyt96AW557iiwoHQj8U3ebZGaDLpsyw916AysilgGV3FO3A+dXck+lWW+RtIOkB4D3kOWaurV7LTazQZHfqdd/V1a+cmpCgdxTN9Dm2SHNzFbk9EVmY1I2t9sWu4w2IWe+793/jVL1D7lwdqn6H//OZ0vVv+8r15SqX9Y4PO911N5rHtTW/QsPJTczs56jvhyNl8fBycysjwn8nNOgK5Bbb5Kk89L26yVt1oVmmtlAUaF/uXspcX6TdHxa/1dJ72jFp3JwKqhgbr3DgScj4lXAycCXO9tKMxtEZYNTmfNbKncgsC2wJ/CttL9SCgcnSZtJ+qqkn0o6XdJRkjYt24A+sjy3XkS8CFRy61XbBzgrvb4A2F1pPmMzs7ZQ9pxT3pKjzPltH+DciFgSEfcCd6X9ldLMldOFwF/IouvbgDcAV0s6VdKksg3pA/Vy69UOI1teJj0X9TSwbr2dSZotaZ6keYseW9SG5prZIFCo0AJMrZxz0lI9DLXM+a1I3aY1HBAh6XcR8aaqVRMi4ntp2xMR8QFJE4GPAXOAWWUbM0giYg7Z98aM7WdEl5tjZn0qCCIKnUIWRcTMdrenVRpeOdUEJoDLJB1V2ZzKLIuIrwJvbFP7ekmR3HrLy6TAvTbweEdaZ2YDK4Yjd8lR5vzWlryjzXTrHQOsLWkesFHqlvpnSacyGCfg5bn1JK1KdgNwbk2Zubx0BXkAcEUU/JPGzGxMAiIid8lR5vw2FzgwjebbHNgK+EPZj1X4OaeIGAFOlHQysAcwHZgM3AKcULYhvS4ilqUrx0uACcAZldx6wLyImAt8Dzhb0l3AE2Q/YDOz9io5vWmZ81sqdz7ZxKvLgCMjYrhci8bwEG5ELCaLlLVRddwrkFvvBbKkr2ZmnREwMlK+g6bM+S0iTgROLN2IKs4QYZbj7H3mlNtB7YBcGyjn3nXGqNunbl53QG9zWhCceo2Dk5lZHwuiJVdOvcbBycysnwXj8srJ6YsKUuaUlD/qJkkzGpQ7UdL9kp7rdBvNbDBF5C/9xsGpuHeSDZHcCpgNfLtBuYtoQeoOM7NCAmJ4JHfpN+7WK24f4AdpXP91ktaRtGFEPFRdKCKuA3BKPTPrhKA/r4zy+MqpuJbmj3JuPTNrjcjuOeUtfcbBqUsiYk5EzIyImVPXm9rt5phZv0rPOeUt/cbBaRSSjpQ0X9J84CHakD/KzKy0kQJLn3FwGkVEnBoR0yNiOvBz4NA0am9n4Ona+01mZt3Qgtx6PcfBqbiLgXvIJtL6LvCRyoZ0ZVV5/RVJDwCrS3pA0uc63E4zGyTRkqzkPcej9QpKo/SObLBtetXrTwKf7FCzzGzAZaP1+i/45HFwsrYbKZmg+LmRZ0rV/+ndPylV/+h/+7+l6j/+/ZtL1T9k0w+Wql/Wly/+Uqn602ZsUKp+/gzjo1vy5Iul6r97o4NL1T/7TyVzM+aJ/rwyyuPgZGbW56IPR+Pl8T2ngppIX/RrSX+WdKuk06Syf/eZmY2u3UPJJU2RdKmkO9P/k+uUmS7p2nTuu0nS+6q2nSnp3sroZ0nT847p4FRc0fRF742INwCvA9bD8zuZWRtFwPDwSO5S0nHA5RGxFXB5el9rMXBoRGwL7Al8XdI6Vds/URn9HBHz8w7o4FTc8vRFKUXROpI2rC0UEZUbJBOBVcnuV5qZtUkQI/lLSfsAZ6XXZwH7rtSKiDsi4s70+kHgUbI/0MfEwam4wumLJF1C9oN5Frig/U0zs0EVnckQsX7Vc50PA+uPVljSjmR/nN9dtfrE1N13sqRJeQd0cGqDiHgHsCEwCditXhnn1jOzlggYXjaSuwBTK+ectMyu3o2kyyTdUmdZYS7n9FhNw2iXepTOBt4fEZX+xOOB1wA7AFOAY/M+lkfrjULSkcAH0tsbaCJ9UUS8IOlCssvhS+tsnwPMAZix/Qx3/ZnZmBXstlsUETMb7iNij0bbJD1SmYUhBZ9HG5R7OfBL4ITKDA1p35WrriWSvg98PK+xvnIaRbPpiyStWbkPJWki8A/AXzrcbDMbIEEwEvlLSXOBWen1LODC2gKSVgV+RnZv/oKabZXzosjuV92Sd0BfORV3MbAXWfqixcD7KxskzU8BbA1gbupPHQKuBE7rfFPNbGAEjCxre2bXk4DzJR0O3Ae8F0DSTOBDEXFEWvdmYF1Jh6V6h6WReedIWg8QMB/4UN4BHZwKKpK+KCIeIetTNTPriIC2T4kREY8Du9dZPw84Ir3+L+C/GtSve+99NA5OZmb9LMZnhggHJ2u7oZJJMl4+YaWH0Zty2NZHlKq/3w/3L1V/4oRyn/9Hj51eqv6gmzR51VL1L37+xy1qSbtEKx6y7TkOTmZmfazynNN449F6BRXNrVdVfq6k3BEpZmalFH/Oqa/4yqm46tx6O5Hl1tupXkFJ+wHPda5pZjaogpakJ+o5vnIqrlBuPUlrAscA5SbBMTMrqAO59TrOV07FNcqt91BNuS8C/0n2LFRDKXXIbIBp06aNVtTMrLGUlXy88ZVTC6U5SraMiJ/llY2IORExMyJmTl1vavsbZ2bjUuU5pzYnfu04XzmNYgy59d4IzJS0gOy7fYWkqyJi1zY31cwGVfRnt10eXzmNotncehHx7YjYKCI2A94E3OHAZGbtFB6tN/CK5NYzM+u4kZH+Cz55HJwKKpJbr2bdArKp2s3M2if6855SHgcnsxxl0yeZtVMAw8uGu92MlnNwMjPrZwEx7CsnMzPrIUGMy3tOHq1XUNHcepKukvRXSfPT8opOt9XMBkgHRutJmiLpUkl3pv/r9nVLGq46982tWr+5pOvT+fO8NGvuqByciqvOrTebLLdeIwdXhqBHxKMdaZ2ZDaSI7MopbynpOODyiNgKuDy9r+f5qnPf3lXrvwycHBGvAp4EDs87oINTcYVy65mZddrwsuHcpaR9gLPS67OAfYtWlCRgN+CCZuo7OBXXKLdePd9Pl7X/ln4wK5E0W9I8SfMWPbao1W01swFRmc+pQPqiqZVzTlpmN3GY9auSDjwMrN+g3Gpp39dJ2jetWxd4KiKWpfejnTuX84CI1js4IhZKWgv4CXAI8IPaQhExB5gDMGP7GeNvqI2ZdUjh9EWLImJmo42SLgM2qLPphBWOFhGSGh1w03T+2wK4QtLNwNNFGlfLwWkUY8itR0QsTP8/K+mHwI7UCU5mZq0QActa8JxTROzRaJukRyRtGBEPpdsZde+lV53/7pF0FbAd2R/p60iamK6e6p47a7lbbxTN5taTNFHS1PR6FeBdgGfDNbM2CmJkJHcpaS4wK72eBVxYW0DSZEmT0uupwC7AbSm7zpXAAaPVr+XgVNzFwD1kufW+C3ykskHS/PRyEnCJpJuA+WR/HXy3o600s8FS/J5TGScBb5N0J7BHeo+kmZJOT2VeC8yT9GeyYHRSRNyWth0LHCPpLrJ7UN/LO6C79QoqklsvIv4GbN/BZpnZgIuA4aXtTV8UEY8Du9dZPw84Ir3+PfD6BvXvIbvFUZiDk5lZX3PiVzMz6zERtOKeUs9xcDIz62sxLrOSe0BEQU3k1ltV0hxJd0j6i6T9O91WMxscTTyE21d85VRcdW69nchy6+1Up9wJwKMRsbWkIWBK55poZoMoht2tN8iW59YDrpO0TuWhtJpy/wK8BiAiRgDnJjKz9olo+2i9bnC3XnG5ufUkrZNeflHSnyT9WFLdHFTOrWdmrRBpssG8pd84OLXWRLLUHL+PiBnAtcDX6hWMiDkRMTMiZk5db2on22hm40m6cspb+o2D0ygkHVmZOAt4iPzceo8Di4Gfpvc/BuoOnDAza4UIGBkeyV36jYPTKJrNrZfuR10E7JpW7Q7chplZ2wQxPJK79BsPiCjuYmAvstx6i4H3VzZIml9JYUSWQ+psSV8HHqsuZ2bWch1IX9QNDk4FFcmtl17fB7y5Q80yswFXGRAx3jg4Wa4XRhaXqv/8yN9K1V/wt3tK1f/wmV8qVf+Wq+4oVX9kWbkulaGJ5XrfF/3kxlL1VxtavVR9a7OIvuy2y+PgZGbWz9ytZ2ZmvSaIvhyNl8ej9QpqIrfeQZJuTmV+XZkZ18ysLTrwEK6kKZIulXRn+n9ynTJvrTx6k5YXJO2btp0p6d6qbdPzjungVFx1br3ZZLn1ViBpIvAN4K0R8XfATcBRnWykmQ2W6MxDuMcBl0fEVsDl6X1tO66sevRmN7JRzb+pKvKJyvaImJ93QAen4pbn1ouI64B1JG1YU0ZpWUOSgJcDD3a4nWY2YDrwnNM+wFnp9VnAvjnlDwB+FRFjHk3l4FRcbm69iFgKfBi4mSwobQN8r97OnFvPzFpiJBh+cTh3AaZWzjlpmd3EUdavSjrwMFA3Z2iVA4Ef1aw7Md3uOFnSpLwDOji1kKRVyILTdsBGZN16x9cr69x6ZtYKQTYTbt4CLKqcc9Iyp3o/ki6TdEudZZ8Vjpc989nwJlbqUXo9cEnV6uPJZmvYgWwaoWPzPpdH641C0pHAB9LbG8jPrTcdICLuTvXPp07frJlZywSMtOAh3IjYo9E2SY9UpghKwefRUXb1XuBnqSepsu/KVdcSSd8HPp7XHl85jaLZ3HpkwWobSeul928Dbu9Yg81s8EQw8uJw7lLSXGBWej0LuHCUsgdR06VXuT+f7sXvC9ySd0BfORWXm1svIh6U9HngaklLgfuAw7rRWDMbDAGMjLT9OaeTgPMlHU52XnsvgKSZwIci4oj0fjOyHqbf1tQ/J/3RLmA+8KG8Azo4FdREbr3TgNM61CwzG3jBSLQ3OEXE42SzLNSunwccUfV+ATUDxdL63Zo9poNTDxiOZTy57LGG2z/883K3rS7/5R9L1d9z3x1L1f/F+deWqr908Yul6pfNbddtZds/ZZ83tKgl3bH4oju73YSeFhEsW7Y0v2CfcXAyM+tjAQy3+cqpG7o2IKKJdEDvS9tvlfTlqvWTJJ2X6l+f+jor245P6/8q6R1V6/dM6+6SdFzV+s3TPu5K+1x1rMdI2yZIulHSL1rxXZmZNRTZPae8pd90c7RekXRA6wJfBXaPiG2BDSRV+j0PB56MiFcBJwNfTnW2IXsAbFtgT+BbKVhMAE5Nx90GOCiVJdU9Oe3rybTvpo9R1fSj8Sg9M+uAIFg2vCx36TfdDE5F0gFtAdwZEZUbMpcB+1fVr6TTuADYPQ1T3Ac4NyKWRMS9ZKPrdkzLXRFxT0S8CJwL7JPq7Jb2ASum5mj2GEh6JfAPwOklvhszs2IiGBkZzl36TTeDU246ILKT/qslbZaSqu7LSw/CLq8fEcuAp4F1R9lvo/XrAk+lfdS2o9ljAHwd+CTQf9fRZtZ3KkPJx1u3Xk8PiIiIJyV9GDiP7GT/e2DL7raqMUnvAh6NiD9K2jWn7Gyy7kw2nrbSyEszs2Ii+rLbLk9Hr5wkHVmZzwN4iPx0QETERRGxU0S8EfgrUJkze2GlfrqqWht4vHp9zX4brX+crEtxYs36sRxjF2BvSQvIug13k/Rf9b6L6tx6606dUq+ImVmu8Xrl1NHgNIZ0QEh6Rfp/MvARXrqXU51O4wDgivSg7FzgwDTSbnOyARd/IMuNt1Uambcq2YCGuanOlWkfsGJqjqaOERHHR8QrI2KztP8rIuKfy3xnZmajiQiWDi/NXfpNN7v1ctMBpbffkFR5ivALEVG5cvoecLaku4AnyIIBEXFrSrh6G7AMODIihtN+jyLLlDsBOCMibk37OhY4V9KXgBt5aZqLpo9hZtZZ0ZdXRnm6FpyaSAd0UIMyLwDvabDtRODEOusvJguKtevvIY22K3uMqu1XAVc12m5m1goBbU9f1A09PSBiULww/AJ3PPOXhtt/cc7vSu2/bPqbn5x+Zan6ZmWs/o9bdfX43/rP3KmHRnXY1kfkFyohIljWh912eRyczMz6mrv1zMys10RHpszoOE82WJCk10i6VtISSQ1ncWyUp8/MrB2CYOnwstylDEnvSflNR9IcTo3KNZW/dDQOTsU9AXwU+FpOuUZ5+szMWi46k77oFmA/4OpGBcaYv7QhB6eCIuLRiLgBaHjnMSdPn5lZW4zESO5SRkTcHhF/zSk2lvylDfmeU2uNlqdvBdXpi4Alb934HbeUOO5UYJHru77rt77+R97w0XL1ya3/6rwCo3mWpy+5YuSiqQWKriZpXtX7ORExp8yxa9TLOboTTZwXqzk4dUn6pZgDIGleRDTsx83j+q7v+v1df6x1ASJizzL1q9pxGbBBnU0nRMSFdda3lYPTKCQdCXwgvd0rIh7MqbI8T1/6K6FuvkAzs14TEXuU3EVu/tJmzou+5zSK6lyABQJTJetFozx9Zmbj2Vjylzbk4FSQpA0kPQAcA3xa0gOSXp62XSxpo1T0WOCYlI9vXV7K0zeasv2+ru/6rj+49dtO0rvT+e+NwC8lXZLWbyTpYlg+510lf+ntwPk1+UubOi8qC2pmZma9w1dOZmbWcxyczMys5zg4mZlZz3FwMjOznuPgZF0haYqkKd2q3wttcP3yP0MbvxyceoSkz4z3+pI2kXSupMeA64E/SHo0rdus3fV7oQ2uX/5nOMq+bx7k+uONh5L3CEn/ExGbjOf6kq4Fvg5cEBHDad0E4D3Av0bEzu2s3wttcP3S9fdrtAk4LSLWG8/1B4mDUwdJeqbRJuBlETFqOqlxUP/OiKg75/Zo21pVvxfa4Pql6y8FzgHqnbgOiIi1xnP9QeLcep31FLBDRDxSu0HS/SsXH3f1/yjpW2Qp8yvlp5GlM7mxA/V7oQ2uX67+TcDXImKlLP6SiuSG6/f6A8PBqbN+AGwKrHRyB344APUPJZtk7PO8lDL/AeAiiqV5Klu/F9rg+uXq/yvQ6Ar+3QNQf2C4W8/MzHqOR+tZT5D0rm7W74U2uL7rl6k/3jg49QhJfxrk+sAOXa7fC21wfde3xN161lGSXgPsw0v3GxaSzflyeyfq90IbXN/1y9QfFL5y6gJJ60uakZb1B6W+pGOBc8mGnv8hLQJ+JOm4dtfvhTa4vuuXqT9QIsJLhxZgOnAd2URcl6XlL2ndjAGofwewSp31qwJ3trt+L7TB9V2/7O/woCweSt5ZZwIfjIjrq1dK2hn4PvCGcV5/BNgIuK9m/YZpW56y9XuhDa7v+mV/hweCg1NnrVF7YgeIiOskrTEA9f8VuFzSnbz0AOYmwKvIpndud/1eaIPru37Z3+GB4AERHSTpFGBLsodZq5+OPxS4NyJG/eXs9/ppH0PAjqx4M/iGSHnW2l2/F9rg+q5fpv6gcHDqMEnvZMWROg8CF0bExYNQ38ysCAenLpP0p4iYMaj1zczq8VDy7tOA1zczW4mDU/d9d8Drm5mtxN16ZmbWc3zlZGZmPcfByczMeo6Dk5mZ9RwHJzMz6zkOTmZdImmCpG9IulXSzZK26HabzHqFg5NZ9xwP3BMR2wKnAB/pcnvMeoYTv5p1QUqU++6I2D6tuhf4hy42yaynODiZdccewDRJ89P7KWTzY5kZ7tYz65bpwGciYnpETAd+A8zvZoPMeomDk1l3TAYWA0iaCLwduKirLTLrIQ5OZt1xB7Bzev0x4JcRcW8X22PWU5xbz6wLJE0GfgVMBa4FZkfE891tlVnvcHAyM7Oe4249MzPrOQ5OZmbWcxyczMys5zg4mZlZz3FwMjOznuPgZGZmPcfByczMes7/B4FoIZHEm8ykAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "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",
    "from pbo.utils.two_dimesions_mesh import TwoDimesionsMesh\n",
    "from pbo.sample_collection.dataloader import SampleDataLoader\n",
    "from pbo.networks.learnable_q import FullyConnectedQ\n",
    "\n",
    "\n",
    "data_loader_samples = SampleDataLoader(replay_buffer, batch_size_samples, shuffle_key)\n",
    "q = FullyConnectedQ(\n",
    "    state_dim=4,\n",
    "    action_dim=2,\n",
    "    actions_on_max=env.actions_on_max,\n",
    "    gamma=gamma,\n",
    "    network_key=q_network_key,\n",
    "    layers_dimension=layers_dimension,\n",
    "    zero_initializer=True,\n",
    "    learning_rate=learning_rate\n",
    ")\n",
    "\n",
    "omega_visu_mesh = TwoDimesionsMesh(omegas, omega_dots, sleeping_time=0, axis_equal=False, zero_centered=True)\n",
    "theta_visu_mesh = TwoDimesionsMesh(thetas, theta_dots, sleeping_time=0, axis_equal=False, zero_centered=True)\n",
    "l2_losses = np.ones((max_bellman_iterations, fitting_steps)) * np.nan\n",
    "metrics = np.ones((max_bellman_iterations + 1, n_simulations, 2)) * np.nan\n",
    "metrics[0] = env.evaluate(q, q.params, horizon, n_simulations=1)\n",
    "\n",
    "for bellman_iteration in range(1, max_bellman_iterations + 1):\n",
    "    q.reset_optimizer()\n",
    "    params_target = q.params\n",
    "    best_loss = float('inf')\n",
    "    patience = 0\n",
    "\n",
    "    for step in range(fitting_steps):\n",
    "        cumulative_l2_loss = 0\n",
    "        \n",
    "        data_loader_samples.shuffle()\n",
    "        for batch_samples in data_loader_samples:\n",
    "            q.params, q.optimizer_state, l2_loss = q.learn_on_batch(q.params, params_target, q.optimizer_state, batch_samples)\n",
    "            cumulative_l2_loss += l2_loss\n",
    "\n",
    "        l2_losses[bellman_iteration - 1, step] = cumulative_l2_loss\n",
    "        if cumulative_l2_loss < best_loss:\n",
    "            patience = 0\n",
    "            best_loss = cumulative_l2_loss\n",
    "        else:\n",
    "            patience += 1\n",
    "\n",
    "        if patience > max_patience:\n",
    "            break\n",
    "\n",
    "    metric = env.evaluate(q, q.params, horizon, n_simulations=1)\n",
    "    metrics[bellman_iteration] = metric\n",
    "\n",
    "    d_on_omegas = env.best_action_on_omegas(q, q.params, omegas, omega_dots, sample_thetas_theta_dots)\n",
    "    T_on_thetas = env.best_action_on_thetas(q, q.params, sample_omegas_omega_dots, thetas, theta_dots)\n",
    "\n",
    "    omega_visu_mesh.set_values(d_on_omegas)\n",
    "    omega_visu_mesh.show(r\"d on some sampled $\\theta$ and $\\dot{\\theta}$,\" + f\"\\nl2 loss: {str(jnp.round(cumulative_l2_loss, 5))}, iteration {bellman_iteration}, step {step + 1}.\", xlabel=r\"$\\omega$\", ylabel=r\"$\\dot{\\omega}$\")\n",
    "    theta_visu_mesh.set_values(T_on_thetas)\n",
    "    theta_visu_mesh.show(r\"T on some sampled $\\omega$ and $\\dot{\\omega}$\" + f\"\\n{metric[:, 0].mean()} steps, V = {str(jnp.round(metric[:, 1].mean(), 1))}.\", xlabel=r\"$\\theta$\", ylabel=r\"$\\dot{\\theta}$\", clear=False)\n",
    "\n",
    "\n",
    "for bellman_iteration in range(0, max_bellman_iterations, max(max_bellman_iterations // 10, 1)):\n",
    "    plt.plot(l2_losses[bellman_iteration], label=f\"Iteration {bellman_iteration + 1}\")\n",
    "\n",
    "plt.legend()\n",
    "plt.xlabel(\"fitting step\")\n",
    "plt.ylabel(r\"$(\\Gamma^*Q_i - Q_{i +  1})^2$\")\n",
    "plt.title(\"Training losses\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-27T21:39:42.337073Z",
     "iopub.status.busy": "2022-09-27T21:39:42.336936Z",
     "iopub.status.idle": "2022-09-27T21:39:42.406180Z",
     "shell.execute_reply": "2022-09-27T21:39:42.405667Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7fca6543bdf0>]"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(range(1, max_bellman_iterations + 1), [np.argmin(l) for l in l2_losses])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-27T21:39:42.408417Z",
     "iopub.status.busy": "2022-09-27T21:39:42.408283Z",
     "iopub.status.idle": "2022-09-27T21:39:42.507050Z",
     "shell.execute_reply": "2022-09-27T21:39:42.506572Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7fca7be6d070>]"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, (ax1, ax2) = plt.subplots(1, 2)\n",
    "\n",
    "ax1.plot(range(max_bellman_iterations + 1), metrics[:, :, 0].mean(axis=1))\n",
    "ax1.set_xticks(range(0, max_bellman_iterations + 1, 3))\n",
    "ax2.plot(range(max_bellman_iterations + 1), metrics[:, :, 1].mean(axis=1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-27T21:39:42.509275Z",
     "iopub.status.busy": "2022-09-27T21:39:42.509141Z",
     "iopub.status.idle": "2022-09-27T21:39:42.869102Z",
     "shell.execute_reply": "2022-09-27T21:39:42.868666Z"
    }
   },
   "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": [
    "positions = env.collect_positions(q, q.params, horizon)\n",
    "\n",
    "plt.plot(positions[:, 0], positions[:, 1], color=\"black\")\n",
    "plt.axis(\"equal\")\n",
    "_ = plt.title(f\"{positions.shape[0]} steps\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-27T21:39:42.871224Z",
     "iopub.status.busy": "2022-09-27T21:39:42.871091Z",
     "iopub.status.idle": "2022-09-27T21:39:42.881444Z",
     "shell.execute_reply": "2022-09-27T21:39:42.881008Z"
    }
   },
   "outputs": [],
   "source": [
    "# env.simulate(q, q.params, horizon)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Save the data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-27T21:39:42.883639Z",
     "iopub.status.busy": "2022-09-27T21:39:42.883509Z",
     "iopub.status.idle": "2022-09-27T21:39:42.893958Z",
     "shell.execute_reply": "2022-09-27T21:39:42.893518Z"
    }
   },
   "outputs": [],
   "source": [
    "# np.save(f\"figures/data/FQI/{max_bellman_iterations}_metrics_{seed}.npy\", metrics)"
   ]
  }
 ],
 "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"
  },
  "vscode": {
   "interpreter": {
    "hash": "af5525a3273d35d601ae265c5d3634806dd61a1c4d085ae098611a6832982bdb"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
