{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "pycharm": {
     "is_executing": true
    },
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<torch._C.Generator at 0x112b46930>"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# The script has to be run multiple times to get repeated seeds. Done to have consistent seeding.\n",
    "# I.e. if runs across three different seeds are available in the benchmark directory, you have to run this script three times in order to generate\n",
    "# ROC curves across all three seeds.\n",
    "\n",
    "\n",
    "from stable_baselines3 import PPO\n",
    "import torch as th\n",
    "import os\n",
    "import numpy as np\n",
    "from stable_baselines3.common.vec_env import VecNormalize, DummyVecEnv\n",
    "import gym\n",
    "import xmltodict\n",
    "import random\n",
    "from scipy.spatial import distance\n",
    "from PIL import Image\n",
    "\n",
    "np.random.seed(42)\n",
    "random.seed(42)\n",
    "th.manual_seed(42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Already FINISHED with results\n",
      "Model:  /Users/yannick/Documents/neurips_benchmarks/neurips_benchmarks/Cheetah_zip/Dropout/HalfCheetah-v3_6\n",
      "Method:  dropout\n",
      "Run ID:  6\n",
      "Is at last:  True\n"
     ]
    }
   ],
   "source": [
    "env_name = \"HalfCheetah-v3\"\n",
    "short_env_name = \"walker\"\n",
    "model_base_dir = '../neurips_benchmarks/'+env_name+'/Dropout'\n",
    "method = \"dropout\"\n",
    "\n",
    "subdirs = [ f.path for f in os.scandir(model_base_dir) if f.is_dir() and env_name in f.path]\n",
    "sub_run_numbers = [int(subdir.split(\"_\")[-1]) for subdir in subdirs]\n",
    "sub_run_numbers.sort()\n",
    "\n",
    "is_at_last = True\n",
    "chosen_id = 0\n",
    "for i in sub_run_numbers[:-1]:\n",
    "    if not os.path.isfile(\"save_previous_results\"+short_env_name+\"_\"+method+\"_\"+str(i)+\".pkl\"):\n",
    "        is_at_last = False\n",
    "        chosen_id = i\n",
    "        model_base_dir = os.path.join(model_base_dir, \"_\".join(subdirs[0].split(\"_\")[:-1])+\"_\"+str(i)) \n",
    "        break\n",
    "if is_at_last:\n",
    "    model_base_dir = os.path.join(model_base_dir, \"_\".join(subdirs[0].split(\"_\")[:-1])+\"_\"+str(sub_run_numbers[-1]))\n",
    "    chosen_id = sub_run_numbers[-1]\n",
    "\n",
    "if os.path.isfile(short_env_name+\"_roc_curve_\"+method+\"_js_policy.png\"):\n",
    "    print(\"Already FINISHED with results\")\n",
    "\n",
    "num_steps_per_env = 2000\n",
    "\n",
    "print(\"Model: \", model_base_dir)\n",
    "print(\"Method: \", method)\n",
    "print(\"Run ID: \", chosen_id)\n",
    "print(\"Is at last: \", is_at_last)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "objc[25813]: Class GLFWApplicationDelegate is implemented in both /Users/yannick/.mujoco/mujoco200/bin/libglfw.3.dylib (0x14e283778) and /Users/yannick/Documents/VARL/va-for-rl/venv/lib/python3.9/site-packages/glfw/libglfw.3.dylib (0x14e408740). One of the two will be used. Which one is undefined.\n",
      "objc[25813]: Class GLFWWindowDelegate is implemented in both /Users/yannick/.mujoco/mujoco200/bin/libglfw.3.dylib (0x14e283700) and /Users/yannick/Documents/VARL/va-for-rl/venv/lib/python3.9/site-packages/glfw/libglfw.3.dylib (0x14e408768). One of the two will be used. Which one is undefined.\n",
      "objc[25813]: Class GLFWContentView is implemented in both /Users/yannick/.mujoco/mujoco200/bin/libglfw.3.dylib (0x14e2837a0) and /Users/yannick/Documents/VARL/va-for-rl/venv/lib/python3.9/site-packages/glfw/libglfw.3.dylib (0x14e4087b8). One of the two will be used. Which one is undefined.\n",
      "objc[25813]: Class GLFWWindow is implemented in both /Users/yannick/.mujoco/mujoco200/bin/libglfw.3.dylib (0x14e283818) and /Users/yannick/Documents/VARL/va-for-rl/venv/lib/python3.9/site-packages/glfw/libglfw.3.dylib (0x14e408830). One of the two will be used. Which one is undefined.\n",
      "2022-05-26 17:43:20.520 Python[25813:2287766] ApplePersistenceIgnoreState: Existing state will not be touched. New state will be written to /var/folders/kp/3bh91wns7nz7wx71lyc4rwwr0000gn/T/org.python.python.savedState\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Creating offscreen glfw\n"
     ]
    }
   ],
   "source": [
    "model = PPO.load(os.path.join(model_base_dir, env_name+\".zip\"))\n",
    "\n",
    "def standard_deviation(distributions):\n",
    "    distributions = distributions.cpu().numpy()\n",
    "    return np.std([d for d in distributions])\n",
    "\n",
    "def compute_policy_uncertainty(probs):\n",
    "    return np.mean(np.std(probs.cpu().numpy(), axis=0))\n",
    "\n",
    "def js_policy_uncertainty_cont(probs):\n",
    "    probs = probs.cpu().numpy()\n",
    "    pairwise_js = []\n",
    "    for i in range(probs.shape[0]):\n",
    "        for j in range(i, probs.shape[0]):\n",
    "            pairwise_js.append(distance.jensenshannon(probs[i], probs[j]))\n",
    "    return np.max(pairwise_js)\n",
    "\n",
    "def js_policy_uncertainty(probs):\n",
    "    probs = probs.cpu().numpy()\n",
    "    pairwise_js = []\n",
    "    for i in range(probs.shape[0]):\n",
    "        for j in range(i, probs.shape[0]):\n",
    "            pairwise_js.append(distance.euclidean(probs[i], probs[j]))\n",
    "    return np.max(pairwise_js)\n",
    "    \n",
    "if env_name == \"Walker2d-v3\":\n",
    "    env = VecNormalize.load(os.path.join(model_base_dir, env_name, \"vecnormalize.pkl\"), DummyVecEnv([lambda: gym.make(env_name)]))\n",
    "else:\n",
    "    env = DummyVecEnv([lambda: gym.make(env_name)])\n",
    "\n",
    "values_buffer = []\n",
    "value_sd_buffer = []\n",
    "render_buffer = []\n",
    "iid_obs_buffer = []\n",
    "iid_policy_sd_buffer = []\n",
    "iid_js_policy_buffer = []\n",
    "\n",
    "rews = []\n",
    "obs = env.reset()\n",
    "img = env.render(mode='rgb_array')\n",
    "random_step = random.randint(0, num_steps_per_env)\n",
    "for step in range(num_steps_per_env):\n",
    "    iid_obs_buffer.append(obs)\n",
    "    action, _, dist = model.policy.predict(obs, deterministic=True, masksemble_mode=\"AVERAGE\")\n",
    "    iid_policy_sd_buffer.append(compute_policy_uncertainty(dist))\n",
    "    iid_js_policy_buffer.append(js_policy_uncertainty(dist))\n",
    "    obs, rew, done ,_ = env.step(action)\n",
    "    rews.append(rew)\n",
    "    render_buffer.append(img)\n",
    "    img = env.render(mode='rgb_array')\n",
    "    if step == random_step:\n",
    "        Image.fromarray(img).save(\"iid_img_\"+short_env_name+\"_\"+str(i)+\".png\")\n",
    "    \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "import cv2\n",
    "\n",
    "first_img = render_buffer[0]\n",
    "obs_out = cv2.VideoWriter(\"strong_\"+short_env_name+\"_\"+method+\"_iid.mp4\", cv2.VideoWriter_fourcc(*'mp4v'), 60, (first_img.shape[1], first_img.shape[0]), isColor=True)\n",
    "\n",
    "for i in range(len(render_buffer)-1):\n",
    "    # obs_frame = (file.obs[i,:,:, -1] * 255).astype(np.uint8)\n",
    "    pil_image = render_buffer[i].astype(np.uint8)\n",
    "    pil_image = cv2.cvtColor(pil_image, cv2.COLOR_RGB2BGR)\n",
    "    obs_out.write(pil_image)\n",
    "\n",
    "obs_out.release()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Creating offscreen glfw\n",
      "501\n",
      "Creating offscreen glfw\n",
      "501\n",
      "Creating offscreen glfw\n",
      "501\n",
      "Creating offscreen glfw\n",
      "501\n",
      "Creating offscreen glfw\n",
      "501\n"
     ]
    }
   ],
   "source": [
    "model = PPO.load(os.path.join(model_base_dir, env_name+\".zip\"))\n",
    "\n",
    "def standard_deviation(distributions):\n",
    "    distributions = distributions.cpu().numpy()\n",
    "    return np.std([d for d in distributions])\n",
    "\n",
    "def compute_policy_uncertainty(probs):\n",
    "    return np.mean(np.std(probs.cpu().numpy(), axis=0))\n",
    "\n",
    "def js_policy_uncertainty_cont(probs):\n",
    "    probs = probs.cpu().numpy()\n",
    "    pairwise_js = []\n",
    "    for i in range(probs.shape[0]):\n",
    "        for j in range(i, probs.shape[0]):\n",
    "            pairwise_js.append(distance.jensenshannon(probs[i], probs[j]))\n",
    "    return np.max(pairwise_js)\n",
    "\n",
    "def js_policy_uncertainty(probs):\n",
    "    probs = probs.cpu().numpy()\n",
    "    pairwise_js = []\n",
    "    for i in range(probs.shape[0]):\n",
    "        for j in range(i, probs.shape[0]):\n",
    "            pairwise_js.append(distance.euclidean(probs[i], probs[j]))\n",
    "    return np.max(pairwise_js)\n",
    "\n",
    "ood_obs_buffer = []\n",
    "ood_policy_sd_buffer = []\n",
    "ood_js_policy_buffer = []\n",
    "images = []\n",
    "rews = []\n",
    "render_buffer = []\n",
    "\n",
    "random_step = random.randint(0, 250)\n",
    "for i in range(5):\n",
    "    \n",
    "    if env_name == \"Walker2d-v3\":\n",
    "        env = VecNormalize.load(os.path.join(model_base_dir, env_name, \"vecnormalize.pkl\"), DummyVecEnv([lambda: gym.make(env_name, terminate_when_unhealthy=False, xml_file=os.path.join(\"/Users/yannick/Documents/VARL/va-for-rl\", short_env_name+\"_benchmark_configs\", \"adapted_config_\"+str(i)+\".xml\"))]))\n",
    "    elif env_name == \"Ant-v3\":\n",
    "        env = DummyVecEnv([lambda: gym.make(env_name, terminate_when_unhealthy=False, xml_file=os.path.join(\"/Users/yannick/Documents/VARL/va-for-rl\", short_env_name+\"_benchmark_configs\", \"adapted_config_\"+str(i)+\".xml\"))])\n",
    "    else:\n",
    "        env = DummyVecEnv([lambda: gym.make(env_name, xml_file=os.path.join(\"/Users/yannick/Documents/VARL/va-for-rl\", short_env_name+\"_benchmark_configs\", \"adapted_config_\"+str(i)+\".xml\"))])\n",
    "    obs = env.reset()\n",
    "    img = env.render(mode='rgb_array')\n",
    "    \n",
    "    ep_step_ctn = 0\n",
    "    while True:\n",
    "        images.append(img)\n",
    "        if ep_step_ctn > 10:\n",
    "            ood_obs_buffer.append(obs)\n",
    "            render_buffer.append(img)\n",
    "        action, _, dist = model.policy.predict(obs, deterministic=True, masksemble_mode=\"AVERAGE\")\n",
    "        ood_policy_sd_buffer.append(compute_policy_uncertainty(dist))\n",
    "        ood_js_policy_buffer.append(js_policy_uncertainty(dist))\n",
    "        obs, rew, done ,_ = env.step(action)\n",
    "        rews.append(rew)\n",
    "        if ep_step_ctn == random_step:\n",
    "            Image.fromarray(img).save(\"ood_img_\"+short_env_name+\"_\"+str(i)+\".png\")\n",
    "        img = env.render(mode='rgb_array')\n",
    "        ep_step_ctn += 1\n",
    "        if done or ep_step_ctn > 500:\n",
    "            print(ep_step_ctn)\n",
    "            break\n",
    "        \n",
    "    env.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    },
    "tags": []
   },
   "outputs": [],
   "source": [
    "import cv2\n",
    "\n",
    "first_img = render_buffer[0]\n",
    "obs_out = cv2.VideoWriter(short_env_name+\"_\"+method+\"_ood_collection.mp4\", cv2.VideoWriter_fourcc(*'mp4v'), 60, (first_img.shape[1], first_img.shape[0]), isColor=True)\n",
    "\n",
    "for i in range(len(render_buffer)-1):\n",
    "    # obs_frame = (file.obs[i,:,:, -1] * 255).astype(np.uint8)\n",
    "    pil_image = render_buffer[i].astype(np.uint8)\n",
    "    pil_image = cv2.cvtColor(pil_image, cv2.COLOR_RGB2BGR)\n",
    "    obs_out.write(pil_image)\n",
    "\n",
    "obs_out.release()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "# VALUE Uncertainty\n",
    "model = PPO.load(os.path.join(model_base_dir, env_name+\".zip\"))\n",
    "\n",
    "def standard_deviation(distributions):\n",
    "    distributions = distributions.cpu().numpy()\n",
    "    return np.std([d for d in distributions])\n",
    "\n",
    "iid_values_buffer = []\n",
    "iid_values_sd_buffer = []\n",
    "ood_values_buffer = []\n",
    "ood_values_sd_buffer = []\n",
    "for i in range(len(iid_obs_buffer)):\n",
    "    vf_obs, _ = model.policy.obs_to_tensor(iid_obs_buffer[i])\n",
    "    vf_obs = th.tile(vf_obs, (4*vf_obs.shape[0], 1, 1, 1))\n",
    "    with th.no_grad():\n",
    "        head_values = model.policy.predict_values(vf_obs)\n",
    "    iid_values_buffer.append(head_values.cpu().numpy())\n",
    "    iid_values_sd_buffer.append(standard_deviation(head_values))\n",
    "\n",
    "for i in range(len(ood_obs_buffer)):\n",
    "    vf_obs, _ = model.policy.obs_to_tensor(ood_obs_buffer[i])\n",
    "    vf_obs = th.tile(vf_obs, (4*vf_obs.shape[0], 1, 1, 1))\n",
    "    with th.no_grad():\n",
    "        head_values = model.policy.predict_values(vf_obs)\n",
    "    ood_values_buffer.append(head_values.cpu().numpy())\n",
    "    ood_values_sd_buffer.append(standard_deviation(head_values))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(500, 500, 3)\n"
     ]
    }
   ],
   "source": [
    "import cv2\n",
    "\n",
    "def norm_array(x):\n",
    "    return (x - np.min(x)) / (np.max(x) - np.min(x))\n",
    "\n",
    "normed_value_sd = norm_array(ood_values_sd_buffer)\n",
    "\n",
    "# Create Video\n",
    "def increase_brightness(img, value=30):\n",
    "    hsv = cv2.cvtColor(img, cv2.COLOR_BGR2HSV)\n",
    "    h, s, v = cv2.split(hsv)\n",
    "\n",
    "    lim = 255 - value\n",
    "    v[v > lim] = 255\n",
    "    v[v <= lim] += value\n",
    "\n",
    "    final_hsv = cv2.merge((h, s, v))\n",
    "    img = cv2.cvtColor(final_hsv, cv2.COLOR_HSV2BGR)\n",
    "    return img\n",
    "\n",
    "def increase_brightness_greyscale(img, value=30):\n",
    "\n",
    "    lim = 255 - value\n",
    "    img[img > lim] = 255\n",
    "    img[img <= lim] += value\n",
    "    return img\n",
    "\n",
    "\n",
    "\n",
    "from skimage import exposure\n",
    "first_img = render_buffer[0]\n",
    "print(first_img.shape)\n",
    "obs_out = cv2.VideoWriter(\"render_out_\"+short_env_name+\"_blinking.mp4\", cv2.VideoWriter_fourcc(*'mp4v'), 60, (first_img.shape[1], first_img.shape[0]), isColor=True)\n",
    "\n",
    "for i in range(len(render_buffer)-1):\n",
    "    # obs_frame = (file.obs[i,:,:, -1] * 255).astype(np.uint8)\n",
    "    pil_image = render_buffer[i].astype(np.uint8)\n",
    "    # pil_image = exposure.adjust_gamma(pil_image, gamma=norm_array(normed_entropies * normed_js * normed_value_dists)[i],gain=1)\n",
    "    pil_image = increase_brightness_greyscale(pil_image, value=(normed_value_sd[i] * 255).astype(np.uint8))\n",
    "    pil_image = cv2.cvtColor(pil_image, cv2.COLOR_RGB2BGR)\n",
    "    obs_out.write(pil_image)\n",
    "    \n",
    "obs_out.release()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.plot(np.concatenate([v[0] for v in iid_values_buffer] + [v[0] for v in ood_values_buffer]))\n",
    "plt.plot(np.concatenate([v[1] for v in iid_values_buffer] + [v[1] for v in ood_values_buffer]))\n",
    "plt.plot(np.concatenate([v[2] for v in iid_values_buffer] + [v[2] for v in ood_values_buffer]))\n",
    "plt.plot(np.concatenate([v[3] for v in iid_values_buffer] + [v[3] for v in ood_values_buffer]))\n",
    "plt.savefig(\"value_prediction_\"+short_env_name+\".png\", dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(np.concatenate([iid_values_sd_buffer,ood_values_sd_buffer]))\n",
    "plt.savefig(\"value_sd_\"+short_env_name+\"_\"+method+\".png\", dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXoAAAD4CAYAAADiry33AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8rg+JYAAAACXBIWXMAAAsTAAALEwEAmpwYAAAuuElEQVR4nO3deXwU9d0H8M+XcIsHSEQ5gwIqrQoawarVapVy9BHbaovaPtDqYy9qW5+2YK1I8aLqU8VKH+ShKFoRFVtFDrlvORIghBzkICQkhNzkvvb4Pn/sbLK72WN2MzszO/t9v155sTs7u/PbCfnMb37zm9+PmBlCCCGsq4fRBRBCCBFdEvRCCGFxEvRCCGFxEvRCCGFxEvRCCGFxPY0ugK/BgwdzUlKS0cUQQoiYcuTIkSpmTvT3mumCPikpCampqUYXQwghYgoRFQV6TZpuhBDC4iTohRDC4iTohRDC4iTohRDC4iTohRDC4iTohRDC4iTohRDC4iToY8yhgmrklTcYXQwhRAwx3Q1TIrgfLD8IAChcPMPgkgghYoXU6IUQwuJUBT0RTSWiHCLKJ6L5fl5/koiyiCidiLYT0SiP1xxElKb8rNOy8EIIIUILGfRElABgKYBpAMYDeIiIxvusdgxAMjNfD2AtgJc9Xmth5gnKz30aldsSjp45j1nLD6Dd7jS6KEIIC1NTo58EIJ+ZC5i5HcAaADM9V2DmnczcrDw9CGC4tsW0pnlr03GwoAaF1U1GFyUiuXJRWIiYoCbohwEo9nheoiwL5FEAmzye9yWiVCI6SET3+3sDET2urJNaWVmpokjCaF9knMOU1/ZgQ/o5o4sihAhB04uxRPRDAMkAXvFYPIqZkwE8DOB1IrrK933MvJyZk5k5OTHR73DKwmROlrlq8zlSqxfC9NQE/VkAIzyeD1eWeSGiewA8DeA+Zm5zL2fms8q/BQB2AZjYjfIKIYQIk5qgTwEwlohGE1FvALMAePWeIaKJAN6CK+QrPJYPJKI+yuPBAG4DkKVV4YUQQoQW8oYpZrYT0VwAmwEkAFjJzJlEtAhAKjOvg6upZgCAj4kIAM4oPWyuBfAWETnhOqgsZmYJeiGE0JGqO2OZeSOAjT7LFng8vifA+74EcF13CihMjtnoEgghQpA7Y0VECGR0EYQQKknQCyGExUnQCyGExUnQCyGExUnQi26RS7FCmJ8EvRBCWJwEvegWPfveNLXZkVZcq+MWhbAGCXoRM365+ijuX7of9a02o4siREyRoBfdEqyN3ulkHNewBp5eUgcAsMn4/UKERYJeRIRUtNks23MKM5fuR0phTfQLJIQISIJeRE32OdcQxqW1LQaXRIj4JkEfRfvzq/DHf58wuhhCiDgnQR9Fj6w4hNWHzhhdDCFEnJOgN5AVbjaSwSuFMD8JehERGbtSiNghQW+gWA7LaFbkT1c1Yd3x0ihuQYj4EjdBb3c4sTmzDCxtDZpS080yXFNe240nPjim/QcLEafiJuj/tiMfP33vCHacrAi9cpRszy5H9rl6w7YfK2wOORgLoaW4CfqzSl/u6qZ2Xbb3UWpxl2WPrkrFtCV7ddm+XqJ5gpRVKgdFIbQQN0Gvt105xp056EGP6wvT39iLI0VyV60Q3SVBL0yt5LzcVStEd0nQCyGExfU0ugBWY3c4kSFty0IIE5Gg19irW3KxbPcpJF3aP+S6Vuhbwpb4FkJYmzTdaCyz1DVmelWjPr17jBKN/vNCiOiQoDeQZGV45GY3ISIjQS8iIpkrROyQoLeIbVnlsDn0n2KPgpyXaF0DJ2kvEiIiEvQaKapuMmwmpS/zq/DYu6n4ny25um/brBdjG9vsuO7ZzdidW2l0UYQwnAS9Ru58ZRduXbzDkG27h3UoPt+s2zbVVK71qIG32hyobe564TuvvAENbXb8dav+Bz8hzEZV0BPRVCLKIaJ8Iprv5/UniSiLiNKJaDsRjfJ4bTYR5Sk/s7UsvBAPLjuACYu2Gl0MIUwtZNATUQKApQCmARgP4CEiGu+z2jEAycx8PYC1AF5W3jsIwLMAJgOYBOBZIhqoXfHNS4u6bHFNM05XNWnwSdZ14myd0UUQwvTU1OgnAchn5gJmbgewBsBMzxWYeSczu9sNDgIYrjz+FoCtzFzDzOcBbAUwVZui66e+1Ya6ZltY79Gi5frrL+/EXa/u0uCTYle3r+dK9yAhVAX9MACeY+6WKMsCeRTApnDeS0SPE1EqEaVWVprv4tn1C7fghkVbjC6GKTED7XYn7BH0+Pk4tRjPfJoRhVJJDx0hPGl6MZaIfgggGcAr4byPmZczczIzJycmJmpZJFOL5bqmZ5CO+9Mm3PPX3WF/xu/XpuO9g0Wq1w/WXZOZ8WHKGbS0O8IuhxBWpybozwIY4fF8uLLMCxHdA+BpAPcxc1s47xXetmWVY3NmmdHFCEthtX49fvzZm1eFeZ+cwPMbsgwthxBmpCboUwCMJaLRRNQbwCwA6zxXIKKJAN6CK+Q9Z9zYDGAKEQ1ULsJOUZZFXUphDW748xbUtYTXtq6nQI0Lj72bip++d0TXsoRLzc1Qet4w1dRmBwBUW3yMISEiETLomdkOYC5cAZ0N4CNmziSiRUR0n7LaKwAGAPiYiNKIaJ3y3hoAz8F1sEgBsEhZFnVLtuWhrsWG9JJaPTYXE77z9/342kvbNf1MPZrCmRlv7T6FGp9pIGXsGyHUUTVMMTNvBLDRZ9kCj8f3BHnvSgArIy2g0M6xM7Waf2awrNXqgujpqia8tOmkJp8lRDySO2OjxOp9PvTs1eKUmrsQ3SJBLyxNDhFCSNAjt7wBSfM34HhxbZfX1qeXYt3x0og+VwImfC3tDjic3nsu0kHTrH5GJUQ44n4qwe3Zrk5CGzPO4YYRl3i9Nnf1MQNKZKzUwhrcOHIgevRQF5VaHtCuXfAFZk4YquEnCiEAC9fozTp8bjS8tk2bERr35lXigWUHsGJfgSafF4nP0iI7gxJCBGbZoI8FWh2KCiq1GfjMPZ5+fkWjJp/nz4q9Bdh5siL0ikGouRAcP4d5IUKzbNAHm/koGJvDiefWZ+F8k3433li1PdlfP/fnN2Tjx++kqP4Mf79H6T8vRHjivo3e16aMMvxj32mc9zOZRTjCCW+rx1Z3umIGa4IL2oc/4i0KYT2WrdFHyqn0+vDt/RENeobRv46W6Lg1b1IDF8JYEvRuFs+iJz86rvs2ZahgIcxBgl50UdnQhjQ/9xXEIjmZEEKCvpPGlc9YzBd3KO7MqcT9S/cbWxhFpEEtJxNCdLJs0MdCP3r30LpCCBFNlg16o4WqUKYU1qC0rlWXsqgVSS1Yj6aRSLYhTTZCdLJs0Efaj14vR4vOa/6Zgb7xiZI67bdl4O6Vi7xChMeyQR+PAlVil+05pWs53LTqVhko14N9uhwLhOgkQW8CVs8kdw281abNxN3SL1+I8EjQu0l2RN2y3cacWQgR7yToFYdO6zKVrV9mOcZoWVFuszuwPv2c8rmuD25u16ZG73auriXkOrHQ+0qIaLNs0If7B+57g1C0WwesHj8HC6J/4Aw2X4DZL8YLoSfLBn2kfvNhmiafE4tBbsYLmMyBD7patfkLYXWWDfru1uj8hZ7N4cTaIyUdA58F0xjkZqjvLztgyfrm+vRSJM3fgOrGtpDrFlVrM4Z+INJkI0QnywZ9NCzfU4DffXwcn6ad7dbnHC407npANK36shAAcKqyKeSBLKwx6a14VBRCRxL0Ho6dCX4TU2WDq6Za22zTozhdhBo6eYNy8VNPkdac2+1Or+cV9ervEnZ31ww+Hr0cHYRwk6D38J2/f2l0EYL6j7/tM7oIHbQO0kkvbtf084QQnSwf9OebbUGnBYyFZoHS2hY4nIysc/VGFyWoVpvT7/JnPs3QdDtyw5QQ4bHsVILuJoUnPnB1wXvgpuH+1wuQGWbKklsX78BP77gy6tuJ5Du3evSNP13l/wJrfatxo3QyA7tyKnDTqIG4sG8vw8ohhJEsX6PX2968qrDf43lSEah5Zndupdfz7y87gD+s1X/WKF+rDhR1PI5WTTuSj3WfqZXWtmDO2ymGzLAlhFnEbdCnFdciaf4GZJT6H9lRzyYdzxw7cVbdSJOHC2vwUaq288Bq+Z2NahJzn8m5Dw7uu3ELKhuNKZAQJqAq6IloKhHlEFE+Ec338/odRHSUiOxE9IDPaw4iSlN+1mlV8JBlDnGxcGtWGQBgd05l0PViTXFNc9jveWxVKpLmb+j2tkMNHxxJ9nf3HCEWrsEIEW0h2+iJKAHAUgD3AigBkEJE65g5y2O1MwDmAPidn49oYeYJ3S+qUCO/shEjBvUP6z3bssujVBpvkYZ2OGHte4A307UWIYyipkY/CUA+MxcwczuANQBmeq7AzIXMnA7Af7eLGLQju8LoIqhS0dC1/3lacS3+ujVX97J4ttE/tz4ryJrqFVY1IftcQ9jvk5q8EJ3U9LoZBqDY43kJgMlhbKMvEaUCsANYzMyfhvHeqFixtwB7cl0XTQPlQYOG87kyc5dmDa0qmjV+uo66J/Z+8t5xGm0lfLnl2rSJv7kzv8uyP32agRtHDozoZi1mxsmyBlx7xUVaFE+ImKDHxdhRzJwM4GEArxPRVb4rENHjRJRKRKmVldq0mQcLgec3ZKu+6BlPwmnmMLLGvCmjDC9szPb72heZZcgOcr/B6sNnMG3JXuzNs9a1GSGCURP0ZwGM8Hg+XFmmCjOfVf4tALALwEQ/6yxn5mRmTk5MTFT70ZqIpGatRW3cyi0LRjebTFuyt+Ox7+8qq9R1ECisDv+itRCxSk3QpwAYS0Sjiag3gFkAVPWeIaKBRNRHeTwYwG0AtGm8FaYV6MzAygc3IcwsZNAzsx3AXACbAWQD+IiZM4loERHdBwBEdDMRlQB4EMBbRJSpvP1aAKlEdBzATrja6HUJ+mgOaqX1JxdVN+MPa4/D7jD2WnZ3a+Khulca2QHmVGV0h0UWwsxUDYHAzBsBbPRZtsDjcQpcTTq+7/sSwHXdLKPl/fyfR2B3Mn5w80iji6Ladj9dMvUeg0bNwVzOIoSI4ztj9Tb/k/SAr9lVTGRilC/zq7Ant+uFy5TC4EM660FNrxvfNcy7p4WIHssOaubrZJn/nhh61fjWpBSHXsmEHl5xCABQuHhG1LbhnrBECBEdlq3R+9b2Ms5qN8SvVWuFWrW8qGnr95zv9dl1mUHWDMyzvNti5AY3fxpabTL/bRBVjW3IkO7Q3WLJoN+fX4X9+dWaf+47AWqeb+7IC/o+uQ3fxTP/qxoDzxEQiU+OajvAm56uW7gFM9/cb3QxTGvGG3vxbRNNuhOLLBn0jyjNDWpEksG+FdZXtwQfbqCmWdtQ667TVU1Ifn4rSmtbovL5Dy474He5Ice7GDnI5pSHP8xDvCivDz3ZvAjOkkFvNo/8X9cDz3YDmxreP1iEqsb2LnPMGn2jU7iClTfWvosQ0SRBrwN/tbXDhTWafPaxM7URvzfSib3NIliTWMdrEvhCSNDHuqf+dSLs90htV4j4EvdBb8RkGEJH8ssSQoLeTJ7+d/i1cy1Fu3eQ1icSeRWBh0KWsxYhOknQm8jJMg16XvgJa9+Lrh2rahzsUnkWwpwk6CPgWVmsqO86w5ORVh0o9Hru747gUIOPRYuZDgRS4RfxJO6DvrvhM+nF7ZqUIxSbypEtD5/27s0z9fW9AdbUnoSnEOZkuaDflRO7t8IHU1YX/TOHYBV9u8PZrdEpX9+WC7tDvzq9e2TLWO9CKoQWLBf0c95Oifo2GMC2rHKkl9RGfVtu0WhuCScCxzy9Ce8dLIp4W69vy8OnaaonJus2CXghOsXN6JWBNEY4Cfhj76ZqXBL9RHrIWPBZJh6ZPAqbM8sier/Nrv/EKq6avYS+iG9xH/SRKDfgAqxZ2r/f3n8az2/wPzG3GeNUavZCWLDpJpRTQfpeq7V8T4EGJTEfNU3w3blWoGfkRnMqSWE9x4tr8c7+00YXI2riLui7085spGiE5OJNJ+EMMrtVUXV486xKtIpYNXPpfiz8XJfprA0Rd0Efq5xa3t3kkcgNrYGvURRWN4f1sdJIIoQ5SdDHCD1qy/NVDJAWa2Fu07FLpxBmJUEfI2IhrkIdjPRs2pGxbmJLWnEt6pptRhfDsiTo49yZmvCaZ4Llp5kORoFaumRaR3O6f+l+/Gil+pnhRHgk6GOElhVUzx4p//Fm4Lk41x8v7bLso9RiDUsiRKf0EpkAPFriLuib2x1GFyEiTRqWu1hlLf7jI10n3K4PcvE2FKlMC2GMuAt6AWw44X/YYiuRNvrY0Z0xlIQ6EvQW45lvZvsDkuwVwhgS9EI/Oib96kNn9NuY6BaT1UcsSYLeYkz9N6Nj4WL1DmgRmB5nqGY7C9aKBL0QIibokcEWzXl1QU9EU4koh4jyiWi+n9fvIKKjRGQnogd8XptNRHnKz2ytCi78M3M7uEX/hmJSYVUTnv0sI+hYR3oxvgTWFzLoiSgBwFIA0wCMB/AQEY33We0MgDkAVvu8dxCAZwFMBjAJwLNENLD7xRZCdMfP3z+KVQeKkO1nTmGz0uOAYNWDjpoa/SQA+cxcwMztANYAmOm5AjMXMnM6AN+ZJb4FYCsz1zDzeQBbAUzVoNxCBbOdhpr5bCPeuNuiW236TwYTKau2n+tBTdAPA+B5O2SJskwNVe8loseJKJWIUisrK1V+tPBH/hTUifd+9ifLGgAAiz7PNLgk5gpwM5VFS6a4GMvMy5k5mZmTExMTjS6OEHGjVIdJ57VizQjWh5qgPwtghMfz4coyNbrzXhGBWB3iQRgjlk5sdOl1E/1NGEJN0KcAGEtEo4moN4BZANap/PzNAKYQ0UDlIuwUZZmIR7GUKkI3Vg1XMwkZ9MxsBzAXroDOBvARM2cS0SIiug8AiOhmIioB8CCAt4goU3lvDYDn4DpYpABYpCwTOtD7DyhkjUv+ok0nlq5V6DHRu0Wb6NFTzUrMvBHARp9lCzwep8DVLOPvvSsBrOxGGYUQUWKGSdQLq9TNTWzVENaDKS7GCiGMYYYaffH58Ca/iSY9zhqMIEEv9GOCUBHe5FcSHyTohWbMUDsU4SET/NLUNslI003kJOgtzOaInbsehTADqx5MJOgt7KWN2bpuT3rdxB4TVOhVs2r7uR4k6C1s1QF9x2RvsQW/Was5xOtCfzEV9JLzEZOgF7pxmGBIXGE+EuDRJ0EvRBzrEUNVel2GKbboQUeCXggDWXW0xGiQfRU5CXoh4ljs1Of1YdULvhL0QhjI6EqqKfrRa7ye6EqCXggDGR1exse8ejI5eOQk6IUwkOHtzrGU9DrKLK3DkaLzRhdDM6pGrxRCWFNM5byOE4/MeGMfAKBw8Yzob1QHUqMXwkBGtxSYoo1e5VmNVS+U6kGCXggDGd1yI7wZ3pQWJRL0Is6Y6w/Z6Fqq8fV59SyawbqQoBcijpnhzljpXhl9EvRCGEhqqerPKvRoVrHqr0OCXggTKa1twefHS3Xbngkq9JYNVzOR7pUibqSX1BpdhC58K6m3Lt4BAJj21cvRM0HqYZ5kULPIyf8kETf251cbXQTV9Mobc3Sv1HY90ZUEvRAGCtTrRq9QMz7mTcaiBxMJeiEMFCjQnTolvQkq9KoZ3RU1lknQi7gRKiicTkbG2TqdSuMSqETSTOGHLkMgWHPHS9ALofjf3afw7b/tw9Ezxg9mpVeN3gz96C3bXmIiEvRCKLJK6wG4ujjqJVDfcL2C/vKL++qyHS1Ir5vISdAL4aZUbvWcwzzQpvQqww3DL9ZnQxqwagjrQYJeCIURjRiBwsuqg2uZnVX3ugS9iEvkJ9bdfcrNELJ6nlXECr0ulG5IP6fLdvSkKuiJaCoR5RBRPhHN9/N6HyL6UHn9EBElKcuTiKiFiNKUn2Ual18IzbijX9ecN7hG795McU0zkuZvwGdpZ3XZbiQOFlQjaf4GpBXXRnU7v1x9NKqfb4SQQU9ECQCWApgGYDyAh4hovM9qjwI4z8xjALwG4C8er51i5gnKz880KrcQmnN3QNGzi13AG6Z0K4FLbnkDAOCzNP3G2XFTe0zbebISAHDgVPTucDbD2Vw0qKnRTwKQz8wFzNwOYA2AmT7rzASwSnm8FsA3yQz3VgsRBiNq9IHb6PUrA+BxkDMg6NQmhTUjWB9qgn4YgGKP5yXKMr/rMLMdQB2AS5XXRhPRMSLaTURf97cBInqciFKJKLWysjKsLyCEVnp0tNEbXBAYd+OOEVsdPrC/qvXMMkwxMyNp/gYs3nQy6uXRSrQvxp4DMJKZJwJ4EsBqIrrIdyVmXs7MycycnJiYGOUiCRFAR9ONfgJuS+8aPYw/yPXvnWDcxsPgvlC+bPcpYwsSBjVBfxbACI/nw5Vlftchop4ALgZQzcxtzFwNAMx8BMApAOO6W2ghosEddnrdrAQErqXqnbd2Jb1McDITkNwwFTk1QZ8CYCwRjSai3gBmAVjns846ALOVxw8A2MHMTESJysVcENGVAMYCKNCm6EJoy4irSkaPdePezCubXc0QaSYY/iEQ90HR6Kt/sXjBNuTEI8xsJ6K5ADYDSACwkpkziWgRgFRmXgfgHwDeI6J8ADVwHQwA4A4Ai4jIBsAJ4GfMXBONLyKElejVRu/OrILKJgBAfatdl+1GQo98teqgZqpmmGLmjQA2+ixb4PG4FcCDft73CYBPullGIfRlgl43um0fxteSt2WXAwCa2x1B13PvK6O788XioUDujBVCYcgQCAZPPNIRngYm/cepJarW06W2HYsproIEvYgragJU19P3QP3odd58DwOryT1iLIWMPguLRIztYiGip/OmIWPL4SqDvlV6c4xLH5w+bfRq1jHBf5AwSdCLuBEqKDr6kutQFjeje904TdDu7XSqWy/24tU8JOhF3DhaFLzroBGV2rK6Vv036qF3T1cExEKNXg+qmvZi8IhjqaAvrzf2j0aY2/aTFUFfX5PiGunD5lBZxdTAF5llfpdHO0ymX3c5AKBngivgjcz5QM1UFQ2teHNHnsd6epXIelR1r4wVW7LKjS6CsICWEN389BDtdmB3aJqh102gsfef/PA49uVXeSyRpI+UpWr0cvIptGCGVoxo1159P9/IXjeBDmpN7d43b0W6Tw4WVOOJD46pusCt5gAbi2cW1gp6E/yBCqEFvbPEyDZ6tbNphWp6C2T2ysNYd7wUbfbQTXI7ItyG2Vkq6OWCkog1Rs0Z61tzNbLpZujFfXXZjppd+vS/M0J/Tgw2IVks6I0ugbACM8zXqtsNU0r6JXgkged0gueb2vFhypmoluGRyaMAANde0WUEc7/CPSZpPXOYNN0YrKqx3egiCJPLUabMC0bPYYoD0buN3nOy9F+vSUNdsw0A8MSaY5j3yQnkV4TebxFTNq22ouZvYnc165vg12oYSwX9K5tzjC6CMLljZ2oBAEXVTQHX0XUqwcC3TEV5u8q/ygPfkLUrdzFVNrQBAGyOKJYnytMpdtbotRGLxwtLBb0Qar21J/C0CE492248NmXEOOcdY934JL17ufvsxgqXvwLt36Y2dUMz1zXb8M7+09Ycj16IeGPUn7HTK/Sju62u3Su9k9wd8J1DA0cv6d1nNe12Jw4WVOOWKy8N8Y7wuEse6PjdrqI3DgA89e90bDxRhqTBF2hTMB1JjV7ErYZWm9/lRrXRewZOtEvgG+Rnapq9V2Cvf6Jao3eXIa+iEbOWH0ROmet6QFpxrSaf36TcANfdaRvPN7n+v7Ta9LtzWisS9CJuXbdwC9rsXe+CNajlBtcu+KJzOQMphTU4VdkYle3aQ3zJzjZ89+iWUSmG17bc6gMcgLsr0FdWe2DvHN1U3frvHyrCwYJqVetGmzTdiLjWanOiT88Er2V6tsEGqikzGA8uOwAAKFw8Q/PtOpSLrVuyyjB+aNdujexToy8534Ixl12oeTlabQ6UnPc+m+hBwEepxZpvK1CgO1Qe2cO9qOvukx+N31+4pEYv4pufv9q+vRKwZFueLhdlb7tqsN/loabV6y53L5rM0nr817upXV53+iT9nLdTolKOP6xNx9Kdp7yW/fS9o1i4LlPzbdU0tXc5qADqB7FzX8f4/HippuXSgwS9iGttjq6B+srmHLy2LRdv7syPyjab2uyYvfIwimuaA97N/d2/fxmVbQOuaxOhhgNoUCYJ91cLbrU5VNeCQ/EetMylqrEtZNNSJKa8tge3/2Vnl+XBvsv5ps57c9yD3W3K6BxxVO2FXH9abQ7UtUSnmcqXBL2Ia/88UBTwtYIotY9vySrD7txKvLolx5Db6a9buAXHQ1zo/P3a4wCAwuquNeBrnvkCT3xwTJOyJARo/Ld3Y6joR1YcxO8/Pq56/WAHlYnPbe147K/mvyXL/zDTalzzzBe44c9bAAB/3ZKDfXldD3pakaAXca2ysS3ga5+mRecU3X3TlsPJprlY5+tURfCD3IYT57yeN7bZUVgV+Ca0QAJdDglWoXdfrN2TW+k3fPfnV+PjIyXYk1sZ9MY4t1Zb8GayRnc/+xBdj06W1WPd8dKQTX6VDW2oaPCeO+ONHfn44T8OhSxrpORirIhrbUpXOT1vknpXOYtYn34OfXqGrmudLKvHO/sLMfCC3vjtPeM6ZoWKpqZ2B6p9DoIOJ2PlvtNeyzJL6/BxaglWHz6Ddruzy4XHHSfLcVXiAIy61H/f86ogB9pA/rYjH3eOS8R/rjyMn955JX435WrsPFmBe8cP8Rqc7T9XHg75WWdrWzDjjX1B16lsaMOAPv6j8mhRLeauPoa9f7gLU1/fCwB44oNjWPWTSV7rHSk6jysHX4CBF/TGzS9sC7iteWvT8ZcHrg9Z7nBJ0Iu4ZlMCfleu/+FpmVnTkR0zztZ5PR96ST+cDlETdgcIAPTrlYA5tyXh2Jla3Dku0We9PeiV0AOf/+p2r+VOJ8PJjJ4J4R0gbnreO5Cu+uNGr+dJ8zd0eU9NUzuczBg8oA9a2h34yTuuC71/nH4NHp48CjllDRh/xUXo1zuhy3vD8T9bcgG4zjyWbMvDmzvzseonk7rsE3+cTkaPHoQXN2ZjeZA7pN2mLdmDp6df6/eWsZX7XQe+r7/s3fY/2+Mg892/78fRM7VI6EE49eJ0v+Vx+zC1WII+GK0uDon4klNWD6eTkVVa7/f10U9tDKt7nM3hRA+igG3PvrOgzbp5BF7adFL15ze22fHEB8ewK6cSh5/+Ji67sHOI35NlnQOPbTpxDtePuATDLumH2W8fxt68Kmz57R0Ye9kA1duKxI1Km/Zjt4/GCo/a/4sbT+LFjd7fU+1olf4cUJq89uVXdXSPPd/U7vfg4+vTtLP4479PqL7xqdXmxDOfRd4L6KhHU52/8l3pcwCNBssEfU2TPiNX9unZQ9UEBkIbh/74TTy0/CAKImj/VSO3vBFrUorRHmTQrp+9dwRfZJZh6MV9ce/4IRg+sD9uHXMpxg25EA4n45XNOfjV3WNQ0dCGKa/twUV9e+Lw0/egb6/OWuubO/Jw+9jELu3BnxwtCau85+pasSunEgDQ2u5xJ61HY/edr+xEkZ+LqFNe24N7rr0srO1FaoVPE48/2ef8H1zD0Wpzdlwv+M2Haare8+RH6i/UWgWZbYCe5ORkTk3t2q83lPNN7V5XyD3dPmYwTlc14Wxti9/X33hooqpeBMMu6Yf5067Br1T2OJhzaxLe+bJQ1brd8etvjsWgC3rjWRV9jwf06dl5cUnx829chf/ddSrAO4zz5L3j8MQ3x2LZ7lNYHKTWu+onk7xOlfXUu2ePkF3sfnPPWLy+zTXJ9Y9uGYX3Dgbu6ROO138wAWOHDEBxTQt+9s8jmnxmPHv3J5NUtetHW6Q3WBHREWZO9veaZXrd+I6+5+nHtyXhX7+4FbeN8T9Y0n03DMXfH7kRD00aifceneR3nQt6J2D1f03Gf9wwFNuevBMP3DTc73pLZk3A/ROG4u05N2PhfV/Burm3AYDXRbcNT9yOq4d03mU4+2ujsO3JO/GKT9tc317ev57ff+tqvPWjm5C9aCoAoFcCYd+8u/Dbe8fh7mtcNbW/PTQR371xWMB98fz9XwXgClG330252u+6vUO06T48eSR+dMuooOu4fT73dnzwX7cEXWfDE7fjv+8dh/cfm4zn7v8qfnX3GACuZoAXv3Od17pzbk0CAMy4/grcOS4RBS9Ox0vfda3zwne+ilMvTkfeC9MwbsiAqN6+r6YftTvkAWgW8oCrBjvjjX3dCvm9f7gLz3x7PL574zAMu6SfZmWLRf17J5jiLtZosEzTTU+fv+a0Bffije35WLn/NK5KHIAhF/XF+4/d0tFGNuSiPiivb8Mjk0cCAKZfdwWmX3cFAODoM/d2tDXun383Fnyagb89PBH9e7t215jLBuDVB2/Ay9+7Hs02B9JLavHw/x3CgD49MXPCMMyc0Bm07hOm3h5NPl8ZejE+m3sbrnnGNbbJhX17YcxlAzqCNenS/lj8vesxeEBv7MurwsLPswAAv7zLFXzucLljbCKGD+wPABgxqH/Hf9LcIJNr3D9xGKZddzn69EzAiEH9MPTifkjoQShcPAO7ciqwJascqw+5ZhQ68ecpuPpPrjJu/+87cVXiALy0KRsThl+CvflVeHr6tejbKwG/uWcstp+swLBL+uGRFd5dxE4+NxVO5o595881l1+Ivz9yI65MHICvDL0YAHDbmM47Rnsm9MDDk0eioqG1IzQX3vcV/OzOqzDwgl4AXAf6hyaNxPduHN7RKyUBhM2/uQPM+rSDdsc/Zifj0VXhn8l214hB/fHo7aMBAOuOl2rWP15rd19zWdTncz1d1YTkpEGYP+0ajB58AX76nnXOkizTdNNqc3QEJ+A6/WFmNLc7cIFH16jc8gZMeW0P3nhoIiYlDcKlA3qjl5+a6/78KhCAW8f4v0Xd17sHCnHbmMG4KtH7YpfTyXhuQxYemjQSU17bg7uuTsTbP3adNZyra8FnaaWYc2tSR3uuv14e27LKMXxQP1xzeefFq1OVjRh6cT+/vRdsDifGPr2p4/nnc2/Hyv2n0dBqw4rZN4f8LvkVDUjo0QOjB1+A4ppmZJbWY+pXL1e1H4DO3hhfzr8bQ31qiT946wCOnjmPj392K8ZeNsDrd6PGeweLMGJgP3zj6vDamn0vgh175t6ATX0AMPUrl+OLzMhvhglX4eIZeHNHHl5VepPouV03Zsa/jp5Fjx7Abz/Uvx37n49OxrjLB2DSC9sBAB8+fgv69U7AZRf2xaUDeuMX7x/FVp+L2Vp6+YHr8f3kER3Pp76+x+sCtx78/c2oFazpRlXQE9FUAEsAJABYwcyLfV7vA+BdADcBqAbwA2YuVF57CsCjABwAnmDmzcG2FWnQe4ab7y8sHrmDbc6tSVh431cMLo3xPIN+06+/jmuvuAgL12V2uYayb95duKB3Twy8oDfuX7pfs6FyQylcPANOJ6O0rgVF1c1dzowiMWX8kC69fPxt1x/PitPKOcnYnVOJVQHuIr64Xy98+svbcNeru1SV655rh+D+iUMxd7X32YO7LBln6zB4QB9c7mfS8EkvbEOFMuvVklkTcLqqCf86erbLMMujLu2PXb/7Bq5d8AVabU6cenF6l+6hVw+5EG/96CZ8Qyl3zvNTuwxwV1HfikkvbvdatvN338BojzHpk+ZvwB3jEpE4oA8+OVrS5drcHeMSseDb41FR34qHld/rnFuTkHWuHodP1+CdH9+May6/CJdd2CdoE3QowYIezBz0B65wPwXgSgC9ARwHMN5nnV8AWKY8ngXgQ+XxeGX9PgBGK5+TEGx7N910E0fq2JnzXNfSHvH7reRESS2Pmree04trjS6KKYyat56//pcdXZY3t9n50XdSeM3hInY6nUE/o6nNxrf/ZTuPmreei6qaeEN6Kc9ZeYgXrsvgX75/hLdllfFVT23gHSfLeV9eZcf7yutb+IcrDvLmjHM8at56HjVvPf/PlpyOx7/455Eu28oqreMTJZ2/u/qWdp7w5838p3+f4PXHS/n3H6fxqHnredmufB41bz0v2ZbLdoeTnU4nn6lu6njfudoWZmZuszm4vN71+Mv8Kh41bz3vyC4P+n1PVzbywVNVHc/zyht4ybZcbmm3MzNzyflmfvazDLY7XPut3e7o2Icpp6s7/hZtdge32RxdPv/lL7J51Lz1/PrWXK5ubAtaFje7w8lf5ldxZUOr1/Lapnaua2lnh8PJ27LKOsrR0m7nVpu94/s0tdn4hQ1ZvCWzrKPcGWdr+c0deSG33WZzcEV9q9/l7n3f1GZjm93BmzPOcWOrrWNfedqVU9FRJi0BSOUAuRqyRk9EXwOwkJm/pTx/SjlAvOSxzmZlnQNE1BNAGYBEAPM91/VcL9D2Iq3RC2F2zIw3tufjuzcOw/CB/fDPg0UYPqg/7gqzGUoLNofTb5OlnhxORkFlI8YO0X7443gUrEavpoF0GADPwaFLAEwOtA4z24moDsClyvKDPu/t0iWEiB4H8DgAjBw5UkWRhIg9RIRf3zO24/mPvpZkWFmMDnnANaCZhLw+jP9tA2Dm5cyczMzJiYmhb2EWQgihnpqgPwvA88rmcGWZ33WUppuL4booq+a9QgghokhN0KcAGEtEo4moN1wXW9f5rLMOwGzl8QMAdigXB9YBmEVEfYhoNICxAIy/9UwIIeJIyDZ6pc19LoDNcPXAWcnMmUS0CK6rvOsA/APAe0SUD6AGroMBlPU+ApAFwA7gl8wc3TnShBBCeLHMDVNCCBHP4mKsGyGEEP5J0AshhMVJ0AshhMWZro2eiCoBdGcs18EAojedemyRfeFN9kcn2RferLA/RjGz3xuRTBf03UVEqYEuSMQb2RfeZH90kn3hzer7Q5puhBDC4iTohRDC4qwY9MuNLoCJyL7wJvujk+wLb5beH5ZroxdCCOHNijV6IYQQHiTohRDC4iwT9EQ0lYhyiCifiOYbXZ5oIaKVRFRBRBkeywYR0VYiylP+HagsJyJ6Q9kn6UR0o8d7Zivr5xHRbH/bMjsiGkFEO4koi4gyiejXyvJ43R99iegwER1X9sefleWjieiQ8r0/VEahhTKq7IfK8kNElOTxWU8py3OI6FsGfaVuI6IEIjpGROuV5/G5LwLNMRhLP1Axr61VfgDcAeBGABkey14GMF95PB/AX5TH0wFsAkAAbgFwSFk+CECB8u9A5fFAo79bBPviCgA3Ko8vBJAL1zzF8bo/CMAA5XEvAIeU7/kRgFnK8mUAfq481myuZ7P+AHgSwGoA65XncbkvrFKjnwQgn5kLmLkdwBoAMw0uU1Qw8x64hoL2NBPAKuXxKgD3eyx/l10OAriEiK4A8C0AW5m5hpnPA9gKYGrUC68xZj7HzEeVxw0AsuGaqjJe9wczc6PytJfywwDuBrBWWe67P9z7aS2AbxIRKcvXMHMbM58GkA/X31hMIaLhAGYAWKE8J8TpvrBK0Pub17bL3LQWNoSZzymPywAMUR4H2i+W21/KqfZEuGqxcbs/lKaKNAAVcB2wTgGoZWa7sornd/Oa6xmA51zPVtgfrwP4AwCn8vxSxOm+sErQCwW7zjfjqs8sEQ0A8AmA3zBzvedr8bY/mNnBzBPgmrZzEoBrjC2RMYjo2wAqmPmI0WUxA6sEfbzPTVuuNEFA+bdCWR5ov1hmfxFRL7hC/n1m/peyOG73hxsz1wLYCeBrcDVRuWeT8/xuVp7r+TYA9xFRIVxNuXcDWIL43BeWCXo189pameecvbMBfOax/D+V3ia3AKhTmjQ2A5hCRAOVHilTlGUxRWlD/QeAbGb+q8dL8bo/EonoEuVxPwD3wnXdYidcczkDXfeHJed6ZuanmHk4MyfBlQc7mPkRxOG+AGCNXjeu3wemw9Xr4hSAp40uTxS/5wcAzgGwwdVe+ChcbYnbAeQB2AZgkLIuAViq7JMTAJI9PucncF1YygfwY6O/V4T74na4mmXSAaQpP9PjeH9cD+CYsj8yACxQll8JVzjlA/gYQB9leV/leb7y+pUen/W0sp9yAEwz+rt1c798A529buJyX8gQCEIIYXFWaboRQggRgAS9EEJYnAS9EEJYnAS9EEJYnAS9EEJYnAS9EEJYnAS9EEJY3P8DsoUgnZoNMOQAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(np.concatenate([iid_policy_sd_buffer,ood_policy_sd_buffer]))\n",
    "plt.savefig(\"policy_sd_\"+short_env_name+\"_\"+method+\".png\", dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(np.concatenate([iid_js_policy_buffer,ood_js_policy_buffer]))\n",
    "plt.savefig(\"js_policy_sd_\"+short_env_name+\"_\"+method+\".png\", dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "from sklearn.metrics import roc_curve, auc\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.preprocessing import label_binarize\n",
    "from sklearn.multiclass import OneVsRestClassifier\n",
    "from sklearn.metrics import roc_auc_score\n",
    "\n",
    "# Compute micro-average ROC curve and ROC area\n",
    "value_fpr, value_tpr, _ = roc_curve([0 for _ in range(0,len(iid_obs_buffer))] + [1 for _ in range(0,len(ood_obs_buffer))], iid_values_sd_buffer + ood_values_sd_buffer)\n",
    "value_roc_auc = auc(value_fpr, value_tpr)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYoAAAEWCAYAAAB42tAoAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8rg+JYAAAACXBIWXMAAAsTAAALEwEAmpwYAABLIUlEQVR4nO3dd3hUZfbA8e9JT+iEIr1LERAUKaKCKEXgh66iiIqry6qIWMDFBiqLZS2IonQV0WVtWLEAAqIgSJPeRJoQOkgLISHl/P64N2ESkskAmUwmOZ/nyZO5/cydO3Pufd9731dUFWOMMSYnIYEOwBhjTMFmicIYY4xXliiMMcZ4ZYnCGGOMV5YojDHGeGWJwhhjjFdFPlGIyF0i8ovHcFsR+UNE4kXkhrNdPpBE5CcR+Weg48hrBWEfi8h2Ebk2h2ntRSTuPNbdWUS+Oov5J4vI8+e6vfxS0OIUkadE5J1Ax+FPIlJRRDaISGRerjfoE0V2X+Dz/GEZDoxW1eKq+pW7vs4iMk9EjovIARH5WUR6nGfouRIRFZG6/t5ODtue677XYyKySkSu9zLvMDfWh7OMf9gdP8zvAQe3F4CX0gfE8ZCIrBWREyISJyJTRaRJAGPMcyJSSUTeFpHd7onZVje5NPDH9lT1RVX9p7vtmu6xGXa26xGR1u7nUjybaStEZMC5xHc+MaVT1X3AXODec11HdoI+UfhBDWBd+oCI9ASmAh8AVYGKwDPA/wUkuvzzMFBJVUviHHRTRKSSl/k3AXdmGfd3d7zJgYhcBpRS1UUeo0fh7P+HgLLAhcBXQLd8D9BPRCQWWAjEAFcCJYBLgJ+Bjjksc84/oHnJ/azigJ6e40WkMdAI+CgQcXnsn/8B9+XluotEohCRJ0Rki3tFsF5E/pbDfFuA2sA37hlOJDASeE5V31HVo6qapqo/q+o9WZYdISKHRWSbiFznMb6UiLwrIntEZJeIPC8ioR7T/+FeKh4WkZkiUsMdP8+dZZUbSy8RKSMi37pn+ofd11WzvI0aIrLAfa8/iEi5HN7r9KxnPu6Vw40AqrpaVVPcSQqEA9W87OalQIyIXOSu6yIgyh2fvn6v8btXglvd2LeJyO05xP6qiPzi7tu67hXeURE5KCKfeMzXQERmichfIvK7iNziMW2yiIx190O8u88uEJE33Ng2ikjzLJu+zD1+DovIeyISlUN8lUXkc/d9bhORh7zst+twfhzTl60HPAD0VtUfVTVJVRNU9X+q+pLHcmVE5Dt3Xy0WkToe6xglIjvFuRr8TUSu9Jg2TEQ+FZEP3GXXiUgLj+mXuGfFx8W5ivlEPIqPRKS7iKwUkSMislBEmnpMay4iy91lP8H5/HMyEDgG9FHVLeo4oqrvqepb7vrSz7D7isgO4Ed3/FQR2et+5vM8jrlW7njP79ffRGS1x3uf4k5K/34dcT//du5x0sRj2QoikiAi5bOJ/33OPDG6E/heVQ/lcuxFi8hrIvKn+x5+EZHobGJqIyIhIjLUnXe/+7mV8rZ/gMVAbXF/S/KEqgb1H7AduDbLuLuAXzyGbwYq4yTGXsAJnLPl7ObNWB/QAOdHspaX7d8FJAP3AKHA/cBuQNzpXwITgGJABWAJcJ877XpgM9AQCAOGAgs91q1AXY/hWOAmnLOwEjhXOl95TP8J2IJzBhrtDr+UQ9x3Ags8hhsBR4BIj3HfAoluHDOAkBzWNQyYAjwFvOyOewV40h0/LLf43f1zDKjvDlcCLvL8jNzP721gJhDjTvsIGOJOiwKu8FjfTuBud982Bw4Cjdzpk93hS93lfgS2ufslFHgemJvluFiLkyzLAguA591p7YE493UI8BvOVWcEzonHVqBzDvtuKjDYY7gf8Gcux/xk4BDQ0n1v/wM+9ph+h7uvw4BHgb1AlMdnlQh0dd/nf4BF7rQI4E+cq5lw4EbglMf7bA7sB1q5y/7d3S+RHssOdJftifO9eD6H97Ao/bjw8j5r4hx7H7ifZ7Q7/h84x08k8Aaw0mOZLUDHLPv3Cc/jNMu6wzzmHYt7/LrDDwPf5BBbNSAFqObxuccBN5D7sTcG57tZxd2Pl7vvJbuY/oHzG1EbKA58AfzX2/5xp60GeuTZ72xerShQf+6BGo/zI5f+l4DHj382y6wErndf30XOiaKt+0FEeVnXXcBmj+EYd5kLcIqpkrJ8gL1xf4CA6UBfj2khbuw13OFMiSKbbTcDDnsM/wQM9RjuD8zIYdkSOAkzfVsvAJOymS8c56x3kJc4huEkhOrADneZHe6XKSNReIvfPdCP4CSS6Czz3YVzlvQJ8DkQ4THtA2AiUDXLMr2A+VnGTQCedV9PBt72mPYgsMFjuAlwJMtx0c9juCuwxX3dntOJohWwI8t2nwTey2EfzMqy3iG4P9xe9vdk4J0ssWz0Mv9h4GKPz2q2x7RGwEn39VXALtyTHHfcL5xOFONwrq491/070M5ddneWZReSc6LYnOV993A//+PAD+64mjjfgdpe3ltpd55S7vDzuMcxZx7jw/CeKFrhHLfpJ3nLgFu8bHs28JT7uiNwAOfYz/HYw/mOn0z/PLLMk11Mc4D+HsP1cRJwmLf9g3Mic6e34+hs/gpL0dMNqlo6/Q/nBzKDiNzpcbl8BGgMZFskk8Uh97+3snlwztgAUNUE92VxnPqOcGCPx7Yn4FxZ4E4f5THtL0BwzjTOICIxIjLBvQw9hnOpWtrzUtszFpykU9xddrx7ORsvIk+p6nHgO+BWd97eOGemmahqsqpOBzpJLhX4qroD5wfgReAPVd3pa/yqegLnC9bP3V/fSeZKzbo4V2D/VtVTHuMfw9lnS9xilH+442sArdL3rbt/b8dJ4On2ebw+mc1w1spKz/fzJ85ValY1gMpZtvsUzklDdg7j/KClO0Tuxxvk8DkDiMi/xCnOPOpuvxSZj/esy0aJU75dGdil7i+Ny/M91wAezfLeqrnLZbfsn17iz/Q+VXWa+90diHN14ikjBhEJFZGXxClKPoaTwPF4fx8CN4pTbHwjsFxVvcWRQVUX4+yP9u6xVxeY5mWR94E+7us+OFd1yXg/9srhXMFu8SUmnP3qGf+fOEnC83jK9D1zlcBJvHmisCSKHLnldG8DA4BY92Bci/PjkpvfcT6Em85x8ztxrijKeSSykqp6kcf0+zyTnKpGq+rCHNb3KM4ZRSt1Kpmvcsfn+l5UtZ86d3IVV9UX3dEfAb1FpA3OwTvXyyrCgDpepqf7wI3zg7ONX1VnqmpHnB+QjTifW7oNOJfy00Wkvsf72quq96hqZZwKvLHi3Cm2E/g5y74trqr3+/AecuJZR1Md5ww6q53AtizbLaGqXXNY52qcosJ0c4CqnvUGZ0Oc+ojHgFuAMu7xfhTfjvc9QBUR8ZzX8z3vBF7I8t5iVPWjHJat7mVbc4AbRMSX3yDP5HMbzgnDtTgJsKY7Pv0YWo/zY3qdO++HPqzT0/s4RXd9gM9UNdFLXF/gfFZX4ySl993x3o69gzhFf9l9l7KLaTdO4klXHafIy/OkJtNybtKvC6zyEvtZKfSJAqdIQ3EuCxGRu3GuKHLlnh0NAp4WkbtFpKRbuXSFiEz0Yfk9wA/Aax7L1hGRdu4s44EnPSrjSonIzR6r2IdTNpmuBM6Z7hERKYtzKXs+vsc5CIcDn6hqmhtHAxG5zq10CxeRO3B+1H/2sq50nwCdgE+zmZZj/OLc/329iBTDSa7xQJrnwu4P0lPAbHErb0XkZjldIX4Y57NOw6lfuVBE+rjvIVxELhORhr7smBw8ICJV3diHuO81qyXAcRF53N1/oSLSWJy7m7LzPU7RTfp7/AOnrPwjcZ7PiBCRKBG5VUSe8CHGEjg/JAeAMBF5Bijp4/v7FUgFBohImDi3RLf0mP420E+cSmMRkWIi0k1ESrjLpgAPufv6xizLZjUSKAP81/1OiLueZj68vyScK5IYnKvXrD7EqV+4CqeOIjsHcI6T2lnGTwH+hpMssjvZyeBeBX8GvIdTr7TMnZTjsed+xyYBI8W56SFUnErryBxi+ggYKCK1xLkd90Wc72oKOWsJbPf1SsoXhT5RuGcYr+EcyPtwyp4XnMXyn+EUifwDJ7vvwykH/drHVdyJcym9HueH7DPcS25V/RJ4GfjYvYxei3MmlG4Y8L57+XoLTsVdNM5ZySKcCuZzpqpJOGdF15L5zEvcbe/HOXgfBnqp6nIf1nlSVWer6slsJnuLPwQnKe/GKYJrh3NjQNb1v4+T2H4UkZrAZcBiEYnHKSZ4WFW3ukVrnXCK1nbjFLe8jFNpeK4+xEn8W3GKDs54mExVU4HuOD9429z3+g7O2e8Z3H16VERaeYx+CBiNU+l5xN3W34BvfIhxJs5+3YRzZp1I9kUT2cVyCufMuK+73TtwfvSS3OnLcG7aGI1zLG/GqT/yXPYunM+vF86xldO2DgKt3fh+wambWImTCLxd9X3gvq9dON+pRdnM8xHO8fOju53stp+AUy+3wP1+tXbH7wSW45xwzPcSR7r3cU62MpKKD8fev4A1OHcE/uVOC8khpknAf3GKabfh7K8Hc4npdpyT0DyTXmljjAkQEemEU2F5Q6BjyUpEFgPjVfW9QMeSX0RkErBbVYcGOpazJSIVcK78m+dSbHZ267VEYYxJ5xaL/o5zJZR+ZlrbLUYt9Nyr1JU4P7TbAhtNwVHoi56MMWelPk4l6BGcmw96FqEk8RxO8e+rliQysysKY4wxXtkVhTHGGK8KRCNbZ6NcuXJas2bNQIdhjDFB5bfffjuoqtm1W5WroEsUNWvWZNmyZbnPaIwxJoOInPNzFVb0ZIwxxitLFMYYY7yyRGGMMcYrSxTGGGO8skRhjDHGK0sUxhhjvPJbohCRSeL08bo2h+kiIm+KyGYRWS0il/grFmOMMefOn89RTMZpjjinNt2vA+q5f61wullslcO8xhhjzkZKEhzdAicPcmrn0vNald8SharOc1tizMn1wAdu50CLRKS0iFQqKg2QGWNMnkg+CbvmwZGtkHQENk2F/SsyJg/+piMrdvvSu27OAvlkdhUyd6gS5447I1GIyL3AvQDVq3vrXdEYYwqpU/FwaB3s/BkkBNJOwY65sGO218UaX7CfNxe0Pq9NB0UTHqo6EZgI0KJFC2vu1hhTOMXvgYT9kJoEexZDSBigsHoCHFjtfdnYRpCWwvrI3izfVoI7Hu4FJapypyrt/jxKrVrPnXNYgUwUu8jccXtVd5wxxhQ+qnBki5ME0lJAU5xio43/g12/wKH1oGm5r+eClhAaCVXaOv81FZo/SAJleP75ebz66kJCQ0/S+tYY6pYAEaFmzdLnFXogE8U0nE7cP8apxD5q9RPGmKB2bAfsmAOHN0FIBOyaD2FRTiI4ddz39VxwmVO8lHgYqneAtFQnuVz1CsSUO2P26dP/4IEHPmLbtiMA9O17KbGx0Xn0pvyYKETkI6A9UE5E4oBngXAAVR0PfA90xemgPQG421+xGGNMnktJhK3fwbbpsG8ZHFjl23IxFaFYRZAwp2gpLRkiSsKlg6BMXSjbEER8WtWuXcd45JGZfPbZegCaNq3I+PHdaNOmWi5Lnh1/3vXUO5fpCjzgr+0bY8w5U4WUBDixF3YtcIp3Uk/B3iXOXUW5XR3Uug6KVYIyFzrLlb8YStWC2IZuvUPeeOCB7/n669+JiQln+PD2PPxwa8LC8v7xuKCozDbGGL84dRwO/wFHt0HyCZh1j1NPkJbi+zoiS0HDO6BcE+evchufrwjORUpKWkYyePnlawkPD+W11zpRvXopv23TEoUxpmhQhfhd8Ou/YcePcOoYnDzofZmoWEg8BBWaO/UGoZHOFUK1q6F2V4gokT+xA0ePJjJ06I9s2vQXM2bcjohQv345pk692e/btkRhjCk8NM15zmDPYvjjMwiLccYl7HXuOMpJ5bZwfAfU6AQJ++DqN5yiIgl8c3iqytSp63nkkRns2RNPaKiwcuVemjc/v4fozoYlCmNMcEs8DGvehXmDfV+m3k3Q8Hao1BqKXeDXoqLzsWXLXwwYMJ0ZMzYD0KZNVcaP707TphXzNQ5LFMaY4LBjLhz5A1ZPhINrIbqcU5SUVUi4cydRswEQHesUE4VFO7epxl4EIaH5H/s5GDFiIU8/PZfExBRKl47i5Zev5Z//vISQkPxPapYojDGBlZYCKSfh+C7Yu9i5yyiylPNjn3gY/vzBufsoq6xJIqYiXPdfqNkxf+L2s4SEZBITU+jTpykjRnSiQoViAYvFEoUxJn8c2+k+gbwOfnsdSlRx7jg6W80fgoji0OA2JzmER0N44H5E88qBAyf4/fdDXHGF057d44+3pX37mlx1VY0AR2aJwhjjT4c2wre3wME1Z07LmiSiy8PJA06FcrGKzp1GIRFOhXJMBecJ5agy+RN3PkpLUyZNWsFjj80iLCyEjRsHULZsNJGRYQUiSYAlCmNMXkk8DEc2O81XLH7RabsoO7GN4IJWUP1qp/4gslS+3mZakKxdu59+/b5lwQKnIe2OHWuTkJBM2bJ51/xGXrBEYYzxXfJJ2PylkxCOxznFSH9tcJKENxfdDU3vhUqtCuwdRvnpxIlTDB/+MyNHLiIlJY2KFYvxxhtd6NXrIqQA7h9LFMaY7J3YC6vfhk2fOncZ+arMhVCiGpSqDVe8mG0jdkVdz55TmTFjMyLQv38LXnjhGkqXjgp0WDmyRGFMUZaaDMd3wvYZEDffuUIICXP+p57yvmzNLnBBC4goBbW7Q+naEBqRP3EHuccfb8u+ffGMG9eNVq2qBjqcXFmiMKYoOLEPvunp9JJ2YKVzl1Bacu7JAKBmZ6h+jfOQWrFKzl1GxmcpKWm89dZitm8/wqhR1wHQvn1Nli27NyDPRJwLSxTGFDaH1sPuX2HFaKc5ihPZdPOSfCLzcJkLnXGN7nRaOi3bwKlgLlWzQDRjEayWLNnFffd9y8qVznMg9957KRddVAEgaJIEWKIwJvioOpXHqUkQNw/WvAN7FkFyfO7LhkbADdOgZE0oWcMZtkSQ544cSeSpp+YwfvwyVKFGjVKMHt01I0kEG0sUxhRkx+OcXtNO7IGt38L6D3zrLhOcOoSIEtDkHihbH0pW92+sBoCPP17LI4/MYN++E4SFhfDoo214+umrKFYseOtvLFEYE2hpKfDnLPhzDhzb5jxktnOuU2zkTXQ5p64hOQHaPAuVWjq9o4XH2FVCAP3wwxb27TtB27bVGDeuG02a5G8Dfv5gicKY/HQqHta+B3E/OVcLe5f4tlxUWajWHiQULnnY7RzHkkFBkJSUwq5dx6ld23lq/JVXOnLlldX5+9+bBVU9hDeWKIzxp0MbYE5/CC/uFB3l5uJ+Ti9pxS5w+lK4oCVEl/V/nOac/PjjNu6//ztCQoRVq/oRERFKuXIx3H1380CHlqcsURiTl1KTIe5n+G0kbJue83yl6zjNV9S6Dso3c55BMEFj3754/vWvWUyZshqABg3KERd3LOOqorCxRGHM2UpJgtRE5zbUvUtgwdNOA3Zx83JepuEdUPcGp8ioeOV8C9XkrbQ05e23f+OJJ+Zw5EgiUVFhDB16JYMHtyUiIjj6uTgXliiMyY2qU2z09Q0533F0RpIQaHoPXDIQYhv4O0KTT/72t0+YNu13ADp3rsOYMV2pU6fwFw1aojDGk6Y5RUYJ+50H0H55Ck4dz3n+4lWdvpUrNIdGd0Cxyk4/C6ZQuvHGBixZsotRo7pw882NCmQDfv5gicIYVdj4ISx6wWkJ1Zur34Cm9zndappCb9q034mLO0b//pcBcOedF3PjjQ0pUSIywJHlL0sUpuhIPuG0iHp4k/PcwsaPnNtVc3qi+eJ+zp1HEgqX/9vaOCpCduw4ykMPTefrr38nMjKULl3qUrt2GUSkyCUJsERhCrOURNi/AtZNhtUTfVum7XNw6cBC0bWmOXvJyam8+eZinn32J06cSKZEiQief74DNWqUCnRoAWWJwhQemga7FsAn7QDNeb7ock69QnR5uPBmaHArhEZahzpF3KJFcdx337esXu08EX/zzY14/fXOVKlSMsCRBZ4lChO8Eo/Awmdg01SnSCkn6c1aXPEfqNkx38IzweXpp+eyevU+atUqzejRXenatV6gQyowLFGYgi31FGz4n/OE8/7lcGAVnDzofRkJdfpQ6PI+RMfalYLJlqpy/PgpSpZ06hxGj76ODz5YxZAhVxETEx7g6AoWSxSmYDmxD3b+BEe3wZq34ejW3Jep1AbaPA2VL4fIol2WbHzz++8H6d//e0Rg1qw+iAj165fjhReuCXRoBZIlChNYp+Kdbjj3LXf6VTh5IOd52zzr1C+Uv9jpj7l4ZbtaMGclMTGF//xnPi+9tIBTp1KJjY1m+/Yj1KpVOJveyCuWKEz+UoUt0+D3T51nF3JSph5U6wDlm0Kd6+0hNnPeZs3aQv/+37N5818A/OMfzXjllY7ExsYEOLKCz6+JQkS6AKOAUOAdVX0py/TqwPtAaXeeJ1T1e3/GZAJo89dOMxjZqdDcuVKo0Bya3msPtJk8o6r07TuN995bCUCjRuUZP74bV15ZI7CBBRG/JQoRCQXGAB2BOGCpiExT1fUesw0FPlXVcSLSCPgeqOmvmEw+O74Lpt0I8bucv6xaDYH6vaB8k/yPzRQZIkLNmqWJjg7jmWfaMWhQm0LdgJ8/+POKoiWwWVW3AojIx8D1gGeiUCD9JuVSwG4/xmP8SRUO/wG7fnH+1r2X87y3/ATV2uVbaKboWblyL3v2HOe665xbXB9/vC19+jS1uohz5M9EUQXY6TEcB7TKMs8w4AcReRAoBlyb3YpE5F7gXoDq1a3f3wLlyFb4pqfzBHROomLhuvehwiVQvFL+xWaKnOPHk3j22Z8YNWoxsbHRbNw4gLJlo4mMDLMkcR4CXZndG5isqq+JSBvgvyLSWDVzW86qOhGYCNCiRQsvj9wav1F1+l744wtA4M8fsk8OYTFQoRmUuRAuHwYlrRzY+J+q8tVXG3nooRnExR0jJES47bYmhIdbd7F5wZ+JYhdQzWO4qjvOU1+gC4Cq/ioiUUA5YL8f4zK+SEmELd/AwbWw/gM4tt37/LW7wzWjLTGYfPfnn0cYMGA63367CYAWLSozYUJ3LrnErl7zij8TxVKgnojUwkkQtwK3ZZlnB3ANMFlEGgJRgJcb6Y3fpKU4ralu+NB5rsGbWl2hZicICYfKbZ1bWO15BhMAqspNN33Kb7/toWTJSF58sQP9+rUgNNSuJPKS3xKFqqaIyABgJs6tr5NUdZ2IDAeWqeo04FHgbREZiFOxfZeqWtFSfko+CZ93ciqgsxNV1mkOo3JbpytPe57BFABpaUpIiCAijBjRifHjl/H6652pVKlEoEMrlCTYfpdbtGihy5YtC3QYwS1+Dyx6zrkzKSUx87TIUnDZY9DwditGMgXOoUMJPPHEbADefrtHgKMJLiLym6q2OJdlA12ZbfLT7Pth1ficp/9zG5SqmW/hGOMrVeWDD1bxr3/N4uDBBCIiQnn22fZUrWpNgOcHSxSF3bGdsOItWPbqmdPq9IDGfaFOdxAr0zUF04YNB7j//u/4+ec/AWjfvibjxnWzJJGPLFEUNke2OInhwCqnFdbs3LnKqYA2pgBTVZ55Zi4vv7yA5OQ0ypWL4bXXOtGnT1PEbp7IV5YoChNNg3frZj+tUmvo9qHTs5sxQUBE2LXrOMnJadxzzyW89NK1lC1r/ZYHgiWKYJeaDLsXwPe3Q7xHCyiXPQ5l68MFl0G5xoGLz5izsHv3cQ4eTKBp04oAvPJKR/r2bU7bttYiQyBZoghWiUdgTA5NEtTvBVe9lP00Ywqg1NQ0xo1bxpAhP1KlSglWruxHREQo5crFUK6cJYlAs0QRjPYthymXnjm+9TPQYpD18maCyvLle7jvvm9Ztsy5Ir7qqhocO5ZEuXLWT0RBYYkiWCQchO96wY4fM4+vciXcOi8wMRlzHo4dS+Lpp39k9OilpKUpVauW5M03u3DDDQ2ssrqA8TlRiEiMqib4MxiTg5n/hLXvnjm+/etwycP5H48x50lVueqq91i1ah+hocKgQa0ZNqw9JUpEBjo0k41cE4WIXA68AxQHqovIxcB9qtrf38EVecf+hLdrZh5Xvil0nwplLwxISMbkBRFh4MDWjB27jAkTutOs2QWBDsl4kWsTHiKyGOgJTFPV5u64taoakFtpikQTHoc2Oj3D/bUh8/gHj0NE8cDEZMx5OHUqlZEjfyU0VBg8uC3gXFWkpak14JdP/N6Eh6ruzFJmmHouGzO5OHkIxpY7c3yH0dD8gfyPx5g8MH/+n/Tr9x3r1x8gMjKUO++8mIoViyMihIZaXUQw8CVR7HSLn1REwoGHgQ25LGPO1s+DYdmIzOPKXww3/wjRZQMTkzHn4eDBBB57bBbvvbcSgHr1yjJ2bDcqVrSr4mDjS6LoB4zC6dp0F/ADYPUT5ystxamD2PotzH0k87TWz0DbfwckLGPOl6oyefJKBg+exaFDJ4mICOXJJ6/giSeuICrKbrQMRr58avVV9XbPESLSFljgn5AKuZOHYPqdsO377KdbPYQpBKZMWcOhQyfp0KEWY8d2pX79bIpUTdDwJVG8BVziwziTm087wM65mccVqwQxFeGywdAwaweAxgSHhIRkjh5NpFKlEogIY8d2ZenS3dx+exN7JqIQyDFRiEgb4HKgvIgM8phUEqfHOuMrVdi9MHOSuLAnXDMWYsoHLi5j8sD06X/wwAPfU7t2GWbN6oOIUL9+ObuKKES8XVFE4Dw7EQZ49i94DOd2WZMbVdi1AD65MvP4gSkQYrnWBLddu47xyCMz+eyz9QCUKBHJoUMnremNQijHRKGqPwM/i8hkVf0zH2MKfqqweiLM7nfmtFZDLEmYoJaamsaYMUsZOvRHjh8/RbFi4QwffjUPPdSKsDB7JqIw8qWOIkFEXgUuAqLSR6pqB79FFcy+vhE2f3nm+Kb3QscJ+R+PMXkoLU1p124yCxbsBOCGGxowalQXqle3higLM18Sxf+AT4DuOLfK/h044M+gglLyCXi/KRzdmnl8yyfh8mEQGhGQsIzJSyEhQqdOddix4yijR3elR4/6gQ7J5ANfmvD4TVUvFZHVqtrUHbdUVS/LlwizKJBNeHzR7czbXR8+CWFR2c9vTJBQVT79dB1hYSHcdFMjAJKSUkhOTqN4cTv5CSb+bsIj2f2/R0S6AbsBe1RYFWbcBes/yDy+1nVwwzQIsQeLTHDbsuUv+vf/nh9+2EL58jF06FCLMmWiiYwMI9IaeS1SfPk1e15ESgGP4jw/URJ4xJ9BFXhpKc5VxJ8/ZB7/cCKE2TfIBLekpBRefXUhL7wwn8TEFMqUieKFFzpQqpRdIRdVuSYKVf3WfXkUuBoynswumo7HwcRqmcfdfwBi7J5xE/x++mk799//HRs3HgSgT5+mjBjRiQoVigU4MhNI3h64CwVuwWnjaYaqrhWR7sBTQDTQPH9CLEDid2dOElFloM8qSxKmUEhNTaN/fydJ1K8fy7hx3bj66lqBDssUAN6uKN4FqgFLgDdFZDfQAnhCVb/Kh9gKjoSD8GU32Lvk9LiL/g5dJgcsJGPyQlqakpiYQkxMOKGhIYwb14158/7kscfaEhlp9WzG4e1IaAE0VdU0EYkC9gJ1VPVQ/oRWQJw6DuOyNLNx0d3QZVJg4jEmj6xZs49+/b6jQYNY3n33egDatatJu3Y1AxuYKXC8JYpTqpoGoKqJIrK1yCWJzV/D1zecHr7gMrhpplPkZEyQOnHiFMOH/8zIkYtISUlj27bDHD58kjJlogMdmimgvCWKBiKy2n0tQB13WABNf6aiUPNMElbUZAqBb775nQEDprNjx1FEoH//FrzwwjWULm13NJmceUsUDfMtioIm8TBMuvD0cMeJ0PSewMVjzHlKSUmjV6/P+OILp3PKZs0uYMKE7rRsWSXAkZlg4K1RwKLXEKCmOX1WJx7OPN6ShAlyYWEhlCoVSfHiETz33NUMGNDSGvAzPvPrkSIiXUTkdxHZLCJP5DDPLSKyXkTWiciH/ozHq7hfYGRo5iTR6ikYlBqwkIw5H4sXx7F4cVzG8KuvdmTDhgd45JHWliTMWfHb/W/ucxhjgI5AHLBURKap6nqPeeoBTwJtVfWwiFTwVzxenYrP3GdEiWrwz63WDIcJSkeOJPLkk7OZMOE3GjQox8qV/YiICCU21vqJMOfGp19CEYkGqqvq72ex7pbAZlXd6q7jY+B6YL3HPPcAY1T1MICq7j+L9eeN5BPwlke/TLf8BNXa5XsYxpwvVeWjj9YyaNBM9u07QVhYCD161Cc1NQ3rlNKcj1wThYj8HzACp8e7WiLSDBiuqj1yWbQKsNNjOA5olWWeC91tLMA5koep6gzfQs8DaSnwZvHTw2XqWZIwQemPPw7Rv//3zJ7tNHPftm01xo/vTuPGgblIN4WLL1cUw3CuDn4CUNWVIpJXz/WHAfWA9kBVYJ6INFHVI54zici9wL0A1atXz6NNA7M8eqCrfDnc+kverduYfJKcnEqHDh8QF3eMsmWjeeWVa7n77uaEhEigQzOFhE/NjKvqUZFMB533Tiwcu3CaAElX1R3nKQ5YrKrJwDYR2YSTOJZm2pjqRGAiOP1R+LDt3B2Pg7Xvnh7uvSBPVmtMflFVRITw8FBeeKEDc+du55VXrqV8eWvAz+QtX259WCcitwGhIlJPRN4CFvqw3FKgnojUEpEI4FZgWpZ5vsK5mkBEyuEURWXpIs4Plr6auXG/Piv8vklj8sq+ffH06fMlzz8/L2PcnXdezHvvXW9JwviFL4niQZz+spOAD3GaG38kt4VUNQUYAMwENgCfquo6ERkuIun1GzOBQyKyHpgLDPZ7MyFpqTDvsdPDV70CFZr5dZPG5IW0NGXChGU0aDCGKVNWM3LkIo4fTwp0WKYI8KUr1EtUdXk+xZOr8+oK9eRfMDb29HDXKdDw9rwJzBg/WrVqL/36fceiRc5zEV261GXMmK7Urm3tjhnf+Lsr1NdE5ALgM+ATVV17LhsqEN7JUgff4LbAxGGMj5KTU3nyyTm88cYiUlOVSpWKM2pUF3r2bESWekNj/CbXoidVvRqnZ7sDwAQRWSMiQ/0eWV5KPgFTWsCpY85w5cthUBrYF80UcGFhIaxYsZe0NOXBB1uyYcMD3HzzRZYkTL7Ktegp08wiTYDHgF6qGuG3qLw466Kn6X+H9R9kHmdJwhRgO3YcJTU1jVq1nGKlP/44xNGjSbRoUTnAkZlgdj5FT7leUYhIQxEZJiJrgPQ7nqqey8byVdIxeE0yJ4na3WFgsiUJUyAlJ6cyYsRCGjYcwz33fEP6SVy9erGWJExA+VJHMQn4BOisqrv9HE/e2fhR5uGHT0KYtblvCqZff91Jv37fsXr1PgDKlo0mISGZYsUCcuFuTCa5JgpVbZMfgeS5pCPO/3KN4e9rAhqKMTk5fPgkTzwxm4kTnRsLa9UqzZgxXbnuunoBjsyY03JMFCLyqare4hY5eVZkFPwe7lRhvtuqeYk8bPLDmDyUlJRCs2YT2LHjKOHhIQwefDlDhlxFTEx4oEMzJhNvVxQPu/+750cgeWr/ytOvG/UJWBjGeBMZGUbfvs2ZM2cb48Z1o1Gj8oEOyZhs+fLA3cuq+nhu4/JLrnc9pSTCKI9O4h/Nm6ahjDlfiYkp/Oc/86lfvxy33dYEcLooDQ0Vu93V+J1f73rC6Xgoq+vOZWP5Yu2k069bB9fjHqbwmjVrC02ajGP48HkMHDiTkyeTAec5CUsSpqDzVkdxP9AfqC0iqz0mlQAKblOrcx44/brtc4GLwxhg7954Bg2ayUcfOQ0aXHRRecaP7050tNVDmODhrY7iQ2A68B/As7/r46r6l1+jOheqMKHK6eHL/x24WEyRl5qaxoQJv/HUU3M4ejSJ6Ogwnn22HQMHtiEiwnqbM8HFW6JQVd0uIg9knSAiZQtcsvi8C5zYc3q49dOBi8UUeampyltvLeHo0SS6dq3H6NHXZTxpbUywye2KojvwG87tsZ4FqQrU9mNcZ+/PH06/HphiT1+bfHf8eBKpqUrp0lFERITy9tv/x7598dx4Y0OrhzBBLcdEoard3f951e1p/rh1AYTYpb3JP6rKl19u5KGHptO5cx3effd6AK64wp7hMYWDL209tRWRYu7rO0RkpIgUrG9AwsHTr8s3CVwcpsjZvv0IPXp8zE03fcquXcdZu/YAiYkpgQ7LmDzly+2x44AEEbkYeBTYAvzXr1GdrTn3n34dUSJwcZgiIzk5lZdf/oVGjcbw7bebKFkyktGjr2Phwn8QFeVLE2rGBA9fjugUVVURuR4Yrarvikhffwfms+QE2PSZ89oa/TP5ICEhmdat32HNmv0A3HprY0aO7ESlSnaSYgonXxLFcRF5EugDXCkiIUDBuQn8w1anX/f+NXBxmCIjJiacFi0qk5CQzNix3ejUqU6gQzLGr3xJFL2A24B/qOpet37iVf+G5aOE/XDQ7Zk1JAwqNAtoOKZwUlU++GAVdeqUzaigfv31zkREhNqDc6ZI8KUr1L3A/4BSItIdSFTVD3JZLH/Muu/06/6HAheHKbQ2bDjA1Ve/z113fc29937DqVOpAJQqFWVJwhQZvtz1dAuwBLgZuAVYLCI9/R2YTzZ/5fyv1AYiSwY0FFO4nDyZzNChP3LxxeP5+ec/KV8+hiefvILwcF/u/zCmcPGl6GkIcJmq7gcQkfLAbOAzfwaWqx0/nn59zZjAxWEKnRkzNvPAA9+zdethAO655xJeeulaypaNzmVJYwonXxJFSHqScB3Ct9tq/WvqNadfV2weuDhMoRIff4o+fb7k4MEEGjeuwPjx3WjbtmA9NmRMfvMlUcwQkZlAeifUvYDv/ReSD45sOf269TOBi8MUCqmpaaSlKeHhoRQvHsGoUV2IizvGwIGtCQ+3p/yNybXjIgARuRG4wh2cr6pf+jUqL1q0aKHLnqkBf3zhjBiY7NzxZMw5+O233dx337dcf319nn66XaDDMcZvzqfjIm/9UdQDRgB1gDXAv1R117mFmMfSk0SjPpYkzDk5diyJp5/+kdGjl5KWphw7lsQTT1xhVxDGZMNbXcMk4FvgJpwWZN/Kl4h8ERXr/K97Q0DDMMFHVZk6dR0NGozmzTeXIAKDBrVm+fL7LEkYkwNvp+MlVPVt9/XvIrI8PwLySaL7zESVKwMbhwkqx48n0avXZ0yfvhmAVq2qMH58d5o1uyDAkRlTsHlLFFEi0pzT/VBEew6ramASR+qp068jSwckBBOcihePICkplVKlInnppWu5995LCQmxfiKMyY23RLEHGOkxvNdjWIEO/grKq0SPjvVC7clY4928eX9SqVJx6tWLRUSYNKkHUVFhVKxYPNChGRM0vHVcdHV+BuKz9J7CStYMaBimYDt4MIHHHpvFe++t5JprajFrVh9EhBo1Sgc6NGOCTvDdMnTquPO/WsHMYyaw0tKUyZNXMnjwLP766yQREaFceWV1UlOVsDArZjLmXPj1CWsR6SIiv4vIZhF5wst8N4mIikju9/iGuMVN1kGRyWLduv20bz+Zvn2n8ddfJ7nmmlqsWXM/zz7bnrCwwDcmYEyw8tsVhYiEAmOAjkAcsFREpqnq+izzlQAeBhb7tOKkI87/0tYHgDnt6NFEWrd+l/j4U1SoUIyRIztx221NELGrCGPOV66JQpxv2u1AbVUd7vZHcYGqLsll0ZbAZlXd6q7nY+B6YH2W+Z4DXgYG+xZxFBAPUWV9mt0UbqqKiFCqVBSPP96WXbuO8eKL11CmjDXgZ0xe8eV6fCzQBujtDh/HuVLITRVgp8dwnDsug4hcAlRT1e+8rUhE7hWRZSKyLPlUsjOyRDUfQjCF1a5dx+jZ81OmTFmdMW7IkCsZN667JQlj8pgviaKVqj4AJAKo6mEg4nw37HapOhJ4NLd5VXWiqrZQ1RbhJJ3vpk0QS0lJY9SoRTRoMIbPP9/As8/+RGpqGoAVMxnjJ77UUSS79Q0KGf1RpPmw3C7A87S/qjsuXQmgMfCT+wW/AJgmIj1UdVmOa5VQIBViyvsQgilMli7dRb9+37F8+R4AbrihAW++2YXQUKuoNsaffEkUbwJfAhVE5AWgJzDUh+WWAvVEpBZOgrgVp+9tAFT1KFAufVhEfsJpeDDnJAGgTleURFfwIQRTGJw4cYrHH5/N2LFLUYXq1Uvx1lvX0aNH/UCHZkyRkGuiUNX/ichvwDU4zXfcoKobfFguRUQGADOBUGCSqq4TkeHAMlWddl6RR9iTtUVFWFgIs2dvJSREGDSoDc8+245ixc679NMY46Nc+6Nw73I6g6ru8EtEuWhRTXTZvy+Ef/weiM2bfLJly1+ULh1FbGwM4BQ7RUWF0aRJxQBHZkxw8kt/FB6+w6mfECAKqAX8Dlx0LhvME8UrB2zTxr+SklJ49dWFvPDCfG6/vQnvvNMDgMsuq5LLksYYf/Gl6KmJ57B7S2t/v0VkiqyfftrO/fd/x8aNBwHnDqfU1DSrrDYmwM76yWxVXS4irfwRjM9SkwO6eZO39u8/weDBs/jgg1UA1K8fy7hx3bj66loBjswYA749mT3IYzAEuATY7beIfOHZ1LgJagcPJtCw4Rj++uskkZGhDBlyJY891pbIyOBrr9KYwsqXb6Nn63spOHUWn/snHB9VvSqgmzd5p1y5GK6/vj5xcccYO7Ybdeta0yzGFDReE4X7oF0JVf1XPsXjmzL1Ah2BOUcnTpxi+PCf6dbtQq66qgYAY8d2IzIy1J6sNqaAyjFRiEiY+yxE2/wMyCcVz+kOLxNg33zzOwMGTGfHjqN8990frF59PyEhQlSUFTMZU5B5+4YuwamPWCki04CpwIn0iar6hZ9jy5mdeQaVnTuP8vDDM/jyy40ANG9+ARMmdLf+qo0JEr6cykUBh3D6yE5/nkKBwCUKExRSUtJ4883FPPPMXE6cSKZ48Qief/5qHnigpXUkZEwQ8ZYoKrh3PK3ldIJI5/1xbmOAY8eS+M9/fuHEiWRuuqkhb7zRhapVSwY6LGPMWfKWKEKB4mROEOksUZhsHTmSSHR0GJGRYZQtG82ECd2JjAylW7cLAx2aMeYceUsUe1R1eL5FYoKaqvLRR2sZOHAmAwZcxtNPtwPgxhsbBjgyY8z58pYorKbR+GTTpkP07/8dc+ZsA2DevB0ZXZQaY4Kft0RxTb5FYYJSYmIKL7/8Cy+++AunTqVStmw0r77akbvuamZJwphCJMdEoarWTobJ0d698Vx11Xv88YdzmNx1VzNefbUj5crFBDgyY0xeC9InnexsNdAqVixGtWqlCAsLYdy4brRrVzPQIRlj/CQ4E0XZBoGOoMhJS1Pefvs3rr66FhdeGIuI8OGHN1KmTDQREaGBDs8Y40fB+dSTBGfYwWrVqr20bTuJfv2+o3//70jvFbFixeKWJIwpAoLzisLki/j4Uwwb9hNvvLGI1FSlcuUS9Otn7WwZU9RYojDZ+uqrjTz44HTi4o4REiI8+GBLnn++AyVLRgY6NGNMPrNEYc6wa9cxbr31M5KSUrn00kqMH9+dFi2sn3JjiipLFAaA5ORUwsJCEBGqVCnJCy90ICIilP79L7M+q40p4uwXwLBw4U4uvXQiU6aszhj36KOX8+CDrSxJGGMsURRlf/11kvvu+4a2bSexZs1+xo5dlnFHkzHGpLOipyJIVZkyZTWPPvoDBw4kEB4ewmOPtWXIkCut6Q1jzBksURQx+/bF07v358ydux2Adu1qMG5cNxo2LB/YwIwxBZYliiKmdOko9uyJp1y5GEaM6Midd15sVxHGGK8sURQBs2Zt4ZJLKhEbG0NkZBhTp95MpUrFiY21BvyMMbmzyuxCbM+e4/Tu/TmdOk3h8cdnZ4xv3LiCJQljjM/siqIQSk1NY8KE33jyyTkcO5ZEdHQY9evHWmdCxphzYomikFm+fA/9+n3L0qW7AejWrR6jR3elZs3SgQ3MGBO0LFEUItu3H6Fly7dJTVWqVCnBm29ex9/+1sCuIowx58WviUJEugCjgFDgHVV9Kcv0QcA/gRTgAPAPVf3TnzEVZjVrlubuu5tRokQk//53e0qUsAb8jDHnz2+V2SISCowBrgMaAb1FpFGW2VYALVS1KfAZ8Iq/4imMtm8/wv/930f8/PP2jHETJ/4fI0d2tiRhjMkz/ryiaAlsVtWtACLyMXA9sD59BlWd6zH/IuAOP8ZTaCQnpzJy5K/8+98/c/JkCgcPJvDrr30BrJjJGJPn/Hl7bBVgp8dwnDsuJ32B6dlNEJF7RWSZiCzLw/iC0i+/7KB58wk88cQcTp5M4dZbG/PFF7cEOixjTCFWICqzReQOoAXQLrvpqjoRmAjQopoUyVbrDh8+yeDBs3j33RUA1KlThrFju9GpU50AR2aMKez8mSh2AdU8hqu64zIRkWuBIUA7VU3yYzxBLS1N+frr3wkPD+GJJ67gySevIDo6PNBhGWOKAH8miqVAPRGphZMgbgVu85xBRJoDE4Auqrrfj7EEpY0bD1KrVmkiI8OIjY3hf/+7kerVS9GgQblAh2aMKUL8VkehqinAAGAmsAH4VFXXichwEenhzvYqUByYKiIrRWSav+IJJgkJyQwZMoemTcfxyisLMsZ36lTHkoQxJt/5tY5CVb8Hvs8y7hmP19f6c/vBaMaMzfTv/x3bth0B4ODBhMAGZIwp8gpEZbaB3buP88gjM5g61bl7uEmTCowf353LL6+Wy5LGGONfligKgE2bDtGixUSOHz9FTEw4w4a145FHWhMeHhro0IwxxhJFQVCvXlkuu6wKxYqF89Zb11GjRulAh2SMMRksUQTAsWNJPPPMXPr3v4wLL4xFRJg27VaKFYsIdGjGGHMGSxT5SFX57LP1PPzwDPbsiWfjxoPMmOG0WmJJwhhTUFmiyCdbtx5mwIDvmT59MwCtW1fl5Zftpi9jTMFnicLPTp1KZcSIhTz33DwSE1MoXTqKl166hnvuuZSQEGvAzxhT8Fmi8LOdO48yfPjPJCWlcvvtTXjttU5UrFg80GEZY4zPLFH4weHDJyldOgoRoU6dsowa1YW6dctyzTW1Ax2aMcacNX82M17kpKUpkyatoG7dt5gyZXXG+Pvua2FJwhgTtCxR5JF16/bTvv1k+vadxl9/ncyotDbGmGBnRU/nKSEhmeee+5kRI34lJSWNChWK8frrnendu3GgQzPGmDxhieI8bNp0iM6dp7B9+xFEoF+/S3nxxWsoUyY60KEZY0yesURxHmrUKEVUVBgXX1yR8eO707p11UCHZAqY5ORk4uLiSExMDHQopoiIioqiatWqhIfnXcdmlijOQkpKGuPHL6N378bExsYQGRnGjBm3U6VKScLCrLrHnCkuLo4SJUpQs2ZNROy5GeNfqsqhQ4eIi4ujVq1aebZe+3Xz0ZIlu2jZ8m0efHA6jz8+O2N8jRqlLUmYHCUmJhIbG2tJwuQLESE2NjbPr2DtiiIXR48mMmTIj4wduxRVqF69FNdfXz/QYZkgYknC5Cd/HG+WKHKgqnzyyToGDpzJ3r3xhIWFMGhQa555pp014GeMKVKszCQHq1bto3fvz9m7N57LL6/G8uX38vLLHS1JmKATGhpKs2bNaNy4Mf/3f//HkSNHMqatW7eODh06UL9+ferVq8dzzz2HqmZMnz59Oi1atKBRo0Y0b96cRx99NADvwLsVK1bQt2/fQIeRo6SkJHr16kXdunVp1aoV27dvz3a+119/nYsuuojGjRvTu3fvM4qPHnroIYoXP938z+jRo5k0aZI/Qz9NVYPq79KqqCYcVH9ISUnNNDxw4Ax9++3fNDU1zS/bM4Xf+vXrAx2CFitWLOP1nXfeqc8//7yqqiYkJGjt2rV15syZqqp64sQJ7dKli44ePVpVVdesWaO1a9fWDRs2qKpqSkqKjh07Nk9jS05OPu919OzZU1euXJmv2zwbY8aM0fvuu09VVT/66CO95ZZbzpgnLi5Oa9asqQkJCaqqevPNN+t7772XMX3p0qV6xx13ZPosT5w4oc2aNct2m9kdd8AyPcffXSt6cs2du43+/b9nwoTuXHVVDQBGjuwc4KhMofKan+oqHtXc53G1adOG1aud5mU+/PBD2rZtS6dOnQCIiYlh9OjRtG/fngceeIBXXnmFIUOG0KBBA8C5Mrn//vvPWGd8fDwPPvggy5YtQ0R49tlnuemmmyhevDjx8fEAfPbZZ3z77bdMnjyZu+66i6ioKFasWEHbtm354osvWLlyJaVLlwagXr16/PLLL4SEhNCvXz927NgBwBtvvEHbtm0zbfv48eOsXr2aiy++GIAlS5bw8MMPk5iYSHR0NO+99x7169dn8uTJfPHFF8THx5Oamsr333/Pgw8+yNq1a0lOTmbYsGFcf/31bN++nT59+nDixAnAOWu//PLLfd6/2fn6668ZNmwYAD179mTAgAGo6hl1CSkpKZw8eZLw8HASEhKoXLkyAKmpqQwePJgPP/yQL7/8MmP+mJgYatasyZIlS2jZsuV5xZibIp8o9u8/weDBs/jgg1UAjBz5a0aiMKYwSU1NZc6cORnFNOvWrePSSy/NNE+dOnWIj4/n2LFjrF271qeipueee45SpUqxZs0aAA4fPpzrMnFxcSxcuJDQ0FBSU1P58ssvufvuu1m8eDE1atSgYsWK3HbbbQwcOJArrriCHTt20LlzZzZs2JBpPcuWLaNx49OtIDRo0ID58+cTFhbG7Nmzeeqpp/j8888BWL58OatXr6Zs2bI89dRTdOjQgUmTJnHkyBFatmzJtddeS4UKFZg1axZRUVH88ccf9O7dm2XLlp0R/5VXXsnx48fPGD9ixAiuvTZzPzO7du2iWrVqAISFhVGqVCkOHTpEuXLlMuapUqUK//rXv6hevTrR0dF06tQpI4GPHj2aHj16UKlSpTO216JFC+bPn2+Jwl/S0pR3313O44/P5vDhRCIjQxk69CoGDz6/swdjcnQWZ/556eTJkzRr1oxdu3bRsGFDOnbsmKfrnz17Nh9//HHGcJkyZXJd5uabbyY0NBSAXr16MXz4cO6++24+/vhjevXqlbHe9evXZyxz7Ngx4uPjM5XT79mzh/Lly2cMHz16lL///e/88ccfiAjJyckZ0zp27EjZsmUB+OGHH5g2bRojRowAnNuYd+zYQeXKlRkwYAArV64kNDSUTZs2ZRv//Pnzc32PZ+Pw4cN8/fXXbNu2jdKlS3PzzTczZcoUOnTowNSpU/npp5+yXa5ChQps3LgxT2PJTpFMFNu2HeaOO75k4cKdAHTqVIcxY7pSt27ZAEdmTN6Ljo5m5cqVJCQk0LlzZ8aMGcNDDz1Eo0aNmDdvXqZ5t27dSvHixSlZsiQXXXQRv/32W0axztnyLFrJWjFbrFixjNdt2rRh8+bNHDhwgK+++oqhQ4cCkJaWxqJFi4iKivL63jzX/fTTT3P11Vfz5Zdfsn37dtq3b5/tNlWVzz//nPr1M9/qPmzYMCpWrMiqVatIS0vLcdtnc0VRpUoVdu7cSdWqVUlJSeHo0aPExsZmmmf27NnUqlUrI+ndeOONLFy4kDJlyrB582bq1q0LQEJCAnXr1mXzZqfR0fQiNn8rknc9lSwZyaZNh7jgguJ8/PFNzJhxuyUJU+jFxMTw5ptv8tprr5GSksLtt9/OL7/8wuzZzgOkJ0+e5KGHHuKxxx4DYPDgwbz44osZZ9VpaWmMHz/+jPV27NiRMWPGZAynFz1VrFiRDRs2kJaWlqlsPSsR4W9/+xuDBg2iYcOGGT+inTp14q233sqYb+XKlWcs27Bhw4wfTXCuKKpUqQLA5MmTc9xm586deeuttzLu8FqxYkXG8pUqVSIkJIT//ve/pKamZrv8/PnzWbly5Rl/WZMEQI8ePXj//fcBp66mQ4cOZ9RPVK9enUWLFpGQkICqMmfOHBo2bEi3bt3Yu3cv27dvZ/v27cTExGR6v5s2bcpU9OYvRSZRzJy5maSkFABiY2OYNu1WNm58gF69GtsDUabIaN68OU2bNuWjjz4iOjqar7/+mueff5769evTpEkTLrvsMgYMGABA06ZNeeONN+jduzcNGzakcePGbN269Yx1Dh06lMOHD9O4cWMuvvhi5s6dC8BLL71E9+7dufzyy7MtX/fUq1cvpkyZklHsBPDmm2+ybNkymjZtSqNGjbJNUg0aNODo0aMZZ/ePPfYYTz75JM2bNyclJSXH7T399NMkJyfTtGlTLrroIp5++mkA+vfvz/vvv8/FF1/Mxo0bM12FnKu+ffty6NAh6taty8iRI3nppZcA2L17N127dgWgVatW9OzZk0suuYQmTZqQlpbGvffem+u6FyxYkOdFidmR9IwaLFpUE1226SBEx+Y+M05XpA89NIOvvtrIc89dzdChV/k5QmNO27BhAw0bNgx0GIXa66+/TokSJfjnP/8Z6FDy1YoVKxg5ciT//e9/z5iW3XEnIr+paotz2VahvaJISUlj5MhfadhwDF99tZHixSMoW9aa/zamsLn//vuJjIwMdBj57uDBgzz33HP5sq1CWZm9aFEc/fp9y6pV+wC46aaGjBrVhSpVSgY4MmNMXouKiqJPnz6BDiPf5UeRU7pClygWL47j8svfRRVq1izN6NHX0a3bhYEOyxRh2T1cZYy/+KM6odAlipYtq9C5c12aN7+AoUOvIiYm7zrvMOZsRUVFcejQIWtq3OQLdfuj8HZL8bkI+kTxxx+HGDhwJiNHdubCC50v43ff3UZIiH0pTeBVrVqVuLg4Dhw4EOhQTBGR3sNdXgraRJGUlMJLL/3Cf/7zC0lJqURFhfHZZ7cAWJIwBUZ4eHie9jRmTCD49a4nEekiIr+LyGYReSKb6ZEi8ok7fbGI1PRlvXPm7qRp0/EMG/YzSUmp3H13M8aP757n8RtjjPHjFYWIhAJjgI5AHLBURKap6nqP2foCh1W1rojcCrwM9Dpzbadt+6s013b7GoCGDcsxfnx3a8TPGGP8yJ9XFC2Bzaq6VVVPAR8D12eZ53rgfff1Z8A1kkuN3+GEaKKiQnnxxQ6sXNnPkoQxxviZ357MFpGeQBdV/ac73AdopaoDPOZZ684T5w5vcec5mGVd9wLpz7M3Btb6JejgUw44mOtcRYPti9NsX5xm++K0+qpa4lwWDIrKbFWdCEwEEJFl5/oYemFj++I02xen2b44zfbFaSJyZscaPvJn0dMuoJrHcFV3XLbziEgYUAo45MeYjDHGnCV/JoqlQD0RqSUiEcCtwLQs80wD/u6+7gn8qMHWSqExxhRyfit6UtUUERkAzARCgUmquk5EhuN08j0NeBf4r4hsBv7CSSa5meivmIOQ7YvTbF+cZvviNNsXp53zvgi6ZsaNMcbkr0LbzLgxxpi8YYnCGGOMVwU2Ufir+Y9g5MO+GCQi60VktYjMEZFC+xRibvvCY76bRERFpNDeGunLvhCRW9xjY52IfJjfMeYXH74j1UVkroiscL8nXQMRp7+JyCQR2e8+o5bddBGRN939tFpELvFpxapa4P5wKr+3ALWBCGAV0CjLPP2B8e7rW4FPAh13APfF1UCM+/r+orwv3PlKAPOARUCLQMcdwOOiHrACKOMOVwh03AHcFxOB+93XjYDtgY7bT/viKuASYG0O07sC0wEBWgOLfVlvQb2i8EvzH0Eq132hqnNVNcEdXITzzEph5MtxAfAcTrthifkZXD7zZV/cA4xR1cMAqro/n2PML77sCwXSu7gsBezOx/jyjarOw7mDNCfXAx+oYxFQWkQq5bbegpooqgA7PYbj3HHZzqOqKcBRIDZfostfvuwLT31xzhgKo1z3hXspXU1Vv8vPwALAl+PiQuBCEVkgIotEpEu+RZe/fNkXw4A7RCQO+B54MH9CK3DO9vcECJImPIxvROQOoAXQLtCxBIKIhAAjgbsCHEpBEYZT/NQe5ypznog0UdUjgQwqQHoDk1X1NRFpg/P8VmNVTQt0YMGgoF5RWPMfp/myLxCRa4EhQA9VTcqn2PJbbvuiBE6jkT+JyHacMthphbRC25fjIg6YpqrJqroN2ISTOAobX/ZFX+BTAFX9FYjCaTCwqPHp9ySrgpoorPmP03LdFyLSHJiAkyQKazk05LIvVPWoqpZT1ZqqWhOnvqaHqp5zY2gFmC/fka9wriYQkXI4RVFb8zHG/OLLvtgBXAMgIg1xEkVR7J92GnCne/dTa+Coqu7JbaECWfSk/mv+I+j4uC9eBYoDU936/B2q2iNgQfuJj/uiSPBxX8wEOonIeiAVGKyqhe6q28d98SjwtogMxKnYvqswnliKyEc4Jwfl3PqYZ4FwAFUdj1M/0xXYDCQAd/u03kK4r4wxxuShglr0ZIwxpoCwRGGMMcYrSxTGGGO8skRhjDHGK0sUxhhjvLJEYQokEUkVkZUefzW9zBufB9ubLCLb3G0td5/ePdt1vCMijdzXT2WZtvB8Y3TXk75f1orINyJSOpf5mxXWllJN/rHbY02BJCLxqlo8r+f1so7JwLeq+pmIdAJGqGrT81jfeceU23pF5H1gk6q+4GX+u3Ba0B2Q17GYosOuKExQEJHibl8by0VkjYic0WqsiFQSkXkeZ9xXuuM7iciv7rJTRSS3H/B5QF132UHuutaKyCPuuGIi8p2IrHLH93LH/yQiLUTkJSDajeN/7rR49//HItLNI+bJItJTREJF5FURWer2E3CfD7vlV9wG3USkpfseV4jIQhGp7z6lPBzo5cbSy419kogscefNrvVdYzILdPvp9md/2f3hPEm80v37EqcVgZLutHI4T5amXxHHu/8fBYa4r0Nx2n4qh/PDX8wd/zjwTDbbmwz0dF/fDCwGLgXWAMVwnnxfBzQHbgLe9li2lPv/J9z+L9Jj8pgnPca/Ae+7ryNwWvKMBu4FhrrjI4FlQK1s4oz3eH9TgS7ucEkgzH19LfC5+/ouYLTH8i8Cd7ivS+O0/1Qs0J+3/RXsvwLZhIcxwElVbZY+ICLhwIsichWQhnMmXRHY67HMUmCSO+9XqrpSRNrhdFSzwG3eJALnTDw7r4rIUJw2gPritA30paqecGP4ArgSmAG8JiIv4xRXzT+L9zUdGCUikUAXYJ6qnnSLu5qKSE93vlI4Dfhty7J8tIisdN//BmCWx/zvi0g9nCYqwnPYfiegh4j8yx2OAqq76zImW5YoTLC4HSgPXKqqyeK0DhvlOYOqznMTSTdgsoiMBA4Ds1S1tw/bGKyqn6UPiMg12c2kqpvE6feiK/C8iMxR1eG+vAlVTRSRn4DOQC+cTnbA6XHsQVWdmcsqTqpqMxGJwWnb6AHgTZzOmuaq6t/civ+fclhegJtU9Xdf4jUGrI7CBI9SwH43SVwNnNEvuDh9he9T1beBd3C6hFwEtBWR9DqHYiJyoY/bnA/cICIxIlIMp9hovohUBhJUdQpOg4zZ9Tuc7F7ZZOcTnMbY0q9OwPnRvz99GRG50N1mttTp0fAh4FE53cx+enPRd3nMehynCC7dTOBBcS+vxGl52BivLFGYYPE/oIWIrAHuBDZmM097YJWIrMA5Wx+lqgdwfjg/EpHVOMVODXzZoKoux6m7WIJTZ/GOqq4AmgBL3CKgZ4Hns1l8IrA6vTI7ix9wOpearU7XneAktvXAchFZi9NsvNcrfjeW1Tid8rwC/Md9757LzQUapVdm41x5hLuxrXOHjfHKbo81xhjjlV1RGGOM8coShTHGGK8sURhjjPHKEoUxxhivLFEYY4zxyhKFMcYYryxRGGOM8er/AbCSmXZrzXhHAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "lw = 2\n",
    "plt.plot(\n",
    "    value_fpr,\n",
    "    value_tpr,\n",
    "    color=\"darkorange\",\n",
    "    lw=lw,\n",
    "    label=\"ROC curve (area = %0.2f)\" % value_roc_auc,\n",
    ")\n",
    "plt.rcParams['figure.figsize'] = [6, 6]\n",
    "plt.plot([0, 1], [0, 1], color=\"navy\", lw=lw, linestyle=\"--\")\n",
    "plt.xlim([0.0, 1.0])\n",
    "plt.ylim([0.0, 1.05])\n",
    "plt.xlabel(\"False Positive Rate\")\n",
    "plt.ylabel(\"True Positive Rate\")\n",
    "plt.title(env_name+\" Masksemble (Changed Gravity Vector)\")\n",
    "plt.legend(loc=\"lower right\")\n",
    "plt.savefig(\"roc_curve_\"+method+\".png\")\n",
    "# plt.show()\n",
    "plt.savefig(\"Masksemble_Walker2d_Changed_Gravity_Vector_ROC.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "# Compute micro-average ROC curve and ROC area\n",
    "policy_fpr, policy_tpr, _ = roc_curve([0 for _ in range(0,len(iid_policy_sd_buffer))] + [1 for _ in range(0,len(ood_policy_sd_buffer))], iid_policy_sd_buffer + ood_policy_sd_buffer)\n",
    "policy_roc_auc = auc(policy_fpr, policy_tpr)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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gw+iqme1I/z6669Uq1aNqlWrAnDrrbcydepUypQpQ758+ahRowYAsbGxvP7669x1112ICM2aNWP69Ol07949SzEGImIShYjwwgtNePbZr5kxoxeVKhXzOiRjsm5XYPcUJSUl8fXCxdx1W0+4oCGr48ZxZeOWcMGZy+ovueQSjh07xpEjR1i1ahVPPPFEpst99dVXKVasGCtXrgTg4MGDmc4TFxfHTz/9RFRUFElJSUyZMoU77riDX375hYsvvphy5crRq1cvHnvsMRo3bszWrVtp1aoVa9euPWs5S5YsoW7duqnDtWrV4ocffiA6Opr58+fz3HPP8cUXXwCwdOlSVqxYQcmSJXnuuee48cYbGT58OIcOHeLqq6+mRYsWlC1blnnz5hETE8P69evp2bMn6d2z1aRJE44ePfq38W+99RYtWrQ4a9z27dupWNG5UCY6OppixYqxf/9+Spcune40ABUqVOCXX36hdOnSJCYmsmTJEho2bMikSZPYtm1b6nQNGzbkhx9+sESRHeLjE4mJcT7mzTfXoFWrakRHR1zTjPFaZmf+wZC/GCfjT1G/9d1s376d2rVrE9ulX7auYv78+YwfPz51uESJEpnOc8sttxAV5fR40KNHD1555RXuuOMOxo8fT48ePVKXu2bNmtR5jhw5wrFjxyhcuHDquJ07d1KmzJku/w8fPsztt9/O+vXrERESEhJS34uNjaVkyZIAzJ07l2nTpvHWW28BzmXMW7du5aKLLuLBBx9k+fLlREVF8eeff6Yb/w8//JDpZ8wOIsL48eN57LHHOHXqFC1btkzdbgBly5Zlx44dIYklVyeKRYvi6Np1ImPHdqFZs8oAliRM9suo+4rGs2DX8eCsM8ArkAoUKMDy5cs5ceIErVq1YsiQITz88MPUqVOHBQsWnDXtX3/9ReHChSlatCiXXnopv/32W2q1zrnyrVpJe2d6oUJnbtK77rrr2LBhA3v37uXLL7/khRdeACA5OZlFixYRExPj97P5LvvFF1+kefPmTJkyhc2bN9OsWbN016mqfPHFF9SsefZFLAMHDqRcuXL8/vvvJCcnZ7jucylRlC9fnm3btlGhQgUSExM5fPgwpUqVSneaFHFxcZQvXz51+6Qkprlz556VvFKq2EIh1yaKefM20rnzBI4fT2DYsKWpicKYs2TWu2kohOCy04IFCzJ48GA6derEAw88QO/evfnXv/7F/PnzadGiBSdPnuThhx/m6aefBuCpp56iS5cuNG7cmBo1apCcnMzQoUO5//77z1pubGwsQ4YM4d133wWcqqcSJUpQrlw51q5dS82aNZkyZQpFihRJNy4RoXPnzjz++OPUrl079SDasmVL3n//fZ566ikAli9fTv369c+at3bt2rz99tupw4cPH049wI4YMSLDbdGqVSvef/993n//fUSEZcuW0aBBAw4fPkyFChXIkycPI0eOJCkpKd35z6VE0aFDB0aOHMl1113HpEmTuPHGG/92n8NVV13F+vXr2bRpE+XLl2f8+PGMGzcOgD179lC2bFlOnTrFG2+8wfPPP586359//nlW1Vsw5cpEMWnSGnr1+oKEhGRuu+1yPvmkg9chmewQDgf1jKTX8d3atXBBbW/iSUeDBg2oV68en332GX379mXq1Kk89NBDDBgwgKSkJPr27cuDDz4IQL169Xj33Xfp2bMnJ06cQERo167d35b5wgsvMGDAAOrWrUtUVBQvv/wyXbp0YdCgQbRr144yZcrQsGHD1Ibt9PTo0YOrrrrqrIP74MGDGTBgAPXq1SMxMZGmTZvy4YdnX55bq1YtDh8+zNGjRylSpAhPP/00t99+O6+99ho333xzhut78cUXefTRR6lXrx7JyclUqVKF6dOn88ADD9C1a1dGjRpF69atzyqFnK+77rqLvn37Uq1aNUqWLJlaTbdjxw7uvvtuZs6cSXR0NB988AGtWrUiKSmJO++8k0svvRSAN998k+nTp5OcnEz//v258cYbU5f97bff8vrrr2c5xkDkuk4Bhw1byn33TSc5WXnkkWt4551W1rmfl8L54J4iSL2brl27ltq1wydR5Eb/+c9/KFKkCHfffbfXoYTU7t276dWrF19//XW676e371mngK53313EY4/NAeCVV5rxwgtNc24XCqGWEw7oYF1Wm7P079+fzz//3OswQm7r1q1nVbsFW65KFJdeWob8+aN4662WPPjg1V6HEz68TgJ2cDdBEhMTQ9++fb0OI+SuuuqqkK4vVyWK2NhL2LDhYSpUKOp1KKGR3QnADujZLu3NVcYEWzCaE3J0ojh9Ook775xK3771aNWqGkDuTRJZTQqWBEIuJiaG/fv3U6pUKUsWJiTUfR6Fv8uKz0eOTRTHj5+mS5eJzJ27kW++2cTG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",
      "text/plain": [
       "<Figure size 432x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "lw = 2\n",
    "plt.plot(\n",
    "    policy_fpr,\n",
    "    policy_tpr,\n",
    "    color=\"darkorange\",\n",
    "    lw=lw,\n",
    "    label=\"ROC curve (area = %0.2f)\" % policy_roc_auc,\n",
    ")\n",
    "plt.rcParams['figure.figsize'] = [6, 6]\n",
    "plt.plot([0, 1], [0, 1], color=\"navy\", lw=lw, linestyle=\"--\")\n",
    "plt.xlim([0.0, 1.0])\n",
    "plt.ylim([0.0, 1.05])\n",
    "plt.xlabel(\"False Positive Rate\")\n",
    "plt.ylabel(\"True Positive Rate\")\n",
    "plt.title(env_name+\"Masksemble (Changed Gravity Vector)\")\n",
    "plt.legend(loc=\"lower right\")\n",
    "plt.savefig(\"roc_curve_\"+method+\".png\")\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Compute micro-average ROC curve and ROC area\n",
    "js_policy_fpr, js_policy_tpr, _ = roc_curve([0 for _ in range(0,len(iid_js_policy_buffer))] + [1 for _ in range(0,len(ood_js_policy_buffer))], iid_js_policy_buffer + ood_js_policy_buffer)\n",
    "js_policy_roc_auc = auc(js_policy_fpr, js_policy_tpr)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "lw = 2\n",
    "plt.plot(\n",
    "    js_policy_fpr,\n",
    "    js_policy_tpr,\n",
    "    color=\"darkorange\",\n",
    "    lw=lw,\n",
    "    label=\"ROC curve (area = %0.2f)\" % js_policy_roc_auc,\n",
    ")\n",
    "plt.rcParams['figure.figsize'] = [6, 6]\n",
    "plt.plot([0, 1], [0, 1], color=\"navy\", lw=lw, linestyle=\"--\")\n",
    "plt.xlim([0.0, 1.0])\n",
    "plt.ylim([0.0, 1.05])\n",
    "plt.xlabel(\"False Positive Rate\")\n",
    "plt.ylabel(\"True Positive Rate\")\n",
    "plt.title(env_name+\"Masksemble (Changed Gravity Vector)\")\n",
    "plt.legend(loc=\"lower right\")\n",
    "plt.savefig(\"roc_curve_\"+method+\".png\")\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "# ! ONLY RUN ONCE\n",
    "value_fprs = []\n",
    "value_tprs = []\n",
    "value_rocs = []\n",
    "\n",
    "policy_fprs = []\n",
    "policy_tprs = []\n",
    "policy_rocs = []\n",
    "\n",
    "js_policy_fprs = []\n",
    "js_policy_tprs = []\n",
    "js_policy_rocs = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "value_fprs.append(value_fpr)\n",
    "value_tprs.append(value_tpr)\n",
    "value_rocs.append(value_roc_auc)\n",
    "\n",
    "policy_fprs.append(policy_fpr)\n",
    "policy_tprs.append(policy_tpr)\n",
    "policy_rocs.append(policy_roc_auc)\n",
    "\n",
    "js_policy_fprs.append(js_policy_fpr)\n",
    "js_policy_tprs.append(js_policy_tpr)\n",
    "js_policy_rocs.append(js_policy_roc_auc)\n",
    "\n",
    "import pickle\n",
    "\n",
    "if not is_at_last:\n",
    "    with open(\"save_previous_results\"+short_env_name+\"_\"+method+\"_\"+str(chosen_id)+\".pkl\", \"wb\") as f:\n",
    "        pickle.dump({\"policy_fprs\": policy_fprs, \"policy_tprs\" : policy_tprs, \"policy_rocs\": policy_rocs, \"value_fprs\": value_fprs, \n",
    "                     \"value_tprs\": value_tprs, \"value_rocs\": value_rocs, \"js_policy_fprs\": js_policy_fprs, \"js_policy_tprs\": js_policy_tprs, \"js_policy_rocs\": js_policy_rocs}, f)\n",
    "    exit(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "\n",
    "data = []\n",
    "if is_at_last:\n",
    "    for i in sub_run_numbers[:-1]:\n",
    "        with open(\"save_previous_results\"+short_env_name+\"_\"+method+\"_\"+str(i)+\".pkl\", \"rb\") as f:\n",
    "            data.append(pickle.load(f))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(250,)\n"
     ]
    },
    {
     "data": {
      "image/png": "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v//++1m8eDFTp05l+/bt5ObmAnDWWWdx0UUXMWvWLKZMmcL8+fMH9FSXlZWxcOFCHnzwQZRSvPrqq7z44ovU19czYcIEjEYjd999NwClpaU899xz3HDDDUycOJEjjzySt956i+zs7EPa/P73v091dTVTp07l6KOP5tlnnwXg1ltv5dprr6WhoYHk5P5HRPPnz+e5557jggsuCLx2880343Q6mTp1KkcddRQ333zzYedlZmYybty4wI/RD3/4Q5588kmOPvpoPvvss0N6kz1tnjRpEjNmzGDy5MlcccUVuFwuvv3tb7N27VqmTJnCU089dcj7MFTOOecc6urqGD9+PJdffjkPPfRQYN+0adMOOfaFF144TCzXrFlDZWUlL774IldccQVHHXVUYN+qVas499xzh21jgP68P/H46NUbvu3PIvchu9f27p176aVNkpJyuyxdurbX/YlCPHjDo43ZbA54RlesWCHz5s2LsUXxxSuvvCI33nhjrM2ICSeeeKK0tbX1um/0esN9Dp4kQ2qvu88/fxLbtpVTU5MXRaM00WDdunVcffXViAh5eXk88cQTsTYprvjGN75Ba2trrM2IOs3NzVx33XXk54cvY1hiiKVvGK6CQoceeOADjjmmnK98xRuWoIUyMTnxxBP55JNPYm1GXPP9738/1iZEneLi4kAYWLhIELH0TlT7e5Z+Z05OThrbt19DcXHvczMajUYTKonh4JEvHTzBXu/f/vbMUSeU4vOOajSa3hnqdySiYqmUmqOU2qKU2q6U+nkv+9OUUs/79n+glKod0oV8PctHn9ybMNmDhoLRaKS1tVULpkbTB+LLZxkcYxoqERuGK6WSgQeBM4G9wBql1EoR2Rx02GVAu4iMV0pdCNwDLDi8tQHwuFj8z1n86nVvIOxoFErwLhXbu3cvzc3NsTZFo4lb/JnSB0sk5yyPA7aLyOcASqnngPOAYLE8D/iV7/lLwB+VUkoG2TXasdvGz944Axi9QgmQkpIy6OzPGo0mNCIplhXAnqDtvcDxfR0jIi6lVCdQCLQEH6SUWgQsAm9Kpp6MG5vDs5etYN+Em0etUGo0msgyIrzhIrIUWArQ0NBweK/zqO8y/9HvRNssjUYzioikg6cRqArarvS91usxyhskmQsMKYJWKaVLKmg0mogRyZ7lGqBeKTUWryheCFzU45iVwCXAamA+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",
      "text/plain": [
       "<Figure size 360x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "tprs = []\n",
    "base_fpr = np.linspace(0, 1, 250)\n",
    "\n",
    "plt.figure(figsize=(5, 5))\n",
    "plt.axes().set_aspect('equal', 'datalim')\n",
    "\n",
    "\n",
    "#plt.plot(value_fpr, value_tpr, 'b', alpha=0.15)\n",
    "tpr = np.interp(base_fpr, value_fpr, value_tpr)\n",
    "print(tpr.shape)\n",
    "tpr[0] = 0.0\n",
    "tprs.append(tpr)\n",
    "\n",
    "for d in data:\n",
    "    #plt.plot(data[\"value_fprs\"][0], data[\"value_tprs\"][0], 'r', alpha=0.15)\n",
    "    tpr2 = np.interp(base_fpr, d[\"value_fprs\"][0], d[\"value_tprs\"][0])\n",
    "    tpr2[0] = 0.0\n",
    "    tprs.append(tpr2)\n",
    "\n",
    "tprs = np.array(tprs)\n",
    "mean_tprs = tprs.mean(axis=0)\n",
    "std = tprs.std(axis=0)\n",
    "\n",
    "tprs_upper = np.minimum(mean_tprs + std, 1)\n",
    "tprs_lower = mean_tprs - std\n",
    "\n",
    "average_roc = (value_roc_auc + sum([d[\"value_rocs\"][0] for d in data])) / (len(data) + 1)\n",
    "plt.plot(base_fpr, mean_tprs, \"darkorange\", label=\"Average ROC curve (area = %0.2f)\" % average_roc)\n",
    "plt.fill_between(base_fpr, tprs_lower, tprs_upper, color='grey', alpha=0.25)\n",
    "\n",
    "plt.plot([0, 1], [0, 1], color=\"navy\", lw=lw, linestyle=\"--\")\n",
    "plt.xlim([-0.01, 1.01])\n",
    "plt.ylim([-0.01, 1.01])\n",
    "plt.legend(loc=\"lower right\")\n",
    "plt.ylabel('True Positive Rate')\n",
    "plt.xlabel('False Positive Rate')\n",
    "plt.savefig(short_env_name+\"_roc_curve_\"+method+\".png\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(250,)\n"
     ]
    },
    {
     "data": {
      "image/png": "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3HzzzXi93sjnK1as4OSTT+bQQw/lqKOO4rrrrsPpdKbiNvapoqKCc845J6nXNAwDq9UaU6BUSvGzn/2MAw88kAkTJrB69eo29zvttNM47LDDGDduHNdddx2BQACA3/3ud0yYMIHDDz+cGTNmsHv3bgDefPNN7rzzzrjdU48Olk1NTW33gKsA/b74HVlNGymeeRcPP3KiDpRxtmjRIo455hheeumluJwv/IuRKEuWLGHlypVMnTqV++67Dwj+El988cWceeaZrF+/nnXr1mG327nrrrsAqKqqYtasWcyePZuvvvqKzz//nBkzZtDS0hK3cvn9/m6f45FHHuFHP/pR0q5pGAZmsznmGuW///1vNm/ezObNm5kzZw7XX399m/stWrSIL7/8knXr1lFTU8PLL78MwK233sratWtZs2YNZ5xxBnfffTcAp59+Om+88Ubc/nj12GAZCARoaWnZO1gqRcnKW3CsfZvGg2/Etd8pnH76CB0o48hut/Ppp5/y5JNPRn6g33nnHWbNmhXZ57///W+ktvPuu+9ywgknMGXKFGbNmhXJDDVmzBjuuOMOpkyZwj//+U/mzZvHsccey5FHHsnFF18c+SXYunUrU6dOZdKkSdx11117JJJ96KGHOPbYYyktLY38ErVnypQpkZrJBx98QHZ2NldccQUAZrOZ+++/n2effRan08kTTzzBZZddxpQpUyLHn3vuuXtl0gkEAtx+++1MnDiR0tJSHn/88cj91dYGs1etWrWKU045BYA//vGPXHnllZx44olceeWVTJ06lQ0bNkTOd8opp7Bq1SocDgfXXHMNxx13HEcddRRvvPFGm/f02muvMWNG8Olp+/btTJs2jSlTpjBlyhSWLVsW+X5MmzaN8847j8MPP5xAIMCvf/3ryP/dU089FfnennbaaUyZMoVJkybtdc1wh47Vao35cff111/n8ssvR0SYMmUKjY2NVFRU7LVfeC653+/H6/VGzh89x9zhcES2iwgnnngib775Zkzl6EiPbbPc1yD0oq8fZc5zVfx+6c08u+B0jkhR+ZLB/PEtmGq+jOs5jf6HETj+gXb3eeONNzjllFMYPXo0/fr1Y/Xq1UybNo0bbrgBh8NBXl4er7zyChdccAG1tbXcd999vP322+Tl5fHAAw/w8MMPc8cddwDQt29fPvvsMyCYtPmqq64C4K677uKZZ57hhhtu4JZbbuHGG2/koosuivxSQzAIb9myhU8++QSlFOeddx4ff/wxxx9//D7L/s4773DmmWcCsHHjRiZOnLjH54WFhQwbNoytW7eyYcMGLrvssg7/z+bNm8eOHTtYvnw5FouF+vr6Do/5+uuvef/998nJyeGRRx7hlVde4c4776SiooLKykomTZrE7373O0488UTmzJlDY2Mjxx13HNOmTdujjf7bb7+lT58+ZGcHF9AbMGAAb7/9NjabjS1btnD55Zfz6aefArBmzRpWrVrFyJEjmTt3LoWFhfzvf//D4/Fw0kknMX36dIYNG8aiRYsoLCyktraWqVOncsYZZyAikeFq2dnZXHLJJW02wdx0001cfvnle2zbtWsXw4YNi7wfOnQou3btYvDgwXsdf+qpp7J8+XK+973vcf7550e233HHHcyfP5+ioiI++OCDyPbS0lI+/vhjLrzwwg7/zzvSI2uW4TV2Wq/pkVv+Fv/4+2fc/MaptDiFzZsbU1PAHm7RokVccMEFAFxwwQUsWrQIi8XCjBkzeOutt/D7/fz73//mzDPPZPny5Xz99decdNJJTJ48mQULFrBz587IuaJ/IdavX8+0adOYNGkSL774YqS29fnnn3PeeecBcNFFF0X2X7p0Ke+99x5HHXUUU6ZMYdOmTWzZsqXNMp966qmMGjWKJUuW7HGOeHj//fe56qqrItn5+/bt2+Exp59+emQEx3nnncdrr70GwD//+c9IjXzp0qU88MADTJ48mRkzZuB2uykrK9vjPJWVlXssLevz+bj++uuZNGkSs2bNYuPGjZHPSktLI8Npli5dysKFC5k8eTLHH388dXV1bNmyBaUUd955J6WlpcycOZPdu3dTWVlJIBBARMjOzsZkMvHSSy+xZs2avb5aB8rOWrJkCRUVFXg8Ht5///3I9tmzZ1NWVsall17KY489Ftk+YMCAyJNCd/XImmVTUxMej2ePDMxZDWt57oGXIr3evSHNWuD4B0hsS9/e6uvr+fDDD1m3bh0iEvkl+tOf/sQFF1zAE088QZ8+fZg0aRIFBQUopZg2bRrPPfdcm+eLriVdffXVvPzyy0yYMIH58+fz0UcftVsWpRS33norV199dYflXrJkCcXFxfzwhz/kj3/8I3/5y184+OCDefXVV/fYr7m5mbKyMg444ADGjh3L6tWrIzXRzrJY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",
      "text/plain": [
       "<Figure size 360x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "tprs = []\n",
    "base_fpr = np.linspace(0, 1, 250)\n",
    "\n",
    "plt.figure(figsize=(5, 5))\n",
    "plt.axes().set_aspect('equal', 'datalim')\n",
    "\n",
    "\n",
    "#plt.plot(value_fpr, value_tpr, 'b', alpha=0.15)\n",
    "tpr = np.interp(base_fpr, policy_fpr, policy_tpr)\n",
    "print(tpr.shape)\n",
    "tpr[0] = 0.0\n",
    "tprs.append(tpr)\n",
    "\n",
    "for d in data:\n",
    "    #plt.plot(data[\"value_fprs\"][0], data[\"value_tprs\"][0], 'r', alpha=0.15)\n",
    "    tpr2 = np.interp(base_fpr, d[\"policy_fprs\"][0], d[\"policy_tprs\"][0])\n",
    "    tpr2[0] = 0.0\n",
    "    tprs.append(tpr2)\n",
    "\n",
    "tprs = np.array(tprs)\n",
    "mean_tprs = tprs.mean(axis=0)\n",
    "std = tprs.std(axis=0)\n",
    "\n",
    "tprs_upper = np.minimum(mean_tprs + std, 1)\n",
    "tprs_lower = mean_tprs - std\n",
    "\n",
    "average_roc = (policy_roc_auc + sum([d[\"policy_rocs\"][0] for d in data])) / (len(data) + 1)\n",
    "plt.plot(base_fpr, mean_tprs, \"darkorange\", label=\"Average ROC curve (area = %0.2f)\" % average_roc)\n",
    "plt.fill_between(base_fpr, tprs_lower, tprs_upper, color='grey', alpha=0.25)\n",
    "\n",
    "plt.plot([0, 1], [0, 1], color=\"navy\", lw=lw, linestyle=\"--\")\n",
    "plt.xlim([-0.01, 1.01])\n",
    "plt.ylim([-0.01, 1.01])\n",
    "plt.legend(loc=\"lower right\")\n",
    "plt.ylabel('True Positive Rate')\n",
    "plt.xlabel('False Positive Rate')\n",
    "plt.savefig(short_env_name+\"roc_curve_\"+method+\"_policy.png\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(250,)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 360x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "tprs = []\n",
    "base_fpr = np.linspace(0, 1, 250)\n",
    "\n",
    "plt.figure(figsize=(5, 5))\n",
    "plt.axes().set_aspect('equal', 'datalim')\n",
    "\n",
    "\n",
    "#plt.plot(value_fpr, value_tpr, 'b', alpha=0.15)\n",
    "tpr = np.interp(base_fpr, js_policy_fpr, js_policy_tpr)\n",
    "print(tpr.shape)\n",
    "tpr[0] = 0.0\n",
    "tprs.append(tpr)\n",
    "\n",
    "for d in data:\n",
    "    #plt.plot(data[\"value_fprs\"][0], data[\"value_tprs\"][0], 'r', alpha=0.15)\n",
    "    tpr2 = np.interp(base_fpr, d[\"js_policy_fprs\"][0], d[\"js_policy_tprs\"][0])\n",
    "    tpr2[0] = 0.0\n",
    "    tprs.append(tpr2)\n",
    "\n",
    "tprs = np.array(tprs)\n",
    "mean_tprs = tprs.mean(axis=0)\n",
    "std = tprs.std(axis=0)\n",
    "\n",
    "tprs_upper = np.minimum(mean_tprs + std, 1)\n",
    "tprs_lower = mean_tprs - std\n",
    "\n",
    "average_roc = (js_policy_roc_auc + sum([d[\"js_policy_rocs\"][0] for d in data])) / (len(data) + 1)\n",
    "plt.plot(base_fpr, mean_tprs, \"darkorange\", label=\"Average ROC curve (area = %0.2f)\" % average_roc)\n",
    "plt.fill_between(base_fpr, tprs_lower, tprs_upper, color='grey', alpha=0.25)\n",
    "\n",
    "plt.plot([0, 1], [0, 1], color=\"navy\", lw=lw, linestyle=\"--\")\n",
    "plt.xlim([-0.01, 1.01])\n",
    "plt.ylim([-0.01, 1.01])\n",
    "plt.legend(loc=\"lower right\")\n",
    "plt.ylabel('True Positive Rate')\n",
    "plt.xlabel('False Positive Rate')\n",
    "plt.savefig(short_env_name+\"_roc_curve_\"+method+\"_js_policy.png\")\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python (va-for-rl)",
   "language": "python",
   "name": "venv"
  },
  "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.9.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
