{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'0.10.3'"
      ]
     },
     "execution_count": 43,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import gym \n",
    "gym.version.VERSION"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "%matplotlib inline\n",
    "from gridworld_env import GridworldEnv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[33mWARN: gym.spaces.Box autodetected dtype as <class 'numpy.float32'>. Please provide explicit dtype.\u001b[0m\n"
     ]
    }
   ],
   "source": [
    "env = GridworldEnv(4) # Number of plan "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7fc557baa438>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "env.render()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Box(3,)"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "env.observation_space"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 0.09375 -0.5      0.     ]\n",
      "4\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(array([ 0.09375, -0.5    , -0.1    ]), -0.1, False, {'success': True})"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(env.reset())\n",
    "print(env.action_space.sample())\n",
    "env.step(env.action_space.sample())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "((4, 3), (1, 4))\n"
     ]
    }
   ],
   "source": [
    "env.verbose = True\n",
    "print( env._get_agent_start_target_state())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(8, 8)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "env.grid_map_shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Box(3,)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "env.observation_space"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Discrete(5)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "env.action_space"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "State \t\t\t\t - Reward\n",
      "[ 0.09375 -0.5     -0.1    ] \t\t\t -0.1\n",
      "[-0.15625 -0.1     -0.1    ] \t\t\t -0.1\n",
      "[-0.40625 -0.1     -0.1    ] \t\t\t -0.1\n",
      "[-0.40625  0.1     -0.6    ] \t\t\t -0.6\n",
      "[-0.65625 -0.1     -0.1    ] \t\t\t -0.1\n",
      "[-0.625  0.3    0.9  ] \t\t\t 0.9\n",
      "Total episode reward:  -0.09999999999999998\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7fb2021c8828>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7fb2021c8048>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7fb1ffff6d30>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\nWAySGv8HJc2Jtt+fe0wAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7fb200057a58>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\nWAySGv8HJc2Jtt+fe0wAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7fb1fff62780>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n4/8AoqWJtVdBELMAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7fb2000a7358>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\nAZP0ijYAZY9PAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7fb1ffd6ff28>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Try random policy \n",
    "env.reset()\n",
    "moves = [0,2,2,3,2,4]\n",
    "env.render()\n",
    "print('State \\t\\t\\t\\t - Reward')\n",
    "for i in range(len(moves)):\n",
    "    move = env.action_space.sample()\n",
    "    obs , reward, _, _ =  env.step(moves[i]) \n",
    "    print(obs,'\\t\\t\\t',reward)\n",
    "    env.render()\n",
    "print('Total episode reward: ', env.episode_total_reward)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Q-learning Example"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[33mWARN: gym.spaces.Box autodetected dtype as <class 'numpy.float32'>. Please provide explicit dtype.\u001b[0m\n",
      "###### LEARNING #####\n",
      "episodes      : 1000\n",
      "total reward  : -22658.100000000024\n",
      "average reward: -22.66\n",
      "Q Value       :[[ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.4863866   0.36206713 -0.01361327 -0.01361327  0.6172492 ]\n",
      " [ 0.6172492   0.11724945  0.11724945  0.4863866   0.75499946]\n",
      " [ 0.75499946  0.6172492   0.2549996   0.6172492   0.89999974]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.75499946  0.6172492   0.2549996   0.89999974  0.6172492 ]\n",
      " [ 0.6172492   0.11724945  0.11724945  0.75499946  0.11724945]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.36206713  0.2439637   0.4863866  -0.1379328  -0.1379328 ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.6172492   0.4863866   0.75499946  0.11724945  0.75499946]\n",
      " [ 0.75499946  0.6172492   0.89999974  0.6172492   0.6172492 ]\n",
      " [ 0.6172492   0.4863866   0.75499946  0.75499946  0.11724945]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.2439637   0.13176546  0.36206713 -0.25603637  0.36206713]\n",
      " [ 0.36206713  0.2439637  -0.1379328   0.2439637   0.4863866 ]\n",
      " [ 0.4863866   0.36206713  0.6172492   0.36206713  0.6172492 ]\n",
      " [ 0.6172492   0.4863866   0.75499946  0.4863866   0.4863866 ]\n",
      " [ 0.4863866   0.36206713  0.6172492   0.6172492   0.36206713]\n",
      " [ 0.36206713 -0.1379328  -0.1379328   0.4863866  -0.1379328 ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.13176546  0.02517717  0.2439637  -0.3682346   0.2439637 ]\n",
      " [ 0.2439637   0.13176546  0.36206713  0.13176546  0.36206713]\n",
      " [ 0.36206713  0.2439637   0.4863866   0.2439637   0.4863866 ]\n",
      " [ 0.4863866   0.36206713  0.6172492   0.36206713  0.36206713]\n",
      " [ 0.36206713  0.2439637   0.4863866   0.4863866  -0.1379328 ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.02517717 -0.07608172  0.13176546 -0.47482294  0.13176546]\n",
      " [ 0.13176546 -0.3682346   0.2439637   0.02517717  0.2439637 ]\n",
      " [ 0.2439637   0.13176546  0.36206713  0.13176546  0.36206713]\n",
      " [ 0.36206713  0.2439637   0.4863866   0.2439637   0.2439637 ]\n",
      " [ 0.2439637   0.13176546  0.36206713  0.36206713  0.13176546]\n",
      " [ 0.13176546  0.02517717 -0.3682346   0.2439637  -0.3682346 ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [-0.07608172 -0.57608193  0.02517717 -0.57608193 -0.57608193]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.13176546 -0.3682346   0.2439637  -0.3682346   0.2439637 ]\n",
      " [ 0.2439637  -0.25603637  0.36206713  0.13176546  0.13176546]\n",
      " [ 0.13176546 -0.3682346   0.2439637   0.2439637   0.02517717]\n",
      " [ 0.02517717 -0.47482294  0.13176546  0.13176546 -0.47482294]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.        ]]\n",
      "###### TEST #####\n",
      "episodes      : 100\n",
      "total reward  : 60.0000000000001\n",
      "average reward: 0.60\n"
     ]
    }
   ],
   "source": [
    "# Q learning params\n",
    "ALPHA = 0.1 # learning rate\n",
    "GAMMA = 0.95 # reward discount\n",
    "LEARNING_COUNT = 1000\n",
    "TEST_COUNT = 100\n",
    "\n",
    "TURN_LIMIT = 1000\n",
    "IS_MONITOR = True\n",
    "\n",
    "class Agent:\n",
    "    def __init__(self, env):\n",
    "        self.env = env\n",
    "        self.episode_reward = 0.0\n",
    "        self.q_val = np.zeros(64 * 5).reshape(64, 5).astype(np.float32)\n",
    "\n",
    "    def learn(self):\n",
    "        # one episode learning\n",
    "        state = self.env.reset()\n",
    "        #self.env.render()\n",
    "        \n",
    "        for t in range(TURN_LIMIT):\n",
    "            act = self.env.action_space.sample() # random\n",
    "            next_state, reward, done, info = self.env.step(act)\n",
    "            q_next_max = np.max(self.q_val[int(64.*(next_state[0]+1.)/2.)])\n",
    "            # Q <- Q + a(Q' - Q)\n",
    "            # <=> Q <- (1-a)Q + a(Q')\n",
    "            self.q_val[int(64.*(state[0]+1.)/2.)][act] = (1 - ALPHA) * self.q_val[int(64.*(state[0]+1.)/2.)][act]\\\n",
    "                                 + ALPHA * (reward + GAMMA * q_next_max)\n",
    "            \n",
    "            self.episode_reward += reward\n",
    "            #self.env.render()\n",
    "            if done:\n",
    "                return self.env.episode_total_reward\n",
    "            else:\n",
    "                state = next_state\n",
    "                \n",
    "        return 0.0 # over limit\n",
    "\n",
    "    def test(self):\n",
    "        state = self.env.reset()\n",
    "        for t in range(TURN_LIMIT):\n",
    "            act = np.argmax(self.q_val[int(64.*(state[0]+1.)/2.)])\n",
    "            next_state, reward, done, info = self.env.step(act)\n",
    "            if done:\n",
    "                return self.env.episode_total_reward\n",
    "            else:\n",
    "                state = next_state\n",
    "        return 0.0 # over limit\n",
    "\n",
    "env = GridworldEnv(1)\n",
    "env.reset()\n",
    "agent = Agent(env)\n",
    "\n",
    "print(\"###### LEARNING #####\")\n",
    "reward_total = 0.0\n",
    "for i in range(LEARNING_COUNT):\n",
    "    reward_total += agent.learn()\n",
    "print(\"episodes      : {}\".format(LEARNING_COUNT))\n",
    "print(\"total reward  : {}\".format(reward_total))\n",
    "print(\"average reward: {:.2f}\".format(reward_total / LEARNING_COUNT))\n",
    "print(\"Q Value       :{}\".format(agent.q_val))\n",
    "\n",
    "print(\"###### TEST #####\")\n",
    "reward_total = 0.0\n",
    "for i in range(TEST_COUNT):\n",
    "    reward_total += agent.test()\n",
    "print(\"episodes      : {}\".format(TEST_COUNT))\n",
    "print(\"total reward  : {}\".format(reward_total))\n",
    "print(\"average reward: {:.2f}\".format(reward_total / TEST_COUNT))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "Q = agent.q_val \n",
    "policy_function = np.argmax( Q , axis = 1).reshape(8,8)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\no1ZdJyQAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7fb2021a1940>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def plot_policy( policy_function ):\n",
    "\n",
    "    plt.figure()\n",
    "    plt.imshow( policy_function , interpolation='none' )\n",
    "    plt.colorbar()\n",
    "\n",
    "    for row in range( policy_function.shape[0] ):\n",
    "        for col in range( policy_function.shape[1] ):\n",
    "            if policy_function[row][col] == 0:\n",
    "                continue \n",
    "            if policy_function[row][col] == 1:\n",
    "                dx = 0; dy = .5\n",
    "            if policy_function[row][col] == 2:\n",
    "                dx = 0; dy = -.5\n",
    "            if policy_function[row][col] == 3:\n",
    "                dx = -.5; dy = 0\n",
    "            if policy_function[row][col] == 4:\n",
    "                dx = .5; dy = 0\n",
    "            plt.arrow( col , row , dx , dy , shape='full', fc='w' , ec='w' , lw=3, length_includes_head=True, head_width=.2 )\n",
    "    plt.title( 'Policy' )        \n",
    "    plt.show() \n",
    "plot_policy(policy_function)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7fb1ffe60be0>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "env.reset()\n",
    "env.render()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.6.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
