{
 "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": 62,
   "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": 36,
   "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": 2,
   "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 555x555 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "filename = '01_example_gridworld.pkl'\n",
    "env = load_object(f'{filepath}/{filename}')\n",
    "env.display(display_values=True, dpi=150)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "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": 127,
   "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 = 0.95\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+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": 128,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[1, 2, 3]\n"
     ]
    }
   ],
   "source": [
    "print(list(env.coins.values()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 129,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[1.99026129 1.6290125 ]\n"
     ]
    }
   ],
   "source": [
    "max_coins_by_trajectory     = np.array([3,2])\n",
    "optimal_steps_by_trajectory = np.array([8,4])\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": 130,
   "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: [31. 33.]: 100%|██████████| 2048/2048 [01:59<00:00, 17.13it/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.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 = 1024*64*2\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 % 8 == 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": 133,
   "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": 138,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [37. 27.]:  18%|█▊        | 360/2048 [00:21<01:39, 16.91it/s]Exception ignored in: <function tqdm.__del__ at 0x7fe8d6bc3620>\n",
      "Traceback (most recent call last):\n",
      "  File \"/Users/alexroman/anaconda3/lib/python3.7/site-packages/tqdm/_tqdm.py\", line 883, in __del__\n",
      "    self.close()\n",
      "  File \"/Users/alexroman/anaconda3/lib/python3.7/site-packages/tqdm/_tqdm.py\", line 1088, in close\n",
      "    self._decr_instances(self)\n",
      "  File \"/Users/alexroman/anaconda3/lib/python3.7/site-packages/tqdm/_tqdm.py\", line 439, in _decr_instances\n",
      "    cls._instances.remove(instance)\n",
      "  File \"/Users/alexroman/anaconda3/lib/python3.7/_weakrefset.py\", line 109, in remove\n",
      "    self.data.remove(ref(item))\n",
      "KeyError: <weakref at 0x7fe8c45e43b8; to 'tqdm' at 0x7fe8ddef2400>\n",
      "Exception ignored in: <function tqdm.__del__ at 0x7fe8d6bc3620>\n",
      "Traceback (most recent call last):\n",
      "  File \"/Users/alexroman/anaconda3/lib/python3.7/site-packages/tqdm/_tqdm.py\", line 883, in __del__\n",
      "    self.close()\n",
      "  File \"/Users/alexroman/anaconda3/lib/python3.7/site-packages/tqdm/_tqdm.py\", line 1088, in close\n",
      "    self._decr_instances(self)\n",
      "  File \"/Users/alexroman/anaconda3/lib/python3.7/site-packages/tqdm/_tqdm.py\", line 439, in _decr_instances\n",
      "    cls._instances.remove(instance)\n",
      "  File \"/Users/alexroman/anaconda3/lib/python3.7/_weakrefset.py\", line 109, in remove\n",
      "    self.data.remove(ref(item))\n",
      "KeyError: <weakref at 0x7fe8c45e43b8; to 'tqdm' at 0x7fe8d81db710>\n",
      "Last Meta-Episode Trajectories: [35. 29.]: 100%|██████████| 2048/2048 [01:54<00:00, 17.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Agent Stats: prob_history[-1], usefulness_history[-1], entropy_history[-1]\n",
      "Saving: results/PUE_plot/DREST_1.npy ... DONE\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [34. 30.]: 100%|██████████| 2048/2048 [02:10<00:00, 15.71it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Agent Stats: prob_history[-1], usefulness_history[-1], entropy_history[-1]\n",
      "Saving: results/PUE_plot/DREST_2.npy ... DONE\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [33. 31.]: 100%|██████████| 2048/2048 [02:11<00:00, 15.54it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Agent Stats: prob_history[-1], usefulness_history[-1], entropy_history[-1]\n",
      "Saving: results/PUE_plot/DREST_3.npy ... DONE\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [34. 30.]: 100%|██████████| 2048/2048 [02:14<00:00, 15.23it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Agent Stats: prob_history[-1], usefulness_history[-1], entropy_history[-1]\n",
      "Saving: results/PUE_plot/DREST_4.npy ... DONE\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [30. 34.]: 100%|██████████| 2048/2048 [02:20<00:00, 14.60it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Agent Stats: prob_history[-1], usefulness_history[-1], entropy_history[-1]\n",
      "Saving: results/PUE_plot/DREST_5.npy ... DONE\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [29. 35.]: 100%|██████████| 2048/2048 [01:58<00:00, 17.24it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Agent Stats: prob_history[-1], usefulness_history[-1], entropy_history[-1]\n",
      "Saving: results/PUE_plot/DREST_6.npy ... DONE\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [36. 28.]: 100%|██████████| 2048/2048 [02:00<00:00, 17.01it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Agent Stats: prob_history[-1], usefulness_history[-1], entropy_history[-1]\n",
      "Saving: results/PUE_plot/DREST_7.npy ... DONE\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [34. 30.]: 100%|██████████| 2048/2048 [01:55<00:00, 17.72it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Agent Stats: prob_history[-1], usefulness_history[-1], entropy_history[-1]\n",
      "Saving: results/PUE_plot/DREST_8.npy ... DONE\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [31. 33.]: 100%|██████████| 2048/2048 [02:08<00:00, 15.98it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Agent Stats: prob_history[-1], usefulness_history[-1], entropy_history[-1]\n",
      "Saving: results/PUE_plot/DREST_9.npy ... DONE\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Last Meta-Episode Trajectories: [39. 25.]: 100%|██████████| 2048/2048 [01:59<00:00, 17.20it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Agent Stats: prob_history[-1], usefulness_history[-1], entropy_history[-1]\n",
      "Saving: results/PUE_plot/DREST_10.npy ... DONE\n"
     ]
    }
   ],
   "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": 124,
   "metadata": {},
   "outputs": [
    {
     "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",
    "\n",
    "plt.subplot(131)\n",
    "plt.plot(MA(n_meta_ep_history), MA(prob_history), color=color)\n",
    "plt.axis([0,2048, 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(usefulness_history), color=color)\n",
    "plt.axis([0,2048, 0,1])\n",
    "plt.yticks([])\n",
    "plt.xlabel('Meta-Episodes')\n",
    "plt.title('Usefulness')\n",
    "\n",
    "plt.subplot(133)\n",
    "plt.plot(MA(n_meta_ep_history), MA(entropy_history), color=color)\n",
    "plt.axis([0,2048, 0,1])\n",
    "plt.yticks([])\n",
    "plt.xlabel('Meta-Episodes')\n",
    "plt.title('Entropy')\n",
    "plt.savefig('figs/temp2.jpeg', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "# np.save('results/environments/01_example_gridworld/default_agent_logits.npy', agent.logits)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Usefulness: 0.7682035252315049\n",
      "Entropy: 0.9640897714699534\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": 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": 43,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 8 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
}
