{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Navigation World MDP [1]"
   ]
  },
  {
   "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",
    "\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": "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\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 0x11e0d82e8>)"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.random.seed(0)\n",
    "nvmdp = NavigationWorldMDP(width=30, height=30, \n",
    "                      nav_cell_types=['white', '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=[\"white\"], 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": [
    "## Features used for short horizon"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sample State Trajectory Features: \n",
      "ind:<white, yellow, red, lime, magenta, blue>, dist:<white, yellow, red, lime, magenta, blue>, dist:<blue>\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[[1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 5.0, 7.0, 38.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 2.0, 4.0, 6.0, 37.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 3.0, 3.0, 5.0, 36.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 3.0, 2.0, 6.0, 35.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 2.0, 1.0, 7.0, 34.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 1.0, 2.0, 6.0, 33.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 1.0, 5.0, 32.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 2.0, 1.0, 2.0, 4.0, 31.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 2.0, 1.0, 3.0, 3.0, 30.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 2.0, 2.0, 4.0, 3.0, 29.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 3.0, 5.0, 2.0, 28.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 4.0, 6.0, 1.0, 27.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 4.0, 5.0, 1.0, 26.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 2.0, 3.0, 5.0, 1.0, 25.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 2.0, 2.0, 4.0, 1.0, 24.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 3.0, 5.0, 1.0, 23.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 3.0, 6.0, 2.0, 22.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 2.0, 7.0, 2.0, 21.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 3.0, 6.0, 1.0, 20.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 2.0, 5.0, 1.0, 19.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 4.0, 2.0, 18.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 2.0, 3.0, 1.0, 17.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 2.0, 3.0, 2.0, 2.0, 16.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 3.0, 1.0, 3.0, 15.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 2.0, 3.0, 2.0, 4.0, 14.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 2.0, 3.0, 5.0, 13.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 1.0, 2.0, 6.0, 12.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 2.0, 3.0, 7.0, 11.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 3.0, 2.0, 6.0, 10.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 4.0, 3.0, 5.0, 9.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 2.0, 5.0, 3.0, 4.0, 8.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 2.0, 4.0, 2.0, 3.0, 7.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 3.0, 3.0, 2.0, 6.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 2.0, 3.0, 4.0, 1.0, 5.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 2.0, 2.0, 4.0, 2.0, 4.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 3.0, 3.0, 3.0, 1.0, 3.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 3.0, 2.0, 2.0, 1.0, 2.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 2.0, 1.0, 3.0, 2.0, 1.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": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(\"Sample State Trajectory Features: \\nind:<{}>, dist:<{}>, dist:<{}>\\n\".format(\n",
    "                                \", \".join(nvmdp.combined_cell_types), \n",
    "                                \", \".join(nvmdp.combined_cell_types), \n",
    "                                \", \".join(nvmdp.goal_cell_types)))\n",
    "[nvmdp.feature_at_state(s,\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() for s in traj_states_list[0]]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Features used for long horizon"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sample State Trajectory Features: \n",
      "ind:<white, yellow, red, lime, magenta, blue>, dist:<white, yellow, red, lime, magenta, blue>, dist:<blue>\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[[1.0, 0.0, 0.0, 0.0, 0.0, 38.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 37.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 36.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 35.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 34.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 33.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 32.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 31.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 30.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 29.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 28.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 27.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 26.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 25.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 24.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 23.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 22.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 21.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 20.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 19.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 18.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 17.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 16.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 15.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 14.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 13.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 12.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 11.0],\n",
       " [0.0, 1.0, 0.0, 0.0, 0.0, 10.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 9.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 8.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 7.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 6.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 5.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 4.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 3.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 2.0],\n",
       " [1.0, 0.0, 0.0, 0.0, 0.0, 1.0],\n",
       " [0.0, 0.0, 0.0, 0.0, 0.0, 0.0]]"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(\"Sample State Trajectory Features: \\nind:<{}>, dist:<{}>, dist:<{}>\\n\".format(\n",
    "                                \", \".join(nvmdp.combined_cell_types), \n",
    "                                \", \".join(nvmdp.combined_cell_types), \n",
    "                                \", \".join(nvmdp.goal_cell_types)))\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": [
    "## Multiple Goals"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "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": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.random.seed(0)\n",
    "nvmdp = NavigationWorldMDP(width=30, height=30, \n",
    "                      nav_cell_types=['white', '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=[\"white\"], 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": 6,
   "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 0x11e933f28>)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "nvmdp = NavigationWorldMDP(width=7, height=7,\n",
    "                      nav_cell_types=['white', '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=[\"white\", \"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": 7,
   "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 0x11eb1c828>)"
      ]
     },
     "execution_count": 7,
     "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=[\"white\", \"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": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZIAAAF8CAYAAADlzD0IAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMi4yLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvhp/UCwAAIABJREFUeJzt3Xt4XPV95/H31xKyhQYWEVzMzSW0kE0KxI6FXaB2LiKAqRPYtqlE2ST1k4Te0m6zS1p21xJg/DR5kt1tt03b1JtCk5II2vQSUFEUEkoCOAjLtbOB7kNNktbcxFUg62LJI3/3j3NkRmJkjfQ7Z84c6fN6nvOMzm/OnN/XPx3PR+cyc8zdERERWahlWRcgIiL5piAREZEgChIREQmiIBERkSAKEhERCaIgERGRIAoSqXlmdp2ZfSOlda82s2Ezq0tj/SJLgYJEEmFm/2pmL5hZU0nbR83sgdB1u/uX3f3y0PXA0TovK1n3AXcvuPtkEuuf0ZfHY1Jf0nZc3OYlbQ+Y2SEzO2hmQ2a2x8xuNLPlJcvcbGaH49B71cx2mdnFSdcsshAKEklSHfCfsi6ixgwCm0vmN8dtM33c3U8ATgP+C9AO3GtmVrLMXe5eAFYCDwF/O+N5kUwoSCRJnwVuMLOTyj1pZv/bzJ4q+at7Y9x+upmNmdnJJcuuNbOX4r/gf9nMHip57nIze8LMXjOzPzGzb5vZR+PnfsLM7jezl+PXf3mqHjP7S2A1cE/8l/3vmNnZ8Z5DfUktd5vZK2b2pJl9rKTfm83sr8zsS/Hew+Nm1jLHmPwl8KGS+Q8BX5ptYXcfcfcHgPcDFwM/W2aZw8AXgVXAm+boXyR1ChJJUj/wAHDDLM/vBtYAJwNfAf7azFa4+7PAd4GfL1n2l4Cvxm+aR5nZKcBXgf9K9Cb6BHBJ6SLAp4DTgbcCZwE3A7j7B4EDwPviw1mfKVPjncDT8et/Afg9M3tPyfPvj5c5Cbgb+Nws/9Ypfw9sMrOTzKwZ2Ah8bY7X4O4HiMZz48zn4kNevww85e4vzbUukbQpSCRpncBvmtnKmU+4+x3u/rK7F939fwLLgbfET38FuBYgPlzTHrfNdBXwuLv/rbsXgT8EBkr6eNLd73P3cXd/EfhfwDsrKdzMzgIuBX7X3Q+5+z7gC0zfo3jI3e+Nz6n8JfD2OVZ7CLgHaIunu+O2SjxLFLpTftHMXgWeAtYB/6HC9YikSkEiiXL3x4Bu4MaZz5nZDWb2/+JDUq8C/w44JX76b4CLzew0YBNwBHiwTBenE72RTvXnRHsQU32camZ3mtkzZjYE3FHSx1xOB15x94Mlbf8GnFEyP1Dy8yiwovRk+iy+RBRGxzysVcYZwCsl83/l7ie5+4+5+3vcfc881iWSGgWJpOEm4GOUvAHH50N+B/hFoNndTwJeIzoUhbsPAt8g+qv9l4A7vfxXUz8HnFmyXiudB34PcOACdz8R+I9TfcSO9XXXzwInm9kJJW2rgWeO9Y+twINEJ9FPJTpJPqd472gd5cNUpKYoSCRx7v4kcBfwWyXNJwBF4EWg3sw6gRNnvPQrRH+1/wLlD2sB/ANwgZldE+8J/AbRSefSfoaB18zsDOCTM17/PHDOLHU/BewCPmVmK8zsQuAjRHs1CxYH4vuA988SjkeZ2fFm9k6i8yiPAveG9C1SDQoSSct2oKlkvhf4OvAvRIeLDlFyiCp2N3AuMODu3yu30vjk8geAzwAvA28jOik9Hi9yC/AOor2dfwD+dsYqPgVsiz+LUe6igGuBs4n2Tv4OuMndvznHv3VO7v64uz9+jEU+Z2YHiYLuD4gO9V3p7kdC+xZJm+nGVpJnZraM6BzJde7+j1nXI7IUaY9EcsfMrogvp10O/DeicyCPZFyWyJKlIJE8uhj4AfAS0bmHa9x9LNuSRGqLmd0Wfx3PYyVtJ5vZfWa2P35snuW1H46X2W9mH56zLx3aEhFZfMxsE9GFJ19y9/Pjts8QXeL+aTO7kegKyt+d8bqTic47thBd5bgHWBdfWVmW9khERBYhd/8O0z+HBHA10dfrED9eU+alVwD3ufsrcXjcB1x5rL4UJCIiS8ep7v5c/PMA0WebZjqD6VdUPs30D+W+wVyfyE3dKaec4meffXbWZSxAXj9UvC7rAhYor+OdV/ncTp7d82zWJczbq7zKqI8e/dDsT9pP+iijc77uOZ57nOlft7PT3XdW2q+7e+ntDEJkHiRnn302/f39WZexAHn99u48jjXkd7zzKp/byS12S9YlzNuf8WfT5kcZ5Vf4lTlfdzM3H3L3ub59eqbnzew0d38u/jqiF8os8wzwrpL5M4m+jHVWOrQlIrJ03A1MXYX1Ycp/E3UvcLmZNcdXdV0et81KQSIisgiZWRfR7RneYmZPm9lHgE8D7zWz/cBl8Txm1mJmXwBw91eAW4lu+7Ab2B63zSrzQ1siIpI8d792lqdayyzbD3y0ZP424LZK+9IeiYiIBFGQiIhIEAWJiIgEUZCIiEgQBYmIiARRkIiISBAFiYiIBFGQiIhIEAWJiIgEUZCIiEgQBYmIiARRkIiISBAFiYiIBFGQiIhIEAWJiIgESS1IzOxKM3sgnp4zs2vS6mumiYkJOjs7aW1tpbOzk4mJiWp1HWRiAjo7obU1esxJ2QwPD7Np0yaam5vZtGkTw8PDWZdUkclJ6O6GW2+NHicns65obnndRsbGxmhvb+ecc86hvb2dsbGxrEuSBJl7Ivd+P3YnZn1Aq7u/4R2mpaXFk7xn+8TEBKtWrWJwcPBoW3NzMwMDAzQ0NCTWT9L3EJ+YgFWroKRsmpthYAASLZtkf9/Dw8OccMIJb2g/ePAghUIhwZ6SHe/JSbjiCujrg5ERaGqCDRugtxfq6hLtKjHV20Ygye1kbGyME088kWKxeLStvr6eoaEhGhsbE+sH8nvP9mf92aMb+Ol2uld4z/Y9C7hneypSP7RlZucAz5cLkTTs2LFjWogADA4OsmPHjmp0v2A7dkx/g4BovsbL5qqrrppXe63o6YlCZHgY3KPHvr6ovVbldRvZunXrtBABKBaLbN26NaOKJGmp75GY2Q3Ay+5+e0nb9cAngZNWrlx5ygsvvJBYf62trdx///3l6uC4445LrB9I9pjC4cPRG5qI1KabuTmV9S6GPZJq3LP9fcDPlTa4+05gJ0SHtpLs7NJLLy0bJNu2bWP79u0J9pTsoZbOzuhY/UwdHZBo2Qkf2tq0aRMPPvjgG9o3btzId77znQR7Sna8u7vh2mujPZEphQJ0dcGWLYl2lZjqbSOQ5HbS3t7OXXfd9Yb2trY27rzzzsT6gfQObaUVIotFqoe2zGwVMOHuL6fZT6lt27bR3Nw8ra25uZlt27ZVq4QF2bYtOt5dqrk5aq9l995777zaa8XmzdE5kanTOIVCNL95c7Z1HUtet5Hbb7+d+vrpf7PW19dz++23z/IKyZu0z5FcDXwt5T6maWhoYGBggI6ODt70pjfR0dGRwon25DU0RCdNOzqiK3I6OtI6iZqsQqHAwYMH2bhxIxDtiSR/oj15dXXRifWurmi+q6u2T7TD9G0E8rONNDY2MjQ0RFtbGxDtiaRxol2yU5Wrto4l6au2Sm3ZsoXu7u5U1p30oZbqSe/3bWaktz2lN95m+Ts/tWwZHDmSZg/pDEi620i6h7Z0jmR2+kCiiIgEUZCIiEgQBYmIiARRkIiISBAFiYiIBFGQiIhIEAWJiIgEUZCIiEgQBYmIiARRkIiISBAFiYiIBFGQiIhIEAWJiIgEUZCIiEgQBYmIiARRkIiISBAFiYiIBKmfexEpK7c3SEy78LwOjEyX5u8xvXXflNLNF282uMlvTmXd99TEPQ7DaI9ERESCKEhERCSIgkRERIIoSEREJIiCREREgihIREQkiIJERESCKEhERCSIPpAoIlJDTn/zc9y04+Y5l7v5utRLqZj2SEREJIiCREREgihIREQkiIJERESCKEhERCSIgkRERIIoSEREFiEzu83MXjCzx2Z53szsD83sSTP7v2b2joX2pSAREVmc/gK48hjPbwbOjafrgT9daEcKEhGRRcjdvwO8coxFrga+5JFHgJPM7LSF9KUgERHJp1PMrL9kun6erz8DeKpk/um4bd70FSkiIvn0krvXxB3fU90jMbMPmdm3zOwBM1tQ0i3E5OQk3d3d7N+/n+7ubiYnJ6vV9ZI0OQnd3dHP3d3RfB6MjUF7e/Rze3s0X+umxto9X2OtbaQmPQOcVTJ/Ztw2f+6eykS0i/Tncy23bt06T1KxWPTW1lYvFAoOeKFQ8NbWVi8Wi4n249H/5fxNCf+qi0W8tRUvFIjHO5ovFlPbtBKZRkfx+vqo5qmpvj5qz7q2xTbWea27WtvIunV4acO6N+P+5bknoH+ulQNnA4/N8tzPAj2AAT8NPLrQf0SaeyRXAHXxHskfmVldin0d1dPTQ19fH8PDwwAMDw/T19dHT09PNbpfcnp6oK8P4uFmeDiar/Xh3roVisXpbcVi1F6r8jrWea07j9tIKTPrAr4LvMXMnjazj5jZr5rZr8aL3Av8EHgS+D/Ary+0rzSD5FSgwd1bgVGiKwQAMLPrzWy/mb144MCBRDvdu3cvIyMj09pGRkbYt29fov1IZO9emDHcjIxArQ/3o4+Wb9+9u7p1zEdexzqvdedxGynl7te6+2nufpy7n+nuf+7un3f3z8fPu7v/hrv/hLtf4O79C+0rzSB5Dfh2/PP9wFunnnD3ne5+rruvXL16daKdrl27lqampmltTU1NrFmzJtF+JLJ2LcwYbpqaoNaHe/368u0XXVTdOuYjr2Od17rzuI1kJc0g2QVcGP+8BvhRin0dtXnzZjZs2EChUMDMKBQKbNiwgc2bN1ej+yVn82bYsAEKhWi+UIjma324b78d6mdcs1hfH7XXqryOdV7rzuM2kpXUgsTd9wFjZvYAcBHw1bT6KlVXV0dvby9dXV1s376drq4uent7qauryimaJaeuDnp7oasrmu/qiuZrfbgbG2FoCNraovm2tmi+sTHbuo6ldKzr6vIz1tpGFj+Lz95npqWlxfv7F3xoLjtmWVewMCn+us2iS8PyZtkyOHIk6yrmZ/lyGB/Puor5y+s2kmbdLS3Q3+9H31BazjHv31FBTdexx5fC50hERGTxU5CIiEgQBYmIiARRkIiISBAFiYiIBFGQiIhIEAWJiIgEUZCIiEgQBYmIiARRkIiISBAFiYiIBFGQiIhIEAWJiIgEUZCIiEgQBYmIiARRkIiISBAFiYiIBKmfexFZXNK8PZ2lvP60LAPSukViTu+kmdrvMa/bSJp118RNDoNoj0RERIIoSEREJIiCREREgihIREQkiIJERESCKEhERCSIgkRERIIoSEREJIiCREREgihIREQkiIJERESCKEhERCSIgkRERIIoSEREJIiCREREgihIREQkiG5sJSJSQ/b8aB12XX8FS9bOTdO0RyIiIkEUJCIiEkRBIiIiQVILEjM728yeN7MHzOwbafVTzuTkJN3d3dx66610d3czOTlZze6XnOHhYTZt2gTApk2bGB4ezriiyoyNjdHe3o67097eztjYWNYlzWlyErq7pz/mwdRYA7kZa8hv3VXn7qlMwNnAHXMtt27dOk9SsVj01tZWLxQKbmZeKBS8tbXVi8Viov045HNK2MGDBx14w3Tw4MHE+0rS6Oio19fXT6u5vr7eR0dHE+4puf9WxSLe2ooXClG9hUI0Xyym8V84OdUb62RVq+74PbDkvXNdhf+d6ffkf/ELmtI+tPVuM3vQzD6Rcj9H9fT00NfXx/DwMO7O8PAwfX199PT0VKuEJeWqq66aV3ut2Lp1K8VicVpbsVhk69atGVU0t54e6OuDqR2+4eFovtY37TyONeS37iykGSTPAecB7wYuM7MLp54ws+vNbL+ZvXjgwIFEO927dy8jIyPT2kZGRti3b1+i/Ujk+9//ftn2xx57rMqVzM+jjz5atn337t1VrqRye/fCjE2bkRGo9U07j2MN+a07C6kFibuPu/uIuxeBbuD8kud2uvu57r5y9erVifa7du1ampqaprU1NTWxZs2aRPuRyAUXXFC2/fzzzy/bXivWr19ftv2iiy6qciWVW7sWZmzaNDVBrW/aeRxryG/dmUjrmBlwQsnPdwAbyi2X5jkSQOdIdI6kLJ0jmWtKjs6RHJvOkRzbRjPbY2a7gGfcvS/Fvo6qq6ujt7eXrq4uzjvvPLq6uujt7aWurq4a3S85hUKBgwcPsnHjRurr69m4cSMHDx6kUChkXdoxNTY2MjQ0RFtbG42NjbS1tTE0NERjY2PWpc2qrg56e6GrK9oT6eqK5mt90y4dayAXYw35rTsLFiVgdlpaWry/v5KvA5i/LVu20N3dncq6sdr5eoJ5SfH3nep4pyjdutPZTk49FZ5/PpVVx9LZTpYvX874+Hgq605TmnW3tLTQ399/dEMxa3Go6CtS9rh7SypFzZM+kCgiIkEUJCIiEkRBIiIiQRQkIiISREEiIiJBFCQiIouQmd1mZi+Y2WMlbSeb2X3xN4vcZ2bNs7z2w/Ey+83sw3P1pSAREVmc/gK4ckbbjcC33P1c4Fvx/DRmdjJwE7ABWA/cNFvgTFGQiIgsQu7+HeCVGc1XA1+Mf/4icE2Zl14B3Ofur7j7IHAfbwykaXTPdhGRfDrFzEo/ubjT3XfO8ZpT3f25+OcB4NQyy5wBPFUy/3TcNisFiYhIPr0U8sl2d3czS+QrDHRoS0Rk6XjezE4DiB9fKLPMM8BZJfNnxm2zUpCIiCwddwNTV2F9GPhamWV6gcvNrDk+yX553DYrBYmIyCJkZl3Ad4G3mNnTZvYR4NPAe81sP3BZPI+ZtZjZFwDc/RXgVmB3PG2P22alcyQiIouQu187y1OtZZbtBz5aMn8bcFulfWmPREREgihIREQkiIJERESC6BzJkpP2nR1zeufI1OpO646UpwKp3iJRpGLaIxERkSAKEhERCaIgERGRIAoSEREJoiAREZEgChIREQmiIBERkSAKEhERCaIgERGRIAoSEREJoiAREZEgChIREQmiIBERkSAKEhERCaIgERGRIAoSEREJoiAREZEgChIREQmiIBERkSCpB4mZfcLMHkq7HxERycasQWJm95rZ2SErN7PlwJqQdSzExMQEnZ2dPPLII3R2djIxMVHtEpaUyUno7ob9+6PHycmsK6pMHuue2rYHBwdztW2PjY3R3t7OxMQE7e3tjI2NZV1SRfJad9W5e9kJ+ADwL8B/B46bbbljTcCvA+8BHpptmXXr1nmSxsfHvbm52YGjU3Nzs4+Pjyfaj0M+p/n/Go85FYt4ayteKERjXShE88Vi8n3ls+7kVG3bTtjo6KjX19dPq7u+vt5HR0ezLu2YqlV3/B54dKOBdRX+d6bfk91YFzzNukfi7n8NvAM4Eeg3sxvM7D9PTXMFlJkdB7zL3e+fd7oF2LFjB4ODg9PaBgcH2bFjRzXLWDJ6eqCvD4aHo/nh4Wi+pyfbuuaSx7rzum1v3bqVYrE4ra1YLLJ169aMKqpMXuvOwlznSCaAEWA5cMKMaS4fBL5S7gkzu97M9pvZiwcOHJhHuXN7+OGHy7bv2rUr0X4ksncvjIxMbxsZgX37sqmnUnmsO6/b9qOPPlq2fffu3VWuZH6yqnsde3BszqmWHOscyZXAPuB44B3ufpO73zI1VbDutwC/ZmZfB37KzH5z6gl33+nu57r7ytWrV4f+G6a59NJLy7ZfcsklifYjkbVroalpeltTE6yp+pmx+clj3XndttevX1+2/aKLLqpyJfOT17ozMdsxL+BB4KeSOH6GzpHUzpTiuQazfJ4jSbfu5OgcSXVldY5kXYX/l8nJOZKN7v54QmH1M0mspxINDQ0MDAzQ0dGBmdHR0cHAwAANDQ3VKmFJqauD3l7o6oLt26PH3t6ovZblse7Sbbu1tTU323ZjYyNDQ0O0tbVxzjnn0NbWxtDQEI2NjVmXdkx5rTsL5u6ZFtDS0uL9/f2prHv58uWMj4+nsm6sto5RVizbX/cSpAGXY2tpaaG/v//oG0qLmVfyjmiwx91bUiytYvpku4iIBFGQiIhIEAWJiIgEUZCIiEgQBYmIiARRkIiISBAFiYiIBFGQiIhIEAWJiIgEUZCIiEgQBYmIiARRkIiISBAFiYiIBFGQiIhIEAWJiIgEUZCIiEgQBYmIiASpz7oA2AOkebfBnN7JUBaJvG5/eb2zY17HO9+0RyIiIkEUJCIiEkRBIiIiQRQkIiISREEiIiJBFCQiIouYmf17M/uumY2b2Q0znrvSzJ4wsyfN7MaF9lEDl/+KiEiKXgF+C7imtNHM6oA/Bt4LPA3sNrO73f2f59uB9khERBYxd3/B3XcDh2c8tR540t1/6O4TwJ3A1QvpQ0EiIrI0nQE8VTL/dNw2bzq0JSKST6eYWX/J/E5335lFIQoSEZF8esndW8o9YWa/AXwsnr3K3Z8ts9gzwFkl82fGbfOmQ1siIouMu/+xu6+Jp3IhArAbONfM3mxmDUA7cPdC+tMeiYjIImZmq4B+4ETgiJn9NvA2dx8ys48DvUAdcJu7P76QPhQkIiKLmLsPEB22KvfcvcC9oX3o0JaIiARRkIiISBAFiYiIBFGQiIhIEAWJiIgESS1IzOx8M9tlZg+a2e1mppspi4gsQmnukTzh7pe4+8Z4vuwnMNMwMQGdnXD4cPQ4MVGtnpemqfFubc3XeOex7slJ6O6GW2+NHicns66oMpOTk3R3d3PrrbfS3d3NZE4Kz+M2kgl3T30CPg+sKvfcunXJdjc+jjc34/D61NwctSf6zyKnU8K/3qqNt+r2YhFvbcULBdwsemxtjdqT7y85xWLRW1tbvVAouJl5oVDw1tZWLxaLifYTyd82Er0Hvt6wrsL/y0B/ooUETKmeIzGz95vZY8CpwMtp9jVlxw4YHJzeNjgYtUvy8jreeay7pwf6+mB4OHonGR6O5nt6sq7s2Hp6eujr62N4eBh3Z3h4mL6+PnpqvPA8biNZSTVI3P1udz+f6OuJt0y1m9n1ZrbfzF48cCDZPh9+uHz7rl3J9iORvI53HuveuxdGRqa3jYzAvn3Z1FOpvXv3MjKj8JGREfbVeOF53EaykubJ9uUls0PA2NSMu+9093PdfeXq1cn2e+ml5dsvuSTZfiSS1/HOY91r10JT0/S2piZYsyabeiq1du1ammYU3tTUxJoaLzyP20hm0jpmRnSnrW/H0xeAZeWW0zmSKk8J/6rzeK4hr3WXniOBfJ4jierWOZLSaTGcI8m8gKSDZGoD6OiIfvEdHSm9OWQdCDUSJKXjfdxxKY636nb3KDTuuQc/77zoMZ0QwZNWLBb9nnvu8fPOO8/vueeelELEPY/byGIIEnP3Ku7/vFFLi3l//9zLLYRZNOLprDyl9aYtxV/3qafC88+nt/605LHuLVuiy3/Tk86GsmXLFrpTLTyd/5hpbiMtLdDf70cLbzHzSt4SDfb4LDe2qjZ9sl1ERIIoSEREJIiCREREgihIRERqyTqYfq3YLFMNUZCIiEgQBYmIiARRkIiISBAFiYiIBFGQiIhIEAWJiIgEUZCIiEgQBYmIiARRkIiISBAFiYiIBFGQiIhIEAWJiIgEUZCIiEiQ+qwLEFnc0vqa1i1A/u40mP66JQvaIxERkSAKEhERCaIgERGRIAoSEREJoiAREZEgChIREQmiIBERkSAKEhERCaIgERGRIAoSEREJoiAREZEgChIREQmiIBERkSAKEhERCaIgERGRIAoSEREJoiAREZEgChIREQmiIBERkSCpBYmZbTCzXWb2kJn9flr9lDMxAZ2d0c+dndG8pGdqvAcH8zXek5PQ3Q0jI9Hj5GTWFc1tbGyM9vZ27r//ftrb2xkbG8u6pIpMbSOPPJKvbWRsDNrb4aWXosecDHf1uXsqE7AKWBH//GXggnLLrVuXbNfj43hzMw6vT83NUXui/0RyOiX8q67aeCc8FYt4ayteKEQ1FwrRfLGYdF/JGR0d9fr6+mljXV9f76Ojo4n2E9E2MjqK19czY7yj9iT7id4DX2+o9D0R6M98kOIptT0Sdx9w90Px7GGgKn/v7dgR/WVcanAwapfk5XW8e3qgrw+Gh6P54eFovqcn27qOZevWrRSLxWltxWKRrVu3ZlRRZfK6jWzdCjOGm2IxapfpUj9HYmYXAivd/Z9L2q43s/1m9uKBA8n29/DD5dt37Uq2H4nkdbz37o0OaZUaGYF9+7KppxKPPvpo2fbdu3dXuZL5yes2MstwU+PDnYlUg8TMTgY+B3yktN3dd7r7ue6+cvXqZPu89NLy7Zdckmw/EsnreK9dC01N09uammDNmmzqqcT69evLtl900UVVrmR+8rqNzDLc1PhwH2VmV5rZE2b2pJndmGpnaR0zA+qBe4H1x1pO50iqPCX8q87r8W+dI5mLtpE8nyMB6oAfAOcADcD3gLelNVhp7pF8ALgI+IyZPWBmF6fY11ENDTAwAB0d0XxHRzTf0FCN3peevI53XR309kJXV/RzV1c0X1eXdWWza2xsZGhoiLa2NgDa2toYGhqisbEx48qOrXQbMcvPNtLYCENDEA83bW3RfI0P95T1wJPu/kN3nwDuBK5OqzOL0yszLS3m/f3prNss+jM8nZWntN60pfjrXrYMjhxJb/1pWb4cxsfTWns6A75s2TKOpDrY6Wzg6Y51etJ8L2lpgf5+t9fnK3tPNGOPu7eUf85+AbjS3T8az38Q2ODuH0+m6unq01ipiIik7hQzK42cne6+M4tCFCQiIvn00mx7JMAzwFkl82fGbanQV6SIiCw+u4FzzezNZtYAtAN3p9WZ9khERBYZdy+a2ceBXqIruG5z98fT6k9BIiKyCLn7vUQfwUidDm2JiEgQBYmIiARRkIiISBAFiYiIBFGQiIhIEAWJiIgEUZCIiNSUdTD9S4dnmWqHgkRERIIoSEREJIiCREREgihIREQkiIJERESCKEhERCRI9t/++wrwlRTXn+a6ReaU5j2Z01x3WpeXLgfSu9eupTYkhllaYzLbvanyQ3skIiISREEiIiJBFCSCGCzrAAAIsUlEQVQiIhJEQSIiIkEUJCIiEkRBIiIiQRQkIiISREEiIiJBFCQiIhJEQSIiIkEUJCIiEkRBIiIiQRQkIiISREEiIiJBFCQiIhJEQSIiIkEUJCIiEmTRBslr1gTbt0ePIiIL1VSE7dujRylr0QbJ3SsugY0buWfFxVmXIiJ5dslLsHEjXPxS1pXUrNSCxMxON7N/MrNDZlb1e8PfdvzmaY+SnokJ6OwE9+hxYiLriiozVffhw/mpe3ISurujse7ujubzYGJigs7OTg4fPkxnZycTeRjsKZsHpj/KG5h7Oje0N7MVQCPwd8Bl7l52v7DlHPP+HeH9Xfamz/Kt5S1H5xt8gglrOPo4pXW8n2++/MnwDq8LX0UmEv51T0zAqlUwOPh6W3MzDAxAQ8Psr8taHuuenIQrroC+PhgehkIBNmyA3l6oq0u6t+Q2lImJCVatWsVgyWA3NzczMDBAQ8KDbZbASj67D1pefX1+wqDBX3+c0n8SfHJNAh224N5/tPKWlhbv7++f81VmtsfdW+ZcsApS2yNx90PuPjj3ksn47we/zPFHDh2dnwqP0hA5/sghth28o1olLQk7dkx/M4ZofkcCfxykKY919/S8HiIQPfb1Re21bMeOHdNCBGBwcJAdtTrYX/5xOFTy1jgVHqUhcmgZ3PHj1a2rhqW2R3K0A7MHmLFHYmbXA58ETlp5Aqe88Plk+vrHhjVsOflTjC5b8Ybnjj9yiH945UbeNfG9ZDrTHgkAra1w//3JrlMkc2vWwKc+BSve+F7CoWVw4wXwveaEOtMeyYK4+053P9fdV64+Jbn1vntiH3cN3sIKH5/WvsLHuWvwluRCRI669NLy7R0d0XH8Wp06OvJX9z33RIezShUKUXvy/XliU8csg93R0ZFoP9EfxQlN+/bCLS0wPuMtcnwZ3PK2BENkcVh0V229uqxAvU+yzCdpPHKIZT5JvU/y6rLC3C+Wedu2LTq3UKq5OWqvZXmse/Pm6JxIoRCdC5g6R7K5xq8n2bZtG80zBru5uZlttTzYAIUiTBJNh5a9/nNBlwHPlOZVW8eZ2TeBtwO9ZrYhrb5K/fnxVzFqK3j74R/wtcFtvP3wDxi1Fbp6KyUNDdEJ6o6O6DBXR0dtn7Cekse66+qiE+tdXdHHGrq60jrRnqyGhgYGBgbo6OigtbWVjo6OVE60J+6qAVhxBH5QgG3nR48rjujqrTJSP0cyl6Su2ppyTfOtbJr4Hr898jcsw5lkGX/Q9PM82HAhfz84y/GMhdA5ElnU8rmhJHLV1pRbvw/fOwn+5kxwg2UOP/8UXPgadFyQYEf5P0ey6IKkahQksqjlc0NJNEiqJv9BsujOkYiISHUpSEREJIiCREREgihIREQkiIJERESCKEhERCSIgkRERIIoSEREJIiCREREgihIREQkiIJERESCKEhERCSIgkRERIIoSEREJIiCRERkETKzK83sCTN70sxuTLMvBYmIyCJjZnXAHwObgbcB15rZ29LqT0EiIrL4rAeedPcfuvsEcCdwdVqd1ae14krt+REv2XX8W0qrXw0cSGndaUqv7nTvIKfxrp6Ua05tQ8njWEO6df946cyePXt6zeyUCl63wsxKb6W40913xj+fATxV8tzTwIawMmeXeZC4+8q01m1mL9bKrSjnQ3VXVx7rzmPNoLor4e5XVqOfJC32Q1uvZl3AAqnu6spj3XmsGVR3tTwDnFUyf2bclorFHiSvZV3AAqnu6spj3XmsGVR3tewGzjWzN5tZA9AO3J1WZ5kf2krZzrkXqUmqu7ryWHceawbVXRXuXjSzjwO9QB1wm7s/nlZ/5u5prVtERJaARXloy8xON7N/MrNDZpabvS4z22Bmu8zsITP7/azrqZSZnR/X/aCZ3W5m6V4bliAz+4SZPZR1HfNhZmeb2fNm9oCZfSPreiplZh8ys2/FdZ+RdT2ViD/U90A8PWdm12RdUy1alEECvAK0Ao9kXcg8/RvwHnf/GeDHzOyCrAuq0BPufom7b4znc3FVjpktB9ZkXccC3efu73L3y7MupBJxcLzT3VvjulM78Zskd/96XO+7iC7//WbGJdWkRRkk7n7I3QezrmO+3H3A3Q/Fs4eBySzrqZS7Hy6ZHWf69eu17CPAF7MuYoHeHe8BfiLrQip0BVAX75H8UfzJ69wws3OA5919OOtaatGiDJK8M7MLgZXu/s9Z11IpM3u/mT0GnAq8nHU9czGz44B3ufv9WdeyAM8B5wHvBi6Lt5dadyrQ4O6twCgpfso6JT8H/F3WRdQqBUmNMbOTgc8R/bWcG+5+t7ufT/QJ2i1Z11OBDwJfybqIhXD3cXcfcfci0A2cn3VNFXgN+Hb88/3AWzOsZSHeR4qXz+adgqSGxBcG3AHc4O4DWddTqfhcw5QhYCyrWubhLcCvmdnXgZ8ys9/MuqBKmdkJJbOXAj/IqpZ52AVM7TmtAX6UYS3zYmargAl3r/k97awsyiAxs+PM7JvA24FeM0vtO2YS9gHgIuAz8VUiF2ddUIWuNLNvm9m3iQ5h1PyVRO7+u+5+Rfx1FI+7+x9lXdM8bDSzPWa2C3jG3fuyLmgu7r4PGDOzB4i28a9mW9G8XA18Lesiapk+RyIiIkEW5R6JiIhUj4JERESCKEhERCSIgkRERIIoSEREJIiCRJYcMzvLzH4Uf/gTM2uO58/OtjKRfFKQyJLj7k8Bfwp8Om76NNH9rv81s6JEckyfI5ElKf6urT3AbcDHgDUzvnxSRCqUm3t1iCTJ3Q+b2SeBrwOXK0REFk6HtmQp20z0Tbp5+NJDkZqlIJElyczWAO8Ffhr4hJmdlnFJIrmlIJElJ74V8J8Cv+3uB4DPAv8j26pE8ktBIkvRx4AD7n5fPP8nwFvN7J0Z1iSSW7pqS0REgmiPREREgihIREQkiIJERESCKEhERCSIgkRERIIoSEREJIiCREREgihIREQkyP8HzpqkAAEElWMAAAAASUVORK5CYII=\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 0x11ea9dcf8>)"
      ]
     },
     "execution_count": 8,
     "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=[\"white\", \"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": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(<Figure size 1008x576 with 4 Axes>,\n",
       " <matplotlib.axes._subplots.AxesSubplot at 0x11eca4ba8>)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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IfUciYiIiIhIRDTnSEREREREBICM5hyJiIiIiMiZru0isMWiePqwREREREREIqSeIxERERERiYzmHImIiIiIyBkvuAhs8QyrU3IkIiIiIiKRKaYFGYqnD0tERERERCRC6jkSEREREZFIOGhYnYiIiIiICGhBBhEREREREfDiWpCheNI0ERERERGRCKnnSEREREREIuEU12p1So5ERERERCQyxTSsTsmRiIiIiIhEothWq9OcIxEREREREdRzJO085PqXABtCbiNMhYi/eH416b+w30djgTdDbiNsRrj/n2aHWPeZyQBLxvy3xNHVUUcwYA0XjAy1/ta3hoTaxhvzw/2Mb9kdfhsTHg/7Mz58Yb+GgyfDb+M8vhRq/XAD590TXhtv1H33lLJi6jlSciQiMoiVHM9w1rNNUYchIiLSLae4lvJWciQiIiIiIpEpptXqYj5OQEREREREJD/UcyQiIiIiItFwzTkSEREREREpuqW8lRyJiIiIiEhkiik50pwjERERERER1HMkIiIiIiIR0VLeIiIiIiIiWa7kSERERERERNc5EhERERERKTrqORIRERERkUh4kV3nSD1HIiLSKzO73cwOm9nzPdxvZvZ9M3vZzH5jZh8sdIwiIhJP7tbrrVCUHImISF/8O3Dlae5fDJyfvV0P/FMBYhIRkdgLVqvr7VYoSo5ERKRX7v44cPQ0D/k08CMPPA2MNLPxhYlOREQkP5QciYhIPpwD7O+wfSBbJiIiclrFNKxOCzKIiAjAaDPb3mH7Nne/LbJoRETkjOAU14IMSo5ERATgLXefPYDnHwQmddiemC0TERHpmQcr1hULDasTEZF8uB/4QnbVug8Dx9z9UNRBiYiI5EI9RyIi0iszWw98jGD43QHgJmAIgLvfCjwAXAW8DBwHro0mUhERiZsMGlYnIiIx4u7Le7nfga8WKBwRERkkHAq64EJvQhtWZ2ZTzOxNM3vMzB4Kq52epFIpVq1axYIFC1i1ahWpVKrQIQjv7oenn346lvuhubmZZcuWsXnzZpYtW0Zzc3PUIeUsnYYNG2DNmuBvOh11RLlrex/V1dXF8n0E0NjYyPz58wGYP38+jY2NEUckUZ+nMplWXj65k20nHublkzvJZFoLHYIQ7Id9uzbRcPR19u3aFLv9kE6lOHzHj2nZ8zKH7/gx6Rh+PrpnOHpoF/tffJij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40uWxOvL4GBSWQmPPx6smPb44/H7MlheDnffDaNHB39j9H28XduxsGJFfI+F8vJy7r77bkpLS7n77rtjlRi1aTsWzOJ5LLQxs2lm9iszO2FmN3S570oze8nMXjazG6OKMS7MEpxdcR4AZ1ecF6svg4NJSUkZF370K4wc+z4u/OhXYpMYtUmWlnL2NZ8nUVHB2dd8PlaJURuzBKPGT2fStIWMGj89lsdCMlnK++Z8Dksked+cz8UqMWpTUlbG+L/4KgDj/+KrhUuMikxoS3mLiMigdBT4C+AzHQvNLAn8APgEweIG28zsfnffVfgQRUQkTs6YpbxFRGRwcffD7r4NONnlrjnAy+7+qrungLuBTxc8QBERiR8NqxMRkUHmHDpfRPVAtkxEROS0imlBBg2rExERgNFmtr3D9m3ufltk0YiIiERAyZGIiAC85e6zu7vDzL4KXJfdvMrdu7s640Gg40U9JmbLREREelbgYXO9UXIkIiKn5e4/IFhs4XS2Aeeb2bkESdEy4I/Djk1ERAYBJUciIhJHZjYO2A4MBzJm9nVgurvXm9n/ADYBSeB2d38hwlBFRCQGjOJarU7JkYiI9Jm71xIMmevuvgeABwobkYiISP4oORIRERERkeio50hERERERATMiyc7UnIkIiIiIiLRKLLV6nQRWBEREREREdRzJCIiIiIiEdJqdSIiIiIiIlBUw+qUHImIiIiISGSKqedIc45ERERERERQz5GIiIiIiESpiHqOlByJiIiIiEg0vLiG1Sk5EikaRfTJ0G82SNoQeVemtISWKWeF18ArhFs/UPba26HWXwhVv30n1PpLmk6G2sYERoZWN8DBkzDh8cFwHgnXG/PDPYf4z8Jv45Wlt4Zaf8k3wm1jzu1HTi0soreu5hyJiAxmH+LdC+yd7iYiIiLqORIRERERkWgYGlYnIiIiIiIS8OLJjpQciYiIiIhIZIqp50hzjkRERERERFDPkYiIiIiIRKXIFgZSciQiIiIiIpGxTNQRvEvJkYiIiIiIRKeIeo4050hERERERAT1HImIiIiISISKabU6JUciIiIiIhINR9c5EhERERERgeLqOdKcIxEREREREdRzJCIiIiIiUSqiniMlRyIiIiIiEgmjuIbVKTkSEREREZFouBfVggyacyQiIiIiIoJ6jkREREREJEIaViciIiIiIgJakEFE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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=[\"white\", \"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": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "([0, 0, -10], [10.0, 1.0, 10.0, 5.0])"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "nvmdp.nav_cell_rewards, nvmdp.goal_cell_rewards"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(<Figure size 1008x576 with 4 Axes>,\n",
       " <matplotlib.axes._subplots.AxesSubplot at 0x11ea01b00>)"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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lJVR/cGrSO/dR/UHr4o6nNOSTBrLfy8YA959XQzBanWl84VEfFJaEREREREZdTKUTg+VkiMREREREYmEQ1HnFA2ldPqwREREREREIqSeIxERERERiYjmHImIiIiIiACQ1ZwjERERERE503X/CGypKJ0+LBERERERkQip50hERERERCKjOUciIiIiInLGC34EtnSG1Sk5EhERERGRyJTSggyl04clIiIiIiISIfUciYiIiIhIJBw0rE5ERERERAS0IIOIiIiIiAh4aS3IUDppmoiIiIiISITUcyQiIiIiIpFwSmu1OiVHIiIiIiISmVIaVqfkSEREREREIlFqq9VpzpGIiIiIiAjqOZIeHnL9y4G6kNsI01jgRMhtlM63JqdPr6OhGeH+Py0Mse4zVCKBVVSEVr2dLAu1fgAmV4dbfxEcPW9iqPV3HR4Tahv7rwj3Pd5/Gn4b0x8N+z0+fGFvQ2tz+G28lc+EWj/cwFs3hdfG/pZvnlJWSj1HSo5EREaxsmNZzn66I+owREREBuSU1lLeSo5ERERERCQypbRaneYciYiIiIiIoJ4jERERERGJimvOkYiIiIiISMkt5a3kSEREREREIlNKyZHmHImIiIiIiKCeIxERERERiYiW8hYREREREclxJUciIiIiIiL6nSMREREREZGSo54jERERERGJhJfY7xyp50hERIZkZreb2UEze3aQ+83M/tHMXjCzX5vZe4odo4iIxJO7DXkpFiVHIiIyHP8GXPUG9y8D3p67XA/8cxFiEhGR2AtWqxvqUixKjkREZEju/ijQ/AYP+TDwXQ88AUw0s3OKE52IiEhhKDkSEZFCOBfY0+v23lyZiIjIGyqlYXVakEFERAAmm9nWXrdvc/fbIotGRETOCE5pLcig5EhERAAOu/vCETx/HzCz1+0ZuTIREZHBebBiXanQsDoRESmEe4BP5latuwRodfcDUQclIiKSD/UciYjIkMxsI/B+guF3e4GbgDEA7n4rcC/wQeAF4BiwKppIRUQkbrJoWJ2IiMSIu18zxP0O/HmRwhERkVHCoagLLgwltGF1ZjbbzF41s0fM7P6w2hlMJpOhrq6OXbt2UVdXRyaTKXYIAqTTaWpra3niiSeora0lnU5HHVJeWltbeec730k6nead73wnra2tUYeUt0wG6upg3brgOo6Hwmg4njs7O1m5ciUAK1eupLOzM+KIJOrzlHuWgyd205F5jYMnduOeLXYIAmSzXTTuqOdo8ys07qgnm+2KOqS8nDx2jL1/9/eQybD37/6ek8eORR1S3tyzNB/YwZ7nH6D5wI5YHgvd29DZfii225BJpzl4x/cAOHjH98gU7TNbaf3OUdg9Rw+4+8dDbuMUmUyGpUuX0tDQQHt7O9dccw01NTXU19eTTCaLHc4ZK51OM23aNFpaWgBYt24dt9xyC01NTaRSqYijG1praysTJ07sub1jxw4mTpzIa6+9RlVVVYSRDV8mA0uXQkMDdHRARQXU1EB9PcTlUBgNx3Ol5lKGAAAgAElEQVRnZycTJkygqyv40LVp0ybuuusu2traKC8vjzi6M14k5yn3LFtfq6P15Ktk6OLXrQ9QNWYqCycux0zTgYslm+3iyZ+tJXMy+LJi784HOfDiY1x8dS2JROkPrjl57Bj7/qa253bXq6+y729qOfcraxkzblyEkQ2fe5Ydv/wOR5sbyWbSJJIpxk+axbzLPx2bY6H/Nvx2yw9itw2ZdJo9N66GbJDUHdv2NMeefoaZN68nGYPPbIUU9h77gJn9wsy+EHI7fWzevLnngxRAe3s7DQ0NbN68uZhhnPHWr1/fkxh1a2lpYf369RFFlJ9LL700r/JStHlzkBi1twcrwbS3B7fjdCiMhuN51apVPYlRt66uLlat0rScEhDJeepQurEnMQLI0EXryVc5lG4sZhhnvL07H+pJjLplTnayd+dDEUWUn1e/9U95lZeilqadPUkFQDaT5mhzIy1NOyOObPhGwzYc2bipJzHqkc0G5UXgPvSlWMJMjg4A5wEfAJaY2QXdd5jZ9Wa2y8wONTYW/kSwbds2Ojo6+pR1dHSwffv2grclg3vssccGLH/88ceLHMnpeemll/IqL0XbtgU9Rr11dECcDoXRcDxv2bJlwPInn3yyyJFIP8M6T3Vmjha84aNdh3sSo24ZujjadaTgbcng2g6/PHD5kd3FDeQ0ZY4M/HoZrLwUdby2ryep6JbNpOlo3R9RRPkbDduQfmXPwOWNe4vSfin9CGxoyZG7n3D3DnfvAuqAd/W67zZ3f7u7T5k1a1bB216wYAEVFRV9yioqKpg/f37B25LBXXbZZQOWx6XnZc6cOXmVl6IFC4KhdL1VVECcDoXRcDwvWrRowPKLL764yJFIb8M9T5Unxxe87fFlk0n2G9mepIzxZWcXvC0Z3ITJbxm4/OzZxQ3kNCXPHvj1Mlh5KaqYeC6JZN9hW4lkioqq6RFFlL/RsA2pN88cuHzWjNDbDnqGzoDkyMx6n00uA14Mq63+li1bRk1NDZWVlQBUVlZSU1PDsmXLihWCAKtXr6a6urpPWXV1NatXr44oovwM1sMVl54vgGXLgjlGuUOBysrgdpwOhd7Hs5nF8njesGEDZWV9PwiXlZWxYcOGiCISiPY8NSU1i6oxU3sSpCRlVI2ZypRU4b8wlMHNmLuY5Ji+8/6SY8qZMXdxRBHlZ+rnBl4gcrDyUlQ9bS7jJ83qSS665xxVT5sbcWTDNxq24exrVkCiX1qQSATlZ5gwh9W9z8yeMrPHgX3u3hBiW30kk0nq6+vZuHEjFRUVbNy4MVaTt0eLVCpFU1MTa9aswcxYs2ZNbBZjAKiqquK1115j3rx5AMybNy9WizFAsOhCfT1s3AjnnRdcx2kxBuh7PK9duzaWx3N5eTltbW2sWLGCRCLBihUrtBhDaYjsPGWWYOHE5VxQ9XskKeOCqt/TYgwRSCTKuPjqWmbMXQLAjLlLYrMYA8CYceM49ytrKZs6FYCyqVNjtRgDBMfCvMs/zXmLruWsyimct+jaWC1kAH23Yea8pbHchmQqxcyb1zNuwYVgxrgFFxZ1MYZSWq3OvJgznAawcOFC37p1a2j1T506lVdffTW0+gGw0lmb/bSF/DoYO3YsJ06cCLWNMJkZ4R8r4b6Oli8PlvIOV7TvJ3EQ9nvSwoUL2bp1a8+LaULluV5zwZ8N+bwH/2vNU+6+MLTAYqxqzJv8vZM+Flr9Pz/0b3xgyqdCqx+AN00Kt/4iOHrexKEfNAL/9e838t6P3Bxa/fuvCPc9fvfnb2D2N78WahvTHw33Pf75x2/n/Ev/ONQ2RoOwX0uNq/+WWev/NrT693/9m5xo3NOzEeVvm+5v+dr1Qz7v+Y9+uSjnqXh8NSIiIiIiIqPSGfEjsCIiIiIiInGiniMREREREYmEU9zV6Iai5EhERERERCJTSjOWlRyJiIiIiEg0XHOORERERERESo6SIxERERERiY4P4zIMZjbRzH5sZjvN7Hkze2++oWhYnYiIiIiIRKaAw+q+Bdzn7h8zsxSQ9y8iKzkSEREREZHIeAFWZDCzKuAK4FNBnZ4G0vnWo2F1IiIiIiISd28BDgEbzGybmf2rmVXkW4mSIxERERERiYQTDKsb6gJMNrOtvS7X96uqDHgP8M/uvgDoAG7MNx4NqxMRERERkWg4MLw5R4fdfeEb3L8X2OvuDbnbP+Y0kiP1HImIiIiISGTch74MXYc3AXvM7B25osXAjnxjUc+RiIiIiIiMBn8B/CC3Ut1LwKp8K1ByJCIiIiIi0SnAanUA7r4deKOhd0NSciQiIiIiIhGxQv7O0YgpORIRERERkegUqOeoELQgg4iIiIiICOo5kh7F6M4Mr423fOtrodX9ehtfD7X+lz8X9tcmy4G6kNsQGYXKkjClOrz6j1i49QNHz5sYav3FsP+KcM9T/tNw23jbF54IrW6A3UVo44VvXBJq/cd3hr+fpz9aQl0Upynsbdh3Mtw2Dh3tV+BoWJ2IiIiIiAhQUsPqlByJiIxmHZ3wxNNRRyEiIvIGSqfnSHOOREREREREUM+RiIiIiIhEScPqREREREREUHIkIiIiIiKCAyW0Wp3mHImIiIiIiKCeIxERERERiZBrWJ2IiIiIiAiacyQiIiIiIgJozpGIiIiIiEipUc+RiIiIiIhExjSsTkREREREzniO5hyJiIiIiIiAac6RiIiIiIhIqVHPkYiIiIiIREfD6kRERERERFByJCIiIiIiApRUcqQ5RyIiIiIiIqjnSEREREREouKU1Gp1So5ERERERCQypfQjsKEPqzOzL5jZL8NuR0REwmNmt5vZQTN7tlfZJDN7wMx25a6rB3nudbnH7DKz64oX9fDoPCUiEjEfxqVIBk2OzOxeM5s9ksrNbCwwfyR1nK7Ozk5WrlzJ4cOHWblyJZ2dnVGEccbr7ISVKyGdDq61G4ovnU5TW1vLE088QW1tLel0OuqQ8pbJZKirq2PdunXU1dWRyWSiDilv3fuhpaUlrvvh34Cr+pXdCDzk7m8HHsrd7sPMJgE3ATXAIuCmwZKofMX9PJXJpNm+527SmU6277mbTCZ2r4lRIZNOc/CO70Emw8E7vkcmfsdm7GW7umi59z5O7H6FlnvvI9vVFXVIeXPP0nxgB3uef4DmAztwz0YdUt6y2S4ad9TTlT5G4456stn47YdCeKNhdRuA+83sDuCr7n7yNOr/E+AOYO3pBHe6Ojs7mTBhAl25g2vTpk3cddddtLW1UV5eXsxQzmidnTBhAnS/x23aBHfdBW1toN1QHOl0mmnTptHS0gLAunXruOWWW2hqaiKVSkUc3fBkMhmWLl1KQ0MDHR0dVFRUUFNTQ319PclkMurwhmU07Ad3f3SAROTDwPtzf98BPAJ8qd9jlgIPuHszgJk9QJBkbSxAWLE9T2UyaR7c+XW6vw59te15Xm3byZK5XySZjMdrYjTIpNPsuXE1ZIMPsse2Pc2xp59h5s3rScbk2Iy7bFcXe9Z8Gc99e9p6/4O0/eIxZq67iURZPGZ/uGfZ8cvvcLS5kWwmTSKZYvykWcy7/NOYxWPts2y2iyd/tpbMyWA/7N35IAdefIyLr64lkYjHfiiUQfeYu/9f4D3ABGCrmd1gZv9f92Wois1sDPB+d3+4cOEOz6pVq3oSo25dXV2sWrWq2KGc0Vatej0x6tbVFZRLcaxfv77nA3m3lpYW1q9fH1FE+du8eTMNDQ20t7fj7rS3t9PQ0MDmzZujDm3YRsN+GMRUdz+Q+7sJmDrAY84F9vS6vTdXNmJxPk89s/9nnDpOxHPlUixHNm7qSYx6ZLNBuRRF6/0P9iRG3byzk9b7H4woovy1NO3sSYwAspk0R5sbaWnaGXFkw7d350M9iVG3zMlO9u58qCjtmw99KZahUsE00AGMBcYD+fQRfgL44UB3mNn1wF8BE6dMmZJHlcOzZcuWAcs3bdrEpk16wxtQERcJ2bQpuBTWDYWu8BS7Px9uGxZy/b19+9vf5le/+lXR2huJXbt20d7e3qeso6OD7du3s3z58oiiys9jjz02YPnjjz9e5Eje0GQz29rr9m3ufttwn+zubhbJlNrQz1NjkuNGGuMp2jr3D1j+atvz1D/3fMHb47nCV1l0PyleU8e2Pc3ubU8XtM7dBa1tYA/6j8Nt4PMh19/L0V8+TnrvvoLX29pc8CrpbD/Ukxh1y2bSdLTuZ9I58wrfYAjaDr88cPmR3cUJIA6r1ZnZVcA/APcA73H3Y3nW/Q5gvpl9Bninmf2Fu/8fgNwJ9zaAhQsXFvxkumjRIl5++dSdvGLFCu68885CNwdWOjv0tIXwkWblyoGToBUroNC74S3f+lphK+xn9xe/xOyv/+9Q23j5c18seJ21tbWsW7fulPLPfvazrF1b1FFEp62uro5rrrmmT4JUUVHB/PmRTBM5LZdddhkPP3xq58Sll14aQTSDOuzuC/N8zqtmdo67HzCzc4CDAzxmH68PvQOYQTD8bsSKdZ6qKj+n4O+QE8qn03my9ZTyqRPOZ/7Mjxa6OY6+oyDTvCK1/4rCn2sP3vE9jg2QBI1bcCFvuu4TBW3rbV94oqD19feQ/4TF9gehtvHCNy4peJ0t9943YC/R+MsvpfqD/ac5jtz0Rwv/gaf5wA5+u+UHfRKkRDJFRdX0grcVlgmT30Lb4RdPLT97dvGDidgbDYT8n8AfuvuNp3HCwd2/5O5L3f0q4LnuE04xbNiwgbJ+41TLysrYsGFDsUIQYMMG6D9cuKwsKJfiWL16NdXVfT8UVVdXs3r16ogiyt+yZcuoqamhsrISM6OyspKamhqWLVsWdWjDNhr2wyDuAbpXn7sO+OkAj6kHrjSz6txCDFfmygohtuepd0+/mlO77C1XLsVy9jUrINHvo1AiEZRLUVRduQTrNxHZysupunJJRBHlr3raXMZPmkUiN1+we85R9bS5EUc2fDPmLiY5pu9+SI4pZ8bcxeE3PpyV6kphtTp3f5+7F6Qj3t0vL0Q9w1VeXk5bWxsrVqxgzpw5rFixQosxRKC8PFh8YUXuHLNihRZjKLZUKkVTUxNr1qzh7LPPZs2aNbFaBAAgmUxSX1/Pxo0bWbt2LRs3bozVYgzQdz8sXrw4lvvBzDYC/wW8w8z2mtmfADcDv2dmu4AluduY2UIz+1eA3EIM64Anc5e13YszjFScz1PJZIolc7/I1AnnUz6miqkTztdiDBFIplLMvHk94xZcCAQ9RlqMobgSZWXMXHcTVVcuITFuHFVXLonVYgwAZgnmXf5pzlt0LTPnLeW8RdfGajEGgESijIuvrmXG3CVMmPI2ZsxdUtzFGEooOYrPKy9P5eXl4Qyhk7yUlwdD6H70o8IPpZPhSaVSrF27ll/96lexGUrXXzKZZPny5bGZYzSQ7v0QV+5+zSB3nfK1ortvBf601+3bgdtDCi22kslUKEPoJD/JVIo3XfcJdm97uuBD6WR4EmVlVH/wKtJ794UylK4YzBJMOmdebOYYDSSRKGPWvKWRtH1G/QisiIiIiIhIHIzaniMREREREYmBEuo5UnIkIiIiIiLRUXIkIiIiIiJnumL/yOtQNOdIREREREQE9RyJiIiIiEiUvPA/8ny6lByJiIiIiEh0SmhYnZIjERERERGJjOYciYiIiIiIlBj1HImIiIiISHRKqOdIyZGIiIiIiESjxJbyVnIkIiIiIiLRKaHkSHOOREREREREUM+RiIiIiIhEqYR6jpQciYiIiIhIZEppzpGG1YmIiIiIiKDkSEREREREBNCwOhERERERiVIJDasrgeToKcCiDkJi7uXP3RBq/WP/Ovw2IOz6IfxjrYTe3U6b3o+kH3fseDrqKEZk/G9fizqEEZvOxFDr3w1MfzS897AXvnFJaHUD+Bfv5oWvh9tGmP8/AK3N4bcxGuy/It7nqZNP9ivQ7xyJiIiIiIjkKDkSEZFiOI8WHvAfD/m4eH8PKSIiUhhKjkREREREJDrqORIRERERkTOdoTlHIiIiIiIigRJKjvQ7RyIiIiIiIig5EhERERGRqOSW8h7qMhxmljSzbWZWd7rhKDkSEREREZHo+DAuw/M54PmRhKLkSEREREREolOA5MjMZgBXA/86klCUHImIiIiISNx9E/hrIDuSSpQciYiIiIhIZIY552iymW3tdbm+5/lmy4GD7v7USGPRUt4iIiIiIhKd4c0pOuzuCwe57zLgQ2b2QeAsYIKZfd/dP55vKOo5EhERERGRaAxnvtEQyZO7/w93n+Hus4GVwMOnkxiBkiMRERERERFAw+pERERERCRCw/0do+Fw90eAR073+UqOREREREQkOgVMjkZKyZGIiIiIiESmkD1HI6U5RyIiIiIiIqjnSEREREREolRCPUdKjkREREREJBrDWKq7mJQciYiIiIhIJCx3KRWhzTkys3eZ2eNm9gsz22BmpbTdIiJyhtN5SkRE+gtzQYbfuPul7v6+3O2FIbZ1itZWeOc7obw8uG5tLWbr0q2zE1auBPfgurMz6ojyk8lAXV3f67jpjn3XrvhuQzqdpra2lsWLF1NbW0s6nY46pLx1Hwtz5sTzWBilIj1PnTx5jF+8cjv3v/QNfvHK7Zw8eayYzUtOJpPmN1u+D8BvtnyfTCZe7y+ezXLsuR2Qu/ZsNuqQ8uaepfnADjrbD9F8YAfu8duGbLaLxh31PPvorTTuqCeb7Yo6pLxl0mkO3vE99q79Cgfv+B6ZYp5rfRiXIgltWJ27n+x18wSwJ6y2+mtthYkTX7+9Y0dw+7XXoKqqWFFIZydMmABdufeHTZvgrrugrS1IWktdJgNLl0JDQ/D3NddATQ3U10MyGXV0w9N7G9rb47kN6XSaadOm0dLSAsDDDz/MLbfcQlNTE6lUKuLohqf/sfDyy/E6FkarKM9TJ08e46HGb/fc7uhq5qHGb7N41mcZM2ZcscI442UyaRruWQO5D+NH9j7NkX3PUPOhdSSTpf/+4tksr/7zbZx4pRHcOXTH9xn75llM/bPrsUQ8FiR2z7Ljl9/haHMj2Uya3275AeMnzWLe5Z/GLB7bkM128eTP1pI5GXzr1Xb4RQ68+BgXX11LIhGPGSyZdJo9N66GXHLd1dzMsaefYebN60kW4Vx7xizlbWYfMrNnganAkTDb6u3SS/Mrl3CsWvX6h8FuXV1BeRxs3vx6UgHBdUNDUB4Xo2Eb1q9f35MYdWtpaWH9+vURRZS/uB8Lo1lU56kn9t+ZV7mE44WnftSTGPXwbFAeA53P7+TEK4147ht+T6c58Uojnc/vjDiy4Wtp2tmTGAFkM2mONjfS0hSfbdi786GexKhb5mQne3c+FFFE+TuycVNPYtQjmw3Ki6GEeo5CTY7c/R53fxewF1jeXW5m15vZLjM71NhY+HZfeim/cgnHli0Dlz/5ZHHjOF3btkFHR9+yjg7Yvj2aeE7HaNiGxx57bMDyxx9/vMiRnL64Hwuj2XDOU8dPthW83c7MwGO9ByuXcLQ3D/whpL25aJ2II5Leu68nMerm6TTpffsjiih/Ha/t60mMumUzaTpa47MNbYdfHrj8yO7iBjIC6VcGfs2nG/cWOZLohbkgw9heN9uAnpTa3W9z97e7+5RZswrf9pw5+ZVLOBYtGrj84ouLG8fpWrAAKir6llVUwPz50cRzOkbDNlx22WUDll8ao67guB8Lo9Vwz1NnjZlQ8LbLkwOP8R6sXMJROWngDyGVk2YWOZLTk5pxLtZvyJOlUqTOnR5RRPmrmHguiX5DGBPJFBVV8dmGCZPfMnD52bOLG8gIpN488Gs+NWtGcQI4Q3qOrjKz/zSz/yQYrnB/iG31MdgXyjH6onlU2LAByvoNtS0rC8rjYNmyYH5OZWVwu7IyuL1sWbRx5aP3NpjFcxtWr15NdXV1n7Lq6mpWr14dUUT5i/uxMIpFdp66ZPrKvMolHG+76I+g/7wWSwTlMVB+/lzGvnlWT4JkqRRj3zyL8vPnRhzZ8FVPm8v4SbN6EqREMsX4SbOonhafbZgxdzHJMX0nkCbHlDNj7uKIIsrf2desgP7z1BKJoDxsHsw5GupSLKElR+7+U3f/ndzlT72IS49UVQWLL8ybF9yeN0+LMUShvDyYcL5iRfD3ihXxmoCeTAYLF2zcGPS2bNwYr4UMoO82rF0bz21IpVI0NTWxZs0axowZw5o1a2K1GAP0PRYgfsfCaBXleWrMmHEsnvVZKsomAVBRNkmLMUQgmUxR86F1nD3jQhLJMZw948LYLMYAYIkEU//seqZc93EslWLKdR+P1WIMAGYJ5l3+ac5bdC0z5y3lvEXXxmoxBoBEooyLr65lxtwlmCWZMXdJrBZjAEimUsy8eT3jFlwIwLgFFxZtMQbgjOk5ilRVFTz3XPD3c88pMYpKeTnceSf87u8G13H7MJhMwvLlQXK0fHm8kopu3duwenV8tyGVSrF27Vqqq6tZu3ZtrBKjbt3HQioVz2OhmwX+0cxeMLNfm9l7BnncRWb2TO5x/9j9G0Jm9odm9pyZZc2sqEtnl5oxY8bxvjf/MQDve/MfKzGKSDKZ4h2LPk7VlLfxjkUfj01i1M0SCca9cx6WSgXXMUqMupklmHTOPGbOXcKkc+bFKjHqlkiUMWveUspS5cyatzRWiVG3ZCrFm677BCSTvOm6TxQvMSox8Xv1iYhIlJYBb89drgf+eZDH/TPw6V6PvSpX/izwB8Cj4YYpIiJxcUYMqxMRkVHpw8B3PfAEMNHMzun9gNztCe7+hLs78F3gIwDu/ry7/6boUYuISOnSsDoREYmpc+n7Y6l7c2X9H7N3iMeIiIgApdVzFL8BkSIiEobJZra11+3b3P22yKIRERGJgJIjEREBOOzuAy6QYGZ/TjB/COBJoPcPYswA9vV7yr5c+Rs9RkREpOjD5oaiYXUiIvKG3P2f3H2+u88H/h34ZG7VukuAVnc/0O/xB4A2M7skt0rdJ4GfFj9yERGJBc05EhGRmLoXeAl4AfgO8NnuO8xse6/HfRb419zjXgQ25x7zUTPbC7wX+JmZ1RcpbhERKUGG5hyJiEhM5Vaf+/NB7pvf6++twLsGeMzdwN2hBSgiIjICSo5ERERERCQ6JTTnSMmRiIiIiIhExrx0siMlRyIiIiIiEg2tViciIiIiIlJ61HMkIiIiIiKRKeZqdENRciQiIiIiItFRciQiIiIiIlJaPUeacyQiIiIiIoJ6jkREREREJEol1HOk5EhERERERKLhpTWsTsmRSMkooXeG02ajpA2R12VTZRyffXZ4DbxIuPUDZ+0+Emr9xTD+t6+FWn9Zx8lQ25jOxNDqBth3EqY/OhrOI+Haf0W455DM/eG38eKKW0Otv/yvMqG2sej2Q6cWltBLV3OORERGs4t4/Qf23ugiIiIi6jkSEREREZFoGBpWJyIiIiIiEvDSyY6UHImIiIiISGRKqedIc45ERERERERQz5GIiIiIiESlxBYGUnIkIiIiIiKRsWzUEbxOyZGIiIiIiESnhHqONOdIREREREQE9RyJiIiIiEiESmm1OiVHIiIiIiISDUe/cyQiIiIiIgKl1XOkOUciIiIiIiKo50hERERERKJUQj1HSo5ERERERCQSRmkNq1NyJCIiIiIi0XAvqQUZNOdIREREREQE9RyJiIiIiEiENKxOREREREQEtCCDiIiIiIgIlFbPkeYciYiIiIiIEGJyZGY1Zva4mf3SzL4RVjuDSaehtjb4u7Y2uC3Fl8lAXR3s2hVcZzJRR5Sf7tdRS0t8X0eZTIa6ujrWrVtHXV0dmbjtBEbLfnj9GIjjsTAaRX2eyma7eOmlBwB46aUHyGa7ih2CAO5ZDrbtouNEMwfbduGejTqkvGSzXTTuqKcrfYzGHfWxfB25Z2k+sIM9zz9A84EdsdsHANmuLlruvY9s57Hguit++yGTceoe6KArA3UPdJDJFKk7x4GsD30pEvOQls4zs2nAa+5+3Mx+ANzs7s/0f9zCheZbtxa27XQapk0LPkh1q66GpiZIpQrbFhAs0B53IbwMMhlYuhQaGqC9HSoroaYG6ushmSx8e4VW9NdRCDshk8mwdOlSGhoa6OjooKKigpqaGurr60mGshMKfzAUfz8UXjGPhYULYetWt9dvD+891oyn3H1hYaMpbcM9T42fMMMXLvrvBW07m+3isV98hUxXZ09Zsqycy973NyQShR/xftbuIwWvs9i8fGzh6/QsW3dvpPXYPjJ+kqSNoWrcuSycfQ1mhf3++Oh5EwtaHwSvoyd/tpbMyV6vozHlXHx1bSivozC4Z9nxy+9wtLmRbCZNIpli/KRZzLv80wXfBwD7ryj8eSrb1cWeNV/GO1/fD1Zezsx1N5EoK/x+eHHFrQWvM5Nxrlq5ny3bjtPe4VRWGIsWnMV9d04nmSzs/9mipXvY+vTxnkrHV83w91z2l0M+79HNXyrKeSq0niN3b3L347mbJ4GifU+6fn3fD1IQ3F6/vlgRCMDmza9/GITguqEhKI+D0fA62rx5Mw0NDbS3t+PutLe309DQwOa47ARGy36I97EwWkV5ntq9++d9EiOATFcnu3f/vFghCHDo6Is9iRFAxk/Semwfh46+GHFkw7N350N9EiOAzMlO9u58KKKI8tfStLMnMQLIZtIcbW6kpWlnxJENX+v9D/ZJjAC8s5PW+x+MKKL8bX74WE9iBNDe4Wz51XE2P3ysKO2bD30pltDnHJnZBcAUd9/Rq+x6M9tlZocaGwvf5mOPDVz++OOFb0sGt20bdHT0LevogO3bo4knX6PhdbRt2zY6+u2Ejo4OtsdlJzBa9kO8j4XRbqjz1InjrxW8zbbXdg9S/krB25LBHT3e1JMYdcv4SY4efzWiiPLTdvjlgcuP7C5uICPQ8dq+nsSoWzaTpqN1f0QR5e/Ey7sHLt8dn+N5+zMn6DjWNwPp6HSefvZERBFFJ3voPJgAABSySURBVNTkyMwmAbcAf9K73N1vc/e3u/uUWbMK3+5llw1cfumlhW9LBrdgAVRU9C2rqID586OJJ1+j4XW0YMECKvrthIqKCubHZScwWvZDvI+F0Ww456mxZxV+ONSEibMHKX9zwduSwY0/axpJG9OnLGljGH/W1Igiys+EyW8ZuPzs2cUNZAQqJp5LItl3jHQimaKianpEEeVv7FtmD1w+Oz7H8/x3j6ViXN/hcxXlxoXvKvxw1gG5D30ZgpnNNLOfm9kOM3vOzD53OqGEuSBDGfB94AZ3bwqrnYGsXh3MSeitujool+JZtiyYV1FZCWavz7NYtizqyIZnNLyOli1bRk1NDZWVlQBUVlZSU1PDsrjsBEbLfvj/27v7IKnOKo/jv9M9M8yQgcmQIMhbABMEhDAKGZSISWB4GWWT1TUL0dWquOuW1sYqU5vUxi0hJaRWSy13a9VdiipjWQUO0ZjUpmZhRkgWXc1KDJFUjAkREwOBEJOIIAQyTPfZP7oZZnhJzwz39nNvz/dT1dW5F7jPeUJPH04/zz195mdBSt/PQqUKmacmT75B2aq6PueyVXWaPPmGcoYx5I0e8Q41DB/fUyCdvudo9Ih3BI6sfyZMX6xs9Vmvo+o6TZi+OFBEA9c4drpGjJrUUyCdvueocez0wJH1X8PSFlld378Hq6tTw9KWQBENXOui4Wp+d63qiwVS/XBT83tq1bpoeFnGj2hbXbekf3T3mZLeK+kfzGzmQGOJc+XoZknXSPqqme0ws/fFOFYfNTWFm7VXry4cr16drpu3K0U2W7jhvK1NWru28JyWZgxS39fR4sXpfB1ls1l1dnaqra1N06ZNU1tbW4zNGOJRCT/PvX8WpPT9LFSwYHkqk6nStQv/WZOmLJIkTZqyKLZmDLgws4zmTb5FV0/8sK5823W6euKHY2nGEJdMpkrXfGiNJkxv0cjRV2rC9JZUNWOQCn8HM9//aU1r/rhq60drWvPHY2vGEJdMVZUmrru7pxhqWNoSWzOGuGSzpo7N47Rp/VhJ0qb1Y2NpxnBe3s9Hqcu4v+zuTxT/+8+SnpE0fqDhxNatrr/i6FbXm1m/VuIucpCYr18OCfryraEr3r+EFStWqL29PdYx4v5hyGSkfPo6vPYR9xzoVhe9OLrV9bbj4S/o+sVfju36Et3qkiCObnWV5plH79WMBZ+KdYw4utX19vvP36HJ//b1WMeIo1tdb1Xj9qr74JWxXf+cbnUjJ/i8936u5J/bse2ufucpM5ss6aeSZrn70YHEl56SFgAAAEBFMUnWv5WMy82s98d9G9x9wznXM6uX9CNJnx9oYSRRHAEAAAAIqX87Kl4rtXJkZtUqFEab3P2BwYRCcQQAAAAgmH6uHL31NcxM0nckPePu3xjsddJztxsAAAAAnN+1kj4haZGZ7S4+PjjQi7ByBAAAACCMfnajK3kZ958pgs5QFEcAAAAAAunfl7yWC8URAAAAgGD6+SWvZcE9RwAAAAAgiiMAQD+Y2XIz22Nme83srtDxAAAqiHvpR5lQHAEA3pKZZSV9W1KrpJmSbjGzmWGjAgBUBJcsX/pRLhRHAIBSmiXtdffn3b1L0mZJNwWOCQBQKVg5AgCkyHhJ+3sdv1Q8BwBARaFbHQBAki43s8d7HW9w9w3BogEADB0J6lZHcQQAkKTX3H3eBX7tgKSJvY4nFM8BAHDRLEHfc8S2OgBAKb+UdJWZTTGzGkmrJD0UOCYAQKVI0D1HrBwBAN6Su3eb2W2SOiVlJd3r7k8HDgsAgMhRHAEASnL3LZK2hI4DAFBhXFIZW3WXQnEEAAAAIAiTJ+qeI4ojAAAAAOFQHJ3x3LPjtGTBZ2IcYY2WLFgb4/WlbVoT6/UxVFgFjBH3m1tGca+9L8ncHOv13e/XksxHY7v+c/5wbNdGep2cfFnoEC7asFeOhQ5hyDv4gXhzyMln4x/jdyvXx3r9qtvjH2PZuKZYr+++N9YxnvPXY7t2FOhWBwAVba4KRWupBwAAgdCtDgAAAMCQR0MGAAAAAChIUkMGttUBAAAAgFg5AgAAABBSglaOKI4AAAAABFLehgulUBwBAAAACMOVqOKIe44AAAAAQKwcAQAAAAiJVt4AAAAAkKxW3hRHAAAAAMJJUHHEPUcAAAAAIFaOAAAAAITikvLJWTmiOAIAAAAQCN9zBAAAAAAFCSqOuOcIAAAAAMTKEQAAAICQErRyRHEEAAAAIAwaMgAAAACAVGjIkA8dRI+Kvueoe1hWWru28AwAgXVfUlN4T7qkJnQoSAjyFIAkIU9VeHH06ozLpIUL9eqMUaFDAQC9umBy4T3pfZNDh4KEeG1ao7RwoV67qjF0KAAQLk+5l36USWzFkZmNM7MnzOykmQXZvndw7pji89gQw0PSiRPSqlXS1KmF5xMnQkc0MGmPX5K6uqQ1a6Rf/KLw3NUVOqKBy+Vyam9vl7urvb1duVwudEiDcnD5jMJz64zAkUBKRp46NGd0n2eUXy7Xpd37HtRP93xLu/c9qFwuXW+SuVyX9jy2Ubs6/kV7HtuYuvglKd/drcNbOvTm71/U4S0dynd3hw5pwHI5V/u243KX2rcdVy6XnHtoBiJInjp9z1GpR5mYx1SJmVmtpDpJD0pqcffzvtJH1o/3+Vd/JpIxd31qlg5feebTN+vOy6syPc+nNe49rLn3/jqSMSVp2/+tiexawcTwMjhxQho5Uur9HldVJR09KtXVRT9e1NIev1QohMaOlQ4fPnOusVE6dEiqiWXFPPoXUi6X07Jly7Rz504dO3ZM9fX1mj9/vjo7O5XNRr8VaUnm5siutetrN+rw3Ik9x9aVk9dke55Pa9y1X3PvfCiSMXf6wzrqf7TTx/PmzfPHH3+85J8zs13uPi+SIFKiv3lqxMgJPq/5tkjG3P2xGfrT1IYzMVwgT136/BE1ff+ZSMasFMNeORb5NXO5Lm1/5uvq+95laplxh7LZaN8k/zzt0kivJxXi3/nQ6r73a1hG829cF3n8knTwA1b6Nw1Qvrtb+1d/Sd7r00erq9PEdXcrUxX9Zxa/W7k+8mvmcq7lqw7qsV+d1LHjrvpLTM3vrlXH5nHKZqP/f7ZsXFNk10pCnmqoGeMLxqwq+ec6Xvr3suSp2FaO3P2kux8u/TujM2XHfmW6znyifDrR9E44ma6cpvzP/nKGNWTdemvfwkIqHN96a5h4Birt8UvSPff0LYykwvE994SJZzC2bt3aUxhJ0rFjx7Rz505t3bo1cGSlTdm0S5mTp3qOTyea3gknc/KUpmwsXbwgeiHy1BU/P9CvPHXFzw+UM6wh66kD/61zP9Tx4vnk27vrB+feyO75wvmUOPLj7X0KI0nyEyd05MfbA0U0cFsfeaOnMJKkY8ddjz1xUlsfeSNwZKWRp84V28pRzwBmO3TWJ3Jm9veS7pR0aXXV8Muvu+auyMb749QG7f7ku5SvOfcT5UxXTk3fe1qjXjgS2XgSK0cXMnWq9MIL5/+1eFYtopXG7WdIoKYm6ctflmprz/mlzMlTavpCu0Y9eTCy4Vg5GriSear6ksuv/cAXIxvv8BUj9dTKd14wT82+b48aXzwa2XiVIo6Vo5/u+ZZOnDr/vwks6s+PM9GvIHg+nVuMkTCB81RDzRhf8LaVJf9cx4FvliVPBdlj7e4bJG2QCtvqorz2qOePaHbbs3rqY9OVr+5V9Z7KaXbbs5EXRriw5ubzF0crV0qbN5c/noFatUq6775zz6clfqlwj9G6deeeX71aWrs2jhGjr7Lb29t1yy239KwcSVJ9fb3a2tq0YsWKyMeLcludJOlJ6dW12/XU3cuVH3bmLTfzZrdmr+2MNOEgOr3z1IiREyJ9YTe+eFQzH/itfvNX05Sv7rVidCqvmQ/8lsKojEbWjT9vcTRm5Ew1TfpwpGPFsa1uz2Mb9fpLT55z/rIJc/TO5r+JfLw4ttUd3tJx3lWihqUtavzg8sjHi2NbXfu24/r4Zw/1rBxJUv1w06b1Y7ViySWRjxfltjpJCchT5W24UEpFdqvrrsvK8i7l8oXtC7m8LO/qrqNVajl997uFe3R6q6oqnE+DtMcvSV/8YuEeo94aGwvn06K1tVXz589XfX29zKznnqPW1tbQofVbd/0wWS5feE86earwnpTLq7t+WOjQEEh3bVXxJuO8MqdyUj4v5b1wHmUze/yHJJ39D34rnk++K+f+tWRn/VPOMoXzKdGwtEV21o28VlenhqUtgSIauNZFw9X87lrVDzeZFQqj5vfUqnXR8NCh9VvQPOUqvgeWeJRJnN3qqs1su6Q5kjrNbH5cY53t4NyxylVnNeKVNzRn42804pU3lKvO0rWuzOrqCs0LVq4sbLFbuTJdzQzSHr9U2L546FBhpWjx4sJzfM0Y4pHNZtXZ2am2tjatXbtWbW1tsTVjiMvB1hnK1VZrxPOva87qLRrx/OvK1VbTtS6wkHnqUNNo5aszqv/DCc36wXOq/8MJ5aszdK0rs2y2Ri0z7tCYkTNVV32pxoycGUszhrhkszWaf+M6XTZhjoYNH6XLJsyJrRlDXDJVVZq47m41LG1R7bSr1LC0JbZmDHHJZk0dm8dp0/qx+tKdo7Rp/djYmjHEhTx1RmyvPHc/JSlI2Z99s1tXbX1Bkx49IHNp1Ld/pX0LxuvwlJEhwhnS6urSswXtfNIev1QohOLZQlc+2WxWK1asiGUbXTlkj3fpqvU/16QfPVl4T/rsD7XvI3N0+Oq3hw5tSAubp3J6x8MvasLOQzJJjd95Svub364jk0aECGdIy2ZrIt9CV07ZbE0sW+jKKVNVFcsWunLKZk0rllwSyza6cgiepxK0rS49ZfkANG3s2/7UvNAhiO4/AEJoWtO3s57lXVfcv1tX3L87UEQIbfYPn+tzbC5N2vmytPPlQBEBGMqC5ymKIwAAAAAo75e8llKRDRkAAAAAYKBYOQIAAAAQhkt+9pcZB0RxBAAAACCcBG2rozgCAAAAEE6CGjJwzxEAAAAAiJUjAAAAAKG4S3nuOQIAAACARG2rozgCAAAAEIwnaOWIe44AAAAAQKwcAQAAAAjG2VYHAAAAAHLxPUcAAAAAIEly7jkCAAAAgEShOAIAlGRmy81sj5ntNbO7QscDAKgMLsnzXvLRH1HkKoojAMBbMrOspG9LapU0U9ItZjYzbFQAgIrgXthWV+pRQlS5iuIIAFBKs6S97v68u3dJ2izppsAxAQAqREQrR5HkKoojAEAp4yXt73X8UvEcAABJEUmuMg/cV9zMXpX0YoxDTJK0L8brlwNzCC/t8UvMISninsMV7j769IGZdUi6vB9/rlbSyV7HG9x9Q/EaH5W03N3/rnj8CUnz3f226MJOLvJUvzCH8NIev8QckiJ1eap4nUhyVfBW3r3/58TBzF5193lxjhE35hBe2uOXmENSlHsO7r48gssckDSx1/GE4rkhgTxVGnMIL+3xS8whKVKap6SIctVQ2Fb3p9ABRIA5hJf2+CXmkBRpnMMvJV1lZlPMrEbSKkkPBY6pkqTxNXE25hBe2uOXmENSpHUOkeSq4CtHZXAkdAARYA7hpT1+iTkkRerm4O7dZnabpE5JWUn3uvvTgcOqJKl7TZwHcwgv7fFLzCEpUjmHqHLVUCiONpT+LYnHHMJLe/wSc0iKVM7B3bdI2hI6jgqVytfEWZhDeGmPX2IOSZHaOUSRq4I3ZAAAAACAJKjYe47MbJyZPWFmJ80slStkZjbfzB41s5+Z2b+GjmcwzGxWcQ7/a2bfNTMLHdNgmNntZvaz0HEMhplNNrNXzGyHmf04dDyDZWafNLOHi/NIXRvp4rd27yg+XjazvwwdE8JLe64iTyUHeSo88lRlqNjiSNIfJS2W9IvQgVyEFyUtcvf3S3qbmc0OHdAg7HH3Be6+sHicug4uZjZMUlPoOC7SNne/3t2Xhg5kMIpJ5jp3X1ycR+o6pbl7RzH261Vokbo9cEhIhrTnKvJUApCnwiNPVY6KLY7c/aS7Hw4dx8Vw90Pufrqf+ylJuZDxDIa7n+p1+Kb6fjlXWvytpO+FDuIi3VD8VPT20IEM0jJJ2eInct80s2zogAbLzKZKesXdj4WOBeGlPVeRpxKDPBUeeapCVGxxVEnM7GpJo939N6FjGQwzu9HMfi1pjKTXQ8czEGZWLel6d38kdCwX4WVJ0yTdIKml+HpKmzGSatx9saQ3JN0UOJ6L8RFJD4YOAogSeSoc8lRikKcqBMVRwpnZKEnfUuFToVRy94fcfZaklyStCB3PAH1C0vdDB3Ex3P1Ndz/u7t2S2iXNCh3TIByR9JPifz8iaUbAWC7WX4jvCEIFIU8FR55KBvJUhaA4SrDizbkbJd3h7odCxzMYxX3Qpx2VdCJULIP0TkmfNbMOSe8ys8+FDmigzGxEr8NrJf0uVCwX4VFJpz9JbJL0QsBYBs3MxkrqcvdUfTINXAh5KhHIU8lAnqoQFVscmVm1mW2XNEdSp5nNDx3TINws6RpJXy12Dnlf6IAGYbmZ/cTMfqLCknOqutC4+z+5+zJ3Xy7paXf/ZuiYBmGhme0ys0clHXD3naEDGih33y3phJntUOFn4v6wEQ3aTZL+K3QQSI4KyFXkqcDIU8lAnqocfM8RAAAAAKiCV44AAAAAYCAojgAAAABAFEcAAAAAIIniCAAAAAAkURwBAAAAgCSKI+CCzGyimb1Q/IJDmVlj8Xhy2MgAACBPAXGgOAIuwN33S/pPSV8pnvqKpA3u/vtgQQEAUESeAqLH9xwBb8HMqiXtknSvpE9LanL3U2GjAgCggDwFRKsqdABAkrn7KTO7U1KHpKUkHABAkpCngGixrQ4orVXSy5JmhQ4EAIDzIE8BEaE4At6CmTVJWiLpvZJuN7O3Bw4JAIAe5CkgWhRHwAWYmalwo+vn3X2fpK9J+nrYqAAAKCBPAdGjOAIu7NOS9rn7tuLxf0iaYWbXBYwJAIDTyFNAxOhWBwAAAABi5QgAAAAAJFEcAQAAAIAkiiMAAAAAkERxBAAAAACSKI4AAAAAQBLFEQAAAABIojgCAAAAAEkURwAAAAAgSfp/z1rLxvJtLrEAAAAASUVORK5CYII=\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=[\"white\", \"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": [
    "## 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
}
