{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Frozen Lake experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\u001b[41mS\u001b[0mFFFFFFF\n",
      "FFFFFFFF\n",
      "FFFHFFFF\n",
      "FFFFFHFF\n",
      "FFFHFFFF\n",
      "FHHFFFHF\n",
      "FHFFHFHF\n",
      "FFFHFFFG\n"
     ]
    }
   ],
   "source": [
    "import copy\n",
    "import gym\n",
    "import matplotlib.cm as cm\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib import rc\n",
    "import numpy as np\n",
    "\n",
    "# generate the map\n",
    "env_frozenlake = gym.make('FrozenLake-v0', map_name='8x8')\n",
    "env_frozenlake.reset()\n",
    "env_frozenlake.render()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# don't stop the env on holes and add penalty\n",
    "def continue_on_hole(env, penalty = 0.01, goal_reward = 1):\n",
    "    env.penalty = penalty\n",
    "    env_modified = copy.deepcopy(env)\n",
    "    desc = env.desc.flatten()\n",
    "    for s in range(env.nS):\n",
    "        for a in range(env.nA):\n",
    "            possible_outcomes = env.P[s][a]\n",
    "            new_possible_outcomes = []\n",
    "            for outcome in possible_outcomes:\n",
    "                prob, next_state, reward, done = outcome\n",
    "                if desc[next_state] == b'G':\n",
    "                    reward = goal_reward\n",
    "                if desc[next_state] == b'H':\n",
    "                    done = False\n",
    "                    reward = -penalty\n",
    "                new_possible_outcomes.append((prob, next_state, reward, done))\n",
    "            env_modified.P[s][a] = new_possible_outcomes\n",
    "    return env_modified"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# The policy given a Qfunc\n",
    "class policy_from_Qfunc(object):\n",
    "    def __init__(self, Qfunc, random_tie_breaking = False):\n",
    "        self.Qfunc = Qfunc\n",
    "        self.random_tie_breaking = random_tie_breaking\n",
    "        \n",
    "    def act_from_values(self, values):\n",
    "        if self.random_tie_breaking:\n",
    "            inds = np.flatnonzero(values == values.max())\n",
    "            a = np.random.choice(inds)\n",
    "        else:\n",
    "            a = np.argmax(values)\n",
    "        return a\n",
    "    \n",
    "    def act(self, s):\n",
    "        values = self.Qfunc[s, :]\n",
    "        return self.act_from_values(values)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Frozen Lake experiments for a policy\n",
    "def run_exp(env, policy, n_exp = 1000, max_iter = None, seed = None, render = False, print_result = False):\n",
    "    if seed is not None:\n",
    "        env.seed(seed)\n",
    "        \n",
    "    if max_iter is None:\n",
    "        # use the default max_episode_steps\n",
    "        max_iter = env._max_episode_steps\n",
    "        \n",
    "    desc = env.desc.flatten()\n",
    "    \n",
    "    reward_total = 0.0\n",
    "    danger_total = 0.0\n",
    "    for exp in range(n_exp):\n",
    "        s = env.reset()\n",
    "        for i in range(max_iter):\n",
    "            a = policy.act(s)\n",
    "            s, r, done, info = env.step(a)\n",
    "            if desc[s] == b'H':\n",
    "                danger_total += env.penalty\n",
    "            if desc[s] == b'G':\n",
    "                reward_total += 1\n",
    "            if render:\n",
    "                env.render()\n",
    "            if done:\n",
    "                break\n",
    "    if print_result:\n",
    "        print('Avg collision rate: {:.3f}'.format(danger_total / n_exp), \n",
    "              'Avg reward: {:.3f}'.format(reward_total / n_exp)\n",
    "             )\n",
    "    return danger_total / n_exp, reward_total / n_exp"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Value iteration and optimal policy with Lagrange multiplier"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "class ValueIterationAgent(object):\n",
    "    def __init__(self, env, Qfunc_init = None, gamma = 0.99, max_iter = None):\n",
    "        self.env = env\n",
    "        self.gamma = gamma\n",
    "        if max_iter is None:\n",
    "            self.max_iter = env._max_episode_steps\n",
    "        else:\n",
    "            self.max_iter = max_iter\n",
    "        if Qfunc_init is None:\n",
    "            self.Qfunc = np.zeros([self.env.nS, self.env.nA])\n",
    "        else:\n",
    "            self.Qfunc = Qfunc_init\n",
    "        self.Vfunc = np.zeros(self.env.nS)\n",
    "    \n",
    "    def compute_V_from_Q(self):\n",
    "        self.Vfunc = np.max(self.Qfunc, axis=1)\n",
    "    def compute_Q_from_next_V(self):\n",
    "        for s in range(self.env.nS):\n",
    "            for a in range(self.env.nA):\n",
    "                self.Qfunc[s, a] = 0\n",
    "                possible_outcomes = self.env.P[s][a]\n",
    "                for outcome in possible_outcomes:\n",
    "                    prob, next_state, reward, done = outcome\n",
    "                    future_reward = 0 if done else self.Vfunc[next_state]\n",
    "                    self.Qfunc[s, a] += prob * (reward + self.gamma * future_reward)\n",
    "            \n",
    "    def do_value_iteration(self):\n",
    "        self.compute_V_from_Q()\n",
    "        for i in range(self.max_iter):    \n",
    "            old_V = self.Vfunc.copy()\n",
    "            self.compute_Q_from_next_V()\n",
    "            self.compute_V_from_Q()\n",
    "            if np.allclose(self.Vfunc, old_V):\n",
    "                break\n",
    "        \n",
    "    def get_policy(self):\n",
    "        return policy_from_Qfunc(self.Qfunc)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# The Lagrange multiplier method\n",
    "penalty_list = [0, 0.01, 0.02, 0.09, 0.1]\n",
    "env_list = []\n",
    "for penalty in penalty_list:\n",
    "    env_list.append(continue_on_hole(env_frozenlake, penalty=penalty))\n",
    "\n",
    "env_test = continue_on_hole(env_frozenlake, penalty=1)\n",
    "\n",
    "def LM_exp_curve(env_list, print_result=False):\n",
    "    reward_list = []\n",
    "    danger_list = []\n",
    "    for i, env in enumerate(env_list):\n",
    "        VI_FL = ValueIterationAgent(env)\n",
    "        VI_FL.do_value_iteration()\n",
    "        policy = VI_FL.get_policy()\n",
    "        danger, reward = run_exp(env_test, policy)\n",
    "        if print_result:\n",
    "            print('the {}th env avg danger {:.3f} and avg reward {:.3f}'.format(i, danger, reward))\n",
    "        reward_list.append(reward)\n",
    "        danger_list.append(danger)\n",
    "    return danger_list, reward_list\n",
    "\n",
    "danger_LM, reward_LM = LM_exp_curve(env_list)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# RMDP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Construct the RMDP by chaning the reward\n",
    "# Reward is -1 if on a hole `H` or 0 otherwise\n",
    "env_RMDP = continue_on_hole(env_frozenlake, penalty=1, goal_reward=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "RMDP policy in Frozen Lake:\n",
      "Avg collision rate: 0.000 Avg reward: 0.000\n"
     ]
    }
   ],
   "source": [
    "# Construct the RMDP by chaning the reward\n",
    "# Reward is -1 if on a hole `H` or 0 otherwise\n",
    "env_RMDP = continue_on_hole(env_frozenlake, penalty=1, goal_reward=0)\n",
    "\n",
    "# Solve the RMDP and test its optimal policy in the original Frozen Lake\n",
    "VI_RMDP = ValueIterationAgent(env_RMDP)\n",
    "VI_RMDP.do_value_iteration()\n",
    "print('RMDP policy in Frozen Lake:')\n",
    "run_exp(env_frozenlake, VI_RMDP.get_policy(), print_result=True);"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Visualization of the threat function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.colorbar.Colorbar at 0x1270e8ef0>"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 5 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "env = env_frozenlake\n",
    "TF = -VI_RMDP.Qfunc\n",
    "TF_grid = np.zeros((env.nrow, env.ncol, env.nA))\n",
    "x_arr = np.arange(0, env.nrow, 1)\n",
    "y_arr = np.arange(0, env.ncol, 1)\n",
    "for row in x_arr:\n",
    "    for col in y_arr:\n",
    "        for a in range(env.nA):\n",
    "            s = row*env.ncol + col\n",
    "            TF_grid[row, col, a] = TF[s][a]\n",
    "\n",
    "fig, ax = plt.subplots(1, 4, constrained_layout=True)\n",
    "a_list = ['LEFT', 'DOWN', 'RIGHT', 'UP']\n",
    "for a in range(env.nA):\n",
    "    ax[a].set_title(a_list[a])\n",
    "    pcm = ax[a].imshow(TF_grid[:,:,a], cmap=cm.jet)\n",
    "\n",
    "fig.colorbar(pcm, ax=ax[:], shrink=0.6, location='bottom')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Solve PMDP using the RMDP Q-function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "# RP policy given a threat function\n",
    "class policy_RP(policy_from_Qfunc):\n",
    "    def __init__(self, Qfunc, threat_function, threat_threshold = 0.03, random_tie_breaking = False):\n",
    "        super().__init__(Qfunc, random_tie_breaking)\n",
    "        self.threat_function = threat_function\n",
    "        self.threat_threshold = threat_threshold\n",
    "        self.is_safe_action_list = []\n",
    "        for s in range(self.threat_function.shape[0]):\n",
    "            self.is_safe_action_list.append(self.threat_function[s, :] < self.threat_threshold)\n",
    "    def act(self, s):\n",
    "        is_safe_action = self.is_safe_action_list[s]\n",
    "        if np.any(is_safe_action):\n",
    "            # replace the values of non-safe actions to -inf\n",
    "            values = np.where(is_safe_action, self.Qfunc[s, :], - np.inf)\n",
    "        else:\n",
    "            # no safe actions, follow RMDP policy from negative threat function\n",
    "            values = - self.threat_function[s, :]\n",
    "        \n",
    "        return self.act_from_values(values)\n",
    "\n",
    "    \n",
    "class RPValueIterationAgent(ValueIterationAgent):\n",
    "    def __init__(self, env, threat_function, **kwargs):\n",
    "        self.threat_function = threat_function\n",
    "        self.threat_threshold = kwargs.pop('threat_threshold')\n",
    "        self.is_safe_action_list = []\n",
    "        for s in range(env.nS):\n",
    "            self.is_safe_action_list.append(self.threat_function[s, :] < self.threat_threshold)\n",
    "         \n",
    "        super().__init__(env, **kwargs)\n",
    "    \n",
    "    def compute_V_from_Q(self):\n",
    "        for s in range(self.env.nS):\n",
    "            is_safe_action = self.is_safe_action_list[s]\n",
    "            \n",
    "            if np.any(is_safe_action):\n",
    "                self.Vfunc[s] = np.max(self.Qfunc[s, is_safe_action])\n",
    "            else:\n",
    "                action_from_threat_func = np.argmin(self.threat_function[s, :])\n",
    "                self.Vfunc[s] = self.Qfunc[s, action_from_threat_func]\n",
    "\n",
    "    def get_policy(self):\n",
    "        return policy_RP(self.Qfunc, self.threat_function, self.threat_threshold)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "env_train = continue_on_hole(env_frozenlake, penalty = 0)\n",
    "env_test = continue_on_hole(env_frozenlake, penalty = 1)\n",
    "\n",
    "def RP_exp_curve(threat_threshold_list, threat_function, n_exp=3000, print_result=False):\n",
    "    reward_list = []\n",
    "    danger_list = []\n",
    "    for i, threat_threshold in enumerate(threat_threshold_list):\n",
    "        RP_VI = RPValueIterationAgent(env_train, threat_function, threat_threshold=threat_threshold)\n",
    "        RP_VI.do_value_iteration()\n",
    "        policy = RP_VI.get_policy()\n",
    "        danger, reward = run_exp(env_test, policy, n_exp=n_exp)\n",
    "        if print_result:\n",
    "            print('the {}/{}th case avg danger {:.3f} and avg reward {:.3f}'.format(i, len(threat_threshold_list), danger, reward))\n",
    "        reward_list.append(reward)\n",
    "        danger_list.append(danger)\n",
    "    return danger_list, reward_list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "# PMDP policy in Frozen Lake\n",
    "n_exp = 3000\n",
    "threat_threshold_list_logx = np.logspace(-4.0, 1.0, num=20)\n",
    "\n",
    "danger_rp, reward_rp = RP_exp_curve(threat_threshold_list_logx, -VI_RMDP.Qfunc, n_exp=n_exp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "# compute the threat function for a heuristic policy\n",
    "def policy_evaluation(env, policy, gamma=0.99):\n",
    "    Qfunc = np.zeros([env.nS, env.nA])\n",
    "    for i in range(env._max_episode_steps): \n",
    "        Qfunc_new = np.zeros([env.nS, env.nA])\n",
    "        for s in range(env.nS):\n",
    "            for a in range(env.nA):\n",
    "                possible_outcomes = env.P[s][a]\n",
    "                for outcome in possible_outcomes:\n",
    "                    prob, next_state, reward, done = outcome\n",
    "                    future_reward = 0 if done else Qfunc[next_state, policy.act(next_state)]\n",
    "                    Qfunc_new[s, a] += prob * (reward + gamma * future_reward)\n",
    "        Qfunc = Qfunc_new\n",
    "    return Qfunc\n",
    "\n",
    "\n",
    "def random_policy_evaluation(env, gamma=0.99):\n",
    "    Qfunc = np.zeros([env.nS, env.nA])\n",
    "    for i in range(env._max_episode_steps): \n",
    "        Qfunc_new = np.zeros([env.nS, env.nA])\n",
    "        for s in range(env.nS):\n",
    "            for a in range(env.nA):\n",
    "                possible_outcomes = env.P[s][a]\n",
    "                for outcome in possible_outcomes:\n",
    "                    prob, next_state, reward, done = outcome\n",
    "                    future_reward = 0\n",
    "                    if not done:\n",
    "                        for next_a in range(env.nA):\n",
    "                            future_reward += Qfunc[next_state, next_a] / env.nA\n",
    "                    \n",
    "                    Qfunc_new[s, a] += prob * (reward + gamma * future_reward)\n",
    "        Qfunc = Qfunc_new\n",
    "    return Qfunc\n",
    "\n",
    "\n",
    "Qfunc_heuristic1 = random_policy_evaluation(env_RMDP)\n",
    "policy_heuristic1 = policy_from_Qfunc(Qfunc_heuristic1)\n",
    "Qfunc_heuristic2 = policy_evaluation(env_RMDP, policy_heuristic1)\n",
    "policy_heuristic2 = policy_from_Qfunc(Qfunc_heuristic2)\n",
    "Qfunc_heuristic3 = policy_evaluation(env_RMDP, policy_heuristic2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "# run experiments\n",
    "danger_rp1, reward_rp1 = RP_exp_curve(threat_threshold_list_logx, -Qfunc_heuristic1, n_exp=n_exp)\n",
    "danger_rp2, reward_rp2 = RP_exp_curve(threat_threshold_list_logx, -Qfunc_heuristic2, n_exp=n_exp)\n",
    "danger_rp3, reward_rp3 = RP_exp_curve(threat_threshold_list_logx, -Qfunc_heuristic3, n_exp=n_exp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x129511b00>"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.rcParams.update({'font.size': 14})\n",
    "rc('text', usetex=True)\n",
    "plt.figure()\n",
    "\n",
    "plt.plot(threat_threshold_list_logx, danger_rp1, 'o-', label=r'P-MDP with $\\eta^0$')\n",
    "plt.plot(threat_threshold_list_logx, danger_rp2, '^-', label=r'P-MDP with $\\eta^1$')\n",
    "plt.plot(threat_threshold_list_logx, danger_rp3, 'v-', label=r'P-MDP with $\\eta^2$')\n",
    "plt.plot(threat_threshold_list_logx, danger_rp, 'rs-', label='RP')\n",
    "\n",
    "plt.plot(threat_threshold_list_logx, threat_threshold_list_logx * 100, 'r--', \n",
    "             label='Upper bound') \n",
    "plt.ylim(0, 5)\n",
    "plt.xscale('log')\n",
    "plt.xlabel(r'threat threshold $x$')\n",
    "plt.ylabel('Average danger')\n",
    "plt.legend(loc = 'center left', bbox_to_anchor=(-0.02, 0.4))\n",
    "\n",
    "plt.figure()\n",
    "\n",
    "plt.plot(threat_threshold_list_logx, reward_rp1, 'o-', label=r'P-MDP with $\\eta^0$')\n",
    "plt.plot(threat_threshold_list_logx, reward_rp2, '^-', label=r'P-MDP with $\\eta^1$')\n",
    "plt.plot(threat_threshold_list_logx, reward_rp3, 'v-', label=r'P-MDP with $\\eta^2$')\n",
    "plt.plot(threat_threshold_list_logx, reward_rp, 'rs-', label='RP')\n",
    "plt.xscale('log')\n",
    "plt.xlabel(r'threat threshold $x$')\n",
    "plt.ylabel('Average reward')\n",
    "plt.legend(loc = 'center left', bbox_to_anchor=(0, 0.4))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x129830b70>"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plt.scatter(danger_rp1, reward_rp1, marker='o', label=r'P-MDP with $\\eta^0$')\n",
    "plt.scatter(danger_rp2, reward_rp2, marker='^', label=r'P-MDP with $\\eta^1$')\n",
    "plt.scatter(danger_rp3, reward_rp3, marker='v', label=r'P-MDP with $\\eta^2$')\n",
    "plt.scatter(danger_rp, reward_rp, marker='s', label='RP')\n",
    "\n",
    "plt.plot(danger_LM, reward_LM, 'k-', label='Lagrange multiplier method' )\n",
    "plt.xlabel('Average danger')\n",
    "plt.ylabel('Average reward')\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "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.7.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
