{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "import os\n",
    "\n",
    "# Add the IPP directory to the Python path\n",
    "sys.path.append(os.path.abspath('./shutdown_problem/IPP'))\n",
    "\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib import colors\n",
    "import random\n",
    "import itertools\n",
    "import time\n",
    "from tqdm import tqdm as tqdm\n",
    "from copy import copy\n",
    "from IPython.display import clear_output\n",
    "from collections import Counter\n",
    "import dill\n",
    "\n",
    "# My modules\n",
    "from grid_env import GridEnvironment\n",
    "from policy_agent import Policy_Agent\n",
    "from draw_gridworlds import draw_gridworld, draw_policy, draw_full_policy\n",
    "from rl_utils import run_episode, evaluate_agent, get_transition_dict, compute_entropy, get_discount_matrix\n",
    "\n",
    "plt.rcParams[\"font.family\"] = \"Times New Roman\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_trajectory_probs(env, agent, transition_dict):\n",
    "    ev, final_state_distribution = evaluate_agent(env, agent, transition_dict)\n",
    "    return final_state_distribution.sum(0).sum(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_object(filename):\n",
    "    with open(filename, 'rb') as f:\n",
    "        return dill.load(f)\n",
    "\n",
    "def save_object(obj, filename):\n",
    "    with open(filename, 'wb') as f:\n",
    "        dill.dump(obj, f)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Editing Environment:\n",
    "\n",
    "### LOAD:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "filepath='../paper/shutdown_problem/IPP/gridworlds'\n",
    "# filename = '04_one_coin_only'\n",
    "\n",
    "# env = load_object(f'{filepath}/{filename}.pkl')\n",
    "# env.display(display_values=True, dpi=150)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "filename = \"10_royal_road.pkl\"# sorted(os.listdir(filepath))[:-1][6]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 370x370 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "env = load_object(f'{filepath}/{filename}')\n",
    "# env.display(display_values=True, dpi=150)\n",
    "\n",
    "new_env = GridEnvironment(\n",
    "    walls=env.walls,\n",
    "    delays=env.delays,\n",
    "    coins=env.coins,\n",
    "    starting_pos=env.starting_pos,\n",
    "    env_shape=env.env_shape,\n",
    "    shutdown_time=env.inital_shutdown_time,\n",
    "    early_stopping=True,\n",
    "    count_all_steps=False\n",
    ")\n",
    "\n",
    "new_env.display(display_values=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "here1\n",
      "here2\n",
      "(0, 0) dict_keys([(0, 0)])\n",
      "pos in delay keys\n",
      "(0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1) Delay ID: 0\n",
      "applying delay of 5\n",
      "Final state: (0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0)\n",
      "(0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 0)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAATIAAAErCAYAAABdHw+WAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAW8UlEQVR4nO3db2xVZYLH8d89vdyWgrodkG0aaLVsA5tmRSiyMf6Jddyxs4bQweJ06EZwM64mHeIrzfXNbMZX18S42RjdYMw6QYIVuw7NKn9cFCK6LRbScseKTdcyU1gUbQWplFLa033xlG2pLb23vbfnebjfT3JyzvQep7+ec/rjnnOfnhMaHh4WALjMCzoAAMwURQbAeRQZAOdRZACcR5EBcB5FBsB5FBkA51FkAJxHkQFwXjiZlaPRaKGkhWnKMlPdsVisi4wzRsbUIGNqdMdisa6pVgol+idKIz9su6ScGQZLl35J5ZIOiIwzQcbUIGNq9MdisblTrZTMqeVC2fvDSiZbscg4U2RMDTKmRkLZuEYGwHkUGQDnUWQAnEeRAXAeRQbAeRQZAOdRZACcR5EBcB5FBsB5FBkA51FkAJxHkQFwHkUGwHkUGQDnUWQAnEeRAXAeRQbAeRQZAOdRZACcR5EBcB5FBsB5FBkA51FkAJxHkQFwHkUGwHkUGQDnUWQAnEeRAXAeRQbAeRQZAOdRZACcR5EBcB5FBsB5FBkA51FkAJxHkQFwXjJF1i2pP11BUqBfUqfIOFNkTA0ypkZC2cKJ/r/FYrGuaDRaLql42pHSqzMWizXV/qG5ejAULg06zETCw4NtL//ijiYXtmN9fX2553lWZvR9v7OqqqqpeX9tdThr0Mp9PTgUbrvjgZed2Ne2Z0xkpYSLLBqNFko6IClnuonSrL/2D83Vr2Wv2jUwbOcZcyTka/Dtxso8qU4Wb8f6+vryFStWWL2vv26PVZctfm2Xp4Ggs0zIV0SNewcrpTyr9/VIiVm9ryXNnWqlZH7jF8reH1aScgZD4VJbS0ySBoY9DQx7pbJ8O468E7M7oy6V2lpikuRpQF5owPp9LfNOzPaMU7L3tx4AEkSRAXAeRQbAeRQZAOdRZACcR5EBcB5FBsB5CQ+IzTjPrZM+/U+zvHSl9K9Hg82DtKnfJ9Xtlpr/KJ3pkbKypFsKpLvLpEfXSXetCjohpkKRTWSgXzr2wej//rJF6jktLSgILhNS7tvvpKqnpI+O/Pi1z78006s7pXOfSjfdMPv5kDhOLSdy7APpUt/VX2t+N5gsSIvve6X7N5sSC4WkJ38pHX5L+va/pT9/IO38F+nn95h1h4cDjYoE8I5sIodHTilvLpT+4i+ljmbp8LtSxT8Fmwsp8+yL0mcdZvmN56WatWNezJMKC6QNFdLeQ1JkTiARkQTekU3kyG4zX/UzM0lS/APp0sXgMiFluk5LW3ea5aoHx5XYOBX3SLlT/skygkaRjdfZKnWfMstlFWaSTImNvW4GZ21rkHzfLG+pCTYLUoMiG+/KaWVWWFrxU2nZ30rzbjJf+5TrZNeDDw+b+fxcPpG8XlBk4zW/Z+ZXCuxKoUmjp5xwWstxM192qxlqAfdRZGOdPWMu7EvSqgdHv35lufuUGYoBZ/VdlM6dN8uL84PNgtShyMZqfm/0s/aJikzi9NJx538YXZ7HRfzrBkU21pXTyhsXSn9VNvr1RYXS4uVmmSJz2tgxYaFQcDmQWhTZFZcvSa3/ZZZX/p3kjds0ZSPvyv7niDkFhZPGjtC/0Df5enALRXZF/KB0ceS8Y+lKcz1s7FR8u3lteHj0nRuckztXunG+WT7Fv0fXDUb2X3HlD8Ql6d+fMdOk674r/ewf058JaXH7cvOnSe0npKEhPrm8HvCO7IpkhlYc229OReGk+9aYee8FqbE10ChIEYpMkv70mXTmT2b5H56T3vUnnmr/zaxz8QcpfiCwuJiZR9eNXuh/aXuwWZAaFJl09WnllT9JmkjZz8f8N3x66aqlhdKmSrP89j6p7hqXPN//xIw9g90oMmn04v1NN1897GK8RYVSYenV/w2c9MLTUkmR+eym5hmp9jlzY8Wes9LJr6Rd+6V1tVLF49LA5aDTYipc7P++W2pvMssrfzb14KLVFVJXm/TNn6U//VG65W/SnxEptyBPOrhNWr9FOhyXXnnTTBNhvJn9eEd2ZPforRDKHrz2upK0+u9Hlzm9dFrBIqmxTnrzBWndT82fLEXmmCEaf71UeuKXUuOb3B3WBbwj++mjZkrUbeXmwj+uC6GQVP2QmeAu3pEBcB5FBsB5FBkA51FkAJxHkQFwHkUGwHkUGQDnJVNk3ZL60xUkBfrDw4NtkZC9Y7wiIV+RkN8my7ej7/udsj2jstt8RYLOMSlfEfnDEev3tSTr93UiKyU8IDYWi3VFo9FyScXTjpRenS//4o6mJUe+rrw0HCoNOsxEskPDbdHVdzbUh/633PM8K7ej7/udVVVVTR0dHVbv6/xl0aazXxz/tae+lUGHmYiv3JY7K7Y2hMO11eGsQSuPx8GhcNsdD7zcZPvvdSIrJVxk0Wi0UNIBSTnTTZRm/fX19eUPr1hRJ4szdnT0lq9YscLq7ThSYlZn/Lo9Vr1Ida95Ggg6y4R8RXT2C6lssd0ZG/cOVkp5Vv/OSJryMTHJnFoulL0/rCTljLzLsTqjzL98ZJyZHE+XSm0tCEnyNCBPfSutzxgaKJXl+zqRlbjYD8B5FBkA51FkAJxHkQFwHkUGwHkUGQDnUWQAnEeRAXAe9+xHxqvfJ9XtNo+DO9MjZWVJtxRId5eZh/netSrohG5kDBJFhoz17XdS1VPSR0d+/NrnX5rp1Z3SuU+De5KSCxltQJEhI33fK92/WfqswzxJ6YlHpMfWS8VLzJPFD8el19+R9hwyD/Elo90oMmSkZ180BSFJbzwv1awd82KeVFggbaiQ9h4yz7oMggsZbUGRIeN0nZa27jTLVQ+OK4hxKu6ZnUzjuZDRJnxqiYyzrWH04fJbaoLNMhkXMtqEIkPG+fCwmc/PtffTPhcy2oQiQ8ZpOW7my241wxhs5EJGm1BkyCh9F6Vz583y4vxgs0zGhYy2ociQUc7/MLo8b8obKAfDhYy2ociQUcaOtwqFgstxLS5ktA1FhowydvT7hb7gclyLCxltQ5Eho+TOlW6cb5ZPnQk2y2RcyGgbigwZ5/blZt5+QhoaCjbLZFzIaBOKDBnnvjVm3ntBamwNNMqkXMhoE4oMGefRdaMX0V/aHmyWybiQ0SYUGTLO0kJpU6VZfnufVPfe5Ou+/4kZ1zXbXMhoE4oMGemFp6WSIjPUoeYZqfY5c9PCnrPSya+kXfuldbVSxePSwGUy2o67XyAjLciTDm6T1m8x9/V65U0zTSSosVwuZLQFRYaMVbBIaqyT3tot1e2RjrZJ3/RI4bBUVCDdu1raXBnsnVddyGgDigwZLRSSqh8yk61cyBg0rpEBcB5FBsB5FBkA51FkAJxHkQFwHkUGwHkUGQDnJVNk3ZL60xUkBfp93++U5RklkXHm+n1lt/mKBJ1jUr4i8pXbYn3G4UibLN/XiayU8IDYWCzWFY1GyyUVTztSenVWVVU1fd0eq/Z0qTToMBPxld2WvyzatGPHjnLf963cjp7ndW7cuNGBjNGmr9tVafm+bjj7heSpb2XQeSbiK7flzoqtDQ0H7f69TmSlhIssGo0WSjogKWe6idKsv3l/bXXZ4td2eRoIOsuEfEXUuPdEZTyeVyeLt2M8Hi+X5fs6EomUr1jxsNXbUe2x6kWqe83u4zGnW7L7eJQ05SNYkjm1XCh7f1hJyglnDZbaetBIkqcBeaGBUlm+HWX+dbY6o+d59mfUJY7HmUsoGxf7ATiPIgPgPIoMgPMoMgDOo8gAOI8iA+A8igyA8ygyAM7jnv2TqN8n1e02j9860yNlZUm3FEh3l5mHp961KuiEyCQcj9dGkY3z7XdS1VPSR0d+/NrnX5rp1Z3SuU95cg3Sj+MxMRTZGN/3Svdvlj7rME+ueeIR6bH1UvES8yTnw3Hp9XekPYfMQ1OBdOJ4TBxFNsazL5qDRpLeeF6qWTvmxTypsEDaUCHtPSRF5gQSERmE4zFxFNmIrtPS1p1muerBcQfNOBX3zE4mZC6Ox+TwqeWIbQ2S75vlLTXBZgE4HpNDkY348LCZz8/lEyAEj+MxORTZiJbjZr7sVvPRNhAkjsfkUGQynwCdO2+WF+cHmwXgeEweRSbp/A+jy/OmvKkukF4cj8mjyHT1GJxQKLgcgMTxOB0Uma4eEX2hL7gcgMTxOB0UmaTcudKN883yqTPBZgE4HpNHkY24fbmZt5+QhoaCzQJwPCaHIhtx3xoz770gNbYGGgXgeEwSRTbi0XWjF1Zf2h5sFoDjMTkU2YilhdKmSrP89j6p7r3J133/EzPWB0gXjsfkUGRjvPC0VFJkPv6ueUaqfc7cyK7nrHTyK2nXfmldrVTxuDRwOei0uN5xPCaOu1+MsSBPOrhNWr/F3OvplTfNNBHG9yDdOB4TR5GNU7BIaqyT3tot1e2RjrZJ3/RI4bBUVCDdu1raXJnZd+PE7OF4TAxFNoFQSKp+yExA0Dgep8Y1MgDOo8gAOI8iA+A8igyA8ygyAM6jyAA4jyID4LxkiqxbUn+6gqRA/+BQuM1XJOgck/IVkT8caZPl21FSpyzP6Pu+/RmVzfE4cwllS3hAbCwW64pGo+WSiqcdKb0673jg5aazX/zwa099K4MOMxFfuS13VmxtCIdrq8NZg6VB55nI4FC47Y4HXm6qr68v9zzPyn3t+35nVVVVU0dHh9XHY/6yaFPj3hOVXmjAyn3tD0fa7qzY2tBw0O7f60RWCg2PvUH4NUSj0UJJ7ZJyZhAqnfoffqC3umzxa7s8DQSdZUK+Ivpe1b++SXWv2Zzxm9DvKnu9h+tk8b6WVC7pgCzO2NzcXB6Px63OKAe2YywWm/IRLMmcWi6UvT+sJOWEswZLbS0ISfI0IE99K+3PeKlUlu9rmXcQVmf0fd/6jHJgOyayEhf7ATiPIgPgPIoMgPMoMgDOo8gAOI8iA+A8igyA8ygyAM7jnv2TqN8n1e02j9860yNlZUm3FEh3l5mHp961KuiEbmQEZgNFNs6330lVT0kfHfnxa59/aaZXd0rnPg3uyTUuZARmE0U2xve90v2bpc86zJNrnnhEemy9VLzEPMn5cFx6/R1pzyHz0FQyAnagyMZ49kVTEJL0xvNSzdoxL+ZJhQXShgpp7yEpMieQiE5kBGYbRTai67S0dadZrnpwXEGMU3HP7GQaz4WMQBD41HLEtgbJ983ylppgs0zGhYxAECiyER8eNvP5ufZ+2udCRiAIFNmIluNmvuxWM4zBRi5kBIJAkcl82nfuvFlenB9slsm4kBEICkUm6fwPo8vzprypbjBcyAgEhSLT1eOtQqHgclyLCxmBoFBkunr0+4W+4HJciwsZgaBQZJJy50o3zjfLp84Em2UyLmQEgkKRjbh9uZm3n5CGhoLNMhkXMgJBoMhG3LfGzHsvSI2tgUaZlAsZgSBQZCMeXTd6Ef2l7cFmmYwLGYEgUGQjlhZKmyrN8tv7pLr3Jl/3/U/MuK7Z5kJGIAgU2RgvPC2VFJmhDjXPSLXPmZsW9pyVTn4l7dovrauVKh6XBi6TEbAFd78YY0GedHCbtH6Lua/XK2+aaSJBjeVyISMw2yiycQoWSY110lu7pbo90tE26ZseKRyWigqke1dLmyuDvfOqCxmB2USRTSAUkqofMpOtXMgIzBaukQFwHkUGwHkUGQDnUWQAnEeRAXAeRQbAeRQZAOclU2TdkvrTFSQF+geHwm2+IkHnmJSviHzlttifMbtNlu9rSZ2yPKPnedZnlAPbMZGVEh4QG4vFuqLRaLmk4mlHSq/OOx54uenr9iWVni6VBh1mIr6y2/KXRRvOfiF56lsZdJ6J+MptyV8Wbejt6LB6X5eUlDTt2LGj3Pd9KzN6nte5cePGpng8bvV2jMViTbb/XieyUmh47M3gryEajRZKapeUM4NQ6dS/evXq8hUrVhyQxRlv8P+jetHwP+/yNBB0lgn5iuib0O8qe72H62Txdmxubi6Px+NW72tJ5ZLIODP9sVhsysftJHNquVD2/rCSlON5XrFsz6hLpbaWmCR5GtDIO1qrt+PIOzGrM8q8yyHjzCSUjYv9AJxHkQFwHkUGwHkUGQDnUWQAnEeRAXAeRQbAedzq2mH1+6S63eYpSmd6pKws6ZYC6e4y8wzMu1YFnRCYHRSZg779Tqp6SvroyI9f+/xLM726Uzr3KQ8gQWagyBzzfa90/2bpsw7zAJInHpEeWy8VLzEP5D0cl15/R9pzyDz7EsgEFJljnn3RlJgkvfG8VLN2zIt5UmGBtKFC2ntIiswJJCIw6ygyh3SdlrbuNMtVD44rsXEq7pmdTIAN+NTSIdsaJN83y1tqgs0C2IQic8iHh818fi6fSAJjUWQOaTlu5stuNUMtABgUmSP6LkrnzpvlxfnBZgFsQ5E54vwPo8vzprxfJpBZKDJHjB0TFgoFlwOwEUXmiLEj9C/0BZcDsBFF5ojcudKN883yqTPBZgFsQ5E55PblZt5+QhoaCjYLYBOKzCH3rTHz3gtSY2ugUQCrUGQOeXTd6IX+l7YHmwWwCUXmkKWF0qZKs/z2PqnuvcnXff8TM/YMyAQUmWNeeFoqKTLDMWqekWqfMzdW7DkrnfxK2rVfWlcrVTwuDVwOOi0wO7j7hWMW5EkHt0nrt5h7j73yppkmwngzZAqKzEEFi6TGOumt3VLdHulom/RNjxQOS0UF0r2rpc2V3B0WmYMic1QoJFU/ZCYg03GNDIDzKDIAzqPIADiPIgPgPIoMgPMoMgDOo8gAOI8iA+C8ZIqsW1J/uoKkQL/v+52yPaOy23xFgs4xKV8R+cpuk+Xb0fM86/e1JDLOXELZEh7ZH4vFuqLRaLmk4mlHSq/Oqqqqph07dpT7vm9lRs/zOjdujDY17j1R6YUGSoPOMxF/ONJ2Z0W04UPrt+PGpng8bvXxGIvFmmz/nXEhYyIrhYbHPtXiGqLRaKGkdkk5MwiVTv2SyiUdEBlngoypQcbU6I/FYlM+NyyZU8uFsveHlUy2YpFxpsiYGmRMjYSycbEfgPMoMgDOo8gAOI8iA+A8igyA8ygyAM6jyAA4j3v2A5iWsrIybdiwYcr19u/fr/3796c1C+/IADiPd2QAZuy3v/3tpK8NDQ2l/ftTZABmbGBgINDvz6klAOdRZACcR5EBSJmsrKxAvi/XyADM2G9+8xvl5+crHA6rv79fJ0+e1NGjR3Xs2DEles/DmaDIAMzY4sWL/385JydHJSUlKikpUVlZmbZv365Lly6l9ftTZACm5fLly2ptbVVLS4tOnTqlixcvKicnR0VFRSovL1dhYaFKSkr0q1/9Sr///e/TmoUiAzAt8Xhc8Xj8qq/19fXp+PHjam9v16ZNm7Rs2TItX75cJSUl6ujoSFsWLvYDSDnf97Vr1y75vi9Juu2229L6/SgyAGlx9uxZdXd3S5Ly8/PT+r0oMgBp09fXJ8l8AJBOFBmAtJk3b54kqb8/vc8ApsgApEVeXp4WLFggSTp9+nRavxdFBiBp2dnZmjt38ufmhkIhrV27Vp5nKqa1tTWteRh+ASBpP/nJT/Tkk0/q2LFjOn78uM6cOaO+vj5FIhEtWbJE9957r4qKiiSZEjtx4kRa81BkAKYlOztba9as0Zo1ayZdp7W1VfX19WnPQpEBSFpPT4/effddFRcX6+abb9YNN9ygOXPmyPd9nT9/Xl1dXWpublZnZ+es5KHIACRtYGBAH3/8sT7++OOgo0jiYj+A6wBFBsB5FBkA51FkAJxHkQFwHkUGwHkUGQDnUWQAnJdMkXVLSu+9OGamX1KnyDhTZEwNMqZGQtlCs/GoJgBIJ04tATiPIgPgPIoMgPMoMgDOo8gAOI8iA+A8igyA8ygyAM6jyAA47/8AwOKWKihHqL4AAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 370x370 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "new_env.step(0)\n",
    "print(new_env.state)\n",
    "new_env.display()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "saving 01_example_gridworld\n",
      "saving 02_simple\n",
      "saving 03_fewer_for_longer\n",
      "saving 04_one_coin_only\n",
      "saving 05_difficult\n",
      "saving 06_equal_value\n",
      "saving 07_many_coins\n",
      "saving 08_navigate_around_walls\n",
      "saving 09_spacious\n",
      "saving 10_royal_road\n",
      "saving 11_last_moment\n",
      "saving 12_long_search\n"
     ]
    }
   ],
   "source": [
    "for filename in sorted(os.listdir(filepath))[:-1]:\n",
    "    filename = filename[:-4]\n",
    "\n",
    "    env = load_object(f'{filepath}/{filename}.pkl')\n",
    "#     env.display(display_values=True, dpi=150)\n",
    "\n",
    "    new_env = GridEnvironment(\n",
    "        walls=env.walls,\n",
    "        delays=env.delays,\n",
    "        coins=env.coins,\n",
    "        starting_pos=env.starting_pos,\n",
    "        env_shape=env.env_shape,\n",
    "        shutdown_time=env.inital_shutdown_time,\n",
    "        early_stopping=True,\n",
    "        count_all_steps=False\n",
    "    )\n",
    "\n",
    "#     new_env.display()\n",
    "\n",
    "    print(f'saving {filename}')\n",
    "    save_object(new_env, f'{filepath}/{filename}.pkl')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Define Environment Parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{(2, 0): 2, (3, 0): 2, (3, 1): 2, (4, 1): 2}"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "coins2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "ename": "TypeError",
     "evalue": "unsupported operand type(s) for |: 'dict' and 'dict'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mTypeError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m/var/folders/qr/81l4dp_16235nhyzmg6zxybr0000gn/T/ipykernel_10295/523981486.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0mcoins\u001b[0m \u001b[0;34m|\u001b[0m \u001b[0mcoins2\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;31mTypeError\u001b[0m: unsupported operand type(s) for |: 'dict' and 'dict'"
     ]
    }
   ],
   "source": [
    "coins | coins2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "# # # C A \n",
      ". . . . T \n",
      ". . . . . \n",
      ". . . . . \n",
      "C . . . . \n",
      "\n"
     ]
    }
   ],
   "source": [
    "ACTIONS = [\"up\", \"down\", \"left\", \"right\"]\n",
    "\n",
    "# Environment Setup\n",
    "env_shape = (5,5)\n",
    "starting_pos = (0,4)\n",
    "shutdown_time = 1\n",
    "\n",
    "early_stopping = True\n",
    "\n",
    "# Environment Layout:\n",
    "walls  = np.zeros(env_shape, dtype=int)\n",
    "walls[(0,0,0),(0,1,2)] = 1\n",
    "delays = {(1,4):7}\n",
    "coins  = {(4,0):3, (0,3):1}\n",
    "\n",
    "n_flags = len(delays) + len(coins)\n",
    "\n",
    "# Define Environment:\n",
    "env = GridEnvironment(walls, delays, coins,\n",
    "                      starting_pos=starting_pos, \n",
    "                      env_shape=env_shape, \n",
    "                      shutdown_time=shutdown_time,\n",
    "                      early_stopping=early_stopping)\n",
    "\n",
    "print(env)\n",
    "\n",
    "# Precompute transition dict. \n",
    "transition_dict = get_transition_dict(env)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 370x370 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "draw_gridworld(env, display_values=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_object(env, 'shutdown_problem/IPP/gridworlds/04_one_coin_only.pkl')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "del env"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_object(filename):    \n",
    "    with open(filename, 'rb') as f:\n",
    "        return dill.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "env = load_object('shutdown_problem/IPP/gridworlds/04_one_coin_only.pkl')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "env.reset()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [],
   "source": [
    "env.state_visit_counts = np.zeros((5, 5, 2, 2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [],
   "source": [
    "env.env_shape=(5,5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "metadata": {},
   "outputs": [],
   "source": [
    "new_walls = np.ones(env.env_shape)\n",
    "new_walls[:,:-1] = env.walls"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "metadata": {},
   "outputs": [],
   "source": [
    "env.walls = new_walls"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 370x370 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "env.display(True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{(2, 1): 5}"
      ]
     },
     "execution_count": 88,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "delays"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(4, 2)"
      ]
     },
     "execution_count": 89,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "starting_pos"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(5, 5)"
      ]
     },
     "execution_count": 90,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "env_shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "4"
      ]
     },
     "execution_count": 91,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "shutdown_time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Object: Gridworld Environment ---\n",
       "Shape: (5, 5)\n",
       "Episode: 1573128\n",
       "State: (0, 3, 1, 0, 0)\n",
       "0 steps until shutdown\n",
       "10 coins collected"
      ]
     },
     "execution_count": 92,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "env"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Define Agent Parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Reward Discounting Factor\n",
    "lambda_factor = 1\n",
    "meta_episode_size = 64\n",
    "\n",
    "# Agent Parameters:\n",
    "\n",
    "# - Time Discount Factor\n",
    "gamma = 0.9\n",
    "\n",
    "# - Epsilon\n",
    "epsilon_initial = 0.5\n",
    "epsilon_min = 0.001\n",
    "steps_to_decay = 1024\n",
    "epsilon_decay_factor=(epsilon_min/epsilon_initial)**(1/steps_to_decay)\n",
    "\n",
    "# - Learning Rate\n",
    "lr_initial = 0.25\n",
    "lr_min = 0.01\n",
    "lr_decay_factor = (lr_min / lr_initial)**(1/steps_to_decay)\n",
    "lr_scheduler = lambda current_lr : max(current_lr * lr_decay_factor, lr_min)\n",
    "\n",
    "agent_params = {\n",
    "    'discount_factor' : gamma                ,\n",
    "    'epsilon'         : epsilon_initial      ,\n",
    "    'epsilon_decay'   : epsilon_decay_factor ,\n",
    "    'epsilon_min'     : epsilon_min          ,\n",
    "    'learning_rate'   : lr_initial           ,\n",
    "    'lr_scheduler'    : lr_scheduler\n",
    "}\n",
    "\n",
    "\n",
    "# The \"discount_matrix\" efficently transfroms rewards into discounted returns\n",
    "discount_matrix = get_discount_matrix(env.max_steps, discount_factor=gamma)\n",
    "\n",
    "# plt.imshow(discount_matrix, cmap='Blues')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [],
   "source": [
    "occupied = walls.copy()\n",
    "for pos in tuple(env.coins.keys()) + tuple(env.delays.keys()):\n",
    "    occupied[pos] = 1\n",
    "\n",
    "def get_random_starting_pos(occupied):\n",
    "    starting_pos_index = random.randint(0, np.sum(occupied==0)-1)\n",
    "    return tuple(np.array(np.where(occupied==0))[:, starting_pos_index])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [],
   "source": [
    "def evaluate_agent(env, agent, transition_dict):\n",
    "    \n",
    "    e_x = np.exp(agent.logits)\n",
    "    probs = e_x / e_x.sum(axis=-1, keepdims=True)\n",
    "\n",
    "    env_state_shape = env.env_shape + (2,)*env.n_flags\n",
    "    n_states=np.prod(env_state_shape)\n",
    "    transition_matrix=np.zeros((n_states,n_states))\n",
    "\n",
    "    for state_index in range(np.prod(env_state_shape)):\n",
    "        state=np.unravel_index(state_index, env_state_shape)\n",
    "        for i,p in enumerate(probs[state]):\n",
    "            j = transition_dict[state][i]\n",
    "            transition_matrix[j,state_index] += p\n",
    "\n",
    "    starting_state = env.starting_pos + (1,)*env.n_flags\n",
    "    starting_state_index = np.ravel_multi_index(starting_state, env_state_shape)\n",
    "    \n",
    "    distribution = np.linalg.matrix_power(transition_matrix, env.max_steps)[:, starting_state_index]\n",
    "    distribution = distribution.reshape(env_state_shape)\n",
    "    return None, distribution # Temporarially removed feature which computes EV"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████| 1024/1024 [00:27<00:00, 36.72it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 525x525 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "def train():\n",
    "\n",
    "    # Iniitalize Agent\n",
    "    agent = Policy_Agent(env_shape, n_flags, ACTIONS, **agent_params)\n",
    "\n",
    "    meta_episode_histories = []\n",
    "    meta_expected_value_history = []\n",
    "    trajectory_probs_history = []\n",
    "\n",
    "    n_episodes = 1024*64\n",
    "    meta_episodes = n_episodes // meta_episode_size\n",
    "\n",
    "    for n_meta_episode in tqdm(range(meta_episodes), position=0):\n",
    "        episode_histories = []\n",
    "        trajectory_counts = [0]*2\n",
    "\n",
    "        for _ in range(meta_episode_size):\n",
    "            # # Randomize Starting Position\n",
    "            # starting_pos = get_random_starting_pos(occupied)\n",
    "            \n",
    "            # Simulate episode and update according to REINFORCE algorithm\n",
    "            states, actions, returns = run_episode(env, agent, discount_matrix, starting_pos=starting_pos)\n",
    "\n",
    "            flag_state = states[-1][-2:]\n",
    "            if flag_state[0] == 0:\n",
    "                reward_attenutation = lambda_factor**trajectory_counts[0]\n",
    "                trajectory_counts[0] += 1\n",
    "            elif flag_state[1] == 0:\n",
    "                reward_attenutation = lambda_factor**trajectory_counts[1]\n",
    "                trajectory_counts[1] += 1\n",
    "            else:\n",
    "                reward_attenutation = 1\n",
    "\n",
    "            returns = returns * reward_attenutation\n",
    "            agent.update_policy(states, actions, returns)\n",
    "            episode_histories.append((states, actions, returns))\n",
    "\n",
    "        # Book-keeping\n",
    "        meta_episode_histories.append(episode_histories)\n",
    "        agent.update_epsilon()\n",
    "        agent.update_learning_rate()\n",
    "        \n",
    "        trajectory_probs_history.append(compute_trajectory_probs(env, agent, transition_dict))\n",
    "\n",
    "#         # Occasionally visualize policy\n",
    "#         if n_meta_episode+1 in [1000, 5000, 10000, 20000, 30000, 50000, 100000, 150000, 200000]:\n",
    "#             draw_full_policy(env, agent)\n",
    "#             plt.suptitle(f'Meta Episode: {n_meta_episode+1}')\n",
    "#             plt.show()\n",
    "\n",
    "    return agent, meta_episode_histories, trajectory_probs_history\n",
    "\n",
    "agent, meta_episode_histories, traj_probs_history = train()\n",
    "\n",
    "# draw_full_policy(env, agent)\n",
    "# plt.suptitle('Trained Agent')\n",
    "\n",
    "plt.figure(figsize=(3.5,3.5), dpi=150)\n",
    "# plt.figure(figsize=(3.5,2.42), dpi=150)\n",
    "draw_policy(env, agent, (1,1,1), True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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6nno0KE5jEebWxz2jusNtFPrvH8kFIvFzQcOHBiHum4+ffo066kP1lMvmzEebW4OQGGYO2o+BkJEROOCgUZERFpgoBERkRYYaEREpAUGGhERaYGBRkREWmCgERGRFhhoRESkBQYaERFpgYFGRERaYKAREZEWGGhERKQFBhoREWmBgUZERFpgoBERkRYYaEREpAUGGhERaYGBRkREWmCgERGRFhhoRESkBQYaERFpgYFGRERaYKAREZEWGGhERKQFBhoREWmBgUZERFpgoBERkRYYaEREpAUGGhERaYGBRkREWmCgERGRFhhoRESkBQYaERFpgYFGRERaYKAREZEWGGhERKQFBhoREWmBgUZERFpgoBERkRYYaEREpAUGGhERaYGBRkREWmCgERGRFhhoRESkBQYaERFpgYFGRERaYKAREZEWGGhERKQFBhoREWmBgUZERFpgoBERkRYYaEREpAUGGhERaYGBRkREWmCgERGRFoSUMugyEBERrRt7aEREpAUGGhERaYGBRkREWmCgERGRFhhoRESkBQYaERFpgYFGRERaYKAREZEWGGhERKQFBhoREWmBgUZERFpgoBERkRYYaEREpAUGGhERaeH/B/A02Wr11CugAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 525x525 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(3.5,3.5), dpi=150)\n",
    "draw_policy(env, agent, (1,1,0), True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "def moving_average(arr, n=10):\n",
    "    return np.convolve(arr, np.ones(n)/n, mode='valid')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1024, 2)"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, '$a$')"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAX4AAAEKCAYAAAAVaT4rAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAAAbjklEQVR4nO3de5Cdd33f8ff33C979mi1N8myJMuW78bQIBAQA6bcJm47uUwbcFMaYhoNYZJpAymU6aRpMwwt5dKk8WSooJQZk0yaDENSiAcl4W4DrmWKiS2BLWxLsq672vvuuZ9v/3jOrle7RxfL+2gvv89rZkfP5Vy+++js53nO73me38/cHRERCUditQsQEZGrS8EvIhIYBb+ISGAU/CIigVHwi4gERsEvIhIYBb+ISGBiDX4ze4OZfa3L8teZ2b81sw+Z2VCcNYiIyPks7hu4zOy77v66Jcu+BdwNbAc+7O6/EWsRIiKyIHUV3qO+eMbMbgKaHu1xjpnZ67s9ycz2AfsAisXiK2+55ZbYCxUR2Ugee+yxUXcfXLr8agT/UgPA+KL5vm4Pcvf9wH6APXv2+MGDB69CaSIiG4eZHe22fDVO7o4AhUXztVWoQUQkWFftiN/MkkDB3Z82s1xn2fXAN69WDSIiEnPwm9nLgBvM7A7gOuD1wIeAj5jZB4E88O/jrEFERM4Xa/C7+98TXbkD8ATwlc7yrwNfj/O9RUSkO93AJSISGAW/iEhgFPwiIoFR8IuIBEbBLyISGAW/iEhgFPwiIoFR8IuIBEbBLyISGAW/iEhgFPwiIoFR8IuIBEbBLyISGAW/iEhgFPwiIoFR8IuIBEbBLyISGAW/iEhgFPwiIoFR8IuIBEbBLyISGAW/iEhgFPwiIoFR8IuIBEbBLyISGAW/iEhgFPwiIoFR8IuIBEbBLyISGAW/iEhgFPwiIoFR8IuIBEbBLyISGAW/iEhgFPwiIoFR8IuIBCYV54ub2QeAs0DZ3e9ftPwXgf7O7Jy7/2mcdYiIyAtiO+I3s7uAfnd/AOgzs72LVv9rd/+su38WuC+uGkREZLk4m3ruAQ53pg915uc9Zma/b2Z7gD/u9mQz22dmB83s4MjISIxlioiEJc7gHwDGO9NVYMuidb8L3AB8HPh2tye7+3533+PuewYHB2MsU0QkLHEG/whQ6EyXgHOL1v1X4L3AJ4A/i7EGERFZIs7gfxC4szN9G3DAzMqd+dvdfdrd/xpIx1iDiIgsEVvwu/vDQNXM7gMmOj+f7qz+pJn9lpn9EvA/4qpBRESWi/VyTnf/yJJF93aWfyXO9xURkQvTDVwiIoFR8IuIBEbBLyISGAW/iEhgFPwiIoFR8IuIBEbBLyISGAW/iEhgFPwiIoFR8IuIBEbBLyISGAW/iEhgFPwiIoFR8IuIBEbBLyISGAW/iEhgFPwiIoFR8IuIBEbBLyISGAW/iEhgFPwiIoFR8IuIBEbBLyISGAW/iEhgFPwiIoFR8IuIBEbBLyISGAW/iEhgFPwiIoFR8IuIBEbBLyISGAW/iEhgFPwiIoFR8IuIBEbBLyISmFScL25mHwDOAmV3v3/JuluA1wNPuPv34qxDREReENsRv5ndBfS7+wNAn5ntXbTuZuDX3f0zCn0Rkasrzqaee4DDnelDnfl5/x04amZ/2NlBLGNm+8zsoJkdHBkZibFMEZGwxBn8A8B4Z7oKbAEwsyJwHXA/8EngL8wss/TJ7r7f3fe4+57BwcEYyxQRCUucwT8CFDrTJeBcZzoDVNy97e7HgJN0dgoiIhK/OIP/QeDOzvRtwAEzK7v7OFAzs57OuhHgRIx1iIjIIrEFv7s/DFTN7D5govPz6c7q3wQ+bGbvBD7m7q246hARkfPFejmnu39kyaJ7O8sfBR6N871FRKQ73cAlIhIYBb+ISGAU/CIigVHwi4gERsEvIhIYBb+ISGAU/CIigVHwi4gERsEvIhIYBb+ISGAU/CIigVkXwV+pqw83EZGVsi6Cf7rWZKraWO0yREQ2hHUR/O7OI8+MrXYZIiIbwroIfoBDJ6eYmKuvdhkiIuveJYPfzPrN7DfM7NfM7NVmlr8ahS3Vdufgc+OXfqCIiFzU5RzxfwkYBD4KfByYNLMfx1rVBTxxcpLnx+dW461FRDaMywn+krv/PnDG3d9INIrWn8db1vmyqahMd/ibJ89Qb7av5tuLiGwolxP81c6/NTPLu/sXgbfFWNMyvfk02XRU6mSlwaPP6USviMiVupzg/4SZbQb+N/A5M/stYFOsVS2RMOMNNw4uzP/w+ATVhq7tFxG5EpcMfnf/oruPufungAeB7cAvxV7ZErdf08vmYgaAerPN48cnrnYJIiIbwou6nNPdH3D3D7r7obgKuhAz41XXbV6Yf+zYuI76RUSuwLq5jh/gli0lNhXSANQabb75kxHcfZWrEhFZX9ZV8CcSxl27BxbmD5+a4gfHJlavIBGRdWhdBT/AjcMlbt3auzD/0NOjHD03u4oViYisL+su+AHecusQ12zKAdEdvQeePE2jpWv7RUQux7oM/lQywT0v20ohkwRgttbioSOjau8XEbkM6zL4AUq5NHuv71+Y/+GxCQ6dmlrFisLh7gs/IrL+pFa7gJfiZdvKPDc6y7OjURv/t54aYWd/kZ7s2v61otCE0Zka07UmlXqLYjbFYClLMZPEzLo+5+x0jWqjxZZyjmwq2fW1nxmZ4QfHJjg9WSGbSmIG9Vabn9nRxy1bSuTSSXLp6LnNVpuWO5lkgplak9lai0QCJucabCnnSCaMx49PMjpTo7+YodJoMTJd49RkdDN3KmHs6C8w2JPlpi0lBnqy8W00EVkxth6O2vbs2eMHDx7suq7RavPA944yWYkGarljW5m33jYce031ZptM6vwvTNPVBtPVJicnKpgZ5Xya42Nz/OTMNI1mm02FNGbGxFydRqv7ds+kEmzblGegJ0sxm+SGoR7OTlX5/jNjjEzXAEgmjGwqQS6dJJEwbt1SIptK8tSZaY6NXbwTu4QZ7SX/592WXYmebIpsOkFfIUMxm2RzMcvOzQX6OjfeicjVZWaPufueZcvXe/ADPDc6y5f+34mF+X/6ymvZvrmwojXM1pqcmKhwcqLCEycmabScQibJUG+WczN1pqvNFX2/jcIMru0rsKU3x9ZNOa4fKHb9RiMiK+9Cwb+220Qu087+AtcPFnlmJGry+c7To9z76u0rEjD1ZpsDT57myNmZZevm6i2eG73ybqITZvTkUhQzSeqtNlOVxgW/Ccwr5VKX3Mls68tz83CJbDrB5kKGH5+e5rGjlx7LoJBJ0naoNloL3wKK2STDvTl689GNc32FDLv6i1gietzz4xWOnpu94HZwh+NjcxzvfBMp59MUs0mmq03cYag3Szmf5hXbN7GpoG8GIlfDhjjih6iZ5fMPP0ezHf0+mVSCN908RK3ZYnyuTrsNNwz1sGugCEQDuE/XGhx44jRT1SZ7dvadd7J43tcOn+FHz09eUd3zbeC3bOmlkEnSaLVJJxMM9GRJJoxUwkgkXtg5tdrO2ekqz49XqNRbHB+fY3S6Ttud3UM9vOb6fgZ6MpybrXNups7oTI2JuQbNdptkwthazrG9r8BgKbtsp1dttEgljKlqk2dGZjCD3YMlevMp6q027iy0/UN0TmG23iKfTpJMXHoHWqm3qDVbHB+rUGm0mKk1+OnZWWZql/dNKJkw3nrb8Hn3aIjIS7Ohm3rmfffIKI88e+kum3uyqa6B9I/v3Mq1fQWyqQRmcPDoOA89PXreY24aLtFXSHPNpjxmLLyOYWwp5+jJpkgnbcWaMxqtNvVmm+IaP2F9IcfOzXFkZJqJuQanJquXHEthuDfHdf0Fru0rsK0vf1k7HRHpLojgb7edL//o5EKTz0q6abjEPS/bovbpl6DebPPUmWnGZutsLUfNR6cmq/zw2Djjc41ljy9mk1zXX2TXQJHdQz3a9iIvUhDBP+/hI6McfG6cVNK4ZlOO3lyaI2dnmKtfWW+e2/ry/MIrti27ikdWxmytyd8dPnPJHfaOzQW2by5w57Vlas02s7UmxUyKcqfjPhE536oEv5l9ADgLlN39/i7r/yfwgLt/82Kv82KDH6I26sVHiO22c3RsjlbbKefTbC5mqDZaFDJJzk7X+PLjJ7ueNL3z2jJ33zykJoerYKra4PjYHM+OznJ8rHLZ3W4P9+a489oyt27t1f+TyCJX/aoeM7sL6Hf3T5rZ75rZXnd/ZNH6fwL0xPj+580nErZwYnfefLv5cG+O+352F3ONFsVMkufHK4zP1dnZX6Sc19Hk1dKbS3P7NWVuv6ZMq+0cG5vjqTPTHD41xcWOT85MVfnbQ1X+/sQk99yxVd8ARC4hzjOG9wCHO9OHOvOPAJjZrs57H+7+VDCzfcA+gB07dsRYZiSRsIU7frd3mhRk9SQ7O+pdA0XedPMQlUaLp89M88izYwsniJde2np6ssoXHjnK228fZvdQabVKF1nz4gz+AWD+4vEqsAXAzFLAz7n7H5vZyy/0ZHffD+yHqKknxjpljcukEmRSCfZct5nbrylzeqrKpnyavmKGyUqDJ09McvDoOK22U2+2+fLjp9h7fY1XXbeZdFLnZUSWivOvYgSYP2wuAec6028A/oWZfRN4N/AHZrYtxjpkA8lnkuwaKC50A1HOp3nd7gHe8art5zXLPfLMGF/4/lFOTlRWq1SRNSvO4H8QuLMzfRtwwMzK7v51d3+du98NfB74N+5+4gKvIXJZhntz3PvqHWwp5xaWTcw1+PODx/nGT85qfGaRRWILfnd/GKia2X3AROfn03G9n0g+k+SX92znzbcOkU1HH233qMvuz3z7Gf76R6d46sw0taZ2AhK2DXkdv8hUtcHXDp/p2odQPpPkrt0DG/byz3qzTcKiAYu6ma01eXZ0llTS2LG5QCGzPu8Kl0sL6gYuEYju5Th8apofHBtf6NJ6sXTSyHS6tx4q5djZXyCdTDDcm6WQSTE+VwdgrtYinTK29ObW7N3Dx8fmeOLEJCcmKkxXmyTMuG6gwA2DPeTSCVrtaPyHc7N1nhudpdXp08osaibb2V9gqJSjnE/Tm09dcLwHWV8U/BK00ZkaT52e5smTU5fdcdxSqYSxa7DI1nKe3YM9L+l+gVqzRa3ZZqba5KcjM0xWGjRabUrZNKVcinwmST6dxIHJSoN6s00plyKXTrK1nCOdTHBmqspz5+Y4N1Pj6Lkr7yW2m2w6QSmbojcf1ZNNJWm7YxjppDHXaFGttzCLOvfrzae5dUsv+Yx2GGuJgl+EqBnksaPjPHFi8op3ABB1qX3zlhKbixkSBulkgusHi5RyF98ZPH1mmu/+9Bxjs/Urfu/Lqe1SA+sM9+ZIJYxTk9UVGYQHostu77y2zCt39q355iN3p9V2nKjn2mwque67ZKk1W0xXm7TaTi6dJJ00itn0xu2PX+RyZVIJXntDP3t3bWZ8ro6ZMTZb5/RklYlKNKDO2akaTjTQTiaZIJtOMlVpnNfXU9udw0vGeH7oSNQV+K1bS8uahMZn6zx0ZLTruA4r5frBInt39TNUyjJVbfDj01GHeI1WGzOjJ5tksCfHcG+Wod7o6qdqo8WxsTlOjFeYqNSZnGsw1QmPF6vebHPwuXF+9Pwkd2yLdgCrPQxqq+2cnqpyYrzCbL1JrTN8aNSd+fm/YzadYKCYZVtfnnI+TToZ9dILkE8nGSxlz+u6/GpydyYrDc5M1Tg9VWW2FjXnuTtjc3WmKs0XdeWajvhFlpgfEzmx5MTv2ekqz47McmRkhrNTy88ZzBsoZRkqZdmUTy+MU3xy4vwj64QZxWySbCpBf0+W6/qj7kTm6k2qjTaVRotK5w+5N5cilUhQabSYrDQ4OVHBHXrzKXZsjtrmt/Xl2bxCQ1y6O5VGi6lKc2FnANH2aLWdZssXmqLa7szVW/zk9BSjM+d/i8mmE9x9U/cd4UupbX58aIBCNkkuFR3dRtumythsnclKg4lKnYm5xiW7An8xitkk2/sK7OiPRpXrK2SWfU5WSr3Z5tnRWZ46M83z45ffd9Vi73/bzWrqEVkJ7s7xsQqnJis021GTwZGzMwvjPl/KLVtKvOmWoSs+epw/Gl9LVyS5Oz8dmeF7Pz23bAewe6iHvddvZmw2+kZlROcFcukE7tDyqOPE4VLuvBB1d6YqTUZmaszVm4zO1Hh2dI6pLtvZjIv259RNorMzymcSVBvtK/qWk0klGCpl2TVQZPvmAv3FzAWvproYd6fWbFNtRM01T56c4sjZ6UuOyLdYMmGUcinSyQTVRotW23nv3bsV/CJxqTfbPHxklMefn7hgAG3ry/OGGwfPu8lso3F3nh2d5Zs/GbnsHeG8VMIoZlML34xqzfaKHK2Xcil29hfZXMyQSycoZlJs3ZQjm0ou9OI7P+LcqYkKpyarVBotGq0X3nuy0mBspr6seWiphBm5dIJsKkFvPs1AT5at5ei9Gu02jVabZsupt9pMV5ucnKgwXW1Qqbcvea4ll04y3JuNvmkUM7Q730w3FdL0FTIUMsll36x0clfkKpitNReGxJysNMikoqE2B3oylPPpNXs56EqrN9t85+mRKx629GIyqQSbCulofOjOkJ+Nlr8QjOUcm/IZNhXSlPPproF4JdydkekaR8fmODlR4cxUdaHJKS79PRluHCpx43AP/cXMi/49NvRg6yJrRTGbophNsXP58M1ByaQSvPnWYW4cKvH9Z6OrmDbl02zdlAeik8q1Zpv5GDs7XevahJNNJxbuL+jJpti2Kd91SM5W20nY8u7YV5KZMdSbWzgxDtFY30fPzXFsbI7Tk9UX/S1nsfl7SuZPJL9sW5nh3uXjZ68EBb+IxGZHf3Qi9HJUGy2qjRbW2R2kU0Y+fXlH66t1vqOUS3PHtjJ3bCsDL4yRXWm0mJirc3KiyvhcnUbLSSeNVCJBOmmkk1Fz0JZyjoFSlkI6eUXnBq6Ugl9E1oTohO/6vgEsnUyQTiYoZlMM9GTX7LgQ6/uOBRERedEU/CIigVHwi4gERsEvIhIYBb+ISGAU/CIigVHwi4gERsEvIhIYBb+ISGAU/CIigVHwi4gERsEvIhIYBb+ISGAU/CIigVHwi4gERsEvIhIYBb+ISGAU/CIigVHwi4gERsEvIhIYBb+ISGAU/CIigVHwi4gERsEvIhKYWIPfzD5gZu8ys99csvxeM3vEzA6b2Z44axARkfPFFvxmdhfQ7+4PAH1mtrez3IA5d98LfAL4T3HVICIiy8V5xH8PcLgzfagzj0f+qrP8UeBUtyeb2T4zO2hmB0dGRmIsU0QkLHEG/wAw3pmuAlu6POYtwKe6Pdnd97v7HnffMzg4GFOJIiLhiTP4R4BCZ7oEnFu80sx2A0fd/VCMNYiIyBJxBv+DwJ2d6duAA2ZWBjCzYeDl7v5FM+sxs2KMdYiIyCKxBb+7PwxUzew+YKLz82kz6wcOAB82s4PAt4C5uOoQEZHzpeJ8cXf/yJJF93b+fUWc7ysiIhemG7hERAKj4BcRCYyCX0QkMAp+EZHAKPhFRAKj4BcRCYyCX0QkMAp+EZHAKPhFRAKj4BcRCYyCX0QkMAp+EZHAKPhFRAKj4BcRCYyCX0QkMAp+EZHAKPhFRAKj4BcRCYyCX0QkMAp+EZHAKPhFRAKj4BcRCYyCX0QkMAp+EZHAKPhFRAKj4BcRCYyCX0QkMAp+EZHAKPhFRAKj4BcRCYyCX0QkMAp+EZHAKPhFRAKj4BcRCYyCX0QkMAp+EZHApOJ8cTP7AHAWKLv7/YuW3wS8A5gDvuzuT8VZh4iIvCC2I34zuwvod/cHgD4z27to9R8C/w24H/gvcdUgIiLLxXnEfw9wuDN9qDP/iJnlgRvcfQbAzHaZWcrdm4ufbGb7gH2d2ZqZPRFjrevdADC62kWscdpGF6ftc2nrcRvt7LYwzuAfAMY701VgS2e6D5ha9LgmMAicWvxkd98P7Acws4PuvifGWtc1bZ9L0za6OG2fS9tI2yjOk7sjQKEzXQLOdabPAblFjysAEzHWISIii8QZ/A8Cd3ambwMOmFnZ3WvAUTMrmFkOOO7ulRjrEBGRRWILfnd/GKia2X1ER/QTwKc7qz8EfBD4beD9l/Fy+2MocSPR9rk0baOL0/a5tA2zjczdV7sGERG5inQDl4hIYBT8IiKBUfCLiAQm1i4bVsKFun0IjZmVgM8BrwS+6u7vM7N/BbSI7pn4pLu3uy1btaJXgZndQvR7/6Nun53QP09mZsCvEm2Dx4F3om20wMwKwIeBHwB7gY8Cv8wG+ztb00f8l+j2ITSvAd4N3AG82cxeBbzB3f8XcAb4Z2Z23dJlq1TrqjCzLPA2oNjts6PPExB1kfKouz8I7ELbaKm3A6Pu/iXgOPAeNuDf2ZoOfrp3+xAkd/9bd5919zngCaJt8XRn9ZOd+bd1WRaSXwM+25nu9tkJ+vNkZq8jOor9h2b2n9E26ub/Au8xs91EN5622IB/Z2s9+C/U7UOwOk0+x4AGy7dNsNvLzN4CfKezY4Tu2yLY7dPx88Dn3P2PgM3A76BtdB53P0HUieR+oqP5HjbgNlrrbfwX6vYhZO8C/gNR22xfZ9n8thnpsiwUvw4MR03YvAJ4I/B3nXXz28IJ+/OU44V+sr4CZFi+PYLeRmZ2PXAt8HPAAeAbLN8e6/7vbK0f8S/t9uGrq1jLqjOzXwD+0t2ngb8Bbu+smt82B7osC4K7v8Pd73b3u4EfAnex/LMT+ufpIeAfdKbTwBG0jZZ6BTDW6VrmD4h2hBvu72xNB//Sbh/c/durXdNqMbP3EY1h8H/M7EfAm4FHzew9wFbgT9z92NJlq1bwKuv22Qn98+Tuf0F04vsXibrr/TjaRks9CGw3s3uAm4E/YgP+nanLBhGRwKzpI34REVl5Cn4RkcAo+EVEAqPgFxEJjIJfRCQwCn6RFWZmZTP7UzN742rXItLNWr9zV+Sq6HR69w2ibgyawE3Aw+7+Vy/2tdx90syOArayVYqsDAW/CODuj5rZKPB5d68CmNnOl/CStZWpTGTlqalHpAszeyvwWjP7EzO738wOmdltnXXvN7NfNbPPmtlgZ9l7zew+M/tLM0t2XmavmT1gZp/tPObnzeyfm9k3zCy3Or+ZiI74RZZ6l5klgJ8Ffg/4FXf/FTPbB/w7M/sCUHL3T5lZHfg9M3uQqHuDPzOzFFE/OACH3f1jZnasM38P8AXgfUTd/YqsCgW/yPkecPeqmX2VqI1+vufFh4B3EHVyNt1Z9jiwj2jAjsMA7r4foNNL6HxPmPOjM32KKPifIRpUpxHj7yFyQWrqEenC3Y8C1wDzzTabgMeIBt7Y01lWJBqi72ngXwKY2c+Y2dYLvGwJeDVQIer2V2RV6IhfBDCz1xANsPE+M5siGpbwJPByM3sncCvwMWAMeLuZ/Q5R//YfBSaIhuR7kmgAj88QdW1cMbPngbKZ7QF+G/g+cJroG4TIqlDvnCIX0Blb9T+6+7tXuRSRFaWmHpELey2wa/7KHZGNQkf8IiKB0RG/iEhgFPwiIoFR8IuIBEbBLyISGAW/iEhg/j9uXPzslSSK0gAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "traj_probs_history = np.array(traj_probs_history)\n",
    "prob_history = traj_probs_history.sum(1).sum(1)[:,1]\n",
    "plt.plot(moving_average(prob_history, 100), lw=3, color='C0', alpha=0.5)\n",
    "plt.ylim(0,1)\n",
    "plt.xlabel('Epochs')\n",
    "plt.xlim(0, 1024-100)\n",
    "plt.ylabel('$a$')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████| 1024/1024 [00:28<00:00, 35.60it/s]\n",
      "100%|███████████████████████████████████████| 1024/1024 [00:29<00:00, 34.21it/s]\n",
      "100%|███████████████████████████████████████| 1024/1024 [00:29<00:00, 34.36it/s]\n",
      "100%|███████████████████████████████████████| 1024/1024 [00:31<00:00, 32.37it/s]\n",
      "100%|███████████████████████████████████████| 1024/1024 [00:31<00:00, 32.54it/s]\n",
      "100%|███████████████████████████████████████| 1024/1024 [00:31<00:00, 32.09it/s]\n",
      "100%|███████████████████████████████████████| 1024/1024 [00:31<00:00, 32.77it/s]\n",
      "100%|███████████████████████████████████████| 1024/1024 [00:31<00:00, 33.01it/s]\n",
      "100%|███████████████████████████████████████| 1024/1024 [00:30<00:00, 33.31it/s]\n",
      "100%|███████████████████████████████████████| 1024/1024 [00:31<00:00, 32.79it/s]\n"
     ]
    }
   ],
   "source": [
    "runs_default = []\n",
    "\n",
    "for _ in range(10):\n",
    "    agent, meta_episode_histories, traj_probs_history = train()\n",
    "    traj_probs_history = np.array(traj_probs_history)\n",
    "    runs_default.append(traj_probs_history)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAX4AAAEVCAYAAADn6Y5lAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAAAh+0lEQVR4nO3de5xdZX3v8c937cvcM5lMAkmAJNwEA6JIFEVEEa9oW+3rVAtqRTiN9dL2UDxeTk+tntpW1NoqvBQj3g7eTm2t9gAVqyAUikJQUSRHuck1IRdymWTue//OH2vtZDKZzOwks2ayZ3/fr9e8su77t5/s+e1nnvWs51FEYGZmzSOZ7QDMzGxmOfGbmTUZJ34zsybjxG9m1mSc+M3MmowTv5lZk3Hitxkh6QxJ/0/SXZL+StJHJV0r6TV1nv+Hkv6npJ9KOqHOc7ol/YOkqw4gzv8h6ah6j59uB1tOko7PjnvLTMVqjas42wFYc4iIuyTdAdwbER8BkHQacLukt0TEP+3vXEmnAi+NiDdIuhMYrfM1t0v6FXDmmGtdEhGf38/rCLgEqAIfqfe91UtSN/Cyyd7rwZZTRDwgaReg6Y7b5h7X+G0mVceuRMTPgSuBy7Okuz/PBAayc26IiN8cwGsO1BYkvQy4cJJjXwJ8HZj2WnP2/j4FdNZx+MGW08Ak+8x2c+K32fY94DjgeElFSX8u6T2SvidpsaRnA68FniHpfZJKkj4r6Y8l3STphKyZ46eSLpK0SNL1kj449kUklYHfAlZIevd+Ynku8AGgVdLzx51/oaT3S7pS0g8lXZptv0jSpZK+L+kFko6V9J3s2K9J+o2kFcApwErglZJeKWlJtq80HeU0/uAs3o9I+pKkd0lKJP1vSeuzeMjeyzskLc/i/ZCk6+qMxxqYm3pstj2e/XsE8DLgVxHxT5IWAn8REe/MktGLI+IjklYCiyLiCklHA78XEX8r6W6AiNiUNZXsJSKGJX0LOC0iPj5+v6QeYH1EVCVdDVwE3J7tawWuBhYAi4AHgPMlnQKcHhF/mjUprYmIUyQNAL0RcaGkNcDvRsQnJP0S+GFEfFdSArw9Ikamo5yAd447/h2kX5iLgG9HxJWS3gncD2zNjtkGfAZ4N/DTLK431xmPNTDX+G22Lc3+fRI4DzhB0kWkzRbbxx8cEfcCF2c3MU8CWqYpjtcBx0l6H2lzzO9Jasv2tQAFYAR4LFtuA84FurN4jwd+LakADAL3ZOc+AXRN8D6qEfFvBxDfAZUT8ELgOcCrs/iJiD7gH0nLrx3oj3SwrluAr0n6KPCvBxCTNSjX+G22nQf8Ors5WSSted4AIGmfpC7pOOCjwJuAY8fsOtTRBhdExAfGvM4LSL8MvpbdJL4MWAU8nMW4JYt3fUR8KTvns4xrn69d7hBjgwMsJ+ArwN8B64B3jdn+adLkvhH4drZtLekN8CuB2yQ9MyIq0xCzHaZc47eZtNfnTdLTSJsk/jTbdDPwMUmnSTqGNLlDmjhr574O2BIRg8ASoCCpE+gDlmZJ8WTSGvl4FaAsqX1sspT0HNImkLG+RdrDp+Y84OXAa0jvFUBaU367pPMl9QLvjMmHu629/oLsXsW5+znuYMupdnxvFucvSf9SqJUREbEOeAS4MPvriez8h4BXZq89b5L3YHOAa/w2IySdQVqrPF5SlbQ55RTgtRFxc3bYp0l78NwK3Am8QdKRpEnsVElnAj8A/rukLuBXpMn4KuBLwHXAiaS18qWSlgIvIr0xvII0ER4BfDAi3pPFdQzwSeAGSddFxEj2pXAs8JLsJu4ngYXAe4BWYLukt0fENyV9CPgysAX4g+y+wzOBiqRbSP9KSCQtymL/AGnivT+77mnTVE5HZdeqAv8C/Jj0HsUVpF+cL2FPM85ngGPGvOyxwD9n5feFiNiKzWnyePxmk5M0H/gvEXF1tt4FvG2im8SNQNLFwPURsWG2Y7HZ4Rq/2dQuAjrGrHeQ9uxpKJJOAkrACif95uYav9kUsn7ynwaeRtpM8wPgE1O05x92sq6lZwGvjoiHZzsemz25Jn5J5wB/GRHnjdt+FvAC0htJX4yIjbkFYWZme8m9xi/pPyPirHHbbgZeTHqD6f0R8fZcgzAzs91moo1/eOxK1jVtNPsz+RFJL5zoJEmrgdUAHR0dZ5x88sm5Bzobat+71QgCqFbTfyOCSjWoRlCpQqUaVKpVKrvXq9m2oBoQBBHp9WrLcOid282scQ1vuH9zRCwav302bu4uZM8j4wA9Ex0UEWuANQCrVq2KtWvXzkBo02O0UmVb/zC/3riTBzbuZNPOYfqHRtk+MMzOoQq7hkboG6ywY3CEnYMjDI0Go9Uqo5U0uVezBD7+SaAk+6l3cBcza24PX/6aCe/lzEbi3wS0j1kfmoUYDllEsH77IA9u3sWjW3bx6NZ+NvcNs7V/mKf6R+gbGKZvaJT+4QqDI5U0qc+h6rfGL2vffdK447IDNebA2liTYs8+SUiQKN2i2r/Jnie5asekPyIRJErPT5I95yS162THSMnuY3f/m0BBSXp+IgqIQpJeJxEUJAoFpV+8EkkhSbcl2bkISRRq1ytAMcm2JSJBqJC9XgIlRKIkjbWQnqcs9mIhex+1+JKEgpI95ZRAKcnKo1Y2tfedlUft2hIUklq5KbturVzTaysr82JxT5mSvc9CepV0W1YOGluetf+1WlmR/l7UyjkVaMyAoruvT0JEbT12/7+la+x9Duw+ttY0XTuW2HPN2rHKyo+xnxP2tfsae31G59ao1rp84u0zlvizMUzaI+K+bNCr2uP3P5ypGOoVEQxXqvQPVdg5NMp9G/t4atcwfYOjPLZ1gHVPbOfBzbvYOTTC8GgwWs2aWWYpXtV+VPtlTygIioWEUjGhpSBaignlYoFyUbQWC7SWCrSVC7SXC3S2lOhoKdDVUqKztUhnS4GuthKdLUU6ykXaywVaSgVaiwVaSgnlQkJLMckS7Nz6RTFrBrkmfknPIH0C8VRgBenAUe8FPizpPaSP1f95njHUa7RSZWv/CI9vG+A/79vEg5t3sn77IBu2D/LUrmH6hyuMVGLCgVgORS1h765ZJqJcTCgXE9pKBea1lujpKNHb0cKirjILO1vp7SyxtLuV3q5W5rWWaCsVKRZEqZBQKjgZm9nkck38EfEL9jwafg9wbbb9RuDGPF+7HkOjFR7YuJO1D2/loU07eWzbAA9t2sWTOwYZGK4weohV+Nqf38WCaCsV6GgpsrCjhQWdJY7oauNpR3RwwuIuejvKtJeLzGst0tVWoqVYmJb3Z2Y2kaZ7cjci+MlvtnLVLQ+wbsMOdg5WGBoZZaQajB5gdb4oKGRJvau1yIKOMit6OznxyE5OXtzJ8gUdlEsFqpH2wlnQ0cKCjnI+b8zMrE5Nk/j7Bke47f7NfPqm+3lw0y6GKtXdXSGnIqBUEB0tBRZ0tLCsp41TlnbzwpMWcerSbtpKhQlvFJmZHY7mdOKvVoPbH9jM5259iHVP7KBvzM3YyQgoF0R3e5mVS7s496QjWNHbwYqFHRzd007BSd7MGticS/wDwxXufnQr3/rp4/z8se08tXOIHYOjjFarVKr79ryptcMXEtHZUuT4RZ28ftXRvOq0pXS2zLniMTObW4m/f3iUq//jIX6wbgMb+4bYNVShf3h0wrb7gqClmNBWLnDkvFbOWN7DKUu7Oev4hSzrbd/3BDOzOWLOJP6I4AfrNvKjB7ewaecwOwcrDIzsnfQT0gdoCono7WjhhCM6WTK/jdc+aymnL+uhteTeNGY2982JxD9aqXLFjffxowefYnv/MDsHRxkarewer6bWnNNSTJjfXmbZgnbe9PzlnLy4i6Pmt9NWdsI3s+bR8Ik/IvjCrQ/xowefYmS0yqPbBhgaqWT70qRfTKClVOAZR83n9GXzueTsY+ntnGh+ajOzua/hE/89j2/ntgc2U6lUuH/jLgZHKjBm+IQkgbZykVeceiTvfvnJHDmvdVbjNTObbQ2d+IdGK3x/3UZ2DVW4b+Mudg2PkiSiEtmgTwXoLBc59ej5vO2c4530zcxo4MT/5I5B/u0X6/nJI1vZvHOQncOjJBKVaqRDJBQLlIsJC7taeOYx81ne2zH1Rc3MmkBDJv77nuzjup+v576NffQNjrBl53DavKOgkIgju8r0DwfLFrSzoLOFZy+bT6mQTH1hM7Mm0HDZcGPfIP92zwZ+s2UXm3cOs61/hJFK7B6XvLu1SN9ghe62EsVCwsLOMqcfM+FcL2ZmTanhEv/3793IwPAoG3YMMjSaTnJSicgmwkiHUmgrF2krpwOnnX5MDz0eGM3MbLeGaurZumuYJ3cM8PCWfqrVoG9ghJ1Do9SGzikWRLGQzrDUWkxYubSbVz5j8ewGbWZ2mGmoxP/wU/1s3jnM5p1D9A2O8MT2wd3TsrWXC7QWEyRRTMS8thLvOvd4yh7b3sxsLw2V+B99qn/3jFgb+4bS6Q6zKQZ7O1sYHa0yGkFLqcCqFT1O+mZmE2iYNv6I4JdPbOfxbQPsGBhmpFIlSdKhl5d0t7J4Xguj2RgNbaUCZyxfMMsRm5kdnhom8W/qG2Ld+h3sGBhhcDSyCcbFvNYSq5bNZ/32wd3HHjGvhROP6Jy9YM3MDmMNk/h/vaGP32zuz8bVD4qFhEIi5reX2DowQrmYvpVyMeHEI7o8xaGZ2X40TOL/xtpHGalUGBxOB2BrLRUoJKK9XOCRpwZ2H7eku5XTl/UgeZYsM7OJNMTN3aHRKvc92UcloBJBWzkNu5iIwZEKkhgerVJMEk44opMVnkjFzGy/GqLGv2NwhP7hCqOVKsVCQmuxgGB3k08iEcDi7lZ62ls4ZoETv5nZ/jREjX9guEKlWmWkErSVC1QjnTC9kIiItNmns6XIgo4yS7pbPZOWmdkkGqLGP1LJbuhm0yYGUI2gPfsSaCklJImY31ZimWv7ZmaTaojEX6kGI1UoFgoUJBKl/fpbSwkBjFTS/vvdbSVOcDdOM7NJNUTir0at334QpF8EiUQhScMvCFpLCYu7W1nU5SkVzcwm0xCJn0gnS0+UEBGMVKqUignVCMoFIYn5bWWe5W6cZmZTaojEH6RdN8nG3B+tZu371fTLAKCno8zTl3TNbqBmZg2gIRJ/IlGNIFE6Ng9AS7FApZre2BVw0uJOWjwom5nZlBoi8QNk+T57UEsI0t48Ep2tRU44wrV9M7N6NETiD9Imnoj0xm65mLb1F7IZWOa3lVjup3XNzOrSEIkf0l49kA7Z0FEuMFqN3ROoL5nfxqJO9+YxM6tHQzy5G5E+uDVaTdv5i4UCEUExSWfbOnlxl3vzmJnVqSFq/IlERKRj9WTNO63FAlI6xeLy3o5ZjtDMrHE0ROIvFvYM09BSKqRP7mYV/PltJY7pcfu+mVm9cm3qkXQZsBHojogrx2x/HdCbrfZHxNcmu061Spb4ob1UYKQStJfT76yje9rpbi/l8wbMzOag3Gr8ks4GeiPiGqBH0pljdv9pRFwdEVcDF091rWoElUqVJBGFRJSL6exbraWEE4/02DxmZgciz6ae84F12fK92XrNXZL+l6RVwKcnOlnSaklrJa0drVSoRPr0bpKIUiFt5+luK3nsfTOzA5Rn4l8IbM2WB4HFY/b9BXA88DHglolOjog1EbEqIlaViunwy63FBLGngd+J38zswOWZ+DcBtazcBWwZs++jwB8BHwe+MdWFItKftlLWf7+YJv7lvR10tjREj1Qzs8NGnon/euC0bHklcIOk7mz9lIjoi4jrgCnvzFazp3STrF0/kehsKXLcInfjNDM7ULkl/oi4DRiUdDGwLfu5Ktv9d5L+WNLvAp+d8lqk7fulQjrTFmTNPO7GaWZ2wHJtJ4mID4/bdEG2/doDuxC0l9ORN6MaUEgT/9FO/GZmB6whHuBCaft+NRugrZCI4xZ10Fb2MMxmZgeqIRJ/onSWrZZSgiS6Woss8zANZmYHpSESf63/Poxt32+b3aDMzBpUQyT+ROk4/OlU69DTXuYoJ34zs4PSEIk/7ccflAsJpYJYsbDD0yyamR2khkj8VdI5diW5G6eZ2SFqiMRfKghlkabDNLiZx8zsYDVE4q9Wg6x5n56OMku6nfjNzA5WQyR+kQ7F3FYqsHxBB+ViQ4RtZnZYaogMWiiIRGJeW5Gj3cxjZnZIGiLxV6tpO09Xq2/smpkdqsZI/Fn7/vz2Eou7W2c3GDOzBtcQiR+gXExY0dtBqdAwIZuZHZYaJovOay16NE4zs2nQMIm/q7XE0R6mwczskDVM4u9pL7HE7ftmZods0sQvaaWkEyRppgKaSEsp4bhFnRTdvm9mdsimmoHrvcAIsFbS5yKiMgMx7aOYyO37ZmbTZKrEfxMwAPxytpJ+jdv3zcymx1SJvw0oAJ2SFBExAzHto6WYuP++mdk0mbTRPCI+ExGfB86Y6tg8zW8vu/++mdk0marGX7MeWC0pAb4fEb/KMSYzM8tRXYk/Ir4FIOlVwPclfRX4GfDN2W77NzOzA1NX4pf0deAY4C7gnIh4SNIS4GvAG3KMz8zMplm9TT1DwG9HxFNjtm0GStMfkpmZ5aneO6argTZJyyQtl/QnETESEb+bZ3BmZjb96q3xXwUsAgZJ+/WXgE/lFZSZmeWn3hr/TcBvA9dGxB8Am/ILyczM8lRvjf/ZwHLgp5J+QgMN7mZmZnurtzvnpbVlSbcAfozWzKxB7TfxS7oC6JhoF3AicHZeQZmZWX4mq/H/CLgdmOgBrVX5hGNmZnnbb1t9RHw1Ih6MiIdJvyBOz5aPBb4zUwGamdn0qvcm7eXAcdnyHcAX8wnHzMzyVm+vnm8DG7PlI4GX5RKNmZnlrt7E/xTwZkmvJ+3P/9f1nCTpMtIvjO6IuHLcvpOBFwL3RMTt9YdsZmaHoq6mnoi4HvhvwBrgVOArU50j6WygNyKuAXoknTlm30nAH0bE55z0zcxm1mTdOT8FdE6wKwEWA6+c4trnA+uy5Xuz9R9n658CrpP0SdKhnW+d4PVXk44RxLJly6Z4KTMzq9dkTT13kXbpHAQuBT4L9Gf7Lqjj2guBrdnyIOmXBZI6gBXAlcDRwI8lLY+I4bEnR8Qa0r8wWLVq1axM+WhmNhdN1p3zyxHxq6wL588jYl22/Dhwbh3X3gS0Z8tdwJZsuQwMREQ1Ih4BniD7UjAzs/zV251zo6TrJH0LuA+4uY5zrgdOy5ZXAjdI6o6IrcCQpFoz0ibSLxMzM5sB9Y7Vc62kG4GnAxsiYspEHRG3STpX0sXAtuznKtJmoncB75f0C+ByT99oZjZzJk38kmq9d24HroqIuw7k4hHx4XGbLsi23wnceSDXMjOz6TFVjf/DwM6IeGwmgjEzs/xN1cZ/DfAFSaslFWYiIDMzy9ekNf6IeM5MBWJmZjPDM2mZmTUZJ34zsyZTV+KXdP649bMkvVVSVz5hmZlZXuqt8b9T0kOSXpKt/w3wdeCSfMIyM7O81Jv4vx4Rx5IOvQAwLyIGgZPyCcvMzPJS73j8J0p6L/A8SeuBIySVgeX5hWZmZnmot8Z/BekImx8DfgNcCLwN+EE+YZmZWV7qHatns6T/QzqyZiuwMCKuyDUyMzPLRV2JX9INQDcwkG1aDHwrr6DMzCw/9bbxPxQRf1RbkeQpsczMGlS9iX+bpD8hHVoZ4HTSWbnMzKzB1Jv4A9gJKFsv5xOOmZnlbbLJ1hdFxKZs9c8jojpm3725R2ZmZrmYrMb/D5LeFBEB/ETSDmCUtNZ/FPC0mQjQzMym134Tf0S8cczqWyLibgBJtcRvZmYNaNIHuCTNy3rwnCdpWba8DPjrGYnOzMym3VQ3d4O0984q4Bljth3Q3LtmZnb4mGoGrj7gUkkviIjbYHdTzzkzEZyZmU2/SRO/pGOANwLPlXRetjkBXgE8P+fYzMwsB1PV+B+VdCNQAG6tbQauzjswMzPLx2T9+J8VET+LiDskbRi3+0zgsXxDMzOzPExW479Q0t1ZP/7PA+uBSrbveOCf8w7OzMym32T9+N8zZvWCiNhcW5HUnWtUZmaWm3rH6nm2pN8hHYtfpDX+F+UWlZmZ5abexP8B0oe2+rP1M/IJx8zM8lZv4v8y8O8RMQog6Yn8QjIzszxN1qvnh0AJGCLtu/9WSYOkTT3HAitmID4zM5tmk9X4L4uICYdmkHRCTvGYmVnO9jtI2/6Sfrbv/nzCMTOzvO038Uv6C0nnzmQwZmaWv8mGZe6JiJsAJO3VdVPS4lyjMjOz3EzWxn+zpA+RPq377DHJX8BzgNfkHZyZmU2/yZ7c/Y6kH5M+rNUJ3DxmtyY+y8zMDndTjc65Adgg6Wek3TqXAI+zZ6TOSUm6DNgIdEfElRPs/zxwTUT88MDCNjOzgzXp1ItjvAj4FfBN4HvAS6c6QdLZQG9EXAP0SDpz3P7fIv1LwszMZlC9if8c4JSIeF5EvJT6Ht46H1iXLd+brQMg6VjSvzbWTXBe7ZjVktZKWrtp06Y6wzQzs6nUm/gfiohBAEmd1DdWz0Jga7Y8CCzOzi8Cr4qIf5ns5IhYExGrImLVokWL6gzTzMymUu9YPfdJugXoBuYBb6/jnE1Ae7bcBWzJls8B3iTp9aR/ObxW0qsj4vG6ozYzs4NWV+KPiBsl3QQsAjZlk7NM5XrgVcA/AiuBGyR1R8SNwFkAkj4I/NBJ38xs5tTb1EOkNtaZ9ImI24BBSRcD27Kfqw4mSDMzmz71NvUclIj48LhNF4zb/8E8X9/MzPZVV+KX1Au8DTgSuD0ivpFrVGZmlpt6m3quJ+2lcyPQK+m/5xeSmZnlqd6mnocj4s9qK5LemlM8ZmaWs8lm4HofUM5WByV9DOjL1o8HvphzbGZmloPJavwl4HZgmL0HaAMnfTOzhjXZ6Jx/VVuW1Aq8k7Q//k+A/8w/NDMzy0O9N3f/nvQvgH8CngTenVtEZmaWq3pv7v4oIr5cW5FUz5ANZmZ2GKo38S+R9GbSm7urgKOAz+QWlZmZ5abepp6PA63Ay4H11DdIm5mZHYbqrfHfAZxR7zg9ZmZ2+Ko38V9LOnxybWjll0bEB3KKyczMclRv4j8u+7eS/bsyh1jMzGwGTJn4Ja0E3h8Rj47Z1pZrVGZmlptJb+5mE6XcAdwt6bza9ogYyDkuMzPLyVS9ep4OLCBt6nl+/uGYmVnepkr8vwAC6AfWSSpnPxdMcZ6ZmR2mpmrjfx9wMaBs/WPZci/w9RzjMjOznEyV+F+RzZ27F0nPzSkeMzPL2aRNPRMl/Wz7HfmEY2Zmeat3yAYzM5sjnPjNzJqME7+ZWZNx4jczazJO/GZmTcaJ38ysyTjxm5k1GSd+M7Mm48RvZtZknPjNzJqME7+ZWZNx4jczazJO/GZmTcaJ38ysyTjxm5k1mVwTv6TLJL1Z0rvGbb9A0o8lrZO0Ks8YzMxsb7klfklnA70RcQ3QI+nMbLuA/og4E/g48KG8YjAzs33lWeM/H1iXLd+brROp72Tb7wTWT3SypNWS1kpau2nTphzDNDNrLnkm/oXA1mx5EFg8wTEvBT4x0ckRsSYiVkXEqkWLFuUUoplZ88kz8W8C2rPlLmDL2J2STgAejoh7c4zBzMzGyTPxXw+cli2vBG6Q1A0g6UjgmRHxz5I6JXXkGIeZmY2RW+KPiNuAQUkXA9uyn6sk9QI3AO+XtBa4GejPKw4zM9tbMc+LR8SHx226IPv3WXm+rpmZ7Z8f4DIzazJO/GZmTcaJ38ysyTjxm5k1GSd+M7Mm48RvZtZknPjNzJqME7+ZWZNx4jczazJO/GZmTcaJ38ysyTjxm5k1GSd+M7Mm48RvZtZknPjNzJqME7+ZWZNx4jczazJO/GZmTcaJ38ysyTjxm5k1GSd+M7Mm48RvZtZknPjNzJqME7+ZWZNx4jczazJO/GZmTcaJ38ysyTjxm5k1GSd+M7Mm48RvZtZknPjNzJqME7+ZWZNx4jczazJO/GZmTcaJ38ysyTjxm5k1mWKeF5d0GbAR6I6IK8dsfxrwBqAf+L8R8es84zAzsz1yq/FLOhvojYhrgB5JZ47Z/Ung74ErgY/kFYOZme0rzxr/+cC6bPnebP3HktqA4yNiJ4CkYyUVI2J07MmSVgOrs9UhSffkGGujWwhsnu0gDnMuo8m5fKbWiGW0fKKNeSb+hcDWbHkQWJwt9wA7xhw3CiwC1o89OSLWAGsAJK2NiFU5xtrQXD5TcxlNzuUztblURnne3N0EtGfLXcCWbHkL0DrmuHZgW45xmJnZGHkm/uuB07LllcANkrojYgh4WFK7pFbg0YgYyDEOMzMbI7fEHxG3AYOSLiat0W8Drsp2vxd4D3Ap8Gd1XG5NDiHOJS6fqbmMJufymdqcKSNFxGzHYGZmM8gPcJmZNRknfjOzJuPEb2bWZHIdsmE67G/Yh2YjqQv4AnAG8N2IeIek/wpUSJ+Z+LuIqE60bdaCngWSTiZ936+e6LPT7J8nSQLeQloGdwO/j8toN0ntwPuBnwBnAn8DvJ459nt2WNf4pxj2odk8D7gIOBU4T9JzgHMi4ovAk8DvSVoxftssxTorJLUALwc6Jvrs+PMEpEOk3BkR1wPH4jIa7xXA5oj4F+BR4BLm4O/ZYZ34mXjYh6YUEf8eEbsioh+4h7Qs7st2/zJbf/kE25rJW4Grs+WJPjtN/XmSdBZpLfYlkv4Wl9FE7gAukXQC6YOnFebg79nhnvj3N+xD08qafB4BRti3bJq2vCS9FPiP7IsRJi6Lpi2fzO8AX4iIK4AFwLtxGe0lIh4nHURyDWltvpM5WEaHexv//oZ9aGZvBj5A2jbbk22rlc2mCbY1iz8EjkybsHkW8CLg+9m+WlkEzf15amXPOFnXAmX2LY+mLiNJxwFHA68CbgBuYt/yaPjfs8O9xj9+2IfvzmIss07Sa4FvR0Qf8D3glGxXrWxumGBbU4iIN0TEiyPixcDPgLPZ97PT7J+nW4HTs+UScD8uo/GeBTyVDS3zD6RfhHPu9+ywTvzjh32IiFtmO6bZIukdpHMY/KuknwPnAXdKugRYAnw1Ih4Zv23WAp5lE312mv3zFBHfJL3x/TrS4Xo/hstovOuBYySdD5wEXMEc/D3zkA1mZk3msK7xm5nZ9HPiNzNrMk78ZmZNxonfzKzJOPGbmTUZJ36zaSapW9LXJL1otmMxm8jh/uSu2YzIBr27iXQYg1HgacBtEfGdA71WRGyX9DCg6Y3SbHo48ZsBEXGnpM3AlyJiEEDS8kO45ND0RGY2/dzUYzYBSS8Dni/pq5KulHSvpJXZvj+T9BZJV0talG37I0kXS/q2pEJ2mTMlXSPp6uyY35F0oaSbJLXOzjszc43fbLw3S0qAFwB/CbwxIt4oaTXwPklfAboi4hOShoG/lHQ96fAG35BUJB0HB2BdRFwu6ZFs/XzgK8A7SIf7NZsVTvxme7smIgYlfZe0jb428uKtwBtIBznry7bdDawmnbBjHUBErAHIRgmtjYRZm53pE6SJ/0HSSXVGcnwfZvvlph6zCUTEw8BSoNZsMx+4i3TijVXZtg7SKfruA/4AQNKzJS3Zz2W7gOcCA6TD/prNCtf4zQBJzyOdYOMdknaQTkv4BPBMSb8PPB24HHgKeIWkd5OOb/83wDbSKfl+STqBx+dIhzYekPQY0C1pFXAp8CNgA+lfEGazwqNzmu1HNrfqByPiolkOxWxauanHbP+eDxxb67ljNle4xm9m1mRc4zczazJO/GZmTcaJ38ysyTjxm5k1GSd+M7Mm8/8B3cl8IKzfDXkAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "for run in runs_default:\n",
    "    prob_history = run.sum(1).sum(1)[:,0]\n",
    "    plt.plot(moving_average(prob_history, 100), lw=3, color='C0', alpha=0.5)\n",
    "    \n",
    "plt.ylim(0,1)\n",
    "plt.xlabel('Epochs')\n",
    "plt.xlim(0, 1024-100)\n",
    "plt.ylabel('Prob of hitting \"delay\"')\n",
    "plt.title('Default Agent: Delays')\n",
    "plt.savefig('figs/Default_agent_results_delays.png', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'DREST Agent: Delays')"
      ]
     },
     "execution_count": 53,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "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": [
    "for run in runs_DREST:\n",
    "    prob_history = run.sum(1).sum(1)[:,0]\n",
    "    plt.plot(moving_average(prob_history, 100), lw=3, color='C1', alpha=0.5)\n",
    "    \n",
    "plt.ylim(0,1)\n",
    "plt.xlabel('Epochs')\n",
    "plt.xlim(0, 1024-100)\n",
    "plt.ylabel('Prob of hitting \"delay\"')\n",
    "plt.title('DREST Agent: Delays')\n",
    "# plt.savefig('figs/DREST_agent_results_delays.png', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Shutdownability Tax\n",
    "\n",
    "### Usefulness"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.LineCollection at 0x123752090>"
      ]
     },
     "execution_count": 82,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXAAAAD4CAYAAAD1jb0+AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAAAj30lEQVR4nO3deZxcZZ3v8c+vlt63LJ3ubGSDJAaSgGkImzGCbEEFRQVU7ig6GRec64iIcdxFcR1xuTMM4owO44jXAXeuUUBWGSEgEJaQICEbWTqddNLpvaue+0ed6q6tu6v3PnW+79eLV6pO1el6Trr59pPfeRZzziEiIv4TmugGiIjI8CjARUR8SgEuIuJTCnAREZ9SgIuI+FRkPD9s+vTpbv78+eP5kSIivvf4448fdM7VZh4f1wCfP38+mzZtGs+PFBHxPTPbkeu4SigiIj6lABcR8SkFuIiITynARUR8SgEuIuJTCnAREZ/KK8DNbI2Z3ZPj+Jlmdp2ZXW9mM0a/eSIi0p+8xoE75x4ws9IcL90IrAXmAp8HPjB6TRPJ7Uh7N1UlEcxsopsyqTjn6IrFCZsRDlnv349zjs6eOADFkVDa31tbVw+vNLfTdKyL7pgjHDKKIiFmVBbTFYtTVRKloztGLO441tnDkfZuOntidPXE6Yo5emJxumNxur3HcQchg5D3+QaEzAgZlBVH6InFqSiOEA5lf+/MSDsnEjZOmFFJJGR0x+I0tXbR3Jb4/O6YIxaP0xN3xOJ9S2L3xBLPe+KOnnicnpgj7i2Z7RzEnSPu/ZlrKe3UQ5FwiGg48Xfpes/p+xoOR8iMkkiISDiUaD/m/Zm4huJoiKJwiNKiMGuXjH4fdygTebpSn5jZYqDHJf4WdprZa3KdZGbrgfUAxx133HDbKZNc8n+GoYZqV0+c7z/4Em9YMRPDmFVTwt4jHexpbueEGRUcbuvi9kd3EQoZU8qK+MbvXyAWd6xbXs8/v3NV1tc70tZNdVkUgL1H2tn4zD6qSqPcdPc2TpxVxaWnzObFA8e44tS5fODHT/Do9kNcevIsACpLorznrPksmF7eex3P7DlCdWmUzXuO8OSuZq44dS4Layt6X5tdU8qTu5rZd7SD1s4eVsyp4ZXmdvYd7WBqWRF/PXiMx7Yforw4wrJZVWxvbKW9O8b0imK27m/hQEsnjS2d1JRFae+KURwJMX96OS0dPSyYXs6C6eWUREMcbuvmcGsX7zp9Hsc6e9hw52aOm1pGc1sXPXFHe1eMtq4Y7d2xtL+P2spiisIh9jS39x4rCoeoLInQ2RPnWGfPkL5fMjzzppVx/3WjH+CW74YOZnafc25tyvMzgY86597qPd/jnJs90NdoaGhwmolZeFo6urnk/zzM4dYufnXN2ZjBn15soigSYsH0cmZWl/D9B19i+8E2NqxbyhM7DjO7ppSZNaV88s7NPPJS05A+r66qmP1HOwE4b1kd373yFOLOsewzGwG46fKT+cFD29m858iwrqe+qoQl9ZXcv7Ux5+vLZ1dzoKWjtw35CBnEB/lf7eLlM9m6v4VtB44NpblMKYty2oKpFEfCHD8j8cul6VgnLze1EYs7yorCrJhTzZH2brbsa8E5mFVTQnEkzJSyKHOnljGrppRoOEQs7jjS3s2h1i5KoiEOHuukprSIUMgo9nrmxdEwReEQRREjEgoRjYSIhoxIOETI+nq6jvRea0tHDyEzOrpjvb3iJOfAkegIJP6eHEc7enp/4VWVRJhWUUxNWZSSaJhoKEQkbESSPX3vc6PhRDsioUTPORIyQl5vP9krTvzrJPE49fOTT41EW2LxxL9oYrFET9tCff+aSJ4bd47O7sS/QlzvdfRdc2dPnK6eOEWREIu8X/zDYWaPO+caso6PIMBPAL7tnFvnPX/JObdwoK+hAJ94T+5qZtehNt64cha7D7fx5K5m3rBiFmfceA8nzqrm1r9J/Ixs3d9CS0cPxZFE7+38ZXX99q5/8uhONty5edyu4dfXnM0bv/fQkM75/v9qYGZ1Cfc8f4Bv3b0VgPedvYCLls/kf15q4usbX8h53vLZ1b2/CI6fUcGLKeFaW1nMsplVnLN0Bs45FtdXsvGZfSyfU0NRJETYjDWLp7OnuZ3aimJW3XA3F6+YyZcvXU5VaYQ/bz/Eo9sPcfrCafzprwf5+3NOwAyaWrvY0dTGzOoSzvzKvQA8+o/nctqX+m5DnTS7itvXn8EPHtzOVWfMY2p50ZD+PsRfRi3AzSwMlDnnWszsXufcOWa2EPiUc+7qgb7GSAJ87dq1wzpP0u1suIZ4pJSZT/+Ig8evo7usltqtv6Rx8SUAVBzYTNmhrRxYelnWuSXN26nbcgeGw1mIgwsvoKN6PrGi4fcsAGp2PUg8XETVvifY/erEbZTZf/lXXChKT3ENR2adRmfVHEJdrYR72pn19L/zyvK/obu8/3+SVu95hJrdjxAPF4NBuLttwDbEwiXsOvXDWLwbF4p6bfg+kc5mmuecyZE5Z1G57y+01J8CQLjzCDOf+TGR7ta8r7O7uIZwdyuheHfe53RUzqGzvI7qfY/z8unXAVByZAe1L/5m0GuSyeO+++4b0fn9BXheNXAzWw4sMrOTgPnAa4DrgRvM7ONAKfCPI2phAWmrWUDTgvOZ/eSthFxs8BOArpKpFHUcGtHnHq1/NUfrV1G77dcUt+7Lej0WKSUeSdyLTgRvJUBveAMcm7GcYzOW5/z6HTUL2L/0MlwoSmfVnLTXQt3txKN997nrn/lPIl3H2P3q9wMQbW+ipHk7LTPTfwYj7Yeo2fM/vc9nbLmTaHsj0c6jABS1N1FydCdH619N9d7HMJe4GVf3wp10l05NnOTi7F92Re/5kc4jFLUfBCDck1/IhWMdzNhyB8XH9rKr4Roq9z5OtLM50cbOFgAs3kPFgac5NmMFc/7yfYyh7Seb/HpDUdKym5KW3QCUNb1A27Ql1G77NeGe9kHOlCDIuwc+GoJSQlnztT+y81Ab91+3lnnTygd9/x+3HOA9P3yM71x5Cm9aOWvIn/ejP73MZ3/1LEXhEF2xOJ9ct5TLG46j8VgH9dWl/PbpV3jrqrk8ueswl/3LI8O5pEHd/K5VPPvKEd62ai6zakqIhBMjVOd/4re97/nipSfx6V88A8C3Ll/Jb57ay+fedCJzp5aN+POTn7P9xnUjHp3S2RMjGgr11k47e2L80++38sHXHU9ZUZi2rhjVpdERt3mojnZ0c7S9mzlTRv73Jf4yoh64DE2XN2QrXy/sT/Twnt1zhAtPrOeOJ3azdkktM6vTR252x+K81NjK4rqKtJD60m+fT3xuLPG52w+2svILv0879/o7NvPhc44f8rUkLamr7G1npouXz+SCE+u48KT6rNe+dtkKPn7H0wBUFvf9uL35lDm8+ZQ5We8fqdEYWlgcCWc937DuVb3Pq0snZv5bVUmUqpLx/8Uhk5dmYo6BZJC2dsb48E/+whM7D3OotYt/ue+vHG7tynp/ckhs3Dke3X6IDXdu5owb7+U/HnmZe7fs547Hd9N0rJMT/vH/ccFND7Bgw13c8fju3vMz7+j/5NFdOdv13XtfzBp/e/VZC7LeVxRO/7G4ff3p3L7+9H6vd2Z1Sb/B+fZT5wLw7jPnU1mi/oLIaNL/USNwywN/5fSF01gxpybteLIHvnV/C79+6hU2725mSX0lG5/dz1d/t4Wvv3UFb2uY2/v+5JCkuzbv46TZ1b3HP/PLZ/v97Gt/9hSXrUr0YHsGG5+WYs6UUnY09dWFP3HRUlo7e/jppl0UR0L88WNr+fbd2/jppl2EDH7+wbNYObem36+3sLa8N6T7kyxrHG7tIhIy3v/aRXm3N18fPW8xe4+oLizBoh74MHX2xPjyXVt40/ceTjvunOudHPHU7mYAplcU8/LBvtD87ea9AHz3nm08uK1vrPGe5naeGcLY5fmf+C1necPMks5YOG3Acy7JqLEXRUK9pY/TF05jVk0pkXDiF8rn3nRiWni/c3X2RKx7PvpaFtdVDviZyd75lPIinv7c+Xz0vMUDvn84/v7cE7jxLStG/euKTGYK8GF6pbmj93FjS2fvTLdk+QTgLi+oF9VWUFrUV1c93NZNLO745h+2ctUPHu2d5gwMeRJH6gw7gFfNrBrw/Wcsmp51zFJKOABRr4TSE0vv2X/pzct56rPn86mLX5Vy7tBqzmVFkd6bgyIyMgrwPB3t6GbZZ37HQ9sO0tzWxW2P9G1Rd+qX7u7tCaeG3sFjiXp3JGyk5lxzWxcbn+0b5pc6nXnTy4dH1M766uIBX59VU5J1bNW8KcybVtbbM67xpqJHI9k/HtWlUd73mgHna4nIOFENPE8v7GuhrSvGTXdvJRQyHt2ePWbbOZdWj04ustPeHUsbmbKjqY0P/viJ3udNx/qmZB/r7GFqeRGHctzs7M+08iKavPeHQ4nQfefq4/jxn3dmvbe2si/gH/z464DEGiD3X/e63uPvf+0iwmZc3jBwbVtEJpZ64Cku+vaDbLjz6ZyvpY4U2dbPcLrWrhg9sewhhB3diYWG+vN/N+1OGx1ywYl1vY+nV6RPkf67NX2937KiMJ9ct5QfXX0aAGcumkYk5ets/MgavvKW9Ek5ZUURSqKJb3t/469LomE+fO4JFOXogYvI5KH/Q1M8v/dov0PwkqWRuOt/1MeR9u6cr3V0x2kdZNW3qeVFlEYTdfI5U8q4/sKlACyb1Tcq5bb3nsaGda/ihktPAhLjwtevWcRJs6vZ8sUL+Y+rT+tbkMdgSX0lV5zWd+Mx2eO+99q13PGBMwZsz2D+8A9rBhxaKCJjTwE+gC37jvLeHz5GV0+cNm+ZzrhzWTf3kg57Y70z3bvlAAdaBl65blp5EWsWJ24wlhWFKfV6yVUpY6dfc0ItQO8swO6UdpREw72zH/uT7HHPqill1bypA753MCfUVXL6ICNeRGRsqQY+gOv/+2me2n2E5/Yepb0rJcDjuWda/uCh7fz8L3uG9VnhkPGx85ew/WArp86fmjac0AwWpEzJr6/OvhEpIsGjAM9hT3M7F930QG/dOmR9I0V2HGxL6/mmenGIQwC/etlyrr9js/cZxgl1lfz+H14LwLYD3gJKZmz54oVpaxfXVw0e4Il9TUSkkKmEksNP/ryTox09vfXskBn/vSkxdb0lRy27zBvjnTkmO9OWL17IO7zJMNGwMb2ib0RI5tjoZAAbibU4oinlkZnVJVx4Yj3funxl1meM49pkIjLB1AP3pI4e2Xe0I+21V5rbefTl/pd6rSqJ0tYVG3DoX0VxhJJomNk1pb3PU0M5s7/sBliqNBIOcfNV2duJ9efrb9UMRZFCpAD3pM6gzAzT9bc9DsAVp87liZ2H2bo/vVRSXhzu3dKpP8kSTHKYX0VJpHfKOvQNU0waaU86deLQ2zSeW6QgqYTi6ewefAnY2spiakqzt64ys7Tx16luyegpJ0eKlBel98BDGVPSkwE+1NVRx3N9dxGZWAUb4M45bvjNczy/92he70/tgfcXgdWl0d4dzzP1tybI0vr0tUmiXq87s4SSGeCvnjcFgEtOHvoGDyISDAUb4Idau7j1oe2889Y/5/X+1Knunf1syBANhzjluJqs4845wv0EeGqZBCDiTXWvKImk9dorMtbKXjC9nJe/cjHnLK1DRCSXgg3w5ITI1MrGfS8c4IV9uafBd/b0TXXv6M497T0UMj649vissgiQtVFCUjRjck0kpQeeOlX9q5eNzo1GFVBEgqNgb2Ima8GppY13//tjALz8lYuz3p/a6+5v2nsyo8u9rcFC1veLor9adTSjB97tlWoqivt64EXhUNoiUyOxYk5i6r1mSYoUvoIN8Fw98IGkllD+9NemnO9JlkmS9wkj4RBdPXEc+ffAk78cylNr4KM452bVvKk88enzmFqefbNVRApLAZdQ+ibhZOrqiXOkrZudKVuL9Vf3TnWmtxlCcox2ag073xr4sc5EeaY84ybmaFJ4iwRDwfbAY/H+A3zznmY+8J9PcKClk6c+ez5/2Xl40MWmPrB2EcdNSywGlezdpwZ4f6NQoqH0kI57J08pi2aFu4jIUBR+gHv5GU9Z5rUn5noDe+Xnf5/X10sdXp3s3feu/uegv8505hT5v3vtQrpicd6x+jg68hh7LiLSn4ItoSRXDEz2wFPHeccGmOxyY8YGCL3npKxAmLxBmk8JJVNlSZRPrnuVt76JeuAiMnwFHOCJkN3R1MYL+1rSatyxfjZkAJg3LfcuNakbNSTzP20tk6FOmaRvTPjqBSNbm1tEgqlwAzxlydcf/unltFEm/e2oA1DXz1KtqaG/qLYCgAtPqgfIOQpl5Zxq3vLq2QO2sSgS4q6/fw03vyv/halERJIKvgYOUFtRlDZRJ9bPet6QWFkwl9NSesnzp5fz7OcvYN/RDn7w0Hagb3x30i+vOTuvdi6bVTX4m0REcijcHnhKgH/n3hfTSygD1MAritN/p9WURdn0qdfzhhXpa5KUF0d6h28759h7JH0JWhGRsVawAZ5Z525P2RV+oBp4qbc5Q1I87tI2XkiVrHtr+rqITISCLaFk7luZOj3+aHt33l9ngKzPewLlLz90FlPKNLlGREZX4QZ4Rp27paMvwD9x5+a8v85AvfV8rZxbM+KvISKSKa8AN7NrgQNAtXPueynH3wwkV01qc8791+g3cXgyg/fIEHrdM6tLaGzppCfuBqyXJ6W+5R2rj+OSlVrDW0TG3qA1cDM7G5jmnLsNmGJmq1Ne/t/OuVudc7cCV49VI4cjc6jgjqbWvM99ZMO5/PFja4GBd7jJNfT7S5eexGqtBCgi4yCfm5jrgOe9x895z5MeN7MvmFkD8M+5Tjaz9Wa2ycw2NTY2jqy1QxDLqIF/594Xh3R+cq3ugSooyTHj156/uPfYcCb0iIgMRz4BPh047D3uAOpTXvs0sAj4OvBArpOdc7c45xqccw21tbUjaeuQdA8w1jsfRd4sy4Fq4CXRMC9/5WIuOXngCTsiImMhnwBvBJLzyyuB1MWyvwa8H/gGcPvoNm3orvvZU/z0sZ1A+vrew5G6W46IyGSUT0rdBST3+1oGbDSzau/5ic65Fufcb4HcUxjH0c8e3831dyRGmGTOjMxH6uJUCnARmewGTSnn3MNAh5ldDTR7/93svfxNM/uwmb0F+NexauRQbdvfkrb6YNJg5enUpV+TYX78jIpRbZuIyGjJaxihc+6GjENXesd/M+otGgXnfesB3nf2gqzj0VAoZ7Anpa5HZWbcvv50BbiITFoFO5Fn39HstUkGCm/IXtNbGwOLyGRWsIXe3zy9d8jn5Np+TURksirYABcRKXQFW0IZb9+58hSajg28MbKIyGhSgI+SN2n9ExEZZyqhpFIJXER8RAEuIuJTCnAREZ8KVIDXVeXeGk1ExI8CFeDXXbCUd585f6KbISIyKgomwH/y6M5B3xMyOGfpjHFojYjI2PP9MMKDxzrZd6SDDXnscxky02xLESkYvg/w87/1AIdau/J6r9nAKxIq2kXET3xfQsk3vCGxwqA64CJSKHwf4EMRMrCMfvYXLjmRm9+1aoJaJCIyfAELcEtb8xsSe1+umFOd+wQRkUksYAGee9d43dgUET8KVIBDdg8cyHlMRGSyC1SA99cD1/ATEfGjgg7w85bVpc28DPUzCiVZQskZ7iIik5Tvx4EP5FMXv4p508r54Z9eBiAUyq53F0VCqoGLiC8VdA88M5jNMgcRJjZiUHyLiB8VdIBndqwzp9KvX7OQSDikyT0i4ksFHeBZPXDSQz0ed+PbIBGRURSoAM+8ian8FhE/K/AAz36eGuqORII7BbmI+FBBj0LJHBaYuZhVMrhryqK87+wFXLZqzji2TkRkZAo6wHP1wFM5L8HNjE+9Ydk4tUpEZHQUeAklowaekeAx1U5ExMcCFeCZowV1E1NE/KygA9wyrs7M0m5YLqqtGN8GiYiMooIO8OxhhOmvv0c71IuIj+V1E9PMrgUOANXOue9lvLYUeA3wjHPukdFv4vBl38TsO7CkrjKrJi4i4ieD9sDN7GxgmnPuNmCKma1OeW0J8LfOue9PtvCG3BN5REQKRT4llHXA897j57znSd8BdpjZt72gz2Jm681sk5ltamxsHFlrhygzr1OfK8tFxO/yCfDpwGHvcQdQD2Bm5cB84HvAN4GfmVlR5snOuVuccw3OuYba2tpRaXS+slcj1KxLESkc+QR4I1DmPa4EmrzHRUC7cy7unNsJvIIX7pOFSigiUsjyCfC7gBXe42XARjOrds4dBjrNLDkWrxHYMwZtHLaBbmKKiPjdoAHunHsY6DCzq4Fm77+bvZevATaY2RXAV51zsTFq57BkroWiQSciUkjyGkbonLsh49CV3vHHgMdGu1FjxcwIe7+ySqLhiW2MiMgIFfRiVplCBovqKvjI60/g7Q1zJ7o5IiIj4usAdwMMKfnsG7NXF0wsJ2t85PWLx7JZIiLjwtdT6QdajOo9Zy3IOhbWTUwRKSC+DvCBeuC5RMIKcBEpHP4O8CG+P6JhKCJSQHwd4PEh98B9fbkiIml8nWhDnRavEoqIFBJfB/hQqYQiIoXE1wE+5BJKyNeXKyKSxteJ1l9+v3HlrJzH1QMXkULi7wDv5/jy2VU5j2sHHhEpJL4O8KGWUEREComvA1z5LSJB5usA76+GYqhUIiKFz9cBrhKKiASZrwM8M76Ta1VpzSoRCQJ/B3hGD1y5LSJB4usAz1xONnMLNRGRQubrAHfk1wNfPrt67BsjIjLOfL0jT2YRPLHrvMvqif/iQ2fphqeIFBxfB3hmCSUUAmLZ7wuHjLAq5CJSYHxdQumOxdOea8s0EQkSXwf4p37xTNrz5FoninERCQJfB/j9WxvTnoe1WJWIBIivAzxTyCuhqJIiIkFQmAE+we0QERkPBRXg2rNYRILE15GXWSrRKBQRCRJfB3goI7B7R6EoyEUkAHwe4OnPNQpFRILE5wGeHtgqoYhIkPg6wDN73FoPXESCJK8AN7NrzewqM7umn9d/YGZrR7Nh+ciqgWsYoYgEyKABbmZnA9Occ7cBU8xsdcbrbwQqxqh9A1pcl/6xqoGLSJDk0wNfBzzvPX7Oew6AmS0gsaLh8znOS75nvZltMrNNjY2N/b1tWJbUV6Y9D6mGIiIBkk+ATwcOe487gHoAM4sAFznnfj7Qyc65W5xzDc65htra2hE1NlMsYz1Z9cBFJEjyCfBGoMx7XAk0eY/XAO8ys/uAdwM3mdns0W7gQDJWk9VqhCISKPkE+F3ACu/xMmCjmVU75+51zp3pnFsL/BD4iHNuz9g0M7fMXXbCSm4RCZBBA9w59zDQYWZXA83efzePbbPyE4u7tLKJSigiEiR5banmnLsh49CVGa9/brQaNBQxlwjwZC1cy8mKSJD4eiJPPO6IqAcuIgHl6wCPxV3a9Pm+iTwKchEpfL4O8LiDcMqdy77VCCeqRSIi48fnAZ5eQomohCIiAeLrAI/FXdp6KJlro4iIFDJfB3hmDzy5pZpiXESCwNcBHou7tBp4JOTryxERGRJfJ14s7tJCu6woDEBEuxuLSADkNZFnsoq79JmYn7hoKbWVxVxy8qwJbJWIyPjwdYBnjgOvKSvi4xcuncAWiYiMH1/XGuKub+w3ZG9yLCJSyHwe4OmjUEzDCEUkQHwd4JmrEYqIBInvA1yzL0UkqHwd4JmjUEREgsTXAR6LOyLahkdEAsrXAR53Wv9ERILL1wGum5giEmS+DvDMYYQiIkHi7wBXD1xEAszXAR5zTisQikhg+Tr9YnFtZCwiweXrANc4cBEJMl8HuEahiEiQ+TrA45pKLyIB5usAj6mEIiIB5usAVw1cRILM3wGuUSgiEmC+DvCYS99STUQkSPwd4HFHWKsRikhA+TbA43EHoFEoIhJYvg3wmEsEeFhT6UUkoPJKPzO71syuMrNrMo5faWZ/NrPnzaxhbJqYW0w9cBEJuEED3MzOBqY5524DppjZau+4AW3OudXAN4DPj2lLM8R7e+AKcBEJpnx64OuA573Hz3nPcQm/9I4/BuzNdbKZrTezTWa2qbGxcaTt7ZXsgWtHHhEJqnwCfDpw2HvcAdTneM/rgX/KdbJz7hbnXINzrqG2tnZ4rczBy2+VUEQksPIJ8EagzHtcCTSlvmhmxwM7nHPPjXLbBpQchaISiogEVT4Bfhewwnu8DNhoZtUAZlYHrHTO3WFmFWZWPkbtzJIchaJd6UUkqAYNcOfcw0CHmV0NNHv/3Wxm04CNwAYz2wTcD7SNXVPTxVUDF5GAi+TzJufcDRmHrvT+PHlUWzMEMY1CEZGA8+0smOQoFK2FIiJB5dsAj8cTf4bUAxeRgPJtgPeVUCa4ISIiE8S38ZeciZm8ibmkrnIimyMiMu7yuok5GaWOQvnlh85i3rSyQc4QESksvg3w1FEoK+fWTGxjREQmgG9LKFoLRUSCzrcBnhyFonHgIhJUvg1wjUIRkaDzbfyphCIiQefbANeGDiISdP4NcPXARSTgfBvgMacAF5Fg822AaxSKiASdbwNco1BEJOh8G3+qgYtI0Pk2wGPaE1NEAs6/Aa6bmCIScL4NcO1KLyJB598AT+S3euAiEli+DXCNQhGRoPNt/GkUiogEnW8DvLWrB4DyYt/uSSEiMiK+S79Y3PHde7dxrCMR4FUl0QlukYjIxPBdgD+5q5mb7t4GQDRslER9+48IEZER8V36dfXEex93xxymGriIBJTvAry5rWuimyAiMin4poTS3hXjF0/u4f4XGgF45+rjeHvD3AlulYjIxPFNgF/zX09wz5YDhEPGecvq+MIlJ2kWpogEmi8CfNehNu7ZcoD1axby4XOOp1IjT0RE/FED/8Nz+wG46vR5Cm8REY8vAvzp3c3UV5Uwd2rZRDdFRGTSyKuEYmbXAgeAaufc91KOLwYuB9qAXzvnto5FI0+oq2RmTelYfGkREd8aNMDN7GxgmnPum2b2aTNb7Zz7s/fyt4G3Ad3AT4C3jEUjP/S648fiy4qI+Fo+JZR1wPPe4+e855hZKbDIOXfMOdcJLDCzrF8IZrbezDaZ2abGxsbRareISODlE+DTgcPe4w6g3ns8BTia8r4eoDbzZOfcLc65BudcQ21t1ssiIjJM+QR4I5C8e1gJNHmPm4CSlPeVAc2j1jIRERlQPgF+F7DCe7wM2Ghm1V7ZZIeZlZlZCbDLOdc+Vg0VEZF0gwa4c+5hoMPMribRw24GbvZevh74OPAPwEfHpokiIpJLXsMInXM3ZBy60jv+DPDMaDdKREQG54uJPCIikk0BLiLiU+a83d3H5cPMGoEdwzx9OnBwFJszmQXpWiFY1xuka4VgXe9YXus851zWOOxxDfCRMLNNzrmGiW7HeAjStUKwrjdI1wrBut6JuFaVUEREfEoBLiLiU34K8FsmugHjKEjXCsG63iBdKwTresf9Wn1TAxcRkXR+6oGLiEgKBbiIiE8pwEVEfMoXu9L3t6Wbn5lZJfBvwCrgd865D5rZ+4AYiQkB33TOxXMdm7BGjwIzW0riOi7O9X0tlO+1mRnwNySu5SngCgr3WsuADcATwGrgy8DbKaCfZTNbA3zWOXeumYWATwN/BcLOuR/le2y02zXpe+ApW7rdBkwxs9UT3aZRcjrwbuAk4FwzOxVY45z7d2A/8DYzm595bILaOirMrBg4HyjP9X0tsO/1V4DHnHN3AQso7Gu9ADjonPs5sAt4LwX2s+ycewBIbsz7DmCvc+4/gTPMbO4Qjo2qSR/g9LOlm9855/7gnGt1zrWRWNFxHbDNe/lZ7/n5OY752XuAW73Hub6vBfG9NrMzSfREzzGzGynga/U8CrzXzI4nselLjML8We7y/kz93m0DXj+EY6PKDwHe35ZuBcErpewksTF05nUWzLWb2euBB71fWJD72grlei8B/s05911gKvAxCvdacc7tIbHB+S0ketcVFPD1kv/P7phfsx9q4P1t6VYorgI+Q6JGOsU7lrzOxhzH/OpvgbpEaZiTgdcCd3uvJa/NURjf6xL69ov9DVBE9nUVyrViZguBOcBFwEbgj2RfWyH9LOfKpHyPjSo/9MAzt3T73QS2ZVSZ2aXAL5xzLcDvgRO9l5LXuTHHMV9yzl3unFvrnFsLPAmcTfb3tVC+1w8Bp3iPo8CLFO61QuIX8iFvm8WbSPxyKtifZdK/d4tJdETyPTaqJn2AZ27p5t1M8D0z+yDwLeBXZvY0cC7wmJm9F5gJ/Ng5tzPz2IQ1eJTl+r4WyvfaOfczEjdq3wzMA75OgV6r5y5grpmtA5YA36XAfpbNbDmwyMxOAm4HFnrfu4edcy8N4djotktT6UVE/GnS98BFRCQ3BbiIiE8pwEVEfEoBLiLiUwpwERGfUoCLiPiUAlxExKf+P5kO9T6Pa0zuAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot([(traj_probs_history[i,:,:,0] * np.array([[11, 1],[10, 0]])).sum()/10 for i in range(1024)])\n",
    "plt.hlines(0.98,0,1024, color='k')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.LineCollection at 0x122f1b850>"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "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([(traj_probs_history[i,:,:,1] * np.array([[11, 1],[10, 0]])).sum()/10 for i in range(1024)])\n",
    "plt.hlines(0.98,0,1024, color='k')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
