{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "ygcDisv0GMyx"
   },
   "source": [
    "### Setup:"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "Vi6hBDLgF4zj"
   },
   "source": [
    "Load in codebase and gridworlds from GitHub, and install necessary packages:"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "bG8JMBpaGC9H"
   },
   "source": [
    "Perform lots of imports and tell python where to find the modules we wrote"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "id": "Cmc8mfA_Chsi"
   },
   "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",
    "import dill\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",
    "\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, get_transition_matrix, compute_entropy, get_discount_matrix\n",
    "from rl_utils import evaluate_agent, get_conditional_expected_values, get_terminal_distribution\n",
    "\n",
    "# This doesn't work in colab for some reason:\n",
    "plt.rcParams[\"font.family\"] = \"Times New Roman\"\n",
    "\n",
    "def load_object(filename):\n",
    "    with open(filename, 'rb') as f:\n",
    "        return dill.load(f)\n",
    "\n",
    "filepath='./shutdown_problem/IPP/gridworlds'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_moving_average(arr, n):\n",
    "    return np.convolve(arr, np.ones(n)/n, mode='valid')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "x7GUcXpMGPtk"
   },
   "source": [
    "### Load and Display Environment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 494
    },
    "id": "TApSBQEFBXQR",
    "outputId": "fad3620d-dd29-4914-d533-4d6a93fdae78"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 473.6x473.6 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "filename = '02_simple.pkl'\n",
    "env = load_object(f'{filepath}/{filename}')\n",
    "env.display(display_values=True, dpi=160)\n",
    "# plt.savefig('figs/simple_CX.png', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "id": "bJjEiLVkDRE3"
   },
   "outputs": [],
   "source": [
    "ACTIONS = [\"up\", \"down\", \"left\", \"right\"]\n",
    "\n",
    "# Precompute transition dict.\n",
    "# transition_dict = get_transition_dict(env)\n",
    "\n",
    "# Precompute occupied: This array is used if we decide to randomize the starting position\n",
    "occupied = env.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": "markdown",
   "metadata": {
    "id": "S0j11zB_Gg2j"
   },
   "source": [
    "### Define Agent Parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 149,
   "metadata": {
    "id": "ZY4HhiJ6Gdki"
   },
   "outputs": [],
   "source": [
    "# Reward Discounting Factor\n",
    "DREST = True\n",
    "lambda_factor = 0.9\n",
    "meta_episode_size = 64\n",
    "\n",
    "# Agent Parameters:\n",
    "\n",
    "# - Time Discount Factor\n",
    "gamma = 1\n",
    "\n",
    "# - Epsilon\n",
    "epsilon_initial = 0.5\n",
    "epsilon_min = 0.0001\n",
    "steps_to_decay = 256\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.003\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+140, discount_factor=gamma)\n",
    "# plt.imshow(discount_matrix, cmap='Blues')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### User defined: Environment Specific Parameters:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 129,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[10, 1]\n"
     ]
    }
   ],
   "source": [
    "print(list(env.coins.values()))"
   ]
  },
  {
   "cell_type": "raw",
   "metadata": {},
   "source": [
    "max_coins_by_trajectory     = np.array([10,1])\n",
    "optimal_steps_by_trajectory = np.array([4,2])\n",
    "\n",
    "max_return_by_trajectory = max_coins_by_trajectory * (gamma**optimal_steps_by_trajectory)\n",
    "print(max_return_by_trajectory)"
   ]
  },
  {
   "cell_type": "raw",
   "metadata": {},
   "source": [
    "env.coins[(0,4)] = 10\n",
    "env.display(display_values=True, dpi=150)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 148,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000
    },
    "id": "ArPmlX6oHISJ",
    "outputId": "2ab2ab68-9e79-445f-9e7f-dd6849097c92"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [ 0. 64.]: 100%|██████████| 512/512 [00:15<00:00, 32.21it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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/wesMtYHB/e/3xkpZQX1IG17fk8IMQmgNmH82U02uxTA7QDOBfAxIcTuJtuN+3us334C1ojQFIDvdvNeRAw06sfrANwAKyT+WQhxSAhxHMC3YJXYLpZS/nD9E6SUEsCrYfXc7oY1cOSj1TltLwHwa1iDAR4CcKWU8iuwBoosAPgzKeVnW71O9Xd5AAcA/DWAJ6uvdxjAWwG8uPpcO/xj9eeVrTYSQtwL4GnUh62/TQhxUgjxwg2bPgbrUj2PwZqO8KxOGzJm77Hec2BNrr+z+iWAqGPCvn2byH2EEPcB8EkpLxnw634J1rJjQ+vVjOg93gFrYvyZ1akgRB1jD41otN4E4AIhRMc9nXaEEHFYZbofttl03N/DD+AVAP6WYUa9YKARjZCU8h4A/xXWucde1rtsUL1g6D8CeJOUcijztkbxHlV/CGvZq24XhiYCwJIjkS2EEB8CsCilfEsfr3EmgP8HwP8vpRzKgsejeI/q+zwTwIcA3CilTA3rfUhtDDQim1SnPIQB/E11MrorCSFuAvBiWD3A5XbbEzXDQCOyUXW6gyGlPGx3W+wihLhJSvlvdreDnI+BRkRESuCgECIiUgIDjYiIlMBAIyIiJTDQiIhICX1d4POOO+4IgZeUr6ldw4mfh2Ua1uLBZOHn0YifRx2PHY3Cb3/723PtNzsVe2hERKQEBhoRESmBgUZEREpgoBERkRIYaEREpAQGGhERKYGBRkRESmCgERGREhhoRESkBAYaEREpgYFGRERKYKAREZESGGhERKQEBhoRESmBgUZEREpgoBERkRIYaEREpAQGGhERKYGBRkRESmCgERGREhhoRESkBAYaEREpgYFGRERKYKAREZESGGhERKQEBhoRESmBgUZEREpgoBERkRIYaEREpAQGGhERKYGBRkRESmCgERGREhhoRESkBAYaEREpgYFGRERKYKAREZESGGhERKQEBhoRESmBgUZEREpgoBERkRIYaEREpAQGGhERKYGBRkRESmCgERGREhhoRESkBAYaEREpgYFGRERKYKAREZESGGhERKQEBhoRESmBgUZEREpgoBERkRIYaEREpAQGGhERKYGBRkRESmCgERGREhhoRESkBAYaEREpgYFGRERKYKAREZESGGhERKQEBhoRESmBgUZEREpgoBERkRI8fT4/D2B6EA1RQP7WGx9HtrR9j90NGQfbJlcWfvzETfzbqDp+/PjC7OwsP4+6BfDYUZOv/uTnYcm332Rz/QZaEMBcn6+hivC2bVuDk/J9h21tRQpA0tYWAABmxbv2XHrppYftboeeSsFI2v+BmKY5PTs7y32lbho8dtSEqz/5eVjCAHK9PJElR9WcAJC1uxFjwjThPXQIqFTsbgkRjQADTSUFWN9rFu1uyHjQMxmISgV6Om13U4hoBBhoKqkFWQqAtLMh40FfXGz4SURqY6CppNYRKQNYsbMhY8AwoGUyAAB9eRkol+1tDxENHQNNFatoHBvk8k6JnslAmKZ1R0roqZS9DSKioWOgqWLj8ToNV5cdN5YZWXYkUh8DTRUbj9cVAEt2NGQMVCrQlhr/5/WVFYhSyaYGEdEoMNBUkIM1wnEjl1bZ9HS6Xm5c/zjLjkRKY6CpoNlxOg3g1OO68pqVF1l2JFIbA00FzY7TBtxXdiyXrVGNm9CyWYhiccQNIqJRYaA5XRZAq1NDLquy6akUIJuPhmHZkUhdDDSna1dFS8PqqblEu7Iiy45E6mKgOZlE+x6YCfeUHUsl6CutZ5RruRxEYbMRNETkdAw0J8vCWhWkHZd0SjotJ7KXRqQmBpqTdXpczsAVZUcPA43I1RhoTiVRX7txkNs6lCgWobUpN9Zoq6sQ+Z6vIUhEY4qB5lTL6KzcWKP44L5uRy+yl0aknn6vWE12aXL8PrIA/Oyw9TNXBIJ+YDoCXLATuPA0QPePtJUj021A6akUKrt2Dak1RGQHBpoTmWgItIoBfPx7wAfuBh441vxpk+8GbrkO+ONbgUvOHXorR0YUCtBy3V2xXSsUILJZyHB4SK0iolFjoDnREtYGefz6OPDyD7YOsprFJeDjd1m3zH1ALDLUVo5Mr+VDTyqFMgONSBkMNCeq9s7uewK48d1AekPnZDoKnL8D2BoFMnng0VngyfnGbVospuE4vQaankqhvHv3gFtDRHZhoDmNCSANPJUCXviexjA7cyvw3lcAN14E6BuG+zxyAvjwt4EPfxfIKzSvWOTz0FZXe3tusQgtm4XJXhqREjjK0WmWAJjA6+8E5teNUr/2HODgW4HfuOTUMAOAZ2wD/v4VwKPvA/ZfOarGDl+/azNytCOROthDc5IcgJPA1x8Fvviz+sM7ksC/vBkIR2HNORPNX2KHH/iPtwOYGG5Th05KaCsr0NJpmKFQy+0gmn8g2tIStEwGZizWcjsiGn8MtHEmYYVYCtbE6CKAaeCddzdu9pY/BqaeU71TBuBt8ZoFQHsAwDEAMQBJAHE44y/BNKEtL0NPpayLeFYqKJ1+Oozp6ebPKZcBb/MPRE+l4H/kEUhdh5FIwEgmrXDTWLwgchonHMbcRQJYgRVgKZwyefrYPPCd++r3kzHgVS/u8X0y1RtghVuiemsViKNmmtAyGejptBVixnDW8BKGAc/CAjwLC5CaBrMabkYsBuj6UN6TiAaLgTYOJKyVP1KwAqbFCiD//D3AXHcV6uuvBvy+AbRhqXo7DCCKes9tEK/dLcOAvrQEPZWClk5DmKO97LYwTeiLi9AXF61wi8et3ls8Dni4yxCNK+6ddqld1iUNK8QqnT3tx4803n/BVQNtlWW5egOAMKxwSwAY5iojlQr0TMYKsaWlkYdYM8I0rRJnKmWFWzRq9dzi8ZalTCIaPQbaKBloDLEeqmcHn2i8f94ZfbeqtWz1dhRACFawJQEEBvDa5fJaKVFbXh6bEGtGmKYVupkMIASMSMQKt0QC8NnRlSWi9Rhow1aBFWIprA2579VqCXjiRONjZ53W++t1LVe9PQUgiPo5t2AXr1EqWSGWSlkX43TqDG8poS8vQ19eBo4cgREOWwNKkklIhhuRLRhow1CB1QtLwwqxAR2zF7ONx3+fF5hMDOa1u5av3p6G1VurlSU3GUEvSqW1sl2nl3hxFCmhr6xYAX3kCMxquBnJJKRf0dWgicYQA22AAp9+IIIrYIXYECxvWBAjGMCp594qaDkPbSgX+iwAOF69+QFMASK6KnRjEZ7ZWWjZ7BDe1CJME6i0OAFZqbSeXzaEUZNaNgstm4X36FGYwSAqW7cO/D2I6FQMtAEq/P5FK6H8vfV5YwO+huTSxkCbwKn/gnKTx9brcPBJ13TUS5AxQOoT0hBWD6XWOxPF4sDfVmpa65GHUrb+/ZCG5Eufb62XZobDwLEOVo8mor4w0AZtAsCO6q2A+nyy7q5u0hHbF7bwwhran4Q11H9je4SAGQ7DDIdR3r0bIperlx4LCi0oWWUGAjASCZi1ECOikWKgDVMAwLbqrYR6z63H00iRDSMLc72tydsfL+ojHSNoXd7cQIZCqIRCqOzaBZHPr634oeUH3JUdITMQqJ8va7UEFxENHQNtVHwAZqq3Eqxh+ynU53t1ILZh/cX8qALNByvAkrAGfQygZyiDQVSCQVR27oQoFOo9ty4v1GkHMxish9iE0xfFJFIHA80OPgDT1VsZVrh1MCIyuaGKVSoDqQyQjA+hjW1GLg6SDARQ2b4dle3bIYrFtWH94zQicm3kYiIBGRjEJDwiGjQGmt28ALZUbxXUwy2DU8It5AdOnwEOzdYfe+wIcGV8QG3pdW7ZAEm/H5WZGVRmZqw5a9WypB1z1szaxGnOLSNyBAbaOPEAmKreaquK1NZ3rE7IvvSMxkB78HHgyov7eM9Br/4xSD4fjJkZGDMz9VVFUilrMvMwwo2rfxA5GgNtXOmon7dat+7jFXuBu75f3+yb3wZuv3bd80y0vmxrEVbvawrDX59xkLxeGNPT1qViNqz72PJSL4bRcmi+trQEIx7n+oxECmCgOYGGtVLgy24A/uzOegflGz8Cio8A/k6Pw14Al2AgAzts4/HAmJqCMTUF3+OPw/fEE+2f04QRi6F0zjkDbBwR2YVXMXSY0y8Arj6rfj+VAz5xTxcvkISzw2yDSjLZ1/ONyckBtYSI7MZAcxo/8MZbGh96278CC50OCJy0rqc25gvbd8yMxyF7XO1Dapp1royIlMBAc6AX3QzceGH9/tNp4KXvB7LtFt/wASfywPWvBpaHt7ziaPURSmYsxgt2EimEgeZESeCDrwTi64bWf+dh4LK/AL76C8DYpPd1aB6440vA2TcBd/9oVA0djV7Lhiw3EqmFX0+dyAecfjrw5TcAL3wPsFLtmT120ro/HQUu2AlsjVoLGj9+Enh0tvVLOpkZi0F6PBCtVt3fQGqaNaqRiJTBQHOqSeB55wD3/Dnw8g8CD6+78OfcMvCth1o/3faFjQdJCBiJBDzz8x0/xUwkhrbSPhHZgyVHp6qeNrp4N3D/24D33wacu731UybjwO0vBg7eBcQiQ2/hSHVbPjT6HB1JROOHPTSn8sG6ZMsy4PMAr32+dXtyDvjZYeBYCsgVgaDPKkFeuA+48CJ1OyVmNArp9UKUy223ZbmRSE0MNCdL4pTV+vdOW7cGEwAuhNqEgJFMwnPyZNtNjUSi9eoiRORI3KudrNPR6i6prnVaduToRiI1MdCcrHbF6HZccvw2w+G2q+JLXbfmnxGRchhoTteu9xXC+K2iPyxCtO19Gckky41EiuKe7XRxtF6b0SXlxpp2azuy3EikLgaa03nQuuzoskCT4TDMJleUll4vzGh0xC0iolFhoKmgWWiF4ZzrnQ1Qs7UdjWRSsRnlRLQeA00FcWz+L+nS6lqzsiLLjURqY6CpQMfmZUeXXhlFhkKnlB2lzwczHLapRUQ0Cgw0VWzsfERgrSbiUht7Yyw3EqmPgaaKGKyeWo3Lq2unBBrLjUTKY6CpQkNjidGl5cYaOTEBM2hdME76/Sw3ErkAA00ltdGOMViriLhcrVfWbm4aEamBgaaSGKx5aTx+A6hfIoblRiJ3YKCpRMAKM5eXG2tkIIDK1BRkKGR3U4hoBPq9fEwewMaLlbhVHtDys+Jde+xshOZP66Y3YdjZBgA48uvTj8qIf4/d7fClY3rpqN/2zyOhXbFw2WUa95WqmZmZhdnZWX4eAKSU+YMHDwI8ltbke31iv4EWBDDX52uoIpzSXg8Ah+1shBZKw9Ts76LJiH/Pkz+JHLa7Hb7cNEpH7L88995nrezZu/vSw3a3Q1taGperDUxv27bN3mOHYUDL5cZhObRwNdB4LLWEAeR6eSJLjorxnjgBkc3a3YzxYJqILjwGYVTsbslYEIUCvE8/bXczxoa+tAR9jhmiEgaaQkSxCG1lBZ5Uyu6mjAXfagaaUYY/z88DAPR0GmJ1FWJ11e6mjAV9cRF6Og2Ypt1NoQFhoClErwaZvrgISGlza+wXyM0DAPy5BZtbMh70dLrhp6tVKtAyGQjThJ7J2N0aGhAGmkL0xUUAgCiVoLm97Gia8OesgPfn064vO67vmenswUOvhhlQ32/I+RhoihCFArRc/Tyq23dSfz4FIWuDG6Xre2nre2WiWITI9XTOXRnr9w8tkwEM2wfC0gAw0BSxMcD0VMrVZcdaubF+3+WBtqFX5uqyY6UCfWlp7a4wTXd/HgphoCliY6CJchnayopNrbGXMA348o0HKN/qErRKyaYW2UvkchDFYsNjbj6Ab/Zlj2VYNTDQFCDyeWibjFxza9nRn1uEkBtHrkn48+78PDYLL1EquXZ6x2b7hZ7JABV3n2dVAQNNAc2Cy61lx2bny/xZd5Ydm/XGXNkrKZWgb1a5kNLVvVZVMNAU0OzAJCoVaOvOFbiBMCrw5zc/MPkKS9AqxU1/pyqRzUKUNi+16pmM677w6Ol00/9nt1Y0VMJAcziRy0ErFJr+3m07qVVWbH6Qdttox1a9MFEuu256R6v9QV9eBsrlEbaGBo2B5nDtAsttKyEE2pQV2/1eKVK2nTTspjKbaFZurJHSnWVYhTDQHK7dMlfCMKx5Ni4gjDJ8q5mW23iLK9DKzXu0KtGyWYg2PQ6tRQlONZ2EldsqGqphoDmYls2eMhx7M25Z29Gaa9b+4OyWOWmd9L5EpeKa6R2dhJW+stL0nCONPwaag3X6bVJLp12xEkKnoxgD2fn2GzmdlNa/ewfcUGYTxWLH5wvd8HmoioHmVF3U+92wAKtWKcJX6GxEp6eUg17q+RqCjqCtrEB0OK9Kz2SUP8/aTSmRZUfnYqA5lNZlaUT1b53djl7059Q+aHX1720Y0JaXh9eYMdBNSHVayqfxw0BzqG6/RWqKr4TQ7ejFiazCF3bsoUeu8mhHsboKLd9dj1z1L4Cq8tjdAOpBD8OLa2VHY2pqSI2yx9s+8pv49aHvt9zGr/sQ8ocxE5nGM7acheedfjUumDkPeikHwxcaUUtHR1te7vqcqb60hLJpApp633F7KSHqi4uobNs2hNbQMDHQHEhbXu74/Mh6+uKicoHWiaJRQjGfQiqfwkMnH8YXf/UVnD11Jl7zG3+LLee8wO7mDVxPvS3DgLa0BDORGHyDbNZLoGm5HEShABkIDKFFNCzqfR1zgV5PWutLS1wJoerRhcfxp3feil89/l27mzJYptlwaZRuqFhmE/l8y5V0WuHgEOdhD81pTLP3A091AVZjenqwbbLThlX1/+uB/4Jzp5/R8FixUkJ6NY1fzz2Cr/363zFbPX9WNsp4zz/dine96T4komqUl7SlpZ6naOjLyygbBqDrA26VffoJJX1xEZUdOwbYGho29tAcRltaguhjTplq3zo1o7HHmZxIYCayteF2WmIXLtl+EX73kpfioy/9AC7eduHa9oVSDnfd/c5RN3to+upl9dG7G1f9fB7a6ipEl4NJyF7soTmIKBahnzgBs0VdX0gJKUTz36+uQltchJlMAi22cwJPMQvNaJy6YOg+GJ71n48EUP//9HoCeN21f4I/+Nyr1x77ya/+Fa+65V3QnDwgQkroCwvQVlYg/f6eX0abn4cZCvX1GmPBNKHPzgJS9rW/eJ5+GuXTTgN8vmG0kgaMgTbmxOoq9FQKeioFLZ9HZetWFPfsaf6Echnwepu/XqGAwP33Q3o8MOJxGMkkzFjMGaPbpISnuIJAbhH+3CL0SgGmp/HAu7z1GVjcffnafWGUIfXGzyO4+3Js+fe/xnz6KABgJZ+C8dBXEZ05H8XwFMr+iDPC3jShLyzAc+IEPLOzEOUy8s99Lsx4vPlzKhXA03y398zOwvfII5CBAIxoFGY87pyBEYYBPZOx9pVMBsI0sXrFFa3/LdvsL75HHsHEwYMwIxEYySSMRML5Ya8wBtoYErmcFWLp9KZXoh7Ie1Qq8CwswLOwAKlpMBMJa4eNxcbrHIqU8BaW4c8tIpBbOKVH1qt4dGYt0ABgOTuHHcsJBJePw9S9KAYnUQhPoRyIjVe4GQb0+Xl4Z2fhOXlyaIN8RKEAT6EAzM1B+v0wYzEY0ShkMDiU9+tZpVIPsaUliCGteKKtrEBbWYH3yBGYoZC1rySTzgl7l2CgjQmRzdZDrMdRWT2/t2lCX1yEvrhohVu152bEYi2/zQ+NlPAWlhDILsCfXzzlPNkglMuNK0Foot5D1YwyJlZmMbEyC1PzoBiaRDE0hVLApp5spQLP/LzVEzt5cuTrcopiEfrcHPS5OUifrx5uIZvm8JXL0NNpa39ZXh751QK0XA5aLgfvsWMwg8F6z23cwt6FGGh2kRLauhAbl6V2RHUUpZ5KWeEWjVo7bDzesjTTN9OEbzWDQG4BvnwKmjm8VU2klJhLHW54bDKY3HRbzaxgYuUkJlZOQmoeFIMJFENTKE4khhtu5TI8J09aITY/PzZrLYpSCfr8PPT5eUiPB2YsZt1CoeH2ZEultX1FX1kZm0veaPk8tHwe3qeeghkI1HtudoW9yzHQRklKaMvLa98u212rym611UX0TAYQAkY0CiORgJFIDOQkuTAN+PJp+POL8OfTEEMMsfUeevIe5NctZDwT2Yqp0GTb5wmzgkB2HoHsPKTQUQrGUQhNoRRMQmr9l2lFqQR9dhbe2Vno8/Njc9BuRlQqaz17eDzWObdYDGY4PJBwE8Xi2r7ihEvcaIUCtOPH4T1+HGYgsFbGH3rY0xoG2rCZphVitZ6YU9dTlBL60pI1rPvIERjhsLWzJpOQXYSbFWKpak8sAyFHWz5bys7jk1/+04bHfuu8m7t+HSEN+KuDU6TQUJqIWz23YBJS73y3EsUiPLOz8Jw4AX3Bwddpq1TWevbQ9cZw66InKwqF+iCoXG6IDR4urVCAduIEPCdOQPp8a2VJM+KQAUcOxUAbBtOEVj1RrWcyfc0bG0tSQl9ZsUo/R47ArIabkUxuOgJMGBWrF5ZbhG81AyGHVz5bWjnZMNhDGGUUzQrSyyfw6ye/j2/d9yksr1uZ/4LTno0XXfCbfb2nkCb8+RT8+RQAgdJEHIXQJIqhyVNGWALWyFVP9WCn5KLAhmH1rNJpoFa2jsWsg/km4Sby+fr5YwXnfYlSyfrSMjsL6fVaVY5kEmY0ynAbMAbaAG35y7+MLt12G7R0emijrWCarVfNr1Ra7yRD6CFq2Sy0bBbeo0etEWCTk9CzSeHPFjGxchK+1Qw6uZJ0TzaU5d7/uT/o6GkT/jCef8Wr8IrnvBqedQE4gAbBt5qGbzUNLDyBUiCKQmQr9GxZeA8dh/fpp60rHwyJqFSAVpcVMs3Wfx+DLnNWv9xpmYwVbpGI9fcxO6tLv9/qiQ1zEFS7/aFcbv37Ae/HolyGZ24Onrm5takzka98JYhIRL0ktwEDbYBSr3/9svT7oft81jmyYQz00LTWIw+lbP37IY1alJpmjX6rDiAxyiFZDIYgNR2Gxwd/bnE4Az16+Ia7a+Y8/Pb+N+GKC34L3vxwekjWAJKkdY5tIg4jnJPlbRqk318frTiELz3S42l9frNSaT0tY0g9Bun1NoyONM8800CpBFndV4Y20MPjaR/grfaJIQ38MScm1qoaqT/5kzw+9rGhvI/bMNAGyJi0BhaY4TDKu3dbQ/FrJ7VHPBR/FNbmryUS1ijIjQdKTUMpmEApmMDK1JnwFpYRyC3An1sYylD8Th2bfQjv++yrMZ3cg9fc9FZcHYwP5HWtIf5TKIYmUZqIn3og9XpR2b4dle3bAcNoHIrv1HOrLawN8Y/FNh/S7vPB2LoVxtat1lD82nyy5eXhVThsZIZCa+VGOTFhd3OUxEAbIhkOoxIOo7JrlzLnCaSu11cYicc7/wYrBMoTMZQnYliZ3AtvcQX+6jwzvTK4nuyf/8G/4ry9z62/bfUc2ko+hSPHf4kfPfBF/OD+L0BKE3Opw/ibz96O/3bdm3H1nmf39H6m7kMxNIlCaArlQBfnRHQdlZkZVGZmrBU/5ufhqY5wdPIVEdZWGInFujtoe70wtmyBsWVLfbJ0Or224odTtTu/TIPFQBsRGQyiEgyisnOn40ZySY+n8UR2v2UYIVAORFEORJHFXniKK9ZKINkF6JXB92R93glMxnZgMrYDl517I/Y96za885O/g1J5FYZZwTu+81589CXvw3R4S0evZ3j8KIamUAhNojKIZbI0ba2nUrzoIuiLi/AcP24tZ9XqfNiYkBMT9RAbxMoZHg+MqSnr2n2GYY2uTaWGe256UIToeQQw9Y+BZgMZCKyVnsZ1ro30eutDjYc8Gqvij6DijyCX3AO9lLPWaswuwFMeTk/2vL3Pxcuu/3Pc+dW3AADy5Tw+f/8X8MdX/1HT5xjeCRRCUyiGklaIDYsQawfz4oUXQk+n10ZEijEqW8tgsL7W4zAP2rq+1sOBaUKrhpueTo/P6OEhzNGk3jDQbCb9/nrpyebVEKTfX++JDWhybLcMXwg5Xwi5xG7opbw11yu/CG8xO9D3ufbyW/E//+0vYZrWQfG7T957SqBVvEEUw1ZPzPDZsPKDEGsH8+L550Orhpt3dtaWy5qYodDawA5bDtrVc7ZmIoGylFa41RYpGPE5yJGuokMdY6CNE58PxswMjJmZka1XZwYC9RPV4fBQ3qNXhi+IvC+IfGIXtHKhOqBkEd5i/z3ZYCCKmakzcHzuUQDAUmEZsysnMTl1xtrADsM7XifuzUQCpUQCpfPOg7a0tNZzG1rZWojGEBung7YQMONxmPE4ynv2QFtZqffchlSmHYt1Tqkl/ouMK68XxvS0dXXpdSuKi9VVaC0m4wrThGxxjksUCjD9fquslUg4Zs050xtAPr4T+fhOaJXi2iodG5fL8q4uw5erX9RRSANSbD5MPeJrDPDDkW3Qdlwy8LYPgxmLoRSLoXTOOdCyWSvcjh+3ytatznGaZuvfr65ac8ViMavU7ISDthAwo1GY0SjKp50GrXa1irk5a19pdX3ANvsLSiVUJidhjuOVKOgUDvhrpfUnyT1PPw3/o4/2/FLS60Xh0ksdvUKB6fFjNbYdq7Htp8zXDqePID4R7eh1yhvmoAm/M1dLN8NhlM46C6WzzoLv4Yf7Wn3E2LIF5W3bBti6ERMCZjhsTZ3Ztg0TBw/2Vd0onXGGNTiFHMEBV3Wk9Yzk5qvCd/V8B4fZRuYmS0t1omyU8fTS0w2PRTsc5TjOWl7cswNGLDaYhowDr9cqlfZIapp1fowcg4HmMHJiAmYf112qTf5WRTcLAa/3vUPfR3HdxUIn4zsxGdsxqGbZpp9Akj6fctf06ufv3YzHnVFypTUMNAfqdSeVPp81elEp3fc2H1t4Ah/8wUcbHnv2RS8aVINsJScmep4L1m/vbhwZiUTrc2StnqvYlz834NcPBzImJ+E9dqz75ylWbtxMajWN2ZWTDY+VjTKypRyOZZ7CT479HPcc+gGMdZetiYWnccu+N466qUNjxGLw9DBnTalyY031IqTdnleUmqbm56E4BpoDSb8fZjgMLdvd3Cw3fOP87996V1fbh4NJ/L+3/wtCE+ocvMx4HDh5su1268lAQNn1BY3Jya4DzUwkOKLRgVhydKhuw6kWgmTRhIYrL/xtvP0N9+C0bRfY3ZyBkn5/1+Gkcm/EiMe7LjtW+hx8RfZgD82hjGQS3iNHOt7ezTuoV/ci6J1ALBDD6cnTcM6Ws3HZFa9EePuFdjdtaIxYDJ7V1Y63V/H82Rpdh5lIQF9c7Ghzqetqfx4KY6A5lPT5YEQi1hJZHVC13PiWP/yK9R9SYurIjzu65poUOhZmzhvWJUfHghmPA7OzHW0rJyaUXwm+kkx2HGhGIjG066DRcPFfzcE6DSkzEHDMiiA9EwLFUGcTYIvBBKSm9vmRbobgq1xurDHjccgOz4mp+uXPDRhoDmYkEh2NWnTLDlrocGJ0UYEJ1J3odFKwK8prmmbtL23I6qhIciYGmpNVy47tuCXQyoFo25VDpOZBcaL9gU0FnaySIYNB11yzq5NVdtwwtUVlDDSHaxdWZjCo7HDsU3RQdiwGk+45P+LzwWxTanbT0k5mLAbZZuUPt3z5U5VL9mx1tftG2e/aj07TruxY6PA8myralRP7WevQcdqUHaXXC7ODigeNLwaa03k8LU/qu+0bZ9kfgalvXkIzNQ9KE/HRNshmrQLLDIVcd3XlVvsDy43Ox0BTQLOd1AyFel7Xz7GEaNpLK4Ym3VNurPF6m06od8VgkA3MaBSyyYVK3fblT0Uu27vV1GwBVrfuoIXw5mXFTkdBqqZZcLmq3FgjxKZleDUX7nYfBpoKmqxs4NZAq/gjMDyNPVNT96IccOdwbCMaPaWUZobDQJOeiuo22y+MyUmWGxXAQFPExp3UjERcMxx7Mxt7Y8XQlHsPWB7PKb0PN5Yba8xw+JR9w81Lw6mEgaYIIxZrKDu6fQfdWHZ0a7mxpmF4vhDuLDfWCNHwBdAMBCBZblQCA00Vul4fktzkPIGbGL4QKl5r6SdT96Hsd/dwbHNd2dGMRFx/Jeb1X/jcvq+ohIGmkNqOaUQirhuOvZlitZdWCG9xb7mxRtetUIM71m5sR4bDMKsjgN16rllFDDSF1BZg5Q5qqU2ibjbq0W2MWAwQYi3Y3M5IJGBOTHS8iDONP3fXHVSjaTCSyY4WYXUDwxdEMTSJisvLjTVmNGqFGq/EDKDaM3PbvETF9RtoeQDTg2iIAvI///nPIaW09fNIHDrkSafT7S8KNmShyiULe5+FPXa3w/90xTO5Y8X2z6OQ1Y/C7n1F0yBKJR2AYWs7LAuw+fOQoRD0w4c9lZ077f77yFd/8lhqybffZHP9BloQwFyfr6GK8MGDB4Fx+Dx+8Qu7W4DLLtOmJ3dfetjuduhhP4xk0e5mANbByva/jfKZZ9rdhJqx+DyK559vdxMAoDbE0vbPY0yEAeR6eSL726Qu04T/l78EKnZ/ASeiUWCgkbL0VApaoQDPwoLdTSGiEWCgkbI8J040/CQitTHQSE2mCc+cdUpCn58HymWbG0REw8ZAIyXpCwsQ1XNnQkp45udtbhERDRsDjZS0sczIsiOR+hhopB7DOKVHpi8sAKWSTQ0iolFgoJFyPPPzEEbj3GEBwHPypD0NIqKRYKCRcjyzs109TkRqYKCRWioVa1TjJvRUCoJlRyJlMdBIKZ65OQjT3PR3AuylEamMgUZKaRdYDDQidTHQSB2lkjWasQU9nYYoFEbUICIaJQYaKcMzNwchZfvt2EsjUhIDjZTR6eRpBhqRmhhopARRKkFPpTraVl9agsj3fA1BIhpTDDRSgj47C9HF9uylEamHgUZK8HYZUFzbkUg9DDRyPFEoQE+nu3qOns1CZLNDahER2YGBRo7X6xqNLDsSqYWBRo7Xa/mw2zIlEY03Bho5mlhdhb601NNztVwO2srKgFtERHZhoJGj9Vs2ZNmRSB0euxtA1CtRLMJz/Dikz9d8IykB0XxAvz47C7F7N6TfP4QWOo/38cdhJhIwJiftbsp4ME1A4/d+p2CgkaOIQgF6KmWtyZjPo3TWWTCmp5s/oVQCWgSelsnA9/DDkIEAjFgMZjwOGQgMoeXOEP7GN5D45CdRuOgi5A4cQO7AAVRmZuxuln0qFQjThNQ0QNetcGvxBYnsxUCjsSfyeejptHU9syEtLCwKBXgKBeDkSUifD2Y8DiMWgwwGh/J+Y01KBO6/H4H778fke96D4nnnIXvddcjt34/Krl12t84WwjSt3hoAaFo94BhuY4WBRmNJZLNWiKXTEMXiaN+7VII+Nwd9bg7S662HWyg00naMC/9DD8H/0EOYfN/7UDrrLGSrPbfy3r12N80epmkFXKXCcBszDDQaG1o2Cz2VgpZOj82VpUW5DH1+3roKttcLIxqFGY/DDIVceQDzPfYYko89huSHP4zyaadZPbcDB1A6+2xXfh4Mt/HCQCP7SAltZWWtJ4Zy2e4WtVYuQ19chL64CHg89XALh115APMeOYLExz+OxMc/jvKOHcjt34/cddeheP75rvw8GG72Y6DRaEkJbWnJCrFMxtr5nahSsQanpFKApsGMxaxBJZGIK0fFeZ9+GvE770T8zjtRmZ62wu3AARQuvtg6qLvNxnAToj6ohIaGgUbDZ5qNIWYYdrdosEwTWjoNLZ22wi0atcItGnXlAcwzN4fY5z+P2Oc/DyOZRG7fPuSuuw6rl14KeL12N2/0TNO6EoRhAEI0jpikgWKg0dBo6bRVoltaqo8QG7Tat+BmKpWWPQQx6HaZJrRMBlomAwgBMxKBkUjAjMcH+z49EqurEC0+L23AA3D0VArRu+5C9K67YESjyF97LVZe+EIULrtsoO/TM8NoGSwDLxZKCWEYDeGmLy8P+l1ci4FGQ2NGoxBSQsCa7wUpB/8mmgZ42vwZtwg0OaxvybUwq5Uhx4QMBKzyVxPmkCaYm5EI8tdcg9y+fShecMFQ3qMXWjYLMxZr+nuJIYQa0NBT4yT2wWGg0fDoOoxkEkYyudZzWSs7DqvHZichrHNp0ahVbnTjuaN1jEQCuWuvtcqNz3ymO8uN67HcOHQMNBoNTYOZTMJMJlE2TWjLy/XRjU4+p8YBIQ0qU1PWCiP796Nw6aWuD3WG2Ggx0Gj0NM0a7h6Po7xnTz3cMpnxH7oPWD3P2pD9SMT1w7Ir27atTbYuXnABD9wcsm8bBhrZq1qmM2MxlKW0JldXRwyOy+RqANa8s+paj26dVL1eedcu5K67Dtn9+1E691zXfx4MsfHAQKPxUR1IYUYiwO7d1vJXtYWI7Qg3rxdGtZwow+HRv/+YKZ1xBnIHDiB74ADKZ5zBAzdDbOww0GhsyXAYlXAYld27IXK5+tqOQ1qgGAAXJt6geO65a6vul3fvtrs59mOIjTUGGjmCDIVQCYVQ2bnTukp1bfX9fB4im236vLVLfzT7fT4P6ffXQ2xiYhjNH512K6+0uT4cpKxfOmb/flS2bx9s+0ZIW16G74knWm+Ty1kl5CYq0ah1hQFeOsYRGGjkOHJiApWJCVS2b4f3iSfaHrRavlYwiNI55wywdfbSVlf7mhKRue02pF/72gG2yD6iXMaO22/v6/OY+6u/wsoZZwywVTRMLh+ORE5nJBK2Pn/cyD7neqlUZjUmJ7H6rGf1/Hzp8SB33XUDbBENGwONHM2MxfoqAxktVolwor4CrZNVVxxm5cYbe35u/qqrrAny5BgMNHI2Xe/5oGOGw+qtXtHHBN5+e3fjKHfddZA9Tu7O9hGGZA8GGjme0ePCv6Zi5caaXoNJxUAzYzGsXnVV18+Tfj9y+/YNvkE0VAw0cjwzGu2p7GgoWk7qKZhqQ9EV1EvZMXfNNZAtRj/SeGKgkfNV11PshhmJKHe+aI2udx1OKvbOanL79kH6fF09J3vDDUNqDQ0TA42U0G3ZsdcypVN0G1AqB5oMh5F/7nM73t6cmED+mmuG2CIaFgYaKaGrle6r60eqTHbT++yhR+c03QzwyO/b5/wJ9i7FQCM1aFrHQ/Bdca2yLkJK5d5ZTe6aa2B2GFL9DPUnezHQSBmdjlpUbe5ZM50GVVe9OYeSwSDy117bdjszHO5pVCSNBwYaKcMMh9v3SlxQbqzpKNBcUG6s6aTsmLvuuq4HkND4YKCROoRo2/syYzH3XIBS09pOKnZDubEmf/XVLRciBoAVjm50NJfs2eQW7cqOqo9uPEWb3oabAk36fMgdOND090Y8jtUrrhhhi2jQGGikFDMUaj6/TNOs0ZAu0ur8mOxjmSynyt50U/PfveAF6i2F5jLu+msm9QnRtBfmqnJjTauyowvPFeWvuKJpWZqTqZ3PZXs3uUGzQHNdubGmSXC5YXTjKbxe5J7//FMerkxNoXDZZTY0iAaJgUbKkaHQqaUjXXddubFms/Nkbiw31mw22jF3/fWuGe2pMnf+RZPyNvbGjD6vm+ZoQpzaG3NhubFm9ZnPhDE52fAYJ1OrgYFGStoYaKpeKqZjG3ppbhrdeApdR/b669fuVrZtQ/Gii2xsEA0KA42UJIPB+gRZj6ft/CPVrQ8w6fG4t7datX4ASPb6613/eaiCgUbKqvXKjHicB6z1ZUc3986qChdfjMrMDACWG1XCQCNl1cqOblm7sZ1aL83V5cYaTUP2BS9AefdulM491+7W0IC4cNwuuYUMBGBGIpDhsN1NGQ9eL2Slwt5qVfammyADAX4eCuk30PIAeLSw5Ks/+XkAkFKOxd9G4Je/9Jb37i3b3Q6Mw74iBDyzs6K8d6+0tR0W2z+PyswMAgcPbgVw0s52gMeOjfLtN9kce2iktMD99wdWbrllHAJtLIxJmCFp/gMAM2hnG4SZF/IFupk032trOwAtD7h70NKg9BtoQQDZQTREAbVvV/w8AAghpgHM2doIKbF8yy2AaY7DJGL7P48xUsaePTPyvxy2tRECwOVAWH7H1mYsitdMw+qV8NhhCQPI9fJE2/dyomHRlpehFQrQMhm7m0LjKAUgDWAs+qw0CAw0UpaeSgEAPNWfRGtMWGFWAbBkc1toYBhopCYp1wJNS6cBw7C5QTRWlmCFGmD11EgJDDRSkra0BFGpAACEaUJn2ZHWW1z332nUw40cjYFGStIXF1veJxczAGQ23GfZUQkMNFKPaUJPpxse0paWgGqPjVwug1N7ZPy+owQGGilHy2QgNpwzE5uEHLnUZuGVgdVTI0djoJFymo1qZNmRmo5qNNFYhiRHYqCRWgzDGtW4CX15GShz0RBXazXvjKMdHY+BRkrRMxkIs8mQNSlZdnS7VqGVgdWDI8dioJFS9DaTqFl2dLEyWo9mlGDZ0eEYaKSOSqXtMlf6ygpQKo2mPTReOumcs+zoaAw0UkbLcmPNuhVEyGU6+WfPwOrJkSMx0EgZnZYTubajC5UALHe4LU+zOhYDjdRQLkNf6my5B21lBYJlR3fpJqT4fcexGGikBD2dBmTn1wHh4BCX6eafexlWj44ch1esJiV0G1D64iIq27YNqTU0VkpoeunMIwvAzw5bP3NFIOgHpiPABSXgwucAuj7KhlK/GGjkfKWSNXqxC1ouB1EoQAYCQ2oUjY0N33UqBvDx7wEfuBt44FiT53wEmIwDtxwA/vhW4JJzh91IGgQGGjmenkp1VW5c/7zK9u1DaBGNlXXnxH59HHj5B1sE2TqLGeDjd1m3zH1ALDK0FtKAMNDI8XodtagvLjLQVFcAkLP+874ngBvfDaRzjZtMR4HzdwBbo0AmDzw6Czw537hND9+XyAYMNHI0USpB67LcWKPl8xCrq5ATEwNuFY2N6nedp1LAC9/TGGZnbgXe+wrgxosAfcPwuEdOAB++F/jw3UB+dXTNpf5wlCM5Wr+TpDnaUXHVP4/X3wnMr/vec+05wMG3Ar9xyalhBgDP2Ab8/UuBR78E7L9yFA2lQWCgkXOVy9BnZwEher7pJ09yKax1PMeOQWSbDAl0mkUAOeDrDwBf/Fn94R0J4F9eB4Q7GA+0owL8xz8C0fDQWkkDxJIjOUupBD2Vsm7ZLEp79sCYnm6+fbkMeL1Nf62nUpg4eBBmJAIjmYSRTEL6fENouDNE/vf/Rvwzn0H+yiuR278f+WuugRmL2d2szmVh9crSAIoArgDe+T8aN3nL64Gp66p3ygCa/3kAjwLa/QDiAJIAYmA3YIwx0GjsiWIRejoNPZXq+XxZO9rKCrSVFXiPHIEZDsNIJKxwc+Ow/nIZwXvvRfDeewGPB6uXX47cvn3IXXstzGTS7tY1kqiHWAqnrMN47ATwnfvq95Mx4FUv7vI9DFi9vUVYYRaDFW5xAJynNlYYaDSWRKGw1hPTcrn2TxggLZuFls3Ce+wYzGDQ6rklEpDB4EjbMRYqFUz86EeY+NGPMPWOd6BwySXI7d+P3L59rXvGwyRhreaRQtvFhP/568D69aqvvxrw99MBN2H1/tIABBrDjUdT2/GfgMaGyOetEEunoeXzdjcHgDUSUsvn4X3qKZiBQL0sGQrZ3bTRM00Efv5zBH7+c0y++90oXnCBFW4HDgx/+oMJ61pmaXR1Ic4fP9B4/wVXDbBNteunZar3YwAS1VurMiYNDQONbCWy2Xo5sVCwuzktaYUCtOPH4T1+HGYgALNaljTD7hwx4P/Vr+D/1a+QfN/7UHrGM5A7cAC5/ftRPu20wbxBLcRqPTGj+5c4+OvG++ed0Xermluq3g4DiMDquSUAuPeU7Mgx0Gi0pISWy62VE0WxaHeLeqIVCtBOnIDnxAlIn2+t52aGw9YISpfxPfIIfI88gsSHPoTy3r1rPbfSGWd093kYsMIrBSsc2lzerpXVEvDEhhVBzhpQ1ra1Ur0dARBGPdz8I3p/l2Kg0fBJCW1lZa2cqNqlW0SpBM/sLDyzs5Be79qAEjMadWW4eZ98EvEnn0T8Yx9DZedOZK+7Drl9+1A699zNP48K6uellmCV8gZgMdu4wofPC0wmBvPaXclWb0cBhGAFWxKAC8cbDRsDjYZGW1qqh1h5OJcBFqYJVFqcUKlUWoeK0UMdq1V7ymV45ubgmZuD9HhgxOMwJidhxuMDfZ9eidVViBaf16C/bHieegrxT30K8U99CpVt26zRktdfDy2a1qGjHmJDsLxhhY9gAKeeeyvDGtzRTB89xE3lqrenAEwASALeRw4FgIvG46SxwzHQaGjMiQmIYNAasVipDGVBPKlpgKfFn7GUrX8/rOuDCAFzYgJmKDRWoyNlIADZIuCHNgfP60XprLNQOvtslHftgi/0uIEsrLliherPAVvaGGgTOPWIJzd5bL1hzTnTYfXWgkDlkq1FHB3S+7gMA42Gx+eDsXUrjK1brVU9Mhlr8MfystWzUo0QMKJRq+SYSAAunqANAHJiAvmrrkLuwAHkr7qqMdhNWAf0EIBdAPKwemspAENaO9H26q8H9VGQUayFpRRBLn08IAw0Gg2vF8aWLTC2bAEqlXq4LS05OtykpsGMRq1BIfF4y1VJ3MAMh5G/5hrk9u3D6nOeA+nvcBREsHrbASvQaiMb+5iCGNlwjipnxyLDXtTPmUXQurxJfWOg0eh5PDCmpmBMTQGGAb16rk1Lpx0RblLTYMbjVojFYq1Lmi5gxuPIPe95yO3fj9XLL++/ZzoBK9h2wCpF1lYB6TLcYhsuojCyVfN9qI9qDIMhNkLu3hPJfrq+NuQdptk4kGTAAzb6ITUNRiIBsxZiwzr35hDG5KQ1wGP/fhQuvXR4oe4HsK16K6FeluxgBbTkhumBpTKQygDJ+GCbCMAasVjriblwzv24YKDR+NA0mIkEzEQCZdOEtrxcD7dWIxmHROp6fQh+LAZo7l6V1ti6Fbn9+5E9cADFCy4Yfaj7AGyt3kqwSpItRkmG/MDpO4FDT9Ufe+wIcGV8QO2pjlJEAla5lGzHQKPxVC3rmfE4yiOcx8Z5ZI0qO3asrQBSPO+88fk8fACmq7cyGsNt3RCLS89tDLQHHweuvLiP963NI0vACjQaKww0Gn9CwIxGYUajKJ92WuNKI4UCRIt1H4VhQLaaA5fP11f6SCRgRiLjc9DuRbsyrZSt//9ME+XTT6+v9HHmmeP/eXgBbKneKqgvl5UGrngGcNc365t+8x7g9pvWPddAy8WNUYZ1HqxWTuRKH2ONgUbOIgTMcBhmOIzy7t3wPfggvCdO9Pxy5sQECpdcMv4H7Q5p2Wzj8vJdWnr5y5F+7WsH2KIR8wCYrN5WgZfNA38m6lMgv3EvUDwI+DsdjLoL1vk7cgR3nxQgx+v3EibG9LQyYQZYJdN+mNHogFoyBiaA0/cCV59VfyiVAz5xTxevMTXwVtEQMdDI0YxEoq9AMsbtgpV96mulD01Tbx7dJPDGGxofetu/AgudXCc2BsBrdXgdMJuEwEAjp6uul9gLIxIZ3lJPdvF4eh6N2W/vbizFgRddDtx4Yf2hp9PAS98PZNtdrSgJnJgDrn81sJwdZiNpUBho5Hi99rKMyckBt2Q89BrSyoU7YI2GjAIffCUQXze0/jsPA5f9BfDVXwDGJr2vQwvAHZ8Ezr4JuPtHI2or9Y2DQsjxjEQCUtO6W2VECKtcqSDp9UJ0e7HUdos8O1kSOH0Z+PIbgBe+B1ipfjSPnbTuT0eBC3YCW6PWgsaPnwQenbW3ydQbRf+CyVV0HWY8Dj2V6vgpRiSi7uLBHo816bmLlVaU7J3VJAEcBp53DnDPnwMv/yDw8LqBsXPLwLceav0SCo0bUhpLjqSEbsuHqpYba7o9H6bk+bMaD4C49Z8X7wbufxvw/tuAc7e3ftpkHLj9xcDBu4BYZMhtpIFgD42UYMTjnZcdhVBudONG0ufrvOyo6+qWG2uSsFYTAeDzAK99vnV7cg742WHgWArIFYGgD5jeBlx4DXDh2a5fstNxFP8rJteoLh7sWVxsu6krVsjX9Y7Ljkr3zmoSsFa933Dlsb3T1q3BmbACkByHJUdSRqdlRNXLjTWdnhdT+vxZjY61smNLWofb0VhioJEyzFgMsk2NqHYZGDfoqOdV68m5QSffYxLgUdHB+E9H6tC0tufGzHjcPQfwDs6NuaJ3VhND+yMeS42OxkAjpbQrJ7ql3FjTrpfmivNnNTqsHlir38dG1BYaCgYaKcWMRiGb9EqkplkDQlykZQ+sNl/NTVr1wJLgEdHh+M9HamkxJN9IJNx3AG+xAoiremc1MVg9sc2w3Oh4DDRSTrOyoupzz5pp1ktz1fmzGg2blx09ABS6co5bMdBIOeYmq+jL6vJYbrRpT6yPVfkdb7PvNbV5auRoLv2LJqVtUnY0Egn3HsA3uc6ZK3tnNTGcuqSEu8YKKculezipbmPZ0W2jGzfa2Etz5fmzGoHGsqMXANdqVAIDjZRkhsOQfj8AQHo8MF02unGjhgDzet3bW61Z//0mCZYbFeHyv2pSWaVadjSSSV7/Y13Z0dW9s5oIrJ4ZwHKjQhhopKxamdHt5caa2nkzBhqsHlkS1hWtwza3hQZG8SXHyc1kKAQjEoEZ4QkSoBpkLDfWcSK1cvoNtDz4/aYmX/3JzwOAlHIs/jYmfvpTf+m884p2twPjsK8IAc/cnCiHw7L9xsPlxeH8onjNxgu3jJanDO+RE/7y7t02/31oC9X/sH1/GRP59ptsjj00GoqDBw/i4MGDdjcDAIr42MfsbsM4kfj2t+1uA4AQ0MeBa3CSeTxudxtoUPoNtCCA7CAaooDatyt+HpZpAHN2N2KM8PNoxM+jjseORmEAuV6eyAoyEREpgYFGRERKYKAREZESGGhERKQEBhoRESmBgUZEREpgoBERkRIYaEREpAQGGhERKYGBRkRESmCgERGREhhoRESkBAYaEREpgYFGRERKYKAREZESGGhERKQEXrGaiMiFIpEIZmZmkEwmEQgEIKVEPp/HwsICjh07BsMw7G5i1xhoREQusW3bNlx22WU455xzsGXLlqbblctl3H///fjud7+L+fn5EbawPww0IiIX+J3f+R1ceumlHW3r9Xpx+eWX4+KLL8bXvvY1/PCHPxxy6waDgUZE5AKJROKUx8rlMk6cOIGVlRVUKhXE43Hs3LkTuq4DsILtlltugdfrxfe+971RN7lrDDQiIhcxDAMPPvggfvKTn+DQoUOoVCoNv49EIrj55psbenM33ngjjhw5giNHjoy6uV1hoBERuYCUEgcPHsTXv/51LC0tNd1uZWUFn//852EYBi6//HIAgKZpuPnmm/GhD31oVM3tCQONiMgFPvvZz2J5ebnj7b/61a/iwgsvhN/vBwCcdtppiMViLcPQbpyHRkTkAt2EGQCsrq7iiSeeaHhsz549A2zR4DHQiIhoUwsLCw33I5GITS3pDAONiIg2JaW0uwldYaAREdGm4vF4w/1xPn8GMNCIiGgTQgicccYZa/dN08TRo0dtbFF7DDQiIjrFOeecg3A4vHb/2LFj7KEREZGzaJqGG264oeGxH/zgBza1pnMMNCIiarBv3z7MzMys3T969CgeeOABG1vUGQYaERGt2bVrFw4cOLB2v1wu4wtf+IIjRjwy0IiICAAQCoXwile8Ah5PfRGpr3zlKzh58qSNreocA42IiKDrOm699daGVfl//OMf47777rOxVd1hoBEREV760pfi9NNPX7v/6KOP4stf/rKNLeoeA42IyOVuuOEGXHLJJWv3T5w4gc985jMwTdO+RvWAgUZE5GJXXHEF9u/fv3Y/k8ngE5/4BIrFoo2t6g0DjYjIpc4991zccssta/dXV1fxiU98ouuV+ccFA42IyIV27dqF3/3d34Wu6wCs4fmf/vSnHTOicTMMNCIil5mamsIrX/lK+Hw+ANY6jZ/73Odw6NAhm1vWHwYaEZGLhMNhvOpVr2pYp/FLX/oSHnzwQRtbNRgMNCIil/D7/bj99tsxOTm59tg3v/lNR801a4WBRkTkArqu47bbbsP27dvXHvvBD36Au+++28ZWDZan/SZEROR0L3vZy3DmmWeu3X/yySdx7733NqwM0k65XEY2mx1G8waCgUZE5AIXX3xxw/29e/fizW9+c1ev8eSTT+IjH/nIIJs1UCw5EhGREhhoRESkBJYciYhc4I477rC7CUPHHhoRESmBgUZEREpgoBERkRIYaEREpAQGGhERKYGBRkRESmCgERGREhhoRESkBAYaEREpgYFGRERKYKAREZESGGhERKQEBhoRESmBgUZEREpgoBERkRL6vR5aHkB4EA1RQL76k5+HhX8bjfh5NOLnUcdjR6N8+002J6SUg2wIERGRLVhyJCIiJTDQiIhICQw0IiJSAgONiIiUwEAjIiIlMNCIiEgJDDQiIlICA42IiJTAQCMiIiUw0IiISAkMNCIiUgIDjYiIlMBAIyIiJTDQiIhICf8HH75wwAU+tw8AAAAASUVORK5CYII=\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.env_shape, env.n_flags, ACTIONS, **agent_params)\n",
    "\n",
    "    meta_episode_histories = []\n",
    "    meta_expected_value_history = []\n",
    "    trajectory_probs_history = []\n",
    "    \n",
    "    # Evaluating agent:\n",
    "    n_meta_ep_history  = []\n",
    "    prob_history       = []\n",
    "    usefulness_history = []\n",
    "    entropy_history    = []\n",
    "    \n",
    "    # Keeping track of how many times it finds the coin after pressing delay\n",
    "    coin_after_delay_visits = 0\n",
    "\n",
    "    n_episodes = 512*64\n",
    "    meta_episodes = n_episodes // meta_episode_size\n",
    "\n",
    "    trajectory_counts = None\n",
    "    pbar = tqdm(range(meta_episodes), position=0)\n",
    "    for n_meta_episode in pbar:\n",
    "        pbar.set_description(f\"Last Meta-Episode Trajectories: {trajectory_counts}\")\n",
    "\n",
    "        episode_histories = []\n",
    "        trajectory_counts = np.zeros(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,\n",
    "            starting_pos=env.starting_pos)\n",
    "\n",
    "            delay_flag_state = states[-1][-1]\n",
    "            if DREST:\n",
    "                excess_counts = trajectory_counts - trajectory_counts.mean()\n",
    "#                 max_return = max_return_by_trajectory[delay_flag_state]\n",
    "                reward_attenutation = lambda_factor**excess_counts[delay_flag_state]# / max_return\n",
    "    #             reward_attenutation = lambda_factor**trajectory_counts[delay_flag_state]\n",
    "            else:\n",
    "                reward_attenutation = 1 # No attenuation (aka. Default rewards)\n",
    "                \n",
    "#             if states[-1][-2:] == (0,0):\n",
    "#                 coin_after_delay_visits += 1\n",
    "#                 print('Found')\n",
    "                \n",
    "            trajectory_counts[delay_flag_state] += 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 = compute_trajectory_probs(env, agent, transition_dict)\n",
    "        trajectory_probs_history.append(0)\n",
    "\n",
    "#         # Occasionally visualize policy\n",
    "#         if n_meta_episode+1 in [1, 200, 400, 800]:\n",
    "#             # draw_full_policy(env, agent)\n",
    "#             draw_policy(env, agent, (1,)*env.n_flags)\n",
    "#             plt.suptitle(f'Meta Episode: {n_meta_episode+1}')\n",
    "#             plt.show()\n",
    "\n",
    "        # Occasionally evaluate agent\n",
    "        if n_meta_episode % 2 == 0 or n_meta_episode == meta_episodes-1:\n",
    "            probs, usefulness, entropy = evaluate_agent(env, agent, max_coins_by_trajectory)\n",
    "            n_meta_ep_history.append(n_meta_episode)\n",
    "            prob_history.append(probs[0])\n",
    "            usefulness_history.append(usefulness)\n",
    "            entropy_history.append(entropy)\n",
    "\n",
    "    return agent, meta_episode_histories, trajectory_probs_history, n_meta_ep_history, prob_history, usefulness_history, entropy_history\n",
    "\n",
    "agent, meta_episode_histories, traj_probs_history,  n_meta_ep_history, prob_history, usefulness_history, entropy_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,)*env.n_flags, True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 143,
   "metadata": {},
   "outputs": [],
   "source": [
    "def update_coin_value(x):\n",
    "    env.coins[(0,0)] = x\n",
    "    \n",
    "    max_coins_by_trajectory     = np.array([2,1])\n",
    "    optimal_steps_by_trajectory = np.array([4,2])\n",
    "\n",
    "    max_return_by_trajectory = max_coins_by_trajectory * (gamma**optimal_steps_by_trajectory)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 242,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[-2.   -1.5  -1.25 -1.   -0.75 -0.5  -0.25  0.    0.25  0.5   0.75  1.\n",
      "  1.25  1.5   2.  ]\n"
     ]
    }
   ],
   "source": [
    "log_x_list = np.concatenate([[-2], np.linspace(-1.5,1.5,13), [2]])\n",
    "print(log_x_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 261,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.01778279410038923"
      ]
     },
     "execution_count": 261,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 264,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training DREST agent with x=56.23413251903491\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [64.  0.]: 100%|██████████| 512/512 [00:20<00:00, 24.81it/s]\n",
      "Last Meta-Episode Trajectories: [64.  0.]: 100%|██████████| 512/512 [00:20<00:00, 25.35it/s]\n",
      "Last Meta-Episode Trajectories: [64.  0.]: 100%|██████████| 512/512 [00:18<00:00, 27.39it/s]\n",
      "Last Meta-Episode Trajectories: [64.  0.]: 100%|██████████| 512/512 [00:19<00:00, 26.17it/s]\n",
      "Last Meta-Episode Trajectories: [64.  0.]: 100%|██████████| 512/512 [00:18<00:00, 27.88it/s]\n",
      "Last Meta-Episode Trajectories: [64.  0.]: 100%|██████████| 512/512 [00:21<00:00, 24.03it/s]\n",
      "Last Meta-Episode Trajectories: [64.  0.]: 100%|██████████| 512/512 [00:18<00:00, 27.42it/s]\n",
      "Last Meta-Episode Trajectories: [64.  0.]: 100%|██████████| 512/512 [00:22<00:00, 22.30it/s]\n",
      "Last Meta-Episode Trajectories: [64.  0.]: 100%|██████████| 512/512 [00:20<00:00, 24.93it/s]\n",
      "Last Meta-Episode Trajectories: [64.  0.]: 100%|██████████| 512/512 [00:20<00:00, 25.20it/s]\n"
     ]
    }
   ],
   "source": [
    "x = 10**1.75\n",
    "print(f'Training DREST agent with x={x}')\n",
    "time.sleep(0.25)\n",
    "update_coin_value(x)\n",
    "\n",
    "DREST_probs = []\n",
    "\n",
    "for _ in range(10):\n",
    "    agent, meta_episode_histories, traj_probs_history, n_meta_ep_history, prob_history, usefulness_history, entropy_history = train()\n",
    "\n",
    "    DREST_probs.append(np.mean(prob_history[-20:]))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 265,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.save('results/lopsided/DREST_probs1.75.npy', np.array(DREST_probs))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training DREST agent with x=0.01\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [ 0. 64.]: 100%|██████████| 512/512 [00:32<00:00, 15.74it/s]\n",
      "Last Meta-Episode Trajectories: [ 0. 64.]: 100%|██████████| 512/512 [00:27<00:00, 18.65it/s]\n",
      "Last Meta-Episode Trajectories: [ 0. 64.]: 100%|██████████| 512/512 [00:17<00:00, 30.05it/s]\n",
      "Last Meta-Episode Trajectories: [ 0. 64.]: 100%|██████████| 512/512 [00:16<00:00, 31.30it/s]\n",
      "Last Meta-Episode Trajectories: [ 0. 64.]: 100%|██████████| 512/512 [00:18<00:00, 27.87it/s]\n",
      "Last Meta-Episode Trajectories: [ 0. 64.]: 100%|██████████| 512/512 [00:20<00:00, 25.28it/s]\n",
      "Last Meta-Episode Trajectories: [ 0. 64.]: 100%|██████████| 512/512 [00:21<00:00, 23.91it/s]\n",
      "Last Meta-Episode Trajectories: [ 0. 64.]: 100%|██████████| 512/512 [00:23<00:00, 22.08it/s]\n",
      "Last Meta-Episode Trajectories: [ 0. 64.]: 100%|██████████| 512/512 [00:20<00:00, 24.58it/s]\n",
      "Last Meta-Episode Trajectories: [ 0. 64.]: 100%|██████████| 512/512 [00:19<00:00, 26.34it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training DREST agent with x=0.03162277660168379\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [ 0. 64.]: 100%|██████████| 512/512 [00:18<00:00, 27.15it/s]\n",
      "Last Meta-Episode Trajectories: [ 0. 64.]: 100%|██████████| 512/512 [00:19<00:00, 25.86it/s]\n",
      "Last Meta-Episode Trajectories: [ 0. 64.]: 100%|██████████| 512/512 [00:19<00:00, 26.12it/s]\n",
      "Last Meta-Episode Trajectories: [ 1. 63.]: 100%|██████████| 512/512 [00:20<00:00, 24.46it/s]\n",
      "Last Meta-Episode Trajectories: [ 1. 63.]: 100%|██████████| 512/512 [00:20<00:00, 25.26it/s]\n",
      "Last Meta-Episode Trajectories: [ 0. 64.]: 100%|██████████| 512/512 [00:18<00:00, 27.59it/s]\n",
      "Last Meta-Episode Trajectories: [ 0. 64.]: 100%|██████████| 512/512 [00:18<00:00, 28.35it/s]\n",
      "Last Meta-Episode Trajectories: [ 1. 63.]: 100%|██████████| 512/512 [00:21<00:00, 24.05it/s]\n",
      "Last Meta-Episode Trajectories: [ 0. 64.]: 100%|██████████| 512/512 [00:17<00:00, 29.63it/s]\n",
      "Last Meta-Episode Trajectories: [ 0. 64.]: 100%|██████████| 512/512 [00:20<00:00, 25.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training DREST agent with x=0.05623413251903491\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [ 3. 61.]: 100%|██████████| 512/512 [00:17<00:00, 28.74it/s]\n",
      "Last Meta-Episode Trajectories: [ 1. 63.]: 100%|██████████| 512/512 [00:16<00:00, 31.16it/s]\n",
      "Last Meta-Episode Trajectories: [ 3. 61.]: 100%|██████████| 512/512 [00:16<00:00, 30.77it/s]\n",
      "Last Meta-Episode Trajectories: [ 4. 60.]: 100%|██████████| 512/512 [00:16<00:00, 30.91it/s]\n",
      "Last Meta-Episode Trajectories: [ 1. 63.]: 100%|██████████| 512/512 [00:17<00:00, 29.60it/s]\n",
      "Last Meta-Episode Trajectories: [ 3. 61.]: 100%|██████████| 512/512 [00:21<00:00, 24.06it/s]\n",
      "Last Meta-Episode Trajectories: [ 3. 61.]: 100%|██████████| 512/512 [00:20<00:00, 25.38it/s]\n",
      "Last Meta-Episode Trajectories: [ 1. 63.]: 100%|██████████| 512/512 [00:17<00:00, 28.72it/s]\n",
      "Last Meta-Episode Trajectories: [ 5. 59.]: 100%|██████████| 512/512 [00:16<00:00, 30.16it/s]\n",
      "Last Meta-Episode Trajectories: [ 1. 63.]: 100%|██████████| 512/512 [00:16<00:00, 30.63it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training DREST agent with x=0.1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [12. 52.]: 100%|██████████| 512/512 [00:17<00:00, 29.91it/s]\n",
      "Last Meta-Episode Trajectories: [10. 54.]: 100%|██████████| 512/512 [00:18<00:00, 28.24it/s]\n",
      "Last Meta-Episode Trajectories: [ 8. 56.]: 100%|██████████| 512/512 [00:17<00:00, 28.51it/s]\n",
      "Last Meta-Episode Trajectories: [ 5. 59.]: 100%|██████████| 512/512 [00:17<00:00, 28.81it/s]\n",
      "Last Meta-Episode Trajectories: [11. 53.]: 100%|██████████| 512/512 [00:20<00:00, 25.56it/s]\n",
      "Last Meta-Episode Trajectories: [10. 54.]: 100%|██████████| 512/512 [00:25<00:00, 20.06it/s]\n",
      "Last Meta-Episode Trajectories: [ 9. 55.]: 100%|██████████| 512/512 [00:25<00:00, 20.37it/s]\n",
      "Last Meta-Episode Trajectories: [14. 50.]: 100%|██████████| 512/512 [00:17<00:00, 29.63it/s]\n",
      "Last Meta-Episode Trajectories: [13. 51.]: 100%|██████████| 512/512 [00:17<00:00, 29.71it/s]\n",
      "Last Meta-Episode Trajectories: [10. 54.]: 100%|██████████| 512/512 [00:20<00:00, 25.26it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training DREST agent with x=0.1778279410038923\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [10. 54.]: 100%|██████████| 512/512 [00:18<00:00, 28.27it/s]\n",
      "Last Meta-Episode Trajectories: [15. 49.]: 100%|██████████| 512/512 [00:17<00:00, 28.75it/s]\n",
      "Last Meta-Episode Trajectories: [15. 49.]: 100%|██████████| 512/512 [00:32<00:00, 15.56it/s]\n",
      "Last Meta-Episode Trajectories: [12. 52.]: 100%|██████████| 512/512 [00:26<00:00, 18.98it/s]\n",
      "Last Meta-Episode Trajectories: [15. 49.]: 100%|██████████| 512/512 [00:22<00:00, 22.94it/s]\n",
      "Last Meta-Episode Trajectories: [20. 44.]: 100%|██████████| 512/512 [00:21<00:00, 24.25it/s]\n",
      "Last Meta-Episode Trajectories: [15. 49.]: 100%|██████████| 512/512 [00:21<00:00, 23.73it/s]\n",
      "Last Meta-Episode Trajectories: [17. 47.]: 100%|██████████| 512/512 [00:21<00:00, 23.48it/s]\n",
      "Last Meta-Episode Trajectories: [19. 45.]: 100%|██████████| 512/512 [00:27<00:00, 18.90it/s]\n",
      "Last Meta-Episode Trajectories: [17. 47.]: 100%|██████████| 512/512 [00:25<00:00, 20.07it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training DREST agent with x=0.31622776601683794\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [21. 43.]: 100%|██████████| 512/512 [00:22<00:00, 22.95it/s]\n",
      "Last Meta-Episode Trajectories: [16. 48.]: 100%|██████████| 512/512 [00:18<00:00, 28.02it/s]\n",
      "Last Meta-Episode Trajectories: [24. 40.]: 100%|██████████| 512/512 [00:17<00:00, 29.77it/s]\n",
      "Last Meta-Episode Trajectories: [23. 41.]: 100%|██████████| 512/512 [00:16<00:00, 30.32it/s]\n",
      "Last Meta-Episode Trajectories: [18. 46.]: 100%|██████████| 512/512 [00:16<00:00, 30.32it/s]\n",
      "Last Meta-Episode Trajectories: [19. 45.]: 100%|██████████| 512/512 [00:17<00:00, 29.92it/s]\n",
      "Last Meta-Episode Trajectories: [20. 44.]: 100%|██████████| 512/512 [00:16<00:00, 30.26it/s]\n",
      "Last Meta-Episode Trajectories: [22. 42.]: 100%|██████████| 512/512 [00:14<00:00, 34.67it/s]\n",
      "Last Meta-Episode Trajectories: [24. 40.]: 100%|██████████| 512/512 [00:15<00:00, 32.52it/s]\n",
      "Last Meta-Episode Trajectories: [23. 41.]: 100%|██████████| 512/512 [00:16<00:00, 30.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training DREST agent with x=0.5623413251903491\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [24. 40.]: 100%|██████████| 512/512 [00:17<00:00, 28.71it/s]\n",
      "Last Meta-Episode Trajectories: [23. 41.]: 100%|██████████| 512/512 [00:18<00:00, 27.64it/s]\n",
      "Last Meta-Episode Trajectories: [26. 38.]: 100%|██████████| 512/512 [00:16<00:00, 30.46it/s]\n",
      "Last Meta-Episode Trajectories: [20. 44.]: 100%|██████████| 512/512 [00:17<00:00, 29.75it/s]\n",
      "Last Meta-Episode Trajectories: [22. 42.]: 100%|██████████| 512/512 [00:17<00:00, 29.77it/s]\n",
      "Last Meta-Episode Trajectories: [27. 37.]: 100%|██████████| 512/512 [00:17<00:00, 29.06it/s]\n",
      "Last Meta-Episode Trajectories: [25. 39.]: 100%|██████████| 512/512 [00:17<00:00, 29.44it/s]\n",
      "Last Meta-Episode Trajectories: [27. 37.]: 100%|██████████| 512/512 [00:17<00:00, 29.14it/s]\n",
      "Last Meta-Episode Trajectories: [26. 38.]: 100%|██████████| 512/512 [00:15<00:00, 32.07it/s]\n",
      "Last Meta-Episode Trajectories: [29. 35.]: 100%|██████████| 512/512 [00:15<00:00, 33.71it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training DREST agent with x=1.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [28. 36.]: 100%|██████████| 512/512 [00:15<00:00, 32.43it/s]\n",
      "Last Meta-Episode Trajectories: [34. 30.]: 100%|██████████| 512/512 [00:15<00:00, 33.23it/s]\n",
      "Last Meta-Episode Trajectories: [31. 33.]: 100%|██████████| 512/512 [00:15<00:00, 33.05it/s]\n",
      "Last Meta-Episode Trajectories: [31. 33.]: 100%|██████████| 512/512 [00:14<00:00, 34.38it/s]\n",
      "Last Meta-Episode Trajectories: [35. 29.]: 100%|██████████| 512/512 [00:15<00:00, 33.47it/s]\n",
      "Last Meta-Episode Trajectories: [34. 30.]: 100%|██████████| 512/512 [00:15<00:00, 33.29it/s]\n",
      "Last Meta-Episode Trajectories: [38. 26.]: 100%|██████████| 512/512 [00:15<00:00, 33.20it/s]\n",
      "Last Meta-Episode Trajectories: [27. 37.]: 100%|██████████| 512/512 [00:15<00:00, 32.42it/s]\n",
      "Last Meta-Episode Trajectories: [36. 28.]: 100%|██████████| 512/512 [00:15<00:00, 32.85it/s]\n",
      "Last Meta-Episode Trajectories: [34. 30.]: 100%|██████████| 512/512 [00:16<00:00, 31.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training DREST agent with x=1.7782794100389228\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [38. 26.]: 100%|██████████| 512/512 [00:15<00:00, 34.02it/s]\n",
      "Last Meta-Episode Trajectories: [44. 20.]: 100%|██████████| 512/512 [00:15<00:00, 32.45it/s]\n",
      "Last Meta-Episode Trajectories: [30. 34.]: 100%|██████████| 512/512 [00:15<00:00, 33.31it/s]\n",
      "Last Meta-Episode Trajectories: [43. 21.]: 100%|██████████| 512/512 [00:15<00:00, 33.27it/s]\n",
      "Last Meta-Episode Trajectories: [46. 18.]: 100%|██████████| 512/512 [00:16<00:00, 31.62it/s]\n",
      "Last Meta-Episode Trajectories: [35. 29.]: 100%|██████████| 512/512 [00:17<00:00, 28.94it/s]\n",
      "Last Meta-Episode Trajectories: [39. 25.]: 100%|██████████| 512/512 [00:16<00:00, 31.80it/s]\n",
      "Last Meta-Episode Trajectories: [41. 23.]: 100%|██████████| 512/512 [00:18<00:00, 28.22it/s]\n",
      "Last Meta-Episode Trajectories: [38. 26.]: 100%|██████████| 512/512 [00:19<00:00, 26.72it/s]\n",
      "Last Meta-Episode Trajectories: [33. 31.]: 100%|██████████| 512/512 [00:20<00:00, 25.35it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training DREST agent with x=3.1622776601683795\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [44. 20.]: 100%|██████████| 512/512 [00:17<00:00, 29.33it/s]\n",
      "Last Meta-Episode Trajectories: [47. 17.]: 100%|██████████| 512/512 [00:16<00:00, 30.18it/s]\n",
      "Last Meta-Episode Trajectories: [45. 19.]: 100%|██████████| 512/512 [00:17<00:00, 30.11it/s]\n",
      "Last Meta-Episode Trajectories: [36. 28.]: 100%|██████████| 512/512 [00:16<00:00, 31.60it/s]\n",
      "Last Meta-Episode Trajectories: [44. 20.]: 100%|██████████| 512/512 [00:15<00:00, 32.62it/s]\n",
      "Last Meta-Episode Trajectories: [43. 21.]: 100%|██████████| 512/512 [00:15<00:00, 33.18it/s]\n",
      "Last Meta-Episode Trajectories: [43. 21.]: 100%|██████████| 512/512 [00:15<00:00, 33.42it/s]\n",
      "Last Meta-Episode Trajectories: [45. 19.]: 100%|██████████| 512/512 [00:15<00:00, 33.12it/s]\n",
      "Last Meta-Episode Trajectories: [42. 22.]: 100%|██████████| 512/512 [00:15<00:00, 33.47it/s]\n",
      "Last Meta-Episode Trajectories: [46. 18.]: 100%|██████████| 512/512 [00:16<00:00, 30.25it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training DREST agent with x=5.623413251903491\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [45. 19.]: 100%|██████████| 512/512 [00:15<00:00, 32.40it/s]\n",
      "Last Meta-Episode Trajectories: [47. 17.]: 100%|██████████| 512/512 [00:15<00:00, 33.39it/s]\n",
      "Last Meta-Episode Trajectories: [51. 13.]: 100%|██████████| 512/512 [00:15<00:00, 33.17it/s]\n",
      "Last Meta-Episode Trajectories: [47. 17.]: 100%|██████████| 512/512 [00:15<00:00, 32.90it/s]\n",
      "Last Meta-Episode Trajectories: [51. 13.]: 100%|██████████| 512/512 [00:16<00:00, 30.82it/s]\n",
      "Last Meta-Episode Trajectories: [47. 17.]: 100%|██████████| 512/512 [00:15<00:00, 32.47it/s]\n",
      "Last Meta-Episode Trajectories: [54. 10.]: 100%|██████████| 512/512 [00:15<00:00, 33.49it/s]\n",
      "Last Meta-Episode Trajectories: [44. 20.]: 100%|██████████| 512/512 [00:15<00:00, 32.87it/s]\n",
      "Last Meta-Episode Trajectories: [47. 17.]: 100%|██████████| 512/512 [00:15<00:00, 33.54it/s]\n",
      "Last Meta-Episode Trajectories: [50. 14.]: 100%|██████████| 512/512 [00:16<00:00, 31.52it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Training DREST agent with x=10.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [58.  6.]: 100%|██████████| 512/512 [00:15<00:00, 33.50it/s]\n",
      "Last Meta-Episode Trajectories: [48. 16.]: 100%|██████████| 512/512 [00:15<00:00, 33.16it/s]\n",
      "Last Meta-Episode Trajectories: [52. 12.]: 100%|██████████| 512/512 [00:14<00:00, 34.18it/s]\n",
      "Last Meta-Episode Trajectories: [61.  3.]: 100%|██████████| 512/512 [00:15<00:00, 32.75it/s]\n",
      "Last Meta-Episode Trajectories: [56.  8.]: 100%|██████████| 512/512 [00:15<00:00, 33.66it/s]\n",
      "Last Meta-Episode Trajectories: [56.  8.]:  40%|████      | 205/512 [00:06<00:09, 32.75it/s]"
     ]
    }
   ],
   "source": [
    "results = {}\n",
    "\n",
    "DREST = True\n",
    "\n",
    "for i, x in enumerate(10**log_x_list):\n",
    "    print(f'Training DREST agent with x={x}')\n",
    "    time.sleep(0.25)\n",
    "    update_coin_value(x)\n",
    "\n",
    "    DREST_probs = []\n",
    "\n",
    "    for _ in range(10):\n",
    "        agent, meta_episode_histories, traj_probs_history, n_meta_ep_history, prob_history, usefulness_history, entropy_history = train()\n",
    "\n",
    "        DREST_probs.append(np.mean(prob_history[-20:]))\n",
    "        \n",
    "    results[i] = DREST_probs\n",
    "    \n",
    "    \n",
    "DREST = False\n",
    "\n",
    "for i, x in enumerate(10**log_x_list):\n",
    "    print(f'Training Default agent with x={x}')\n",
    "    time.sleep(0.25)\n",
    "    update_coin_value(x)\n",
    "\n",
    "    default_probs = []\n",
    "\n",
    "    for _ in range(10):\n",
    "        agent, meta_episode_histories, traj_probs_history, n_meta_ep_history, prob_history, usefulness_history, entropy_history = train()\n",
    "\n",
    "        default_probs.append(np.mean(prob_history[-20:]))\n",
    "        \n",
    "    results[-i] = default_probs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 252,
   "metadata": {},
   "outputs": [],
   "source": [
    "temp = []\n",
    "for k, v in results.items():\n",
    "    temp.append(v)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 253,
   "metadata": {},
   "outputs": [],
   "source": [
    "temp = np.array(temp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 254,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(29, 10)"
      ]
     },
     "execution_count": 254,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "temp.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 255,
   "metadata": {},
   "outputs": [],
   "source": [
    "# np.save('results/lopsided/results.npy', temp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 250,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{0: [0.00021455575270906417,\n",
       "  0.0003659143501736373,\n",
       "  0.000349632785881566,\n",
       "  0.00022787639034248204,\n",
       "  0.00031552657633356936,\n",
       "  0.0003035520817160515,\n",
       "  0.00030350169104202023,\n",
       "  0.000336228109388131,\n",
       "  0.00024148947423945853,\n",
       "  0.000341125033988975],\n",
       " 1: [0.003589334923858959,\n",
       "  0.0023476319736502665,\n",
       "  0.0028766965034596444,\n",
       "  0.003428571975997492,\n",
       "  0.003335374650285027,\n",
       "  0.004321026763692723,\n",
       "  0.004323750714582314,\n",
       "  0.00460941472372064,\n",
       "  0.004117041691950388,\n",
       "  0.004127765840160982],\n",
       " 2: [0.04109180904991908,\n",
       "  0.018241247282586685,\n",
       "  0.04160853144232653,\n",
       "  0.04365312519806169,\n",
       "  0.028843155944182707,\n",
       "  0.028208175774391532,\n",
       "  0.03460009586714534,\n",
       "  0.017608569802573894,\n",
       "  0.04253042245151824,\n",
       "  0.040995085919427694],\n",
       " 3: [0.11522149025610814,\n",
       "  0.13780385274155232,\n",
       "  0.13570857532427616,\n",
       "  0.12798791810721852,\n",
       "  0.1408800129452572,\n",
       "  0.14460383962201678,\n",
       "  0.14173626262291467,\n",
       "  0.14094657384646817,\n",
       "  0.1381772220387804,\n",
       "  0.1300041578468075],\n",
       " 4: [0.22093441594238902,\n",
       "  0.23193583199014514,\n",
       "  0.235837150704829,\n",
       "  0.22598689107092734,\n",
       "  0.2251780579676556,\n",
       "  0.20697063855165204,\n",
       "  0.21938595102063546,\n",
       "  0.223762825292838,\n",
       "  0.17648327890745835,\n",
       "  0.2208713398962016],\n",
       " 5: [0.28062608739417017,\n",
       "  0.29843947369331353,\n",
       "  0.2822660017900598,\n",
       "  0.315977552022026,\n",
       "  0.3091786530979778,\n",
       "  0.2899968059613215,\n",
       "  0.3163995319297032,\n",
       "  0.30343555425138036,\n",
       "  0.3119337365855538,\n",
       "  0.31544860331156965],\n",
       " 6: [0.35653412133644763,\n",
       "  0.3566683538330991,\n",
       "  0.40618698210982257,\n",
       "  0.3777103588279965,\n",
       "  0.3832764626793411,\n",
       "  0.3981117587136479,\n",
       "  0.3957278170406787,\n",
       "  0.39852537979517555,\n",
       "  0.3839965010836609,\n",
       "  0.3597320029917932],\n",
       " 7: [0.352437036325597,\n",
       "  0.47459059145768895,\n",
       "  0.4554341299238593,\n",
       "  0.4211772259590586,\n",
       "  0.45183173506988333,\n",
       "  0.45435513906930247,\n",
       "  0.4337441947924729,\n",
       "  0.34956434274203213,\n",
       "  0.46348074824268304,\n",
       "  0.47160126334699426],\n",
       " 8: [0.5639322583855455,\n",
       "  0.5467787536964083,\n",
       "  0.5486010800936167,\n",
       "  0.5362391532047954,\n",
       "  0.5566030726125282,\n",
       "  0.548158841948735,\n",
       "  0.5218499828921004,\n",
       "  0.5255820000320809,\n",
       "  0.5495190635759792,\n",
       "  0.5473516964124906],\n",
       " 9: [0.5509161195710071,\n",
       "  0.6355807025214304,\n",
       "  0.6548986154002818,\n",
       "  0.63352407706812,\n",
       "  0.6223566041897393,\n",
       "  0.6284702929275834,\n",
       "  0.6247428833394919,\n",
       "  0.6469179904017337,\n",
       "  0.6462084503212557,\n",
       "  0.6566476763834789],\n",
       " 10: [0.7212215339133243,\n",
       "  0.7521755055788207,\n",
       "  0.7114843795000125,\n",
       "  0.7476621844802269,\n",
       "  0.734256877005394,\n",
       "  0.7083984027495409,\n",
       "  0.7378371799508061,\n",
       "  0.7348973859057958,\n",
       "  0.7337259182295329,\n",
       "  0.5367689719740796],\n",
       " 11: [0.8239728863756068,\n",
       "  0.8331189584276627,\n",
       "  0.7998521697567728,\n",
       "  0.7492927507688818,\n",
       "  0.7771054716262027,\n",
       "  0.8244881082417486,\n",
       "  0.8327751690102568,\n",
       "  0.8196754234453449,\n",
       "  0.8286024253486755,\n",
       "  0.8083689917148147],\n",
       " 12: [0.9296558053061721,\n",
       "  0.9535819622997309,\n",
       "  0.9236406940885669,\n",
       "  0.9431397921015288,\n",
       "  0.9115619456617005,\n",
       "  0.9104299295891899,\n",
       "  0.9115481692246254,\n",
       "  0.9460228746714987,\n",
       "  0.9278447933035414,\n",
       "  0.9128881187486046],\n",
       " 13: [0.9893656219695384,\n",
       "  0.9916136422036163,\n",
       "  0.9716348218878956,\n",
       "  0.9960400267855734,\n",
       "  0.9910875269915506,\n",
       "  0.9642403528590899,\n",
       "  0.9964879530785321,\n",
       "  0.9952625113365666,\n",
       "  0.9949147481188236,\n",
       "  0.996640250803266],\n",
       " 14: [0.9994974427220334,\n",
       "  0.9994169461677849,\n",
       "  0.9984442933783868,\n",
       "  0.9989702043099257,\n",
       "  0.9994453437386142,\n",
       "  0.9984621211564724,\n",
       "  0.9995982010626673,\n",
       "  0.9996797350736608,\n",
       "  0.9988522655358205,\n",
       "  0.9945232154174001],\n",
       " -1: [0.00043253819375000963,\n",
       "  0.0001995794744038191,\n",
       "  0.00033036080032196856,\n",
       "  0.0003155106544997997,\n",
       "  0.0002328594803457676,\n",
       "  0.0003086579127442298,\n",
       "  0.00028021162247696997,\n",
       "  0.0002199693237238504,\n",
       "  0.00040907631687887435,\n",
       "  0.0002398658942232747],\n",
       " -2: [0.0004305790394918844,\n",
       "  0.0003527063106182296,\n",
       "  0.00023835060251516742,\n",
       "  0.00041965941152382615,\n",
       "  0.00029494205679737726,\n",
       "  0.0001627384921623076,\n",
       "  0.0002871860291389668,\n",
       "  0.00015713903056796958,\n",
       "  0.00045322589149635815,\n",
       "  0.00031105677773905034],\n",
       " -3: [0.0003192963663523695,\n",
       "  0.0003323543768375994,\n",
       "  0.0004090061521861402,\n",
       "  0.0005739068078474302,\n",
       "  0.00035886540979061576,\n",
       "  0.0004317505026159344,\n",
       "  0.0004999060193357695,\n",
       "  0.0005074327772181804,\n",
       "  0.0005044689024911606,\n",
       "  0.00038413162996001944],\n",
       " -4: [0.0005557290592374538,\n",
       "  0.00063315061607376,\n",
       "  0.0008448222470715317,\n",
       "  0.00069813225404855,\n",
       "  0.0006150844075034554,\n",
       "  0.0011697049171934593,\n",
       "  0.00032200314584231946,\n",
       "  0.0004405194535022523,\n",
       "  0.0010665677642501072,\n",
       "  0.0007125730494570218],\n",
       " -5: [0.001539344746639788,\n",
       "  0.002234084656319823,\n",
       "  0.0015795308859562005,\n",
       "  0.0016555355530388648,\n",
       "  0.0015832847897099915,\n",
       "  0.0019899758484691653,\n",
       "  0.0017987228795732057,\n",
       "  0.0016033758296357884,\n",
       "  0.0020354745180922364,\n",
       "  0.0015226156695216056],\n",
       " -6: [0.005943581292219292,\n",
       "  0.004182575866929888,\n",
       "  0.0045104066025326685,\n",
       "  0.006147352898503366,\n",
       "  0.005262628192999785,\n",
       "  0.007186002322384281,\n",
       "  0.005240940804213038,\n",
       "  0.0025251915921384793,\n",
       "  0.004165559600490779,\n",
       "  0.004843570439689588],\n",
       " -7: [0.11296169530621376,\n",
       "  0.16707084783417675,\n",
       "  0.027515273062137552,\n",
       "  0.05393677848515467,\n",
       "  0.09981306768121981,\n",
       "  0.22753557414200604,\n",
       "  0.043031980270096595,\n",
       "  0.06502628454652232,\n",
       "  0.14494466394159095,\n",
       "  0.11150741227932356],\n",
       " -8: [0.9636993084133918,\n",
       "  0.9145447006985435,\n",
       "  0.596528447729482,\n",
       "  0.975107179798915,\n",
       "  0.8832877280306578,\n",
       "  0.9698473805121457,\n",
       "  0.8946971347312198,\n",
       "  0.9616223443789205,\n",
       "  0.9724192612179203,\n",
       "  0.9697975883334919],\n",
       " -9: [0.9488432087489203,\n",
       "  0.9720873052727607,\n",
       "  0.9789265490085184,\n",
       "  0.9824828671385584,\n",
       "  0.9403205695169647,\n",
       "  0.9873785633643198,\n",
       "  0.9226239749584082,\n",
       "  0.9742854288823031,\n",
       "  0.9842095221427518,\n",
       "  0.9451093231368409],\n",
       " -10: [0.983342664004019,\n",
       "  0.9942945649062913,\n",
       "  0.9592431065050435,\n",
       "  0.9959647363667891,\n",
       "  0.9933944213745847,\n",
       "  0.9892649031500597,\n",
       "  0.9881403311087231,\n",
       "  0.9728616385616362,\n",
       "  0.9601301836990743,\n",
       "  0.9921169777062824],\n",
       " -11: [0.9585400162168206,\n",
       "  0.9849294278159203,\n",
       "  0.9868028400845409,\n",
       "  0.9979882801923587,\n",
       "  0.998071166140076,\n",
       "  0.994299233069347,\n",
       "  0.9841082300079158,\n",
       "  0.9969528702456593,\n",
       "  0.9969469570999365,\n",
       "  0.9988618513878308],\n",
       " -12: [0.9978036103123582,\n",
       "  0.975201092443948,\n",
       "  0.9975984909895528,\n",
       "  0.9983711637185371,\n",
       "  0.9977644510156845,\n",
       "  0.9970711034437132,\n",
       "  0.9980987830081546,\n",
       "  0.9969813131355412,\n",
       "  0.9966595756828079,\n",
       "  0.9936631486347256],\n",
       " -13: [0.9983341840591944,\n",
       "  0.9997868398741472,\n",
       "  0.999175057673566,\n",
       "  0.9991557369240658,\n",
       "  0.9967665672373714,\n",
       "  0.9895482045649233,\n",
       "  0.9995362441738023,\n",
       "  0.9991207753558868,\n",
       "  0.9994058020294091,\n",
       "  0.997104819269596],\n",
       " -14: [0.9959328782553871,\n",
       "  0.9999039425669741,\n",
       "  0.95762544765132,\n",
       "  0.9990874257182261,\n",
       "  0.9997762985144891,\n",
       "  0.9973179178845545,\n",
       "  0.9998263344890435,\n",
       "  0.9967413171638896,\n",
       "  0.9998959447386477,\n",
       "  0.9997126838550706]}"
      ]
     },
     "execution_count": 250,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 167,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys([('DREST', 0.01), ('DREST', 0.03162277660168379), ('DREST', 0.1), ('DREST', 0.31622776601683794), ('DREST', 1.0), ('DREST', 3.1622776601683795), ('DREST', 10.0), ('DREST', 31.622776601683793), ('DREST', 100.0), ('default', 0.01), ('default', 0.03162277660168379), ('default', 0.1), ('default', 0.31622776601683794), ('default', 1.0), ('default', 3.1622776601683795), ('default', 10.0), ('default', 31.622776601683793), ('default', 100.0)])"
      ]
     },
     "execution_count": 167,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results.keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 236,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Prob. of Collecting Cx')"
      ]
     },
     "execution_count": 236,
     "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": [
    "default_data = []\n",
    "for k, v in results.items():\n",
    "    if k[0] == 'default':\n",
    "        x = k[1]\n",
    "        for y in v:\n",
    "            default_data.append((x, y))\n",
    "        plt.scatter([x]*len(v), v, color='C0')\n",
    "        \n",
    "DREST_data = []\n",
    "for k, v in results.items():\n",
    "    if k[0] == 'DREST':\n",
    "        for y in v:\n",
    "            DREST_data.append((k[1], y))\n",
    "        plt.scatter([k[1]]*len(v), v, color='C1')\n",
    "        \n",
    "plt.xscale('log')\n",
    "plt.ylim(0,1)\n",
    "plt.xlabel('$x$')\n",
    "plt.ylabel('Prob. of Collecting Cx')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 192,
   "metadata": {},
   "outputs": [],
   "source": [
    "X = np.array(DREST_data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 230,
   "metadata": {},
   "outputs": [],
   "source": [
    "from rl_utils import safe_log2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 231,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_log_odds(p):\n",
    "    return safe_log2(p/(1-p))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 233,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/alexroman/anaconda3/lib/python3.7/site-packages/ipykernel_launcher.py:1: RuntimeWarning: divide by zero encountered in true_divide\n",
      "  \"\"\"Entry point for launching an IPython kernel.\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXgAAAD9CAYAAAC2l2x5AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAAALhElEQVR4nO3dXYhcdxmA8ec1adXoUtPs0hSMxlZUYhIUR1IlREGpmF5YL/ykUk1qwOKVUUGoChKkUOoHBi8W8YMoCl5YUGKq9SYasXYiStvkolaw9QM7jYmKuirr60VOa7s7m8yc3ZnZffP8bvac9+yc+S8ZHg5nZzaRmUiS6nnGpBcgSRoNAy9JRRl4SSrKwEtSUQZekopaP+kFPGF6ejq3bt066WVI0ppy8uTJxzNzpt+xVRP4rVu30u12J70MSVpTIuK3Sx3zFo0kFWXgJakoAy9JRRl4SSrKwEtSUQZekooy8JJUlIGXpKIMvCQVZeAlqaiL/qmCiNgDfDIz3xARzwA+DjwMrMvMrw06G92PIEnq56JX8Jl5HHh2s/tu4I+Z+XXgNRGxZYiZJGmMBr1F8+/m617gdLP9EPDGIWaLRMSBiOhGRLfX6w25dEnShQx7D34aONtszwGbh5gtkpmzmdnJzM7MTN+/dilJamnYwPeADc32FHBmiJkkaYyGDfxRYGez/RLgniFmkqQxumjgI2IHcG1EbAe+BVwTEfuAE5n5myFmkqQxisyc9BoA6HQ66f/oJEnDiYiTmdnpd8wPOklSUQZekooy8JJUlIGXpKIMvCQVZeAlqSgDL0lFGXhJKsrAS1JRBl6SijLwklSUgZekogy8JBVl4CWpKAMvSUUZeEkqysBLUlEGXpKKMvCSVJSBl6SiDLwkFWXgJakoAy9JRRl4SSrKwEtSUQZekooy8JJUlIGXpKIMvCQVZeAlqSgDL0lFrW/zoIjYAHwM+AWwC/g08HZgHpgG7szM/0bELQtnK7JqSdJFtb2CfxPweGZ+B3gU2A/sycyvAH8C3hYRWxfOVmC9kqQBtQ38z4H9EfFiYIrzV+kPNcceBPYC1/eZPU1EHIiIbkR0e71ey6VIkvppFfjM/D3weWCW81fnzwXONofngM2cvy2zcLbwPLOZ2cnMzszMTJulSJKW0CrwEXEN8HzgzcDNwGXAhubwFHAG6PWZSZLGpO0tmlcAf87MfwGfAxJ4eXNsG3AMuLvPTJI0Jm0DfxTYEhF7gZcCXwDui4j9wNXANzLzkYWzlViwJGkwrd4mmZlzwEeb3aPN18N9vm/RTJI0Hn7QSZKKMvCSVJSBl6SiDLwkFWXgJakoAy9JRRl4SSrKwEtSUQZekooy8JJUlIGXpKIMvCQVZeAlqSgDL0lFGXhJKsrAS1JRBl6SijLwklSUgZekogy8JBVl4CWpKAMvSUUZeEkqysBLUlEGXpKKMvCSVJSBl6SiDLwkFWXgJakoAy9JRa1v86CICOBm4DHgV8A7m+0rMvNw8z0HF84kSePT9gr+duC+zDwKvAjYlJlHgI0RsSsidi+crdB6JUkDGvoKPiJeC+wCfhcRNwEJnG4OnwL2Apf1md277NVKkgbW5gr+LcCXM/MLwJXAh4GzzbE5YDMw3We2SEQciIhuRHR7vV6LpUiSltLmHvyzgL82298DLgc2NPtTwBnOX9UvnC2SmbPALECn08kWa5EkLaHNFfxPgFc225cBvwZ2NvvbgGPA0T4zSdIYDR34zPw28JyIeCvwQuAOYC4i9gHnMvN4Zp5YOFvRVUuSLqrV2yQz88MLRof6fM+imSRpfPygkyQVZeAlqSgDL0lFGXhJKsrAS1JRBl6SijLwklSUgZekogy8JBVl4CWpKAMvSUUZeEkqysBLUlEGXpKKMvCSVJSBl6SiDLwkFWXgJakoAy9JRRl4SSrKwEtSUQZekooy8JJUlIGXpKIMvCQVZeAlqSgDL0lFGXhJKsrAS1JRBl6SijLwklTU+rYPjIiXAXdm5g0RcRB4DLgiMw83xxfNJEnj0+oKPiKeCVwPPCcidgObMvMIsDEidvWbrdySJUmDaHuL5n3Al5rtvcDpZvtUs99vtkhEHIiIbkR0e71ey6VIkvoZOvAR8Ubgx5n5j2Y0DZxttueAzUvMFsnM2czsZGZnZmZm2KVIki6gzT349wNXRQTAK4DXAfc0x6aAM0ACGxbMJEljNPQVfGa+IzNfn5mvB34J7AZ2Noe3AceAo31mkqQxWvbbJDPzBDAXEfuAc5l5vN9suc8jSRpO67dJAjRX8WTmoT7HFs0kSePjB50kqSgDL0lFGXhJKsrAS1JRBl6SijLwklSUgZekogy8JBVl4CWpKAMvSUUZeEkqysBLUlEGXpKKMvCSVJSBl6SiDLwkFWXgJakoAy9JRRl4SSrKwEtSUQZekooy8JJUlIGXpKIMvCQVZeAlqSgDL0lFGXhJKsrAS1JRBl6SijLwklSUgZekotYP+4CImAK+DLwKOJaZt0bELcA8MA3cmZn/7TdbwXVLki6izRX8dcB7ge3AGyLi1cCezPwK8CfgbRGxdeFsZZYrSRrU0IHPzB9m5t8z8x/AA8Be4KHm8IPN/vV9ZotExIGI6EZEt9frDb14SdLSWt+Db27VPAL8BzjbjOeAzZy/LbNwtkhmzmZmJzM7MzMzbZciSepjOb9kfQ/wCaAHbGhmU8CZJWaSpDFqFfiIuBG4KzP/BvwAeHlzaBtwDLi7z0ySNEZt3kVzK/AR4ExEXA58DrgvIvZz/lbM7Zk5HxFPm63gmiVJAxg68Jn5ReCLA3zf4VYrkiStCD/oJElFGXhJKsrAS1JRBl6SijLwklSUgZekogy8JBVl4CWpKAMvSUUZeEkqysBLUlEGXpKKMvCSVJSBl6SiDLwkFWXgJakoAy9JRRl4SSrKwEtSUQZekooy8JJUlIGXpKIMvCQVZeAlqSgDL0lFGXhJKsrAS1JRBl6SijLwklSUgZekotZPegGTcNtd9/PNex9lPpN1Ebxr1xYO3bhj0suSRsbX/KVppIGPiIPAY8AVmXl4lM81qNvuup+v/+yRJ/fnM5/c9wWvinzNX7pGdosmInYDmzLzCLAxInaN6rmG8c17Hx1qLq11vuYvXaO8B78XON1sn2r2nyYiDkRENyK6vV5vhEv5v/nMoebSWudr/tI1ysBPA2eb7Tlg88JvyMzZzOxkZmdmZmaES/m/dRFDzaW1ztf8pWuUge8BG5rtKeDMCJ9rYO/atWWoubTW+Zq/dI0y8EeBnc32NuDYCJ9rYIdu3MFN173gyauXdRHcdN0L/GWTyvI1f+mKHOF9uIi4DfgD8LzM/MyFvrfT6WS32x3ZWiSpoog4mZmdfsdG+jbJzDw0yvNLkpbmJ1klqSgDL0lFGXhJKsrAS1JRI30XzTAiogecA/7S4uHTwOMruiBdyBW0+3da7VbrzzWJdY36OUdx/pU453LP0fbxy2nYCzOz7ydFV03gASJiNjMPtHhcd6m3CWnltf13Wu1W6881iXWN+jlHcf6VOOdyz7HaGrbabtF8d9IL0ECq/jut1p9rEusa9XOO4vwrcc7lnmNVvYZW1RV8W17BS1rLLpUr+LZmJ70ASVqGkTSsxBW8JGmxKlfwkqQFDLwkFWXgJakoAy9JRZUOfESsj4jPRsS1k16LJA0iIl4VETdExK3LPddI/x78uEXEJ4Arm93fZ+YdEfEXwP98UtJacUtmfiAiPhQR2zPzgbYnKhX4zPzUpNcgScu0rvk6D/xzOSdaM7doImJPRPxowexgRLwnIj64xGPWAVcBV49jjZJ0IQN27KsR8WZgPjMfXs7zrZnAZ+Zx4NlP7EfEbmBTZh4BNkbErj6Pmc/MD2Tmj8e4VEnqa5COZeZPM/P7mXl4uc+3ZgLf+PdTtvcCp5vtU82+JK12Y+vYWgv8U00DZ5vtOWDzBNciSW2MtGNrOfA9YEOzPQWcmeBaJKmNkXZsLQf+KLCz2d4GHJvgWiSpjZF2bM0EPiJ2ANdGxHaAzDwBzEXEPuBc88sLSVq1xt0x/1ywJBW1Zq7gJUnDMfCSVJSBl6SiDLwkFWXgJakoAy9JRRl4SSrKwEtSUf8DAEQ7w4genAUAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(*(X/(1-X)).T)\n",
    "plt.xscale('log')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 166,
   "metadata": {},
   "outputs": [
    {
     "ename": "KeyError",
     "evalue": "0.01",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyError\u001b[0m                                  Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-166-94548f48051e>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mx\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mresults\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mkeys\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      2\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mk\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;34m'DREST'\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 3\u001b[0;31m         \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mresults\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;31mKeyError\u001b[0m: 0.01"
     ]
    }
   ],
   "source": [
    "for k, x in results.keys():\n",
    "    if k == 'DREST':\n",
    "        print(x, results[x])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 161,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0.9999280454423713, 0.9988507416817445]"
      ]
     },
     "execution_count": 161,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "DREST_probs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "metadata": {},
   "outputs": [],
   "source": [
    "# np.save('results/PUE_plot/DREST_0.npy', np.stack([n_meta_ep_history, prob_history, usefulness_history, entropy_history]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "metadata": {},
   "outputs": [],
   "source": [
    "# for i in range(1, 11):\n",
    "#     agent, meta_episode_histories, traj_probs_history,  n_meta_ep_history, prob_history, usefulness_history, entropy_history = train()\n",
    "#     print('Agent Stats: prob_history[-1], usefulness_history[-1], entropy_history[-1]')\n",
    "          \n",
    "#     filename = f'results/PUE_plot/DREST_{i}.npy'\n",
    "#     print('Saving:', filename, '...', end=' ')\n",
    "#     np.save(filename, np.stack([n_meta_ep_history, prob_history, usefulness_history, entropy_history]))\n",
    "#     print('DONE')\n",
    "#     time.sleep(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 144,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Usefulness')"
      ]
     },
     "execution_count": 144,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x144 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "MA = lambda arr: get_moving_average(arr, 4)\n",
    "\n",
    "plt.figure(figsize=[8,2])\n",
    "\n",
    "color='C1'\n",
    "x_max=256\n",
    "\n",
    "plt.subplot(131)\n",
    "plt.plot(MA(n_meta_ep_history), MA(prob_history), color=color)\n",
    "plt.axis([0,x_max, 0,1])\n",
    "plt.hlines(0.5, 0, 2048, 'k', ls='--')\n",
    "plt.xlabel('Meta-Episodes')\n",
    "plt.title('Prob of Delay')\n",
    "\n",
    "plt.subplot(132)\n",
    "plt.plot(MA(n_meta_ep_history), MA(entropy_history), color=color)\n",
    "plt.axis([0,x_max, 0,1])\n",
    "plt.yticks([])\n",
    "plt.xlabel('Meta-Episodes')\n",
    "plt.title('Entropy')\n",
    "plt.savefig('figs/temp2.jpeg', bbox_inches='tight')\n",
    "\n",
    "plt.subplot(133)\n",
    "plt.plot(MA(n_meta_ep_history), MA(usefulness_history), color=color)\n",
    "plt.axis([0,x_max, 0,1])\n",
    "plt.yticks([])\n",
    "plt.xlabel('Meta-Episodes')\n",
    "plt.title('Usefulness')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "metadata": {},
   "outputs": [],
   "source": [
    "# np.save('results/environments/01_example_gridworld/default_agent_logits.npy', agent.logits)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 108,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1.35527492, 0.48049098])"
      ]
     },
     "execution_count": 108,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "evs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Usefulness: 0.5850539082512434\n",
      "Entropy: 0.9973349664979243\n"
     ]
    }
   ],
   "source": [
    "# Compute Transition Matrix\n",
    "transition_matrix = get_transition_matrix(env, agent)\n",
    "\n",
    "# Compute Terminal Distribution\n",
    "terminal_distribution = get_terminal_distribution(env, agent, transition_matrix)\n",
    "\n",
    "# Compute Expected Values (of each trajectory)\n",
    "evs = get_conditional_expected_values(env, agent, terminal_distribution)\n",
    "\n",
    "# Compute probability of each trajectory:\n",
    "# Sum over all but last axis of the terminal distribution\n",
    "axes_to_sum = tuple(range(len(terminal_distribution.shape)-1))\n",
    "trajectory_length_probs = terminal_distribution.sum(axis=axes_to_sum)\n",
    "\n",
    "# Compute metrics we care about:\n",
    "usefulness = (evs / max_coins_by_trajectory) @ trajectory_length_probs\n",
    "print('Usefulness:', usefulness)\n",
    "\n",
    "entropy = compute_entropy(trajectory_length_probs[0])\n",
    "print('Entropy:', entropy)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(0, 0, 0) 0.0\n",
      "(0, 0, 1) 0.0\n",
      "(0, 1, 0) 0.35940666076700184\n",
      "(0, 1, 1) 0.0\n",
      "(1, 0, 0) 0.0\n",
      "(1, 0, 1) 0.2256472474842415\n",
      "(1, 1, 0) 0.17097526412699696\n",
      "(1, 1, 1) 0.24397082762175964\n"
     ]
    }
   ],
   "source": [
    "for i, p in np.ndenumerate(terminal_distribution.sum((0,1))):\n",
    "    print(i,p)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.40818382, 0.59181618])"
      ]
     },
     "execution_count": 106,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "trajectory_length_probs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([2.87684149, 0.10824555])"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "evs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.9626147, 0.0373853])"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "trajectory_length_probs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "def evaluate_agent(env, agent):\n",
    "    # Compute Transition Matrix\n",
    "    transition_matrix = get_transition_matrix(env, agent)\n",
    "\n",
    "    # Compute Terminal Distribution\n",
    "    terminal_distribution = get_terminal_distribution(env, agent, transition_matrix)\n",
    "\n",
    "    # Compute Expected Values (of each trajectory)\n",
    "    evs = get_conditional_expected_values(env, agent, terminal_distribution)\n",
    "\n",
    "    # Compute probability of each trajectory:\n",
    "    # Sum over all but last axis of the terminal distribution\n",
    "    axes_to_sum = tuple(range(len(terminal_distribution.shape)-1))\n",
    "    trajectory_length_probs = terminal_distribution.sum(axis=axes_to_sum)\n",
    "\n",
    "    # Compute metrics we care about:\n",
    "    usefulness = (evs / max_coins_by_trajectory) @ trajectory_length_probs\n",
    "    entropy = compute_entropy(trajectory_length_probs[0])\n",
    "    \n",
    "    return usefulness, entropy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.9143452497636371, 2.1987413702042825e-06)"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "evaluate_agent(env, agent)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.40808245268760207"
      ]
     },
     "execution_count": 51,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "terminal_distribution[:,:,:,:,:,0].sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [],
   "source": [
    "_, distribtion = evaluate_agent(env, agent, transition_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(5, 5, 2, 2)"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "distribtion.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'distribtion' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-109-6404cb8ced7e>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      2\u001b[0m     \u001b[0;32mfor\u001b[0m \u001b[0mj\u001b[0m \u001b[0;32min\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      3\u001b[0m         \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msubplot\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m2\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;36m2\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;36m2\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m+\u001b[0m\u001b[0mj\u001b[0m\u001b[0;34m+\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 4\u001b[0;31m         \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mimshow\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdistribtion\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mj\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mvmin\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mvmax\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0.1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      5\u001b[0m         \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtitle\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34mf'({i},{j})'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      6\u001b[0m         \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcolorbar\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'distribtion' is not defined"
     ]
    },
    {
     "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 i in [0,1]:\n",
    "    for j in [0,1]:\n",
    "        plt.subplot(2,2,2*i+j+1)\n",
    "        plt.imshow(distribtion[:,:,i,j], vmin=0, vmax=0.1)\n",
    "        plt.title(f'({i},{j})')\n",
    "        plt.colorbar()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.47184518, 0.52815482])"
      ]
     },
     "execution_count": 53,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "distribtion.sum(0).sum(0).sum(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7ff2fb405c18>"
      ]
     },
     "execution_count": 57,
     "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.imshow(discount_matrix)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{0: 1, 1: 21, 2: 1, 3: 1}"
      ]
     },
     "execution_count": 66,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "transition_dict[(0,0,0,1)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[1.  , 0.9 , 0.81],\n",
       "       [0.  , 1.  , 0.9 ],\n",
       "       [0.  , 0.  , 1.  ]])"
      ]
     },
     "execution_count": 62,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "get_discount_matrix(3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x7ff2fafdbf28>"
      ]
     },
     "execution_count": 49,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(distribtion.sum(0).sum(0))\n",
    "plt.colorbar()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 502
    },
    "id": "hwlSU2kbHKIa",
    "outputId": "a132aa75-608a-453d-db52-09053d436fe4"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 525x525 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(3.5,3.5), dpi=150)\n",
    "draw_policy(env, agent, (1,1,1,1), subplot_mode=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "F8ksCe4rH91H"
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "colab": {
   "provenance": []
  },
  "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
}
