{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "2b9aedec",
   "metadata": {},
   "source": [
    "This file collects result for continuous action environments. The agents here are trained with the EvA-RL framework."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fe68f48e",
   "metadata": {},
   "outputs": [],
   "source": [
    "from __future__ import annotations\n",
    "import os\n",
    "os.environ[\"XLA_PYTHON_CLIENT_PREALLOCATE\"] = \"false\"\n",
    "from typing import Any, NamedTuple\n",
    "import jax.numpy as jnp\n",
    "import jax\n",
    "import numpy as np\n",
    "from typing import Dict\n",
    "from collections import namedtuple\n",
    "from models import *\n",
    "from wrappers import *\n",
    "import orbax.checkpoint as oc\n",
    "\n",
    "class Transition(NamedTuple):\n",
    "    done:     jnp.ndarray\n",
    "    action:   jnp.ndarray\n",
    "    value:    jnp.ndarray\n",
    "    reward:   jnp.ndarray\n",
    "    log_prob: jnp.ndarray\n",
    "    obs:      jnp.ndarray\n",
    "    info:     Any\n",
    "\n",
    "\n",
    "import argparse\n",
    "import time\n",
    "import pickle\n",
    "import gc\n",
    "from functools import partial\n",
    "from typing import Sequence, NamedTuple, Any\n",
    "\n",
    "import numpy as np\n",
    "import jax\n",
    "import jax.numpy as jnp\n",
    "import optax\n",
    "import flax.linen as nn\n",
    "from flax.linen.initializers import constant, orthogonal\n",
    "from flax.training.train_state import TrainState\n",
    "import orbax.checkpoint as oc\n",
    "import distrax\n",
    "import gymnax\n",
    "import gymnasium as gym\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "plt.rcParams.update({\n",
    "    \"text.usetex\": False,\n",
    "    \"font.family\": \"serif\",\n",
    "    \"font.serif\": [\"Palatino\"],\n",
    "    \"axes.labelsize\": 18,\n",
    "    \"font.size\": 18,\n",
    "    \"legend.fontsize\": 18,\n",
    "    \"xtick.labelsize\": 18,\n",
    "    \"ytick.labelsize\": 18,\n",
    "})\n",
    "sns.set_style(\"darkgrid\")\n",
    "import wandb\n",
    "from scipy.stats import sem\n",
    "\n",
    "# Local modules\n",
    "from wrappers import (\n",
    "    LogWrapper, FlattenObservationWrapper, LogEnvState,\n",
    "    BraxGymnaxWrapper, VecEnv, NormalizeVecObservation,\n",
    "    NormalizeVecReward, ClipAction\n",
    ")\n",
    "from models import ActorCriticDiscreteAction, ActorCriticContinuousAction, PredictabilityHead, FeatExtractorDiscreteAction\n",
    "from utils import Transition, load_feat_extractor_params, extract_submodel\n",
    "\n",
    "os.environ[\"XLA_PYTHON_CLIENT_PREALLOCATE\"] = \"false\"\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b70591ec",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_parser() -> argparse.ArgumentParser:\n",
    "    parser = argparse.ArgumentParser(\n",
    "        description=\"Evaluation\"\n",
    "    )\n",
    "    parser.add_argument(\"--save_dir\", default=\"./complete_continuous_longrun/\", type=str, help=\"Directory to save results\")\n",
    "    parser.add_argument(\"--experiment_name\", default=\"Pong-misc_64envs_100steps_10000000.0ts_2seed_10dtr_200gtr_3dt_Pong-misc_32bs_0.001lr_100ep_4h_8l_128hd\", type=str,)\n",
    "    parser.add_argument(\"--num_eval_samples\", default=250, type=int)\n",
    "    parser.add_argument(\"--num_trajs_per_state\", default=10, type=int, help=\"Number of trajectories to sample per state during MC evaluation\")\n",
    "    parser.add_argument(\"--experiment_name_file\", type=str, default=\"./complete_continuous_long_run_scripts/experiment_names.txt\",\n",
    "                        help=\"File containing the experiment names to evaluate\")\n",
    "    parser.add_argument(\"--PREDICTABILITY_COEF\", default=0.0, type=float, help=\"Predictability coefficient\")\n",
    "    parser.add_argument(\"--PRED_LR\", default=0.0, type=float, help=\"Learning rate for the predictability transformer\")\n",
    "    parser.add_argument(\"--use_pretrained_transformer\", default=0, type=int, help=\"Use pretrained transformer\")\n",
    "    return parser\n",
    "\n",
    "parser = get_parser()\n",
    "args = parser.parse_args([])\n",
    "save_dir = args.save_dir\n",
    "experiment_name = args.experiment_name\n",
    "experiment_name_file = args.experiment_name_file\n",
    "if args.PRED_LR != 0:\n",
    "    pred_lr = 1e-4 if args.use_pretrained_transformer == 1 else 1e-3\n",
    "else: \n",
    "    pred_lr = 0\n",
    "use_pretrained_transformer = args.use_pretrained_transformer\n",
    "pred_coef = args.PREDICTABILITY_COEF\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1d6f4e99",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 180 Eval Value files\n",
      "Experiment names:  ['halfcheetah_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0.001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0.001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0.0001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0.0001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0.001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0.0001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0.001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0.0001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0.0001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0.001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0.001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0.0001predlr', 'ant_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0.001predlr', 'ant_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0.0001predlr', 'ant_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0.001predlr', 'ant_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0.0001predlr', 'ant_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0.001predlr', 'ant_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0.0001predlr', 'ant_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0.001predlr', 'ant_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0.0001predlr', 'ant_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0.001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0.0001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0.001predlr', 'ant_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0.0001predlr', 'ant_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0.0001predlr', 'ant_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0.001predlr', 'ant_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0.0001predlr', 'ant_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0.001predlr', 'ant_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0.0001predlr', 'ant_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0.001predlr', 'ant_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0.0001predlr', 'ant_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0.001predlr', 'ant_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0.0001predlr', 'ant_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0.0001predlr', 'reacher_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0.001predlr', 'reacher_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0.0001predlr', 'reacher_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0.001predlr', 'reacher_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0.0001predlr', 'ant_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0.001predlr', 'ant_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0.0001predlr', 'ant_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0.001predlr', 'ant_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0.001predlr', 'ant_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0.0001predlr', 'reacher_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0.0001predlr', 'reacher_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0.001predlr', 'reacher_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0.0001predlr', 'reacher_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0.001predlr', 'reacher_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0.0001predlr', 'reacher_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0.001predlr', 'reacher_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0.0001predlr', 'reacher_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0.001predlr', 'reacher_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0.0001predlr', 'reacher_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0.001predlr', 'reacher_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0.0001predlr', 'reacher_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0.001predlr', 'reacher_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0.001predlr', 'reacher_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0.0001predlr', 'reacher_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0.001predlr', 'reacher_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0.0001predlr', 'reacher_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0.001predlr', 'reacher_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0.0001predlr', 'ant_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0.001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0.001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0.0001predlr', 'ant_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0.001predlr', 'reacher_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0.0001predlr', 'reacher_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0.001predlr', 'reacher_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0.0001predlr', 'reacher_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0.001predlr', 'reacher_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0.0001predlr', 'reacher_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0predlr', 'reacher_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0.001predlr', 'reacher_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0.0001predlr', 'reacher_2048envs_10steps_50000000.0ts_1seed_25dtr_1000gtr_5dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0.001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0.001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0.0001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0.001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0.0001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0predlr', 'ant_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0.0001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0.001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0.0001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0.001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0.0001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0.0001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0.001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0.001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_1usepretrained_0.0001predlr', 'ant_2048envs_10steps_50000000.0ts_0seed_25dtr_1000gtr_5dt_ant_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_1usepretrained_0.0001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_2seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.005pc_0usepretrained_0.001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_0usepretrained_0.001predlr', 'halfcheetah_2048envs_10steps_50000000.0ts_3seed_25dtr_1000gtr_5dt_halfcheetah_256bs_0.001lr_100ep_4h_4l_16hd_0.0pc_1usepretrained_0.0001predlr']\n"
     ]
    }
   ],
   "source": [
    "# List all the files in the save directory that end with _a2c_params.pkl\n",
    "\n",
    "eval_value_files = []\n",
    "for root, dirs, files in os.walk(save_dir):\n",
    "    for file in files:\n",
    "        if file.endswith(\"predlr_eval_values.pkl\"):\n",
    "            eval_value_files.append(file)\n",
    "print(f\"Found {len(eval_value_files)} Eval Value files\")\n",
    "sorted(eval_value_files)\n",
    "experiment_names = [eval_file[:-len(\"_eval_values.pkl\")] for eval_file in eval_value_files]\n",
    "print(\"Experiment names: \", experiment_names)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "959f7e46",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'env_name': 'halfcheetah',\n",
       " 'num_envs': 2048,\n",
       " 'num_steps': 1,\n",
       " 'num_timesteps': 50000000.0,\n",
       " 'seed': 0,\n",
       " 'num_dtr': 25,\n",
       " 'num_gtr': 1000,\n",
       " 'num_dt': 5,\n",
       " 'env_name_2': 'halfcheetah',\n",
       " 'batch_size': 256,\n",
       " 'learning_rate': 0.001,\n",
       " 'num_epochs': 100,\n",
       " 'num_heads': 4,\n",
       " 'num_layers': 4,\n",
       " 'hidden_dim': 16,\n",
       " 'pred_coef': 0.0,\n",
       " 'use_pretrained_transformer': 0,\n",
       " 'pred_lr': 0.001}"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Create parser for the experiment name\n",
    "# Example: 'reacher_2048envs_10steps_50000000.0ts_4seed_25dtr_1000gtr_3dt_reacher_256bs_0.001lr_100ep_4h_4l_16hd_0.0005pc_0usepretrained_0predlr'\n",
    "\n",
    "def parse_experiment_name(experiment_name):\n",
    "    parts = experiment_name.split(\"_\")\n",
    "    env_name = parts[0]\n",
    "    num_envs = int(parts[1][:-4])\n",
    "    num_steps = int(parts[2][:-6])\n",
    "    num_timesteps = float(parts[3][:-2])\n",
    "    seed = int(parts[4][:-4])\n",
    "    num_dtr = int(parts[5][:-3])\n",
    "    num_gtr = int(parts[6][:-3])\n",
    "    num_dt = int(parts[7][:-2])\n",
    "    env_name_2 = parts[8]\n",
    "    batch_size = int(parts[9][:-2])\n",
    "    learning_rate = float(parts[10][:-2])\n",
    "    num_epochs = int(parts[11][:-2])\n",
    "    num_heads = int(parts[12][:-1])\n",
    "    num_layers = int(parts[13][:-1])\n",
    "    hidden_dim = int(parts[14][:-2])\n",
    "    pred_coef = float(parts[15][:-2])\n",
    "    use_pretrained_transformer = int(parts[16][0])\n",
    "    pred_lr = float(parts[17][:-len(\"predlr\")])\n",
    "    return {\n",
    "        \"env_name\": env_name,\n",
    "        \"num_envs\": num_envs,\n",
    "        \"num_steps\": num_steps,\n",
    "        \"num_timesteps\": num_timesteps,\n",
    "        \"seed\": seed,\n",
    "        \"num_dtr\": num_dtr,\n",
    "        \"num_gtr\": num_gtr,\n",
    "        \"num_dt\": num_dt,\n",
    "        \"env_name_2\": env_name_2,\n",
    "        \"batch_size\": batch_size,\n",
    "        \"learning_rate\": learning_rate,\n",
    "        \"num_epochs\": num_epochs,\n",
    "        \"num_heads\": num_heads,\n",
    "        \"num_layers\": num_layers,\n",
    "        \"hidden_dim\": hidden_dim,\n",
    "        \"pred_coef\": pred_coef,\n",
    "        \"use_pretrained_transformer\": use_pretrained_transformer,\n",
    "        \"pred_lr\": pred_lr\n",
    "    }\n",
    "parse_experiment_name(experiment_names[0])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8b282b12",
   "metadata": {},
   "source": [
    "Create valid combinations for plotting the results.\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "81a6c33a",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█▌        | 28/180 [00:00<00:00, 276.04it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 180/180 [00:01<00:00, 168.26it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Successful experiments: 120/180\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# For experiments in the experiment \n",
    "from tqdm import tqdm\n",
    "eval_results = {}\n",
    "total_num = len(experiment_names)\n",
    "unsuccessful = 0\n",
    "for experiment_name in tqdm(experiment_names):\n",
    "    if not( \"0.0005pc\" in experiment_name or \"0.0pc\" in experiment_name):\n",
    "        continue\n",
    "        \n",
    "    try:\n",
    "        with open(f'{save_dir}/{experiment_name}_eval_values.pkl', \"rb\") as f:\n",
    "            eval_values = pickle.load(f)\n",
    "    except:\n",
    "        print(f\"Error loading {experiment_name} eval values\")\n",
    "        unsuccessful += 1\n",
    "        continue\n",
    "        \n",
    "    eval_results[experiment_name] = eval_values\n",
    "\n",
    "print(f\"Successful experiments: {len(eval_results)}/{total_num}\")\n",
    "\n",
    "experiment_names = list(eval_results.keys())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c3695ada",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Environment wise count:\n",
      "{'reacher': 40, 'ant': 40, 'halfcheetah': 40}\n"
     ]
    }
   ],
   "source": [
    "# Split by env\n",
    "envs = [\"reacher\", \"ant\", \"halfcheetah\"]\n",
    "env_wise_count = {env: 0 for env in envs}\n",
    "for experiment_name in experiment_names:\n",
    "    for env in envs:\n",
    "        if env in experiment_name:\n",
    "            env_wise_count[env] += 1\n",
    "            # break\n",
    "print(\"Environment wise count:\")\n",
    "print(env_wise_count)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "00bf180f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Find the experiments that have the same parameters but different seeds\n",
    "\n",
    "groups = {}\n",
    "\n",
    "for exp_name in eval_results.keys():\n",
    "    start = exp_name.index(\"ts_\") + 3\n",
    "    end = exp_name.index(\"seed\") + 5\n",
    "    if exp_name[:start] + exp_name[end:] not in groups:\n",
    "        groups[exp_name[:start] + exp_name[end:]] = []\n",
    "    groups[exp_name[:start] + exp_name[end:]].append(exp_name)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "b457d0ad",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Group experiments by environment name, number of driver states, predictability coef, pred lr, and use pretrained transformer\n",
    "\n",
    "def group_experiments_by_env_and_params(experiment_names):\n",
    "    groups = {}\n",
    "    for experiment_name in experiment_names:\n",
    "        # Parse the experiment name\n",
    "        parsed_experiment_name = parse_experiment_name(experiment_name)\n",
    "        env_name = parsed_experiment_name[\"env_name\"]\n",
    "        num_dt = parsed_experiment_name[\"num_dt\"]\n",
    "        pred_coef = parsed_experiment_name[\"pred_coef\"]\n",
    "        pred_lr = parsed_experiment_name[\"pred_lr\"]\n",
    "        use_pretrained_transformer = parsed_experiment_name[\"use_pretrained_transformer\"]\n",
    "        \n",
    "        # Create a key for the group\n",
    "        group_key = f\"{env_name}_{num_dt}_{pred_coef}_{pred_lr}_{use_pretrained_transformer}\"\n",
    "        \n",
    "        # Add the experiment to the group\n",
    "        if group_key not in groups:\n",
    "            groups[group_key] = []\n",
    "        groups[group_key].append(experiment_name)\n",
    "    \n",
    "    return groups\n",
    "\n",
    "groups_by_env_and_params = group_experiments_by_env_and_params(eval_results.keys())"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "200b1f0a",
   "metadata": {},
   "source": [
    "# Pred Coef Effect"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "2fc2d390",
   "metadata": {},
   "outputs": [],
   "source": [
    "import itertools\n",
    "\n",
    "from scipy.stats import sem\n",
    "import numpy as np\n",
    "from collections import defaultdict\n",
    "\n",
    "THRESH = 1_000.0   # anything ≥ 1e3 is considered “arbitrarily large”\n",
    "\n",
    "def compute_group_mae(groups, group_name, eval_results):\n",
    "    \"\"\"\n",
    "    Return {estimator: {'agg', 'std', 'num_experiments'}} for one group,\n",
    "    **after removing MAE outliers ≥ THRESH**.\n",
    "    \"\"\"\n",
    "    experiments = groups[group_name]              # list of exp-ids\n",
    "    per_estimator = defaultdict(list)             # key → list of MAEs\n",
    "\n",
    "    for exp in experiments:\n",
    "        res = eval_results[exp]\n",
    "        mc  = res[\"mc\"]                           # ground-truth vector\n",
    "        for key, val in res.items():\n",
    "            if key == \"mc\":\n",
    "                continue\n",
    "            mae = float(np.mean(np.abs(val - mc)))\n",
    "            if mae < THRESH:                      # keep only reasonable MAEs\n",
    "                per_estimator[key.lower()].append(mae)\n",
    "\n",
    "    # aggregate (skip estimators that have no remaining samples)\n",
    "    stat_of_group = {\n",
    "        est: {\n",
    "            \"agg\": np.mean(vals),\n",
    "            \"std\": sem(vals),\n",
    "            \"num_experiments\": len(vals)\n",
    "        }\n",
    "        for est, vals in per_estimator.items() if vals\n",
    "    }\n",
    "    return stat_of_group\n",
    "\n",
    "\n",
    "\n",
    "def compute_group_return(groups, group_name, eval_results):\n",
    "    \n",
    "    experiments = groups[group_name]\n",
    "    returns = []\n",
    "    for experiment in experiments:\n",
    "        returns.append(np.mean(eval_results[experiment][\"mc\"]))\n",
    "    \n",
    "    return {\n",
    "        \"agg\": np.mean(returns),\n",
    "        \"std\": sem(returns),\n",
    "        \"num_experiments\": len(experiments)\n",
    "    }\n",
    "    \n",
    "# For each environment, plot the effect of the number of driver states on the results\n",
    "# pred_coef_ = [1e-2, 5e-2]\n",
    "num_dt_ = 5\n",
    "pred_lr_ = 1e-4 # Anything other than 0\n",
    "use_pretrained_transformer_ = 1 # Use pretrained transformer\n",
    "\n",
    "# Find the mae and returns for these groups\n",
    "pred_coef_groups = {}\n",
    "pred_coef_group_results = {}\n",
    "pred_coef_group_return = {}\n",
    "for use_pretrained_transformer_ in [0, 1]:    \n",
    "    for pred_lr_ in [0, 1e-4]:\n",
    "        for experiment_name in eval_results.keys():\n",
    "            parsed_experiment_name = parse_experiment_name(experiment_name)\n",
    "            env_name = parsed_experiment_name[\"env_name\"]\n",
    "            num_dt = parsed_experiment_name[\"num_dt\"]\n",
    "            pred_coef = parsed_experiment_name[\"pred_coef\"]\n",
    "            pred_lr = parsed_experiment_name[\"pred_lr\"]\n",
    "            use_pretrained_transformer = parsed_experiment_name[\"use_pretrained_transformer\"]\n",
    "            \n",
    "            if (pred_lr_ ==0 and pred_lr != 0) or (pred_lr_ != 0 and pred_lr == 0):\n",
    "                continue\n",
    "            if num_dt != num_dt_ or use_pretrained_transformer != use_pretrained_transformer_:\n",
    "                continue\n",
    "            \n",
    "            # if use_pretrained_transformer != use_pretrained_transformer_:\n",
    "            #     continue\n",
    "            # Create a key for the group\n",
    "            group_key = f\"{env_name}_{pred_coef}_{pred_lr}_{use_pretrained_transformer}\"\n",
    "            \n",
    "            # Add the experiment to the group\n",
    "            if group_key not in pred_coef_groups:\n",
    "                pred_coef_groups[group_key] = []\n",
    "            pred_coef_groups[group_key].append(experiment_name)\n",
    "\n",
    "\n",
    "        for pc_group in pred_coef_groups.keys():\n",
    "            pc_group_stat = compute_group_mae(pred_coef_groups, pc_group, eval_results)\n",
    "            pred_coef_group_results[pc_group] = pc_group_stat\n",
    "            pc_group_return_ = compute_group_return(pred_coef_groups, pc_group, eval_results)\n",
    "            pred_coef_group_return[pc_group] = pc_group_return_\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "5c4530c2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "halfcheetah_0.0_0.001_0\n",
      "{'fqe': {'agg': np.float64(28.147297382354736), 'std': np.float64(8.883781973592711), 'num_experiments': 4}, 'tis': {'agg': np.float64(3.180107283592224), 'std': np.float64(1.4702601160293678), 'num_experiments': 5}, 'pdis': {'agg': np.float64(2.5438591957092287), 'std': np.float64(0.8397674527900626), 'num_experiments': 5}, 'dr': {'agg': np.float64(6.2129194140434265), 'std': np.float64(1.8766369487192753), 'num_experiments': 4}, 'predictor': {'agg': np.float64(4.860826778411865), 'std': np.float64(1.9682472417766), 'num_experiments': 5}}\n",
      "{'agg': np.float32(-1.4742432), 'std': np.float32(2.0080814), 'num_experiments': 5}\n",
      "halfcheetah_0.0005_0.001_0\n",
      "{'fqe': {'agg': np.float64(24.883360958099367), 'std': np.float64(11.973212894002636), 'num_experiments': 5}, 'tis': {'agg': np.float64(3.3966276168823244), 'std': np.float64(1.2292762759310243), 'num_experiments': 5}, 'pdis': {'agg': np.float64(4.878611755371094), 'std': np.float64(1.8562500644470936), 'num_experiments': 5}, 'dr': {'agg': np.float64(6.648672699928284), 'std': np.float64(2.2427657236026177), 'num_experiments': 5}, 'predictor': {'agg': np.float64(3.458831858634949), 'std': np.float64(0.9417726485786724), 'num_experiments': 5}}\n",
      "{'agg': np.float32(1.6914333), 'std': np.float32(1.8373853), 'num_experiments': 5}\n",
      "ant_0.0_0.001_0\n",
      "{'fqe': {'agg': np.float64(55.976191711425784), 'std': np.float64(6.949204153666913), 'num_experiments': 5}, 'tis': {'agg': np.float64(2.538317084312439), 'std': np.float64(0.6215373042141926), 'num_experiments': 5}, 'pdis': {'agg': np.float64(62.3641637802124), 'std': np.float64(25.87864727699151), 'num_experiments': 5}, 'dr': {'agg': np.float64(10.19785442352295), 'std': np.float64(2.8608276024143633), 'num_experiments': 5}, 'predictor': {'agg': np.float64(3.036798083782196), 'std': np.float64(0.8955020693685077), 'num_experiments': 5}}\n",
      "{'agg': np.float32(-1.1267288), 'std': np.float32(1.1807834), 'num_experiments': 5}\n",
      "ant_0.0005_0.001_0\n",
      "{'fqe': {'agg': np.float64(49.791686630249025), 'std': np.float64(10.00766234897724), 'num_experiments': 5}, 'tis': {'agg': np.float64(2.2522686958312987), 'std': np.float64(0.42983725403074546), 'num_experiments': 5}, 'pdis': {'agg': np.float64(57.45420031547546), 'std': np.float64(22.142880016473327), 'num_experiments': 5}, 'dr': {'agg': np.float64(11.789376044273377), 'std': np.float64(6.8479453914446315), 'num_experiments': 5}, 'predictor': {'agg': np.float64(2.847022771835327), 'std': np.float64(0.5659056293386887), 'num_experiments': 5}}\n",
      "{'agg': np.float32(-1.6513754), 'std': np.float32(0.7744584), 'num_experiments': 5}\n",
      "reacher_0.0005_0.001_0\n",
      "{'fqe': {'agg': np.float64(60.60452728271484), 'std': np.float64(5.453302156308798), 'num_experiments': 5}, 'tis': {'agg': np.float64(14.040278244018555), 'std': np.float64(0.6414884843459895), 'num_experiments': 5}, 'pdis': {'agg': np.float64(56.297824668884275), 'std': np.float64(20.437640184304367), 'num_experiments': 5}, 'dr': {'agg': np.float64(38.51008644104004), 'std': np.float64(3.7078655644902114), 'num_experiments': 5}, 'predictor': {'agg': np.float64(13.01805305480957), 'std': np.float64(0.6452064607356353), 'num_experiments': 5}}\n",
      "{'agg': np.float32(-14.040278), 'std': np.float32(0.6414885), 'num_experiments': 5}\n",
      "reacher_0.0_0.001_0\n",
      "{'fqe': {'agg': np.float64(59.05248336791992), 'std': np.float64(6.28931568608232), 'num_experiments': 5}, 'tis': {'agg': np.float64(13.94307861328125), 'std': np.float64(0.4364667172189738), 'num_experiments': 5}, 'pdis': {'agg': np.float64(53.14870672225952), 'std': np.float64(30.53820360686368), 'num_experiments': 5}, 'dr': {'agg': np.float64(42.939784622192384), 'std': np.float64(6.630111776972534), 'num_experiments': 5}, 'predictor': {'agg': np.float64(12.923251342773437), 'std': np.float64(0.4453502104031009), 'num_experiments': 5}}\n",
      "{'agg': np.float32(-13.943079), 'std': np.float32(0.43646672), 'num_experiments': 5}\n",
      "halfcheetah_0.0_0.001_0\n",
      "{'fqe': {'agg': np.float64(28.147297382354736), 'std': np.float64(8.883781973592711), 'num_experiments': 4}, 'tis': {'agg': np.float64(3.180107283592224), 'std': np.float64(1.4702601160293678), 'num_experiments': 5}, 'pdis': {'agg': np.float64(2.5438591957092287), 'std': np.float64(0.8397674527900626), 'num_experiments': 5}, 'dr': {'agg': np.float64(6.2129194140434265), 'std': np.float64(1.8766369487192753), 'num_experiments': 4}, 'predictor': {'agg': np.float64(4.860826778411865), 'std': np.float64(1.9682472417766), 'num_experiments': 5}}\n",
      "{'agg': np.float32(-1.4742432), 'std': np.float32(2.0080814), 'num_experiments': 5}\n",
      "halfcheetah_0.0005_0.001_0\n",
      "{'fqe': {'agg': np.float64(24.883360958099367), 'std': np.float64(11.973212894002636), 'num_experiments': 5}, 'tis': {'agg': np.float64(3.3966276168823244), 'std': np.float64(1.2292762759310243), 'num_experiments': 5}, 'pdis': {'agg': np.float64(4.878611755371094), 'std': np.float64(1.8562500644470936), 'num_experiments': 5}, 'dr': {'agg': np.float64(6.648672699928284), 'std': np.float64(2.2427657236026177), 'num_experiments': 5}, 'predictor': {'agg': np.float64(3.458831858634949), 'std': np.float64(0.9417726485786724), 'num_experiments': 5}}\n",
      "{'agg': np.float32(1.6914333), 'std': np.float32(1.8373853), 'num_experiments': 5}\n",
      "ant_0.0_0.001_0\n",
      "{'fqe': {'agg': np.float64(55.976191711425784), 'std': np.float64(6.949204153666913), 'num_experiments': 5}, 'tis': {'agg': np.float64(2.538317084312439), 'std': np.float64(0.6215373042141926), 'num_experiments': 5}, 'pdis': {'agg': np.float64(62.3641637802124), 'std': np.float64(25.87864727699151), 'num_experiments': 5}, 'dr': {'agg': np.float64(10.19785442352295), 'std': np.float64(2.8608276024143633), 'num_experiments': 5}, 'predictor': {'agg': np.float64(3.036798083782196), 'std': np.float64(0.8955020693685077), 'num_experiments': 5}}\n",
      "{'agg': np.float32(-1.1267288), 'std': np.float32(1.1807834), 'num_experiments': 5}\n",
      "ant_0.0005_0.001_0\n",
      "{'fqe': {'agg': np.float64(49.791686630249025), 'std': np.float64(10.00766234897724), 'num_experiments': 5}, 'tis': {'agg': np.float64(2.2522686958312987), 'std': np.float64(0.42983725403074546), 'num_experiments': 5}, 'pdis': {'agg': np.float64(57.45420031547546), 'std': np.float64(22.142880016473327), 'num_experiments': 5}, 'dr': {'agg': np.float64(11.789376044273377), 'std': np.float64(6.8479453914446315), 'num_experiments': 5}, 'predictor': {'agg': np.float64(2.847022771835327), 'std': np.float64(0.5659056293386887), 'num_experiments': 5}}\n",
      "{'agg': np.float32(-1.6513754), 'std': np.float32(0.7744584), 'num_experiments': 5}\n",
      "reacher_0.0005_0.001_0\n",
      "{'fqe': {'agg': np.float64(60.60452728271484), 'std': np.float64(5.453302156308798), 'num_experiments': 5}, 'tis': {'agg': np.float64(14.040278244018555), 'std': np.float64(0.6414884843459895), 'num_experiments': 5}, 'pdis': {'agg': np.float64(56.297824668884275), 'std': np.float64(20.437640184304367), 'num_experiments': 5}, 'dr': {'agg': np.float64(38.51008644104004), 'std': np.float64(3.7078655644902114), 'num_experiments': 5}, 'predictor': {'agg': np.float64(13.01805305480957), 'std': np.float64(0.6452064607356353), 'num_experiments': 5}}\n",
      "{'agg': np.float32(-14.040278), 'std': np.float32(0.6414885), 'num_experiments': 5}\n",
      "reacher_0.0_0.001_0\n",
      "{'fqe': {'agg': np.float64(59.05248336791992), 'std': np.float64(6.28931568608232), 'num_experiments': 5}, 'tis': {'agg': np.float64(13.94307861328125), 'std': np.float64(0.4364667172189738), 'num_experiments': 5}, 'pdis': {'agg': np.float64(53.14870672225952), 'std': np.float64(30.53820360686368), 'num_experiments': 5}, 'dr': {'agg': np.float64(42.939784622192384), 'std': np.float64(6.630111776972534), 'num_experiments': 5}, 'predictor': {'agg': np.float64(12.923251342773437), 'std': np.float64(0.4453502104031009), 'num_experiments': 5}}\n",
      "{'agg': np.float32(-13.943079), 'std': np.float32(0.43646672), 'num_experiments': 5}\n"
     ]
    }
   ],
   "source": [
    "# Using pred_coef_groups, we will plot the variation  of the predictability gap as teh pred coef is increased\n",
    "# Similarly, we will plot the variation of the returns as the pred lr is changed for the same pred coef\n",
    "\n",
    "\n",
    "estimators = [\"fqe\", \"pdis\", \"dr\", \"predictor\"]          # <- fixed order\n",
    "colors = plt.cm.Set2.colors                              # pick 8 nice colours\n",
    "\n",
    "pc_mae_results = {}\n",
    "pc_return_results = {}\n",
    "\n",
    "for pred_lr_ in [0, 1e-4]:\n",
    "    for use_pretrained_transformer_ in [0, 1]:\n",
    "        if use_pretrained_transformer_ == 0:\n",
    "            pred_lr_ = 0.001\n",
    "        \n",
    "        for group_name in pred_coef_groups.keys():\n",
    "            env_name, pred_coef, pred_lr, use_pretrained_transformer = group_name.split(\"_\")\n",
    "            if pred_lr != str(pred_lr_) or use_pretrained_transformer != str(use_pretrained_transformer_):\n",
    "                continue\n",
    "            \n",
    "            group_mae = pred_coef_group_results[group_name]\n",
    "            group_return = pred_coef_group_return[group_name]\n",
    " \n",
    "            print(group_name)\n",
    "            print(group_mae)\n",
    "            print(group_return)\n",
    "        \n",
    "            "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1d231e37",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "env: ant, est: fqe, mu: 49.5594596862793, sd: 9.766071273343515\n",
      "env: ant, est: pdis, mu: 25.911211919784545, sd: 8.095369029925283\n",
      "env: ant, est: dr, mu: 10.653643369674683, sd: 4.510283265517769\n",
      "env: ant, idx: 1, beta: 0.0005, mu: 2.847022771835327, sd: 0.5659056293386887\n",
      "mean: 2.847022771835327, std error: 0.5659056293386887\n",
      "saved ./results/mae_ope_vs_evarl_ant.pdf\n",
      "env: halfcheetah, est: fqe, mu: 29.49739110469818, sd: 9.449392076127019\n",
      "env: halfcheetah, est: pdis, mu: 3.312802243232727, sd: 1.6110655694313782\n",
      "env: halfcheetah, est: dr, mu: 6.157284379005432, sd: 2.165156555040203\n",
      "env: halfcheetah, idx: 1, beta: 0.0005, mu: 3.458831858634949, sd: 0.9417726485786724\n",
      "mean: 3.458831858634949, std error: 0.9417726485786724\n",
      "saved ./results/mae_ope_vs_evarl_halfcheetah.pdf\n",
      "env: reacher, est: fqe, mu: 57.28392639160156, sd: 6.206050144364383\n",
      "env: reacher, est: pdis, mu: 51.32661008834839, sd: 37.366211808710474\n",
      "env: reacher, est: dr, mu: 32.330797004699704, sd: 5.95374927379034\n",
      "env: reacher, idx: 1, beta: 0.0005, mu: 13.01805305480957, sd: 0.6452064607356353\n",
      "mean: 13.01805305480957, std error: 0.6452064607356353\n",
      "saved ./results/mae_ope_vs_evarl_reacher.pdf\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjYAAAHSCAYAAAD/i4E8AAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAYNlJREFUeJzt3Xd0VNXax/HvlEwyKQRDQpHQISBglCaXagFFQZRipylYUAHvtV5U7GC5dlRUQPB67XRQuogQkBY6UgVNAiaQ0NIz5f0j7wyJmUBIJmWG32ctFidnl/PsmUny5Jx99jE4nU4nIiIiIn7AWNkBiIiIiHiLEhsRERHxG0psRERExG8osRERERG/ocRGRERE/IYSGxEREfEbSmxERETEbyixEREREb+hxEZERET8hhIbERER8Rvmyg7AX6SmnkYPp/AtBgPUqBGm905Eqiz9nMrneh1KQomNlzidXNAfOl+m905Eqjr9nCo5XYoSERERv6HERkRERPyGT16KSk9P56uvvuKnn37i0KFDpKenExERQYMGDbjiiisYNmwY1apV89hu2rRpLFmyhMTERIxGIw0bNqRPnz4MHjwYi8VSCaMRERERbzE4nb511e7XX3/lscce49ixYwAEBARgtVo5deqUu86cOXO45JJLCrVLSkpiyJAhJCUlAWC1WrHb7eTm5gLQsmVLpk+fTnh4eKniOnbswp7Y5YsMBoiMDNN7JyJVln5O5XO9DiXhU2dsNm3axAMPPEB2djbXXXcd999/P61bt8ZgMJCVlcW+fftYvnw5oaGhhdrZbDZGjhxJUlISUVFRvPHGG3Tu3BmHw8GiRYt49tln2bVrF0888QSffvppJY1OREREyspnEpusrCyeeuopsrOzGTJkCM8++2yhcqvVSmxsLLGxsUXazp49m7179wIwceJE2rRpA4DRaKR37944HA4ee+wxVq5cydq1a+nUqVP5D0hERES8zmcmD8+dO5eEhASioqJ44oknzqvtnDlzAOjYsaM7qSmoT58+REdHF6orIiIivsdnEhtXwnH99dcTGBhY4nZZWVnEx8cD0L17d491DAYD3bp1AyAuLq5sgYqIiEil8YlLUbm5uezYsQOAVq1acfjwYSZNmsQvv/xCamoq1apVIzY2ljvuuIOrrrqqUNsDBw7gcDgAaNasWbHHcJUdPXqUEydOUL16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QUhIyHkdJzAwwL1ttzvIy7MTEGDCZDqTO9psdmw2BxaLCaPxzP68PDt2uwOLxYzRmL+WjsXi92+NlIHZbHT/bzafmX/mjc8eQG6uDYfDSWCgudD6Tjk5eTidEBR05vMOkJ2dh8FQ+PvA6XSSk2PDaDQU+jw7HE5yc22YTEYCAkwF9jvIzbVrTBqTxuRhTIGBZrKz/WtM5/s+lZR+e3qJ680sKC/PTl6evUjd3Fw74Gm/zeO2yN/ZbA73/67tgsry2SsoJ8fz/uzsvCL7nE7P+x0Op8f9drsDu71o7BqTxgQak2tMBgOEhQW52/rDmP6uJGNyvQ4l4feXogqeecnOzi62XsHbdM/3bI2IiIhUDX6f2NSsWdO9nZycXGw9V1loaKgSGxERER/l94lNs2bN3Nt79+4ttp7r7qmmTZuWe0wiIiJSPvw+sWnUqBEXX3wxAKtWrfJYJzMzk40bNwLQpUuXCotNREREvMvvExuDwcDNN98MwI8//khiYmKROl9++SWZmZmYTCb69u1b0SGKiIiIl/hUYnPy5EnS0tLc/xyO/NnSWVlZhfb/fR2aESNGEBUVRVZWFg888AA7duwAIDc3l6+++or33nsPgNtuu03PiRIREfFhPnW7d//+/UlKSiqyf+rUqUydOrVQvddee839dVhYGB9//DEjRoxg//79DBw4kJCQEHJzc8nLy7/FrGvXrjz99NPlPwgREREpNz6V2JRF69at+eGHH5g8eTI///wzR44cwWq1EhsbS//+/Rk4cGChRYlERETE9/hUYvPTTz+VqX1kZCRjx45l7NixXopIREREqhKdohARERG/ocRGRERE/IYSGxEREfEbSmxERETEbyixEREREb+hxEZERET8hhIbERER8RtKbERERMRvKLERERERv6HERkRERPyGEhsRERHxG0psRERExG/41EMwRaqqY38d41hyKtnZOe59e3bsIygoEIDIWjWIrB1ZWeGJiFwwlNiIeMHM/85l8n8+K7Tv3hsfdG/f98RwHnhyREWHJSJywVFiI+IFA4fezJW9uhZbHlmrRgVGIyJy4VJiI+IFkbUjdalJRKQK0ORhERER8RtKbERERMRvKLERERERv6HERkRERPyGEhsRERHxG0psRERExG8osRERERG/ocRGRERE/IYSGxEREfEbSmxERETEbyixEREREb+hxEZE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DB06lJ49exIbG0vbtm3p168f77zzDmlpacUe95prrqF58+bMmjWL3NxcpkyZwk033cTll19Ou3btGDp0KL/88stZY8/Ozuajjz6id+/exMbG0qlTJ+677z73OkVn463YMzIyeO+99+jbty9t2rShefPmJCYmeiXGsqpXrx4NGzYEzv44EREpmV27drl/Fu7evfusdZ988kmaN2/OsGHDPJbn5uYyf/58IH+ttQ4dOlC3bl2OHTvGzz//7O3Qi+jevbt7259+PuhSlJ/766+/aNKkSYnrBwcHExkZSVpaGg6Ho9C1WU9GjhzpToICAwOxWq2cPHmS3377jd9++43Zs2czffr0s14vzszMZPDgwWzdupWAgAACAgJIT09n3bp1rF+/nldeeYVbbrmlSLsTJ05wzz33sGvXLiD/TJTNZuOXX35h1apVPPfcc2cdqzdiP3HiBAMGDODQoUMEBARgtVq9GqM3uG58dDgc5X4sEX/XsmVLmjVrxr59+5g7dy4tWrTwWC8zM5OlS5cCxa9mv3TpUk6cOEHDhg3dE/z79evHhx9+yIwZM+jZs2d5DMGt4E3R/vTzQWds/NCll16KwWAA4LXXXuPgwYMlbjtixAji4uKoU6cOkH9tNi4urtC/gjp06MBrr73GihUr2LZtG+vWrWPbtm1Mnz6d2NhYkpOTefzxx896zPfff5+//vqLDz/8kM2bN7N582YWLlzI5ZdfjtPpZPz48Zw+fbpIu2effZZdu3ZhsVh48cUXiY+PZ8OGDfz000/07NmTCRMmnPWsizdinzhxIhkZGe7YN2zYwMqVK6lRo4ZXYiyrhIQE/vjjDwCio6PL7TgiF5Kbb74ZgAULFhSbECxdupTMzEyCg4O57rrrPNZxXYZy9QdnkqBVq1Zx9OhRL0ZdVMFnJ9arV69cj1WRlNj4oejoaG699VYg/3LLDTfcQP/+/XnxxReZMWMGe/fuxVvLF73++uv079+/0O2CFouFTp06MX36dCIjI9m5cycbN24sto+srCymTZtGz549CQgIAKBx48ZMmjSJwMBAMjMz3XOGXLZt2+b+a+j555/njjvuIDAwEIC6devy3nvvERsbS1ZWVrnGnpOTw6effloo9tq1a2O1Wr0SY2nl5eWxbt06HnroIfe1+oEDB3r9OCL+okuXLmf998orr7jr3nTTTRiNRlJSUliz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v/ySzMxMJk+ezFNPPeWx3rme/t2iRYtCEyVF/EWXLl3OWWfixIlFlnho1qwZrVq1YufOne4lHoq7DOVKTiIjI+nQocM5j2cwGOjVqxfTpk1j3rx5PPbYY+6FQL1p5MiRPPzww2zZsoWff/6Zq666qkgd1++Csxk6dKj7wZqVSWds/FC3bt1YsmQJzzzzDNdffz1NmjTBYrFw6tQprFYrDRs25IYbbuCdd95hxowZHm9H7tChA5988gmdO3cmLCyM1NRUkpKSCv0CrlatGt988w3Dhg2jbt26mEwmTCYTV1xxBW+//TYvvfRSuY7zoosu4ptvvmH06NE0btwYg8GAyWSiW7duTJs2jUGDBhXbtqJiL0uM3hQVFeVeJPCrr74q96XaRXxNcXcaFfyXl5fnsW3Bu59CQ0M9Pnw4OzvbfdPCtddeW+I7Kl1ndlJTU4uswO4tPXr0cJ+lP9tZG19hcFa1+3BFRERESklnbERERMRvKLERERERv6HERkRERPyGEhsRERHxG0psRERExG8osRERERG/ocRGRERE/IYSGxEREfEbSmxERETEbyixEREREb+hh2CKiIhf2b9/P9OnT+fXX38lOTkZo9FI7dq16datGw899BARERGVHaKUIz0rSkRE/Mbs2bMZN26c+4GVwcHB5ObmYrPZAGjYsCFz584lKCioMsMsJD09nWnTprFkyRISExMxGo00bNiQPn36MHjwYCwWS6X2X9r2s2bNYuzYseeMb9q0aXTu3LlUY/NEiY2IiPiFrVu3cuedd2K32+nVqxePPfYYDRo0wG63M2/ePP79738D8OGHH9KzZ89KjjZfUlISQ4YMISkpCQCr1Yrdbic3NxeAli1bMn36dMLDwyul/7K0dyU2RqPxrGfJ3nvvPdq3b1+q8XnkFBER8QODBw92xsTEOO+++26nw+EoUt6rVy9nTEyM89tvv62E6IrKy8tz3njjjc6YmBhnly5dnHFxcU6n0+m02+3OH374wdmmTRtnTEyM87777quU/svafubMmc6YmBjn1VdfXar4S0uTh0VExOcdPnyY9evXAzBmzBgMBkOhcofDwcmTJwGoU6dOhcfnyezZs9m7dy8AEydOdF+OMRqN9O7dm5deegmAlStXsnbt2grvv7zjKy9KbERExOetW7cOgMjISC6//PIi5atXryYtLY2AgADatWtX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",
      "text/plain": [
       "<Figure size 600x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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yvbtW/n3vx8iMzODXr368swzz2MymXxdVr70eyqb++tQGDpiIyLiAxERdVkXteWCjwrwF2FhVf0m1AC0bt2GiRMnMXHieFau/A6bLYTHHnvK12WJlyjYiIj4SEREXb8KBEZy/fU38cgjj/Pmm6+xcOE32Gw2HnhgnK/LEi9QsBERkXJp8OChDB481NdliJfpdm8RERExDAUbERERMQwFGxERETEMBRsRERExDAUbERERMQwFGxERETEMBRsRERExDAUbERERMQwFGxERETEMBRsRERExDAUbERERMQwFGxERETEMBRsRERExDAUbERERMQyrrwsQESmvYmNjSExM8HUZxRYWVpWIiLpeH3fOnA+YO3dWnvWBgYFUqlSZpk2bccstfbjxxh6YTCbP9uXLlzJlygt5+tlsNkJCQgkPr0aTJk1p3boN119/Ezab7YJ1dO3aHoB//nMsY8bcm2e7y+VizZofWb16Jfv27eH06dNYLGaqVAmjatVwWrS4klat2tC+fQdCQytc6pdBLpGCjYiID8TGxtClSwfS0lJ9XUqx2WwhREVtLpFw4xYWVtWznJyczMmT8Zw8GU9U1FpWrFjKlClTCQwMzNOvcuXKmM0WALKysjh9OpGEhFPs3fsny5Yt5o03XuPOO0cwYsQ/sVov/U9iUlIS48c/xrZt0Z51FouF4OAKnDjxF8eOxfHHH9v56qvPefrp5+jTp38R9l4uhYKNiIgPJCYmkJaWymMvvk1Eg8a+LqfIYg8f4PUJ40hMTCjRYLNkyfeeZafTyZEjh5k+/Q02b97Ib7+tZ9asGTz44CN5+s2a9TG1atX2fO5yuYiJ+R/R0b+zcOE3HDx4gDlzPiA6eguvvz4933B0IS+9NJFt26KxWCzcdtsd3HrrIOrUicBsNmO32zly5DAbN65n9ervLz6YeIWCjYiID0U0aEzjK67ydRl+xWw207BhI1555Q1GjfoHsbExLF78Lffe++BFj7qYTCYuv7w+l19en/79B/Lee2/z1VefsXXr77z11n958slnCl1HTMxRoqLWAnD33fczYsRdubZbrVYaN25C48ZNGDZsFBkZ6Ze8r3LpdPGwiIj4paCgIG64oQcAqakpHD165JL6WywWHn7433Tu3BWA775bwtGj/yt0//3793mWu3W7rhD1Bl9SfVI0CjYiIuK3qlWr7llOSUkp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02bhwoXs27cPgOnTp9OmTRsAzGYzffr0wel08thjj/HLL7+wYcMGOnXq5JWaRUREpHQVKdjceeedbN261RNm6tSpw8CBAxk4cCB169b1aoFu+YWanIYMGcJXX30FwM6dO3MFm0WLFgHQsWNHT6jJqW/fvrz55pvExsayaNEiBRsRERE/VaRgEx0djclkYsCAAQwdOpT27dt7u65LFhQU5Fl2OBye5bS0NKKjowHo3r17vn1NJhPdunXjiy++ICoqqmQLFRERkRJTrIuHf/nlFypUqEBgYCCtWrXyVk1FkvOhm02bNvUsHzx4EKfTCUCTJk0K7O/edvLkSc6cOUPlypVLplAREREpMUUKNhMnTmTBggXs2rWLL774gi+++IL69eszcOBABgwYkOs0UGk4d+4cH3zwAQDt27enYcOGnm3x8fGe5Ro1ahQ4Rs5t8fHxhgo2xxMTOZ54mrTMTM+6bYcOY/v/29trhVWhVliYr8oTERHxmiJfY3PnnXeyZ88ez0zChw8f5q233mLatGl06NCByMhIbrnlFm/Xm4fT6eTJJ5/k5MmTBAUFMWHChFzbU1JSPMv53Qae37acfYxg1opVvPjF17nWXf/kM57lCXcMZeKwf5R2WSIiIl5XrFNRzZs359lnn+XJJ59k9erVzJ8/n99++42NGzeyadMmXnjhBU9b94XG3jZ58mTWrFkDZB9Jat68eYm8zsUEBQV4lh0OJ1lZDgICLFgs5++ot9sd2O1OAgMtmM3n12dlOXA4nAQGWjGbs2dkDgz03hRDY3vfQr+OHQrcXiusitdeKzDQSnBwQL77BJCZacfpdBEUZM01+3RGRhYuFwQHB+QaLz09C5Mp99fX5XKRkWHHbDbl+jo5nS4yM+1YLGYCAiw51jvJzHRgtZqxWs+vdziyT1FarUV/n8riPhX3e0/7pH3SPpW9fQoKspKebqx9utT3qbC88tczMDCQvn370rdvX+Li4liwYAGLFi3i2LFjnja33HILt9xyC7169aJDhw5eeaTCq6++yqeffgrA+PHjPfPZ5BQaGupZTktLK3CsnNty9iks95uZU1aWg6wsR562mZkOIL/19nyXi6tWWFipnWrKzLSTnp6V6/P8ZGTkvz5nXzeXK//1Tqcr3/UOh9MTWnKy253Y7efXu78F7faiv085lYV9civO915O2iftk/bJt/tkMkHFisGevkbYp78rzD65vw6F4fWne9epU4dx48bx448/MmfOHHr16oXVauXUqVN88cUXjBo1im7duvHiiy8W63Vee+01PvzwQwCeeuop7rrrrnzbVa9e3bN84sSJAsfLuS1nHxEREfEfXg82biaTiS5duvDWW2+xdu1axo8fT5MmTXC5XJw6dYrPP/+8yGO/+uqrzJkzB4AnnniC0aNHF9i2UaNGnsNq+/fvL7Cde1u1atUMdeGwiIhIeVJiwSanypUrM2rUKJYsWcI333zD0KFDi3S6B7JDjftIzRNPPMHdd999wfY2m422bdsCsHbt2nzbuFwu1q1bB0CXLl2KVJeIiIj4XqkEm5yuuuoqJk2aVKSJ8HKGmqeeeuqiocZt4MCBAGzcuJHt27fn2b5ixQpiYmJytRURERH/U6SLh3NeFFwctWvXLnTbnNfUjB8/vsBravITGRnJxx9/zL59+3j44Yd59dVX6dSpE06nk++//95zi3j37t31OAURERE/VqRgc+ONNxb7riaTycTu3bsL1fbYsWOea2rMZjOzZs1i1qxZBbYfPXo0Y8aM8XxutVqZMWMGI0eOJC4ujrvuugubzYbT6SQjIwOAFi1aMHXq1GLskYiIiPhakW/3Lql5afLjfiSCe/nUqVMXbJ+amppnXUREBEuWLOHDDz9k9erVxMbGYrVaady4Mf369WP48OEE/v9MvCIiIuKfihxsTCYTderUITIykg4dCp78zRsiIiLYu3dvscepUKEC48aNY9y4cV6oSkRERMqaIgWb7t27ExUVRWxsLO+88w5169Zl0KBBREZGXvB5TCIiIiIlqUh3Rc2cOZM1a9bw6KOPUq9ePY4ePcq0adO48cYbufvuu1mxYgWZOR64KCIiIlIainwqqnr16txzzz3cc889/P777yxYsICVK1eybt06oqKiuOyyy+jfvz+RkZFceeWV3qxZREREJF9emcemXbt2TJkyhaioKCZPnkzbtm05e/Ysn376KUOGDGHAgAF8/PHHnD592hsvJyIiIpIvr07QZ7PZGDx4MJ999hmrVq3i3nvvpUaNGuzbt4+XX375grdoi4iIiBRXic08fPnllzN48GD69etHQEDAxTuIiIiIFFORr7EpSFpaGitWrGDBggVER0cD2XPeNG3aVLP6ioiISInyWrDZsmULCxYs4PvvvyctLQ2X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EQAdO3akTZs2ebb37duXiIiIXG1Lc/ySrq+kKNiIiIjf++OPPwBo1apVnqM1iYmJvPzyywD079+fkJCQUq/v79LS0oiOjgage/fu+bYxmUx069YNgKioqFIdv6TrK0m63VtERPzerl27AGjZsqVnXUJCAj/++COzZs3i6NGj1KxZk3/9618+qjC3gwcP4nQ6AWjSpEmB7dzbTp48yZkzZ6hcuXKpjO/N+hITExk0aBCHDx/G4XBQrVo12rRpw2233UbHjh0LtT+XQsFGRET8msPhYO/evUB2sImJiaFv375kZGR42rRq1YqpU6dSo0aNi45X2NuUC/Lxxx9f9A92fHy8Z/lCNeXcFh8fX+hgU9zxvVlfWloau3btolKlSmRlZREbG0tsbCxLly5l0KBBvPjii1it3osjCjYiIuLXDh48SFpaGgBXXnklv/32W65QA3DkyBFWrVrF2LFjLzpecHAw4eHhRa4nICDgom1SUlI8yzabrcB2Obfl7FPS43ujvurVq/PQQw9x880307BhQwIDA3E4HGzfvp3p06ezfv16vv32W0JCQpgwYULhdqwQFGxERMSv7d69G8g+ehAeHk7fvn256aabiI+PZ8eOHXz22Wds3bqVqVOnYrVa+ec//3nB8fr06UOfPn1Ko3RD69q1K127ds21zmKx0LZtW+bMmcNDDz3Ejz/+yOeff86IESOoX7++V15XFw+LiIhf27lzJ3D++hqTyYTNZqNevXr079+fzz77jC5dugDw5Zdf+qzOnEJDQz3L7qNN+cm5LWefkh6/pOszm8089dRTQPat+GvWrCl034uO7bWRREREfMB9xObKK6/Md7vFYqFXr14AJCUllVpdF1K9enXP8okTJwpsl3Nbzj4lPX5J1wdQr149qlSpAkBMTMwl9b0QnYoSERG/5XQ6+fPPP4Hcd0T93alTpwCoWbPmRcdcvnw5kydPLnJN06dPp23bthds06hRI8xmM06nk/3793Pdddfl227//v0AVKtWrdAXDntj/JKuryTpiI2IiPitw4cPk5qaClw42Pzwww8AhXrYYnp6OqdOnSryh/sBnBdis9k84Wft2rX5tnG5XKxbtw7AcyqtsIo7fknXB3D06FFOnz4N4Jnozxt0xEZERPyWe/4agD///DPPxaoAy5YtY9euXVgsFm677baLjjlo0CAGDRrk1TrzM3DgQLZs2cLGjRvZvn07rVu3zrV9xYoVnlM0AwcOLPXxi9Pf5XLlmSjx79tfe+01IPt6m+uvv/4S965gOmIjIiJ+y319DcC///1vli1b5jlikpiYyMyZM3n22WcBGDNmDPXq1fNJnfmJjIykadOmuFwuHn74Yc/zlpxOJytWrPDcAt29e3c6deqUp/+3335Ls2bNaNasmeeREt4cvzj94+LiGDJkCF9++SUxMTG4XC5P323btnH33XezevVqAG6//XYaNmx46V/AAphc7lcTERHxMyNGjGDTpk2YTCbPH0+LxYLNZiM5OdnTbtiwYTz77LOYzWXr//nY2FhGjhxJXFwckH0KyOl0eubhadGiBfPmzaNSpUp5+uacSLCgSQGLM35x+sfGxnLTTTd5Pg8MDCQ0NJSUlBQyMzM96zVBn4iIyP9zuVyeIzaTJk1i69atrF+/noSEBOx2O/Xq1aNt27YMHTr0ohfz+kpERARLlizhww8/ZPXq1cTGxmK1WmncuDH9+vVj+PDhBAYG+mz8ovYPDw9nwoQJbN26lT179pCYmMi5c+cIDAwkIiKCNm3aMHjw4BJ5IKmO2IiIiF86cuQIPXv2BLIvcL3U243FmMrWMTkREZFCch+tqVatmkKNeCjYiIiIX3LPOHzFFVf4uBIpSxRsRETEL7mP2LRo0cLHlUhZomAjIiJ+yR1sdMRGctLFwyIiImIYOmIjIiIihqFgIyIiIoahYCMiIiKGoWAjIiIihqFgIyIiIoahYCMiIiKGoWAjIiIihqFgIyIiIoahYCMiIiKGoWAjIiIihqFgIyIiIobxf9oZSks4FwUDAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 600x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjYAAAHSCAYAAAD/i4E8AAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAWDZJREFUeJzt3XdcleX/x/HXGYwDKIbiSFTcpqZpmjkbWu5yZMtVWn1taMOWlQ3LyrKs7JvfhmJ7qbgKV5kpmiMcuc2RgAUKLjacc35/8OMIAYpwGOfm/Xw8fHh7X/d13Z8bEN7c47pNTqfTiYiIiIgBmMu7ABERERF3UbARERERw1CwEREREcNQsBERERHDULARERERw1CwEREREcNQsBERERHDULARERERw1CwEREREcNQsBERERHDsJZ3AUaRkHAWvZzCs5hMUL16FX3uRKTC0vepbDkfh6JQsHETp5NK/UXnyfS5E5GKTt+nik6XokRERMQwFGxERETEMBRsRERExDAUbERERMQwFGxERETEMBRsRERExDAUbERERMQwFGxERETEMBRsRERExDAUbERERMQwFGxERETEMBRsRERExDAUbERERMQwFGxERETEMKzlXYBIQeLi/iEu7p9C22vVqk2tWrXLsCIREfEECjZSIX366RymT3+90PbHH3+aJ598pgwrEhERT6BgIxXS6NFj6NOnH6mpqQwc2BuAJUuWY7PZAHS2RkRECqRgIxVSzqWm5ORk17rWrdvg7+9fjlWJiEhFp5uHRURExDAUbERERMQwdClKRKScxMREk5iYUN5llFhQUHVCQuq5fdzZsz8kLOzjIm27bt2WAtfv37+XiIgfiIrawvHj8aSmplC1aiChoQ25+uquDBw4iICAgELH/fHHJbz66ktFrvn77xdTp86lRd5e3E/BRkSkHMTERNOtawdSUlPLu5QS87PZWBe5pVTCTY6goOoXtX16ehrTp7/OsmU/4HQ6AbBarfj62khMTCAh4QS//76ZL74I47HHnqJnzxsvOGa1atUwmy3n3cZs1oWQ8qZgIyJSDhITE0hJTeXTiQ/Tol5IeZdTbHujYxj91rskJiaUarBZvHh5kbdNS0tjwoRx7N69E4Abb+zLrbfeQfPml2EymUhLS+O33yL55JMPOXLkEC+++CynTp1i6NBbzzvuxx9/prMxHkDBRkSkHLWoF0L7Jo3LuwxDefvtaa5Q8/jjkxg0aGiedl9fX669tiedO3fl6acnsnnzRt577y2aN29B69ZtyqNkcSOdMxMREcM4ePBPfvxxCQD9+g3MF2py8/Hx5cUXp3LJJUHY7Xb++993y6pMKUUKNiIiYhjh4d8D2fe63HXXPRfcPjCwGkOGDAPgjz+2c+DAvlKtT0qfgo2IiBjG779vBqBp0+ZcemndIvW55prr8vUXz6V7bEREpMK76abehba9884HNGrUmKysLKKjjwLQrFnzIo8dGtoILy8vMjMzOXjwz0K3u/feUed9Kqp16za8+uqbRd6vlA4FGxERqfDON9+P3Z4FwJkzp13rqlYNLPLYZrOZKlWqkpiYwOnTpwvd7tSpU+cdJ/f+pfwo2IiISIVX2AR87paZmVFomybf8wy6x0ZERAwh91maizl74nA4OHv2DABVqlR1e11SthRsRETEEKxWKyEh9QHYt29vkfsdPnyIzMxMAOrXb1AqtUnZUbARERHD6NChIwAHDuzj2LHYIvVZs+Zn13K7dleWSl1SdhRsRETEMAYNugUAp9PJ3LmfXHD706dPsWBB9tw3depcyhVXtC/V+qT0KdiIiIhhNGnSlL59BwDZb+ZeuHB+odump6f//3uiTgIwdux/sFjO/5JLqfgUbERExFAee+wpWrRoCcD06a/x8suT2bt3j+st3+npaaxZ8zP33DOSzZs3AtmvX+jTp3+51Szuo8e9RUTEUGw2GzNnfsgbb0xl5cplLF8ewfLlEVitVmw2P5KSzrpCjslk4tZb7+CBBx6+4LgXmqAP4OGHJ9Kz541uOQ4pHgUbERExHJvNxgsvvMJttw1n2bKlREVtIT4+3vVYd84277wzi1atWhdpzAtN0AfZl7ekfCnYiIiUo73RMeVdQomUZv1jx/6HsWP/U6IxWrS4jBYtLsuzbvv2rTz66EOkpqYSHv49LVu2wmQyFdi/X7+B9Os3sEQ1SNlSsBERKQdBQdXxs9kY/da75V1KifnZbAQFVS/vMoqsbdt2PP/8FJ5/fhLLlv2AzebHxIlPlXdZ4iYKNiIi5SAkpB7rIrec9x1IniIoqDohIfXKu4yLcu21PXn44ceZMeMNwsO/x2az8cADE8q7LHEDkzPnDiopkRMnzqKPpPslJyfTsGEdAA4f/ht/f3+3jW0yQY0aVfS5E5EKS9+nsuV8HIrC487YREZG8t1337Fjxw5OnDiByWQiODiYK664gttuu42rrrqq0L5JSUmEhYWxYsUKYmJiMJvNhIaG0r9/f0aMGIG3t3cZHomIiIi4m8ecsXE6nbzwwgt8++23rnW+vr4ApKWludbdddddTJo0KV//2NhYRo4cSWxs9hTbNpsNu91ORkb2m1xbtmzJ3LlzCQws+qvuc6vsabq06IyNiFRm+j6V7WLO2HjMBH0LFixwhZrevXuzfPlytm/fzvbt24mIiKBnz54AzJ07l5UrV+bpm5WVxbhx44iNjSU4OJiwsDC2bdvG9u3bmTFjBv7+/uzevZsnnniizI9LRERE3Mdjgs3ChQsBaNCgAW+//TahoaGutkaNGvHuu+9Sr172zWsRERF5+oaHh7N//34AZs6cSZcuXQAwm83069ePKVOmALBmzRo2bNhQykciIiIipcVjgs3x48cBaNGiBVZr/luDvLy8uOyy7LkKUlJS8rTlhKJOnTrRrl27fH379+9PSEhInm1FRETE83hMsMk5G7N3716ysrLytWdmZrJnzx4AWrc+N4tkamoqUVFRAPTo0aPAsU0mE927dweyb04WERERz+QxweaOO+4A4K+//uKxxx7jr7/+crUdOnSIRx55hOjoaOrXr89dd93lajt48CAOhwOApk2bFjp+Ttvx48eLNG22iIiIVDwe87j39ddfz6RJk5g+fTrLly9n+fLleZ6Kqlq1KnfccQePPPIIAQEBrn7x8fGu5Vq1ahU6fu62+Ph4qlWr5v6DEBERkVLlMWdsIPtR7vfff5/q1bOn7k5LS3M96p2ZmUlKSgpnz57N0yc5Odm1bLPZCh07d1vuPiIiIuI5POaMTWpqKpMmTSIiIoLWrVvz5ptvum4W3rNnD2+//TaLFi3i119/Ze7cubRo0aJM6/Px8XIt2+0OMjPteHlZsFjOZcesLDtZWQ68vS2YzefWZ2basdsdeHtbMZvPvYgtIyMLh8OJj481zwva0tMzcTrB1/fcPgHS0jIxmfLW4nQ6SU/Pwmw24e197tPtcDjJyMjCYjHj5WXJtd5BRoYdq9WM1XpufXkdU+6M6evrha+vl1uPCcBq1edJx6Rj0jFV7GPy8bGSlmasY7rYz1NRecwEfS+99BJfffUVDRs2ZNGiRfj4+ORpT0tL4+abb+bIkSNceeWVfPXVVwD8/PPP3H///QAsWrSo0MCzatUqHnzwQQCWLFlCs2bNLqq+yj55UmnRBH0iUpnp+1Q2w03Ql5SUxHfffQfA8OHD84UayJ6FeMSIEQD8/vvvJCRkv1iuZs2arm3i4uIK3Ufuttx9RERExHN4RLA5cuSI6xHv+vXrF7pdgwYNXMsxMTEANG7c2HVa7cCBA4X2zWkLDg7WjcMiIiIeyiOCTe7rfTnveipIzlkawHXJwmaz0b59ewDWrl1bYD+n08m6desA6Nq1a4nrFRERkfLhEcGmUaNGrke7582bV+AEfXa73fUuqcDAQBo2bOhqGzRoEAAbN25k+/bt+fpGREQQHR2dZ1sRERHxPB7xVJSvry/Dhg3j888/Z9euXYwbN44nnnjCNane/v37efPNN9m6dSsAo0aNwmI5dyf14MGD+eyzz9i/fz/jx49n2rRpdO7cGYfDwfLly5k8eTKQPTNx586dy/4ARaRSiomJJjEx4cIbVnBBQdUJCann9nFnz/6QsLCP86339vYmMLAazZo158Yb+3H99b3yPJnz449LePXVl/L1s9ls+Pn5U6NGME2bNqNt23Zce23P804FAtCtWwcA7r77XsaO/U++dqfTyerVP7Fy5TL279/LyZMnsVjMXHJJENWr16Bly1a0adOODh064u8fkK+/uJdHBBuAxx9/nCNHjrB27VrXH29vbwAyMjJc2w0YMMD1FFQOq9XKrFmzGDVqFLGxsdx1113YbDYcDgfp6ekAtGzZkunTp5fdAYlIpRYTE03Xrh1JTU258MYVnM3mR2Tk5lIJNzmCgqq7lpOSkjh+PJ7jx+OJjFxLRMQSXn11uutnQm7VqlXDbM7+RTczM5OTJxNJSDjBvn17WLp0EW+//QZ33jmSkSPvLvA9hBdy9uxZJk2ayLZtUa51FosFX98A4uL+4dixWP74YzvffvsVzzzzAv36DSzG0cvF8Jhg4+vry8cff8zy5ctZvHgxu3btIiEhAZPJRJ06dWjTpg1Dhgzh2muvLbB/SEgIixcvZs6cOaxcuZKYmBisVitNmjRhwIABjBgxosD/FCIipSExMYHU1BQmvvweIQ2blHc5xRZz+E/emjyBxMSEUg02ixcvdy07HA6OHDnMzJlvs3nzRn77bT0ffzyLBx98OF+/jz/+jDp1LnX92+l0Eh39F1FRvxMe/j0HD/7J7NkfEhW1hbfemnnRPwdeeeV5tm2LwmKxMGzYHdx88xDq1g3BbDaTlZXFkSOH2bhxPStXLr/wYOIWHhNsIPtllX369KFPnz7F6h8QEMCECROYMGGCmysTESmekIZNaHLZ5eVdhkcxm800atSY119/m9GjbycmJppFixbwn/88eMGzLiaTifr1Q6lfP5SBAwfxwQfv8e23X7J16++8886bPPnks0WuIzr6KJGR2Q+l3HPP/YwceVee9uxfnpvSpElThg8fTXp62kUfq1w8j7h5WERE5N98fHy47rpeAKSkJHP06JGL6m+xWBg//lG6dOkGwA8/LObo0b8u0OucAwf2u5a7d7+mCPX6XlR9UjwKNiIi4rGCg89NqFrc9/yNGXMfkP107YoVEcUa4/jxwieAlbKlYCMiIh7rn3+OuZarVg0s1hgtWrTkkkuCAPLcBHwhl13W0vU01vvvv3NRZ3uk9CjYiIiIR0pOTmLFimVAdqipV6/wmekvpEmT7OlDYmNjitynTp1LGTBgEAAHD/7J8OG3MGbMcN56axpLly7i0KE/8ZDXMRqKR908LCIicvbsWfbt28OsWTM5ceI4AMOG3Z5nlvqLVbVqVQDOnDl9Uf0mTnyK6tWr8+23X5Kamsr+/fvYv3+fq/2SS4K48cY+DB8+Os8j61J6FGxERKTCy5kkryC9e/dl1KgxZVjNOVarlXvuGcftt48gMvJXtm2LYs+e3fz112HXvDnffvsVy5f/yBtvvEPLlq3Lpc7KRMFGREQqvNxnO7y8vHLNPNyX9u0LDz1FdebMGQACA6sVq39AQAC9e/ejd+9+AKSnp7NjxzbmzfuGyMi1nDp1iueee4qvv16Aj49PieuVwinYiIhIhZd7gr7ScPDgnwBcemldt4zn4+NDx46d6NixE1OnvkhExFLi4+PYuHEDPXpc65Z9SMF087CIiFRqe/fudr2zq127K90+/k03DXYtX+xcO3LxFGxERKRSmzMn+0WbFovFdSnJnWw2P9eyXt1T+hRsRESkUrLb7cycOYP167NfizBw4KCLet/VsWOxRZq7JiJiqWu5WbMWF1+oXBTdYyMiIpWG0+kkJiaaqKgtLFjwPQcPHgDgyiuv4uGHH7+osQ4fPsSkSRPp1Kkz119/A1dc0d71ws2srCwOHfqTefO+5ccflwBw2WWtaNPmCrcej+SnYCMiIoZ1772jMJstQHbYSE5Owm63u9r9/PwZPnwUw4ePvuALNP/NarXicDjYsCGSDRsigewntmw2P86ePZNncr5mzVrw2mvTSzTXjhSNgo2ISDmKOfxneZdQIhW9/lOnTrmWfX19qVatGjVq1KRp02a0bduOa6/tic1mK9bYnTp15ptvwtmwIZIdO7Zx+PBB4uPjSUo6i6+vL9WrB9OsWXOuueY6rruul0JNGTE5Nd+zW5w4cRZ9JN0vOTmZhg3rAHD48N/4+/u7bWyTCWrUqKLPnZSLmJhounbtSGpqSnmXUmI2mx+RkZsv6v4UKRp9n8qW83EoCp2xEREpByEh9YiM3Ox6zNiTBQVVV6iRCkPBRkSknISE1FMgEHEzXfATERERw1CwEREREcNQsBERERHDULARERERw1CwEREREcNQsBERERHDULARERERw1CwEREREcNQsBERERHDULARERERw1CwEREREcNQsBERERHDULARERERw1CwEREREcNQsBERERHDsJZ3ASIilVVMTDSJiQnlXUaJBQVVJySkntvHnT37Q8LCPs6zzmQyYbP54e/vT61atWnatDnt219Jt27X4OXlVeA4f/99jGHDbsq33mw24+fnR9269bjyyo4MGXIrtWvXdvtxSNlSsBERKQcxMdF07daB1JTU8i6lxGx+NiLXbSmVcJMjKKi6azk9PY0TJ45z/Hg8O3fuIDz8ewIDA7n33vsZNOiW847j7++Pj48vAFlZWZw5c5p9+/awb98ewsPnMWXKa3Tu3LXUjkNKn4KNiEg5SExMIDUllZdnPU/DpqHlXU6xHT5whMn3TyExMaFUg83ixcvz/Ntut3PkyGE2b/6N+fO/5++/Y5k+/XW2b9/G88+/jMlkKnCchx9+nH79Brr+nZaWxs8/r+S9994mKeksL730LN99t4iqVQNL7VikdCnYiIiUo4ZNQ2nRtnl5l+FxLBYLjRs3oXHjJgwadAuvvTaFn35awcqVy2jUqDEjR95dpHF8fX3p128gZrOZV155gaSkJFav/ombbx5SykcgpUU3D4uIiEfz9fXluedeolmz7ID4xRdzOXPm9EWN0alTF9fy4cOH3FqflC0FGxER8XheXl6uszTJycn8+usvFzmC07XkcNjdV5iUOQUbERExhE6dumCxWADYti3qovr+9tt61/Kll9Z1a11SthRsRETE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NXkCCQkJCjYiIgahYFMJ3Nv3RgZ06lhoe50g912KCWnYhCaXXe628dJSU1zLjVu0wtfm57axRUTEeBRsKoE6QUElvtQkIiLiCTSPjYiIiBiGgo2IiIgYRrEvRZ0+fZpRo0blW3/q1CmAAtv+vY2IiIiIOxU72GRlZbFp06ZC2wtrM5lMOJ1OTCZTcXctIiIiUqBiBZuOHQt/wkZERESkvBQr2Hz++efurkNERESkxHTzsIiIiBhGuQQbu93OqlWrymPXIiIiYmBlOkHfwYMHmTdvHkuWLCExMZHdu3eX5e5FRETE4Eo92KSkpPDDDz8wf/58tm/fDqCnokRERKRUlFqw+f3335k/fz7Lli0jNTUVp9MJwKWXXkrv3r3p27dvae1aREREKim3BpuEhATCw8OZP38+R44cAc6dnRk1ahT9+/enbdu27tyliIiIiEuJg43D4eCXX35h3rx5/Prrr9jtdpxOJz4+PvTq1YsffvgBgEcffRSbzVbigkVEREQKU+xgc+TIEebNm8fChQtJSEhwXWpq3749gwcPpm/fvgQEBLiCjYiIiEhpK1awufPOO9m6dasrzNStW5dBgwYxaNAg6tWr59YCRURERIqqWMEmKioKk8nETTfdxK233kqHDh3cXZeIiIjIRSvRPTZr1qwhICAAb29v2rRp466aRERERIqlWDMPP//887Rs2ZLTp0/z9ddfc9ttt9G3b18+/PBD/v77b3fXKCIiIlIkxQo2d955J/Pnz2fhwoUMHz6cqlWrcvjwYd555x169uzJ6NGjWbhwISkpKe6uV0RERKRQJXpXVIsWLXjuuedYu3Ytb731FldffTVOp5ONGzcyadIkunbt6to250ZjERERkdLilpdgent7079/f8LCwli1ahUPPPAAderUITU11bXNjTfeyJQpU9i0aZNCjoiIiJQKt7/du27dukyYMIGffvqJ2bNn06dPH6xWKydOnODrr79m9OjRdO/enZdfftnduxYREZFKzu3BJofJZKJr16688847rF27lkmTJtG0aVOcTicnTpzgq6++Kq1di4iISCVVasEmt2rVqjF69GgWL17M999/z6233oq/v39Z7FpEREQqkVJ7u3dhLr/8ci6//HKeffbZst61iIiIGFyxgs2xY8fcsvNLL73ULeOIiIiIQDGDzfXXX4/JZCrRjk0mE7t37y7R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IiJiGAo2IiIiYhgKNiIiImIYCjYiIiJiGAo2IiIiYhgKNiIiImIYCjYiIiJiGAo2IiIiYhgKNiIiImIYCjYiIiJiGAo2IiIiYhgKNiIiImIYCjYiIiJiGAo2IiIiYhgKNiIiImIY1vIuQKS8HTiwz21jpaamupZ37tyBzWZz29g5goKqExJSz+3jiogYgYKNVFonT8RjNpu5//57S2X8gQN7l8q4Nj8bkeu2KNyIiBRAwUYqraSzZ3A4HLw863kaNg11y5hpqencM/B+AD5ZMgtfm49bxs1x+MARJt8/hcTEBAUbEZECKNhIpdewaSgt2jZ3y1ipyecuRTW/vCk2f/dfihIRkcLp5mERERExDAUbERERMQwFGxERETEMBRsRERExDAUbERERMQwFGxERETEMBRsRERExDAUbERERMQwFGxERETEMBRsRERExDAUbERERMQwFGxERETEMBRsRERExDAUbERERMQwFGxERETEMBRsRERExDAUbERERMQwFGxERETEMBRsRERExDAUbERERMQxreRcgYgQn/jnBibgE0tLSXev27TyAr68PADVqVadG7RrlVZ6ISKWhYCPiBvM/W8THb87Js+6eAfe7lu99Ygz/eXJsWZclIlLpKNiIuMHQUTdzTe9uhbbXqFW9DKsREam8FGxE3KBG7Rq61CQiUgHo5mERERExDAUbERERMQwFGxERETEMBRsRERExDAUbERERMQwFGxERETEMBRsRERExDAUbERERMQwFGxERETEMBRsRERExDAUbERERMQwFGxERETEMBRsRERExDAUbERERMQwFGxERETEMa3kXUFQnT57k559/ZsOGDezevZtjx46RlZVFUFAQrVu3ZvDgwdxwww3nHSMpKYmwsDBWrFhBTEwMZrOZ0NBQ+vfvz4gRI/D29i6joxEREZHS4DHBplu3bmRlZbn+7ePjg5eXF3FxccTFxfHTTz/Ro0cP3nvvPWw2W77+sbGxjBw5ktjYWABsNhsZGRns3LmTnTt3smTJEubOnUtgYGCZHZOIiIi4l8dcisrKyqJNmza88MILrFq1ih07drB161Z++uknbrnlFgB+/fVXnn/++QL7jhs3jtjYWIKDgwkLC2Pbtm1s376dGTNm4O/vz+7du3niiSfK+rBERETEjTwm2Hz66ad8//333HnnndSrV8+1PiQkhKlTp3LbbbcBsHjxYv7+++88fcPDw9m/fz8AM2fOpEuXLgCYzWb69evHlClTAFizZg0bNmwoi8MRERGRUuAxwebqq68+b3vOWRuAnTt35mlbuHAhAJ06daJdu3b5+vbv35+QkJA824qIiIjn8ZhgcyE+Pj6uZbvd7lpOTU0lKioKgB49ehTY12Qy0b17dwAiIyNLsUoREREpTYYJNps2bXItN2vWzLV88OBBHA4HAE2bNi20f07b8ePHOXXqVOkUKSIiIqXKEMHmzJkzfPjhhwB06NCBRo0audri4+Ndy7Vq1Sp0jNxtufuIiIiI5/CYx70L43A4ePLJJzl+/Dg+Pj5Mnjw5T3tycrJruaDHwAtqy92nqHx8vFzLdruDzEw7Xl4WLJZz2TEry05WlgNvbwtm87n1mZl27HYH3t5WzGYTAN7eHv+pkVJktZpdf1utFtd6d3ztAWRkZOFwOPHxsWIynVufnp6J0wm+vue+3gHS0jIxmfL+P3A6naSnZ2E2m/J8PTscTjIysrBYzHh5WXKtd5CRYdcx6Zh0TAUck4+PlbQ0Yx3TxX6eisrjf3pOnTqV1atXA/D888/TokWLcqkj55OZW2amncxMe75tMzLsQEHrswpcFvm3rCyH6++c5dxK8rWXW3p6wevT0jLzrXM6C17vcDgLXG+3O7Db89euY9IxgY4p55hMJqhSxdfV1wjH9G9FOaacj0NRePSlqGnTpvHFF18AMGnSpDxPRuXw9/d3LaemphY6Vu623H1ERETEc3hssHnjjTeYM2cOAE899RR33XVXgdvVrFnTtRwXF1foeLnbcvcRERERz+GRwWbatGnMnj0bgCeeeIIxY8YUum3jxo1d1wsPHDhQ6HY5bcHBwVSrVs19xYqIiEiZ8bhgM23aNNeZmieeeIJ77rnnvNvbbDbat28PwNq1awvcxul0sm7dOgC6du3qxmpFRESkLHlUsMkdap566qkLhpocgwYNAmDjxo1s3749X3tERATR0dF5thURERHP4zHBJvc9NZMmTTrv5ad/Gzx4MM2aNcPpdDJ+/HjX+6AcDgcRERGuR8R79OhB586d3V+8iIiIlAmPeNz72LFjrntqzGYzH3/8MR9//HGh248ZM4axY8e6/m21Wpk1axajRo0iNjaWu+66C5vNhsPhID09HYCWLVsyffr00j0QERERKVUeEWxyXomQs3zixInzbp+SkpJvXUhICIsXL2bOnDmsXLmSmJgYrFYrTZo0YcCAAYwYMQJvb2+31y4iIiJlxyOCTUhICPv27SvxOAEBAUyYMIEJEya4oSoRERGpaDzmHhsRERGRC1GwEREREcNQsBERERHDULARERERw1CwEREREcNQsBERERHDULARERERw1CwEREREcNQsBERERHDULARERERw1CwEREREcNQsBERERHDULARERERw/CIt3tL5ZN4PI7EE/FkpKe51h3atwtvH18AgmrUJCi4VnmVJyIiFZSCjVRIyxZ8ydcfzciz7qmxQ1zLd9z3KHf+57GyLktEpNTFxf1DXNw/rn9fcok/J08mu/5dq1ZtatWqXR6leQQFG6mQ+gwZzlU9bii0PahGzTKsRkSk7Hz66RymT3+90PbHH3+aJ598pgwr8iwKNlIhBQXX0qUmEamURo8eQ58+/UhNTWXgwN4ALF26HF9fG4DO1lyAgo2IiFQaMTHRJCYmlHcZF83pPLf870tVFU1QUHVCQuqV2/4VbEREpFKIiYmmW5f2pKSll3cpFy3nzI0n8PP1Yd36qHILNwo2IiJSKSQmJpCSls4Xg21cFlzxZztJzXTSLSwFgHV3+2HzMpVzRRe257iDEeGpJCYmKNiIiIiUhcuCzbSvYynvMgr191kHfyc5C22vE2CiTpWKH8zKi4KNiIhIBfLh7xm8tCYjz7qcMzcAL1zjzYvX+pZ1WR5DwUZERKQC+c+V3tzU3KvQ9joBFf+SVHlSsBEREalA6lQxU6dKeVfhuXSRTkRERAxDwUZEREQMQ8FGREREDEPBRkRERAxDwUZEREQMQ8FGREREDEPBRkRERAxDwUZEREQMQ8FGREREDEPBRkRERAxDwUZEREQMQ8FGREREDEPBRkRERAxDwUZEREQMQ8FGREREDEPBRkRERAxDwUZEREQMQ8FGREREDEPBRkRERAxDwUZEREQMQ8FGREREDEPBRkRERAxDwUZEREQMQ8FGREREDEPBRkRERAxDwUZEREQMQ8FGREREDEPBRkRERAxDwUZEREQMQ8FGREREDEPBRkRERAxDwUZEREQMQ8FGREREDEPBRkRERAxDwUZEREQMQ8FGREREDEPBRkRERAxDwUZEREQMQ8FGREREDMNa3gWUtaSkJMLCwlixYgUxMTGYzWZCQ0Pp378/I0aM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f//7X+bNm0evXr1K4xBccj8UbaTvDzpjY0CXX345JpMJgNdff53Dhw8Xue/YsWOJjIykTp06QPa12cjIyDx/cuvYsSOvv/46q1evZseOHWzcuJEdO3Ywd+5c2rRpQ1xcHI8//vh59/nee+/xzz//8N///petW7eydetWIiIiuOKKK3A6nUydOpWzZ8/m6/fcc8+xe/duvL29eemll4iKimLz5s38/PPP9OrVi1dfffW8Z13cUfvMmTNJTk521b5582bWrFlD9erV3VJjSUVHR/PXX38BEBISUmr7EalMbr75ZgCWLl1aaCBYuXIlKSkp+Pn5ceONNxa4Tc5lqJzx4FwIWrt2LcePH3dj1fnlfndivXr1SnVfZUnBxoBCQkIYNmwYkH25pW/fvgwePJiXXnqJefPmsX//ftw1fdG0adMYPHhwnscFvb296dy5M3PnzqVGjRrs2rWLLVu2FDpGamoqYWFh9OrVCy8vLwAaNWrErFmz8PHxISUlxXXPUI4dO3a4fht64YUXuP322/Hx8QGgbt26vPvuu7Rp04bU1NRSrT09PZ2PPvooT+21a9fGZrO5pcbiyszMZOPGjTzwwAOua/VDhw51+35EjKJr167n/fPKK6+4tr3pppswm83Ex8ezfv36AsdbvHgxAL169cLf3z9fe0xMDBs2bMBkMuUJNvXr16d9+/ZkZWURHh7u5qPMlpqaSnh4OFOnTgWyv+/179+/VPZVHnQpyqBeeOEFatSowdy5c0lJSWH37t2uyyEA1atXZ+DAgdx7772l9pijv78/HTt2JCIigqioKDp06FDgdr179y7wcllQUBBXXHEFGzduzDd/xA8//ABAnTp1CvyBbbFYeOCBBxg7dmyp1t69e3datmxZYFtp15jbjz/+6Prty+l0curUKex2u6t95MiRpX5aW8STnThx4rztSUlJruVatWpx9dVXs379ehYtWkS3bt3ybBsfH++6hy53aMltwYIFOJ1OrrrqKurWrZunbfDgwURFRTF//nzuu+++4hxOHlOnTuWtt94Czj3uncPLy4tp06ZRs2bNEu+nolCwMSir1crDDz/MmDFj+Pnnn9m8eTN//PEHBw8eJDMzk4SEBObOncuiRYv46KOPaNOmTbH3tXr1ahYtWsQff/xBQkJCgWcg/vnnn0L7t23bttC2nP9sp0+fzrN+586dAFx1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MQwFGxERETEMBRsRERExDAUbERERMQy9BFNERAzlzz//ZO7cufz222/ExcVhNpupXbs23bt354EHHiAoKKi8S5RSpHdFiYiIYYSHhzN58mTXCyv9/PzIyMggKysLgNDQUBYtWoSvr295lplHUlISYWFhrFixgpiYGMxmM6GhofTv358RI0bg7e1druMXt/+CBQuYNGnSBesLCwujS5cuxTq2gijYiIiIIWzfvp077rgDu91O7969mThxIg0aNMBut7N48WKefvppAP773//Sq1evcq42W2xsLCNHjiQ2NhYAm82G3W4nIyMDgJYtWzJ37lwCAwPLZfyS9M8JNmaz+bxnyd599106dOhQrOMrkFNERMQARowY4WzWrJnzrrvucjocjnztvXv3djZr1sz57bfflkN1+WVmZjoHDBjgbNasmbNr167OyMhIp9PpdNrtducPP/zgbNeunbNZs2bOe++9t1zGL2n/+fPnO5s1a+a87rrrilV/cenmYRER8XjHjh1j06ZNAEyYMAGTyZSn3eFwcPr0aQDq1KlT5vUVJDw8nP379wMwc+ZM1+UYs9lMv379mDJlCgBr1qxhw4YNZT5+addXWhRsRETE423cuBGAGjVqcMUVV+RrX7duHYmJiXh5eXHllVeWcXUFW7hwIQCdOnWiXbt2+dr79+9PSEhInm3LcvzSrq+0KNiIiIjH++OPPwBo06ZNvrM1iYmJvPbaawAMHDgQPz+/Mq/v31JTU4mKigKgR48eBW5jMpno3r07AJGRkWU6fmnXV5r0uLeIiHi8Xbt2AdC6dWvXuoSEBH766Sc+/vhjjh49Su3atXnkkUfKqcK8Dh48iMPhAKBp06aFbpfTdvz4cU6dOkW1atXKZHx31peYmMiQIUM4fPgwdrud4OBg2rVrx7Bhw+jUqVORjudiKNiIiIhHs9vt7Nu3D8gONtHR0fTv35/09HTXNm3atGH69OnUqlXrguMV9THlwnz22WcX/IEdHx/vWj5fTbnb4uPjixxsSjq+O+tLTU1l165dBAYGkpmZSUxMDDExMSxZsoQhQ4bw8ssvY7W6L44o2IiIiEc7ePAgqampALRq1YrffvstT6gBOHLkCCtWrODee++94Hi+vr7UqFGj2PV4eXldcJvk5GTXss1mK3S73G25+5T2+O6or2bNmjz00EPccMMNNGrUCG9vb+x2O9u3b2fmzJmsX7+eBQsW4Ofnx+TJk4t2YEWgYCMiIh5t9+7dQPbZgxo1atC/f3969uxJfHw8O3bs4Msvv2Tr1q1Mnz4dq9XK3Xfffd7x+vXrR79+/cqidEPr1q0b3bp1y7POYrHQvn17Zs+ezUMPPcRPP/3EV199xciRIwkNDXXLfnXzsIiIeLSdO3cC5+6vMZlM2Gw2GjRowMCBA/nyyy/p2rUrAN9880251Zmbv7+/aznnbFNBcrfl7lPa45d2fWazmaeeegrIfhR/9erVRe57wbHdNpKIiEg5yDlj06pVqwLbLRYLffr0AeDs2bNlVtf51KxZ07UcFxdX6Ha523L3Ke3xS7s+gAYNGnDJJZcAEB0dfVF9z0eXokRExGM5HA727NkD5H0i6t9OnDgBQO3atS845o8//sjUqVOLXdPMmTNp3779ebdp3LgxZrMZh8PBgQMHuOaaawrc7sCBAwAEBwcX+cZhd4xf2vWVJp2xERERj3X48GFSUlKA8webVatWARTpZYtpaWmcOHGi2H9yXsB5PjabzRV+1q5dW+A2TqeTdevWAbgupRVVSccv7foAjh49ysmTJwFcE/25g87YiIiIx8qZvwZgz549+W5WBVi6dCm7du3CYrEwbNiwC445ZMgQhgwZ4tY6CzJo0CC2bNnCxo0b2b59O23bts3THhER4bpEM2jQoDIfvyT9nU5nvokS/93+xhtvANn321x77bUXeXSF0xkbERHxWDn31wA8+uijLF261HXGJDExkY8++ojnnnsOgLFjx9KgQYNyqbMggwcPplmzZjidTsaPH+9635LD4SAiIsL1CHSPHj3o3Llzvv4LFiygefPmNG/e3PVKCXeOX5L+sbGx3HLLLXzzzTdER0fjdDpdfbdt28Y999zDypUrAbjtttto1KjRxX8AC2Fy5uxNRETEw4wcOZJNmzZhMplcPzwtFgs2m42kpCTXdsOHD+e5557DbK5Yv8/HxMQwatQoYmNjgexLQA6HwzUPT8uWLZk7dy6BgYH5+uaeSLCwSQFLMn5J+sfExNCzZ0/Xv729vfH39yc5OZmMjAzXek3QJyIi8v+cTqfrjM2UKVPYunUr69evJyEhgaysLBo0aED79u259dZbL3gzb3kJCQlh8eLFzJkzh5UrVxITE4PVaqVJkyYMGDCAESNG4O3tXW7jF7d/jRo1mDx5Mlu3bmXv3r0kJiZy5swZvL29CQkJoV27dgwdOrRUXkiqMzYiIuKRjhw5Qu/evYHsG1wv9nFjMaaKdU5ORESkiHLO1gQHByvUiIuCjYiIeKScGYcvu+yycq5EKhIFGxER8Ug5Z2xatmxZzpVIRaJgIyIiHikn2OiMjeSmm4dFRETEMHTGRkRERAxDwUZEREQMQ8FGREREDEPBRkRERAxDwUZEREQMQ8FGREREDEPBRkRERAxDwUZEREQMQ8FGREREDEPBRkRERAxDwUZEREQM4/8ApD7vzu1tya0AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 600x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Compare standard RL + OPE setting with EvA-RL starting from scratch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from collections import defaultdict\n",
    "\n",
    "def split_key(k):\n",
    "    env, beta, lr, pre = k.split(\"_\", 3)\n",
    "    return env, float(beta), float(lr), int(pre)\n",
    "\n",
    "# ------------------------------------------------------------\n",
    "# constants that define the two settings you want to compare\n",
    "# ------------------------------------------------------------\n",
    "OPE_FILTER  = dict(pred_coef=0,   pred_lr=0,     pre=1)   # RL + OPE\n",
    "EVA_FILTER  = dict(pred_lr=1e-3,  pre=0)                 # EvA-RL\n",
    "\n",
    "ope_estimators = [\"fqe\", \"pdis\", \"dr\"]            # bars at β=0\n",
    "palette_ope    = plt.cm.Pastel1.colors[:4]               # 4 distinct colours\n",
    "color_pred     = \"tab:orange\"                            # predictor bars\n",
    "\n",
    "# ------------------------------------------------------------\n",
    "# PASS 1 – collect data\n",
    "# env → baseline dict(est → (µ,σ))\n",
    "# env → list of tuples (β, µ_pred, σ_pred)\n",
    "# ------------------------------------------------------------\n",
    "baseline = {}                       # env -> {est: (mean, std)}\n",
    "eva      = defaultdict(list)        # env -> list of (β, mean, std)\n",
    "\n",
    "for key, stat in pred_coef_group_results.items():\n",
    "    env, beta, lr, pre = split_key(key)\n",
    "\n",
    "    # -------- RL + OPE baseline (β = 0) ---------------------\n",
    "    if (beta == OPE_FILTER[\"pred_coef\"] and\n",
    "        lr   == OPE_FILTER[\"pred_lr\"]   and\n",
    "        pre  == OPE_FILTER[\"pre\"]):\n",
    "        baseline[env] = {e: (stat[e][\"agg\"], stat[e][\"std\"])\n",
    "                         for e in ope_estimators}\n",
    "\n",
    "    # -------- EvA-RL predictor (pre=0 , lr=1e-3 , β>0) -------\n",
    "    if (pre == EVA_FILTER[\"pre\"] and\n",
    "        lr  == EVA_FILTER[\"pred_lr\"] and\n",
    "        beta > 0):\n",
    "        eva[env].append((beta,\n",
    "                         stat[\"predictor\"][\"agg\"],\n",
    "                         stat[\"predictor\"][\"std\"]))\n",
    "\n",
    "# sort β lists\n",
    "for env in eva:\n",
    "    eva[env].sort(key=lambda tup: tup[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "d027c9f4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "env: halfcheetah, return: -1.745233178138733 , std: 2.075809955596924\n",
      "env: ant, return: -1.3596603870391846 , std: 1.1650875806808472\n",
      "env: reacher, return: -14.111185073852539 , std: 0.4532167315483093\n",
      "EvARL env: halfcheetah, return: 1.691433310508728 , std: 1.8373852968215942\n",
      "EvARL env: ant, return: -1.651375412940979 , std: 0.7744584083557129\n",
      "EvARL env: reacher, return: -14.040278434753418 , std: 0.6414884924888611\n",
      "env: halfcheetah, best_beta: 0.0005, μ: 1.0061560898229538, σ: 0.0032913024769708824\n",
      "env: reacher, best_beta: 0.0005, μ: 1.0419860329283528, σ: 0.3798453475018899\n",
      "env: ant, best_beta: 0.0005, μ: 0.9996753817817399, σ: 0.0008618113100612283\n",
      "saved ./results/evarl_vs_rl_return_all_envs.pdf\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAv4AAAHOCAYAAADg9w2JAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAZ5JJREFUeJzt3Xd8U9Xj//F3mu5B2UWGMlMEWZUhLhQQFFAZAipDPiCIylDBgR/xi8oHHAxlKCoKiB9FkSHIkOFHlpUpylBBhrQFyix0N03u74/+Ehs6aNO0UPJ6Ph48Hsm959xzbtJc3rk591yTYRiGAAAAAFzTfK50BwAAAAAUP4I/AAAA4AUI/gAAAIAXIPgDAAAAXoDgDwAAAHgBgj8AAADgBQj+AAAAgBcg+AMAAABegOAPAAAAeAGCPwAAAOAFCP4AAACAFyD4AwAAAF6A4A8AAAB4AYI/AAAA4AUI/gAAAIAXIPgDAAAAXsD3SncAAFD82rZtq5YtW+rNN98s9rZeeuklbdu2TT/88EOxt3W1OXbsmM6cOXNF+1CxYkVdf/31V7QPAK5OBH8AcNOff/6pmTNnas+ePTpz5ozKli2runXrqm3bturXr5+z3KxZs1S3bl21b9/+Cvb26tOvXz9t27bN+TwgIEA33HCDevToof79+8vH558fpWNjY9WuXTu98MILGjRo0JXo7mUdO3ZMkfVvVFpqyhXtR2BQsP7843e3wv/ixYs1ZsyYPNd/9dVXatq0aaG3e+jQIXXq1En+/v7asmWLypQpU6B6W7duVf/+/Z3PfXx8VLZsWbVo0UIjR45UnTp1XMq/9NJL+v777/XLL78Uuo+ANyD4A4Abdu3apf79+6tq1arq2bOnKlWqpBMnTujXX3/VZ5995hL8P/zwQ3Xs2JHgn4sqVaroueeekySdP39e3333nSZOnKjz58/r2WefvcK9K5wzZ84oLTVFFbqMkl+FGlekD9azMTr73WSdOXOmSGf9R4wYoerVq+dY7u42ly1bpkqVKunChQv6/vvv1bNnz0LV79evnxo1aqTMzEz9+eefWrBggbZu3arvvvtOlSpVcqtPgDci+AOAG2bNmqWwsDB98803Oc5enj179gr1qmSkp6fLz8/P5Yy8u8LCwvTggw86nz/yyCO67777NH/+fI0YMUJms7nIbZQ0vwo1FFCl7pXuRpHceeedatSokUe2ZRiGli9fri5duig2NlbLli0rdPBv3ry57r33XufzWrVqady4cVq6dKkGDx7skX4C3oCLewHADceOHVPdunVzHbJQoUIF5+PIyEilpKRoyZIlioyMVGRkpF566SVJUlxcnMaNG6eOHTuqcePGatWqlUaMGKHY2FiX7S1evFiRkZHauXOnJk6cqFtuuUVNmzbV008/rXPnzrmUNQxD77//vu688041adJE/fr108GDB3P0MSEhQW+99Zbuv/9+NWvWTFFRUXr88cf1xx9/uJTbunWrIiMjtWLFCk2dOlV33HGHmjRpoqSkJEnSunXr1KVLFzVq1EhdunTR2rVr3XtB/7+AgADddNNNSk5Ovua/QJVGVqtVLVu2zHU4UFJSkho1aqS33nrLZfnOnTsVFxenTp06qVOnTtqxY4dOnjxZpH40b95ckhQTE1Ok7QDehjP+AOCGatWq6ZdfftGBAwdksVjyLPf222/rlVdeUePGjdWrVy9J/wyX2LNnj3755Rd17txZVapUUVxcnL788kv1799fK1asUFBQkMu2xo8frzJlymjYsGGKi4vTvHnz9Prrr+vdd991lnnvvff0wQcfqE2bNmrTpo327dungQMHymq1umwrJiZG69at07333qvq1avrzJkz+uqrr9S3b1+tWLFCERERLuXff/99+fn5adCgQcrIyJCfn582b96s4cOHq27duho1apTOnz+vMWPGqEqVKkV5aRUXFyeTyVTgceDwvKSkpBxfKk0mk8qVK6f27dtr7dq1eu211+Tv7+9cv27dOmVkZKhTp04u9ZYvX67rr79ejRs3lsViUWBgoL777js9/vjjbvcvLi5OkvgbAQqJ4A+g5L3+uvTVV1e6F1l695ZefbXQ1QYOHKjBgwera9euaty4sW6++Wa1bt1arVq1kp+fn7Pcgw8+qHHjxqlGjRouQ1ok6a677nIZviBJd999t3r37q3vv/9eXbt2dVlXtmxZffrppzKZTJIku92u+fPnKzExUWFhYTp37pxmz56tu+66S7NmzXKWmzp1qmbNmuWyrcjISH3//fcuw3UefPBB3Xffffrmm2/09NNPu5RPT0/XokWLFBgY6Fw2adIkVahQQV988YXCwsIkSS1bttTAgQNVrVq1Ar2ONpvNGTATEhL0zTffaO/evbrrrrtc2kLJGjBgQI5l/v7+2rNnjzp16qRFixZpy5Ytuvvuu53rV65cqRo1argMEbJarVq9erUefvhhSVJgYKDatm2r5cuXFyr4Jycn69y5c84x/hMmTJDJZFKHDh3c30nACxH8AcANt912mxYsWKCPPvpImzdv1i+//KLZs2erfPnyGj9+vNq1a3fZbWQPtlarVUlJSbr++utVpkwZ7d+/P0fw79WrlzPMS1nDHebOnau4uDjVr19fP/30k6xWq/r27etS7rHHHssR/LOfqbXZbLp48aKCg4NVq1Yt7d+/P0dfu3bt6tLfU6dO6ffff9eQIUOcod/xutStW1epqamX3X9JOnz4sFq3bu2yrG3btvrPf/5ToPooHq+++qpq1arlsszxJfGWW25RuXLltHLlSmfwv3Dhgn766ScNHDjQpc7GjRuVkJCgLl26OJd16dJFQ4cO1cGDB1WvXr0C9efll192eV6+fHm9/fbbaty4caH3DfBmBH8AJe/VV906y361ady4sWbMmKGMjAz98ccfWrdunebOnauRI0dq6dKlqls3/ws809LS9OGHH2rx4sWKj4+XYRjOdYmJiTnKV61a1eW5Y5jDxYsXJUnHjx+XJNWsWdOlXPny5RUeHu6yzG6367PPPtMXX3yh2NhY2Ww257qyZcvmaPvSGV4cbd1www05yub15SE31apV0/jx42W323Xs2DHNmjVL58+fV0BAQIHqo3g0btw4z4t7fX191aFDB3333XfKyMiQv7+/1qxZI6vVmmOYz7Jly1S9enX5+/vr77//lpQ11C0oKEjLly93zuh0+vRpl3phYWEuXzSffvppNW/eXCkpKVq7dq1WrFjhkYvLAW9D8AeAIvL391fjxo3VuHFj1axZU2PGjNHq1as1bNiwfOu98cYbWrx4sR577DE1bdpUYWFhMplMevbZZ12+BDjkFXRyK3s5s2bN0nvvvacePXpo5MiRCg8Pl4+PjyZMmJDr9opr2E1wcLBuvfVW5/OoqCh1795dU6dO1SuvvFIsbaLoOnfurK+++kobN25U+/bttXr1atWuXVv169d3lklKStL//vc/paen5zok57vvvtOzzz4rk8mk22+/3WXdxIkT1b17d+dzi8Xi/Dtp3769UlNTNXbsWN1888267rrrimkvgWsPwR8APOimm26SlDUU5nIc4/gds/xIWWPpczvbXxCOXwSOHj2qGjX+mUf+3LlzunDhQo62W7VqpQkTJrgsv3jxosqVK1fgthxncbM7cuRIofvuUL9+fT3wwANasGCBBg4cmONXDlwdWrRooUqVKmnlypWKiorSzz//rKFDh7qUWbNmjdLT0zVu3Lgcf1NHjhzRu+++q507d6p58+aaM2eOy/rL/Vo2evRorVu3Th988IFef/11z+wU4AX4nQwA3PDzzz/nemZ8w4YNkqTatWs7lwUHBzuH42SX2xz18+fPdxl2Uxi33nqr/Pz89Pnnn7v0bd68ebm2fWn/V61apfj4+AK1VblyZd14441asmSJyxeVLVu26K+//nKr/w6PP/64MjMzc4RBXD18fHx077336n//+5+WLVumzMzMXIf51KhRQ4888ojuvfdel3+DBg1ScHCwli9fLinrbzf7v8qVK+fb/vXXX68OHTpoyZIlOYYJAcgbZ/wBwA3jx49Xamqq7rnnHtWuXVtWq1W7du3SqlWrVK1aNZdhCg0bNlR0dLTmzJmjypUrq3r16mrSpInuuusuffvttwoNDVXdunW1e/du/fTTT7mOsS+I8uXLa+DAgfrwww/1xBNPqE2bNtq/f782btyY44zrXXfdpZkzZ2rMmDFq1qyZDhw4oOXLl7v8UnA5zz33nJ544gk9+uij6tGjhxISEvT555+rXr16SklJcWsfpKyzvW3atNE333yjp556yqXv0dHRSk9Pz1Gnffv2+U6rWpKsZ6/c3PKeanvjxo06fPhwjuVRUVHOvxHHjdamTZsmi8WiOnXqOMvFx8dr69atLnewzs7f31933HGHVq9erVdeecVlJqyCGjRokFatWqV58+Zp9OjRzuVWq1Xvv/9+jvLh4eHq06dPodsBriUEfwBwwwsvvKDVq1drw4YN+uqrr2S1WlW1alU9+uijevLJJ13mF3/ppZf06quv6t1331VaWpq6deumJk2a6N///rd8fHy0fPlypaenKyoqSnPmzCnS/ObPPPOM/P39tWDBAm3dulWNGzfWp59+qieeeMKl3NChQ5Wamqrly5dr5cqVatCggT788ENNnjy5wG3deeedeu+99/Tuu+9q8uTJuv766zVx4kStX79e27Ztc3sfpKxQ9+OPP+rzzz/X8OHDncs3bdqkTZs25ShfrVq1Kx78K1asqMCgYJ39ruCvYXEIDApWxYoVi7SNadOm5bp84sSJ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ekixsbF666231KFDB7dCtuNDlJ3VapPVastRNiPDJim35Zl5bDv35deqjIxMpaVZnc8NQy7PHex2I9flNptdNps9x/LMTLsyM3MuL+73Kbc+sk/sk1Sy+5RX3WvFtfI+OVxLf3sO7FPp2qdr+ZjheE1L6n0ymaSwsMAC9c3toT6OIT4rV668bNnZs2fLZDKpVatWbrWV/aLh1NTUPMtlX5fXhcYFtXDhQklZw4fyuqC4IMqVK6ehQ4dKyroBmWPqUwAAAKAkuR38H330URmGoRkzZjjn179URkaGJk+erG+//VYmk0mPPPKIW21VrlzZ+dhxFj432ddlr1NYZ86c0Y8//ihJ6tatW4GHM+WladOmzscxMTFF2hYAAADgDreH+kRFRalv3776/PPP1bt3b91xxx3OcfVTpkxRXFycoqOjdf78eUnSk08+6fZQnzp16sjHx0d2u10HDx5UmzZtci138OBBSVKlSpWKNKPP0qVLlZmZKZPJpIceesjt7QAAAABXC7fP+EvSv//9bw0dOlQZGRlas2aNc6jNxx9/rJUrV+rcuXMym80aPny4hg8f7nY7QUFBzqFFmzZtyrWMYRjavHmzJOm2225zuy3pn7n7W7VqpRo1ahRpW5K0e/du52PHTcYAAACAklSkS6pNJpOeeeYZ9ezZU0uWLNGuXbt06tQp2Ww2VaxYUVFRUXrooYc8Ep67du2qHTt2aOvWrfr111/VpEkTl/WrVq1yDqPp2rWr2+3s2LFDR44ckVSwO/UahpHvxboJCQn68MMPJUnXXXedGjRo4HbfAAAAAHd5ZC6latWqadiwYZ7YVJ66deumzz77TAcOHNDw4cP11ltvqXXr1rLb7fr+++81duxYSVl39m3durVL3enTp2vGjBmSpPXr1+d71t1xtr9s2bLq0KHDZfv17bffat26dbr//vvVvHlzVahQQVLW9KWbN2/WO++84/xC8sILLxR62iUAAADAE0rNJKq+vr764IMP1L9/f8XFxWnAgAEKCgqS3W5Xenq6pKz59CdNmuR2G0lJSVq9erUk6f7775e/v/9l69jtdq1du1Zr166VJAUHB8vf31+JiYmy2bKmXvL399dLL72kTp06ud03AAAAoCjcDv5jxoyRJN11110FuinVhAkTlJSUpAkTJrjbpKpXr65ly5bp008/1dq1axUbGytfX1/V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fGkAAAAArqACB/9q1aoVeKOpqan69NNPNWfOHCUnJ8swDNWuXVvPPfecW50EAAAAUDQemcffwWazacGCBfrggw909uxZGYahKlWqaNiwYerevbt8fJhECAAAALgSPBb8V6xYoffee08xMTEyDEPh4eEaPHiw+vXrp4CAAE81AwAAAMANRQ7+mzdv1pQpU/T777/LMAwFBgaqb9++GjJkiMqUKeOJPgIAAAAoIreD/549ezR58mRt3bpVhmHIbDare/fuGjZsmCIiIjzZRwAAAABFVOjg//fff2vKlClas2aNc6aee+65R88++6xq167t8Q4CAAAAKLoCB//Tp09rxowZWrRokTIzMyVl3YV39OjRatKkSbF1EAAAAEDRFTj433PPPUpPT5dhGKpfv76ee+453XnnncXZNwAAAAAeUuDgn5aWJpPJJJPJpIsXL+q1114rdGMmk0nr1q0rdL3skpKSNGfOHK1Zs0axsbHy8fFRzZo11blzZ/Xt21f+/v6F3mZ8fLzWrVunrVu36vfff1d8fLwkqWLFimratKl69uyp1q1b51l/+vTpmjFjxmXbWbNmjW644YZC9w8AAAAoqkKN8XeM6T9+/LhbjZlMJrfqOcTFxalfv36Ki4uTJAUFBSkjI0N79+7V3r17tXz5cs2dO1fh4eEF3uaJEyd09913u9xZOCgoSIZhKC4uTnFxcVqxYoV69OihN954Q2azOc9t+fn55dt2fnUBAACA4lTg4D9s2LDi7MdlZWZmaujQoYqLi1OlSpX09ttv69Zbb5Xdbtfq1av1yiuvaP/+/Xr++ef10UcfFXi7NptNhmGodevW6tq1q1q3bq2IiAjZ7XYdPnxYU6ZM0fr167Vo0SJVrlxZzzzzTJ7batasmebPn++BvQUAAAA8q9QE/yVLlujAgQOSsobWNGvWTJLk4+OjTp06yW63a9SoUdqwYYOio6PzHZqTXXh4uBYvXqyGDRu6LPfx8VHdunU1c+ZMDR48WJs2bdK8efP05JNPckMyAAAAlDo+V7oDBbV06VJJUqtWrZyhP7vOnTurevXqLmULIiwsLEfoz85kMqlHjx6SpJSUFB06dKjgnQYAAACuEqUi+KempmrXrl2SlOdMQiaTSXfccYckacuWLR5tP/sZfpvN5tFtAwAAACXB7Tv3lqRDhw7JbrdLkurVq5dnOce606dPKyEhQWXLlvVI+9u2bZOUdfFurVq18ix38OBBdenSRTExMfLx8VHlypXVokULPfroo2rQoIFH+gIAAAC4o1Sc8T916pTzcURERJ7lsq/LXqcoYmJitGDBAklSp06dFBoammfZ8+fP69ChQwoMDFRGRoaOHj2qhQsXqnv37po6dapH+gMAAAC4o1Sc8U9OTnY+DgoKyrNc9nXZ67grLS1NI0eOVGpqqsqVK6dRo0blWu6GG27Q888/r3bt2ql69ery8/NTRkaGtm3bpilTpmjfvn2aNWuWwsPDNXDgQLf6EhDg53xss9lltdrk52eW2fzPd7fMTJsyM+3y9zfLx+ef5VarTTabXf7+vvLx+WdK1YyMTNnthgICfIs81Wpp4u/vq8DArNczLc0qk8n19TUMQ+npmfLxMcnf/5+PiN1uKCMjU2azj/z8zNmW25WRYZOvr498ff9ZXtzvU3q6VYYh5744sE/s05XYp+z9vRZl39fS/D5J197fHvtUOvfpWj5mON6Dkn6fCuLafdWLKDMzU6NGjdK+ffvk5+enSZMm5flrwwMPPJBjmb+/v26//Xa1aNFCffr00Z49ezR9+nT17NlTYWFhhe6P40OUndVqk9Wa85qDjAybpNyWZ+ax7dyXX6syMjKVlmZ1PjcMuTx3sNuNXJfbbHbZbPYcyzMz7crMzLm8uN+n3PrIPrFPUsnuU151rxXXyvvkcC397TmwT6Vrn67lY4bjNS2p98lkksLCAgvUt1Ix1CckJMT5ODU1Nc9y2ddlr1NYNptNo0eP1rp16+Tr66tJkybp9ttvd2tbAQEBeu655yRlzQoUHR3tdr8AAAAAd5WK4F+5cmXn4/j4+DzLZV+XvU5h2Gw2Pf/881q1apXMZrPeeecd3XvvvW5ty6Fp06bOxzExMUXaFgAAAOCOUhH869Sp4xzDdPDgwTzLOdZVqlTJrRl9HGf6V6xY4Qz9nTp1cqvPAAAAwNWkVAT/oKAgRUVFSZI2bdqUaxnDMLR582ZJ0m233VboNmw2m0aNGqWVK1c6Q3/nzp3d73Q2v/76q/Ox4yZjAAAAQEkqFcFfkrp27SpJ2rp1q0uQdli1apVzGI2jbEE5zvSvWrXKOaa/oKHfuPSK20tkZGQ4p/IMDg5W69atC9U3AAAAwBNKTfDv1q2bLBaLDMPQ8OHDnRfJ2u12rVq1SmPHjpWUdWffS8P19OnTFRkZqcjISMXGxrqsc4zpX7lypTP0F2Z4z/bt2zVgwAAtXbpUJ0+edC63Wq2Kjo7Wo48+6vyi8tRTT6lMmTJu7T8AAABQFKVmOk9fX1998MEH6t+/v+Li4jRgwAAFBQXJbrcrPT1dktSgQQNNmjSpUNvdtWuXVqxYIUkymUwaP368xo8fn2f5f//73y5fDAzDUHR0tPOLSGBgoIKCgpSUlCSrNWsKJx8fHw0ZMkSDBw8uVN8AAAAATyk1wV/KGh+/bNkyffrpp1q7dq1iY2Pl6+urunXrqkuXLurbt6/8/f0LtU27/Z/5Uq1Wq86cOZNv+bS0NJfnFotFL774onbv3q0///xTCQkJSkxMVGBgoOrUqaPmzZurV69eioyMLFS/AAAAAE8qVcFfkkJDQzVixAiNGDGiwHWGDx+u4cOH57quVatW+vPPP93uT7ly5dy+Gy8AAABQUkrNGH8AAAAA7iP4AwAAAF6A4A8AAAB4AYI/AAAA4AUI/gAAAIAXIPgDAAAAXoDgDwAAAHgBgj8AAADgBQj+AAAAgBcg+AMAAABegOAPAAAAeAGCPwAAAOAFCP4AAACAFyD4AwAAAF6A4A8AAAB4AYI/AAAA4AUI/gAAAIAXIPgDAAAAXoDgDwAAAHgBgj8AAADgBQj+AAAAgBcg+AMAAABegOAPAAAAeAGCPwAAAOAFCP4AAACAFyD4AwAAAF6A4A8AAAB4AYI/AAAA4AUI/gAAAIAXIPgDAAAAXoDgDwAAAHgBgj8AAADgBQj+AAAAgBcg+AMAAABegOAPAAAAeAGCPwAAAOAFCP4AAACAFyD4AwAAAF6A4A8AAAB4AYI/AAAA4AUI/gAAAIAX8L3SHSispKQkzZkzR2vWrFFsbKx8fHxUs2ZNde7cWX379pW/v7/b2z5z5oxmz56t//3vfzpx4oQCAwNVt25ddevWTQ899JBMJlO+9Y8dO6bZs2dr8+bNOn36tEJCQtSwYUP16tVLHTt2dLtfAAAAQFGVquAfFxenfv36KS4uTpIUFBSkjIwM7d27V3v37tXy5cs1d+5chYeHF3rbe/fu1aBBg5SQkCBJCg4OVnJysnbu3KmdO3dq9erV+uCDD/L8YrFhwwaNHDlSqampkqTQ0FBduHBBmzdv1ubNm9W9e3dNmDDhsl8eAAAAgOJQaob6ZGZmaujQoYqLi1OlSpU0Z84c7d69W7/++qumTp2qkJAQ7d+/X88//3yht52YmKihQ4cqISFBtWvX1jfffKNffvlFv/zyi1599VX5+flp8+bNmjBhQq71Y2Ji9Mwzzyg1NVVRUVFavXq1du7cqR07dujpp5+WJC1evFizZ88u0msAAAAAuKvUBP8lS5bowIEDkqTp06fr1ltvlST5+PioU6dOev311yVlnXmPjo4u1LY/+eQTnT59WoGBgfroo4/UqFEjSZK/v7/69Omj4cOHS5K+/vprHTlyJEf9adOmKSUlRZUqVdKHH36oWrVqSZJCQkI0YsQI9e7dW5I0a9YsXbhwwY29BwAAAIqm1AT/pUuXSpJatWqlZs2a5VjfuXNnVa9e3aVsQX377beSpE6dOqlGjRo51vft21fBwcGy2Wxavny5y7qUlBStWbNGkvTwww+rTJkyOeoPGTJEUtb1CevWrStU3wAAAABPKBXBPzU1Vbt27ZIk3XnnnbmWMZlMuuOOOyRJW7ZsKfC2Dx8+rOPHj+e77ZCQEDVv3jzXbe/cuVNpaWn51q9evbrq1KlT6L4BAAAAnlIqgv+hQ4dkt9slSfXq1cuznGPd6dOnnRfpXs7Bgwedjy0Wy2W3/ddffxWpfvbyAAAAQEkpFbP6nDp1yvk4IiIiz3LZ1506dUply5b1+LaTkpKUnJyskJAQl/rh4eEKDAy8bP3s7RVGSU4GZDabFRYWpoCUU/JLcH961KtOyimFhYXJbDaX6OsJeINr8rjBMQMoNhwzPKcwbZWK4J+cnOx8HBQUlGe57Ouy1ynotvML7pdu2xH8HfXzq5u9fkH7dakKFcLcqueOu+66VRcvXiyx9krWf650B4Br0rV73OCYARQHjhlXRqkY6gMAAACgaEpF8HecXZfkvEFWbrKvy16noNt2XKRbmG07HudXN3v9gvYLAAAA8KRSEfwrV67sfBwfH59nuezrstfx5LZDQ0Ndwruj/oULF/IN/476Be0XAAAA4EmlIvjXqVNHPj5ZXc1vVhzHukqVKhXowl7JdZYgxw3C8tt23bp1i1Q/v1mJAAAAgOJSKoJ/UFCQoqKiJEmbNm3KtYxhGNq8ebMk6bbbbivwtmvVqqWqVavmu+2UlBTt2LEj123ffPPNzgt786ofFxenQ4cOFbpvAAAAgKeUiuAvSV27dpUkbd26Vb/++muO9atWrVJMTIxL2YIwmUx68MEHJUkrV65UbGxsjjL//e9/lZKSIrPZrPvvv99lXXBwsDp06CBJ+vLLL5WYmJij/scffywpa3x/+/btC9w3AAAAwFNKTfDv1q2bLBaLDMPQ8OHDFR0dLUmy2+1atWqVxo4dKynr7rmtW7d2qTt9+nRFRkYqMjIy12A/aNAgVapUSampqXriiSe0d+9eSVJGRoa++OILvffee5KkXr16qVatWjnqjxgxQsHBwTp9+rSGDh2qo0ePSsr6pWDGjBlasGCBJOnJJ59UeHi4Z14QAAAAoBBMhmEYV7oTBRUbG6v+/fsrLi5OUtYQILvdrvT0dElSgwYNNHfu3Bzhevr06ZoxY4Ykaf369apevXqObe/du1eDBg1y3vE3JCREGRkZslqtkqTbb79dH3zwgfz9c7/JxIYNGzRy5Ejn7D1hYWFKSUmRzWaTJHXv3l0TJkyQibvAAAAA4AooVcFfyrpz7qeffqq1a9cqNjZWJpNJNWvWVJcuXdS3b99cg3lBgr8knTlzRh9//LF+/PFHnThxQgEBAapXr566deumHj16OC8wzsuxY8f08ccfa8uWLTp9+rRCQkLUoEED9e7dWx07diz6zgMAAABuKnXBHwAAAEDhlZox/qVdv379FBkZqenTp5dou47rG/r165dnmUWLFql3796KiopyXgsxd+7cIrXr2M7WrVuLtJ1r0eLFixUZGam2bdte6a4A16SCHPcAwBv5XukO4Mr69NNP9dZbb0mSfH19VaFCBZlMJgUHB1/hnl0Zv//+u9atW6ewsDANGDDgSncHAABcAevWrdPvv/+uG2+88ZqakZHg7+U++eQTSVm/SLz44ovy8/O7wj26sn7//XfNmDFD1apVI/gDAOCl1q1bpyVLlqhbt27XVPBnqI8XO3funM6cOSMpa6pSbw/9AAAA1zKCvxdzTD0qyWuH9gAAAHgLhvpcAYZhaOHChVq4cKEOHTokwzBksVj06KOPOu8inN3p06e1evVq/fTTTzp69KhOnTolq9WqiIgItWzZUgMGDFC9evUK3P7WrVvVv39/l2Xt2rVzPq5WrZp++OEHl/UnTpzQ/PnztWXLFsXGxspqtapy5cqqV6+eOnbsqPvuu08BAQG5tpeUlKSPP/5Y33//vY4fP66goCA1bdpUTz31lJo0aZJvX3/88UctWrRIu3fv1vnz5xUUFCSLxaLOnTvroYceyvO+ClLWfR/mzZunn376ScePH5fdbtd1112n22+/XQMHDlTVqlVdykdGRjofx8XFuTyXpGHDhmn48OGSsr40rV+/Xhs3btSff/6p+Ph4JSUlqWzZsmrcuLF69+6tNm3a5LtvDnv37tXHH3+snTt3KiEhQREREWrfvr2eeuopbviGYtevXz9t27ZNw4YN09ChQzV//nx99913OnbsmBITE/XZZ5+pVatWkqQDBw5o/vz52rp1q+Lj4+Xj46Pq1aurbdu2euyxx1S+fPkc27dardq4caN+/PFH7du3T6dOnVJCQoLCwsLUoEEDdevWTZ07d873Hid2u12rV6/Wd999pz179uj8+fMKDQ1V1apV1bp1az344IOyWCx51o+OjtacOXP022+/KTk5WdWrV1fnzp01ePDgPI9bUtavovPmzdOGDRsUExOjjIwMVa5cWa1atdK//vWvXI+72Y+vf/75p/bv369PPvlE27dv19mzZxUVFaX58+fn2SYAVxcuXNCaNWu0efNmHT58WPHx8UpNTVXFihUVFRWlfv36qWnTpjnqOaZyb9mypebPn1/g48ClGWnJkiVasmSJy7azHxdLG4J/CbPZbHr66ae1fv16+fr6KjAwUMnJydq9e7d2796tv//+WyNGjHCpM3nyZOcfna+vr0JDQ5WWlqZjx47p2LFjWrZsmSZNmlTgewX4+fmpYsWKstlsOn/+vCSpXLlyMpvNzsfZLV26VK+++qrzRml+fn4KCQnRiRMnFBMTox9++EGRkZG68cYbc7R1+vRpde/eXX///bcCAgLk4+OjhIQE/fjjj9qyZYtmzZql22+/PUe9tLQ0vfDCC/r++++dy0JDQ5WYmKgdO3Zox44d+vbbb/XRRx/lGo6XLVumf//738rIyJAk+fv7y8fHR0eOHNGRI0e0ePFiTZs2zaXtihUrKi0tTUlJSfLx8ckRYrL/KrJq1SqNGTNGkmQymRQaGipfX1+dPn1a69ev1/r16zVw4EC9+OKL+bwT0vLlyzVmzBhZrVaFhYXJZrMpNjZWc+fO1ZYtW/TVV18pJCQk320AnpCenq5+/frpl19+ka+vr0JCQlzC+Mcff6wpU6bIbrdLyrqBotVq1YEDB3TgwAEtWrRIH330kRo0aOCy3V27dumpp55yPg8NDZW/v7/OnTunzZs3a/PmzVq7dq2mTp2a671Szp07pxEjRmj79u3OZWXKlFF6err27dunffv26ciRI3r//fdz3a/Zs2dr0qRJkrJurGi1WnX48GFNnz5d27Zt05w5c5zHvux++uknjRw5UhcvXpSUddzz8/NTbGysYmNjtWzZMo0fP15du3bN8zX9/vvvNWrUKFmtVoWGhubaDoD8ffbZZ857MZnNZoWGhkqSjh8/ruPHj2vFihV6+eWXc5zQzK4wxwFHRkpMTFR6eroCAgIUFhbmsr1SPTTaQIno27evYbFYjBYtWhg333yzsXjxYiM1NdUwDMM4ceKE8cQTTxgWi8WoX7++ceTIEZe6M2fONGbPnm38+eefhtVqNQzDMGw2m3HgwAFj1KhRhsViMZo2bWqcPHkyR7vTpk0zLBaL0bdv3xzrYmJiDIvFYlgsFiMmJibXfv/vf/8zIiMjDYvFYjz88MPG9u3bDZvNZhiGYaSnpxvbt283XnnlFePgwYMu9RzbbdGihdGpUycjOjrasNlsht1uN3799VejY8eOhsViMe6++27n9rIbPXq0YbFYjHbt2hnLli0zEhMTDcMwjLS0NGPdunVGu3btDIvFYjz11FM56m7evNmoX7++0aBBA+Ptt982YmJiDLvdbtjtduPQoUPGiBEjDIvFYkRFRRlxcXEudRctWuTsV37Wrl1rvPnmm8aOHTuMlJQU5/L4+Hhj+vTpRsOGDQ2LxWKsW7cuR11HG02aNDFuuukm49///rdx/PhxwzAMIyUlxfj888+d9d999918+wEUlePY1LRpU6Np06bGokWLnMemc+fOGefPnze+/vprZ5kPPvjAOHXqlGEYhpGZmWns2bPH6N+/v2GxWIw777zTSEpKctn+r7/+aowdO9bYsmWL83NsGIZx/vx5Y968eUZUVJRhsViMefPm5eib1Wo1Hn74YcNisRg33XST8dFHHxlnz551rj958qSxYMECY/LkyS71HMe95s2bG/Xr1zcmT57srJeYmGi89957zmPUwoULc7T7xx9/GI0bNzYsFovxyiuvGH/99ZeRmZlpGIZhxMXFGePGjTMsFovRoEED47fffnOp+/PPPzu33bRpU2Pw4MHGX3/95Vx/6fEdQP4WLFhgTJs2zdizZ4+Rnp5uGIZh2O1249ixY8b48eONyMhI48YbbzT27dvnUq+ox4EXX3zR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Pvggz+099NBDkrKOcxs2bHCn+4VWs2ZNtWzZUpI0depU5yQCebn0GALAcxzHkKNHj+Z6jdHvv/+u5cuXF0vbBckDpRHB/yp35513SpIOHjyo1157zfmfTEpKihYsWKCRI0e6jJf1JLPZrLFjx8pkMmnnzp0aMGCAduzY4RwDm5GRoa1bt2r06NH666+/PNZuy5Yt1b17d0nS66+/rgkTJigmJsa5PiMjQ7t379bbb7+tu+++W+fOnXOu8/X11WuvvSZfX1/t3LlTffv2VXR0tMsFsjExMfryyy/Vo0ePHF8s6tWrJykrkKxcuTLX/t18880KDg6WYRh65plndOTIEUlZZwg3bdqkfv36eeaFAK4CZcqU0csvvyxJWrFihYYMGaJff/3VeRyw2+06dOiQPv30U3Xu3Nnl7HydOnWcF+a+/PLLzll6pKwL5Pv375/vbBoPPvigbr75ZhmGoeHDh2v27Nkun/f4+HjNnTtX77zzjkf3eezYsQoODtbRo0fVq1cvrVu3ziV0xMfHa+nSpXrsscecdwMF4Hm33XabfHx8lJCQoNGjRztn7snIyNDKlSs1cODAYru7vcVikZQ1TeihQ4eKpY0rgTH+V7nWrVurc+fOWrFihb788kt9+eWXKlOmjJKTk2Wz2dSwYUN1795db7zxRrG036ZNG7355psaO3asdu7cqT59+sjf31/BwcFKSkpyXgk/aNAgj7b72muvyWw2a+HChZo3b57mzZun4OBg+fn5KTEx0WUar0svAmzdurXee+89vfDCC/r11181YMAA+fn5KSQkJMcvBO3bt3epe8MNN6h169aKjo7Ws88+q1deecX5xap///4aMGCAwsLC9MILL2jcuHHavn277r33XgUHB8tmsyk9PV3lypXTxIkT85yjHyhtunXrprS0NP3nP//Rxo0btXHjRudxIDk52eWLdfbPo4+Pj1599VUNGzZMBw8eVI8ePZw/16empio4OFjvv/9+nhfm+fr6asaMGRo+fLh27Nihd955R5MmTVJYWJgyMzOds3g45uL2FIvFotmzZ2vkyJE6fPiwnn76aZnNZoWFhSktLc1l5iLHr6IAPK9mzZoaNGiQPv74Y61Zs0Zr1qxxfg6tVquqV6+uZ555RqNHj/Z42x06dNCUKVN07tw5derUSeXKlXNe85PXNUulAcG/FJg0aZKaNGmiRYsW6ciRI7LZbLJYLOrUqZMGDBiQ71z3ntC1a1c1b95cn332mbZs2aLjx48rPT1dVatWlcViUYcOHVSnTh2Ptunv76/x48erR48e+vrrr7Vjxw6dOnVKKSkpqlChgmrVqqUWLVqoY8eOuY6zb9++vdauXasvvvhCGzdu1N9//63ExEQFBQWpdu3aatSoke666y7nLyrZTZs2TTNnztSPP/6oEydOKC4uTpJcfvJ/5JFHVLVqVc2ePVt79+6VzWZTRESE2rRpo8GDBzMFJ645jzzyiO644w7997//1U8//aTY2FglJiYqNDRUNWrUULNmzdS2bdscNyi8++679fnnn2vWrFnatWuXUlNTValSJd13330aPHiwateunW+75cuX1/z58/Xdd99p+fLl2rdvny5evKgyZcqoVq1auu222/Tggw96fH9vvvlmrV69Wl9//bV++OEHHTx4UImJiQoICFCdOnXUsGFD3XnnnR7/0gHA1ejRo1W3bl3997//1YEDB5SZmanrr79e99xzjx5//HHt37+/WNoNDw/X559/rpkzZ2rHjh06d+6cc5rugkxtfLUyGdfaVQsAAAAAcmCMPwAAAOAFCP4AAACAFyD4AwAAAF6A4A8AAAB4AYI/AAAA4AUI/gAAAIAXIPgDAAAAXoDgDwAAAHgBgj8AAADgBQj+AAAAgBcg+AMAAABegOAPAAAAeAGCPwAAAOAF/h8i5NLAIYzPsQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from collections import defaultdict\n",
    "\n",
    "# ------------------------------------------------------------\n",
    "# settings that define each regime\n",
    "# ------------------------------------------------------------\n",
    "BASE_FILTER = dict(beta=0.0,   lr=0.0,  pre=1)     # standard RL\n",
    "EVA_FILTER  = dict(lr=1e-3,    pre=0)              # EvA-RL + predictor\n",
    "\n",
    "# helper\n",
    "def unpack(k):\n",
    "    env, beta, lr, pre = k.split(\"_\", 3)\n",
    "    return env, float(beta), float(lr), int(pre)\n",
    "\n",
    "# ------------------------------------------------------------\n",
    "# collect baseline (mean ± SE) AND EvA-RL runs\n",
    "# ------------------------------------------------------------\n",
    "baseline_ret = {}                                   # env → μ_baseline\n",
    "bars = defaultdict(dict)                            # env → β → (μ_norm, σ_norm)\n",
    "\n",
    "for key, stat in pred_coef_group_return.items():\n",
    "    env, beta, lr, pre = unpack(key)\n",
    "\n",
    "    # ---------- baseline ------------------------------------\n",
    "    if (beta == BASE_FILTER[\"beta\"] and lr == BASE_FILTER[\"lr\"]\n",
    "            and pre == BASE_FILTER[\"pre\"]):\n",
    "        baseline_ret[env] = float(stat[\"agg\"])\n",
    "        print(f\"env: {env}, return: {baseline_ret[env]} , std: {stat['std']}\")\n",
    "\n",
    "\n",
    "# second pass so every env has its baseline ready\n",
    "env_lowest_return = {\"halfcheetah\": -560, \"reacher\": -15.8, \"ant\": -900}\n",
    "for key, stat in pred_coef_group_return.items():\n",
    "    env, beta, lr, pre = unpack(key)\n",
    "    if env not in baseline_ret or baseline_ret[env] == 0:\n",
    "        continue                                    # skip if no baseline\n",
    "\n",
    "    # ---------- EvA-RL --------------------------------------\n",
    "    if beta > 0 and lr == EVA_FILTER[\"lr\"] and pre == EVA_FILTER[\"pre\"]:\n",
    "        print(f\"EvARL env: {env}, return: {stat['agg']} , std: {stat['std']}\")\n",
    "        μ_norm = (float(stat[\"agg\"])-env_lowest_return[env]) / (baseline_ret[env]-env_lowest_return[env])\n",
    "        σ_norm = float(stat[\"std\"]) / (baseline_ret[env]-env_lowest_return[env])\n",
    "        if beta not in bars[env]:                   # keep first run per β\n",
    "            bars[env][beta] = (μ_norm, σ_norm)\n",
    "\n",
    "# ------------------------------------------------------------\n",
    "# plotting  (one figure per environment)\n",
    "# ------------------------------------------------------------\n",
    "# Plot all environments in a single figure\n",
    "envs = [\"halfcheetah\", \"reacher\", \"ant\"]\n",
    "if not envs:\n",
    "    print(\"No environments to plot\")\n",
    "else:\n",
    "    # Set up the figure\n",
    "    fig, ax = plt.subplots(figsize=(8, 5))\n",
    "    \n",
    "    # Horizontal baseline line at y = 1\n",
    "    ax.axhline(1.0, color=\"red\", linewidth=1.2, label=\"Standard RL\")\n",
    "    \n",
    "    # Set up positions for grouped bars\n",
    "    num_envs = len(envs)\n",
    "    bar_width = 0.2\n",
    "    group_width = 0.8\n",
    "    x_positions = np.arange(num_envs)\n",
    "    \n",
    "    # Track the best beta for each environment\n",
    "    best_betas = {}\n",
    "    \n",
    "    # Plot bars for each environment\n",
    "    for i, env in enumerate(envs):\n",
    "        beta_dict = bars[env]\n",
    "        betas = sorted(beta_dict)\n",
    "        if not betas:\n",
    "            continue\n",
    "            \n",
    "        # Find the beta with the highest return\n",
    "        best_beta = max(betas, key=lambda b: beta_dict[b][0])\n",
    "        best_betas[env] = best_beta\n",
    "        \n",
    "        # Get the normalized return and std error for the best beta\n",
    "        μ, σ = beta_dict[best_beta]\n",
    "        print(f\"env: {env}, best_beta: {best_beta}, μ: {μ}, σ: {σ}\")\n",
    "        \n",
    "        # Plot the bar for this environment\n",
    "        ax.bar(x_positions[i], μ, width=bar_width, yerr=σ, capsize=3,\n",
    "               color=\"tab:blue\", edgecolor=\"black\", label=\"EvA-RL\" if i == 0 else \"\")\n",
    "    \n",
    "    # Set up the x-axis\n",
    "    ax.set_xticks(x_positions)\n",
    "    ax.set_xticklabels([f\"{env}\" for env in envs], rotation=0)\n",
    "    ax.set_ylabel(\"Normalized Return\")\n",
    "    # ax.set_title(\"EvA-RL vs Standard RL across environments\")\n",
    "    \n",
    "    # Add legend\n",
    "    ax.legend(loc=\"upper center\", bbox_to_anchor=(0.5, 1.15),\n",
    "              frameon=False, ncol=2, fontsize=12)\n",
    "    \n",
    "    ax.grid(axis=\"y\", linestyle=\"--\", alpha=0.4)\n",
    "    \n",
    "    fig.tight_layout()\n",
    "    out = \"./results/evarl_vs_rl_return_all_envs.pdf\"\n",
    "    fig.savefig(out)\n",
    "    print(\"saved\", out)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "pred310",
   "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.10.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
