{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Navigation World MDP\n",
    "\n",
    "The environment is inspired by Navigation Experiment in RHIRL (MacGlashan & Littman, 2015, p. 3695). Additional features were added to support further experimentation."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Warning: OpenAI gym not installed.\n"
     ]
    }
   ],
   "source": [
    "# Other Imports.\n",
    "from simple_rl.tasks import NavigationWorldMDP\n",
    "from simple_rl.agents import QLearningAgent\n",
    "from simple_rl.planning import ValueIteration\n",
    "from simple_rl.tasks.grid_world.GridWorldStateClass import GridWorldState\n",
    "from simple_rl.tasks.navigation.NavigationStateClass import NavigationWorldState\n",
    "from simple_rl.tasks.navigation.NavigationWorldMDP import *\n",
    "\n",
    "# Python Imports.\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "%matplotlib inline\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAckAAAGyCAYAAACP2j9zAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMi4yLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvhp/UCwAAIABJREFUeJzt3X+cHnV97/3Xe3eT7BI2CQgVAnpAKxWyi1SiFAQCKIpWQD3K8bc9peDtrfbUU2y17Wmtj55Ta3uXWvX0NndvvbFiwVqtiSIqYoDcoAI9QEIQQUF+mPBTwkL2ymZ3P+ePmZUrm2v2umb2mrmuvfb9fDz2kZ2Z78z3OzPXtd/Mr/coIjAzM7N99XW6AWZmZt3KnaSZmVkGd5JmZmYZ3EmamZllcCdpZmaWwZ2kmZlZBneSZk1Iepukb5e07OdKekpSfxnLN7P5cSdpPUHSvZIelrS8btzvSNo032VHxKUR8cr5Lgd+2c5X1C37vojYPyKm2rH8WXVFuk0G6sYtScdF3bhNkmqSxiQ9KelmSR+StKyuzEck7Uk79CckXS/pxHa32azbuJO0XtIP/JdON6LL/AJ4dd3wq9Nxs70vIoaBQ4HfB94MXCFJdWUuj4j9gYOBzcBXZk036znuJK2X/DVwkaRVjSZK+oSk++uOlk5Jx6+WNC7pwLqyvy7p0fTI67ckba6b9kpJd0raKel/SrpG0u+k054v6WpJj6XzXzrTHkn/BDwX2Jgekf2BpCPSI76BurZskPS4pLslXVBX70ckfUnS59OjvtslrW2yTf4JeGfd8DuBz2cVjoinI2ITcA5wIvCbDcrsAS4BDgGe1aR+swXNnaT1kpuATcBFGdNvBI4DDgS+CPyLpMGI+DlwA/Af68q+Ffhy2iH8kqSDgC8DHybpIO4ETqovAvwlsBo4GngO8BGAiHgHcB9wdnqK9eMN2ngZ8EA6/xuB/yHpjLrp56RlVgEbgE9lrOuMfwNOlbRK0gHAKcDXmsxDRNxHsj1PmT0tPQ37W8D9EfFos2WZLWTuJK3X/CnwfkkHz54QEV+IiMciYjIi/i9gGfBr6eQvAm8BSE8hvjkdN9trgNsj4isRMQn8PbCjro67I+I7EbE7Ih4B/hZY10rDJT0HeBnwhxFRi4hbgH9k7yPBzRFxRXoN85+AFzVZbA3YCPyn9GdDOq4VPyf5D8WM8yQ9AdwPHA+8vsXlmC1Y7iStp0TEVuDrwIdmT5N0kaQ70tOkTwArgYPSyf8KnCjpUOBUYBq4rkEVq0k6iZn6guTIb6aOZ0u6TNKDkp4EvlBXRzOrgccjYqxu3M+Aw+qGd9T9vgsYrL8xJ8PnSTraOU+1NnAY8Hjd8JciYlVE/EpEnBERN+dYltmC5E7SetGfARdQ17mk1x//ADgPOCAiVgE7SU6PEhG/AL5NcrT1VuCyaPyKnO3A4XXLVf0w8D+AAEYjYgXw9pk6UnO9dufnwIGShuvGPRd4cK6VbcF1JDfkPJvkhpum0qPa42n8HwWzRcOdpPWciLgbuBz43brRw8Ak8AgwIOlPgRWzZv0iydHWG2l8qhXgG8CopNelR3DvJbmBpb6ep4Cdkg4DPjhr/oeA52W0+37geuAvJQ1KOhY4n+RotLC0sz8bOCej4/8lSftJWkdy3fKHwBXzqdtsoXMnab3qo8DyuuFvAVcCPyY5hVmj7rRpagPwAmBHRNzaaKHpjSpvAj4OPAYcQ3KDy+60yJ8DLyY5Sv0G8JVZi/hL4E/SZw0b3WD0FuAIkqPKrwJ/FhFXNVnXpiLi9oi4fY4in5I0RtKJ/x3J6eezImJ6vnWbLWTyS5fNipPUR3JN8m0R8b1Ot8fM2stHkmY5SXpV+kjFMuCPSK45fr/DzTKzEriTNMvvROAnwKMk1/peFxHjnW2SmUn6bBq7uDVjuiT9fRrUcZukFzddpk+3mplZL5B0KsmNc5+PiJEG018DvJ/keecTgE9ExAlzLdNHkmZm1hMi4lr2frZ3tnNJOtCIiO8Dq9JnozO5kzQzs8XiMPa+q/0B9g7r2EezpI6OOOCAA2L16tW55hka2par/Pj4MbnK95Khbfm2VfJMeT7jx+S7RJd3/0E1+3BbznYd06WfqyLbN7dC+Ts5P1vH568k7+ekWz+LeeX97EI1n99t27Y9GhEHA0hnRXJpvxU3387ekYrrI2J92xs4S1d2kqtXr+byyy/PNc/IyGiu8lu35lt+LxkZzbetkscA89l6ecPr5pny7j+oZh+O5mzX5V36uSqyfXMr9NKsnJ+tm/JXkvdz0q2fxbzyfnahms/v6Ojoz54ZepTWPwOqRUSzt9408yDJSwdmHE6TRCufbjUzs8ViA/DO9C7X3wB2RsT2uWYo7UhS0giwHpgC7gZ+m+SNCGuBf48IvxzXzMzaRtI/A6cBB0l6gCTHeQlARPzfJDGLryHpk3YB/7nZMss83XpnRJwEIOlzwEuB/SPiFEn/IOklEXFjifWbmdkiEhFvaTI9SPKWW1ba6dZZL6vdDbwc+E46fBXJA9lmZmZdq9RrkpLOSZMPnk1yyPtkOmknyZvV68teKOkuSY9s3z7nKWIzM7NKlNpJRsSGNPXgAZLXFM28mmgF8MSssusj4gURcfChh875bKeZmVklSusk0/DnGU+SvGz25enwK3AgtJmZdbkyjyTPknSNpGtITrd+DKhJug6Yiogflli3mZnZvJV2d2tEfI3k7eb1/NiHmZktGA4TMDMzy9CVsXRWrq1btuQqPzqSPwos7wvYtm7N16YiisSNbamgXVWoYvtSqIp88YUUWI+R0X3emNSkit7Y573y2e00H0mamZllcCdpZmaWocxHQE6QdL2kzZIuTsd9UtImSZ+V1F9W3VUJ4OfDsO3g5N+8pxjNzLrdfvv1sWrVAPvttziPqcq8Jvkz4IyIqEm6VNIpwNKIOE3S7wOvZd+7XxeMAK49Ah4fgqk+6J+GA8fh1HsLvjHIzKzLHHLIUgYH+5AgAmq1aXbsmOh0sypVZnbrjoiYeUHmHuAM4LZ0+BbgpLLqrsL24bSD7BdITPWLx4eS8WZmC91++/UxONhHX5+QRF+fGBzsW3RHlKWvraRjgYNJjhrXpaPPYFZ2a1r2bEnrx8bGym7WvD0xmBxB1pvqg52DnWmPmVk7LV2aHEHWk5Lxi0nZAecHAp8Czo+IW4Ctkr5Hkt360OzyEbExIi4cHu7+w7FVteQUa73+aVhZa1zezGwhmZiYJmbdaBGRjF9MyrxxZwD4AnBRROwAiIiPRsTpwGPAN8qquwqHjiXXIImACPqnggPHk/FmZgvdrl3T1GrTRAQRwfR0UKtNs2uXO8l2eRPwEuDj6R2tL0v//S4wERE/KLHu0onkJp0Vu2G/PXDCA75px8x6y44dE0xMTDM5GTz88MSiu2kHys1u/Wfgn2eNPq2s+jpBwNKp5Ge1jyDNrAdNT8P0dCy6I8gZi+sKrJmZWQ49k91aSTZlFyqSR5p3WxUJSchbR958TYCtW3LmfqrAmuSso4r9Yfnk/Zx4H7ZutMC2Wmh8JGlmZpbBnaSZmVkGd5JmZmYZSrsmKekE4GJgGrgR+H3g88BzgQngzRHxaFn1my1UU8Dm4WHuGBzk6FqNk8fGWPBvAzBboCoLOAdOIXk+8lRJbwPeBnyixPrNFpwp4N1HHMGWoSHG+/oYmp5mdHycz9x7rztKsw4o8znJHXWDe9J/Z77nq0hSd8yszubhYbYMDbGrP/mq7Orv57ahITYPD7NuAWQaW3HDw/3sv3/3/Vdo6dK+RRdFV6/KgPPNwJCkO4D3AF9pUHbBBJybleGOwUHG+/b+Wtb6+vjRoJPze93++/d3ZXj4xMQ0Tz011elmdEypz0nWBZyfB7wSeCQijpb0RuAi4KP15SNiI7BxzZo1F5TZLrNudXStxtD09C+PJAEGp6d5Yc3J+YvBxMQ027cvvui3blZlwLmAx9PJjwIry6rbbKE6eWyM0fFx+tLg/KGpKY4dH+dkn10x64gyjyTrA84B/htwtKRNJJ3zfy6xbrMFqR/4zL338sZf/VV29fXxR9u3++5Wsw6qOuD8urLqM+sV/cCqqSlWTU35Zh2zDuu+q8RmZmZdomcCzqvQKPj4Rj6XTtv37HEVoce9EqycO6y8iMj/ts+RnKHoW7f0xv4oooqQ+iLh43kV+U7lbVehOkZz1lHgs5i3jijwzoCF9s5dH0mamZllcCdpZmaWwZ2kmZlZhioDzi8B/i6d/B+AT0TE32XMbrZoTU1N8cQ3v8muW2/lmkMO4eSTT6a/3w+BmHVClQHnUxFxGoCkrwFfL7FuswVpamqKd7/73fx061amd+3iD4aGGB0d5TOf+Yw7SrMOKO10a0TsiIiZLK09JC84QNJy4JCIuLusus0Wqs2bN7Nlyxamn34aIti1axe33XYbmzdv7nTTzBalygLOI2JbOurVwJUZZR1wbovaHXfcwfj4+F7jarUaP/rRjzrUIrPFrdROsi7g/Py60a+nwRtAIAk4j4gLh4eHy2yWWdc6+uijGRoa2mvc4OAgL3zhCzvUIrPFrcqAcyQtAY6OiFvLqtdsITv55JMZHR2F9HVZQ0NDHHvssZx88skdbpnZ4lRlwPmHgRXA1SXWabag9ff385nPfIbfeOtbmX7qKf76D/7Ad7eadVDVAecA3yqrTrNe0N/fz8CBB8KBB7Ju3bpON8dsUevK7NahoW2lZyEWy5nct46nj0yn3dO7mZ09kw9bZD2qyJTtEUXyd6vII80rb5sAyJlh2ujvW612aTrtbQ3nybvuowVybnNnsebMNk5nKjBP5zhxx8zMLIM7STMzswzuJM3MzDKU+QjICZKul7RZ0sXpuDMlXS1pk6Tjy6rbzMysHSrLbpU0CrwbODMipkqs18zMrC3KfARkR93gHuAUkjeCfFPSQ8D/ERFPl1V/lXYOwqYjO90K6yUr+iZ49NY7eNV7z29euM6vv+4cPnbmuSW1ymzxqSy7FfgFcChJduv1JEeVs8ueLWn9zp1lt6p9nvsErKw1L2eWx6+f95sc9KKjc83z2K138L/+bUNJLTJbnEp9TrIuu/U84MXA5oiYknQ1cNHs8hGxEdi4dq0uKLNd7fS8XyQ/Zu102ro3wLo35Jon71GnmTVXZXbrjcDMf42PA+4pq24zM7N2qDq79RpJ1wK7gLeWWLeZmdm8VZ3degNwcVl1mpmZtZPDBMzMzDJ0ZcD5+PgxbN16ea55ujEouYi8we5FdGNgeZH1zh1qX2Tb5s5iribwuZKg75JfMgDd+T0s0qYR5r+tDj10KQB339192yRLkVD7nJuq43wkaWZmHXE8yX8rW/npFHeSZmZmGdxJmpmZZag64HxnGm6+KQ0aMDMz61pVB5xviYjTSqzTzMysbUo7koyIHRExk2q6B5gCjpZ0naSPKU0YMDMz61aVBZxHxDbgBcCpwAHA2bPKXSjpLkmPbN++vexmmZmZNVVqJ1kXcH4+QEQ8HhEB/BswUl82ItZHxAsi4uBDDz20zGaZmZm1pLKAc0nLJfWnk18G/KSsus3MbPGS9EJJN0jaLemiWdPOknSnpLslfajZsso8kqwPON8EHAvcmAacPwf4col1m5nZ4vU48LvA39SPTA/UPk3yXuNjgLdIOmauBVUdcP7isuozMzMDiIiHgYcl/easSS8F7o6InwJIugw4F9iWtayuzG4tohszIEcLZIVuWaS5qlXkyRapYzTyrXsUyWHtwn0O3dmuKj6LRXTjtirytyRvEmvezOwucBhwf93wA8AJc83QM52kmZn1tIMk3VQ3vD4i1pddqTtJMzNbCB6NiLVZEyW9F7ggHXxNRPy8QbEHSe6JmXF4Oi6Ts1vNzGzBi4hPR8Rx6U+jDhLgRuAFko6UtBR4M7BhruVWmt2ajn+DpPvnmtfMzKwoSYdIegD4r8CfSHpA0oqImATeB3wLuAP4UkTcPteyKs1ujYgtwBvZ+8KpmZlZ20TEDpJTqY2mXQFc0eqyKs1ulfQa4Cpguqx6zczM2qXq7NZ3kaTwZJU9W9L6sbGxsptlZmbWVGXZrZLOAG6IiIms8hGxMSIuHB4eLrNZZmZmLaksu5Uk0PwcSVcCayT9RVl1m5mZtUOZN+7UZ7cCfDgi/h5A0uaI+JMS6zYzM5u3qrNbZ6adXFa9ZmZm7eIwATMzswxdGUs3tG2IkdGR5gXrbN2SN5q3fEUChvMGOHdreHMV65E3XLlICH7kLF9sPfJ91gGIfYPUpeOT5TXY9oXC3XPuw7zbCrozCN9aV+jFEgssFN1HkmZmZhncSZqZmWVwJ2lmZpahsoBzSQelw9dI2iBpqKy6zczM2qHMI8mZgPOTgV8heSP0yRGxDrgZeG2JdZuZmc1bmc9J7qgb3APsiYiZYPN+4K6y6jYzM2uHSgPOJb1U0k3AGcA9DcqeLWn9TnaW3SwzM7OmKgs4B4iIH0bEWuCrwG/PLj8TcL6SlWU2y8zMrCWVBZxLWlo3+UlgvKy6zczM2qHKgPM/k/RRkhcuPw68o8S6zczM5q3qgPN1ZdVnZmbWbl2Z3Zo8IbJvNuXcui/TMW9+KfRONmUV66GcYaFB+ZmRefNOAbYUyb9ssH0jzk8mtWnbR84N3I35yUUU2oc5t3mjvw212qXptLc1nKdX/jYsNE7cMTMzy+BO0szMLIM7STMzswylXZOUdAJwMcndrDcCfw98nuS1cw8A74iIqbLqNzMzm68qs1sPB14bEaeSpO28psS6zczM5q3K7NbHImJn3bCPIs3a7LFb7+BV7z2/5fK//rpz+NiZ55bYIrOFrfRHQOqzW9Ph1cCZwF80KHs2cPavlt0osx706687h/+Vo/xjt96RlHcnaZap1E6yLrv1vHR4GXAJcEFETM4uHxEbgY1rpQvKbJdZL/rYmefm6vDyHHGaLVaVZbemo9cDn545qjQzM+tmZd64U5/duknSicAbgN9Lh19fYt1mZmbzVnV263BZ9ZmZmbWbwwTMzMwydGnA+fHATbnmGBnNF4i+tUCo9MjoSOl1FAlXzitnLnihYOWR0XzrUWRbVbEeeVUVQZ3/s5g/fLyKwPLRnOuxpYI25f1cAeRtVaPP4qGHJq/cvfvuzgWZ5/3eFttaC4uPJM3MzDK4kzSz7rJ8Ej66JfnXrMPcSZpZdznpUTjlMTjx0U63xKzU5yRPkHS9pM2SLpa0RNINkp6S5FAdM2vs1Tv2/tesg8q8cWcm4Lwm6VLghcDrgL8qsU4zW2j++hZY+8QzwxPpTXgjO+F7m54Zf9MquvZeQ+tZVQacT0XEQ1K+u1DNrBwrp6d54LYfcf6739WxNrz0JHjylufz42N/h+mlyd2dLI29/wWGJC55/XKee8iyttU9PTnJ1OS+1z1rtUtzL2vmztT5WLq0j4mJ6Xkvx9qr9GuSswPOm5Q9W9L6nexsVtTM5umd557JcWte0OlmsOKen3DU5/+RvomJhtOHJC45fDUnLd+vbXX29fXRN9BdR6UTE9M89ZRfjtRtKg04b+aZgPO1Djg3K9kH3/p6PvjW13PH40Mda8Mvn5O8HvjJo/CRbbCs7mhqdx/jHzmG875/ENC+5yQPPvJIAB7Zfs8+00ZG3pZ7eZ18ttHKVXXAuZlZY/tPJm+ZnQJqfc/8vr8fBbHOqTTgXNKXgFcCl0jyS+zM7Bmv2QGD0/CT/eFPRpJ/B6d9l6t1VNUB5zeUVZ+ZLXBP98M/PB/+9XAIwXsOgP94PxzrexSsc7rryvU8KGeEYJA/I7VIvmheWyrIFy0//ZICwaqltKJnVZGrmlf+3E+IVj8nf5L8U0X+bhV1VGGkSA50zu/t1q0FPoflx1O3lRN3zMysI24+/mYUaumnU9xJmpmZZXAnaWZmlqGy7NZ03AfT4UslLSmrbjMzs3Yo80hyJrv1ZOBXJK0DTk+HbyPJcTUzM+taVWa3rgE2pcNXAW8D/qWs+q1ch6wcYMVALXP61MPX5lreUc/K/8B4wzqm+1D0Nyx/9IHjuevoZX2xh2mf0DGbU2XZrcATwJPp6J3AqlnlLpR0l6RH7uO+sptl87RioMZAZHeSnaLoT56xs6amtYSno3ORdGYLQZXZrccDh6eTVpB0mr8UEeuB9QBrtTbvU3bWAZMa5MePNf4IjYycmmtZdxR4Nq1RHZNPXALAwKp932zRK8+/mVl1qsxuvRFYl05+BfD9suo2MzNrh8qyW4HnA9dK2gwcB/xbiXWbmZnNWyeyW/+qrDrNzMzayWECZmZmGboy4Hz8mHG2Xp4vODd3MHiR8N+cCgUMV6BXQqIb1fGcA5PHP+5/YOHcpFPkc9KNNyEVeQHAiEbyzdCFwe5Vyfs56cbPyELkI0kzM7MM7iTNzMwyuJM0MzPLUOZzkqsl/bukmqSB9OcySd+T9PGy6jUzM2uXMo8kHwdezjOhAa8Hbo2I04EhSS8qsW4zM7N5K62TjIhaRPyibtTzSN7+AXALcFJZdZuZmbVDldck7+SZWLrTmRVwDiDpbEnrx8bGKmyWmZlZY1V2khtJTrN+F9gNPDS7QERsjIgLh4eHK2yWmZlZY5V1khExFRHvj4iXA1PAt6qq28zMFg9JL5R0g6Tdki6aNe0sSXdKulvSh5otq8y7W5dIugp4EfAtSeskbZJ0NXB9RDxYVt1mZraoPQ78LvA39SMl9QOfBl4NHAO8RdIxcy2ozIDzPSSvxKp3Wln1mZmZAUTEw8DDkn5z1qSXAndHxE8BJF0GnAtsy1pWV2a3Dm0bYmQ0X6bj1pyZjkXeXZ83CbFIduLIaM58xiJ5mRVkQI7mrKNdb9meeenyyOr2vHS5im1VRcZmoRxh5dsreb+DRebJ+/1I6si3ffP+7UnqyLkeBfZH3r9Z0SOZwG12GHB/3fADwAlzzdCVnaSZmdksB0m6qW54fUSsL7tSd5JmZrYQPBoRa7MmSnovcEE6+JqI+HmDYg8Cz6kbPjwdl8nZrWZmtuBFxKcj4rj0p1EHCXAj8AJJR0paCrwZ2DDXcks7kpS0Gvg6yR1E+wNLgX8BlgM7gfMiYndZ9ZuZ2eIk6RDgJmAFMC3p94BjIuJJSe8jeQSxH/hsRNw+17KqzG49C/hBRJwG/DAdNjMza6uI2BERh0fEiohYlf7+ZDrtiog4KiKeHxH/vdmyqsxu/QnJUSQkkXSPlVW3mZlZO1R5TfIu4ERJtwNrgetnF5jJbt3JzgqbZWZm1liVneS7gI0RsQb4BvD22QVmsltXsrLCZpmZmTVWZScpkuuUAI+Ce0IzM+tulWW3AjcD50naBLwNuLSsus3MzNqh6uzWV5VVn5mZWbs5TMDMzCyDItoVLd0+a9asicsvv7zTzZi3IiHGeQOGqwhjbuSoZ00C8OPHuivZ8DkH9gNw/+NT+0zLG7oOsCXn/ihSRxRI2y8SbG/POPjIIwF45J57OtySxWd0dPTmmXg5rVVwU7M5UuLmuWLpyuIjSTMzswzuJM3MzDK4kzQzM8tQ5iMgqyX9u6SapAFJZ0nalP5sl/S6suo2MzNrhzLvupgJOP8qQERcCVwJIOkHwFUl1m1mZjZvZT4nWQNq0t637kl6HvBQRDxVVt1mtngsP+AA9lu1Ktc8SwcHmajVSmqR9ZJOXJN8A+nR5WwzAedjY2MVN8nMFqr9Vq1i6eBgrnkmajV2PfFESS2yXtKJh9zOJuko9xERG4GNa9asuaDaJpnZQjZRq/mZRytFpUeS6duiJyLC75I0M7OuV1nAuaQTgHOBr5VVp5mZWTtVHXD+g7LqMzMza7fuCt6chyIZpnnlzTzNm8NaRJEc1rzbqlAdOTNMq9hWeXNYq6qjgmZVooqs4iLytqtAlG4ln628iuwP1H1Z3p3mxB0zM7MM7iTNzMwyuJM0MzPLUFl2azrunZK+m+a3HlZW3WZmZu1QWXZr2imui4iXl1inmZlZ25R2JBkRtYj4Rd2oVwH96ZHkJyX1l1W3mZlZO1R5TfLZwNL0SHIXSbDAXpzdamZm3aTKTnIncE36+9XA0bMLRMTGiLhweHi4wmaZmZk1VmUneT1wbPr7cYDTiM3MrKtVlt0KLAPGJW0CXgJ8uay6zczM2iHz7lZJVwD/Z0TcW2TBzm41M7OFbq4jyc8B35b0x5KWVNUgMzOzbpF5JBkR/yLpm8B/A26S9E/AdN30vy2rUduGtjGaM5x3y5Z8AcNVBKIXUUX4OJEzwrmKEOrRAuHYOfd5Fbo15HsxyxtYXiSsPO/nt0iOuKPHO6NZmMAE8DTJ9cRh6jpJMzOz+Tj+Zripxf/FFHk7SzvMdU3yLOBvgQ3AiyNiV2WtMjMz6wJzHUn+MfCmiLi9qsaYmZl1k8wbdyLilPl0kLMDziUdIemhNNz820WXa2ZmVpXKAs5T34mIt5dYp5mZWduU1klGRA2oSXtdbj1d0nXAVyLi4rLqXuwOWTnAioFa5vSph6/NtbyjnjW5z7iBqDGpwdxtMzNbSKqMpdsOHAWcDrxC0rH1EyVdKOkuSY9wX4Wt6kErBmoMRHYn2Q6TGuTJSXeSZtbbyjzdupeI2A3sBpD0dWAEuK1u+npgPYDWFnmKyOpNapAfP9Z4946MnJprWXdkPje27xGmmVkvqexIUlL9qz1eBvykqrrNzMyKKO1IMo2y+ybPBJxfK+kckqPJ6yLCOa5mZtbVyrxxp1HA+Z+XVZ+ZmVm7VXnjjpmZ2YJS2Y07eRwzfgyXb7281DoKBYNXoIp25Q3ULhI+njeOuVv3R95178bQ9ap0a1B7kcDy3HLealikTcoZnp/3PQZQ0fewyJ+TDvKRpJmZWQZ3kmZmZhlK6yRnZ7fWjf+ApM1l1WtmZtYuZR5JzmS3fn9mhKRlwHEl1mlmZtY2pXWSEVGLiF/MGn0+cElZdZqZmbVTlYk7S4DTIuLqOcqcLWn92NhYVc0yMzPLVOWNO+8AvjhXgYjYGBEXDg8Pz1XMzMysElV2kr8GvEfSlcAaSe+vsG4zM7Pcyry7dYmkq3gmu/UrEfGqiDgLuD0iPllW3WZmZu1QdXbrzLSTy6rXzMysXRwmYGZmlqErs1u71UjO7MQicueqNmjT1MPXptMav1w5bx3F8kjzZUChMefcAAAZV0lEQVQWyYetIic1bx1FPiPdmnk6mnNdKslI7VJV7MO827dIk/J+frv1s9tOPpI0MzPL4E7SzMwsgztJMzOzDJUFnEsakXS9pOskfU5SgbedmZmZVafKgPM7I+KkiDglHV5bYt1mZmbzVuZzkjWgNnPAmD43OWM3cH9ZdZuZmbVDpdckJZ0jaSvwbOCxBtMdcG5mZl2j0k4yIjZExAjwAPDaBtMdcG5mZl2jyldlLasbfBIYr6puMzOzIqoMOP+QpGskXUNyuvXbZdVtZmaLl6QXSrpB0m5JF82adpakOyXdLelDzZZVdcD5n5dVn5mZWepx4HeB19WPlNQPfBo4k+Sy342SNkTEtqwFOUzAzMx6SkQ8HBE3AntmTXopcHdE/DQiJoDLgHPnWlZXBpxvG9rWleHKVYT5joyO5CrfKID7qGdNAnBHRnu7Mai9SFh5o/WYfOKSZNrqd827TUUUqaNbQ9Gr+E7lDbavItQ+73cwkS8bpch6VPE3MW/CS1Twt6TOQZJuqhteHxHrcy7jMPZ+/PAB4IS5ZujKTtLMzGyWRyOi8hAan241M7MFT9J7Jd2S/qzOKPYg8Jy64cPTcZmqzG49Ic1u3Szp4rLqNTOzxSciPh0Rx6U/P88odiPwAklHSloKvBnYMNdyyzzdOpPd+tV0+GfAGRFRk3SppNGI6P03dpqZWaUkHQLcBKwApiX9HnBMRDwp6X0kjyX2A5+NiNvnWlaV2a076ibvAabKqtu608ohsWKofScvZm7SqRdTL0T9P2pbHWa28KT9zeEZ064Armh1WZVfk5R0LHBwo+dSZrJb2Vl1q6wKK4b6WFbyrWLq/xF9g18vtxIzWzQqvbtV0oHAp4DzGk2PiI3ARq3VBVW2y6qzexLuf7w9JxEaPeZhZtZOVWa3DgBfAC6aderVzMysK5V2JClpCfBNnsluvRZ4CfDx9DrlhyPihrLqNzMzmy9nt5qZmWVwmICZmVmGroylO/7m47lpr4i+5hT5UgeryKXsVnlzP/PmawKQc/PmzaWExb0Pe4UiX/lg38/JU3wPgGePnJ5RSb46iuXDlv9ZjJwba+uWrbnryPudyl8D0GAfdjMfSZqZmWVwJ2lmZpbBnaSZmVmGKgPO9xouq14zM7N2KfNIcibg/PsZw2ZmZl2tyoDzvYbNzMy6XVddk5wJON/phHMzM+sCXdVJRsTGiLhwJSs73RQzM7Pu6iTNzMy6SZl3ty6RdBVpwLmkE2YPl1W3mZlZO1QdcD572MzMrGv5dKuZmVmGnnmov4qw65GcIdx5g8ShWChx2YoFPufTrWHlI6MjucoX2X9FPie9oh2h3QcfeSQA997TeDuORM5A7QJfwbx/G3Inuycz5So9ku+jW8hi+Oz6SNLMzDrjeCBa/OkQd5JmZmYZKstuTcddLOk6SZ8oq14zW1z6+vvpX7KEweHhTjfFelBl2a2SXgzsHxGnAEslvaTEus1sETj4iCNYsmwZA0uW8KzDD+fgI47odJOsx1SW3Qr8BvCd9PergBOBG8uqv5ccsnKAFQO1lssPRI1JDZbYIrPOGxweZunQEDN/Y9Tfz9KhIQaHh6mNjXW4ddYrqrwmuQp4Mv19Zzr8S5IulHSXpEfu474Km9X9VgzUGIjWO8lJDfLkpDtJ621LBwdR395/wtTXx9JBf/atfap8BGQnsCL9fQXwRP3EiFgPrAdYq7UdvJepO01qkB8/lmd3TZbWFrNuMFGrEdPTqL//l+NiepqJWuv/oTRrpsojyRtIrlFCkrzj90qaWWG1sTEmxseZnpoiIpiemmJifNynWq2tSjuSlLQE+CZpVivwRyTXKK8DbomIH5ZVt5ktDo/ce29ybXJwkIlazR2ktV3V2a0/KKs+M1ucamNj7hytNA4TMDMzy9CV2a3jx4yz9fIuzDDtUD7s1MPXptNO3XeGAhmQ3ZgPmzv7soB8yZeJ6GQeVhsV2b55P+8jowXqqCAXuIrvbe5tVeDTmHtbdd/XfEHykaSZmVkGd5JmZmYZ3EmamZllqLSTlDQg6TJJ35P08Srrts7rEwz0wfJlRa4OmplVr+ojydcDt0bE6cCQpBdVXL91yOEH9LFsAJb0w+qVfRx+gE9imFn3q/ov1fOA29LfbwFOqrh+64Dly8TQEiElP319ybCPKM2s21XdSd4JrEt/P519Q87PlrR+zA8G95TBAdCs/lCCZV35AJKZ2TOq7iQ3kpxm/S6wG3iofmJEbIyIC4f98tSeUpuEmPW4YQTsdga7mXW5SjvJiJiKiPdHxMuBKZJMV+txT+8OxvcE09ORBFFPJ8NP7+6NB/XNrHdVesJL0mHApcA08PmIeLDK+q1zHvjFNMuXiWUDyRGkO0gzWwgq7STTTvG0Kuu07vH07uDp3Z1uhZlZ63wfvpmZWYauvL9waNsQI6MjuebJG9q9kMKYj3pWcofLHY1ClLswrBzyB2pXEUJdpIYqwuCrCB+vQhXfj26V+/NewbaqJtQ+39/phchHkmZmZhncSZqZmWWo+u7W/YB/AZYDO4HzIsK3cpiZWVeq+kjyLOAHEXEa8MN02MzMrCtV3Un+hOQoEpJIuscqrt/MzKxlVXeSdwEnSrodWAtcXz9xJrt1JzsrbpaZmdm+qu4k3wVsjIg1wDeAt9dPnMluXcnKiptlZma2r6o7SQGPp78/Cu4Nzcyse1UdJvBF4HJJ7wD2AP+p4vrNzMxaVnV26xPAq6qs08zMrCiHCZiZmWXoyuzW8WPG2Xp5uVmsizlnsgq5MyB7JL+0iCrWo1u3VTd+b3vls1jJ56pItnH+zdtRPpI0MzPL4E7SzMwsgztJMzOzDJV2kpLOkrQp/dku6XVV1m9mZpZH1Y+AXAlcCSDpB8BVVdZvZmaWR0dOt0p6HvBQRDzVifrNzMxa0alrkm8Avjp75EzA+djYWAeaZGZmtrdOdZJnAxtmj5wJOB8eHu5Ak8zMzPZWeScp6RBgIiL8LkkzM+tqnTiSPBf4WgfqNTOzHpY+QXGnpLslfagdy6w8li4iPlN1nWZm1tsk9QOfBs4EHgBulLQhIrbNZ7kOEzAzs17wUuDuiPhpREwAl5GcuZyXrgw4Hxralj9kOPIVHy2Qsrslb2h3zvBmyB/gXKSOvNsK5Z0BCOUq3o0B0d0s7/ejW7dvJYHloyO5yvfKyw+69m9DcQdJuqlueH1ErK8bPgy4v274AeCE+VbalZ2kmZnZLI9GxNqqK/XpVjMz6wUPAs+pGz48HTcv7iTNzKwX3Ai8QNKRkpYCb6bB8/h5deI5yXdK+m4acn5Y1fWbmVnviYhJ4H3At4A7gC9FxO3zXW6l1yTTTnFdRLy8ynrNzKz3RcQVwBXtXGbVR5KvAvrTI8lPps+1mJmZdaWqO8lnA0vTI8ldzHqGZSbgfOfOiltlZmbWQNWd5E7gmvT3q4Gj6yfOBJyvXFlxq8zMzBqoupO8Hjg2/f044J6K6zczM2tZpTfuRMQtksYlbQIeBS6usn4zM7M8OhFwflHVdZqZmRXRlbF04+PHsHXr5aXWUSSdcTRnXuaWLs2AzJ3juWVrgUqqyOTMmV/apfujSMZm3sjMyJlfCrA1537Pm5EKVJLxm3c9qpD3bwnkz44u9HnPualGcu4/AArM0kld2UmamVnvy3dAVCCwvQ0cS2dmZpbBnaSZmVmGqmPpjgB+QJKrNxERr6yy/rkFw0smGeyfojbVz9ieARbcyXMzM2urTlyT/E5EvL0D9c4hOGL/pxkamKIPmAbGJ/u596nluKM0M1u8OtFJni7pOuArEdEVz0kOL5lkaGCK/rQ/7AeGBqYYXjLJ2J4lba3rkJUDrBio5ZpnIGpMarCt7TAzs+aqvia5HTgKOB14haSZ9B0kXSjpLkmPbN++vdJGDfZP7bMh+tLx7bZioMZA5OskJzXIk5PuJM3MqlZ14s5uYDeApK8DI8Bt6bT1wHqANWvW5HwKbH5qU/1MkxxBzphOx5dhUoP8+LG8m36ylLaYmVm2So8kJQ3XDb4M+EmV9WcZ2zPA+GQ/ERABU5Fck0xu3jEzs8Wq6tOtp0i6WdL1wIMR8YOK688g7n1qObun+tgzLR54ej/ftGNmZpWfbm37W6PbR0xF8tPum3XMzGxhcpiAmZlZhq686DY0tI2RnAHARYKP88p9N1GDdZh6+Npk0sipDWfJux7dGtpdhd5Z9yL3qeUMBq8g5LtQHRV8b7tRoTsT84ai503Bp8A+XARXpHwkaWZmlsGdpJmZWQZ3kmZmZhk60klK+oCkzZ2o28zMrFWVd5KSlgHHVV2vmZlZXp24u/V84BLgo2VXtHzFAew3vKrl8ktqdzEwPc5Rz2ocATdzZ+p89E0OMD3giDkzs4Wg6li6JcBpEXF1xvSzJa3fubM99e03vIqly1oPBq8NHMBk31B7Ks8wPTBJDH2/1DrMzKw9qj6SfAfwxayJEbER2Lh2rS5oV4UTu2s88uA9OebI3iRZzzaamVlvqvqa5K8B75F0JbBG0vsrrt/MzKxlVWe3/uHM75I2R8Qnq6zfzMwsj449JxkRJ3eqbjMzs1Z0ZXZrt8qbqzoymjNrEaBHoiy7MXu3W1WRq1pE7s9vgUDSbtzveT+7UM165K1jNPIHq26pIju6yN/FDnLijpmZWQZ3kmZmZhncSZqZmWWoOkxgRNL1kq6T9DlJi+BtZGZmtlBVfSR5Z0ScFBGnpMNrK67fzMysZZV2khGxp25wN3B/lfWbmZnl0Ym3gJwjaSvwbOCxWdPamt1qZmY2H5V3khGxISJGgAeA186atjEiLly5supWmZmZ7avqG3eW1Q0+CYxXWb+ZmVkeVSfunCXpv6a/3wV8u+L6zczMWlZ1wPnXgK9VWaeZmVlRDhMwMzPL4IDzMhUIfCZn1nWhEPWc7SoS3lxF4HM3BnAXCccukqiRd1WKRKjnDq+uIKd9tMD2zStvyHcRRb4fI6MjucpvKRI+nlOhvz8LjI8kzczMMriTNDMzy+BO0szMLEPVz0mekAacb5Z0cdn19fX10z+whMHlw2VXZWZmPajqI8mfAWdExMnAr0gq7arvwauPYMmyZQwsWcKzDjmcg1cfUVZVZmbWo6oOON8REbV0cA8wVUY9g8uHWTo0hCQk0dfXz9KhIR9RmplZLh25JinpWODgiNg2a3xbAs6XLhtE2nvVpD6WLh2c34LNzGxR6cRbQA4EPgWcP3tauwLOJ3bXiJietexpJiZqGXOYmZntq+obdwaALwAXRcSOsuqpPT3GxPg409NTRATT01NMjI9Te3qsrCrNzKwHVZ248ybgJcDHJQF8OCJuKKOiR35+b3JtcukgExM1d5BmZpZb1QHn/wz8c1X11Z4ec+doZmaFdWV26/j4MWzdenmuefJmCObOpSygivzSQuvRhRmbRWJuq8igrUKhiN8KMmXzKpZHmq9dVeSRdqutW/J9cYvkqub9e1Lo788Cy3t14o6ZmVkGd5JmZmYZ3EmamZllqPoRkNWS/l1SLX0cxMzMrGtVfST5OPBy4PsV12tmZpZb1Y+A1IBa+oykmZlZV+uqa5Iz2a1jY3620czMOq+rOsmZ7NbhYb+tw8zMOq+rOkkzM7NuUvXdrUskXQW8CPiWpBOqrN/MzHqXpLMk3Snpbkkfascyq75xZw/wiirrNDOz3iepH/g0cCbwAHCjpA2z31ucl0+3mplZL3gpcHdE/DQiJoDLgHPnu1BFFIqWLpWkR4CfNZj0XOC+nItbCewssXxVdeRd925dj7zzeJ/ns1jXvVvXw5/3ff2HiDgYQNKVwEEtLnMQqNUNr4+I9TMDkt4InBURv5MOvwM4ISLel6Pd+4qIBfMDPFJgnvVllq+wjlzr3sXrkbcO7/Pua1fXrXsXr4c/7xX9AG8E/rFu+B3Ap+a73IV2uvWJAvNsLLl8VXXkXfduXY+883ifl1tPr6x7t66HP+/VeRB4Tt3w4em4eenK061ZJN0UEWs73Y5OWKzrvljXG7zui3HdF+t6t0OaB/5jkujTB4EbgbdGxO3zWe5CCxlf37xIz1qs675Y1xu87ovRYl3veYuISUnvA74F9AOfnW8HCQvsSNLMzKxKC+KaZJFXbEk6QdL1kjZLuriF8iNp+eskfU45UtglfUDS5hbKHSHpIUmbJH07x/LfKem76XyHNSl7Vlpuk6Ttkl7XwvL3k/SNdJ6vSVrWpPyApMskfU/Sx5uU3WffSbo43c6faFa+lX3fYJ45932D8k33fVY7svZ9gzqa7vuMbZW57xvU0XTfN5hnzn3foHzTfd9o+0v6YDp8qaQlc5VXEjpyg6SnJP1qK3VIOjLdf9dK+qKSZ+bmKn9QOnyNpA2ShlpZj3T8GyTd3+J676zbJwe2OM+Zkq5O5zm+yXocV7f8eyT9Xgvbqk/SF9JtdZWkg+Yqn477ZFrHZ2dv23T6Pt8hzfE9X1CqvgOp4F1Lg8ABwCZgoMV5DgEG098vBUablF9S9/vngJe0WM8y4BJgcwtljwC+kHPdDwP+34Lb7QfA/i2UewPwp+nvfwyc26T8m4APp79/EnhRq/sOeDHw/6TT/mH2dm5Qvum+bzDPnPu+Qfmm+75RO+ba9w3qaLrvG8wz576fa9tk7fsGdcy57xuUb7rvG2z/dcAV6fAfAm9qUn4UeDbw/wG/mrHus+c5BViZDv934Owm5V8E9KXDfza7TVntSn//InB9K+UbfTZamOfLQH+r5eumfa3R9srYH59Nh98G/JcWtu1n0uHfn/0ZScfP/g6dwBzf84X0syCOJCOiFhG/yDnPjkhezQWwB5hqUn5P3eBuYJ//KWY4n+QPZatOT/939YEWy78K6E+PJj7Z6H9xjUh6HvBQRDzVQvGfAMvT31cBjzUp/zzgtvT3W4CTsgo22He/AXwn/f0q4MS5yrey7xvMM+e+b1C+6b7PaEfmvs8oP+e+bzDPnPs+a9vMte8bzDPnvm9Qvum+b7D915B0stB4n++zvyLiodnLbTLPYxGxs2549j6fXX5PREynw/3AXS3UMSXpNek6TLdSHjg63ecfk/Y9Q9FgnlPSZX9T0j9JWt6k/BRAWu6QiLi7hTpm1hka7/PZ5c+g+T6f/R16OXN8zxeSBdFJzoekY4GDo4VoIknnSNpK8r/YZh0F6Wmj0yLi6habsx04CjgdeEXatmaeDSyNiJcDu2g9QeINwFdbLHsXcKKk24G1wPVNyt9J8r9RSNZlVYv1kJZ9Mv19Z855c/G+b0lp+35m+5M81tB0n+fZX1nzSFpNEkuWdUr7l+UlvVTSTSSdwD0t1vEu4As52vQC4FSSo/Gzm80D/AI4FHg1yb54dyvrnZa/spV2AZuBIUl3AO8BvtKk/Nd4Zp+fQfb+q/8OLaGi73nZerqTTK8BfIrkf/xNRcSGiBghyf17bQuzvIPk1EtLImJ3RDwdEZPA14GRFmbbCVyT/n41cHSL1Z0NbGix7LuAjRGxBvgG8PYm5TeSfMm+S/K/xjn/1z/LTmBF+vsKij0X1pT3fWf3/azt33Sf591fjeZRcj31EuCCdDvPWT4ifhjJ4xZfBX67WR2SzgBuiCTyrKU2RcTjERHAv5Gxzxtsq80RMUXGPs/YVq8no7NrMM8rSUILjgY+Alw0V/mIuAXYKul7JPuv4T6f9R2apILveRV6tpNUcuPDF4CLImJHC+Xrb1h4EhhvoZpfA96jJFppjaT3N6mj/kWZLyM51dXM9cDMUcdxzPE/3rp6DgEmIqLpEdHMLMDj6e+PkkRKZYqIqYh4f3qEM0Vyy3WrbiA5FQNJ2P33c8zbEu/7zu77Btv/Rp45Etlnn+fdX3PMsx74dKMj0dnlJS2tm9xwnzeoYwQ4p26f/0WTOpbXnSJvuM8zttVMx7jPPm+03ulZjaMj4tYWt9Wc+7xRHRHx0Yg4neQsyzca1DH7OxSU/D2vTJ4LmJ36ITl0v4rkVMR3SfL4ms3zFuARkmshm4ATm5Q/l+R/7dcA/0h6UT9HG1u5cec1wM0kf/z+Ksey/yZdhy+TnH5rVv7dwPtyLH8VyR+7TSTXEQ5sUv6wtOzVwG/l3XfAJ4DrgE+2WH7Ofd9gnj+ba99nlJ9z38/1GWy07zPqmHPfZ6x75r7PKD/nvs+YJ3PfNyi/rtm+p8F3j+SGnc0kR9+z16NR+S8BPwf+fxrfKNJonrG64dc3Kb8u3d/fA/4V2C/P35CMfd6oTf8OXEtyhLvPzTgZ83wgnefKBvujUflXAX8zxz6fPc8pJJ+nTWk9z29S/mXpv98F/iijjn3+fjLH93wh/fg5STMzsww9e7rVzMxsvtxJmpmZZXAnaWZmlsGdpJmZWQZ3kmZmZhncSZp1gKTnpIHUB6bDB6TDR3S2ZWZWz52kWQdExP0kwc8fS0d9DFgfEfd2rFFmtg8/J2nWIWlSys3AZ4ELgONi76BoM+uwlt7NaGbtFxF7JH2QJFnlle4gzbqPT7eaddarSd4Q0krguZlVzJ2kWYdIOo7ktU6/AXxA0qEdbpKZzeJO0qwD0hfw/gPwexFxH/DXJGHmZtZF3EmadcYFwH0RMfP29v9J8hb7dXPMY2YV892tZmZmGXwkaWZmlsGdpJmZWQZ3kmZmZhncSZqZmWVwJ2lmZpbBnaSZmVkGd5JmZmYZ3EmamZll+N8nwrX0ptsiJQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 504x504 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "(<Figure size 504x504 with 2 Axes>,\n",
       " <matplotlib.axes._subplots.AxesSubplot at 0x124c0f1d0>)"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.random.seed(0)\n",
    "nvmdp = NavigationWorldMDP(width=30, height=30, \n",
    "                      nav_cell_types=['lightgray', 'yellow', 'red', 'lime', 'magenta'],\n",
    "                      nav_cell_rewards=[0, 0, -10, -10, -10],\n",
    "                      nav_cell_p_or_locs=[0.68, 0.17, 0.05, 0.05, 0.05],\n",
    "                      goal_cell_locs=[[(21,21)]],\n",
    "                      goal_cell_rewards=[1.],\n",
    "                      goal_cell_types=[\"blue\"],\n",
    "                      slip_prob=0.00, step_cost=0.0, gamma=.99)\n",
    "traj_states_list, traj_action_list = nvmdp.sample_trajectories(n_traj=8, horizon=100, \n",
    "                                                               init_states=[NavigationWorldState(2,2)],\n",
    "                                                               init_cell_types=[\"lightgray\"], init_unique=True,\n",
    "                                                               rand_init_to_match_n_traj=True)\n",
    "nvmdp.visualize_grid(trajectories=traj_states_list, show_colorbar=True, show_rewards_colorbar=True, goal_marker=\"*c\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cells: ['lightgray', 'yellow', 'red', 'lime', 'magenta', 'blue']\n",
      "Goals: ['blue']\n"
     ]
    }
   ],
   "source": [
    "print(\"Cells: {}\\nGoals: {}\".format(nvmdp.combined_cell_types, nvmdp.goal_cell_types))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Features used for short horizon"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Feature format: \n",
      "<one-hot:lightgray, yellow, red, lime, magenta, blue>, <distance: lightgray, yellow, red, lime, magenta, blue>, <distance:blue>\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(\"Feature format: \\n<one-hot:{}>, <distance: {}>, <distance:{}>\\n\".format(\n",
    "                                \", \".join(nvmdp.combined_cell_types), \n",
    "                                \", \".join(nvmdp.combined_cell_types), \n",
    "                                \", \".join(nvmdp.goal_cell_types)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[[1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 7.0, 7.0, 40.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 2.0, 6.0, 6.0, 39.0],\n",
       " [0.0, 0.0, 1.0, 0.0, 0.0, 1.0, 2.0, 0.0, 6.0, 8.0, 39.0],\n",
       " [0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 2.0, 2.0, 4.0, 0.0, 33.0],\n",
       " [0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 2.0, 4.0, 2.0, 0.0]]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sample_states = [(1,1), (1,2), (2,1), (1,8), (21,21)]\n",
    "list(map(lambda s: nvmdp.feature_at_state(NavigationWorldState(s[0],s[1]),\n",
    "                        feature_type=\"indicator\",\n",
    "                        incl_cell_distances=True,\n",
    "                        incl_goal_indicator=False,\n",
    "                        incl_goal_distances=True,\n",
    "                        normalize_distance=False, dtype=np.float).tolist(), sample_states))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Features used for long horizon"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[[1.0, 0.0, 0.0, 0.0, 0.0, 40.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 39.0],\n",
       " [0.0, 0.0, 1.0, 0.0, 0.0, 39.0],\n",
       " [0.0, 0.0, 0.0, 0.0, 1.0, 33.0],\n",
       " [0.0, 0.0, 0.0, 0.0, 0.0, 0.0]]"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sample_states = [(1,1), (1,2), (2,1), (1,8), (21,21)]\n",
    "list(map(lambda s: nvmdp.feature_at_state(NavigationWorldState(s[0],s[1]),\n",
    "                        feature_type=\"indicator\",\n",
    "                        incl_cell_distances=False,\n",
    "                        incl_goal_indicator=False,\n",
    "                        incl_goal_distances=True,\n",
    "                        normalize_distance=False, dtype=np.float).tolist(), sample_states))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Multiple Goals"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x504 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sample State Trajectory\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[[0.0, 1.0, 0.0, 0.0, 0.0, 38.0, 18.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 37.0, 17.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 36.0, 16.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 35.0, 15.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 34.0, 14.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 33.0, 13.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 32.0, 12.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 31.0, 11.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 30.0, 10.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 29.0, 9.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 28.0, 8.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 27.0, 7.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 26.0, 6.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 25.0, 5.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 24.0, 4.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 23.0, 3.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 22.0, 2.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 21.0, 1.0],\n",
       " [0.0, 0.0, 0.0, 0.0, 0.0, 20.0, 0.0]]"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.random.seed(0)\n",
    "nvmdp = NavigationWorldMDP(width=30, height=30, \n",
    "                      nav_cell_types=['lightgray', 'yellow', 'red', 'lime', 'magenta'],\n",
    "                      nav_cell_rewards=[0, 0, -10, -10, -10],\n",
    "                      nav_cell_p_or_locs=[0.68, 0.17, 0.05, 0.05, 0.05],\n",
    "                      goal_cell_locs=[[(21,21)], [(11,11)]],\n",
    "                      goal_cell_rewards=[1., 1.2],\n",
    "                      goal_cell_types=[\"orange\",\"blue\"],\n",
    "                      slip_prob=0.00, step_cost=0.0, gamma=.95)\n",
    "traj_states_list, traj_action_list = nvmdp.sample_trajectories(n_traj=16, horizon=100, \n",
    "                                                               init_states=[NavigationWorldState(2,2)],\n",
    "                                                               init_cell_types=[\"lightgray\"], init_unique=True,\n",
    "                                                               rand_init_to_match_n_traj=True)\n",
    "nvmdp.visualize_grid(trajectories=traj_states_list, show_colorbar=True, show_rewards_colorbar=True, goal_marker=\"*c\")\n",
    "## Features: <Cell Type Ind, Goal Distances>\n",
    "print(\"Sample State Trajectory\")\n",
    "[nvmdp.feature_at_state(s,\n",
    "                        feature_type=\"indicator\",\n",
    "                        incl_cell_distances=False,\n",
    "                        incl_goal_indicator=False,\n",
    "                        incl_goal_distances=True,\n",
    "                        normalize_distance=False, dtype=np.float).tolist() for s in traj_states_list[0]]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Custom Grid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x432 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "(<Figure size 432x432 with 2 Axes>,\n",
       " <matplotlib.axes._subplots.AxesSubplot at 0x1274cfc88>)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "nvmdp = NavigationWorldMDP(width=7, height=7,\n",
    "                      nav_cell_types=['lightgray', 'yellow', 'red'],\n",
    "                      nav_cell_rewards=[0, 0, -10],\n",
    "                      nav_cell_p_or_locs=[0.5, 0.5, [(2,i) for i in range(1,7)]],\n",
    "                      goal_cell_locs=[[(7,1)],[(1,1)]],\n",
    "                      goal_cell_types=[\"blue\", \"orange\"],\n",
    "                      goal_cell_rewards=[1.,10.],\n",
    "                      slip_prob=0.00, step_cost=0.0, gamma=.50)\n",
    "traj_states_list, traj_action_list = nvmdp.sample_trajectories(n_traj=41, horizon=100, \n",
    "                                                               init_states=[NavigationWorldState(1,2)],\n",
    "                                                               init_cell_types=[\"lightgray\", \"yellow\"], init_unique=True,\n",
    "                                                               rand_init_to_match_n_traj=True)\n",
    "nvmdp.visualize_grid(trajectories=traj_states_list, show_colorbar=True, show_rewards_colorbar=True, goal_marker=\"*c\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Updating Goals dynamically"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x432 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "(<Figure size 432x432 with 2 Axes>,\n",
       " <matplotlib.axes._subplots.AxesSubplot at 0x12759fcf8>)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "nvmdp._reset_goals([[(7,1)],[(1,1)]],[10.,1.],[\"blue\", \"orange\"])\n",
    "traj_states_list, traj_action_list = nvmdp.sample_trajectories(n_traj=41, horizon=100, \n",
    "                                                               init_states=None,\n",
    "                                                               init_cell_types=[\"lightgray\", \"yellow\"], init_unique=True,\n",
    "                                                               rand_init_to_match_n_traj=False)\n",
    "nvmdp.visualize_grid(trajectories=traj_states_list, show_colorbar=True, show_rewards_colorbar=True, goal_marker=\"*c\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x432 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "(<Figure size 432x432 with 2 Axes>,\n",
       " <matplotlib.axes._subplots.AxesSubplot at 0x1279ee4a8>)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "nvmdp._reset_goals([[(7,1)],[(1,1)],[(7,7)]],[10.,1.,10.],[\"blue\", \"orange\",\"purple\"])\n",
    "traj_states_list, traj_action_list = nvmdp.sample_trajectories(n_traj=41, horizon=100, \n",
    "                                                               init_states=None,\n",
    "                                                               init_cell_types=[\"lightgray\", \"yellow\"], init_unique=True,\n",
    "                                                               rand_init_to_match_n_traj=True)\n",
    "nvmdp.visualize_grid(trajectories=traj_states_list, show_colorbar=True, show_rewards_colorbar=True, goal_marker=\"*c\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(<Figure size 1008x576 with 4 Axes>,\n",
       " <matplotlib.axes._subplots.AxesSubplot at 0x127cbbe80>)"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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FHFa3Q3AA+7+PjOrAeqH24CKIxERERERiUwxLgJrZqOBtwMfzbXpfUDfcNvRtDoREREREal2s4E24Ptm9oKZfcfMGobbiIojERERERGJhJObVjfUDZhgZov73a7cq6k4cCLw3+5+AtAFfGG48WhanYiIiIiIRMOBws452urui/Zz/wZgg7s/nd++gwMojjRyJCIiIiIikXEf+jZ0G74ZWG9mR+Z3nQu8MtxYNHIkIiIiIiKHgs8Ct+ZXqnsD+PPhNqDiSEREREREolOE1eoA3P1FYH9T74ak4khERERERCJixbzO0UFTcSQiIiIiItEp0shRMWhBBhERERERETRyJHnz5y8oWduPPfKfJe9j9g3/XrK27zznEgAueeTBkvUBcA9LS9b2xGmzAVizsnR9iByyggCrqytN25abSlKy9vM65o0pafvlsOntpZt2s3slrFL2Meeqp0rWNi9cUvo+gFXXn1qytvvyv6KlfA8Apv6ugoYoDlApX4N9qPR9tHXstcPRtDoRERERERGgoqbVqTgSETmUdfXAUy9FHYWIiMh+VM7Ikc45EhERERERQSNHIiIiIiISJU2rExERERERQcWRiIiIiIgIDlTQanU650hERERERASNHImIiIiISIRc0+pERERERETQOUciIiIiIiKAzjkSERERERGpNBo5EhERERGRyJim1YmIiIiIyIjn6JwjERERERERMJ1zJCIiIiIiUmk0ciQiIiIiItHRtDoRERERERFUHImIiIiIiAAVVRzpnCMRERERERE0ciQiIiIiIlFxKmq1OhVHIiIiIiISmUq6CGzJp9WZ2VVm9nip+xERkdIxs++ZWauZLeu3b5yZPWxmr+X/HbuP534k/5jXzOwj5Yu6MMpTIiIR8wJuZbLP4sjM7jezWQfTuJklgeMPpo0D5Zks4bZOwnU7qX10OZ7JRhHGiJfqCdje2semtX3c+JFzSPXoNLdyC7POc/et4L6bfsfy37cSZivo8EyBwjBk5doX+N1zv2Tl2hcIwzDqkIYtDLPEMylqUp3Edm4iDKvuM+kHwIV77fsC8Ii7zwUeyW8PYGbjgGuAU4CTgWv2VUQNV7XnqZhB0NFLvK2Ly45oIlY5s0pGlr4Mu9pStK7rZd5PN0JfJuqIRpwgC+t/s46Xb32REzc2ElTdxyNASG1yA42jllCb3ABUX56KGySy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icQO0umx+cKoevJUxuGSH3fzsXNnMX9CwLKtId/9nzYy5fpMqqDPvkP2r9/iMYiBx6D37KOLfl6lFCZZF1LTEEJDWPSpdFKYIGbEJ8wEZnL0cduiDueABEHAvMNOqJoFGAYTBDGyY6ayi9yRxOpJmTnufvk+7jp3kMcuBj7eb/t7wPdKFFrVynouR3kMLcIQpZo4NfUh1IdFn0onhQljsL1mItuZyPONq6IO5wAF9KamV80CDIPJOGVZfGEw1bQgg4iIiIiIyIhwyI4ciYiIiIhIFaigkSMVRyIiIiIiEh0VRyIiIiIiMtKZ65wjERERERGRiqORIxERERERiY5XzrrSKo5ERERERCQ6FTStTsWRiIiIiIhERucciYiIiIiIVBiNHImIiIiISHQqaORIxZGIiIiIiESjwpbyVnEkIiIiIiLRqaDiSOcciYiIiIiIoJEjERERERGJUgWNHKk4EhERERGRyFTSOUeaViciIiIiIoKKIxEREREREUDT6kREREREJEoVNK0u8uKoru4V5s9fUJK2d9l1ACVrXyrH6s9dXbK2n19xUcn7yCld+79adRcA8+dfVrI+AJYtW1rS9suh2j8v6uqijuAQFI9hY0eXtItSt9+4cmdJ2y+HqYwpXePvyffxu9J9Q1t1/akla7tcfZTy/0/Nifk+nq+gb8kVatPbLeoQDkr62b126DpHIiIiIiIieSqORESkHOaxg4f9jiEfV93HIUVERIpDxZGIiIiIiERHI0ciIiIiIjLSGTrnSEREREREJKeCiiNd50hERERERAQVRyIiIiIiEpX8Ut5D3QphZjEze8HM7j3QcFQciYiIiIhIdLyAW2E+Byw/mFBUHImIiIiISHSKUByZ2XTg3cB3DiYUFUciIiIiIlLt/gP4WyA8mEZUHImIiIiISGQKPOdogpkt7ne7cs/zzS4GWt39uYONRUt5i4iIiIhIdAo7p2iruy/ax31nAJea2buAWqDJzH7s7h8abigaORIRERERkWgUcr7REMWTu/+9u09391nAB4DfHEhhBCqOREREREREAE2rExERERGRCBV6HaNCuPujwKMH+nwVRyIiIiIiEp0iFkcHS8WRiIiIiIhEppgjRwdL5xyJiIiIiIigkSMREREREYlSBY0cqTgSEREREZFoFLBUdzmpOBIRERERkUhY/lYpSnbOkZnNN7Mn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6c/mcfwBe6d7iYiIiGaOREREREQkDEPL6kRERERERHK8fKojFUciIiIiIhJMOc0c6Z4jERERERERNHMkIiIiIiKhlNnGQCqOREREREQkGItDR3CciiMREREREQmnjGaOdM+RiIiIiIgImjkSEREREZGAymm3OhVHIiIiIiIShqPnHImIiIiIiEB5zRzpniMRERERERE0cyQiIiIiIiGV0cyRiiMREREREQnCKK9ldSqOREREREQkDPey2pBB9xyJiIiIiIigmSMREREREQlIy+pERERERERAGzKIiIiIiIhAec0c6Z4jERERERERilgcmdl8M1tqZi+Y2T3F6udU4mx+aG5s/e27jh9LSWVj2N8IW/fDr1bmjpMkm4morR3M2cNG8/tl7yabSd77KI5jXnntNR559lleee014jhhPwQgkzV+f7SJBw8c4hevXEIma6FD6jXv9HHbznu7HEsYofOUObmlJG6MaRteVldOBxInpi3dTHPlYd4a8jpOsj4jjZihQ2oZP3YYsyc1YQmLH8DdyfgB2uJtZPwAXkY7l/WYx7zUdJSfHTzIxOr94An8OXTKS5mqa0qXpxyIvftXiRRzWd1W4Fp3bzGzn5jZLHdfVcT+OsTZiMfvuJfL4t0APPO1v+GcmWt4z313EqWS92ZNqmwMN94Da3fl3tO3/TPMnwyL74JUAr4XZjMRK1++l9mzziWVihg69G9Y+fJq5lx8J6l0Mt5HcRzzP3/0Izbu2EFbWxuVlZWcN24cX/nEJ4iiBPwQyBVG73vsv7GxYh+t7jx84Av8cMtGHrnlm6RTyUigTsRRFjOIXFHXxIOkWMYgbkzkF5l+JFieMoerGy/GfQkAlx+dxf70YZ6rexlPXu2fWE7MS9Mf5GjNPsB5deojDG4cyyXrbsMScAHDiPkfd4zkgmkTSKUivv2X17J8xSa+ft+exFyAcXda4tXENAAxeEREPdXRTMwS8o/BY8aPjPn7t/bS6k7FyOmMb97J9j2AJeTnQETz0B925KnmwfeQal9JzcFPliZPlVE6L9pPzN13u3tL/rAdyBarrxNtX3I5b62+sOM40zyIt1bPZPuSy0sVggCLVsGyN44X+42tueNFJfnqceaWL7+CaVNnkk6nMDPq6gYxbeosli+/InRoPbZywwY27thBa1sbDrS2tbFxxw5WbtgQOrQee+zVebwe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\n",
      "text/plain": [
       "<Figure size 1008x576 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "nvmdp._reset_goals([[(7,1)],[(1,1)],[(7,7)],[(4,4)]], [10.,1.,10.,5.],list(range(4)))\n",
    "traj_states_list, traj_action_list = nvmdp.sample_trajectories(n_traj=41, horizon=100, \n",
    "                                                               init_states=None,\n",
    "                                                               init_cell_types=[\"lightgray\", \"yellow\"], init_unique=True,\n",
    "                                                               rand_init_to_match_n_traj=True)\n",
    "fig = plt.figure(figsize=(14,8))\n",
    "nvmdp.visualize_grid(trajectories=traj_states_list, \n",
    "                          show_colorbar=True, show_rewards_colorbar=True, \n",
    "                          goal_marker=\"*c\", fig=fig, subplot_str=\"121\")\n",
    "nvmdp.visualize_grid(nvmdp.get_value_grid(), trajectories=traj_states_list, \n",
    "                     show_colorbar=True, show_rewards_colorbar=False, \n",
    "                     goal_marker=\"*c\", fig=fig, subplot_str=\"122\",\n",
    "                     state_space_cmap=False, title=\"Value\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Updating Rewards dynamically"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "([0, 0, -10], [10.0, 1.0, 10.0, 5.0])"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "nvmdp.nav_cell_rewards, nvmdp.goal_cell_rewards"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(<Figure size 1008x576 with 4 Axes>,\n",
       " <matplotlib.axes._subplots.AxesSubplot at 0x127eb2160>)"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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nBnBngPXqyzJjGAPa9YvjzCqwTn7wiep9ZpeearWazj7wicjjatYOEaKoN9LvuR05Mjdv5/L9g/Hghi7z76E1iJerS6Ih0y64XPp1erWHk/Z5NVFt1pdPFZC56Y53N3xNOU1nXQW22p1AenFF9YCO4CRFN1qdbEgyX2vncrdq9fgHnDrtC8U3Wp1sXjAuz75ZpoxzOH0Ey/UanWSNVHlqTAF//j1zSw8p5rjx5exemPxrVYXYlz9h+eZP2MtU0dUsWZXW9GtVuepgM+e/yKnvm8V0+dW8tLS9qJarS4k4DMrPsppw1cyrWoLq9rGFt1qdY7T/NebKb3w7Thw+u4/Fd1qdfGSkC998dc80fE+cHjrvBbOvvBeLcZQpHK+Wl1ULIiRmvQa9ueZ4vmofkUQDzNT6LI/jS5f4rGS9BQ6B7I/qyP3AtJT6IpkGl1fYkGSwEKwkItyMJUuH2LxAIul/4pzMZVOJAphiswUuuIZLTpYiPHkyg6eZP80uuLLtp4K+POP4c/sH/EqnsIC0gXSE7tn5mQaXb44DpYuq3MxlS4f4iUhlkgXdLmYSne0y+cxRf05aosjEREREREpbIV2zJGKIxERERERiYiR8sIZsS2cSERERERERCKkkSMREREREYmEQ0EtIqLiSEREREREIqNjjkRERERE5JjnrmOORERERERECo5GjkREREREJDKFdPJoFUciIiIiIhKJ9HmOCmcym4ojERERERGJiI45EhERERERKTgaORIRERERkUjoPEciIiIiIiIZKdeCDCIiIiIicoxzrKAWZCicSERERERERCKkkSMREREREYlMWECr1ak4EhERERGRSOg8RyIiIiIiImSOOdKCDEeZwnk9j9hsnxN1CHIUmD07d++jh19emfM+AJ75Xu7a/uL138j08dmc9TFvSc6aFpFj3NhHPHeNX5iHPoCpfCJnbf/wovTox9TbctcHwJotuUtU1/74dADu27I0Z3287oL2nLWdDSqORESOYrFOqHuhcKYriIiIHEznORIRERERkWOeO6S0IIOIiIiIiIgRFtAxKoVTpomIiIiIiERIxZGIiPTLzH5kZtvNbHmPbfVmtsjMVmX+H36Yx74/c59VZvb+/EUtIiKFzklPq+vvki8qjkREZCB+woH1pA64GnjA3acBD2Su92Jm9cC1wHzgdcC1hyuiRETk2JQi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jhB9nnIPSJQYiRJj7dpxUYVxzAtxulra6Gpp4571L0cdzqD1LISuLqIRo14soLu0iu7SKrY2zow6miMSOixeupXFS4tntOhgYTzG8cEaYA3/WXl+XvvO54IL/dFuSxERERERicwxcRJYERERERGRYqKRIxERERERiYST39Xo+qPiSEREREREIlNAhxypOBIRERERkYi4jjkSEREREREpOCqOREREREQkOj6AywCYWZ2Z3W5mK83sBTMb9NnWNa1OREREREQik8VpdTcC97r7ZWZWClQOtgEVRyIiIiIiEplsnATWzGqBBcAH0m16N73PkzwgmlYnIiIiIiLFbjKwA/ixmT1jZj80s6rBNqLiSEREREREIuGkp9X1dwEazGxJj8vHDmoqDpwCfNfdTwbagKsHG4+m1YmIiIiISDQcGNgxRzvdfd6r3L4J2OTuizPXb+cIiiONHImIiIiISGTc+7/034ZvBTaa2QmZTecAKwYbi0aORERERETkaPAp4BeZlepeBj442AZUHImIiIiISHSysFodgLsvBV5t6l2/VByJiIiIiEhELJvnORoyFUciIiIiIhKdLI0cZYMWZBAREREREUEjR5Ixe/acnLW94dGXct7H5Bu/nrO2f7nwTAAufuC+nPUBcCfLctZ2W1v6eMTly3+csz5EjlrxGIwcnpu2LTOVJFftZ7ROr8tp+/mwZUEOp91Y7vs4/jNP5axtMnkqp30Aq791Ws7a7n42/X9OX2dg7CMFNERxhHL5HCzzEo99Knd97Gg9aIOjaXUiIiIiIiJAQU2rU3EkInI0a+uAp56NOgoREZFXUTgjRzrmSEREREREBI0ciYiIiIhIlDStTkREREREBBVHIiIiIiIiOFBAq9XpmCMRERERERE0ciQiIiIiIhFyTasTERERERFBxxyJiIiIiIgAOuZIRERERESk0GjkSEREREREImOaViciIiIiIsc8R8cciYiIiIiIgOmYIxERERERkUKjkSMREREREYmOptWJiIiIiIig4khERERERAQoqOJIxxyJiIiIiIigkSMREREREYmKU1Cr1ak4EhERERGRyBTSSWBzPq3OzD5jZo/luh8REckdM/uRmW03s+U9ttWb2SIzW5X5f/hhHvv+zH1Wmdn78xf1wChPiYhEzAdwyZPDFkdmdreZTRpK42ZWBswdShtHqjNM8njL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hBwHKidF567uYBY6T2XduvLUgjcrQoVx2Mti/GVLDX/ZEp2NarrLAH/qWJnLtxFdsmZZJ9nSDi3tjFy0OnQ4A5I1y81UAh6sbIaIFNjd5QqhXJ6qGLs5dDiHxMwmAe8GXujv10ZnT2IRERERERlUDLC+bXt+pJkt7HY8z93nva09s2HAPcAX3H1Xf+NRcSQiIiIiIuH0beXLDnefc7AnmFmSXGH0a3e/dyChqDgSEREREZFg+jhydPA2cotHfwa87u7fH2g7EVkaLyIiIiIickBnANcA55rZ4vzjff1tRCNHIiIiIiISRuF2q3uGAuyEoeJIREREREQC6duHvJaKiiMREREREQmmFB+n1FdacyQiIiIiIoKKIxER6QMzu8jMlpnZSjP7auh4RERkEHHv/VEiKo5EROSgzCwO3AZcDMwAPmpmM8JGJSIig4KDZXt/lIqKIxER6c3JwEp3X+3uncBvgUsDxyQiIoOFRo5ERCRCxgEbuh2/mT8nIiIyqGi3OhERATjSzBZ2O57n7vOCRSMiIoePMtqtTsWRiIgA7HD3OQf4t43A0d2Ox+fPiYiIHDIro8850rQ6ERHpzYvANDObbGYVwEeA+wPHJCIig0UZrTnSyJGIiByUu6fN7HPAI0AcuN3dlwYOS0REpOBUHImISK/c/UHgwdBxiIjIIONACbfq7o2KIxERERERCcLwslpzpOJIRERERETCUXG0z/I3juKC0/+uKG3/+7dzf15w+j8Vpf29HuWbRW1fDg8zZ84qWttDeSLfxzlF6wNgyZJXi9b2VHYXvQ+AG47/x6K1feu3cn9eELuiaH0s98eL1rZEV/ukI0KHcMgqt+4OHcJhb9PZVrS2O2qL3wfAqqt+XLS2O147veh9AFx41Oyitb03TxWzj+X+VtHaLoTgxZGIiBRPW9sMliyZ34dnFq84FxEROSiNHImIiIiIyGFPGzKIiIiIiIjklNOGDPoQWBERERERETRyJCIiIiIiIZXRyJGKIxERERERCcRVHImIiIiIiOCUVXGkNUciIiIiIiJo5EhERERERELSVt4iIiIiIiLltZW3iiMREREREQmnjIojrTkSERERERFBI0ciIiIiIhKKA9nyGTlScSQiIiIiIoHoc45ERERERERyyqg40pojERERERERNHIkIiIiIiIhldHIkYojEREREREJQxsyiIiIiIiIQG5DhmzoILoM6jVHLcAXDNKV8dChiIjQEk9w/XEnkB5aEToUKRPKUyJSTpSnBnlx9CTwhBnbp48MHYqICH86YhSPHzmG7adNCh2KlIknyeWpHdPqQociIhIuT7n3/iiRohVHZnaUmb1kZu1mFmT63n2W+3PTifUhuhcgk6lg+Vu38vSGP7P8rVvJZKJ1JyLTmWD5nV9nzc//wPI7v06mM3ozUbNp44rnl/KNR56l5fmTyKYtdEiHZEhNTegQBuye+nEAbLp4euBIBMorT205YVSI7gVIJGNc/pXz+NS8a7j8K+eRSEbrvnEcuHr0ZP5tzplcPXoyURyDTLhzw9KnuWvR3XzaG0mU0eL8vvKuX6mNdOU53Y6jJUie2rvmqLdHiRQzGewEzgN+V8Q+elj0yZk0Nuy7+5bM/3A1TRzOY/96Vtf5upWNnHj7klKFddjKZCqYv/JNNrfVkPIYSTuBsTuu5KqG8cTjnaHD61WmM8Ge51cz7dLhUA20nknL89cy9LQpxCvSocPrk2zaaHz6Bv52wm7s6EoyHZfT+PRZ1J11C7FEdJLPqEmTYFvuZ/aI8ePpbGtj+9q1QWPqi0Xf/QCNJx7ddZzM5uZUNx03lsf+dH3X+bpFGzjxy/eXPD4pfZ5afPV0mqaM6Drem6eaj67hya+f2nW+dnUzs3/zeqnCOmwlkjGu+tUX2JaqZqfHSM6ayFW/OoH51/yAdKp81kAcSBy47/qPUnfSMKiGM1qn89EXd3PZbXeRCR1cHyXceeTYJuoaMlhlnPccV8NHVzRx4bJa0haNm3lOjLa6nxMnF2/biFuIp16hqvETGOX9OiqbPFVGBXHRiiN3bwfarYQv7MlPbqB5wnCyFbn7Jql8357YV73HOjNMfmJDyWI6nK1q+n6+MMp/PzzOhtYR3L5sO1XxVODo+iAdh/oYbO52rn4ErHord5cjCiyLj01DitwDYCyw8ibMi/CzWaxblhs6seHTIOPwclP+5NiidPXxv/y4YG2dnN7N99rX0pl/waRiufcir9j3HxVrTzH5zoUF61P6LkSemvjsRnaNH9Zrnpr47MaSxXQ4+8AN57AtVd0jT23qHMYHfvllKq3AN8GK8DKLZWM8mLSeeWpcDdd++9pI5alnbb88NRm+OdmKkqd+0/iJgrcJQCPYcM/lqZfagWOB54rS1cf/Uri2lKfeLsiYn5lda2YrzGx7e0dT71/QRyNXNzP7l0uJdb7z/ZJYZ4bZdyxl5JrmgvUpB7a1dQ4p7/kScyCVjcpQ8wHelKNxIysvKtmxd54E4pH6z2dGYhhfGjKJigO8aGLtKWZ/7Q+MfGVTiSOT3nTPUx3thctTdet2MWv+soPmqVnzl1G3blfB+pQDq2s46p3zlEclTx1ApN4qladCKps8VUZrjoLMsXb3ecA8gOHDxhX0akeubmbWXW/w6tXvIpvsVvWmMsy66w0VRiU0pnohSTuh644cQNKynD/2Do454nMBI+ub5Xd+nWmXfgnrtsTFW2DF77/HMf/j2+EC64eW508iM/pyrDrZdc5bU8S33UvNaS8WvL8lS14teJtDamo4Yvx4YvF9r6NsJsNbb75Je0tLwfu74fh/LHib00+dyKvfuohs5b633FhHmln/9IgKozLVPU/VDB9f0DxVt24XM+5dwWsfOoZst/UtsVSWGfeuUGFUQo0rN5GcNfFteSq5+C/c9Z3HC9pXyzG1BW0PcmuNPvud89+Wp374lcf4zbY1Be9v09mF/8X/097IZy+pITZ03/tjtjXNDx9o4adW+I1KVl1VuNkBe6Urz6FtxC0QG7rvZHYPVc03kOh4ouD9XXjU7IK3GTZPlbb46U3Eb428s3RVHMs6ZLK5u3OZLJZ10lVRXKYYXVNrb2RsVQtJywBO0jKMrWphau2NoUPrk6lX3kzLS7vwFvBMLuG0vLSLqVfeHDq0Pht60kIy67fjrSk843hrisz67Qw9KTrD4+0tLXS2tZHNZHB3spkMnW1tRSmMiiU9rBLLZHPvSe2p3HtSJkt6WGXo0CSQ9JBEfpFxllgqA9ksZD13Xkrm/lueYHSytUeeGp1s5f5bCv8LbTHM37aGxhd398hTjS/uZn4RCqNi+QW1NK5oIduaxjNOtjVN4/IWfkHhi8liiXcsIJ56BbJ7ct+I7B7iqVeIdywIHVqfBc1TTv49sJdHiRTtXdjMksBDwAnAI2Z2k7u/UKz+utt0Yj2ZZJyaLXtoeHgNKy+aTEv9UDadWM/YxdtLEYIA8XgnVzWMZ1XT99nWdiKjqxYxtfbGSGzGABCvSDP0tCms+M+vkkydQir5AlOvvDkymzEAxBJO3Vm3sOfFOaSbjyYxYgPDz1oYqc0YALavXcuQmhoqhgyhs709UoUR5Hb9yQxJUrNqBw3znmPltafTMvVINl08nbGPLQ8d3mErZJ7aMnsU2WSMYdtamfL4elafN4Hdo6vZcsIo6pfsKEUIAqRTWeZf8wM+cMM51DYcRdPKTcy/5YlIbMYAkAEuu+0urho9meMnHMVf129i/rY1kdmMASBtxoXLavn4siZOGJrmlT0JfkF0NmMAMLJUNX6CTOVcMonpxNOvE+9YUPabMXSnPLVPMTdkSAHnF6v9g4l3pJn20BomPLcRcxh528usP30cjZOHhwjnsBaPd3LMEZ/jmNCBDFC8Ih2ZKXQHEkt4fgpd4afRlVJ7S0vkiqK94ns6mfbjZ5lwzyu596S//y/WX34CjccXZ1MJ6ZuweSrD1MfXMf6FLRhQ97NX2XDyWJonRHer+qhKp7LcW+ApdKWUAX6zbU1RptGVStqMn1IHrURsvdQ+RpZExxNFmUZXCsHzVBlNqxuU4/ez7+y5/al5bocg7f4jIiHM/uZDPY4t60y8ezET714cKCIJbdZ/9bwTaw4TXtgML2w+wFeIiBRP8Dyl4khERERERKS0H/Lam0G5IYOIiIiIiEh/aeRIRERERETCcHAvn80rVByJiIiIiEg4ZTStTsWRiIiIiIiEU0YbMmjNkYiIiIiICBo5EhERERGRUNwhqzVHIiIiIiIiZTWtTsWRiIiIiIgE42U0cqQ1RyIiIiIiImjkSEREREREgnFNqxMREREREcHR5xyJiIiIiIgA4FpzJCIiIiIiUlZUHImISK/M7CIzW2ZmK83sq6HjERGRwcEBz3qvj74oRK5ScSQiIgdlZnHgNuBiYAbwUTObETYqEREZFNxz0+p6e/SiULlKxZGIiPTmZGClu692907gt8ClgWMSEZFBokAjRwXJVSqORESkN+OADd2O38yfExERKRcFyVXmgfcVN7PtwLoidjEBWF/E9ktB1xBe1OMHXUO5KPY1THT3UXsPzOxh4Mg+fN0QoL3b8Tx3n5dv4wrgInf/dP74GuAUd/9c4cIuX8pTfaJrCC/q8YOuoVxELk/l2ylIrgq+lXf3/5xiMLPt7j6nmH0Um64hvKjHD7qGclHqa3D3iwrQzEbg6G7H4/PnDgvKU73TNYQX9fhB11AuIpqnoEC56nCYVtcUOoAC0DWEF/X4QddQLqJ4DS8C08xssplVAB8B7g8c02ASxdfE/nQN4UU9ftA1lIuoXkNBclXwkaMSaA4dQAHoGsKLevygaygXkbsGd0+b2eeAR4A4cLu7Lw0c1mASudfEO9A1hBf1+EHXUC4ieQ2FylWHQ3E0r/enlD1dQ3hRjx90DeUiktfg7g8CD4aOY5CK5GtiP7qG8KIeP+gaykVkr6EQuSr4hgwiIiIiIiLlYNCuOTKzo8zsJTNrN7NIjpCZ2Slm9pyZPWNmt4SOZyDMbGb+Gp42s5+bmYWOaSDM7AYzeyZ0HANhZpPMbKuZPWlm/x06noEys4+Z2eP564jcNtL5T+1+Mv/YbGaXhY5Jwot6rlKeKh/KU+EpTw0Og7Y4AnYC5wF/Dh3IIVgHnOvuZwKjzWxW6IAGYJm7n+7uZ+WPI7eDi5lVArNDx3GIHnX397j7e0MHMhD5JDPX3c/LX0fkdkpz94fzsb+H3BapjwUOScpD1HOV8lQZUJ4KT3lq8Bi0xZG7t7t7Y+g4DoW7b3H3vfu5p4BMyHgGwt1T3Q476PnhXFHxKeCO0EEconPyd0VvCB3IAF0IxPN35P7DzOKhAxooM5sCbHX33aFjkfCinquUp8qG8lR4ylODxKAtjgYTMzseGOXur4WOZSDM7ANmtgQYA7wVOp7+MLMk8B53/1PoWA7BZuAY4Bzg/PzrKWrGABXufh7QClwaOJ5DcTnwu9BBiBSS8lQ4ylNlQ3lqkFBxVObMbCRwK7m7QpHk7ve7+0zgTeCS0PH00zXAb0IHcSjcvcPd97h7GvgDMDN0TAPQDCzI//1PwPSAsRyq96PPCJJBRHkqOOWp8qA8NUioOCpj+cW5dwJfcvctoeMZiPw86L12AW2hYhmgY4G/N7OHgePM7B9CB9RfZlbT7fAMYFWoWA7Bc8DeO4mzgTUBYxkwM6sHOt09UnemRQ5EeaosKE+VB+WpQWLQFkdmljSzx4ATgEfM7JTQMQ3Ah4GTgO/kdw45LXRAA3CRmS0wswXkhpwjtQuNu/9Pd7/Q3S8Clrr7f4SOaQDOMrNFZvYcsNHdXwgdUH+5+2KgzcyeJPczcXfYiAbsUuD3oYOQ8jEIcpXyVGDKU+VBeWrw0OcciYiIiIiIMIhHjkRERERERPpDxZGIiIiIiAgqjkRERERERAAVRyIiIiIiIoCKIxEREREREUDFkcgBmdnRZrYm/wGHmFld/nhS2MhERESUp0SKQcWRyAG4+wbgR8DN+VM3A/PcfW2woERERPKUp0QKT59zJHIQZpYEFgG3A58BZrt7KmxUIiIiOcpTIoWVCB2ASDlz95SZfRl4GHivEo6IiJQT5SmRwtK0OpHeXQxsBmaGDkREROQdKE+JFIiKI5GDMLPZwAXAqcANZjY2cEgiIiJdlKdECkvFkcgBmJmRW+j6BXdfD3wX+F7YqERERHKUp0QKT8WRyIF9Bljv7o/mj38ITDezuQFjEhER2Ut5SqTAtFudiIiIiIgIGjkSEREREREBVByJiIiIiIgAKo5EREREREQAFUciIiIiIiKAiiMRERERERFAxZGIiIiIiAig4khERERERARQcSQiIiIiIgLA/wefqT/m3biW1wAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 1008x576 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "nvmdp._reset_rewards([0, 0, -0.01], [], [10., 1.0, 10., 5.])\n",
    "traj_states_list, traj_action_list = nvmdp.sample_trajectories(n_traj=41, horizon=100, \n",
    "                                                               init_states=None,\n",
    "                                                               init_cell_types=[\"lightgray\", \"yellow\"], init_unique=True,\n",
    "                                                               rand_init_to_match_n_traj=True)\n",
    "fig = plt.figure(figsize=(14,8))\n",
    "nvmdp.visualize_grid(trajectories=traj_states_list, show_colorbar=True, \n",
    "                     show_rewards_colorbar=True, goal_marker=\"*c\", fig=fig, subplot_str=\"121\")\n",
    "nvmdp.visualize_grid(nvmdp.get_value_grid(), trajectories=traj_states_list, \n",
    "                     show_colorbar=True, show_rewards_colorbar=False, \n",
    "                     goal_marker=\"*c\", fig=fig, subplot_str=\"122\", \n",
    "                     state_space_cmap=False, title=\"Value\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Adding custom obstacles"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "W, H = 30, 30\n",
    "n_obstacles = 30\n",
    "goal_tile = RectangularTile(21,21,1,1)\n",
    "obstacle_cells = list(itertools.chain(*[o() for o in generate_obstacles(\n",
    "                              W, H, n_obstacles, \n",
    "                              obstacle_w_mu=3, obstacle_w_std=3, \n",
    "                              obstacle_h_mu=3, obstacle_h_std=3,\n",
    "                              buffer_w=2, buffer_h=1, max_search_tries=100, exclude_tiles=[goal_tile])]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "(<Figure size 504x504 with 1 Axes>,\n",
       " <matplotlib.axes._subplots.AxesSubplot at 0x1280cb518>)"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "reward_living = -0.01\n",
    "reward_obtacle = -1.0\n",
    "\n",
    "nvmdp = NavigationWorldMDP(width=W, height=H, \n",
    "                      nav_cell_types=['lightgray', 'red'],\n",
    "                      nav_cell_rewards=[0, -10],\n",
    "                      nav_cell_p_or_locs=[1., obstacle_cells],\n",
    "                      goal_cell_locs=[[(goal_tile.x, goal_tile.y)]],\n",
    "                      goal_cell_rewards=[1.],\n",
    "                      goal_cell_types=[\"blue\"],\n",
    "                      slip_prob=0.00, step_cost=0.0, gamma=.99)\n",
    "traj_states_list, traj_action_list = nvmdp.sample_trajectories(n_traj=8, horizon=100, \n",
    "                                                               init_states=[NavigationWorldState(2,2)],\n",
    "                                                               init_cell_types=[\"lightgray\"], init_unique=True,\n",
    "                                                               rand_init_to_match_n_traj=True)\n",
    "nvmdp.visualize_grid(trajectories=traj_states_list, show_colorbar=False, \n",
    "                     show_rewards_colorbar=True, goal_marker=\"*c\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Reference\n",
    "\n",
    "[1] MacGlashan, James, and Michael L. Littman. \"Between Imitation and Intention Learning.\" IJCAI. 2015."
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "irl_python3",
   "language": "python",
   "name": "irl_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.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
