{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "pycharm": {
     "is_executing": true
    },
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<torch._C.Generator at 0x11efda990>"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "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/Masksemble/HalfCheetah-v3_6\n",
      "Method:  masksembles\n",
      "Run ID:  6\n",
      "Is at last:  True\n"
     ]
    }
   ],
   "source": [
    "short_env_name = \"cheetah\"\n",
    "method = \"masksembles\"\n",
    "\n",
    "if short_env_name == \"walker\":\n",
    "    env_name = \"Walker2d-v3\"\n",
    "    save_dir = \"StrongWalker\"\n",
    "elif short_env_name == \"cheetah\":\n",
    "    env_name = \"HalfCheetah-v3\"\n",
    "    save_dir = \"Cheetah_zip\"\n",
    "else:\n",
    "    env_name = \"Ant-v3\"\n",
    "    save_dir = \"Ant-v3\"\n",
    "    \n",
    "if method == \"dropout\":\n",
    "    method_dir = \"Dropout\"\n",
    "elif method == \"ensemble\":\n",
    "    method_dir = \"Ensemble\"\n",
    "else:\n",
    "    if short_env_name == \"walker\":\n",
    "        method_dir = \"Masksembles\"\n",
    "    else:\n",
    "        method_dir = \"Masksemble\"\n",
    "    \n",
    "model_base_dir = '/Users/yannick/Documents/neurips_benchmarks/neurips_benchmarks/'+save_dir+'/'+method_dir\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": "stdout",
     "output_type": "stream",
     "text": [
      "384 384 384\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "objc[27283]: Class GLFWApplicationDelegate is implemented in both /Users/yannick/.mujoco/mujoco200/bin/libglfw.3.dylib (0x14401a778) and /Users/yannick/Documents/VARL/va-for-rl/venv/lib/python3.9/site-packages/glfw/libglfw.3.dylib (0x14419f740). One of the two will be used. Which one is undefined.\n",
      "objc[27283]: Class GLFWWindowDelegate is implemented in both /Users/yannick/.mujoco/mujoco200/bin/libglfw.3.dylib (0x14401a700) and /Users/yannick/Documents/VARL/va-for-rl/venv/lib/python3.9/site-packages/glfw/libglfw.3.dylib (0x14419f768). One of the two will be used. Which one is undefined.\n",
      "objc[27283]: Class GLFWContentView is implemented in both /Users/yannick/.mujoco/mujoco200/bin/libglfw.3.dylib (0x14401a7a0) and /Users/yannick/Documents/VARL/va-for-rl/venv/lib/python3.9/site-packages/glfw/libglfw.3.dylib (0x14419f7b8). One of the two will be used. Which one is undefined.\n",
      "objc[27283]: Class GLFWWindow is implemented in both /Users/yannick/.mujoco/mujoco200/bin/libglfw.3.dylib (0x14401a818) and /Users/yannick/Documents/VARL/va-for-rl/venv/lib/python3.9/site-packages/glfw/libglfw.3.dylib (0x14419f830). One of the two will be used. Which one is undefined.\n",
      "2022-05-26 20:31:44.979 Python[27283:2421310] 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": [
      "128 128 128\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",
      "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": 4,
   "metadata": {
    "collapsed": false,
    "jupyter": {
     "outputs_hidden": false
    },
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "384 384 384\n"
     ]
    }
   ],
   "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",
    "ood_obs_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": 5,
   "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(iid_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(\"iid_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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\n",
      "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+\"_\"+method+\".png\", dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXAAAAD8CAYAAABuHP8oAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8rg+JYAAAACXBIWXMAAAsTAAALEwEAmpwYAAA2sUlEQVR4nO2deZgU1fX3v6e7Z2EYtoFh35VVxQgj4oIRRAXUqDGLxi1uRJP4M4nRoCZqEjXGLS5x43XfcMW4giCCgCI47JvAyL7OwLAMs0/3ff/oquqq6qru6u5apmvO53nmme7q6r63b1d969S555xLQggwDMMw2UfA6w4wDMMw6cECzjAMk6WwgDMMw2QpLOAMwzBZCgs4wzBMlsICzjAMk6UkFXAiepGIyolotW77TUT0PRGtIaIHnesiwzAMY4QVC/xlAOPVG4hoDIALABwvhDgGwMP2d41hGIZJRFIBF0LMA1Cp23wjgAeEEPXSPuUO9I1hGIZJQCjN9w0EMJqI7gNQB+DPQojvkr2pU6dOom/fvmk2yTAM0zJZsmTJPiFEsX57ugIeAlAEYBSAEwG8Q0T9hUFePhFNAjAJAHr37o3S0tI0m2QYhmmZENFWo+3pRqHsADBNRFkMIAKgk9GOQogpQogSIURJcXHcBYRhGIZJk3QF/H8AxgAAEQ0EkAtgn019YhiGYSyQ1IVCRFMBnAGgExHtAHA3gBcBvCiFFjYAuMrIfcIwDMM4R1IBF0JcavLS5Tb3hWEYhkkBzsRkGIbJUljAGYZhshQWcIZhmCyFBZxhWgiLN1di/Z4qr7vB2Ei6iTwMw2QZv3huIQBgywPnetwTxi7YAmcYhslSWMAZhmGyFBZwhmGYLIUFnGEYJkthAWcYhslSWMAZhmGyFBZwhmGYLIUFnGEYJkthAWcYhslSWMAZhmGyFBZwhmGYLIUFnGEYJktJKuBE9CIRlUvLp+lfu4WIBBEZLmjMMAzDOIcVC/xlAOP1G4moF4CzAWyzuU8MwzCMBZIKuBBiHoBKg5f+A+A2ALyYMdNs2F5Zgw+W7fC6GwzjCmnVAyeiCwDsFEKsICKbu8Qw6XPJlG+x82Atzh/WHaEgT/Ew/iZlASeiAgB3IOo+sbL/JACTAKB3796pNscwKVFeVQcAqGkMoy0LOONz0jnCjwLQD8AKItoCoCeApUTU1WhnIcQUIUSJEKKkuLg4/Z4yTAo0hdmzx/iflC1wIcQqAJ3l55KIlwgh9tnYL4ZJCyHpdlMk4m1HGMYFrIQRTgWwEMAgItpBRNc63y2GSY+ANCcTjrAFzvifpBa4EOLSJK/3ta03DJMhwQABYRZwpmXAszyMrwgGtBb4poojOFzX6GWXGMYxWMAZXyHpN5okAR/7yFf4+TMLPewRwzgHCzjjK/QWOACs31vlVXeaJRF2L/kGFnDGV8gCzmGE5oQFj41fYAFnfIUchRJhkTKFJ3j9Aws44ysUC5xFyhS+uPkHFnDGV8TiwDmRxwy+uPkHFnDGV7APPDk8iekfWMAZX6GOQhHsKjCELXD/wALO+Ao5DjwsBFi/jWEL3D+wgDO+Qj2JyZN1xrAF7h9YwBlfEQxED+lwWIB1yhgOI/QPLOCMr5DXcGAL3BwWcP/AAs74CnUiD+u3MZyJ6R9YwBlfIQs4W+DmsAXuH1jAGV8RCsQSeVjAjWEB9w8s4IyvCKgSeVinjGEB9w9WllR7kYjKiWi1attDRPQ9Ea0kog+IqL2jvWQYiwSJE3mSwQLuH6xY4C8DGK/bNgvAsUKIYQA2ALjd5n4xTFoENFEo3valucKTmP4hqYALIeYBqNRtmymEaJKefgugpwN9Y5iUkScxheBJTDPYAvcPdvjArwEw3YbPYZiMUa9KzwJuDAu4f8hIwInoTgBNAN5IsM8kIiolotKKiopMmmOYpEj6jYgAx4GbwALuH9IWcCL6NYDzAFwmEswWCSGmCCFKhBAlxcXF6TbHMJbgRJ7ksID7h1A6byKi8QBuA/BjIUSNvV1imPQJKBY4u1DMYAH3D1bCCKcCWAhgEBHtIKJrAfwXQBsAs4hoORE963A/GcYSpPjAeekwM1jA/UNSC1wIcanB5hcc6AvDZIxkgLMLJQEcRugfOBOT8RWKD5yjUEzhBR38Aws44yvkRJ6IACfymMAWuH9gAWd8BUlOlDBPYprCPnD/wALO+AqBqDgJwbVQzOALm39gAWd8haxNYa6FYko44nUPGLtgAWd8SdQHzgpuBE9i+gcWcMZXyJodEQIRtjQN4UlM/8ACzvgK2QfOYYTm8CSmf2ABZ3yF4gPnRJ44goFYpUbGH7CAM75EsA88DvVqRYw/YAFnfIUsTVwPPB5SFfpi/AELOOMrNJOYrFMa2IXiP1jAGZ8hTWJyIk8ciguFx8U3sIAzvoQTeeJRXCg8ML6BBZzxFTEXCtgC1xFzoXjcEcY2WMAZXyFLdoQt8DgCzcSF8m7pduw5VOdpH/wCCzjjK2SrO8w+cFO8dKEcqW/Cre+txK+e/9azPvgJK0uqvUhE5US0WrWtiIhmEdFG6X8HZ7vJMKnB9cDN8dICl9cs3V7JS+nagRUL/GUA43XbJgOYLYQYAGC29JxhPEfrQmEFV6MeG6+Q67U3hvm3sYOkAi6EmAegUrf5AgCvSI9fAXChvd1imPTQlpNlkTDC7TjwpnAEh+saAcRq1TD2kK4PvIsQYrf0eA+ALjb1h2EyQrEyuRaKKW67UP7w9nIMu2emq222FDKexBTRmSLTI4KIJhFRKRGVVlRUZNocw1giwkuqmeK2C+WTlVFbjyeV7SddAd9LRN0AQPpfbrajEGKKEKJECFFSXFycZnMMYw0lCoXDCOOQx6bJo4Hxql0/k66AfwTgKunxVQA+tKc7DGMPYa5GaIpX49IYjrBby2ashBFOBbAQwCAi2kFE1wJ4AMBZRLQRwDjpOcN4jiwQvKixOV4Vs+IiWvYTSraDEOJSk5fOtLkvDGMb7EKJJ1Zq1912AyTF5UeAQNDdtv0OZ2IyvkIOU+MwQnPcHhdSpfDzL2IvLOCMr4i5UDgT0wy3XRly9iW7UOyHBZzxFdo1MVkw1KjHxk1kC5zviOyHBZzxJexCMcftOHDJAEc4whdVu2EBZ3yF7GUVQiDCda8Ncd+Fwku5OQULOOMrNC4Ub7vS7JCtX/cnMeFJuy0BFnDGV6hD5VgwjGEL3D+wgDO+JML+VlPcruSqtsD5F7EXFnDGXyhrYnIijx6v6oHHJjFdbbZFwALO+AolkYerEZriugslwC4Up2ABZ3yFrNnbK2tQ2xD2tjPNFNfjwKX/btZov2TKQox/bJ47jXlI0looDJONNIYF7v10ndfdaF6oVityEy8mMb/dpF9EzJ+wBc74Cr5JT47bAq6uhcLYCws44ys48iQ5nsWBsw/cdljAGV/BEpEc1y1wdbv8A9kKCzjje4JyObwWTizJyatMTFebbRGwgDO+wsg7wPKtZVtlDQ7XNbrWXoCrETpGRgJORH8kojVEtJqIphJRvl0dY5h0MJIIWUCYKDUNYVz4369da08dhcK5mPaStoATUQ8A/wegRAhxLIAggEvs6hjDpAWb4KaoJ3g37at2vX2/RqFEIgID/zodr3yzxfW2M3WhhAC0IqIQgAIAuzLvEsPYC0emeEtAUhm/RqE0RQQamiK4+6M1rredtoALIXYCeBjANgC7ARwSQsy0q2MMkw5GEsH67S0Ef6fSe+kWysSF0gHABQD6AegOoDURXW6w3yQiKiWi0oqKivR7yjAWMBJrf8pG6ng1DgF1NUIf/hhefqdMXCjjAGwWQlQIIRoBTANwin4nIcQUIUSJEKKkuLg4g+YYJjlG1hBHP3hLbBLT4444RLYK+DYAo4iogKK5smcC4OITTLOD9dtj5FXpffpDZKULRQixCMB7AJYCWCV91hSb+sUwaWGmETyR6d2FTIkDj/gziNDLQyujaoRCiLsB3G1TXxgmY8wFPJYRyLiLJpXeh3j5rTgTk/EVAsCZgzsbbme8we9rYno5x8ICzviOQIAwpFtbzTZ2oXjnqyW/+8CzdBKTYZodslAHdUe2T42/rECTSu9HEWcBZxj7IABBncPbn9Nn2YGSielH8UaWRqEwTHNEnqwkvYD7UzuyAr9nYnr5tVjAGd9BIOhLgLOAexlGGP0f9m0YIVvgDGMLskToS8j6UzqyA/J5PXAOI2QYm5BdKHEC7k/tyAqUKBROpbcdFnDGVwjIPnDtdr9af6ngXTGrmAXux5+BXSgMYyNRH7jehcJ4BWdiOgcLOOMrZGsoENBv96AzDAC1C8WfPwK7UBjGJgQAGPrA/SkeKeHxEHjhxnLjd+c4cIaxCxG9Zec48OaDPPZeLGrsxu/OceAMYyNEBnHg3nSFQczy9qIWihtWP09iMoY0hiO4+a1l2OzBCuLZinwq6V0oHIXi3a2+3KoXixq70ST7wBlDlmw9gA+X78Jf3l/pdVeyBiEECOBMzGZERHGhwPVbIb9fuFnAswF/H4O2EosD50zMZoMkon4V06ytB05E7YnoPSL6nojWEdHJdnWMYdKFLXBjvBoDuVkvwgjd8YE73oQpGS2pBuBxADOEED8jolwABTb0iWHSRj6ZOJW++eDtJGb6791zqA55oQA6tM5NuF9WJvIQUTsApwN4AQCEEA1CiIM29Yth0kJASFEo7EIxYvSATgCAtvmZ2m7WkXVbCPfFLpMIkVH/mo0R985ytI1MyeRX7AegAsBLRHQ8gCUAbhZCcMgE4xlCiQOPPieKbvNpEmBKCADDerZDgAgHaxtdazeiCLgHiTwZvt/KcZOtceAhAMMBPCOEOAFANYDJ+p2IaBIRlRJRaUVFRQbNtTx4EfU0UWVi5kprq3EmZhQCSRc198ZDbsuvqfReOlEyEfAdAHYIIRZJz99DVNA1CCGmCCFKhBAlxcXFGTTHMMmJ+cCj//NCAc12JmoYrNxxCLPX7XW13Yhw/3dwo72sjAMXQuwBsJ2IBkmbzgSw1pZeMUwGqKsR5oaCAFjA1chjc+0rpa60J09ienIX5PNU+kxnMm4C8IYUgbIJwNWZd4lh0kcIIfm/oyKlWOA8iakIqL5WuvPtRv97UszKhd/dy2MrIwEXQiwHUGJPVxjGHghARDqpctmFosEoyclpZOH2qws8K10ojHuw9WgdfdKIPInp1yzAdHB7clyphSL8WY2QBZwxxG1LyQ/Ia2LWNoQBAIVSvDPLd2wMXD+sVHHgbuNGk1mbSs8wzQ0BAQJhk1TBsbq+KbqdFRyAXGYgpuC7DtY63mbMheLPBR28hAU8C/Bv/KwzEAFl5UcAAMf2aAfA/ydyKqgt8Ktf+s7x9jQuFLfDCN1og10oTCKWbjvodReyBvlkGtW/CADw44HR3AOW79jYqF1zB2oaHG/X95OY2RqFwjDNDbmc7PNXnYjdB2uxUbLE2QCXINJMYjaGI443GauF4oULxfk2sjWVnmGaHUJa1bgwL4QBXdooYsVRKDHUFnhT2L1yq164Al2JA+dJTIaxD7WPV37M+h1DXyvdaYTKheL6z+BGGKHzTZjCAs74DO3pJFubHEsfhaCNA3dlkk/679e7IJ7EZBibkMvJypBqu1ts2VeNS6YsxOE690q2poK+VrrTxGqhuNpstE032mAXCmME5/GkTlgIBFU+AsUCd/Ece3TWBny7qRJfrHW32l8iNCLjYS0Ut8XOlUxM55swhQWc8RXhiNBYmLKWCwjsOliL7ZU1jvehOfvdiaLVGt3ESRdKbUMYFz71NVbvPGTStr/XxGQBZ3xFJCIQ0ljg0nYBnP2feRj94BzH+xAKRE+r2saw422lg3oS02mLWAiBiqp6AM6E2y3ddgDLtx/EfZ+uM2nf/jbj22AXCsPYQlNE50KB7EIROCKl1TtNG6n+yv4jzifJWEXjQXHRAFeHDgoHMjFJdYflFRwHzjA2ERECAQMLXH2OuZG8AgD7q+tdaScV3HafqFeid0Lo5O9j9tlWm9xeWYMHZ3yfljXt5cWDBZzxFeE4F0r08Z/fXaFsO1LnrCUuW53NyQJX46bFGFFdK53wgSt3E2YCbrHN376xFE/P/QEb9h5JvRNsgTNM5gghEBHaMDn50aaKamWb0+F9TZJCVhxpfhY4oBVSp7XHaQs8kCTO3+o1o6EpkvBzEpHVUShEFCSiZUT0iR0dYmJwFGFqyJav2gduFPN8uNZpCzwqBvubkYCrRcbNOTe9D1zNroO1KLl3Fjbvq9a/zTLqSepMyMQNku31wG8GYDwFzGTEtGU7lcdcDjU5srUXNPCBq6ly2gKX6ovsr27AjgM1qGtG0ShE2mPJ6cNKLeD6Wigfr9iFfUca8OairWl/fixRy7vzI2vDCImoJ4BzATxvT3cYNW8u2qY85prgyTGywI3uYtxyoRysacRp/56D37+5zNH2UsXNQ0l93OrbDUnL3TVmUFDLaJJaDSfyJOYxALcBcGdav4Whth5Zv5OjCDjFT2Kqqa531iLWX2znri93tD0rCI0v2r2DSeNv14UR5gSjv408XjsO1GDJ1gMpfX6yTNtUXSPpROlkZRw4EZ0HoFwIsSTJfpOIqJSISisqKtJtrkWSE4j9PH4tBGQncsRDMhdKTYOzPnB9mGIo2HxmMwje+cD1x7A8PyHfsYx9+Ctc/Mw3KX2+Molp8qX0m/cdqce8DfE6lMmYZKsL5VQAPyGiLQDeAjCWiF7X7ySEmCKEKBFClBQXF2fQXMtDpd/NMi27udEkKXgyF8oRly1wt2Ovk6GNQnH2wErkQtFfXBvSiM+P1Xu3tv8vn1uIK19cbP55afxUWRkHLoS4XQjRUwjRF8AlAL4UQlxuW88YzYkfZgVPijxG6kSegEHxa6ct8KaIUNwDQPNIqW8OUSjmd5F2+MBNLHDd8x+kcFI73R7ZaoEzDqP1gbOAJ0N2oYSSWOBu+MAL82KrFQ7u2sbR9lKBSHssOX13ENFFvKiFNlbmQPeeFCZ8ZBdKxMR4t+payYSsF3AhxFwhxHl2fBYTQ1N4n6eJk6K4UJJOYjrvAy/Mjwl4h4JcR9tLFbU+Ol0XRW4qQPFGiFnVxkYzNTYgaRSKyXZ9XzLR4GyPA2ccQp2EwhZ4cuTz3qgWikxhXgjVDrtQwhGBNnk5yvOg22uYqbj3k7XoO/lTjUiqrVKnF3eQ2woFAogIgR8/NFd5LZYFrz22UwkrTDaJqSeZ4KczGtkcRsg4iepoYh94cmKJPLFt+hOyc5s81DQ460JpigilIiHg7cIczy/YrHlORBpjID8n6Gj7srUfCADhsLEFrqfJ4mTm7HV7MeHx+VI71lwl6azQlOzikPUuFMZ52AJPTliJQokd1nWNWjHoVJjneFnZpkgErVU+8Pkb92HtrsOOtpkMTUq7avvoAZ0cbVc+bEOBABpNonP0em3VAn/ru+3KY3O3udnkpvXzKfmp5925GUq+C+MZmtte77qRLchCoPaB69PmC/NDKK+qc7QfTWER5zaZ+MR83H/RcQgGJOGi6O0/QVolx2YrvaRPEXoVFSjP65tidx0RE3eKE0SUuyKKt6yl7/z+0h145BfHK5ubLPrAc4PJ8yTiLPBoLYG47YnGIdkIeZlkxwLejFEfF2yBJyeWSh/bpneXFOQGUeNCFEqOQfLOHR+scrRdNWcP7YIpV5Yoz9V3IppaKA73Qy3gjU3WhLmxyVqvNCGippmYWpJdJ40upBEhEEzwTi9PTRbwZoz6RONaKMmJCXhMwU/qX6TZpzAv5LgLJRwRmj4AwLs3nIxeHQoQlhb21S70a2/7N76xFHU6sdRa4NrQPieRPz8YIFTrLHAzSbQahaLWbysGTmV1g5L1mZoPPMnr7EJhjPAq+SJbMZrE7NauFXKDASXLryA35PgkZmMkoolFB4AT+xaZ7G0/eaHYAIQChKaI0Fjgan10+rCK+cAprsSAUYgnEKvmmIygJkorcfsA8Mzcstj2FL55souDPsLH7Hs5AU9iNmPUBw67UJIjW+D60LgN900AAPTtWIDWeUFUNzQ56vsNG/jA3URdMjZHuprJFjiRVrycPq7ULpS4VHqT91hd8o4shNmqv6t6cnTXwVrlcXlVnZKhmQ4RD++UWcCbMecN6648Zg9KcuSTJxSIP6zn3zYGH/7+NBTkhiBEfHSKnehT6b1E7ofGAtfc2jnbvvzx+juSRFgV8KCFWkHq7eoL+7hH5ymPb3lnheod8f1M5SLndrgvC3gzRp2CzT7w5CgWuMFR3auoAO1a5aAwLxr37KQfPOoD99ACVz0+LK3/qfaBaycx3bPA9eh/J1lfmywe62pB3nmwVlkWzQy9Z0Meh1qNSy2+7V0HtVFL2ytrNJFMas1mC5wxhFfkSY4iFgl8kAW50WkfJ9PpG8MRw7sAN9EfLn9SWZnaMEKn+2Eu4Po6LLKVvm73YZ2oGqP3NX+8YpdB+7HH+lj8l77eEte3p+f8gIc/X6/Z96Knv9a8b/SDczDyvtnKc7WFbvXiYxcs4FkCG+DJkU+eRPW3C3KjFriTFQLDEYFQgPD0ZcMdayMRRIQFZfvwTmks0aWiKro+J4FcnVuRj1t9VI6eNbsOKT7quz5cg5vfWpb0s8O6aBUj61d9h6EvofDND/sAaC3zact24r9zyvCL5xYq26rqEl/s1UMoF+IaeOd0/O1/qxN/ARtgAc8SznlsniWrpCUTMQgj1JMvCbiTkShNEYFgkDDxuG6OtZEIWY9ue2+l4evuWuDR/0Y+8I3lVcrjc59YoHlt0ebKpJ9d1Dov6T4LNu5THp/cv6PmtUO10SQvo4qMVpOJAK3TRTYiGsIRvPbtViy28D0ygQU8i8hk9e6WgGKBJ/A/F0i1P5xcaLhJssCbK2rL1c1EHj1PzfnB9H1Whi9Xd6dV09AUl+35r+nfK497dyzQvJborjYF/U6Yr6G25J2ABTyL8DJhIBuQhSlRhT3ZB+6UBS6EMEzkcZPqBN8tGNDGWbuZSp8KVmKp9REf93y8Fje8br7Co35uRO6bUVNGqwM1hiN4fv6muO08iekCDU0RVyYCV+44iE9Wxk+m2AHPYyZGPucS+cBb5UYPeSs+8PKqOox5eG5KixLLJ3COJFjd2+Xj+F7tLb/fDrZX1pi+FiCK9TFIzh9T0udbDQ2UsSL3Rh/5xbpy0/NcvzpTqlr7+rdbce+n6+K2qw2r0q0H4komWK2umA4tIhOzoSmCgX+djkmn98cdE4c42tZP/hudsVbHcNsFC3hijNbE1NNKssBrLdQEX7vrMDbvq8aDM9bjjEGdLfZBsjili8g3t59p6X12kuj7BwOkiZd33oUS/b9yx6GU3mfJAjfxc7y+aJvxG/RfNsUTyixySX0h+L+p8ZOvDeEIQkFnbOVMVqXvRURziGgtEa0hopvt7Jid3D4tekWcavbDNiP2Hq5D38mf4sPlO+NeS2VipSUStuADbyX5wK1MCJdLkRupRGpY8cM7jRxpAwBd2mon+gJEiushaoG740Jp1yonyZ5arAyfmWH7ncHEYXV9U5zLRRZeq5nv81UTomqSDaHV4lzpkMlloQnALUKIoQBGAfgdEQ21p1v28v7SHQC8LaxvlQ17ozPzN7+1PO61VFYqMWPmmj3Y4tPJULNUejWyuNVYcKEcqmnUfK6lPoTNs0HdQv399ReqQICUWim5oYDj4anyx193Wr+U3pfoXG1oimDC4/Px4tebDV9vpVukoqKqHsfc/bliyMmkeo01i4xJNjdVH3ZuwjyTVel3CyGWSo+rAKwD0MOujhlxz0dr8I6qiHuqpFpkpryqDi8s2KxYKat3HsKSrQfSbj8Rc9aXY8Cdn2lu0/RXdn1t63SY9NoSjH1krqV9hRCORmvYQV1jGI/OXI/6pnDMAk/gA88LBUBkzQKX44brmqyPwcfS/EfpVmfDx6xyWBfDHCDg+StPxC1nDUSPDgWuRaHkhFKTGn1o34HqBgy9awZKt1Ti+ldLsW63+QIZczdo5yx2H6o13E/vE0+XZBfBgzWZn7dm2GImEFFfACcAWGTH55nx8jdbcNv7xrGtVlDr9+x1ezHm4bnYd6Qe5z053zBE78bXl+Kfn6xVXjvvyQW4+JlvTD8/ldW0y8qrsErlF3zsi41oDAuUlR8xfc+tqrje6at2W4oxrW0Ix303q92856M1GPy3GdZ2doFdB2sx53vtyfncV5vwxJdleG3hVlU1QvMTk4jQKidoTcCli+nBausn4MJN+wEA3++pSrKncyRyiwSJ0LtjAW46cwAoyb529iUnRR/wnsN1GpGetmwnahrCuPujNfhqQ0XC9+49XK/rg/F+9SnUw0k4TknG8NZ3V2DW2r2OjHXGAk5EhQDeB/AHIUTcZZGIJhFRKRGVVlQkHninUZ/Wd36wGpv3VWPqom1YvfMwnpy9MW7/AzUNAIwF73Bdo6a+BAB8sW6v5b6Me3Qezv9vLHnBSHLm6KIfKqsblMc3vrE0LsZ0/Z4qPDWnTLPtN68vwZiH56Z18LyycCuA5pPGf/6TC3D1y99ptsm/QV1jzAJPlEoPSIs6WLizkMPxquqb4n5rM2IuFO/8dYku0Gqr040uyoeOPmbbCvJ6lwDwtHRcr9l1GJ0KEyfwXDGqj+a52eTjWukCYcVHveOAsRUPJI+lX7HjEK5/tRSfrdqTtJ1UyUjAiSgHUfF+QwgxzWgfIcQUIUSJEKKkuLg4k+YyxsiFot5UVl6FbftjIVjywWd0oA+7ZyYuf157w1FvccURq3385of9Kb33wqe+xkOfr9f4bOdJ1komGmyH790O9qsuYDLycO070qAUM0rmf27bKgcHDD5Lj/rEr7SwP6CuSe6dDzyRT/aHitgdHhFh/sZ9SYtAZcImqUxrboouFD3q5eH2HalPsGf8pPP/GcwnqalpTB6R9PeP15q3Z/GWdu9h+5fyyyQKhQC8AGCdEOJR+7pkjc37qtF38qeYucb6Va2hKYI/vbMc5VV1ykFOuhKTpz80BwCw40CN4nowmxT7bovWH67+GZ3ImuzeLj9u22sLtyiPZV+tkcWciQSnGsObDpc9/y2u1VnXVpCTUl7+Zgse/yJ6FxVMYu31aN8KOw+aW1QyagE/kqQehox8EU/H4rSLRBdrdV0PeT7nsS82ONaX+z6Lxk2n6kKREUKgqq4Ry7cftPwe/YIQyQTfWmnh+EGdtXYvysqP4J4E4q7GibozmcSBnwrgCgCriGi5tO0OIcRnGffKAm9Lk5mfrNyNs4/pauk9R+qbMG3pTsMDXL3p/s/W4XBtzO+ZyiSWzJiH52LLA+em/L5E7DoUfwX/24drcMXJfTXbIiJ6sXp45npb2jU78KrqGnHcPTPx/JUlGDe0S8qfKy8tRgR8XZba3YbMc/NimXFVkuAmc1/07NAKK7YfTLp6SrVq7Uyr5We7tIne3rudvKMmkUwYuZf0PmMnSFfAz/7PPI31bYVUKgIKISwl2hh95vWvlmpKPntBJlEoC4QQJIQYJoT4kfTningDwLNfResopHNVkxamVh4DwAfLYnHXU+Zp02XHPzbftUJSmYQ6yt+pIRxNXFJ/j0z82L/6f8Zz0/Lt8RNfxs8fWOGPby9H/zs+w00GyQ/pkhsKIF8XRqZnQOc2OFzXlFS4ahrDaJ2bWv3w0wZ0AgBcqbuoukmin9qwLrcLNwvpCvjG8iPYuj+1u1mzBB/jfYWlJBuzUNJUJqudsMCzJpV+lUkmV6IhketS6DGqPpaMf02PT6FNFznW2y6q65uwZldsfIwuNvpR+LrMOCnh5reW4Zi7ZmjGbdVO47G/4CltneS9h+tw/N9nYr3Fg/p/y6Mhd5+s3K1sO+OhOXhhwWZ8tmq32dvQd/Knpv3Ps3Ay9i9uDQDYfsA85RwA6hrCKJYsaqsuFCvJRE6T6GJt5A50Y/GJ3FD6baRaX0Q+rqzQFBE47ehOSfezo3aOPj7dDrJGwNURG8/MVVUxS/DbXvj0Nzjqjvibgui6gFEenGHsZtAf53I9ZTM27K0yTKPV83XZPpz9n3lx2zOxvG98Y6mmHKfRJNbv3liqiemW/cV6Ply+C9UN4bhSpEt0cc36iZtxj36Fk+6fjUO1jXhF5Zdft/uwkhBTVn4EH6/YhZe+3mwaT79lfw3++cla/PaNpYavy7y2cKth5JCVeOPe0i35lS8sTih2NY1NMQG3aIErkTCeRqEkCCM0GB674qH1qEu5pmuBA9FjwimsXhzsyP8YpStnawdZUQvlUK02DvffM2IlIhPNuK8wmfhoCkdsqyuyqeII/rdsZ8K18G6fthJ9OrbGDT8+Cpt0k5sHqhvQoXWu8jydu4PSLVpx/Xx1/MTuzLV78aUqhjrZ7dynq7RWzMXPLNT49NXfV1/noq4hjO+2VGLngVr84e3lSftvxvyNFTj1qE6GAjNr3V7MMJjAtrIWZY8OrQBEC1ptq6xBn46tDferbYgoIWtWBVweV6dE0VoftM/zQgFlctWoX0519fIXYq63XIdqgWTKsm0HXQuTdWK1+uY5qjrUgq0nnRCoAzWNaEgyMbl2t9YNMF0liurMrrGPfIUnvixDpUmyx66DtZi6eDsemG78HU745yzNcyslYw/pMrv0t8V/+3CN4fvUx6lRK2oLPdmFJJFLYdqynfj5swszEm8AuOKFxeh/x2cY8/DcuBAsM8vJiqWXFwriypOjscJmWXLhiMC+I/VKspQVF8qaXYfwl/ej6drJYtGdRG/wqN05Rq4dN/qaaiZmJhzTva3lfS9/YZFrq105caHMCgFPtH7hF+vK8eX3sQSavpM/xW3vrTDdHwC+2lARl2Ksx8x6B4CT//Vl3Dajc+DjFbtwygPafc1+w2Xbou2ZuXTUbNFN6lg9/xZtjkV6bN1fg3KVKIYjQpN1aXSwPT23DIeldP4LdesEOsnmfdU46f7ZyXeEdUtv3JBo1IxZgTC53OyJfYuQFwrgiIXqhWqXgcdLYmpQV8Y0EmvZMtxeWYOHP1/viEXapW18CKxTpBpw8Nq3Wx3qiZZENXrS/kzbP9EBkoUFXfNyKR77YgNK7o1as++U7sAp/7J2wtvFok3xYXD66Iq+kz/FXw3Wycu0CHyyNftkXl0YO1D3HanHyPtn402pQuMjupBDo4PtwRnrMeyemdhzqA5bHfRLZoJVX6tsFFz3Simmr9odV2emUbqzO6l/EdrkhyxZ4Ooxa04ug8kTBiuPjVwoL3+zBUu3HcDoB+fgv3PK4tx8duDmeDjRfztwQsCzwgduJdPpMd2knFHMtJP8UJH+QfPl99YXDLCbOz5YhX/P+D7utrsqwV3P2xkUFHMaKwk6AFDSt0hJ6LnxjaVokx/CHROH4NKRvQHEkpdyggG0zgtZ8oEPUsUEt8lPrXyqkxTkxaIfzNwlP306VuPHiczM1nn2R2BkQv/i1koYrFs44anKCgFvLqncTnH9q6Wetq8X72Q056XdrE42FrfJw9eTx6IxHMGybQfx+OwNuH3aKhQX5mHc0C5olIyG3GAAhXmhhG48GbV/2csoFD15oZh4WplcrbHgLkoVO6zP9gU5liv7ndSvKOHCyMWFeb4Q8OZzn5cAq4WEGHewWhckG8gJBjCyXxFevnok+nYswBRpzUPZhZITIhTmhSy5qZrLZU29oIMeK66MI/WZn2/6u+Y81SRm347xmZW9ilpl3Kaa/sWF+GVJL9PXvZhjbrE+8H6djMO8Wgqz/ni68rg5VAZU+9L9Qk4wgItO6InFmyvx/PxNigslFIha4FYse/mnefO6k5zsalLUSSfjhkSXgrvwR9GJzFYJxF2mur4pYzeKet7qwYuHJQ2ha51rrzMgN0jIy2le8tZiBfz60f297oKnDOgS863e8cFqvPVd818aLhuZcFy0ps69n65TViXPCQZQmG9RwJHe4gVO8cxlw/H8VScCiAm3FRF5+estGPjX6difpAhUItR5Bpvjoqbi+6CffB49IHl2ZCKCgUBCF4lRmOxDPxsGwN4s2rNVNYJabBhhJllcfmPq4m2Yurj5TiJmMwM6F2JYz3YAgI17o2VX80IBFORaWwBCqa/jWA9TQ13jQ46WtGIELpYSw855bH6SPc3ZoSpTkKe7oBkJmX4VpbvPPybttgHgpW82Y4FJuQXAeBzkC4td97gj+xXhgYuHxX2+nWSFMjanCSHGvxARnrl8BIBoDD8QNR7yc4JKXHgi5BO/uay9qhZF+e4glVNp35F6rNpxCDMMMnuToZ4zuPpU7XqY8jiN6NNB2VasW6ShbX4I//nl8ZptqQxrMk/jwC7mVQQzDeuVIWijflpsFAoLONCnY0Gzjb32Ez3at8LxPdththTamROMLsFmZW1QeX7CCUsrHdTuEmUFdpUM/nxET7y7ZEfCz5BrEP2ipCcuPMH6krc/SEsDjuxbFL8ivdSXf188DOMe/QoAcPO4AZi5NpaQ17ZVDi46oSf++HbipLxEHNO9Ldbsiq66s+WBc3HuE/OV523yM5O+Zy8fgU9W7tIUYjOCVCZy3DjYQFYIeKaD7QfYjWSNG884KuPPuHhET6yQ6rvkhAJolRNEY1igMRxJ+Ds0NxeKuh+3njMI1fVNOHdYN2Xbvy8eFifgHVvnYn91A356Qg9MU5VYfqd0B94pTSz2Rtx1/tC4bcP7dMCmfdVoqzqv1aGObfNDcW4XwPpargDQOjeolBV+8/qTpP+jMOGxedh1qC7uInv/RcdZ/3AApw/shPHHdsUNPz6E855cYLqf+iLqxDmcFcrI4gWlLjWTmNvOGZTxZ4weEFv6LzcYUCYAaxvDyAkGEIkI7DpUi65t8zV+ZqNVnrzg1KM74uuy/Zpb9i5t8xX3kEwgQPjq1jOQEwwoJR/kZesGdW2Ds4Z2wSzJKn7k58crRcCsUpgX0tQlGdKtLfp3ao37LjoW15zaD51V6fV5oQD+fPZAnHNMV82kvZpLR/ZW1gFQc/HwnmjbKoRrTu2H0Q9GV9SaPHEIpksliWX/f7tWOZh32xg0hgWem6f9nF+d1BvvSxezsYM7K8l1U64YgUmvLYlrs0CKmjm2Rztlm36lJ4GYy+rozoWG3ylTskLAAeA3P+6P577alHxHv9JMbsu9IJWsOTvEUx2nnBuKCfjeQ3W495O1mLu+AuVV9ejeLh9PXz4CP5JW32kuFrgwcJeYYVaJ8Zju7XDd6P5YueMgTujdwXCfVJl+82jl8VBJ2GXXYDgi8PuxA0zfO/X6URjVvwh/OmsgBv51urK9Y+tcPPKLmK/8lKM64psf9mPvoTrcdf5Q3PW/NRjep73yeigYQCgYrYWjz96WadcqB61ygvjzOYNw8lHaErBnDCrG3PXaxdkX3j4W+aEg2hfk4IHp3yurROUECQW5Idx6ziCMHdw5yeikR6aLGo8novVEVEZEk+3qlBG3TxiCF39dkvL7/vPL4/HPC4+N2z68d3sbegXMu3UMBiS5uiZKKEiG/Nl2iELPDq0w5YqYFXZsj/iqbded1i9um5fcNPZo3DT2aFfbJN1tb2Fe1M6Z8Ph8fLBsJ0b2K8KdE4cgECD85rVSJUJFv8qTV6TTj/suOhYf/u5UjOpfhE6FuThtQCcEA2SbeJshuxjMyjEv+MsYfHfnOJx8VEcQEXJDAfzjgmPw5vUn4SfHd8eUK7Wa8NSvhmNot7a48YyjMLhrW7xzw8mKtazm2B7tsPlfEwEAXaU7gW7SmrNHdy7Eun+Ox7Wn9YO+1tnLV4+MWyqxW7tW6NA6F0SE2ycOwUu/joZu/mHcQADA78YcjSHdrFdITIW0LXAiCgJ4CsBZAHYA+I6IPhJCWFvhMw3GDu6CR35+PG55NzaxseWBc9F38qem77nohJ4AgKHd2uDiZxbikhN74faJQ9A2P4R+t0cXe3j28hFoX5CD295biW2VNZo03F5FrbC90ri+xuCubdC7Y4Eya13cJg+Haxs1q9PLP/bbpdrQvx7tW+G5K0Zo/GfFbfI0C0dcPLynEpt6+sBiLN9+EP+44BjcpSoXu+AvY/Dk7LK4z1fz5nUnoVdRAbq2y0dOMICy+yagtjGM/y3bidU7o591XI92qG0M4y8TBiMnFNAsmvHXc4dg4nHdUNsYxlHFhfjy+7245mXj9P/xx3Q1rNP93BUj8BvdrehNY4/Gk1+WabYVtc7VZHoSES44vkfCyayXrj4RV7/0HU52oGB+m/wQjiqOXkSbIgLPXDYcE47rpvT1lndXYMhdMzTvSaemuxOk0ovLToqW1516/ShXXUCyi8Gs3lHPDvFZm/JydaccFR8r3qF1Lj5TWfqJICKs+8d4pXLkKUd3wtuTRqGkb5GyT67ki+/cJg93TBxi6XPHDO5s+3q4ZmTiQhkJoEwIsQkAiOgtABcAcEzAgegE09DubTHh8fmY9ttTAAAP/PQ4fLJyN/p2KsC5x3VHSd8OGHDndJygsrJH9CnCd3eOU1ZYAYBXrxmJDXurMP7YaALHHROH4IbXl+DZy0egMD+EVxduxdlDu6BD61zsPVyHMx/5CkO6tcV7N5yM1nmxoXvo58fjsS824MVfn4ggEQSAP7+7QhOH+so1I7H3cB3Ol0p7hoKEnGAAz1w2HOVV9ehYmIszB3fBzLV7MLBLm7gr9h/OHIBLR/ZC2/wcPPT5egzp2haLt1Sia9t83P/T43DagE44b1g3EBFW7TiE8qo6dG6Tj27t85VFCWRCwQDaBAO4ZGRvNIQFrhjVRzlQAeAv4wfjL+MHo6ahCfM27FPGR2bs4C7Y8sC5KCs/grb5IY0vs6KqHq3zQuhUmKvcSnZvl49zjumKsvsmYN7GCkX8bzl7EIZ0a4veRQX4dtN+3PvpOtx/0XFYtv0ARh9djCe+3IgrRvVBIEA4a2gXbNlXjetG98NFJ/TE9a+Wonv7fJx2dDHGDOqMb28/E+0L7Jvln/bbUzBj9R50KsxDh4LYghvnqBbQnnhcN40xIVPgceGmE/sVYeGm/ejSLvUSrm7773/UqwN+qKjWnE9uos9MPUlnBLTKDWLtP85Bfijo6SIdZlC6qdlE9DMA44UQ10nPrwBwkhDi92bvKSkpEaWl7hRuWrnjIPp0bG1r6M4LCzZjwrFd0b29vXUb0kEIgcaw0Ahvc0W/+vu63YdR09CEEX1ilk4kIrCgbB9GD+jk+SSgEa8u3IK+HVvj9IHFca/VN4URjgis212Fw7WNGOOQv9Mq4YjA1v3V6F/szMSZndQ1hvH9niplHoExhoiWCCHifMiOCzgRTQIwCQB69+49YutW/9XRYBiGcRIzAc/EfNsJQD0711PapkEIMUUIUSKEKCkujrdeGIZhmPTIRMC/AzCAiPoRUS6ASwB8ZE+3GIZhmGSkPXMghGgiot8D+BxAEMCLQgjj1XQZhmEY28lo6lcI8RmAz2zqC8MwDJMCzT+EgWEYhjGEBZxhGCZLYQFnGIbJUljAGYZhspS0E3nSaoyoAkC6mTydAJivkdQy4THRwuOhhccjnmwdkz5CiLhEGlcFPBOIqNQoE6klw2OihcdDC49HPH4bE3ahMAzDZCks4AzDMFlKNgn4FK870AzhMdHC46GFxyMeX41J1vjAGYZhGC3ZZIEzDMMwKrJCwN1ce9NLiOhFIionotWqbUVENIuINkr/O0jbiYiekMZkJRENV73nKmn/jUR0lRffxQ6IqBcRzSGitUS0hohulra35DHJJ6LFRLRCGpO/S9v7EdEi6bu/LVUIBRHlSc/LpNf7qj7rdmn7eiI6x6OvZAtEFCSiZUT0ifS8ZYyHEKJZ/yFa6fAHAP0B5AJYAWCo1/1y6LueDmA4gNWqbQ8CmCw9ngzg39LjiQCmI7r04SgAi6TtRQA2Sf87SI87eP3d0hyPbgCGS4/bANgAYGgLHxMCUCg9zgGwSPqu7wC4RNr+LIAbpce/BfCs9PgSAG9Lj4dK51IegH7SORb0+vtlMC5/AvAmgE+k5y1iPLLBAlfW3hRCNACQ1970HUKIeQAqdZsvAPCK9PgVABeqtr8qonwLoD0RdQNwDoBZQohKIcQBALMAjHe88w4ghNgthFgqPa4CsA5AD7TsMRFCiCPS0xzpTwAYC+A9abt+TOSxeg/AmRRds+4CAG8JIeqFEJsBlCF6rmUdRNQTwLkAnpeeE1rIeGSDgPcAoF5yfYe0raXQRQixW3q8B0AX6bHZuPhyvKRb3RMQtThb9JhI7oLlAMoRvRj9AOCgEKJJ2kX9/ZTvLr1+CEBH+GtMHgNwG4CI9LwjWsh4ZIOAMxIieq/X4sKGiKgQwPsA/iCEOKx+rSWOiRAiLIT4EaLLGI4EMNjbHnkHEZ0HoFwIscTrvnhBNgi4pbU3fcxeyQ0A6X+5tN1sXHw1XkSUg6h4vyGEmCZtbtFjIiOEOAhgDoCTEXUXyQu0qL+f8t2l19sB2A//jMmpAH5CRFsQda+OBfA4Wsh4ZIOAt/S1Nz8CIEdNXAXgQ9X2K6XIi1EADkluhc8BnE1EHaTojLOlbVmH5Jt8AcA6IcSjqpda8pgUE1F76XErAGchOjcwB8DPpN30YyKP1c8AfCndtXwE4BIpKqMfgAEAFrvyJWxECHG7EKKnEKIvotrwpRDiMrSU8fB6FtXKH6LRBRsQ9fXd6XV/HPyeUwHsBtCIqA/uWkT9c7MBbATwBYAiaV8C8JQ0JqsAlKg+5xpEJ2HKAFzt9ffKYDxOQ9Q9shLAculvYgsfk2EAlkljshrAXdL2/ogKThmAdwHkSdvzpedl0uv9VZ91pzRW6wFM8Pq72TA2ZyAWhdIixoMzMRmGYbKUbHChMAzDMAawgDMMw2QpLOAMwzBZCgs4wzBMlsICzjAMk6WwgDMMw2QpLOAMwzBZCgs4wzBMlvL/AbB1QIosoxXjAAAAAElFTkSuQmCC\n",
      "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": "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\n",
      "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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\n",
      "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": "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S/369bn44ovZunXraWV+//13WrVqlfFTunRpXn/99Yz5b775Jo0bN+b888/n0UcfBWD16tUMGDAgfz4EOGfOofRzYXVUR6F66A/Na6mpaaeMP/TQTH3nnWWalubJ822Zwm/dunXBDkFLlCiRMXzbbbfp888/r6qqiYmJWrduXZ01a5aqqh4/flx79OihY8eOVVXV1atXa926dXX9+vWqqpqamqrjx4/P09hSUlLOeR033HCDrlixIl+3eSbGjRunAwcOVFXVzz77TG+66Saf5VNTU7Vy5cq6detWVVX98ccftUuXLpqUlKSqqnv27Mko26VLF/3rr7+yXU92xx6wVM/yezfoX/xn+pORKPLYjz9u0caNx+pPP23N83WboumUf9ZRBOYnF96JYsKECXrvvfeqquq7776r/fv3P6Xs5s2btXr16qqq2r9/f33vvfdyXf/Ro0d1wIAB2qxZM23evLlOnTr1tO1+8cUXevvtt6uq6u23364DBw7UNm3a6EMPPaS1atXSQ4cOZZStX7++7t69W/fu3at9+vTRuLg4jYuL0wULFpy27SNHjmjDhg0zxhcvXqxt27bVVq1a6SWXXKIbNmxQVdUPPvhAr7rqKu3UqZO2b99ejx07pnfccYdedNFF2qpVK/36669VVfXPP//Uyy67TFu3bq2tW7fWn3/+OdfPn5tu3brpwoULVdVJUrGxserx5HziOWvWLL300kszxm+88UadPXt2tmVff/11femll7Kdl9eJIvTaKABqdMyzVe3de5yhQ2fz0UcrARg9+hfat6+VZ+s3piBIS0vjhx9+yKimWbt2LRdeeOEpZerVq8exY8c4cuQIa9as8auq6bnnnqNMmTKsXr0agEOHDuWyhHPb8MKFCwkPDyctLY2vvvqKO+64g8WLF1OrVi0qV67MLbfcwkMPPcRll13Gtm3b6N69O+vXrz9lPUuXLqVZs8weEBo3bsz8+fOJiIjg+++/58knn+TLL78EYPny5axatYry5cvz5JNP0rlzZ95//30OHz5MmzZtuOKKK6hUqRKzZ88mOjqaTZs20a9fP5YuXXpa/JdffjlHjx49bfqoUaO44opT3zGzY8cOatSoAUBERARlypThwIEDVKhQIdt9M2XKFPr165cxvnHjRubPn8+wYcOIjo5m1KhRXHTRRQDExcUxcuTIjOqoQArNRJEH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\n",
      "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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LFmS52s8H7Gxsfzwww/s2rWLMmXKcOuttzJx4kQGDhwIwNixY0lLS+PRRx9l2rRp3HnnnQBUqlSJzZs3F2iWnATmN2adnh5NtmxZDHXqjOTXX3dnDtMioQqbyMhIVq9ezZ49ezDGMGrUKAAaNWrEihUrzpp2586dlChRglKlStG4ceNzxp8P110r2c/rL168eGb3VVddxfbt2zly5Ajff/89N998MwDp6eksW7aM1atXs3r1avbv339Wkch4ba7LfuWVV+jQoQPr16/nxx9/PGuc63MaY/j2228zl713714aNmzIBx98QOXKlVmzZg3R0dEkJyfn+NquueYaWrRocc7f4sWLz5m2atWq7Ntn/bhNTU3lxIkTlC9f/qxpFi9eTK1atahYsSLh4eHcfPPN/Pnnn2dNExoayu233565hZSxXiMjI3PMWJCC9ltz0aIddOz4NQcOxPPllyudjqOU44oVK8bIkSN57733SE1NZcCAASxdujTzy+306dMMHTqUZ599FoBnnnmGt956K/NXdXp6Op999tk5y42KisosPpC166ly5cps2rSJ9PR0vvvuu1xziQi9e/fmySefpGHDhplfop06deLjjz/OnG716tXnzNuwYUO2b9+e2X/ixAmqVq0KwLhx43J9zs6dO/Pxxx9nnuG1atWqzPmrVKlCSEgIEyZMIC0t57MslyxZkllkXP+y73YC6NmzJ+PHjwesYzXXX3/9OccnatSowbJly0hMTMQYw08//UTDhg0xxmS+PmMMs2bNyjxmBLB169azdr15S1AWihkzNnLjjVbjfoMHN2fcuJucjqSUX2jZsiXNmjVjypQpREZG8sMPPzB8+HDq169P06ZNufzyy3nkkUcAaNasGR9++CH9+vWjYcOGNGnShJ07d56zzJdffpnY2FiaNGlC8+bN+eWXXwAYMWIE3bt35+qrr6ZKlSpuc/Xt25eJEydm7nYCGDlyJNHR0TRr1oxGjRrlWKQaNGjAiRMnMo8XPPvss7zwwgu0bNmS1NTcm/t55ZVXSElJoVmzZjRu3JhXXnkFgIceeojx48fTvHlzNm/efNZWSH7dfffdHDt2jLp16/L+++8zYsQIAA4cOEC3bt0AaNOmDX369KFVq1Y0bdqU9PR07rvvPowxDBkyhKZNm9K0aVMOHjzIq6++mrnsP/74o8B3JeZEMipqoGhd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\n",
      "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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\n",
      "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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\n",
      "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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c+cC8KMf/YhLLrmE4447jksuuYTZs2ezZs2a5PXmzp3L8uXLaW1t5Stf+QrHHHMMRx55JH/60586fabf/e53zJs3D4BNmzZx/PHHM3PmTGbOnMm//vWv5Odx/PHHM3/+fKZOnYplWXzve99Lvnf33HNP8rM95ZRTmDlzJtOnT+/yngfDn/70Jy699FJEhNmzZ7N//362b9/ero0xBmMMra2tGGNoampixIgRAKxfv54TTjgBgNNOO43f/e53yfM++9nPJv8GM0FxRMPjYonTm1ZSen39Mn7843/wzDNfZPbsUVk2Lke88B3YtSqz1xw6A076ebdN/vSnPzFv3jwmTZpEdXU1K1as4NRTT2XhwoW0trZSWlrKo48+ysUXX8yePXu45ZZbeO655ygtLeW2226jvr6eG2+8EYDq6upkt6yhoSHpId1www3ce++9XHXVVVx99dVcffXVLFiwgF/+8pdJO5599lk2bNjA66+/jjGG+fPn89JLLyW/WJ3x17/+lc997nMArFmzhqOOav8PtKKigjFjxrBx40ZWr17Nl770pR7fsiVLlrBp0yZWrVqFy+Vi7969PZ6zdu1aXnnlFfx+P4sWLeKxxx7jxz/+Mdu3b2f79u3MmjWL6667jpNPPpn77ruP/fv3c8wxx3DqqadSWlqavM6HH37I4MGD8Xpji/gNHTqUv/3tb/h8PjZs2MCCBQtYvnw5AG+++SarV69m3LhxLFmyhMrKSt544w1CoRDHHXccp59+OqNHj+YPf/gDFRUV7Nmzh9mzZzN//vwDenMXXXQR69atO+C5rrnmGi699NJ2+7Zu3cro0aOT26NGjWLr1q0MHz48uc/tdnP33Xczffp0SktLmThxIosXLwbg8MMP509/+hOf+9znePzxx9m8eXPyvFmzZnHrrbfy/e9/v8f3PB2KzLPsuURbIpjT1BRi7drd/WHdgGLp0qVcfPHFAFx88cUsXboUl8vFvHnz+POf/0w0GuUvf/kL55xzDq+++ipr167luOOOY8aMGTzwwAPtxgwvuuii5OvVq1dz/PHHM336dB5++OGkt7Vs2bKk1/r5z38+2f7ZZ5/l2Wef5cgjj2TmzJm89957bNiwoVObTzrpJEaOHMnTTz/NggULMvp+PPfcc3zta1/D5Yr5JVVVPa8jP3/+fPz+2OqgF154IU888QQAjz32GOeffz4Qe75bb72VGTNmMHfuXILB4AFdzu3btzNkyJDkdiQS4YorrmD69OlccMEFrF27NnnsmGOOSabSPPvsszz44IPMmDGDY489loaGBjZs2IAxhuuuu466ujpOPfVUtm7dys6dOw+w/9FHH2XVqlUH/HQUynSJRCLcfffdrFy5km3btlFXV8dPf/pTAO677z7uuusujjrqKJqbm/F4PsmIGTp0KNu2bevVPTujqDxL04NnOaDKrPXgAWaDvXv38vzzz/POO+8gIliWhYhw++23c/HFF3PnnXdSVVXFrFmzKC8vxxjDaaed1uXYZqqXdNlll/HHP/6RI444gvvvv58XX3yxW1uMMfz7v/87X/va13q0+4UXXmDQoEF84Qtf4KabbqK+vp6pU6cmRSpBU1MTH3/8MRMmTODwww9nxYoVnHPOOT2/MZ3gcrmwbRvggDSW1OceOXIk1dXVvP322zz66KNJ79kYw+9+9zsmT57c5T38fn+7ay9atIja2lreeustbNvG5/N1ek9jDHfccQdnnHFGu+vdf//97N69mxUrVuB2uxk7dmynKTgH41mOHDmynTe4ZcsWRo4c2a7NqlWrADj00EOB2D+QW2+9FYApU6bw7LOx7/T69ev5y1/+kjwvGAwm/+lkguLwLKM9d8O1zFr2eeKJJ7jkkkv46KOP2LRpE5s3b2bcuHG8/PLLnHjiibz55pv86le/Snqes2fP5p///CcbN24EoLW1lfXr13d67ebmZoYPH04kEuHhhx9O7p89e3ZynCp1fOqMM87gvvvuS46Bbt26lV27ui7Y7HK5+PnPf86DDz7I3r17OeWUU2hra+PBBx8EYmOP1157LZdddhklJSVceeWVPPDAA7z22mvJa/z+978/wNM67bTTuOeee5KBk0Q3fOzYsaxYsQKg3ThbZ1x00UX893//N42NjdTV1SWf74477sAYA8DKlSsPOG/SpEls2rQpud3Y2Mjw4cNxOBw89NBDXQbOzjjjDO6++24ikQgQE6HW1lYaGxsZOnQobrebF154oV0vIJWD8Sznz5/Pgw8+iDGGV199lcrKynZdcIgJ6tq1a9m9O9YT/Nvf/sZhhx0GkPxMbdvmlltu4etf/3ryvPXr1zNt2rRObewNxSGWKd3wzqLhP//5qyqU/cDSpUs599xz2+0777zzWLp0KU6nk7PPPpunn346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\n",
      "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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+fqTn/ykz31Xrlypxx9/vKqq3nDDDXrhhRfqUUcdpRdccIEefvjhunbt2tT1jj/+eF25cqV2dHTov/7rv+qHPvQhPfjgg/XBBx/s9/4zZ87UYDCoqqpvvfWWHnPMMbpw4UJduHChPvPMM6nfxzHHHKMf+chHdPbs2RqNRvXqq69OfXa33367qsZ/tyeddJIuXLhQ582bN+A9d4clS5bor3/969T2nDlz9L333uvR5oUXXtCTTjoptX3PPffoZZddpqqqp512mj777LOqqhqJRLSurk4dx1FV1R//+Md600039Xvf/r4rwCodRHtKJBq+ezN4GhpW8J3v/J1HHrmQI46YlkPDCsgTX4Hta7J7zQkHw4k/HrTJ//7v/3LGGWcwZ84c6urqWL16NaeccgpLliyhs7OTiooK7r//fi644AJ27NjB9773PR577DEqKiq46aabaGho4Prrrwegrq4u1S1rbm5OeUjXXnstv/zlL/nSl77EFVdcwRVXXMHixYu5/fbbU3Y8+uijbNy4kRdeeAFV5ZxzzuGpp57iuOOOG9D2v/zlL3z0ox8FYN26dRx6aM+eRnV1NdOnT2fTpk2sXbuWiy66aMiPbNmyZWzevJk1a9bg8XhoaWkZ8pz169fzj3/8g7KyMpYuXcpvfvMbvvOd77B161a2bt1KfX093/rWtzjppJO488472bVrF4cddhinnHIKFRUVqeu89dZbjBkzBr/fD8CECRP461//SiAQYOPGjSxevJhVq1YB8OKLL7J27VpmzpzJsmXLqKmpYeXKlYRCIY4++mhOO+009tprL/7whz9QXV3Njh07OOKIIzjnnHP6jAGef/75bNiwoc9zXXnllXzmM5/psW/Lli3stddeqe1p06axZcsWJk+enNo3a9YsNmzYwObNm5k2bRoPPvhgajgk/XyPx0NNTQ3Nzc2MGzeO+vp6fvCDH/D1r399yM88E0pDLHejRFt6MGf9+qbSFcsCsXz5cq644goALrjgApYvX86hhx7KGWecwR//+EcWLVrEn/70J374wx/y97//nfXr13P00UcDEA6HOfLII1PXOv/881Pv165dy7XXXsuuXbvo6Ojg9NNPB2DFihU8+OCDAHzyk5/k6quvBuJi+eijj7JwYbw6VEdHBxs3buxXLE888URaWlqorKzku9/9blY/j8cee4wvfOELeDzxr9rYsUOvI3/OOedQVhZfHfS8887jtNNO4zvf+Q6/+c1vWLRoERB/voceeogf/ehHQDwT4p133uGAAw5IXWfr1q2MHz8+tR2JRLj88stZs2YNbreb119/PXXssMMOS6XSPProo7zyyis88MADALS2trJx40amTZvGt771LZ566ilcLhdbtmxh27ZtTJo0qYf9999//25/ToMxZswYbrvtNs4//3xcLhdHHXUUb7zxxpDnTZgwgffeey9rdpSGWCYDPEN4lqOqzNoQHmAuaGlp4W9/+xuvvvoqIkIsFkNEuPnmm7ngggv42c9+xtixY6mvr6eqqgpV5dRTTx1wbDPdS7r44ot58MEHOeigg7jrrrt48sknB7VFVfn3f/93Pv/5zw9p9xNPPEFtbS2f+tSnuOGGG2hoaGDu3LkpsUjS1tbGO++8w6xZszjwwANZvXo155577tAfTD94PB4cJ752VO80lvTnnjp1KnV1dbzyyivcf//9Ke9ZVfnd737HfvvtN+A9ysrKelx76dKlTJw4kZdffhnHcQgEAv3eU1X56U9/mvqDlOSuu+6iqamJ1atX4/V6mTFjRr8pOLvjWU6dOpV33303td3Y2MjUqVP7nPuRj3yEj3zkI0DcW3e73T3OnzZtGtFolNbWVurq6oD455r8o5MNSirAM9i64VZmLfc88MADfPrTn+btt99m8+bNvPvuu8ycOZOnn36a448/nhdffJGf//znXHDBBQAcccQRPPPMM2zatAmAzs7OHt5OOu3t7UyePJlIJMKvfvWr1P4jjjiC3/3udwDcd999qf2nn346d955Jx0dHUC8u7Z9+8AFmz0eDz/+8Y+55557aGlp4eSTT6arq4t77rkHiAeZrrrqKi6++GLKy8u5/PLLufvuu3n++edT1/j973/Ptm3belz31FNP5Y477kgFTpLd8BkzZrB69WqAlP0Dcf755/PDH/6Q1tZWFixYkHq+n/70p8SH2uCll17qc96cOXNS0WGIe4iTJ0/G5XJx7733Dhg4O/3007ntttuIRCIAvP7663R2dtLa2sqECRPwer088cQTPTIH0rn//vtZs2ZNn1dvoYS4F33PPfegqjz33HPU1NT06IInSf7udu7cya233sqll16aOv/uu+8G4v//TjrppNSwwOuvv868efP6tXE4lIZYJjxLl6v/6Us//vFzJpR5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\n",
      "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
}
