{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "id": "iXbTDY8af3UD"
   },
   "outputs": [],
   "source": [
    "import gym \n",
    "from gym import error, spaces, utils\n",
    "import numpy as np\n",
    "from scipy.stats import sem\n",
    "import matplotlib.pyplot as plt\n",
    "from tqdm import tqdm\n",
    "from copy import deepcopy\n",
    "import math\n",
    "\n",
    "import random\n",
    "from gym.utils import seeding"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "clR8PKlLTnbh"
   },
   "source": [
    "### Goldmining environment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "id": "FrnU2Dddf3UK"
   },
   "outputs": [],
   "source": [
    "class GoldMining(gym.Env):\n",
    "    \n",
    "    def __init__(self, width, height, max_steps = 200, gold_mines = 4, full_grid=False):\n",
    "        self.height = height\n",
    "        self.width = width\n",
    "        self.max_steps = max_steps\n",
    "        self._max_episode_steps = max_steps\n",
    "        self.gold_mines = gold_mines\n",
    "        self.current_steps = 0\n",
    "        self.mines_left = self.gold_mines\n",
    "        self.EMPTY = 0\n",
    "        self.GOLD  = 1\n",
    "        self.AGENT = 2\n",
    "        self.full_grid = full_grid\n",
    "\n",
    "        self.action_space = spaces.Discrete(4)\n",
    "        self.observation_space = spaces.Tuple((\n",
    "                spaces.Discrete(self.width),\n",
    "                spaces.Discrete(self.height)\n",
    "                ))\n",
    "        self.reset()\n",
    "\n",
    "    def checkAction(self, action):\n",
    "        if action == 0:\n",
    "            return \"UP\"\n",
    "        elif action == 1:\n",
    "            return \"DOWN\"\n",
    "        elif action == 2:\n",
    "            return \"LEFT\"\n",
    "        return \"RIGHT\"\n",
    "\n",
    "    def reset(self):\n",
    "        #Initialize all cells to empty\n",
    "        self.grid = [[0 for i in range(self.height)] for j in range(self.width)]\n",
    "        #Set the agent to (0,0) starting position\n",
    "        self.grid[0][0] = self.AGENT\n",
    "        self.state = [0,0]\n",
    "        #Reset the current time step\n",
    "        self.current_steps = 0\n",
    "        self.mines_left = self.gold_mines\n",
    "\n",
    "        #Storing goldmine locations and respective rewards\n",
    "        self.loc_reward = [[0, 0, 0] for i in range(self.gold_mines)] #(i, j, r)\n",
    "\n",
    "        #Setup the gold mines                \n",
    "        goldmine_count = -1\n",
    "        gold_list_1 = [1,1.1,1.2,1.3,1.4,1.5,2,2.1,7.2,9,0,0]\n",
    "        for g in range(len(gold_list_1)):\n",
    "            goldmine_count += 1\n",
    "            self.grid[g][2] = gold_list_1[g]\n",
    "            self.loc_reward[goldmine_count] = [g, 2, gold_list_1[g]]\n",
    "                    \n",
    "        gold_list_2 = [-1,-8,-8,-8,-8,-8,-8,-8,-8,-8,-8,-8]\n",
    "        for g in range(len(gold_list_2)):\n",
    "            goldmine_count += 1\n",
    "            self.grid[g][1] = gold_list_2[g]\n",
    "            self.loc_reward[goldmine_count] = [g, 1, gold_list_2[g]]\n",
    "                    \n",
    "        gold_list_3 = [-1,2.1,2.2,2.3,2.4,2.5,2.6,2.7,2.8,2.9,6]\n",
    "        for g in range(len(gold_list_3)):\n",
    "            goldmine_count += 1\n",
    "            self.grid[g+1][0] = gold_list_3[g]\n",
    "            self.loc_reward[goldmine_count] = [g+1, 0, gold_list_3[g]]\n",
    "   \n",
    "        #print(\"Displaying grid at reset: \\n\", np.flip(np.transpose(np.array(self.grid)), axis=0))\n",
    "                \n",
    "        if self.full_grid:\n",
    "            return np.array(self.grid).flatten()\n",
    "\n",
    "        return self.get_observation(self.state)\n",
    "\n",
    "    def findReward(self, a, b):\n",
    "        #Given the location find if its respective reward or return -1\n",
    "        for i in range(self.gold_mines):\n",
    "            if self.loc_reward[i][0] == a and self.loc_reward[i][1] == b:\n",
    "                return self.loc_reward[i][2]\n",
    "        return -1\n",
    "\n",
    "    def findRewardLocation(self, a, b):\n",
    "        #Given the location, return the index of the gold mine\n",
    "        for i in range(self.gold_mines):\n",
    "            if self.loc_reward[i][0] == a and self.loc_reward[i][1] == b:\n",
    "                return i\n",
    "        return -1\n",
    "\n",
    "    def step(self, action):\n",
    "        self.current_steps = self.current_steps + 1 \n",
    "        \n",
    "        a, b = self.state[0], self.state[1]\n",
    "\n",
    "        if self.checkAction(action) == \"UP\":\n",
    "            #check if reached the end of the grid from top\n",
    "            if (b+1) == self.height:\n",
    "                #return the current state with reward -1\n",
    "                if self.full_grid:\n",
    "                    return np.array(self.grid).flatten(), -1, self.isTerminal(), None\n",
    "                return self.get_observation(self.state), -1, self.isTerminal(), None\n",
    "            else:\n",
    "                #Move up\n",
    "                self.grid[a][b]   = self.EMPTY\n",
    "                self.grid[a][b+1] = self.AGENT\n",
    "                #update b\n",
    "                b = b + 1\n",
    "                self.state[1] = b\n",
    "\n",
    "        elif self.checkAction(action) == \"DOWN\":\n",
    "            #check if reached the end of the grid from bot\n",
    "            if (b-1) < 0:\n",
    "                #return the current state with reward -1\n",
    "                if self.full_grid:\n",
    "                    return np.array(self.grid).flatten(), -1, self.isTerminal(), None\n",
    "                return self.get_observation(self.state), -1, self.isTerminal(), None\n",
    "            else:\n",
    "                #Move down\n",
    "                self.grid[a][b]   = self.EMPTY\n",
    "                self.grid[a][b-1] = self.AGENT\n",
    "                #update b\n",
    "                b = b - 1\n",
    "                self.state[1] = b\n",
    "\n",
    "        elif self.checkAction(action) == \"LEFT\":\n",
    "            #check if reached the end of the grid from left\n",
    "            if (a-1) < 0:\n",
    "                #return the current state with reward -1\n",
    "                if self.full_grid:\n",
    "                    return np.array(self.grid).flatten(), -1, self.isTerminal(), None\n",
    "                return self.get_observation(self.state), -1, self.isTerminal(), None\n",
    "            else:\n",
    "                #Move down\n",
    "                self.grid[a][b]   = self.EMPTY\n",
    "                self.grid[a-1][b] = self.AGENT\n",
    "                #update a\n",
    "                a = a - 1\n",
    "                self.state[0] = a\n",
    "\n",
    "        else:\n",
    "            #check if reached the end of the grid from right\n",
    "            if (a+1) == self.width:\n",
    "                #return the current state with reward -1\n",
    "                if self.full_grid:\n",
    "                    return np.array(self.grid).flatten(), -1, self.isTerminal(), None\n",
    "                return self.get_observation(self.state), -1, self.isTerminal(), None\n",
    "            else:\n",
    "                #Move down\n",
    "                self.grid[a][b]   = self.EMPTY\n",
    "                self.grid[a+1][b] = self.AGENT\n",
    "                #update a\n",
    "                a = a + 1\n",
    "                self.state[0] = a\n",
    "\n",
    "        #Rewards (and their locations) are updated once consumed\n",
    "        r = self.findReward(a, b)\n",
    "        #Update the rewards since consumed\n",
    "        if r > 0:\n",
    "            i = self.findRewardLocation(a, b)\n",
    "            self.loc_reward[i][2] = -1\n",
    "            self.mines_left -=1 \n",
    "\n",
    "        #Convering the state to a 100 dimensional vector\n",
    "        if self.full_grid:\n",
    "            return np.array(self.grid).flatten(), r, self.isTerminal(), None #would be a normal 2D return later\n",
    "        return self.get_observation(self.state), r, self.isTerminal(), None #would be a normal 2D return later\n",
    "\n",
    "    def findAgent(self):\n",
    "        #Find the index of agent's location\n",
    "        for i in range(self.width):\n",
    "            for j in range(self.height):\n",
    "                if self.grid[i][j] == self.AGENT:\n",
    "                    return i, j\n",
    "\n",
    "    def isTerminal(self):\n",
    "        if self.current_steps == self.max_steps:\n",
    "            return True\n",
    "        #Otherwise check if all gold pots collected\n",
    "        if self.mines_left == 0:\n",
    "            return True\n",
    "        return False\n",
    "\n",
    "    def render(self, mode='human'):\n",
    "        print(\"Current Grid Snapshot: \")\n",
    "        print(\"0 denotes EMPTY\")\n",
    "        print(\"1 denotes GOLD\")\n",
    "        print(\"2 denotes AGENT\")\n",
    "        for i in range(self.width):\n",
    "            print(self.grid[i])\n",
    "            \n",
    "    def get_observation(self, state):\n",
    "        return state[1]*self.width + state[0] "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "H3qDOrNFUOD8"
   },
   "source": [
    "### Learning"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "kGTXZKuQTzJh"
   },
   "source": [
    "#### Helper functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "id": "axQPnaBmf3UM"
   },
   "outputs": [],
   "source": [
    "# add arrows to show learned policy\n",
    "def policy_viz(policy, action_dict):\n",
    "    policy = policy.astype(str)\n",
    "    for i in range(policy.shape[0]):\n",
    "        for j in range(policy.shape[1]):\n",
    "            policy[i][j] = action_dict[int(policy[i][j])]\n",
    "    return policy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "id": "dHMZOjoMf3UP"
   },
   "outputs": [],
   "source": [
    "# smoothen curves\n",
    "def smoothen_curves(frames, returns, window_width=30):\n",
    "    frames = np.array(frames)\n",
    "    returns = np.array(returns)\n",
    "    cumsum_vec = np.cumsum(np.insert(returns, 0, 0)) \n",
    "    returns = (cumsum_vec[window_width:] - cumsum_vec[:-window_width]) / window_width\n",
    "    cumsum_vec = np.cumsum(np.insert(frames, 0, 0)) \n",
    "    frames = (cumsum_vec[window_width:] - cumsum_vec[:-window_width]) / window_width\n",
    "    return frames, returns"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "r5rrWHwmT2WI"
   },
   "source": [
    "#### Hyperparameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "id": "eQUJqbS8f3UR"
   },
   "outputs": [],
   "source": [
    "factor = 10\n",
    "\n",
    "experiment = {'w': 12, 'h': 3, 'ts': 11, 'gms': 35}\n",
    "env = GoldMining(width = experiment['w'], height = experiment['h'], max_steps = experiment['ts'], gold_mines = experiment['gms'])\n",
    "action_dict = {0:'>', 1:'<', 2:'^', 3:'v'}\n",
    "action_dict_flipped = {0:'^', 1:'v', 2:'<', 3:'>'}\n",
    "\n",
    "num_episodes = 100000\n",
    "num_actions = 4\n",
    "gamma = 0.99\n",
    "alpha = 0.001\n",
    "\n",
    "#setting the seed for reproducibility\n",
    "np.random.seed(0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "FalMsaLNT5pL"
   },
   "source": [
    "#### Q-learning"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000
    },
    "id": "Frbsl9kGf3UU",
    "outputId": "f1203df7-1c39-471f-f7e6-15a8aa435701"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run =  0\n",
      "Final policy: \n",
      " [['>' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']\n",
      " ['^' '^' '^' 'v' '^' '^' '^' '^' '^' '^' '^' '^']\n",
      " ['>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '^']]\n",
      "Final q values: \n",
      " [[ 8.09036469e-02  1.35274642e+01  1.31831430e+01  2.57734157e+01]\n",
      " [-4.79513409e+00  1.43951295e+01  1.32132624e+01  2.70438542e+01]\n",
      " [-4.33582222e+00  1.35214651e+01  1.35774775e+01  2.51958124e+01]\n",
      " [-8.10287667e-01  1.23937100e+01  1.35442247e+01  2.32280933e+01]\n",
      " [-3.54111488e+00  1.14774404e+01  1.22494169e+01  2.11394882e+01]\n",
      " [-3.05136556e+00  9.79468946e+00  1.11154142e+01  1.89287759e+01]\n",
      " [-2.52132158e+00  8.23015905e+00  9.41751915e+00  1.65947232e+01]\n",
      " [-2.41723410e+00  6.76520510e+00  8.11584923e+00  1.41360840e+01]\n",
      " [-2.52408229e+00  5.17808221e+00  6.69091359e+00  1.15516000e+01]\n",
      " [-2.92465363e+00  3.06348534e+00  4.43947904e+00  8.84000000e+00]\n",
      " [-2.94077966e+00  1.63024814e+00  2.63544733e+00  6.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 2.03747401e+00  7.11860080e-01 -3.04028877e-02 -4.32094132e-01]\n",
      " [ 3.14034035e+00  6.38886155e-01 -2.12748345e-02 -3.63910724e-01]\n",
      " [ 4.14261577e+00  8.32766161e-01 -4.10072710e-01 -2.36606569e-01]\n",
      " [ 2.07307460e-01  1.28683019e+01 -3.98390073e-01 -3.08518273e-01]\n",
      " [ 6.55976953e+00  7.43057129e-01 -2.21324114e-01 -2.39277554e-01]\n",
      " [ 7.56528898e+00  4.78333953e-01 -2.50546018e-01 -3.30357518e-01]\n",
      " [ 8.44070290e+00  4.62677836e-01 -2.04596972e-01 -2.08875062e-01]\n",
      " [ 8.48296475e+00  2.95656128e-01 -2.17110864e-01 -2.49907927e-01]\n",
      " [ 7.05441255e+00  1.81929706e-01 -8.45610453e-02 -1.58569436e-01]\n",
      " [ 3.52070517e+00  8.96030558e-02 -3.81160755e-02 -8.75613174e-02]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-1.26275472e-02 -1.80229742e-02 -1.03550360e-02  3.24293907e+00]\n",
      " [ 8.53032369e-02 -7.49637666e-01  9.94503661e-02  6.16346373e+00]\n",
      " [ 2.54347523e-01 -1.05626694e+00  2.16292836e-01  8.86987720e+00]\n",
      " [ 3.82471056e-01 -5.10108179e-01  2.51535495e-01  1.12877073e+01]\n",
      " [ 7.14432999e-01 -1.18892210e+00  5.15746601e-01  1.41966289e+01]\n",
      " [ 1.01130764e+00 -1.13306815e+00  6.73281971e-01  1.59248697e+01]\n",
      " [ 1.23382369e+00 -1.07388565e+00  1.18437267e+00  1.61151904e+01]\n",
      " [ 1.22930686e+00 -8.78631148e-01  1.13940923e+00  1.53396987e+01]\n",
      " [ 5.27421399e-01 -5.81903146e-01  1.00451630e+00  8.82531077e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]]\n",
      "Run =  1\n",
      "Final policy: \n",
      " [['>' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']\n",
      " ['^' '^' 'v' 'v' '^' 'v' '^' '^' '^' '^' '^' '^']\n",
      " ['>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '^']]\n",
      "Final q values: \n",
      " [[ 7.00247467e-02  1.38578752e+01  1.35582141e+01  2.57734157e+01]\n",
      " [-4.90159788e+00  1.43106258e+01  1.31465304e+01  2.70438542e+01]\n",
      " [-6.30278325e-02  1.40133364e+01  1.47843309e+01  2.51958124e+01]\n",
      " [-2.16891268e-01  1.25611353e+01  1.33727420e+01  2.32280933e+01]\n",
      " [-4.12969102e+00  1.14601802e+01  1.23770303e+01  2.11394882e+01]\n",
      " [-1.54809396e+00  9.87949114e+00  1.10544454e+01  1.89287759e+01]\n",
      " [-3.22198677e+00  8.77573388e+00  1.00043833e+01  1.65947232e+01]\n",
      " [-2.82777957e+00  7.07206855e+00  8.60276872e+00  1.41360840e+01]\n",
      " [-2.77410017e+00  5.23574604e+00  6.65421661e+00  1.15516000e+01]\n",
      " [-2.89402623e+00  3.20153120e+00  4.31907454e+00  8.84000000e+00]\n",
      " [-3.27825769e+00  1.67532808e+00  2.39504553e+00  6.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 1.91387480e+00  4.05393659e-01 -2.18908177e-02 -4.75507484e-01]\n",
      " [ 2.50234973e+00  5.99680490e-01 -1.74159875e-02 -1.83574267e-01]\n",
      " [ 1.08171914e-01  1.42851583e+01 -3.41866996e-01 -2.17430391e-01]\n",
      " [ 1.64161080e-01  1.35879404e+01 -2.08495182e-01 -3.87110613e-01]\n",
      " [ 4.88343749e+00  6.60957173e-01 -1.93349769e-01 -2.48832011e-01]\n",
      " [ 1.98519360e-01  1.04732826e+01 -2.72954273e-01 -3.24365713e-01]\n",
      " [ 6.87929101e+00  2.80240041e-01 -1.97489524e-01 -2.12208096e-01]\n",
      " [ 6.94887487e+00  4.55043692e-01 -1.69999761e-01 -1.84858457e-01]\n",
      " [ 6.53885770e+00  1.07999088e-01 -1.49671301e-01 -1.79387401e-01]\n",
      " [ 3.48219623e+00  7.04690812e-02 -8.40504690e-02 -1.19163629e-01]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-1.04470423e-02 -2.02851346e-02 -1.04184869e-02  2.60925889e+00]\n",
      " [ 4.82992900e-02 -6.47191386e-01  6.86468904e-02  4.07294788e+00]\n",
      " [ 6.87457119e-02 -4.90206945e-01  4.00390657e-02  5.03315715e+00]\n",
      " [ 9.98094285e-02 -5.23178285e-01  6.59552250e-02  6.80243748e+00]\n",
      " [ 2.51361784e-01 -9.83314144e-01  2.14121703e-01  9.76751687e+00]\n",
      " [ 3.51099979e-01 -6.09835101e-01  3.31400544e-01  1.19713124e+01]\n",
      " [ 6.81120916e-01 -8.40583103e-01  5.91529791e-01  1.38097492e+01]\n",
      " [ 7.09777785e-01 -7.07781254e-01  6.96286085e-01  1.42238489e+01]\n",
      " [ 3.80572314e-01 -4.18891239e-01  8.26498208e-01  8.51820636e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]]\n",
      "Run =  2\n",
      "Final policy: \n",
      " [['>' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']\n",
      " ['^' '^' 'v' 'v' '^' '^' '^' '^' '^' '^' '^' '^']\n",
      " ['>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '^']]\n",
      "Final q values: \n",
      " [[ 3.69620970e-02  1.35549705e+01  1.35404865e+01  2.57734157e+01]\n",
      " [-4.85132690e+00  1.40337541e+01  1.32963837e+01  2.70438542e+01]\n",
      " [-1.22138367e-01  1.34431685e+01  1.41596904e+01  2.51958124e+01]\n",
      " [-2.57564664e-01  1.29281948e+01  1.33950538e+01  2.32280933e+01]\n",
      " [-3.98804955e+00  1.10922247e+01  1.26529092e+01  2.11394882e+01]\n",
      " [-3.35875938e+00  1.01124616e+01  1.08903974e+01  1.89287759e+01]\n",
      " [-2.98930333e+00  8.28659320e+00  9.77390777e+00  1.65947232e+01]\n",
      " [-2.54737168e+00  7.15652546e+00  8.03257817e+00  1.41360840e+01]\n",
      " [-2.53543765e+00  5.42896452e+00  6.33896415e+00  1.15516000e+01]\n",
      " [-2.99169345e+00  3.22551842e+00  4.47235660e+00  8.84000000e+00]\n",
      " [-3.09528553e+00  1.72001363e+00  2.51321242e+00  6.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 1.85790061e+00  3.50731064e-01 -2.69936522e-02 -2.95746931e-01]\n",
      " [ 2.37408168e+00  6.89930136e-01 -1.26841964e-02 -2.16183175e-01]\n",
      " [ 1.21486392e-01  1.41779288e+01 -3.26896996e-01 -2.20487474e-01]\n",
      " [ 1.77602187e-01  1.34719850e+01 -1.50975395e-01 -3.47533904e-01]\n",
      " [ 5.46539626e+00  6.30616707e-01 -1.95161332e-01 -2.88378456e-01]\n",
      " [ 6.89630688e+00  4.84197978e-01 -2.55403060e-01 -2.47241067e-01]\n",
      " [ 7.48560596e+00  4.49399730e-01 -2.30009312e-01 -2.20232379e-01]\n",
      " [ 7.96639772e+00  3.19012890e-01 -2.00089747e-01 -2.06453492e-01]\n",
      " [ 6.78837058e+00  1.73376616e-01 -9.71004102e-02 -1.10848060e-01]\n",
      " [ 3.35939730e+00  7.30937221e-02 -1.09867564e-01 -9.54737560e-02]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-1.62933230e-02 -2.03716016e-02 -1.94826525e-02  2.57452119e+00]\n",
      " [ 4.69255253e-02 -6.89979564e-01  7.68187200e-02  4.15084667e+00]\n",
      " [ 4.55488882e-02 -5.03289587e-01  3.45911719e-02  5.43892901e+00]\n",
      " [ 1.19507321e-01 -3.59393166e-01  5.56533212e-02  7.78457825e+00]\n",
      " [ 3.14868513e-01 -9.57910382e-01  2.46381046e-01  1.15345709e+01]\n",
      " [ 5.40194299e-01 -1.05584064e+00  5.32170361e-01  1.41836479e+01]\n",
      " [ 1.03141877e+00 -1.01415590e+00  7.55111061e-01  1.51219535e+01]\n",
      " [ 1.01695799e+00 -7.73468677e-01  8.67863531e-01  1.48723302e+01]\n",
      " [ 4.05358265e-01 -5.58245166e-01  7.25980934e-01  8.70638534e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]]\n",
      "Run =  3\n",
      "Final policy: \n",
      " [['>' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']\n",
      " ['^' '^' 'v' 'v' 'v' '^' '^' '^' '^' '^' '^' '^']\n",
      " ['>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '^']]\n",
      "Final q values: \n",
      " [[ 4.85037165e-02  1.36314167e+01  1.36438721e+01  2.57734157e+01]\n",
      " [-4.89600096e+00  1.46225522e+01  1.34836914e+01  2.70438542e+01]\n",
      " [-2.17222680e-01  1.38046248e+01  1.46756381e+01  2.51958124e+01]\n",
      " [-4.37656020e-01  1.28987185e+01  1.38741990e+01  2.32280933e+01]\n",
      " [-8.44412988e-01  1.16031181e+01  1.26807841e+01  2.11394882e+01]\n",
      " [-3.81739549e+00  1.02628317e+01  1.12428476e+01  1.89287759e+01]\n",
      " [-3.33620049e+00  8.67287849e+00  1.03628548e+01  1.65947232e+01]\n",
      " [-2.94778303e+00  7.06165247e+00  8.18751956e+00  1.41360840e+01]\n",
      " [-2.56655006e+00  5.23606651e+00  6.57985228e+00  1.15516000e+01]\n",
      " [-2.98167126e+00  3.07657402e+00  4.31072747e+00  8.84000000e+00]\n",
      " [-2.98613093e+00  1.68509643e+00  2.48917751e+00  6.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 1.85336877e+00  6.10720466e-01 -2.05952006e-02 -4.69022869e-01]\n",
      " [ 2.32164410e+00  6.35746217e-01 -1.70107107e-02 -1.82773799e-01]\n",
      " [ 1.34853983e-01  1.42008094e+01 -3.21562611e-01 -2.66037723e-01]\n",
      " [ 1.56137157e-01  1.32426873e+01 -1.70444996e-01 -2.79569139e-01]\n",
      " [ 2.08954516e-01  1.20194956e+01 -1.32077100e-01 -3.22122763e-01]\n",
      " [ 5.49102996e+00  6.06966555e-01 -1.95345923e-01 -3.35554973e-01]\n",
      " [ 6.65661434e+00  5.43899878e-01 -2.94698190e-01 -2.35398579e-01]\n",
      " [ 6.97663500e+00  4.75348920e-01 -3.15887106e-01 -1.64920789e-01]\n",
      " [ 7.16822641e+00  1.12994460e-01 -1.37748567e-01 -1.68490469e-01]\n",
      " [ 3.34809915e+00  9.21850923e-02 -7.85836781e-02 -1.27044465e-01]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-1.65871700e-02 -2.55373409e-02 -1.39851434e-02  2.48324521e+00]\n",
      " [ 4.79427568e-02 -8.35249766e-01  9.18218518e-02  3.72995993e+00]\n",
      " [ 4.66058466e-02 -4.50071088e-01  3.05727540e-02  4.39907963e+00]\n",
      " [ 8.36120509e-02 -4.33715048e-01  6.05534984e-02  5.69845329e+00]\n",
      " [ 1.21491469e-01 -4.80864258e-01  8.86137279e-02  8.03666194e+00]\n",
      " [ 3.23431863e-01 -8.33751632e-01  2.76901460e-01  1.15741353e+01]\n",
      " [ 7.08606744e-01 -1.01149175e+00  4.62513944e-01  1.35417317e+01]\n",
      " [ 6.02518123e-01 -6.10874097e-01  5.47112822e-01  1.41358031e+01]\n",
      " [ 3.62961866e-01 -4.80594044e-01  5.33614714e-01  8.52156882e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]]\n",
      "Run =  4\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Final policy: \n",
      " [['>' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']\n",
      " ['^' '^' 'v' 'v' 'v' 'v' '^' '^' '^' '^' '^' '^']\n",
      " ['>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '^']]\n",
      "Final q values: \n",
      " [[ 6.93193308e-02  1.30573810e+01  1.30819577e+01  2.57734157e+01]\n",
      " [-4.91204256e+00  1.44759712e+01  1.35265531e+01  2.70438542e+01]\n",
      " [-9.00384260e-02  1.36321081e+01  1.48259652e+01  2.51958124e+01]\n",
      " [-3.30763175e-01  1.26291317e+01  1.35601753e+01  2.32280933e+01]\n",
      " [-7.53384204e-01  1.13337025e+01  1.27010708e+01  2.11394882e+01]\n",
      " [-1.25097122e+00  1.03435957e+01  1.12948911e+01  1.89287759e+01]\n",
      " [-3.61040779e+00  8.77595754e+00  1.00791757e+01  1.65947232e+01]\n",
      " [-2.99316272e+00  7.06798538e+00  8.40597920e+00  1.41360840e+01]\n",
      " [-2.75343211e+00  5.59024932e+00  6.53973551e+00  1.15516000e+01]\n",
      " [-2.98119275e+00  3.41227671e+00  4.29526600e+00  8.84000000e+00]\n",
      " [-3.03604460e+00  1.66698490e+00  2.42798880e+00  6.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 1.88473358e+00  5.76328544e-01 -2.14703380e-02 -4.73601000e-01]\n",
      " [ 2.31235136e+00  9.13032233e-01 -1.79791918e-02 -1.39173954e-01]\n",
      " [ 1.16843573e-01  1.42288400e+01 -3.04552336e-01 -1.66308908e-01]\n",
      " [ 1.77198928e-01  1.33620920e+01 -2.76868442e-01 -2.65000916e-01]\n",
      " [ 2.33672025e-01  1.23494374e+01 -2.29931101e-01 -2.10865804e-01]\n",
      " [ 2.50377653e-01  1.09919359e+01 -2.01652284e-01 -3.20752594e-01]\n",
      " [ 6.04642302e+00  3.97524113e-01 -1.91864229e-01 -2.27992656e-01]\n",
      " [ 7.03629957e+00  3.05584107e-01 -1.41811756e-01 -2.62467305e-01]\n",
      " [ 6.62366005e+00  1.52439494e-01 -1.36471695e-01 -1.56323936e-01]\n",
      " [ 3.31975467e+00  1.17811044e-01 -1.05071940e-01 -1.42782504e-01]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-1.00379310e-02 -2.32521856e-02 -1.86331795e-02  2.47768081e+00]\n",
      " [ 5.30921206e-02 -7.93798774e-01  8.86789782e-02  3.59331717e+00]\n",
      " [ 5.38088638e-02 -4.74441670e-01  5.10310220e-02  4.03384360e+00]\n",
      " [ 6.27674375e-02 -5.33102300e-01  5.46361329e-02  4.84424541e+00]\n",
      " [ 8.62006860e-02 -4.49901804e-01  7.32229485e-02  6.33690846e+00]\n",
      " [ 7.99783311e-02 -3.87584295e-01  8.18860229e-02  8.84486802e+00]\n",
      " [ 4.00510694e-01 -7.15537626e-01  2.73582761e-01  1.19453818e+01]\n",
      " [ 5.77250265e-01 -4.83329724e-01  4.07577778e-01  1.33730607e+01]\n",
      " [ 2.26441864e-01 -4.27165458e-01  4.67179470e-01  8.29816102e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]]\n",
      "Run =  5\n",
      "Final policy: \n",
      " [['>' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']\n",
      " ['^' '^' '^' 'v' 'v' '^' '^' '^' '^' '^' '^' '^']\n",
      " ['>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '^']]\n",
      "Final q values: \n",
      " [[ 4.68744052e-02  1.37002623e+01  1.34605828e+01  2.57734157e+01]\n",
      " [-4.82400670e+00  1.44932100e+01  1.34116033e+01  2.70438542e+01]\n",
      " [-4.43045927e+00  1.33397239e+01  1.43764718e+01  2.51958124e+01]\n",
      " [-5.10256019e-01  1.25382652e+01  1.31180621e+01  2.32280933e+01]\n",
      " [-1.02415077e+00  1.08914957e+01  1.17646892e+01  2.11394882e+01]\n",
      " [-3.45483931e+00  9.65988870e+00  1.13708537e+01  1.89287759e+01]\n",
      " [-2.88454509e+00  8.40088370e+00  9.77014010e+00  1.65947232e+01]\n",
      " [-2.51017115e+00  7.00565524e+00  8.19645797e+00  1.41360840e+01]\n",
      " [-2.70666526e+00  5.07587484e+00  6.62220807e+00  1.15516000e+01]\n",
      " [-2.99416743e+00  3.19020148e+00  4.13965361e+00  8.84000000e+00]\n",
      " [-2.96602522e+00  1.62811968e+00  2.60807601e+00  6.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 1.95466573e+00  5.13217467e-01 -2.51313672e-02 -5.10776755e-01]\n",
      " [ 2.99184874e+00  7.46351498e-01 -1.50158237e-02 -3.61567630e-01]\n",
      " [ 3.80250100e+00  6.36394163e-01 -3.05152319e-01 -1.63742767e-01]\n",
      " [ 2.35399842e-01  1.32555605e+01 -4.19231765e-01 -3.03147177e-01]\n",
      " [ 2.07228726e-01  1.18465151e+01 -2.15409496e-01 -2.79789482e-01]\n",
      " [ 6.56653565e+00  6.18677509e-01 -2.51216653e-01 -2.53488606e-01]\n",
      " [ 7.72315199e+00  3.62145058e-01 -2.00365759e-01 -2.12447156e-01]\n",
      " [ 7.97768738e+00  2.93492956e-01 -1.81212424e-01 -1.85088732e-01]\n",
      " [ 6.59433258e+00  1.61516970e-01 -8.21660665e-02 -1.57075322e-01]\n",
      " [ 3.57525221e+00  4.65589086e-02 -1.24694504e-01 -1.27044465e-01]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-9.23104578e-03 -2.70743973e-02 -1.66082206e-02  3.00684271e+00]\n",
      " [ 7.12945104e-02 -7.50487230e-01  9.96753287e-02  5.44912335e+00]\n",
      " [ 1.76264897e-01 -9.93611963e-01  2.01117943e-01  7.53223637e+00]\n",
      " [ 2.75506512e-01 -6.33757684e-01  2.32815839e-01  9.35185490e+00]\n",
      " [ 3.77898645e-01 -5.32069166e-01  2.11032465e-01  1.17386432e+01]\n",
      " [ 6.39956480e-01 -9.65553886e-01  5.86417166e-01  1.43257831e+01]\n",
      " [ 8.34985796e-01 -9.87345104e-01  8.18790276e-01  1.52284236e+01]\n",
      " [ 8.48859804e-01 -7.54576515e-01  9.87151645e-01  1.49374650e+01]\n",
      " [ 4.97949628e-01 -5.52390096e-01  7.23795929e-01  8.72459680e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]]\n",
      "Run =  6\n",
      "Final policy: \n",
      " [['>' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']\n",
      " ['^' '^' 'v' '^' '^' 'v' '^' '^' '^' '^' '^' '^']\n",
      " ['>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '^']]\n",
      "Final q values: \n",
      " [[ 3.25440706e-02  1.35376053e+01  1.36325255e+01  2.57734157e+01]\n",
      " [-4.86069387e+00  1.45312474e+01  1.37619678e+01  2.70438542e+01]\n",
      " [-1.35693982e-02  1.36499529e+01  1.48161960e+01  2.51958124e+01]\n",
      " [-4.27479297e+00  1.22528657e+01  1.35717270e+01  2.32280933e+01]\n",
      " [-3.78270517e+00  1.12584527e+01  1.20002646e+01  2.11394882e+01]\n",
      " [-1.43912884e+00  1.00644339e+01  1.13901217e+01  1.89287759e+01]\n",
      " [-3.03782656e+00  9.12514678e+00  1.00355423e+01  1.65947232e+01]\n",
      " [-2.59912784e+00  7.10055064e+00  7.98736947e+00  1.41360840e+01]\n",
      " [-2.62283914e+00  5.37133337e+00  6.67263027e+00  1.15516000e+01]\n",
      " [-3.04396719e+00  3.25189467e+00  4.16566277e+00  8.84000000e+00]\n",
      " [-2.97608813e+00  1.68935727e+00  2.58460291e+00  6.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 1.89610596e+00  4.98093009e-01 -2.08863639e-02 -5.20274885e-01]\n",
      " [ 2.66837013e+00  9.51094751e-01 -1.18170073e-02 -2.17880327e-01]\n",
      " [ 1.61622854e-01  1.42878018e+01 -4.17422044e-01 -3.15488210e-01]\n",
      " [ 4.67758363e+00  7.27611466e-01 -2.99358991e-01 -3.90584074e-01]\n",
      " [ 5.62131342e+00  6.57256091e-01 -3.16007965e-01 -1.97181126e-01]\n",
      " [ 2.32065179e-01  1.06445348e+01 -2.85169947e-01 -3.00938710e-01]\n",
      " [ 7.26665271e+00  5.01243845e-01 -1.61388635e-01 -2.95412940e-01]\n",
      " [ 7.93485754e+00  3.64865665e-01 -1.89150545e-01 -1.53672260e-01]\n",
      " [ 6.77653260e+00  2.44834001e-01 -1.28788302e-01 -1.42939323e-01]\n",
      " [ 3.60771943e+00  7.24679407e-02 -8.24934829e-02 -1.50639721e-01]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-1.38760063e-02 -3.25596563e-02 -1.13919767e-02  2.79687891e+00]\n",
      " [ 4.33543562e-02 -7.43281169e-01  6.79022843e-02  4.91559190e+00]\n",
      " [ 6.90890578e-02 -5.46745291e-01  5.89271525e-02  6.79713081e+00]\n",
      " [ 3.49765317e-01 -9.63421366e-01  2.29397599e-01  9.89087516e+00]\n",
      " [ 4.87376221e-01 -1.06616311e+00  4.66022720e-01  1.24042650e+01]\n",
      " [ 7.80113931e-01 -7.46659469e-01  5.39300919e-01  1.41094920e+01]\n",
      " [ 8.41695061e-01 -8.31709722e-01  7.27167608e-01  1.50630746e+01]\n",
      " [ 9.01137084e-01 -6.75844706e-01  9.09701536e-01  1.48453618e+01]\n",
      " [ 4.78049139e-01 -6.18811227e-01  7.86281815e-01  8.69561717e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]]\n",
      "Run =  7\n",
      "Final policy: \n",
      " [['>' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']\n",
      " ['^' '^' 'v' 'v' '^' 'v' '^' '^' '^' '^' '^' '^']\n",
      " ['>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '^']]\n",
      "Final q values: \n",
      " [[ 3.98291486e-02  1.30591828e+01  1.35965130e+01  2.57734157e+01]\n",
      " [-4.91843365e+00  1.45861151e+01  1.35000654e+01  2.70438542e+01]\n",
      " [-3.05194600e-02  1.37815008e+01  1.48023036e+01  2.51958124e+01]\n",
      " [-4.19300319e-01  1.25143772e+01  1.32723332e+01  2.32280933e+01]\n",
      " [-4.09573711e+00  1.16811944e+01  1.25259180e+01  2.11394882e+01]\n",
      " [-1.33464161e+00  1.02181172e+01  1.13078427e+01  1.89287759e+01]\n",
      " [-3.36924588e+00  8.86294935e+00  9.98754338e+00  1.65947232e+01]\n",
      " [-2.78198944e+00  7.14514902e+00  8.33147173e+00  1.41360840e+01]\n",
      " [-2.79994619e+00  5.50203460e+00  6.69251045e+00  1.15516000e+01]\n",
      " [-2.89080541e+00  3.37183230e+00  4.50985945e+00  8.84000000e+00]\n",
      " [-3.04100856e+00  1.67112559e+00  2.32058376e+00  6.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 1.85969210e+00  5.64451643e-01 -2.51202847e-02 -5.86514398e-01]\n",
      " [ 2.54992788e+00  8.12840323e-01 -2.05662235e-02 -1.70570378e-01]\n",
      " [ 1.62332137e-01  1.42993484e+01 -3.91250356e-01 -1.84429938e-01]\n",
      " [ 1.46115134e-01  1.33071728e+01 -1.77703445e-01 -3.43204576e-01]\n",
      " [ 4.67170286e+00  3.51121742e-01 -2.15683914e-01 -2.07147086e-01]\n",
      " [ 2.39201570e-01  1.07562531e+01 -3.37357988e-01 -2.86493695e-01]\n",
      " [ 6.64129740e+00  4.69622840e-01 -2.82147162e-01 -2.52779482e-01]\n",
      " [ 7.43486765e+00  2.85181555e-01 -2.01553293e-01 -1.86507398e-01]\n",
      " [ 6.56220138e+00  2.09500555e-01 -1.40167253e-01 -1.98241111e-01]\n",
      " [ 3.37630219e+00  4.27497514e-02 -4.30204902e-02 -1.19163629e-01]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-1.17718022e-02 -2.21641324e-02  2.14061681e-03  2.56561073e+00]\n",
      " [ 4.42004656e-02 -1.01536376e+00  4.97993677e-02  4.09379169e+00]\n",
      " [ 7.83154188e-02 -4.22493833e-01  6.56210786e-02  5.07328338e+00]\n",
      " [ 1.22887480e-01 -4.21658208e-01  7.32996536e-02  6.83006561e+00]\n",
      " [ 3.10479048e-01 -8.88240612e-01  2.70046629e-01  9.71323423e+00]\n",
      " [ 3.71108902e-01 -6.01648964e-01  2.36690841e-01  1.19304219e+01]\n",
      " [ 6.11014511e-01 -8.55409404e-01  4.91397727e-01  1.37904286e+01]\n",
      " [ 7.78202238e-01 -6.67039708e-01  5.33595384e-01  1.42680674e+01]\n",
      " [ 2.54046133e-01 -5.56366874e-01  5.85263189e-01  8.54718445e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]]\n",
      "Run =  8\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Final policy: \n",
      " [['>' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']\n",
      " ['^' '^' 'v' 'v' '^' '^' '^' '^' '^' '^' '^' '^']\n",
      " ['>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '^']]\n",
      "Final q values: \n",
      " [[ 5.45468032e-02  1.36331077e+01  1.37195404e+01  2.57734157e+01]\n",
      " [-4.96148101e+00  1.43854437e+01  1.29544273e+01  2.70438542e+01]\n",
      " [-2.08894699e-02  1.34241507e+01  1.41917547e+01  2.51958124e+01]\n",
      " [-7.74400332e-01  1.27380523e+01  1.39260078e+01  2.32280933e+01]\n",
      " [-3.97743155e+00  1.11924902e+01  1.25462052e+01  2.11394882e+01]\n",
      " [-3.39309501e+00  9.88424153e+00  1.12480961e+01  1.89287759e+01]\n",
      " [-2.96022286e+00  8.60810364e+00  9.37904033e+00  1.65947232e+01]\n",
      " [-2.66126707e+00  6.89650935e+00  8.30342006e+00  1.41360840e+01]\n",
      " [-2.59611852e+00  5.21299927e+00  6.65852612e+00  1.15516000e+01]\n",
      " [-2.95334023e+00  3.23865532e+00  4.36834833e+00  8.84000000e+00]\n",
      " [-2.78662521e+00  1.64456675e+00  2.40430977e+00  6.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 1.88787380e+00  6.53251527e-01 -2.76556516e-02 -3.32158663e-01]\n",
      " [ 2.48938430e+00  6.39042376e-01 -1.78824814e-02 -2.11799069e-01]\n",
      " [ 1.06317419e-01  1.43684045e+01 -3.86927652e-01 -1.93672774e-01]\n",
      " [ 2.04722805e-01  1.27128226e+01 -1.96506819e-01 -3.16860764e-01]\n",
      " [ 5.32570618e+00  5.97887052e-01 -2.29097837e-01 -3.76422716e-01]\n",
      " [ 6.77068662e+00  5.56941287e-01 -3.86494817e-01 -2.98375278e-01]\n",
      " [ 7.53041799e+00  4.67636214e-01 -2.40702961e-01 -2.43739053e-01]\n",
      " [ 7.66605881e+00  2.70575639e-01 -1.99961042e-01 -1.76043783e-01]\n",
      " [ 6.90392876e+00  2.65612472e-01 -4.31405212e-02 -1.96169817e-01]\n",
      " [ 3.48771403e+00  1.00091959e-01 -8.56866550e-02 -9.54737560e-02]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-1.73515607e-02 -1.94125313e-02 -1.19702950e-02  2.63210785e+00]\n",
      " [ 4.11724176e-02 -8.64495079e-01  7.54874018e-02  4.23399096e+00]\n",
      " [ 9.16292513e-02 -3.49044431e-01  4.14196969e-02  5.47216878e+00]\n",
      " [ 1.26193994e-01 -4.59843060e-01  5.66569462e-02  7.76080579e+00]\n",
      " [ 3.40400865e-01 -8.59676972e-01  3.20458044e-01  1.14335820e+01]\n",
      " [ 6.76089811e-01 -1.13910492e+00  5.62931431e-01  1.41064493e+01]\n",
      " [ 6.98846529e-01 -1.03518772e+00  7.19419092e-01  1.51279045e+01]\n",
      " [ 9.70497618e-01 -7.61938417e-01  6.68072949e-01  1.48914461e+01]\n",
      " [ 4.98894257e-01 -5.22548950e-01  7.92655571e-01  8.71191410e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]]\n",
      "Run =  9\n",
      "Final policy: \n",
      " [['>' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']\n",
      " ['^' '^' '^' '^' '^' 'v' '^' '^' '^' '^' '^' '^']\n",
      " ['>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '^']]\n",
      "Final q values: \n",
      " [[ 1.45838889e-01  1.36038102e+01  1.31365987e+01  2.57734157e+01]\n",
      " [-4.69721388e+00  1.42969846e+01  1.28436739e+01  2.70438542e+01]\n",
      " [-4.12644956e+00  1.30919913e+01  1.37654178e+01  2.51958124e+01]\n",
      " [-3.77797209e+00  1.20366120e+01  1.30526999e+01  2.32280933e+01]\n",
      " [-3.31064484e+00  1.06600494e+01  1.18243632e+01  2.11394882e+01]\n",
      " [-1.46741795e+00  9.70930321e+00  1.07698077e+01  1.89287759e+01]\n",
      " [-2.59791013e+00  8.39312290e+00  9.53429484e+00  1.65947232e+01]\n",
      " [-2.42085233e+00  6.74847431e+00  8.20219341e+00  1.41360840e+01]\n",
      " [-2.60105638e+00  5.50698003e+00  6.56466643e+00  1.15516000e+01]\n",
      " [-2.98571146e+00  3.22846854e+00  4.20892326e+00  8.84000000e+00]\n",
      " [-2.97608813e+00  1.57450774e+00  2.42567620e+00  6.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 2.18639090e+00  5.06835532e-01 -2.31366076e-02 -4.45055455e-01]\n",
      " [ 3.42232504e+00  8.81705695e-01 -6.51663907e-03 -4.29789397e-01]\n",
      " [ 4.72324125e+00  7.24667189e-01 -3.31090777e-01 -3.52667977e-01]\n",
      " [ 5.82017708e+00  7.05853282e-01 -3.80350651e-01 -3.38461647e-01]\n",
      " [ 6.87161386e+00  4.95539396e-01 -2.97300217e-01 -1.53047918e-01]\n",
      " [ 3.74337062e-01  1.05348257e+01 -3.46105948e-01 -2.66212901e-01]\n",
      " [ 8.29101070e+00  5.56662688e-01 -1.87303180e-01 -1.54184761e-01]\n",
      " [ 8.20564452e+00  3.66412294e-01 -1.40165087e-01 -2.01722403e-01]\n",
      " [ 6.61660706e+00  1.41233995e-01 -1.36984704e-01 -1.25169499e-01]\n",
      " [ 3.29126804e+00  1.44033700e-01 -4.62035174e-02 -1.19163629e-01]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-1.73197046e-02 -2.19889702e-02 -8.27064719e-03  3.55528735e+00]\n",
      " [ 1.28319680e-01 -8.33518348e-01  1.11155373e-01  6.90458860e+00]\n",
      " [ 2.72868003e-01 -1.07594733e+00  2.76598737e-01  1.01091048e+01]\n",
      " [ 6.11991511e-01 -1.27509745e+00  5.47779257e-01  1.28300706e+01]\n",
      " [ 9.25194269e-01 -1.24471691e+00  8.74195606e-01  1.48115676e+01]\n",
      " [ 1.00255715e+00 -8.74580095e-01  7.99565563e-01  1.59124398e+01]\n",
      " [ 1.31733655e+00 -1.03748957e+00  8.88054314e-01  1.60900919e+01]\n",
      " [ 1.21214206e+00 -7.24669185e-01  1.21280217e+00  1.52970419e+01]\n",
      " [ 7.40393631e-01 -5.80903990e-01  1.03874649e+00  8.80712196e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]]\n"
     ]
    }
   ],
   "source": [
    "# q-learning\n",
    "\n",
    "q_returns_over_runs = []\n",
    "q_max_rewards_over_runs = []\n",
    "q_final_policy_over_runs = []\n",
    "q_final_q_values_over_runs = []\n",
    "num_runs = 10\n",
    "\n",
    "for run in range(num_runs):\n",
    "    print(\"Run = \", str(run))\n",
    "    q = np.zeros((experiment['w']*experiment['h'],num_actions))\n",
    "    episode_returns = []\n",
    "    episode_max_rewards = []\n",
    "    epsilon_schedule = np.concatenate((np.linspace(0.2,0,int(num_episodes*experiment['ts']/2)),np.array([0]*(int(num_episodes*experiment['ts']/2)+1))))\n",
    "    timesteps = 0\n",
    "\n",
    "    for episode in range(num_episodes):\n",
    "        obs = env.reset()\n",
    "        episode_return = 0\n",
    "        episode_max_reward = -100\n",
    "        done = False\n",
    "        while done != True:\n",
    "            timesteps += 1\n",
    "            prev_obs = deepcopy(obs)\n",
    "            a = np.argmax(q[obs])\n",
    "            if np.random.rand()<epsilon_schedule[timesteps]:\n",
    "                #if np.random.rand()<0.1:\n",
    "                a = np.random.randint(num_actions)\n",
    "                #print(\"random action taken\")\n",
    "            obs, r, done, info = env.step(a)\n",
    "            q[prev_obs,a] = q[prev_obs,a] + alpha*(r+gamma*max(q[obs]) - q[prev_obs,a])\n",
    "            episode_return += r\n",
    "            episode_max_reward = max(r, episode_max_reward)\n",
    "            #print(prev_obs,action_dict[a])\n",
    "\n",
    "        episode_returns.append(episode_return)\n",
    "        episode_max_rewards.append(episode_max_reward)\n",
    "        #if episode%1000==0:\n",
    "        #    print(\"Episode \", str(episode), \" ended with return = \", str(episode_return))\n",
    "        #    policy = np.reshape(np.argmax(q,axis=1), (-1, experiment['w']))\n",
    "        #    print(\"Policy: \\n\", policy_viz(np.transpose(policy), action_dict))\n",
    "\n",
    "    policy = np.reshape(np.argmax(q,axis=1), (-1, experiment['w']))\n",
    "    print(\"Final policy: \\n\", np.flip(policy_viz(policy, action_dict_flipped), axis=0))\n",
    "    q_final_policy_over_runs.append(np.flip(policy_viz(policy, action_dict_flipped), axis=0))\n",
    "    #print(\"Final policy: \\n\", policy_viz(np.transpose(policy), action_dict))\n",
    "    print(\"Final q values: \\n\", q)\n",
    "    q_final_q_values_over_runs.append(q)\n",
    "\n",
    "    episodes, returns = smoothen_curves(np.arange(0,num_episodes,1), episode_returns)\n",
    "    q_returns_over_runs.append(returns)\n",
    "    \n",
    "    dummy, max_rewards = smoothen_curves(np.arange(0,num_episodes,1), episode_max_rewards)\n",
    "    q_max_rewards_over_runs.append(max_rewards)\n",
    "    \n",
    "    #plt.plot(episodes, returns, label = 'q')\n",
    "    #plt.legend()\n",
    "    #plt.ylim(min(returns)-10,max(returns)+10)\n",
    "    #plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "awyMts1tT98m"
   },
   "source": [
    "#### Max-Q"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000
    },
    "id": "yLnrSU4Cf3UX",
    "outputId": "98be5d6e-7e09-4306-82a0-7c1dff30fc66"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run =  0\n",
      "Final policy: \n",
      " [['>' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']\n",
      " ['^' '^' '^' 'v' '^' 'v' 'v' 'v' '^' '^' '^' '^']\n",
      " ['^' '>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '^']]\n",
      "Final q values: \n",
      " [[8.13943868e+00 4.07938515e+00 4.05640950e+00 8.24054838e-01]\n",
      " [1.12904322e-01 4.96968569e-02 1.73466844e-01 1.56411895e+00]\n",
      " [9.16384178e-02 4.41060960e-02 5.12552811e-02 1.63527439e+00]\n",
      " [7.05982818e-02 1.36859541e-01 1.23372117e-01 2.10602442e+00]\n",
      " [1.24789900e-01 1.17437648e-01 1.24478263e-01 2.16592756e+00]\n",
      " [6.88494888e-02 1.37462650e-01 1.19162376e-01 2.33080632e+00]\n",
      " [5.24235718e-02 9.29672856e-02 1.44786924e-01 2.41672727e+00]\n",
      " [1.04512029e-02 3.02120892e-02 4.72991622e-02 1.75919916e+00]\n",
      " [3.24617537e-03 3.11783211e-02 2.72393004e-02 1.65621076e+00]\n",
      " [3.65469085e-03 1.10864624e-02 1.59890465e-02 1.33732120e+00]\n",
      " [0.00000000e+00 1.45287732e-02 2.40608406e-03 2.05460203e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [8.22165523e+00 3.90550123e+00 4.25644984e+00 2.52442287e+00]\n",
      " [6.43105612e+00 7.76067458e-02 3.08886583e-01 1.19862811e-01]\n",
      " [4.89325050e+00 7.54910692e-02 9.74804365e-02 4.83034475e-02]\n",
      " [3.11780017e-01 1.58773542e+00 5.86502465e-02 6.08592366e-02]\n",
      " [4.96517360e+00 1.05789403e-01 3.05888996e-02 3.28082450e-02]\n",
      " [2.66473344e-01 1.57126552e+00 7.23796956e-02 2.15316206e-02]\n",
      " [1.39382656e-01 1.29305622e+00 2.65061897e-02 6.30449818e-03]\n",
      " [1.15787868e-01 9.59853098e-01 8.22544889e-03 1.92106683e-03]\n",
      " [2.01840361e-01 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [2.04738860e-01 0.00000000e+00 1.20635695e-04 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [4.36604369e+00 4.16502941e+00 4.31162479e+00 8.30470225e+00]\n",
      " [4.65150209e+00 2.67616549e+00 4.33340148e+00 8.38858813e+00]\n",
      " [4.93096375e+00 1.94622175e+00 4.60683909e+00 8.47332134e+00]\n",
      " [4.67593462e+00 7.99761862e-01 4.55358553e+00 8.55891045e+00]\n",
      " [4.93286081e+00 1.95349093e+00 4.83579957e+00 8.64536409e+00]\n",
      " [4.95888986e+00 7.11233800e-01 5.02140669e+00 8.73269100e+00]\n",
      " [4.71205810e+00 4.88924798e-01 4.66497548e+00 8.82090000e+00]\n",
      " [3.91657349e+00 2.52083310e-01 3.89885147e+00 8.91000000e+00]\n",
      " [3.25331273e+00 6.05921960e-02 3.16270225e+00 9.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]]\n",
      "Run =  1\n",
      "Final policy: \n",
      " [['>' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']\n",
      " ['^' '^' '^' 'v' 'v' 'v' '^' '^' '^' '^' '^' '^']\n",
      " ['^' '>' '>' '<' '>' '>' '>' '^' '^' '^' '^' '^']]\n",
      "Final q values: \n",
      " [[8.13943868e+00 4.07963685e+00 4.14686684e+00 8.39071474e-01]\n",
      " [1.40265322e-01 4.53689343e-02 2.22788279e-01 1.56375899e+00]\n",
      " [3.30190131e-01 1.77362216e-01 1.83487609e-01 1.51401978e+00]\n",
      " [1.57473956e-01 1.54225841e-01 1.49812143e+00 4.48094280e-01]\n",
      " [3.77940658e-02 2.82421032e-02 1.00544478e-01 1.66477542e+00]\n",
      " [2.91953450e-02 6.67528310e-02 7.88452090e-02 2.01238717e+00]\n",
      " [5.92265727e-02 2.81431259e-02 4.40736025e-02 1.76660462e+00]\n",
      " [8.23403879e-02 9.24778871e-06 2.47025705e-03 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [8.22165523e+00 3.91374242e+00 3.98433137e+00 2.43527892e+00]\n",
      " [6.28364057e+00 6.57008241e-02 3.79052496e-01 1.39388070e-01]\n",
      " [4.87645664e+00 9.65148650e-02 9.87497311e-02 3.75576219e-02]\n",
      " [2.72237017e-01 1.56291017e+00 6.78522531e-02 3.93093628e-02]\n",
      " [1.72972232e-01 1.55877736e+00 3.40527774e-02 2.62375795e-02]\n",
      " [1.73479175e-01 1.52093690e+00 2.36581486e-02 4.26104168e-02]\n",
      " [3.65869510e+00 3.97013955e-02 2.11825563e-02 2.23363744e-02]\n",
      " [3.60046290e+00 4.12471349e-02 8.70884159e-03 2.38480345e-04]\n",
      " [1.47714099e-02 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [4.44481540e+00 4.19011463e+00 4.27452968e+00 8.30470225e+00]\n",
      " [4.52019325e+00 2.50606707e+00 4.46111583e+00 8.38858813e+00]\n",
      " [4.79898213e+00 1.85501322e+00 4.66690470e+00 8.47332134e+00]\n",
      " [4.91588308e+00 7.91637771e-01 4.57499403e+00 8.55891045e+00]\n",
      " [4.97596376e+00 7.38328221e-01 4.65617693e+00 8.64536409e+00]\n",
      " [4.93134466e+00 6.68458754e-01 4.65767994e+00 8.73269100e+00]\n",
      " [4.69939291e+00 1.13603217e+00 4.70238670e+00 8.82090000e+00]\n",
      " [4.17352420e+00 9.91625816e-01 3.78352905e+00 8.91000000e+00]\n",
      " [3.00061637e+00 4.94453101e-03 2.96678052e+00 9.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]]\n",
      "Run =  2\n",
      "Final policy: \n",
      " [['>' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']\n",
      " ['^' '^' '^' 'v' 'v' '^' 'v' 'v' '^' '^' '^' '^']\n",
      " ['^' '>' '>' '<' '<' '^' '>' '^' '^' '^' '^' '^']]\n",
      "Final q values: \n",
      " [[8.13943868e+00 4.05268667e+00 4.12358637e+00 8.34803448e-01]\n",
      " [9.30055000e-02 4.76279403e-02 2.10529614e-01 1.57513749e+00]\n",
      " [4.05924087e-01 2.13706163e-01 1.99923724e-01 1.68444005e+00]\n",
      " [1.74665157e-01 2.24418881e-01 1.70738998e+00 4.84720686e-01]\n",
      " [4.17233171e-02 4.45392737e-02 1.43522587e+00 1.01062125e-01]\n",
      " [1.07639429e-01 5.44945161e-06 2.49312760e-03 7.49250250e-03]\n",
      " [6.98438429e-03 5.97423897e-03 2.15138013e-02 9.80245188e-01]\n",
      " [4.14552054e-04 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [8.22165523e+00 4.05558321e+00 4.31258632e+00 2.59764771e+00]\n",
      " [6.43974788e+00 8.54812751e-02 3.05051425e-01 1.41379457e-01]\n",
      " [5.25386796e+00 1.16347334e-01 1.02352064e-01 4.17807228e-02]\n",
      " [2.81821592e-01 1.58531029e+00 8.27396468e-02 3.78853694e-02]\n",
      " [1.97409829e-01 1.57665619e+00 3.34868933e-02 6.28901900e-02]\n",
      " [4.70342878e+00 1.03316992e-01 3.79257152e-02 1.66550647e-02]\n",
      " [1.28177501e-01 1.22626503e+00 4.92823903e-02 1.40417661e-02]\n",
      " [1.17822650e-01 1.02011847e+00 7.76585624e-03 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [4.44395798e+00 4.26986924e+00 4.41119445e+00 8.30470225e+00]\n",
      " [4.54175003e+00 2.62338497e+00 4.40283771e+00 8.38858813e+00]\n",
      " [4.68908525e+00 2.19987340e+00 4.57911881e+00 8.47332134e+00]\n",
      " [4.86093027e+00 8.04363852e-01 4.72450908e+00 8.55891045e+00]\n",
      " [5.09932327e+00 7.60499730e-01 4.70682490e+00 8.64536409e+00]\n",
      " [4.98734372e+00 1.72410790e+00 4.75723131e+00 8.73269100e+00]\n",
      " [4.75958097e+00 4.45843562e-01 4.50579086e+00 8.82090000e+00]\n",
      " [4.14400470e+00 2.77720715e-01 3.97786947e+00 8.91000000e+00]\n",
      " [2.99288582e+00 0.00000000e+00 3.04161919e+00 9.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]]\n",
      "Run =  3\n",
      "Final policy: \n",
      " [['>' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']\n",
      " ['^' '^' '^' '^' '^' 'v' 'v' '^' '^' '^' '^' '^']\n",
      " ['^' '>' '>' '>' '<' '<' '>' '^' '^' '^' '^' '^']]\n",
      "Final q values: \n",
      " [[8.13943868e+00 4.02279323e+00 4.23400502e+00 8.42779498e-01]\n",
      " [1.09605502e-01 3.99193334e-02 1.48242862e-01 1.57412340e+00]\n",
      " [1.07881291e-01 3.44644133e-02 4.73533888e-02 1.60553365e+00]\n",
      " [2.72209729e-01 9.80151082e-02 1.20293483e-01 1.38178852e+00]\n",
      " [2.17876830e-01 6.91951250e-02 1.29830800e+00 2.57298711e-01]\n",
      " [1.26527665e-02 1.19421025e-02 1.12409559e+00 6.66297688e-02]\n",
      " [6.81505383e-03 6.34549915e-03 4.81236100e-02 1.03285064e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [8.22165523e+00 3.89503507e+00 4.14048091e+00 2.64586805e+00]\n",
      " [6.46643579e+00 6.05924718e-02 2.91882787e-01 1.08562901e-01]\n",
      " [4.96028142e+00 9.17407629e-02 1.03175500e-01 9.61686737e-02]\n",
      " [5.13900235e+00 1.11849132e-01 6.95302059e-02 6.78452245e-02]\n",
      " [5.13305622e+00 5.45991347e-02 6.80094122e-02 3.77474547e-02]\n",
      " [1.95789422e-01 1.50204525e+00 8.93565152e-02 2.36265772e-02]\n",
      " [1.60626715e-01 1.26886502e+00 1.24182711e-02 2.25137523e-02]\n",
      " [3.03141360e+00 5.15089514e-02 1.21947408e-02 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [4.25257847e+00 4.23726996e+00 4.41585199e+00 8.30470225e+00]\n",
      " [4.60610910e+00 2.63915993e+00 4.56588963e+00 8.38858813e+00]\n",
      " [4.91843922e+00 1.98221882e+00 4.66176855e+00 8.47332134e+00]\n",
      " [5.03985357e+00 2.05700441e+00 4.83701618e+00 8.55891045e+00]\n",
      " [5.14780949e+00 2.08041707e+00 4.88473028e+00 8.64536409e+00]\n",
      " [5.05249771e+00 6.60968651e-01 4.66281341e+00 8.73269100e+00]\n",
      " [4.78060861e+00 4.81309151e-01 4.74886054e+00 8.82090000e+00]\n",
      " [3.94040320e+00 7.69257542e-01 3.86185513e+00 8.91000000e+00]\n",
      " [2.86006390e+00 0.00000000e+00 2.90756687e+00 9.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]]\n",
      "Run =  4\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Final policy: \n",
      " [['>' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']\n",
      " ['^' '^' '^' 'v' 'v' '^' '^' 'v' '^' '^' '^' '^']\n",
      " ['^' '>' '>' '>' '<' '>' '>' '^' '^' '^' '^' '^']]\n",
      "Final q values: \n",
      " [[8.13943868e+00 3.99738433e+00 3.97963625e+00 8.49903075e-01]\n",
      " [8.21492841e-02 5.41773175e-02 1.48721212e-01 1.59101121e+00]\n",
      " [1.00348001e-01 5.31749614e-02 4.93784162e-02 1.67335444e+00]\n",
      " [1.94769258e-01 2.42300209e-01 2.85946186e-01 1.88708576e+00]\n",
      " [1.91381078e-01 1.79143675e-01 1.83172309e+00 5.62630097e-01]\n",
      " [1.54885676e-02 1.76563881e-03 1.45611559e-02 4.19434333e-01]\n",
      " [9.41713762e-03 2.18613723e-04 8.14793230e-03 3.20776709e-01]\n",
      " [3.22955547e-02 1.87158178e-06 1.05723408e-03 2.70000000e-03]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [8.22165523e+00 3.83715063e+00 4.12397957e+00 2.38757089e+00]\n",
      " [6.28129173e+00 9.45003764e-02 3.21682692e-01 1.36298133e-01]\n",
      " [5.08053123e+00 1.03622879e-01 8.12843192e-02 4.56391054e-02]\n",
      " [2.68254883e-01 1.59758018e+00 8.30335319e-02 4.42635692e-02]\n",
      " [1.99567667e-01 1.56914037e+00 3.95084876e-02 1.03195205e-01]\n",
      " [4.59917019e+00 9.41514942e-02 2.45546642e-02 6.44406530e-02]\n",
      " [3.69073321e+00 6.17557185e-02 3.25727701e-02 7.72387655e-03]\n",
      " [1.93443151e-01 9.65208825e-01 3.45010143e-02 7.63539183e-05]\n",
      " [8.60379834e-03 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [4.10562836e+00 4.29151666e+00 4.40740365e+00 8.30470225e+00]\n",
      " [4.48468636e+00 2.56713226e+00 4.40339225e+00 8.38858813e+00]\n",
      " [4.73351600e+00 2.10120916e+00 4.64732855e+00 8.47332134e+00]\n",
      " [4.89221471e+00 8.05061060e-01 4.69721104e+00 8.55891045e+00]\n",
      " [4.94645982e+00 7.47389026e-01 4.80380346e+00 8.64536409e+00]\n",
      " [4.91819089e+00 1.67645421e+00 4.67486354e+00 8.73269100e+00]\n",
      " [4.84365330e+00 1.16250255e+00 4.75092544e+00 8.82090000e+00]\n",
      " [4.06604473e+00 2.68846035e-01 3.74190677e+00 8.91000000e+00]\n",
      " [2.89044469e+00 2.47426937e-03 2.99680312e+00 9.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]]\n",
      "Run =  5\n",
      "Final policy: \n",
      " [['>' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']\n",
      " ['^' '^' '^' '^' '^' 'v' 'v' 'v' '^' '^' '^' '^']\n",
      " ['^' '>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '^']]\n",
      "Final q values: \n",
      " [[8.13943868e+00 3.99012811e+00 4.04692081e+00 8.05489525e-01]\n",
      " [1.13143802e-01 2.84438079e-02 1.75523959e-01 1.54714027e+00]\n",
      " [1.17387258e-01 4.31251430e-02 3.99331168e-02 1.61189635e+00]\n",
      " [7.28700483e-02 3.72797702e-02 4.33373883e-02 1.64470756e+00]\n",
      " [7.36357260e-02 3.86017812e-02 3.48590139e-02 1.70189603e+00]\n",
      " [5.69487292e-02 7.09330258e-02 1.05076410e-01 2.10067590e+00]\n",
      " [4.85395875e-02 8.33837594e-02 8.90040775e-02 2.27167325e+00]\n",
      " [2.42962430e-02 2.63620552e-02 3.78412094e-02 1.58919699e+00]\n",
      " [5.17068511e-03 1.67731786e-02 1.70530588e-02 1.49652714e+00]\n",
      " [5.92868318e-04 8.32283932e-03 7.53479152e-03 1.24561382e+00]\n",
      " [0.00000000e+00 5.51085070e-03 6.10571964e-03 1.93845136e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [8.22165523e+00 3.64941447e+00 4.10708959e+00 2.68482505e+00]\n",
      " [6.46846794e+00 6.94069241e-02 3.02393418e-01 1.35055233e-01]\n",
      " [4.80259319e+00 1.33185395e-01 9.68091574e-02 8.41223835e-02]\n",
      " [4.96115212e+00 9.26402808e-02 5.05980124e-02 5.87979410e-02]\n",
      " [4.69765936e+00 7.80149131e-02 5.51823499e-02 2.99510390e-02]\n",
      " [2.64878017e-01 1.55175062e+00 5.23110145e-02 2.72501991e-02]\n",
      " [1.25292709e-01 1.37828719e+00 1.38118426e-02 9.17492655e-03]\n",
      " [1.77317855e-01 1.05866370e+00 1.21354827e-02 1.68589064e-03]\n",
      " [2.19205863e-01 1.39277430e-06 9.02098648e-04 0.00000000e+00]\n",
      " [9.85064820e-02 0.00000000e+00 1.34219991e-04 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [4.21022135e+00 4.00928678e+00 4.35662204e+00 8.30470225e+00]\n",
      " [4.68815589e+00 2.59083291e+00 4.39642209e+00 8.38858813e+00]\n",
      " [4.84198930e+00 1.87699089e+00 4.65768576e+00 8.47332134e+00]\n",
      " [4.85554635e+00 1.98519155e+00 4.84351308e+00 8.55891045e+00]\n",
      " [5.18235444e+00 1.73343804e+00 4.82518854e+00 8.64536409e+00]\n",
      " [4.83586622e+00 7.11242446e-01 4.64641622e+00 8.73269100e+00]\n",
      " [4.76755460e+00 5.40568434e-01 4.68265952e+00 8.82090000e+00]\n",
      " [4.06392298e+00 3.10027844e-01 3.89334322e+00 8.91000000e+00]\n",
      " [3.16110291e+00 6.03863537e-02 3.27471247e+00 9.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]]\n",
      "Run =  6\n",
      "Final policy: \n",
      " [['>' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']\n",
      " ['^' '^' 'v' '^' 'v' '^' '^' 'v' '^' '^' '^' '^']\n",
      " ['^' '>' '>' '>' '>' '>' '>' '>' '>' '>' '>' '^']]\n",
      "Final q values: \n",
      " [[8.13943868e+00 4.14505561e+00 4.09127465e+00 8.23839351e-01]\n",
      " [9.00605379e-02 3.76112970e-02 1.50312294e-01 1.57740878e+00]\n",
      " [7.13909298e-02 1.31734104e-01 7.80916345e-02 2.04330419e+00]\n",
      " [1.35809982e-01 1.34148533e-01 1.09649014e-01 2.11913941e+00]\n",
      " [9.87816976e-02 1.78058090e-01 2.16956208e-01 2.31516229e+00]\n",
      " [1.24893840e-01 1.18666717e-01 1.62562234e-01 2.33873759e+00]\n",
      " [1.13278258e-01 1.12817314e-01 1.18208345e-01 2.30720880e+00]\n",
      " [1.78604113e-02 1.99128972e-02 4.48777833e-02 1.73101000e+00]\n",
      " [1.29424557e-03 1.90029371e-02 3.26175175e-02 1.62380786e+00]\n",
      " [2.63219349e-03 5.07550197e-03 1.58267214e-02 1.30573704e+00]\n",
      " [0.00000000e+00 4.51762641e-03 9.38854512e-03 2.18273836e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [8.22165523e+00 3.82332697e+00 4.15133777e+00 2.52645580e+00]\n",
      " [6.29568891e+00 7.83832643e-02 3.78390146e-01 6.26607550e-02]\n",
      " [1.81914323e-01 1.56624465e+00 1.23718405e-01 7.39669488e-02]\n",
      " [4.94079648e+00 1.09494899e-01 3.19077025e-02 3.96636501e-02]\n",
      " [2.25662711e-01 1.60827716e+00 6.46840443e-02 5.27191632e-02]\n",
      " [4.81549387e+00 8.12613730e-02 3.05913360e-02 4.67697006e-02]\n",
      " [4.00214788e+00 6.70917927e-02 4.68475083e-02 9.81345126e-03]\n",
      " [1.66859778e-01 9.99915342e-01 2.99080991e-02 1.18798296e-03]\n",
      " [1.39370059e-01 3.03688870e-04 0.00000000e+00 2.38946054e-04]\n",
      " [1.95934794e-01 1.83462857e-03 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [4.29078637e+00 4.14314280e+00 4.41435665e+00 8.30470225e+00]\n",
      " [4.46728757e+00 2.40840201e+00 4.40659149e+00 8.38858813e+00]\n",
      " [4.64598523e+00 8.27045342e-01 4.42509666e+00 8.47332134e+00]\n",
      " [4.90463228e+00 1.95081437e+00 4.54571494e+00 8.55891045e+00]\n",
      " [4.91575432e+00 7.80233161e-01 4.82104292e+00 8.64536409e+00]\n",
      " [4.81740893e+00 1.80538161e+00 4.74303500e+00 8.73269100e+00]\n",
      " [4.98986076e+00 1.33733015e+00 4.47635841e+00 8.82090000e+00]\n",
      " [4.26334369e+00 2.70181454e-01 3.93621118e+00 8.91000000e+00]\n",
      " [3.06905514e+00 3.63153992e-02 3.10565971e+00 9.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]]\n",
      "Run =  7\n",
      "Final policy: \n",
      " [['>' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']\n",
      " ['^' '^' '^' 'v' '^' 'v' '^' 'v' '^' '^' '^' '^']\n",
      " ['^' '>' '^' '<' '<' '<' '>' '^' '^' '^' '^' '^']]\n",
      "Final q values: \n",
      " [[8.13943868e+00 4.16839562e+00 3.94593663e+00 9.04795236e-01]\n",
      " [1.05904769e-01 2.66537702e-02 2.19832206e-01 2.13291932e+00]\n",
      " [4.75946388e+00 9.83542483e-02 7.61304635e-02 1.25768840e-01]\n",
      " [3.61266187e-02 3.21525312e-02 1.95759578e+00 1.12522728e-01]\n",
      " [4.09739300e-02 5.94688740e-03 8.62759518e-01 1.91230656e-02]\n",
      " [1.77490960e-02 9.39223003e-03 1.19380116e+00 5.93150335e-02]\n",
      " [1.75635335e-03 2.57400000e-06 2.40000000e-03 7.94026056e-02]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [8.22165523e+00 3.94656071e+00 4.24371154e+00 2.69067797e+00]\n",
      " [6.48187630e+00 7.18628372e-02 2.64911761e-01 2.45724155e-01]\n",
      " [7.38659402e+00 1.54529768e-01 2.06604185e-01 1.08536905e-01]\n",
      " [3.14300427e-01 1.59690761e+00 1.41616405e-01 8.93863441e-02]\n",
      " [4.88126890e+00 7.91464338e-02 4.79086026e-02 2.55889350e-02]\n",
      " [1.68515425e-01 1.52373152e+00 5.59834932e-02 4.18898747e-02]\n",
      " [4.04472825e+00 6.41939628e-02 2.09342851e-02 9.06275815e-03]\n",
      " [1.08538745e-01 1.05619404e+00 2.29885368e-02 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [4.36564108e+00 4.11253645e+00 4.25924265e+00 8.30470225e+00]\n",
      " [4.68429017e+00 2.60228865e+00 4.45687198e+00 8.38858813e+00]\n",
      " [4.91627309e+00 3.25205594e+00 4.80039281e+00 8.47332134e+00]\n",
      " [4.93090637e+00 8.15754719e-01 4.97077605e+00 8.55891045e+00]\n",
      " [5.26390174e+00 1.90916619e+00 4.74999986e+00 8.64536409e+00]\n",
      " [5.07063676e+00 6.75223618e-01 4.84326516e+00 8.73269100e+00]\n",
      " [5.14547664e+00 1.43110897e+00 4.86016984e+00 8.82090000e+00]\n",
      " [3.97117434e+00 3.15090867e-01 3.86840191e+00 8.91000000e+00]\n",
      " [3.16976711e+00 0.00000000e+00 3.15713870e+00 9.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]]\n",
      "Run =  8\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Final policy: \n",
      " [['>' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']\n",
      " ['^' '^' '^' 'v' '^' '^' '^' '^' '^' '^' '^' '^']\n",
      " ['^' '>' '>' '<' '>' '>' '>' '^' '^' '^' '^' '^']]\n",
      "Final q values: \n",
      " [[8.13943868e+00 4.05461839e+00 4.03548930e+00 7.95829316e-01]\n",
      " [1.01857092e-01 3.96877995e-02 1.61340836e-01 1.54119168e+00]\n",
      " [3.80482010e-01 1.74639197e-01 1.83345574e-01 1.48207526e+00]\n",
      " [1.53262210e-01 1.54223465e-01 1.47411016e+00 4.18968964e-01]\n",
      " [1.01485884e-02 2.04557408e-03 1.10211146e-02 4.21434330e-01]\n",
      " [1.39250191e-02 6.97428919e-04 2.60837263e-03 3.71867703e-01]\n",
      " [7.78615249e-03 8.58451695e-04 5.43294755e-03 3.03325421e-01]\n",
      " [5.45996302e-02 1.02957147e-05 3.32619623e-05 2.70000000e-03]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [8.22165523e+00 4.03024380e+00 4.37740933e+00 2.55724749e+00]\n",
      " [6.39758114e+00 7.39167060e-02 3.45724062e-01 1.20311080e-01]\n",
      " [5.06501665e+00 9.81527922e-02 9.85801344e-02 5.37889655e-02]\n",
      " [2.82217461e-01 1.55552209e+00 1.02850506e-01 7.43800802e-02]\n",
      " [4.75398097e+00 9.90543515e-02 2.62500141e-02 5.63267419e-02]\n",
      " [4.79893936e+00 9.41491965e-02 4.91063228e-02 5.58525437e-02]\n",
      " [3.96490421e+00 4.95278379e-02 4.04193720e-02 2.73699870e-02]\n",
      " [3.40852145e+00 3.10395420e-02 3.94381504e-02 3.45723952e-05]\n",
      " [8.74350934e-03 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [4.24146578e+00 4.21273398e+00 4.47652209e+00 8.30470225e+00]\n",
      " [4.56174514e+00 2.59164571e+00 4.39795377e+00 8.38858813e+00]\n",
      " [4.81953250e+00 2.01203355e+00 4.51646453e+00 8.47332134e+00]\n",
      " [4.94472709e+00 7.79235354e-01 4.71053724e+00 8.55891045e+00]\n",
      " [4.94414996e+00 1.80124997e+00 4.76335990e+00 8.64536409e+00]\n",
      " [4.98338218e+00 1.83035653e+00 4.63377093e+00 8.73269100e+00]\n",
      " [4.76296248e+00 1.36285536e+00 4.81983469e+00 8.82090000e+00]\n",
      " [3.93135896e+00 9.20481029e-01 3.89751080e+00 8.91000000e+00]\n",
      " [3.16516293e+00 2.39031549e-03 3.10890073e+00 9.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]]\n",
      "Run =  9\n",
      "Final policy: \n",
      " [['>' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']\n",
      " ['^' '^' '^' '^' '^' '^' 'v' 'v' '^' '^' '^' '^']\n",
      " ['^' '>' '>' '>' '>' '>' '>' '>' '>' '^' '^' '^']]\n",
      "Final q values: \n",
      " [[8.13943868e+00 3.99238702e+00 4.09338378e+00 8.70690283e-01]\n",
      " [9.76274595e-02 4.21500737e-02 1.85883780e-01 1.59881969e+00]\n",
      " [6.16568997e-02 4.46756432e-02 5.04849552e-02 1.66633566e+00]\n",
      " [8.38643878e-02 4.79109727e-02 4.35732682e-02 1.73002879e+00]\n",
      " [4.23537127e-02 3.39563527e-02 4.60018879e-02 1.77853190e+00]\n",
      " [7.09602115e-02 3.55657752e-02 5.44261072e-02 1.81225651e+00]\n",
      " [3.15341404e-02 6.97890642e-02 6.42213406e-02 2.10894144e+00]\n",
      " [1.52653670e-02 2.94633854e-02 4.87844926e-02 1.75037053e+00]\n",
      " [3.65000439e-03 2.44010537e-02 3.19765460e-02 1.63871735e+00]\n",
      " [9.28856744e-01 1.60902061e-03 7.19099992e-03 4.89075651e-02]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [8.22165523e+00 4.08650735e+00 4.24465677e+00 2.48057984e+00]\n",
      " [6.38576337e+00 9.09229748e-02 2.72128404e-01 1.22293388e-01]\n",
      " [4.74333281e+00 1.11700652e-01 1.07515250e-01 7.29181522e-02]\n",
      " [4.92954046e+00 1.06791088e-01 5.98214397e-02 7.23734083e-02]\n",
      " [4.93432910e+00 1.01778790e-01 7.46649876e-02 8.24814613e-02]\n",
      " [5.07620339e+00 1.03878776e-01 6.69534861e-02 2.28251573e-02]\n",
      " [1.44549590e-01 1.27073367e+00 5.04140334e-02 8.89417325e-03]\n",
      " [9.18523055e-02 1.06124496e+00 1.25022121e-02 2.03703537e-03]\n",
      " [2.01213763e-01 5.17714128e-04 7.50368219e-04 1.06316160e-03]\n",
      " [3.42113463e+00 3.79956890e-03 1.13132359e-03 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [4.32695837e+00 4.06281375e+00 4.44278889e+00 8.30470225e+00]\n",
      " [4.65484496e+00 2.63693014e+00 4.44715679e+00 8.38858813e+00]\n",
      " [4.91800953e+00 1.81430955e+00 4.73377690e+00 8.47332134e+00]\n",
      " [4.78555763e+00 1.96574244e+00 4.86982573e+00 8.55891045e+00]\n",
      " [5.29974037e+00 1.98841688e+00 4.80020554e+00 8.64536409e+00]\n",
      " [5.09653529e+00 2.05545513e+00 5.00212682e+00 8.73269100e+00]\n",
      " [4.95614749e+00 4.69541956e-01 4.68587022e+00 8.82090000e+00]\n",
      " [3.93930390e+00 3.07536667e-01 3.99241435e+00 8.91000000e+00]\n",
      " [2.98468390e+00 5.09258057e-02 3.16054578e+00 9.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
      " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]]\n"
     ]
    }
   ],
   "source": [
    "# max q-learning\n",
    "\n",
    "max_q_returns_over_runs = []\n",
    "max_q_max_rewards_over_runs = []\n",
    "max_q_final_policy_over_runs = []\n",
    "max_q_final_q_values_over_runs = []\n",
    "num_runs = 10\n",
    "\n",
    "for run in range(num_runs):\n",
    "    print(\"Run = \", str(run))\n",
    "    q = np.zeros((experiment['w']*experiment['h'],num_actions))\n",
    "    episode_returns = []\n",
    "    episode_max_rewards = []\n",
    "    epsilon_schedule = np.concatenate((np.linspace(0.2,0,int(num_episodes*experiment['ts']/2)),np.array([0]*(int(num_episodes*experiment['ts']/2)+1))))\n",
    "    timesteps = 0\n",
    "\n",
    "    for episode in range(num_episodes):\n",
    "        obs = env.reset()\n",
    "        episode_return = 0\n",
    "        episode_max_reward = -100\n",
    "        done = False\n",
    "        while done != True:\n",
    "            timesteps += 1\n",
    "            prev_obs = deepcopy(obs)\n",
    "            a = np.argmax(q[obs])\n",
    "            if np.random.rand()<epsilon_schedule[timesteps]:\n",
    "                #if np.random.rand()<0.1:\n",
    "                a = np.random.randint(num_actions)\n",
    "                #print(\"random action taken\")\n",
    "            obs, r, done, info = env.step(a)\n",
    "            q[prev_obs,a] = q[prev_obs,a] + alpha*(max(r,gamma*max(q[obs])) - q[prev_obs,a])\n",
    "            episode_return += r\n",
    "            episode_max_reward = max(r, episode_max_reward)\n",
    "            #print(prev_obs,action_dict[a])\n",
    "\n",
    "        episode_returns.append(episode_return)\n",
    "        episode_max_rewards.append(episode_max_reward)\n",
    "        #if episode%1000==0:\n",
    "        #    print(\"Episode \", str(episode), \" ended with return = \", str(episode_return))\n",
    "        #    policy = np.reshape(np.argmax(q,axis=1), (-1, experiment['w']))\n",
    "        #    print(\"Policy: \\n\", policy_viz(np.transpose(policy), action_dict))\n",
    "        \n",
    "    policy = np.reshape(np.argmax(q,axis=1), (-1, experiment['w']))    \n",
    "    print(\"Final policy: \\n\", np.flip(policy_viz(policy, action_dict_flipped), axis=0))\n",
    "    max_q_final_policy_over_runs.append(np.flip(policy_viz(policy, action_dict_flipped), axis=0))\n",
    "    #print(\"Final policy: \\n\", policy_viz(np.transpose(policy), action_dict))\n",
    "    print(\"Final q values: \\n\", q)\n",
    "    max_q_final_q_values_over_runs.append(q)\n",
    "\n",
    "    episodes, returns = smoothen_curves(np.arange(0,num_episodes,1), episode_returns)\n",
    "    max_q_returns_over_runs.append(returns)\n",
    "    \n",
    "    dummy, max_rewards = smoothen_curves(np.arange(0,num_episodes,1), episode_max_rewards)\n",
    "    max_q_max_rewards_over_runs.append(max_rewards)\n",
    "    \n",
    "    #plt.plot(episodes, returns, label = 'max-q', c = 'orange')\n",
    "    #plt.legend()\n",
    "    #plt.ylim(min(returns)-10,max(returns)+10)\n",
    "    #plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "wuUBJAwsf3UZ"
   },
   "source": [
    "### Visualizations"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "vu-kKAb9f3Ua"
   },
   "source": [
    "#### Comparison of total episodic rewards i.e. returns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 724
    },
    "id": "JPSLX40Tf3Ua",
    "outputId": "42d2190d-0e73-4a38-a071-bcbb44a99b7b"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Q-learning return for last 10 episodes for each of the 10 runs. Each row is a separate run: \n",
      "\n",
      "[[27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5]\n",
      " [27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5]\n",
      " [27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5]\n",
      " [27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5]\n",
      " [27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5]\n",
      " [27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5]\n",
      " [27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5]\n",
      " [27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5]\n",
      " [27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5]\n",
      " [27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5 27.5]]\n",
      "\n",
      "Max-Q return for last 10 episodes for each of the 10 runs. Each row is a separate run: \n",
      "\n",
      "[[26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8]\n",
      " [26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8]\n",
      " [26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8]\n",
      " [26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8]\n",
      " [26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8]\n",
      " [26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8]\n",
      " [26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8]\n",
      " [26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8]\n",
      " [26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8]\n",
      " [26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8 26.8]]\n",
      "\n",
      "Comparison of average total reward i.e. return:\n"
     ]
    },
    {
     "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": [
    "q_returns_over_runs = np.array(q_returns_over_runs)\n",
    "print(\"Q-learning return for last 10 episodes for each of the 10 runs. Each row is a separate run: \\n\")\n",
    "print(q_returns_over_runs[:,-10:])\n",
    "mean = np.mean(q_returns_over_runs, axis=0)\n",
    "std = np.std(q_returns_over_runs, axis=0)\n",
    "\n",
    "plt.plot(episodes, mean, label = 'q')\n",
    "plt.fill_between(episodes, mean+std, mean-std, alpha=0.2)\n",
    "\n",
    "max_q_returns_over_runs = np.array(max_q_returns_over_runs)\n",
    "print(\"\\nMax-Q return for last 10 episodes for each of the 10 runs. Each row is a separate run: \\n\")\n",
    "print(max_q_returns_over_runs[:,-10:])\n",
    "mean = np.mean(max_q_returns_over_runs, axis=0)\n",
    "std = np.std(max_q_returns_over_runs, axis=0)\n",
    "\n",
    "print(\"\\nComparison of average total reward i.e. return:\")\n",
    "plt.plot(episodes, mean, label = 'max-q', c='orange')\n",
    "plt.fill_between(episodes, mean+std, mean-std, color='orange', alpha=0.2)\n",
    "plt.xlabel(\"Episodes\")\n",
    "plt.ylabel(\"Return\")\n",
    "plt.legend()\n",
    "plt.grid()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "njgAGFwUf3Uf"
   },
   "source": [
    "#### Comparison of max episodic rewards i.e. max reward in episode"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 741
    },
    "id": "YIiPGs9of3Uf",
    "outputId": "041bdebd-0b8d-4e7f-99c8-6cb871b5a1ea",
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Q-learning max reward for last 10 episodes for each of the 10 runs. Each row is a separate run: \n",
      "\n",
      "[[6. 6. 6. 6. 6. 6. 6. 6. 6. 6.]\n",
      " [6. 6. 6. 6. 6. 6. 6. 6. 6. 6.]\n",
      " [6. 6. 6. 6. 6. 6. 6. 6. 6. 6.]\n",
      " [6. 6. 6. 6. 6. 6. 6. 6. 6. 6.]\n",
      " [6. 6. 6. 6. 6. 6. 6. 6. 6. 6.]\n",
      " [6. 6. 6. 6. 6. 6. 6. 6. 6. 6.]\n",
      " [6. 6. 6. 6. 6. 6. 6. 6. 6. 6.]\n",
      " [6. 6. 6. 6. 6. 6. 6. 6. 6. 6.]\n",
      " [6. 6. 6. 6. 6. 6. 6. 6. 6. 6.]\n",
      " [6. 6. 6. 6. 6. 6. 6. 6. 6. 6.]]\n",
      "(10, 99971)\n",
      "\n",
      "Max-Q max reward for last 10 episodes for each of the 10 runs. Each row is a separate run: \n",
      "\n",
      "[[9. 9. 9. 9. 9. 9. 9. 9. 9. 9.]\n",
      " [9. 9. 9. 9. 9. 9. 9. 9. 9. 9.]\n",
      " [9. 9. 9. 9. 9. 9. 9. 9. 9. 9.]\n",
      " [9. 9. 9. 9. 9. 9. 9. 9. 9. 9.]\n",
      " [9. 9. 9. 9. 9. 9. 9. 9. 9. 9.]\n",
      " [9. 9. 9. 9. 9. 9. 9. 9. 9. 9.]\n",
      " [9. 9. 9. 9. 9. 9. 9. 9. 9. 9.]\n",
      " [9. 9. 9. 9. 9. 9. 9. 9. 9. 9.]\n",
      " [9. 9. 9. 9. 9. 9. 9. 9. 9. 9.]\n",
      " [9. 9. 9. 9. 9. 9. 9. 9. 9. 9.]]\n",
      "\n",
      "Comparison of average max reward over each episode:\n"
     ]
    },
    {
     "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": [
    "q_max_rewards_over_runs = np.array(q_max_rewards_over_runs)\n",
    "print(\"Q-learning max reward for last 10 episodes for each of the 10 runs. Each row is a separate run: \\n\")\n",
    "print(q_max_rewards_over_runs[:,-10:])\n",
    "mean = np.mean(q_max_rewards_over_runs, axis=0)\n",
    "std = np.std(q_max_rewards_over_runs, axis=0)\n",
    "\n",
    "plt.plot(episodes, mean, label = 'q')\n",
    "plt.fill_between(episodes, mean+std, mean-std, alpha=0.2)\n",
    "\n",
    "max_q_max_rewards_over_runs = np.array(max_q_max_rewards_over_runs)\n",
    "print(max_q_max_rewards_over_runs.shape)\n",
    "print(\"\\nMax-Q max reward for last 10 episodes for each of the 10 runs. Each row is a separate run: \\n\")\n",
    "print(max_q_max_rewards_over_runs[:,-10:])\n",
    "mean = np.mean(max_q_max_rewards_over_runs, axis=0)\n",
    "std = np.std(max_q_max_rewards_over_runs, axis=0)\n",
    "\n",
    "print(\"\\nComparison of average max reward over each episode:\")\n",
    "plt.plot(episodes, mean, label = 'max-q', c='orange')\n",
    "plt.fill_between(episodes, mean+std, mean-std, color='orange', alpha=0.2)\n",
    "plt.xlabel(\"Episodes\")\n",
    "plt.ylabel(\"Max reward in episode\")\n",
    "plt.legend()\n",
    "plt.grid()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "6qjmwcxwf3Ui"
   },
   "source": [
    "#### Visualizing the learned policies"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 292
    },
    "id": "-kdBO4hjf3Ui",
    "outputId": "6e0ff7d0-f379-42ab-e7de-deb7f13f726d"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Final policy obtained with q-learning:\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAATIAAABwCAYAAACdIfwWAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjEsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8QZhcZAAAV/ElEQVR4nO2dbXBUVZqAn3wYPpIMRAwKiEBmIBCiogIipgwhGCCmdWdqqBFca3aEsqZccbIrOmxprVhOzcxSK7OFLmqh7DoK7iiikIzBhWgcyOhoAnEJEwIEsIEkRBJJIJLPfvfH7fQk9A106HMTr75P1a10X7qfPrz39tvnnHvPOREigqIoipuJHOgCKIqihIsmMkVRXI8mMkVRXI8mMkVRXI8mMkVRXE+0E9Lhw4fLD37wAyfUNDc3Exsbq+5+9Ku7//3qtqe0tPS0iCQG/YOIGN8mTZokTvHhhx+qu5/96u5/v7rtAUrEJudo01JRFNejiUxRFNejiUxRFNejiUxRXM7HH3/sSndlZSUNDQ1GXJrIFMXFtLW1sXz5csShMdO/+tWvOHHihCPurVu3UlBQYMSliUxRXMyuXbsoLS2lsrLSuLu5uZnCwkLy8/ONuwHy8vLIy8sz4tJEpigupivJmEoI3dm5cyetra2OuOvr6/nzn//M9u3baW9vD9uniUxRXIqIBJKME8mmy1lYWEhzc7NRd0FBAT6fj8bGRnbt2hW2b0ATWU1NDW1tbY64GxsbOXPmjCNun8+H1+t1xA3g9Xod6/PQmNvjxpgfOHCAqqoqAIqLi411nIMV767aXmtrK4WFhcbc0DPxmmi6DmgiO3XqFImJiSxatIhXX32VL7/80pg7JiaGG2+8kYyMDNasWcOhQ4eMuSMjI8nNzeWGG27giSee4JNPPsHn8xnzv/vuu4wdO5af//zn/PGPf+T8+fPG3Bpze9wY8+7JwOfzGes4BygpKeHUqVO2nxUubW1tbN++vYc73B8RR8Za2vHFF19QX18ftH/y5Mls3ryZzZs3ExERwW233YbH48Hj8ZCSkkJERMQl3fX19XzxxRdB+3Nycli3bh1FRUU8+uijJCcnB9yzZ88mOvrS//22tjbKy8tt3UuXLmXfvn38+te/ZuTIkdx11114PB7uvPNO4uLiLukGKC8vD/q1vuWWWzhz5gwvvfQSL730EkOGDGHevHl4PB5ycnIYNWpUSG6NuT1ujfmFXFiTycvL47777uuzJxR3fn4+Pp+PyMjw6z67d++mqakp8Pzw4cNUVlYyefLky5fajVsKd7Mba/nAAw8I0KdtwoQJ8sgjj8gnn3wS8NiN5fr973/fZ3dCQoIsWbJENm/eLJ2dnb26vV5vn90xMTEyf/58ef755+Xs2bO9ukVEkpKS+uyfPn26PP3003Ls2LGLxkVj/u2KeXdOnz4tkZGRPTzDhg2Ttra2i74vFLeIyLRp04LK+emnnxpx5+bmBrlXr159yfeJ9D7Wst9qZMOHD2f06NFB+xsbG207EidMmBD4xbrpppsu6h4yZIit+/z583z11VdB+xMSEsjOzsbj8ZCZmXnRX5moqChbt8/no7a2Nmh/TEwMc+fOJScnh5ycnEvWEq6++mpaWlqC9tfV1dHR0RG0f/r06YG4XHfddRd1a8ztcWvMu1NQUEBsbCxXXXUVR48eJTk5mWPHjrFr1y7mzp0bsseO48ePs2/fPlJTUykvL+fqq68GrBrfjBkzwnKL/wLFtGnTKCsrA+DGG28kLy+Pxx57LDyx6S3U2S86Oztl6tSpAkhkZKTcfvvt8tvf/lb2798vPp/P9j19GV3/0EMPBTL+5MmT5bHHHpOPPvpI2tvbw3a/+eabAffIkSPlZz/7mWzZsiVQGwjH7fV6JSYmRgAZMmSI3H333bJ+/Xqprq7u9T2h+jXm9rgt5kVFRVJfXy8PPvigALJq1So5efKkfPzxx5csz6Xc+/fvlwMHDsimTZsEkDlz5khzc7MUFBSE7W5qapKdO3fKyZMnA8eys7NTtm3bJh0dHZf0M9A1Mjt27NhBSkoKjz/+ONnZ2Vx11VXG3LW1tRw5coQ1a9bg8XgwOT+az+dj69atPPHEE3g8HmbMmGGk76CLjRs38sADD+DxeMjIyGDIkCHG3Bpze9wW8/T09KB9o0ePtq0N9pWUlBQA9uzZE9g3dOhQFixYELY7Pj6ezMxMampqAvsiIyPxeDxheQc0kc2fP5/58+c74r7mmmuMXsXpTmRkJK+//rojboCVK1c65taY2+PWmCsWekOsoiiuRxOZoiiuZ0CbloqihMfMmTM5d+4c119/vXH3uHHjWLJkCVOmTDHuHjx4MEuWLDHm00SmKC5m6dKlLF261BH37NmzmT17tiPuhIQENm7caMynTUtFUVyPJjJFUVxPKIlsLPAhUAHsB37haIkURVH6SCh9ZB3Ao8AeIB4oBXYAf3WwXIqiKCETSo2sBiuJAZzFqpmNcaxEiqIofSRC+jYP0HjgT0Aq0NTbiyZOnCjr168Pr2S9cO7cuZCna/muuJ32q7v//eq2JyMjo1REpgf9g90AzF62OBEpFZEfXeq1oQ4avxzcuty700vJu7XsbnU77Ve3PfQyaDzUq5ZXAG8DG4Et5vKroihK+ISSyCKAV7D6xtY4WxxFUZS+E0oiux24H5gLlPm3bCcLpSiK0hdCSWS7sWplNwDT/Nt7Jj5cRAKrwDiBk2634nTMncTJcldXV/P111874nbzee6WmA/onf2VlZWsW7fOEbfP5yM3N9cRt5txMuZO89RTT9lOo22Cbdu2GV/yrAs3n+duifmAJjKTS6ZfSGlpKfn5+Zw8edK4e8eOHaSlpbF8+XLj7tOnT5OWlkZaWppxNzgb89WrV5OWlsaGDRuMu9vb28nPz3ds4kYn4+LW89xNMR/wRHbo0CEqKysdcYOZxT8v5PTp0xQXF9suWRYu7e3tFBcXU1xcbNwNzsa8qqqK4uJijh8/bty9a9cuGhsbHUkIzc3NFBYWBpY8M41bz3M3xXzAEllDQ0Pgy+pEoLoOrFO/hG7E6Zg7SdfxLCgooL293ai7sLCQ1tZWampqesxTbwI3n+duivmAJbKCgoJAJjZ9EE6cOMHevXsBK2BOdeK6DSdj7iTiX0IMrGXVdu/ebdTfPRam4+LW89xtMR+wRNa98MXFxTQ0NBhzd69mt7S0ONaJ6zacjLmTVFZWcvjw4cBzk80on8/Xw2e6iebW89xtMR+QRNbe3s727dsDzzs7O3s8Dxe7peRNsGfPHj744AOk2/jUmpoaIzNdnj17lg0bNvSowp8/f54XX3yRzs7OsP1Oxnzbtm0cPHiwx76ysjJ27txpxO/U8QTrmHZf9HfPnj3GOs7dep477XYi5gOSyHbv3k1jY2OPfaYC9fXXXwf9MpnqULz22muZN28eK1asAGDv3r0kJSXh9XrDdsfHx/O73/2OWbNmBfYlJSXxzjvvEBUVFbbfyZi3t7czZcoU3nnnHQBeeOEFbrrpJmJjY434LyynyY5zuxiYqn249TwH98V8QBJZXl4egwYNYtCgQYC1zLypDsWdO3fS0tLCsGHDAm5THYojR45k1qxZgcVFGxsbaWlpCXtx0S48Hk+PhUtra2uNuZ2MeVZWFtHR0Xz55ZcAnDp1isTERGbOnBm2u6uzfPjw4QDExsYSFRVlLCHk5eUF3ADDhg0z6nbjee7GmA9IIpswYQJHjhxh3LhxAGzevJm1a9dy9OjRsN2tra2UlJTwk5/8BIDc3FyKiooCX7JwuTCxjB8/nqlTpzri7m3f5eBkzOPj45kzZ06PfXfddZeRmmRVVRVvvfUWzz//PAAzZsygsrIy8AUOh7Nnz3L//fdTUlIS2Hfs2DHS09ONNOfdep67MuZ2U2KEu4U6jc+kSZMEkKKiopCn8Qh1mpAHH3xQAFm1apVR9759+wQIbMuXLzfm7ujokMTExID7+uuvD8kdql/EuZg/99xzPeLy9ttvG3OLiGzatEkAmTNnTkiv74u7uro6UO6+MNAxF3HuPBf5ZsacMKfxUfxMnTo18AsL5mpMAFFRUWRn/208vkm30+Tk5AQex8TEkJWVNYClUb5raCLrIxEREYEEExcXR3p6ulF/9+TlpkQ2fvx4UlNTAcjIyHB0llBFuRBNZJdBV4KZP38+MTExRt1ZWVnExMSQmJjIjBkzjLqdpisu3WtnitIfDOhK45MmTSImJsbYZfrujB49mtTUVEaOHGncnZ6eTlxcnCM1pq6O89GjRxvpLL8QJ2Pu8Xj4zW9+40hchg0bRmpqKhMmTDDujo6ODtQmncCt57mrYm7XcRbu9l2Ys3/RokVSV1fniHvt2rUhd5Zfjr+vhOru6OiQzMxMR9yXg87Z/+1yi/Te2T+gNTI3s2rVKhITEx1x33PPPSQkJDjidpKoqCjWrl070MVQvoNoIrtMUlJSHHNfd911jrmdxsm4KEpvaGe/oiiuJ5REtgGoA8zPIqgoimKAUBLZfwMLHC6HoijKZRNKIvsT4I6JqxRF+U4SId3m1roI44F8IKQbPyZOnCjr168Po1i9c+7cOcfuGner22m/uvvfr257MjIySkVketA/2N2TYbONF5HyEF/7nbiP7Jvkdtqv7v73q9sedNC4oijfVjSRKYriekJJZG8AHwPJwAlgqaMlUhTlO8GZM2eMLTMXyp39i418kqIoSjfee+89xowZY2QqLG1aKooyIOTl5RlbB0ATmaIo/U57ezsFBQWayBRFcS/FxcU0NjZy8ODBoDVRLwdNZIqi9Dvda2ImamUDmsh27NjBsmXL2Lp1K83NzUbdtbW1LFq0iFdeeaXHqsYm8Pl8LFu2jNWrV1NRUdFj5XETPPvss/zyl79k9+7dRpYl647G3B6NeTBOxtx0IhvQGWLb29sDS2UNGjRIFi5cKOvWrROv19vre/py5/DSpUsDS07NnDlTnnnmGSkrKxOfzxe2+7XXXgu4v//970tubq4UFhZKW1tb2O6qqiqJjo4WQEaMGCH333+//OEPf5AzZ870+p5Q/RpzezTm9jgR8wMHDvRYOjAqKkoaGhpCKg+93Nkf6ljLPpGcnCwXLq/+5JNPsmXLlqDX1tbW8tVXXwXtnzZtGh6PB4/Hwy233EJkpFV5LCoqCloMdtu2baxcuTLI0dTUxMmTJ4P2jx07Fo/HQ05ODhkZGQwePLhXd01NDZmZmUGOzs5O27b99773PRYsWIDH42HhwoWMGDGiVzdYC5gcP348aH9VVRVtbW099kVHR5Oenh6IS1JSUuDf7Pwac435NyXm3Xn22WdZsWJFj32bNm1i8eJL3+kVERFhO9ay32aIrampoaKiIuTXl5WVceLECbxeL8uWLSMtLa3X1zY2NvbJffz4cTZs2IDX66WhoYHFixcHTqAL6ejo6JO7qamJt956C6/XS3V1NQ899NBFB9EePnyYI0eOhOTu6OigsLAQr9eL1+vlkUce6bHG5oVozO3RmAfjdMy7Y9eUzMvLCymR9Ua/JbIVK1Zw3333Be1fuXIln332WeB5ampq4Ffk1ltvDWkloTvvvJPCwsKg/W+88QYvv/xy4PmoUaPIycnB4/GQmZnJ0KFDL+lOTEy0dVdUVPDwww8HnsfFxZGVlYXH4yE7OzvkVW1ef/11zp8/32NfW1sbP/7xjwP9KVFRUaSlpQXikpycHJJbY26PxjwYp2PexdmzZ5k4cSLPPPMMd9xxBwCff/45zz33HJ2dnZe/cphdezPcLdQ+sv3798vgwYMlKytL1q5dK0eOHLnke0Jt37e2tsq4cePk5ptvlqeeekpKSkqks7PTiFtE5N5775Vx48bJww8/LO+//760tLQYc7/44osyfPhwWbx4sWzcuFHq6+sv+Z5Q/RpzezTm9jgV8+rq6kAfWV/gm7iKUmxsLHV1dcTHxxt3nzt3juLiYsaMGWPc7fP5ePLJJ0lJSSEiIsK4Pz09nbq6Oq644grjbo25PRrzYJyOuUkGNJFdrK8hXK688krH3JGRkUydOtUx/+TJkx1za8zt0ZgH43TMTaI3xCqK4no0kSmK4np0gV5FUfqda665Bp/PZ8yniUxRlH7H9MUDbVoqiuJ6NJEpiuJ6Qk1kC4BK4DAQPNhLURRlAAklkUUB/wksBFKw5vBPcbJQiqIofSGURDYTqyZ2BGgD/ge4x8lCKYqi9IVQrlqOAbrPeXICuPVibzh48ODpiIiIL8IpmKIoig22wyRCSWR210kvOomZiCSGUiJFURQThNK0PAGM7fb8WqDameIoiqL0nVAS2WfARGACEAPcC2xzslCKoih9IZSmZQfwMPA+1hXMDcB+JwulKIrSFxyZs19RFKU/0Tv7FUVxPZrIFEVxPaYTmZNDmTYAdUC5YS9YV2U/BCqw+v9+YdA9GPgU+Nzvftqgu4soYC+Qb9h7DNgHlAElht0Aw4HNwAGs2N9myJuMVeaurQnINeQG+CesY1kOvIF1jE3xC793P2bKbPe9uRLYARzy/00w6F6EVXYfELRsm2PYTeR/mVuUiFSJSJKIxIjI5yKSYtB/h4jcLCLlBp1d2yi/GxGJF5GDBsseISJx/sdXiMhfRGSW4fL/s4hsEpF8w95jInKVA/Hu2l4VkWX+xzEiMtyBz4gSkVoRGWfIN0ZEjorIEP/zN0XkHwy5U8U6v4eKSLSI7BSRiWE67b43q0Vkpf/xShH5N4PuKSKSLCJFIjLdgeNpu5mskTk9lOlPQINBX3dqgD3+x2exagemVnMQ4Jz/8RX+zeQVlmuBu4CXL/XCbxjfA+4AXvE/bwPOOPA5mUAVYHKkSTQwxP93KObuq5wCfAJ8jXW3wEfAD8N02n1v7gFe9T9+Ffg7g+4KrFZZv2IykdkNZTK/tIvzjAduAv5i0BmF1cSpw6rKm3T/B/A4VlXeNAL8L1AKPGjYnQR8CfwXVrP4ZSDW8GeAdd/jGwZ9J4F/B7xYP4CNWDEyQTlWch+BlSCz6Xkzuimuxio7/r99W5zyG4jJRNbnoUzfQOKAt7H6JpoMejuBaVi1p5lAqiFvDlZyLDXku5DbgZuxZj75R6wvmSmi/e4XsH44mjHfrxoD3A28ZdCZgFWjmQCMxkq+f2/IXQH8G9aP3XasftUOQ+5vNSYTmduHMl2BlcQ2Alsc+owzQBHWRRET3I71RT2G1ZSfC7xuyA1/O351wDtYSdgUJ/xbV+10M1ZiM8lCrC6DUwad84CjWLXJdqxzZbZB/ytYcbgDq9l2yKC7i1PAKP/jUVjH19WYTGRuHsoUgXUCVQBrDLsTsa7OgdWvMg/rKp0J/gXrB2M8Vrw/wFztIBaI7/Y4C7NXjGuxuiKS/c8zgb8a9IM1d57JZiVYTcpZWE2/CKxyVxj0dzXzrgN+hPnyg/W9/Kn/8U+BrQ58Rv9i+OpBtlhX/KpE5AnD7jdEpEZE2kXkhIgsNehOE4v/E5Ey/5ZtyH2DiOz1u8tF5F8dunIzR8xetUwS68rz5yKy34HjiYhME5ESf2zeFZEEg+6hIlIvIsMcKPfTInLAfzxfE5FBBt27ROSv/rhnGvDZfW9GiEihiBzy/73SoPuH/setInJKRN53IP5Bmw5RUhTF9eid/YqiuB5NZIqiuB5NZIqiuB5NZIqiuB5NZIqiuB5NZIqiuB5NZIqiuJ7/B2iZMbxnftKEAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 360x108 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "dark"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Final policy obtained with max-q:\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 360x108 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "dark"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "\n",
    "q_learning_run_index = 1\n",
    "max_q_learning_run_index = 1\n",
    "\n",
    "print(\"\\nFinal policy obtained with q-learning:\")\n",
    "\n",
    "arrow_dict = {'^': 1, 'v': -1, '>': 1, '<': -1}\n",
    "X = np.array([np.arange(0, experiment['w'], 1).tolist()]*experiment['h']).astype(float)\n",
    "Y = np.flip(np.transpose(np.array([np.arange(0, experiment['h'], 1).tolist()]*experiment['w'])), axis=0).astype(float)\n",
    "U = np.zeros((experiment['h'], experiment['w']))\n",
    "V = np.zeros((experiment['h'], experiment['w']))\n",
    "\n",
    "U[q_final_policy_over_runs[q_learning_run_index] == '>'] = 1\n",
    "U[q_final_policy_over_runs[q_learning_run_index] == '<'] = -1\n",
    "V[q_final_policy_over_runs[q_learning_run_index] == '^'] = 1\n",
    "V[q_final_policy_over_runs[q_learning_run_index] == 'v'] = -1\n",
    "X[q_final_policy_over_runs[q_learning_run_index] == '>'] -= 0.25\n",
    "X[q_final_policy_over_runs[q_learning_run_index] == '<'] += 0.25\n",
    "Y[q_final_policy_over_runs[q_learning_run_index] == '>'] += 0.25\n",
    "Y[q_final_policy_over_runs[q_learning_run_index] == '<'] += 0.25\n",
    "Y[q_final_policy_over_runs[q_learning_run_index] == 'v'] += 0.5\n",
    "\n",
    "plt.figure(figsize=(5,1.5))\n",
    "plt.grid()\n",
    "q = plt.quiver(X+0.5, Y+0.25, U, V)\n",
    "#plt.axis('off')\n",
    "plt.xticks(ticks=np.arange(0, experiment['w'], 1), color='w')\n",
    "plt.yticks(ticks=np.arange(0, experiment['h'], 1), color='w')\n",
    "#plt.gca().axes.xaxis.set_ticks([])\n",
    "for tic in plt.gca().axes.xaxis.get_major_ticks():\n",
    "    tic.tick1On = tic.tick2On = False\n",
    "for tic in plt.gca().axes.yaxis.get_major_ticks():\n",
    "    tic.tick1On = tic.tick2On = False\n",
    "plt.ylim(0,experiment['h'])\n",
    "plt.xlim(0,experiment['w'])\n",
    "plt.show()\n",
    "\n",
    "print(\"Final policy obtained with max-q:\")\n",
    "\n",
    "arrow_dict = {'^': 1, 'v': -1, '>': 1, '<': -1}\n",
    "X = np.array([np.arange(0, experiment['w'], 1).tolist()]*experiment['h']).astype(float)\n",
    "Y = np.flip(np.transpose(np.array([np.arange(0, experiment['h'], 1).tolist()]*experiment['w'])), axis=0).astype(float)\n",
    "U = np.zeros((experiment['h'], experiment['w']))\n",
    "V = np.zeros((experiment['h'], experiment['w']))\n",
    "\n",
    "U[max_q_final_policy_over_runs[max_q_learning_run_index] == '>'] = 1\n",
    "U[max_q_final_policy_over_runs[max_q_learning_run_index] == '<'] = -1\n",
    "V[max_q_final_policy_over_runs[max_q_learning_run_index] == '^'] = 1\n",
    "V[max_q_final_policy_over_runs[max_q_learning_run_index] == 'v'] = -1\n",
    "X[max_q_final_policy_over_runs[max_q_learning_run_index] == '>'] -= 0.25\n",
    "X[max_q_final_policy_over_runs[max_q_learning_run_index] == '<'] += 0.25\n",
    "Y[max_q_final_policy_over_runs[max_q_learning_run_index] == '>'] += 0.25\n",
    "Y[max_q_final_policy_over_runs[max_q_learning_run_index] == '<'] += 0.25\n",
    "Y[max_q_final_policy_over_runs[max_q_learning_run_index] == 'v'] += 0.5\n",
    "\n",
    "plt.figure(figsize=(5,1.5))\n",
    "plt.grid()\n",
    "q = plt.quiver(X+0.5, Y+0.25, U, V)\n",
    "#plt.axis('off')\n",
    "plt.xticks(ticks=np.arange(0, experiment['w'], 1), color='w')\n",
    "plt.yticks(ticks=np.arange(0, experiment['h'], 1), color='w')\n",
    "#plt.gca().axes.xaxis.set_ticks([])\n",
    "for tic in plt.gca().axes.xaxis.get_major_ticks():\n",
    "    tic.tick1On = tic.tick2On = False\n",
    "for tic in plt.gca().axes.yaxis.get_major_ticks():\n",
    "    tic.tick1On = tic.tick2On = False\n",
    "plt.ylim(0,experiment['h'])\n",
    "plt.xlim(0,experiment['w'])\n",
    "plt.show()\n",
    "\n",
    "#print(q_final_policy_over_runs[q_learning_run_index])\n",
    "#print(max_q_final_policy_over_runs[max_q_learning_run_index])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "FvcZoLqYf3Ul"
   },
   "source": [
    "#### Visualizing the learned q-values (both dominant and expected across the action dimension)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 745
    },
    "id": "5Nu3E4SLf3Ul",
    "outputId": "bc730f4c-6404-400f-bb6d-840b73db8e0b"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Visualizing the learned q values for q-learning\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1440x360 with 8 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Visualizing the action wise maximum q values for q-learning\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Visualizing the learned q values for max-q\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1440x360 with 8 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Visualizing the action wise maximum q values for max-q\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "action_list = ['Up', 'Down', 'Left', 'Right']\n",
    "q_learning_run_index = 1\n",
    "max_q_learning_run_index = 1\n",
    "\n",
    "print(\"\\nVisualizing the learned q values for q-learning\")\n",
    "plt.figure(figsize=(20,5))\n",
    "for i in range(4):\n",
    "    q_vals_to_plot = q_final_q_values_over_runs[q_learning_run_index][:,i]\n",
    "    q_vals_to_plot = np.flip(np.reshape(q_vals_to_plot, (experiment['h'], experiment['w'])), axis=0)\n",
    "    plt.subplot(141+i)\n",
    "    plt.title(action_list[i])\n",
    "    plt.imshow(q_vals_to_plot)\n",
    "    plt.xticks(ticks=np.arange(0, experiment['w'], 1), color='w')\n",
    "    plt.yticks(ticks=np.arange(0, experiment['h'], 1), color='w')\n",
    "    for tic in plt.gca().axes.xaxis.get_major_ticks():\n",
    "        tic.tick1On = tic.tick2On = False\n",
    "    for tic in plt.gca().axes.yaxis.get_major_ticks():\n",
    "        tic.tick1On = tic.tick2On = False\n",
    "    plt.gca().axes.set_xticks(np.arange(-.5, experiment['w'], 1), minor=True)\n",
    "    plt.gca().axes.set_yticks(np.arange(-.5, experiment['h'], 1), minor=True)\n",
    "    plt.grid(which='minor', color='k', linestyle='-', linewidth=1)\n",
    "    for tic in plt.gca().axes.xaxis.get_minor_ticks():\n",
    "        tic.tick1On = tic.tick2On = False\n",
    "    for tic in plt.gca().axes.yaxis.get_minor_ticks():\n",
    "        tic.tick1On = tic.tick2On = False\n",
    "    plt.colorbar(fraction=0.023, pad=0.04)\n",
    "plt.show()\n",
    "\n",
    "print(\"\\nVisualizing the action wise maximum q values for q-learning\")\n",
    "q_vals_to_plot_max = np.max(q_final_q_values_over_runs[q_learning_run_index], axis=1)\n",
    "q_vals_to_plot_max = np.flip(np.reshape(q_vals_to_plot_max, (experiment['h'], experiment['w'])), axis=0)\n",
    "plt.title('Maximum q value across actions')\n",
    "plt.imshow(q_vals_to_plot_max)\n",
    "plt.xticks(ticks=np.arange(0, experiment['w'], 1), color='w')\n",
    "plt.yticks(ticks=np.arange(0, experiment['h'], 1), color='w')\n",
    "for tic in plt.gca().axes.xaxis.get_major_ticks():\n",
    "    tic.tick1On = tic.tick2On = False\n",
    "for tic in plt.gca().axes.yaxis.get_major_ticks():\n",
    "    tic.tick1On = tic.tick2On = False\n",
    "plt.gca().axes.set_xticks(np.arange(-.5, experiment['w'], 1), minor=True)\n",
    "plt.gca().axes.set_yticks(np.arange(-.5, experiment['h'], 1), minor=True)\n",
    "plt.grid(which='minor', color='k', linestyle='-', linewidth=1)\n",
    "for tic in plt.gca().axes.xaxis.get_minor_ticks():\n",
    "    tic.tick1On = tic.tick2On = False\n",
    "for tic in plt.gca().axes.yaxis.get_minor_ticks():\n",
    "    tic.tick1On = tic.tick2On = False\n",
    "plt.colorbar(fraction=0.023, pad=0.04)\n",
    "plt.show()\n",
    "    \n",
    "plt.figure(figsize=(20,5))\n",
    "print(\"Visualizing the learned q values for max-q\")\n",
    "for i in range(4):\n",
    "    max_q_vals_to_plot = max_q_final_q_values_over_runs[max_q_learning_run_index][:,i]\n",
    "    max_q_vals_to_plot = np.flip(np.reshape(max_q_vals_to_plot, (experiment['h'], experiment['w'])), axis=0)\n",
    "    plt.subplot(141+i)\n",
    "    plt.title(action_list[i])\n",
    "    plt.imshow(max_q_vals_to_plot)\n",
    "    plt.xticks(ticks=np.arange(0, experiment['w'], 1), color='w')\n",
    "    plt.yticks(ticks=np.arange(0, experiment['h'], 1), color='w')\n",
    "    for tic in plt.gca().axes.xaxis.get_major_ticks():\n",
    "        tic.tick1On = tic.tick2On = False\n",
    "    for tic in plt.gca().axes.yaxis.get_major_ticks():\n",
    "        tic.tick1On = tic.tick2On = False\n",
    "    plt.gca().axes.set_xticks(np.arange(-.5, experiment['w'], 1), minor=True)\n",
    "    plt.gca().axes.set_yticks(np.arange(-.5, experiment['h'], 1), minor=True)\n",
    "    plt.grid(which='minor', color='k', linestyle='-', linewidth=1)\n",
    "    for tic in plt.gca().axes.xaxis.get_minor_ticks():\n",
    "        tic.tick1On = tic.tick2On = False\n",
    "    for tic in plt.gca().axes.yaxis.get_minor_ticks():\n",
    "        tic.tick1On = tic.tick2On = False\n",
    "    plt.colorbar(fraction=0.023, pad=0.04)\n",
    "plt.show()\n",
    "\n",
    "print(\"\\nVisualizing the action wise maximum q values for max-q\")\n",
    "max_q_vals_to_plot_max = np.max(max_q_final_q_values_over_runs[max_q_learning_run_index], axis=1)\n",
    "max_q_vals_to_plot_max = np.flip(np.reshape(max_q_vals_to_plot_max, (experiment['h'], experiment['w'])), axis=0)\n",
    "plt.title('Maximum q value across actions')\n",
    "plt.imshow(max_q_vals_to_plot_max)\n",
    "plt.xticks(ticks=np.arange(0, experiment['w'], 1), color='w')\n",
    "plt.yticks(ticks=np.arange(0, experiment['h'], 1), color='w')\n",
    "for tic in plt.gca().axes.xaxis.get_major_ticks():\n",
    "    tic.tick1On = tic.tick2On = False\n",
    "for tic in plt.gca().axes.yaxis.get_major_ticks():\n",
    "    tic.tick1On = tic.tick2On = False\n",
    "plt.gca().axes.set_xticks(np.arange(-.5, experiment['w'], 1), minor=True)\n",
    "plt.gca().axes.set_yticks(np.arange(-.5, experiment['h'], 1), minor=True)\n",
    "plt.grid(which='minor', color='k', linestyle='-', linewidth=1)\n",
    "for tic in plt.gca().axes.xaxis.get_minor_ticks():\n",
    "    tic.tick1On = tic.tick2On = False\n",
    "for tic in plt.gca().axes.yaxis.get_minor_ticks():\n",
    "    tic.tick1On = tic.tick2On = False\n",
    "plt.colorbar(fraction=0.023, pad=0.04)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "igoqaOlxf3Un"
   },
   "source": [
    "#### Visualizing the environment i.e. reward structure, agent starting location etc."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 157
    },
    "id": "KlNnfNkWf3Uo",
    "outputId": "db16d0ae-cbec-4f4a-ea90-1c9caaad1d21"
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAc4AAACMCAYAAAD1AUljAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjEsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8QZhcZAAAgAElEQVR4nO3de1xU9b7/8dcwIAzCDKCogXghb3jFW+YlRNQsNStR062kbq22O3PX0cza9WibWWlq1t5u2+1SS/vZCd3eUsAb5q1OEkiJpZioGBcREBlgkMv8/hiZnBiUkTWu8ZzP8/Hw4azF11lvFzPr813f9Z01GrPZjBBCCCHqx03tAEIIIcTdRAqnEEII4QApnEIIIYQDpHAKIYQQDpDCKYQQQjhACqcQQgjhAHdnPKlGo5HPuAghhLhr+fj4UFxcrLH3M6cUToDly5c766kdNnfuXN599121Y1i9+OKLLF26VO0YVvPnz+edd95RO4aNBQsW8Pbbb6sdw+rll1/mzTffVDuG1auvvsprr72mdgyrRYsW8de//lXtGFaLFy+mdevWasewcf78ebUj1LJ27Vq1I1hNnz7dpfIsXLiwzp/JUK0QQgjhACmcQgghhAOkcAohhBAOkMIphBBCOEAKpxBCCOEAKZxCCCGEA6RwCiGEEA6QwimEEEI4QAqnEEII4QApnEIIIYQDpHAKIYQQDnDavWrr4/Dhwxw7dozs7Gx69uzJpEmT6mz79ddfk5iYSEVFBd26dWPcuHG4uysb/8iRIyQlJZGdnU14eDgTJ0602y4nJ4cdO3Zw8eJFSktLnXYf3Jo8OTk5hIeH88QTT9htl5SUxJEjR7h8+TJeXl6Eh4fz0EMPodVqFc1z9OhRvv/+e3JycujRowcTJkyw2y41NZU9e/ZQXFyMu7s7HTt2ZMyYMXh5eSmapyZTcnKyNdP48eNv+W/+/e9/c/bsWd58803F99G3335LcnIyubm5dO/enejoaLvtkpOT2bJlCx4eHtZ1U6ZMITQ0VNE8lZWVxMXFkZGRQVlZGf7+/kRFRdGuXbs68x89epTKyko6derEyJEjFX2fVVZWEh8fT0ZGBiaTCX9/fyIjI+3muXTpEvv27SM7O5uysjKn3As3LS3NZtnLy4v169fzt7/9rVbb6Ohopk2bRps2bTAajWzbto13332XqqoqRTN16tSJVatW0bt3b/Ly8njxxRfZunWr3bbPP/88L730Ejqdjs2bNzNr1iyuXbumaB6j0cjatWs5ceIEvr6+REdH079//1rtzGYzsbGxHDx4EICIiAjGjx+PRmP3Pul3dab6vCNCgM+AFkA18BHwfoO2ep1er2fYsGGcOnWKioqKOtv9/PPP7N+/n1mzZqHX61m3bh3x8fGMHj1aiRg2eYYOHXrLPG5ubvTo0YP+/fvz6aefKprBXp7Tp0/fNE9FRQVjxowhJCSEkpIS1q1bx8GDBxkyZIjieaKiom6Zp3Xr1syaNYvGjRtTXl7Oli1b2L17N2PGjFE0T02mIUOGkJ6eftNMNVJSUqiurlY8Rw1fX18iIyM5c+bMLfOEhITw9NNPOy0LQHV1NXq9nieffBKDwUB6ejqbN2/mmWeewc/Pz6btL7/8wtGjR5kyZQq+vr7Exsby9ddfM3ToUMXzxMTEYDAYOHPmDFu2bOGpp56qlUer1RIWFkavXr3YtGmTYhlu1KVLF+tjnU5HUlISu3btsttWp9PxxhtvcPz4cQICAvj4448pKipi9erViuXRarVs27aNDz/8kOHDhzN48GB27NhBz549SU9Pt2n74IMPsmDBAqKiosjKymLLli0sXLiQl19+WbE8ABs2bECr1fL+++9z4cIFVq5cSatWrQgODrZpd+DAAVJSUnjjjTfQaDQsW7aMwMBAxY9DrpCpPkO1lcBcIAy4H3gW6NygrV7XvXt3unXrRuPGjW/aLikpiX79+tGiRQu8vb0ZNmwYSUlJSkSw0a1bN7p27XrLPM2aNeO+++6jRYsWimewl8fb2/um7fr370/btm1xd3fHYDDQs2dPzp07p3ierl270qVLl1vm8fPzs9mHGo2G/Px8xfM4kgnAZDKxb98+Hn74YadkAcuBuHPnzuh0OqdtwxGNGjVi8ODB+Pn5odFo6NChA35+fmRnZ9dqm5qaSnh4OM2aNUOn0/HAAw+QmpqqeJ6IiAhrnvbt2+Pn50dOTk6ttk2aNCE8PJzAwEBFM9Rl5MiR5Ofn891339n9+YYNGzh27BgVFRXk5uaydetWevfurWiGTp06ERQUxHvvvUd1dTWJiYkcOXKEmJiYWm2nTp3KJ598wsmTJ7ly5QqLFi1i2rRpiuYpLy8nKSmJsWPH4uXlRYcOHQgPD+fo0aO12h45coQRI0YQEBCAv78/I0aM4PDhw4rmcZVM9TnjzL7+B6AY+AkIBk42eOv1lJOTY9MzDAoKori4mJKSklsWuf+LMjIyaN68uaoZzp07x9q1aykvL8fDw8PuG/9OS0hI4P7778fX11ftKABkZ2fz1ltvodPpCA8PJyIiQvGh498zGo3k5+fbLUZ5eXl07NjRuty8eXNKSkooLS2tV8ekIXmaNm3qlOd3RHR0NP/5z3/q3b5fv361zgIbyt4QokajoWvXrrXWd+nShW3btlmXU1NTadGiBQEBARQUFCiSJycnBzc3N5uThJCQEE6dOlWrbVZWFiEhITbtsrKyFMnhapkcnRzUBugJ/E+Dt+yAa9eu2fTgax6Xl5ffyRh3hWPHjnHx4kUGDx6sao42bdpYh40iIiLw9/dXNc/Fixc5f/683esgamjTpg3PPfccCxYsYNKkSfzwww9O6Z3fqKqqiq1bt9KjRw+7haqiogJPT0/rcs1jpa+Z3Zhn27ZtdO/eXfXCGRQURL9+/eo9JDx+/Hi6devGRx99pGiOn3/+mUuXLvHiiy/i7u5uHa6113Hx8fGhqKjIulzzWMmOYXl5ea3RE29vb0wmU622JpPJJqdOp8NkMmE2mxXL4yqZHCmcPsBm4HngaoO26qBGjRrZ7JSaxze+yQWcOHGCuLg4/vjHP7rMmbjBYKBjx45s3LhRtQzV1dVs27aN0aNHO/2Mrr4CAgIICAiw9pyHDBlSa6KKksxmM1u3bkWr1fLQQw/ZbePh4WHTGa153KhRI6fk2b59O1qtlhEjRij+/I4aO3YsSUlJXLx48ZZtH3zwQebPn8+0adMoLCxUNEdlZSWPPfYYo0aNIicnh7lz5/Lll1/azWU0GtHr9dblmsfFxcWK5fH09KxVkMrKyuxO9PPy8qKsrMy6bDKZ8PLyUnxykCtkqm/h9MBSND8H6j+WoZAWLVrYnF5nZWXh6+vrMsXBFZw6dYrNmzczbdo07rnnHrXj2KiurnbaNc76KC8v59dff2Xjxo0sXryYVatWAfDOO++QkZGhWq4baTQaxXvmNcxmMzt27KCkpIRx48bV2XkIDAwkNzfXupybm0vjxo0VH6Y1m8189dVXlJSUEB0d7RKdmbFjx9brbHPw4MG8/fbbzJw50+7QoBJ+/PFHIiMjadq0KQ899BChoaF2r7umpaXRo0cP63KPHj3IyclRbJgWLMfeqqoqm2vQmZmZtSbhgOWsPTMz07p84cIFgoKCFMviSpnqUzg1wCdYrm2uaPAWb1BVVUVFRQXV1dWYzWYqKirsTu3u06cP3333HTk5OZSWlrJ371769OmjZBSH8vz+ZxUVFVRWVjotj9lsvmmeM2fOsHHjRmJiYmjVqpXiORzNk5KSwpUrVzCbzRQWFpKQkFDnxx+UylRdXU11dbXdTF5eXrz88svMmTOHOXPmMHXqVABmz55tc/1DyTxms7nOPACnT5/GaDQClmuLiYmJhIWFKZqlxq5du7h8+TITJ060+fjL73Xv3p3jx4+Tl5dHWVkZhw8ftjkwKyUuLo7Lly8zYcKEm+Yxm81UVlZa919lZaVT3me9evWiRYsWdc6mrdG/f39WrlzJrFmzFJ80daNu3brh6emJTqdj7ty53HPPPaxbt65Wu88++4wZM2YQFhaGn58fr776qt12DeHp6Unv3r3ZunUr5eXlpKenk5KSwoABA2q1HThwIAkJCRQWFlrf94MGDVI0j6tkqs/koIFADPAjcPz6uleAm7/K6mHv3r3s3r3buvz999/z4IMPct9997F06VLmz5+Pv78/nTp1YsiQIaxevZqKigq6d+9e53BTQ+zbt489e/ZYl5OTkxk+fDh9+/Zl2bJlzJs3D39/fwoLC3n77bet7V555RX8/f155ZVXFM+zd+9emzzDhg2jb9++LF++nLlz5+Lv78/evXsxmUysWbPG2rZt27bMmDFD0Tz79+9n37591uWUlBSGDh1K3759WbFiBf/1X/+Fn58fly5dIi4ujrKyMnQ6HZ06dXLacFxiYqJNpuPHjzN06FD69OnDe++9xwsvvICfn5/NdZ+ag6+Pj4/iZzsHDhwgMTHRupyamsqQIUPo3bs3H3zwAXPmzMHPz49ffvmFzZs3c+3aNXx8fOjRo4dTrktfuXKF5ORktFotK1b81u8dNWoUrVq1YvXq1cyaNQuDwUC7du0YMGAA69evp6KigrCwMMUzFRUVkZKSglarZeXKldb1I0eOJCQkhH/9618888wzGAwGioqKrKMDAEuWLMFgMDB79mxFM40bN474+HhKSkps1gcFBbFnzx6GDx9OVlYWc+bMwdfXl7Vr11rbHDt2TPGZrDExMcycORMPDw8OHTrE8OHDuXbtGiEhIZw8eZLOnTuTmZlJQkICS5cuJTEx0fo5ztdff13RLDV51qxZw5w5c/Dx8SEmJobg4GBOnz7NihUr+PDDDwGIjIwkLy+P1157DbB8ZjIyMlLxPK6QSeOM4SGNRmNevny54s97u+bOneu0mxTcjhdffJGlS5eqHcNq/vz5vPPOO2rHsLFgwQKbzonaXn75Zd588021Y1i9+uqr1oOBK1i0aJFTblBwuxYvXkzr1q3VjmHj/Pnzakeo5cZOgNqmT5/uUnkWLlxIRkaG3Yuhcss9IYQQwgFSOIUQQggHSOEUQgghHCCFUwghhHCAFE4hhBDCAVI4hRBCCAdI4RRCCCEcIIVTCCGEcIAUTiGEEMIBUjiFEEIIB0jhFEIIIRwghVMIIYRwgBROIYQQwgFO+3YUxZ9UCCGEuEN69+5NUlKS3W9Hqc/3cd4WV/p6mOnTp+OMDsLt0mg0kucWXC2T5Lk5yXNrrpZJ8txcnz596vyZDNUKIYQQDpDCKYQQQjhACqcQQgjhACmcQgghhAOkcAohhBAOkMIphBBCOEAKpxBCCOEAKZxCCCGEA6RwCiGEEA6QwimEEEI4QAqnEEII4QBVC6fRaOTvf/87zzzzDPPmzeObb76x285sNvPll18ye/ZsZs+ezZdffum0exqazWZeffVVgoODMRgMREZGkpaWVmf7c+fOMWTIELy9venUqRN79+6VPHcwjytmkjx3Vx5XzCR5XDuPqoVzw4YNaLVa3n//fZ5++mnWr1/Pr7/+WqvdgQMHSElJ4Y033mDRokWkpqZy4MABp2SKjY1lzZo1HDp0iIKCAvr3709MTEyd7SdNmkTPnj3Jz89n8eLFjBs3jry8PMlzh/K4YibJc3flccVMkse189SncK4BLgEnbnsrdpSXl5OUlMTYsWPx8vKiQ4cOhIeHc/To0Vptjxw5wogRIwgICMDf358RI0Zw+PBhJeNYZWRkMGjQIEJDQ9FqtUyZMoWTJ0/abXv69GmSk5NZuHAhOp2O6OhounXrxubNmyXPHcrjipkkz92VxxUzSR7XzlOfwrkOeOi2t1CHnJwc3NzcaNGihXVdSEiI3TPOrKwsQkJCbNplZWUpHQmAiRMncubMGU6fPk1FRQWffvopDz1k/7+flpZGaGgovr6+1nU9evS46ZCB5FE2jytmkjx3Vx5XzCR5XDtPfb6P8yDQ5ra3UIfy8nJ0Op3NOm9vb0wmU622JpMJb29v67JOp8NkMmE2m9Fo7H7P6G275557eOCBB+jYsSNarZaQkBD2799vt63RaMRgMNisMxgMdou/5HFOHlfMJHnurjyumEnyuHYe1a5xenp61iqSZWVleHl51Wrr5eVFWVmZddlkMuHl5aVI0fz888/x8fHBx8eHhx9+mIULF3Ls2DEyMzMxmUy8/vrrREVFUVpaWuvf+vj4cPXqVZt1V69etenZSB5l87hiJslzd+VxxUyS5+7Ko1rhbNGiBVVVVeTk5FjXZWZmEhwcXKttUFAQmZmZ1uULFy4QFBSkSI7JkydjNBoxGo3ExcWRmprKE088QcuWLXF3d2fatGkUFhbaHT/v0qULZ8+epbi42LouNTWVLl26SB4n5XHFTJLn7srjipkkz92VR9Uzzt69e7N161bKy8tJT08nJSWFAQMG1Go7cOBAEhISKCwspLCwkISEBAYNGuSUXH379iU2Npbc3Fyqq6tZv349FRUVtGvXrlbbmglNCxcuxGQysWXLFn744Qeio6Mlzx3K44qZJM/dlccVM0ke185Tn2ucThMTE8OaNWuYM2cOPj4+xMTEEBwczOnTp1mxYgUffvghAJGRkeTl5fHaa68BEBERQWRkpFMyvfTSS1y6dInw8HBKSkpo164dmzdvxs/PD4A//elPANZsX3zxBdOmTcPf359WrVqxadMmAgMDJc8dyuOKmSTP3ZXHFTNJHtfOo6nHjQQ2ApFAUyAXeB345KZPqtGY165de9uhlDZ9+nSn3TDhdmg0GslzC66WSfLcnOS5NVfLJHlurk+fPiQlJdmdSFOfM85JCucRQggh7lpyr1ohhBDCAVI4hRBCCAdI4RRCCCEcIIVTCCGEcIAUTiGEEMIBUjiFEEIIB0jhFEIIIRwghVMIIYRwgBROIYQQwgFSOIUQQggHSOEUQgghHCCFUwghhHCAFE4hhBDCAfX5WjHHn1SjcZ3vhhFCCCEc1LhxY4xG421/rdht6fV9L2c9tcOSeyfjat8P+te//lXtGFaLFy/mlVdeUTuGjbfeeouXXnpJ7RhWS5YsYf78+WrHsFq6dCnz5s1TO4bVsmXLmDt3rtoxrJYvX84LL7ygdgwb7733Hs8//7zaMaxWrlzJnDlz1I5h9cEHH9CvXz+1Y1idOHGizp/JUK0QQgjhACmcQgghhAOkcAohhBAOkMIphBBCOEAKpxBCCOEAKZxCCCGEA6RwCiGEEA6QwimEEEI4QAqnEEII4QApnEIIIYQDnHbLvfqoLKrk/BvnKf62GHc/d4JmBxHwcECtdmazmay/Z3F562UAmjzahOA5wWg0dm8jeNuMRiNr167lxIkT+Pr6Eh0dTf/+/e3miY2N5eDBgwBEREQwfvx4xfNUVlYSHx9PRkYGJpMJf39/IiMjadeuXa22ly5dYt++fWRnZ1NWVuaUW/pVVlaSkJBQK8+9995bq+0PP/xAUlISBQUFeHp60qVLFyIjI3FzU66vVllZye7duzl//jwmkwk/Pz8iIiLs5jl58iRHjhzBaDTi7u5OaGgow4YNw9PTU9E8e/bs4fz585SVleHv709ERAShoaE3/XdffPEFFy5cYN68eYrun5pMe/fute4jf39/Bg0aZDfTiRMnSEhIwN39t8PC448/TqtWrRTNs2/fPpvf2QMPPEDbtm3ttr9y5QqJiYlkZmai1Wrp2rUrgwcPVjTP/v37uXDhgjXPwIED7ebZu3cvP//8s3W5uroaNzc3Zs+erWiexMREmzwDBgywm8dsNvPNN9+QlpZGRUUFgYGBREVF0aRJE0XzHDhwgMzMTEwmEwaDgQEDBtCmTRu7bY8ePUp6ejqVlZV06NCBiIgItFqtYnluNGzYMGbOnEnz5s3Jz89n0aJFpKam1mo3ceJEYmJi8PT0JDExkaVLl1JRUdGgbataODOXZKLx0NBtTzfKTpVx5i9n0HXQobtXZ9Pu8n8uc+XAFcI2hoEGzvz5DJ7BngSOC1Q0z4YNG9Bqtbz//vtcuHCBlStX0qpVK4KDg23aHThwgJSUFN544w00Gg3Lli0jMDCQIUOGKJqnuroavV5PTEwMBoOBM2fOsGXLFp566in8/Pxs2mq1WsLCwujVqxebNm1SNMeNeXx9fZkyZYpNnpkzZ9bKU1FRwbBhwwgODqa0tJTY2Fi+/fZbBgwYoGgevV7PH/7wB/R6Pb/88gvbt2/nj3/8IwaDwaZty5YtmTx5Mt7e3ly7do2EhAQOHTrEsGHDFM3j6+vLpEmTrHm2bdtmN0+NtLQ0qqurFctQV6aJEyei1+s5e/YsO3bsYNq0aXYzBQUFMWnSJKflMZvN+Pr68sQTT9jkmTp1aq08VVVVbNq0ifDwcEaPHo1Go6GwsNApecaPH49erycjI4OdO3da33M3GjZsmM3rJSEhQfHOstlsxsfHh3Hjxlnz7Nq1y/qeu1F6ejppaWlMmDABX19fjh49Snx8PJMnT1Y8T3R0NL6+vpw7d464uDgmT56MXq+3afv9999z6dIlJk+eTHV1NTt27ODYsWPcf//9iuWpcd999/Hss8/y6quvcvLkSZo2bWq3Xb9+/XjyySd59tlnuXz5MkuWLOGpp57in//8Z4O2X9/u7UPAKeAMsKBBW7yuqqyKK/uuEDQrCK23Fp+ePvgN9qNgZ0GttgVfFdB8SnMaNW9Eo2aNaDalGfk78pWIYVVeXk5SUhJjx47Fy8uLDh06EB4eztGjR2u1PXLkCCNGjCAgIAB/f39GjBjB4cOHFc0D0KhRIyIiIvDz80Oj0dC+fXv8/PzIycmp1bZJkyaEh4cTGKhsZ+JWeQwGg908vXv3plWrVmi1Wnx9fenSpQsXL15UPM+gQYMwGAxoNBratWtXZx69Xo+3t7d12RkHYXt56vp9geU1d/ToUSIjIxXN8ftMAwcOtGa69957MRgM5ObmOm2bN+Ph4cGAAQPqlSctLQ0fHx/69OmDh4cH7u7uir++PTw86N+/vzVPaGgoBoOBS5cu3fTfVVRUkJ6eTufOnVXLU1RURFBQEAaDATc3N8LCwigoqH38bGie+++/H71ej0ajoW3btuj1ert5MjIy6NGjB15eXnh7exMeHs7JkycVzVNj5syZrFmzhrS0NMxmM3l5eeTl5dVqN3LkSLZv305GRgbFxcWsWbOGUaNGNXj79Tnj1AKrgOHAReAYsB1o0B4pP18OWvBq7WVdp2uvozi5uFbbsl/K0LX/7SxU10GH6aypIZuvJScnBzc3N1q0aGFdFxISwqlTp2q1zcrKIiQkxKZdVlaWonnsMRqN5Ofn19m7utOMRiMFBQX1ypOZmenUog5QUlJy0zwXL14kNjaWa9eu4eHhweOPP65qnoMHDxIeHk7jxo2dmuP3mQoLC+sczsvNzWXVqlV4eXnRuXNn+vXrp/jwcX3zZGVlodfr2bx5Mzk5OTRt2pSoqCinvo5utX9qpKeno9Ppao1G3ck8HTt25PTp0xQWFqLX6zl58iStW7d2ap7S0lKuXLlCQID9S2o3fk2l2WzGaDRSXl6u6CWRmk7CoUOHiI2NxdPTk6+//pp//OMflJeX27QNDQ3l0KFD1uX09HSaNGmCXq/n6tWrt52hPoXzPixnmmevL38BPEoDC2d1WTVaH9uxb62PlurS2sNWv29b085sNis2VFJeXo5OZztE7O3tjclUu0CbTCabsxedTofJZFI0z+9VVVWxbds2unfv7hKFs6qqiu3bt9OtW7db5klNTSU7O5uRI0c6Nc+OHTvo2rVrnQe9li1b8sILL1BcXExqamqdw6dK5fnqq6/qzJOdnc2vv/7K0KFDKS6u3Vl0VqadO3fSpUsXu5latmxpHcK9fPkyO3bswM3NzWlf9VRVVcWuXbvqzGM0GsnMzOSxxx6jVatWJCcns23bNqZPn+6U62ZVVVXExcXRuXNnu4XhRidPnqRz585Oe7/X5ImPjycsLMxunsaNGxMcHMynn36KRqOxzstwZp6EhIQ687Rp04bU1FRatmyJ2Wy2Xm+srKxUtHAGBATg4eFBVFQUf/rTn6isrOTdd99l+vTpfPjhhzZtdTodRqPRulzzuHHjxg0qnPXpSgYDmTcsX7y+rkHcdG5UGats1lWVVOHmXTuSm86NqpLf2laXVOPm7aboi9bT07NWkSwrK8PLy6tWWy8vL8rKyqzLJpMJLy8vp72JzGYz27dvR6vVMmLECKdsw1l5Tp06RWJiIk888YRNZ0PpPF999RVarZbhw4ffsr2vry9t27Zl+/btTsuzc+dOtFqt3WuoZrOZPXv2EBUV5dSzud9vc9euXWi1WoYOHWq3jZ+fn3UYPjAwkAEDBnD69Gmn5YmLi0Or1RIVFWW3jbu7O8HBwbRt2xatVkufPn0oKysjP1/ZyzQ1eeLj49Fqtbecq1BcXMzFixcJCwtTPMeNeRISEm6a59tvvyU3N5cZM2bw3HPP0a9fPzZv3tzgiS915dm9ezdubm51Ts7q27cvgYGBbNy4kdjYWEJDQ3Fzc6t1QtJQNWeVsbGx5OfnU1RUxMaNG+1O5CwrK7MZ0al5XFJS0qAM9XnX2qsGZjvrHOLZ2hOqwHTht2JVll6GLrT2Ttbdq6Ps9G+FqvR0KV6htQtaQ7Ro0YKqqiqb61GZmZl2h2KCgoLIzPytL3HhwgWCgoIUzVOjpiiUlJQQHR3ttBlqjuTZuXMnJSUljB079qZ5fvnlF3bt2sWECRNo1qyZ0/Ls2rWL0tJSHnvssXrvH7PZrPg1zprnjYuLo6SkhEcffdRunvLycnJyctixYwerVq3is88+A2D16tU2ryslM8XHx1NaWsqYMWMceg3dOPSmZJ6EhARKS0t55JFH6szj7KH9G/Ps3r37lnlqnDx5kqCgoFoT4pTMs2fPHkpLSxk9enSdeS5fvkyHDh3w9fXFzc2NLl26YDKZFL/OaTab2bt3L6WlpYwaNarOPO7u7kRGRjJjxgymTZuGTqejWbNmincOi4uLyc3Nrddr8+zZs7Rv39663L59e/Lz8xt0tgn1K5wXgZAbllsCDb6gp9Vp8YvyI/vDbKrKqjAeN3LlwBUCRtUeAggYFUDu57lcu3SNa3nXuLThEu8vysYAAAkzSURBVE0eUW7KNVjOOHv37s3WrVspLy8nPT2dlJQUu7NABw4cSEJCAoWFhRQWFpKQkMCgQYMUzVMjLi6Oy5cvM2HCBDw8POpsZzabqayspKrKcmZeWVlJZWWl4nni4+PrlefcuXNs376d6Ohop3UqAHbv3k1+fj7R0dE3zZOWlsbVq1cxm80UFRVx8OBBu1Pq70QeT09P/vznPzN16lSmTp3KuHHjAHjyySedsq/27t1LQUEBjz/++E330dmzZ6098fz8fL755hu7H31SKs9jjz120zxhYWFkZ2dz/vx5qqurSU5ORqfTKfpxC4B9+/ZRUFDAo48+avNRnLr89NNPik8KutH+/fspKChgzJgxN83TvHlz0tPTKSkpwWw289NPP1FdXa34JYjExEQKCgp45JFHbprHaDRiNBoxm81kZ2fz3XffOW2Y/6uvvmL8+PH4+/tbZ2kfOXKkVru4uDgeeeQR2rRpg6+vL9OnT2fnzp0N3n59rnEeA9oDbYFfgYnAHxq8ZSBkQQjnF57nx2E/ojVoafVyK3T36jCmGDnz3BnCD4cD0DS6KeW/lvPTEz8B0OSxJjSNVv46X0xMDGvWrGHOnDn4+PgQExNDcHAwp0+fZsWKFdbx88jISPLy8njttdcAy+c4nTEzsqioiJSUFLRaLStXrrSuHzlyJCEhIfzrX//imWeewWAwUFRUxKpVq6xtlixZgsFgUPQzZjfmef/9963rH374YUJCQvjoo494+umnMRgMHD58GJPJxH//939b24WEhDBx4kRF8xw/fhytVss//vEP6/oRI0YQEhLCxx9/zMyZM9Hr9eTn53PgwAHrRIV7771X0c8D1uRJTU1Fq9Xa/C4efPBBQkJC+OSTT5gxYwZ6vR4fHx/rz2s6O40bN1a8d35jptWrV1vXDx8+nJYtW7J27VqmT5+OXq/nwoULxMfHc+3aNRo3bkxYWJjiB76rV6/yww8/oNVqba5HDR8+nODgYNatW8e0adPQ6/UEBAQwcuRI69lOs2bNHBpVqG+eH3/8Ea1Wy0cffWRdP3ToUIKDg/nss8948sknrR+9yMrKori4mA4dOiiWoa48//73v23yBAUFsX79emJiYtDr9fTp04fS0lI+//xzKisrMRgMjB492u7lpYbkOXHiBFqtlk8++cS6fsiQIQQHB7NhwwamTJmCr68vRUVF7N69m7KyMnx8fBgwYIDTJiutWbMGPz8/vvzyS65du8a+fftYt24dzZs3Z+PGjUyaNInc3Fy+/fZbNmzYwD//+U/r5zhv3K+3S1PPoZiRwEosM2zXAItv+qQajbnX970aHE4pyb2TWbt2rdoxrKZPn+6UGxTcrsWLF/PKK6+oHcPGW2+9xUsvvaR2DKslS5Ywf/58tWNYLV26lHnz5qkdw2rZsmXMnTtX7RhWy5cv54UXXlA7ho333nuP559/Xu0YVitXrmTOnDlqx7D64IMPnHaGejtOnDiB0Wi0O3GlvjdA2HX9jxBCCPF/mtyrVgghhHCAFE4hhBDCAVI4hRBCCAdI4RRCCCEcIIVTCCGEcIAUTiGEEMIBUjiFEEIIB0jhFEIIIRwghVMIIYRwgBROIYQQwgFSOIUQQggHSOEUQgghHCCFUwghhHBAfb9WzLEn1WjygPOKP7EQQghxZ7Q2m82B9n7glMIphBBC/G8lQ7VCCCGEA6RwCiGEEA6QwimEEEI4QAqnEEII4QApnEIIIYQDXLVwPgScAs4AC1TOArAGuAScUDvIdSFAIvATkAb8Rd04eAHfAalY8ixUN46VFkgBvlI7yHXngB+B40CSulEA8AM2AT9jeS31VzFLRyz7pebPVeB5FfMAvIDl9XwC2Ijlda6mv1zPkoZ6+8besTAA2AOkX//bX+U847Hso2qgjzM26oqFUwusAh4GOgOTrv+tpnVYirmrqATmAmHA/cCzqLuPyoEooAcQjmVf3a9inhp/wVIQXMkQLPvIKW9oB70PxAOdsPzu1NxXp7Dsl3CgN1AKbFExTzAwB8vvqSuW49JEFfN0BZ4C7sPyuxoNtFchxzpqHwsXAPuw5NnHnT3ZsZfnBDAWOOisjbpi4bwPy5nmWeAa8AXwqKqJLL+AApUz3CgbSL7+uBjLAS9YvTiYAeP1xx7X/6j9AeGWwCjgY5VzuCo9EAF8cn35GnBFvTg2hgK/oP5NVNwB3fW/vYEsFbOEAd9i6VBUAl8Dj6uQw96x8FHg0+uPPwUeUznPT1g6Yk7jioUzGMi8Yfki6hYFV9cG6An8j8o5tFiG2C5hGa5RO89KYD6W4RpXYQZ2A98DT6ucJRTIA9ZiGc7+GGisaqLfTMQyNKqmX4FlwAUsHdUiLL87tZzA0tFpgqWIj8RyycYVNMeyj7j+dzMVs9wRrlg4NXbWqX324qp8gM1YrndcVTlLFZZhtpZYRg26qphlNJYC/r2KGewZCPTCchniWSwHQrW4X8+yGkvHqwTXmE/QCBgDxKqcwx/LmVRbIAhLp2KKinl+ApZg6ZTGY5lPUKlinv/TXLFwXsS2J9USdYdIXJUHlqL5OfAflbPc6ApwAHWvCQ/EcvA9h2WoPwrYoGKeGjWv40tYrt/dp2KWi9f/1IwMbMJSSNX2MJbLELkq5xgGZGA5K6/A8h4boGoiy7B6LywdrgIsk3FcQS5wz/XH92B5ff+v5oqF8xiWi8xtsfQ+JwLbVU3kejRY3kQ/AStUzgIQiGWGJliuCQ3DMlNTLS9j6XC1wfL62Y+6ZwtgOWPxveHxg6g7SzsHyyWRjteXhwIn1YtjNQn1h2nBMkR7P5ZhUQ2W/aP2RLOaIdBWWCa/uMJ+Asvxeer1x1OBbSpmuSPc1Q5gRyUwG0jAct1sDZapxWraCEQCTbH00l/nt0kVahgIxPDbRxsAXgF2qZTnHiyTArRYOmNf4jofAXEVzfltlqg78P+wDLmp6TksIxaNsEzGm65uHLyB4cAzKucAy5n4Jixnv5VYrgN/pGoiywhTEyxnwM8ChSpksHcsfAfLe34Glg7HeJXzFAB/x9Kh34nlGDlCyY3Kt6MIIYQQDnDFoVohhBDCZUnhFEIIIRwghVMIIYRwgBROIYQQwgFSOIUQQggHSOEUQgghHCCFUwghhHCAFE4hhBDCAf8ftNVZj9L3a7UAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 720x144 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "dark"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "env_layout = np.flip(np.array([[ 1., 1.1, 1.2, 1.3, 1.4, 1.5, 2., 2.1, 7.2, 9., 0., 0.], \n",
    "                       [ 0., -8., -8., -8., -8., -8., -8., -8., -8., -8., -8., -8.], \n",
    "                       [ 99, 0., 2.1, 2.2, 2.3, 2.4, 2.5, 2.6, 2.7, 2.8, 2.9, 6.]]), axis=0)\n",
    "\n",
    "plt.figure(figsize=(10,2))\n",
    "#plt.imshow(env_layout, cmap='Greys')\n",
    "\n",
    "value = 99\n",
    "masked_array = np.ma.masked_where(env_layout == value, env_layout)\n",
    "cmap = plt.cm.Greys\n",
    "cmap.set_bad(color='limegreen')\n",
    "plt.imshow(masked_array, cmap=cmap)\n",
    "\n",
    "for (j,i),label in np.ndenumerate(env_layout):\n",
    "    if j==2 and i in (8,9):\n",
    "        plt.text(i,j,label,ha='center',va='center', c='w', weight = 'normal', size=12)\n",
    "    elif j==0 and i==11:\n",
    "        plt.text(i,j,label,ha='center',va='center', c='w', weight = 'normal', size=12)\n",
    "    elif j==1 and i>0:\n",
    "        plt.text(i,j,'-8.0',ha='center',va='center', c='k', weight = 'normal', size=12)\n",
    "    elif j==0 and i==0:\n",
    "        plt.text(i,j,'0.0',ha='center',va='center', c='k', weight = 'normal', size=12)\n",
    "    else:\n",
    "        plt.text(i,j,label,ha='center',va='center', c='k', weight = 'normal', size=12)\n",
    "\n",
    "plt.xticks(ticks=np.arange(0, experiment['w'], 1), color='w')\n",
    "plt.yticks(ticks=np.arange(0, experiment['h'], 1), color='w')\n",
    "for tic in plt.gca().axes.xaxis.get_major_ticks():\n",
    "    tic.tick1On = tic.tick2On = False\n",
    "for tic in plt.gca().axes.yaxis.get_major_ticks():\n",
    "    tic.tick1On = tic.tick2On = False\n",
    "plt.gca().axes.set_xticks(np.arange(-.5, experiment['w'], 1), minor=True)\n",
    "plt.gca().axes.set_yticks(np.arange(-.5, experiment['h'], 1), minor=True)\n",
    "plt.grid(which='minor', color='k', linestyle='-', linewidth=1)\n",
    "for tic in plt.gca().axes.xaxis.get_minor_ticks():\n",
    "    tic.tick1On = tic.tick2On = False\n",
    "for tic in plt.gca().axes.yaxis.get_minor_ticks():\n",
    "    tic.tick1On = tic.tick2On = False\n",
    "plt.ylim(-0.5,experiment['h']-0.5)\n",
    "plt.xlim(-0.5,experiment['w']-0.5)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "6ytAI5dtf3U-"
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "colab": {
   "collapsed_sections": [],
   "name": "maxq_gridworld.ipynb",
   "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.6.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
