{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Example in section B.4.1 (Minimum sub-optimality gap)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "theta: 0.0 - Optimal policies: [[1 1]] - Q values: [[0.14999971 0.29999971]\n",
      " [0.14999971 1.29999971]] - Suboptimal actions: [[ True False]\n",
      " [ True False]]\n",
      "-----------------------\n",
      "theta: 0.8846153846153846 - Optimal policies: [[1 0]\n",
      " [1 1]] - Q values: [[0.76923044 1.53846121]\n",
      " [0.76923044 0.76923044]] - Suboptimal actions: [[ True False]\n",
      " [False False]]\n",
      "-----------------------\n",
      "theta: 0.8848848848848849 - Optimal policies: [[1 0]] - Q values: [[0.76946479 1.53892991]\n",
      " [0.76946479 0.76916014]] - Suboptimal actions: [[ True False]\n",
      " [False  True]]\n",
      "-----------------------\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "from tabular.envs.riverswim import RiverSwim\n",
    "from tabular.envs.doublechain import DoubleChain\n",
    "from tabular.envs.mdp import MDP\n",
    "from tabular.utils.bound import solve_bound, solve_bound_new\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "ns = 2\n",
    "na = 2\n",
    "Npoints = 1000\n",
    "gamma = 0.5\n",
    "env = RiverSwim(ns)\n",
    "ns,na = env.dim_state, env.dim_action\n",
    "mdp = MDP(P=env.P)\n",
    "\n",
    "\n",
    "theta = np.linspace(0,1, Npoints)\n",
    "theta = np.array(theta.tolist() + [23/26])\n",
    "theta.sort()\n",
    "Npoints += 1\n",
    "\n",
    "basis = np.eye(ns * na)\n",
    "e1, e2 = basis[-3,:], basis[-1,:]\n",
    "\n",
    "r1 = e1.reshape(ns, na)[..., np.newaxis]\n",
    "r2 = e2.reshape(ns, na)[..., np.newaxis]\n",
    "\n",
    "\n",
    "data = np.zeros((Npoints, ns))\n",
    "data_min = np.zeros((Npoints, ns))\n",
    "i = 0\n",
    "prev_pi = np.array([[0,0],[0,0]])\n",
    "\n",
    "\n",
    "for x in theta:\n",
    "    reward = x * r1 + (1-x) * r2\n",
    "    stats = mdp.get_mdp_statistics(reward, gamma)\n",
    "    gaps = stats.Delta\n",
    "    if np.any(stats.pi != prev_pi):\n",
    "        print(f'theta: {x} - Optimal policies: {stats.pi} - Q values: {stats.Q} - Suboptimal actions: {stats.idxs_subopt_actions}')\n",
    "        print(f'-----------------------')\n",
    "        prev_pi = stats.pi\n",
    "    gaps = gaps[stats.idxs_subopt_actions]\n",
    "    data[i,:] = gaps.flatten().copy()\n",
    "    data_min[i] = gaps.min()\n",
    "    i+=1\n",
    "\n",
    "plt.plot(theta,data_min)\n",
    "plt.xlabel(r'$\\theta$')\n",
    "plt.ylabel(r'$\\Delta_\\theta$')\n",
    "plt.grid()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## About the discontinuity in $\\theta=23/26$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "theta: 23/26 - Gap value: 0.769230769230769 - Optimal policies: [[1 0]\n",
      " [1 1]] \n"
     ]
    }
   ],
   "source": [
    "x = 23/26\n",
    "reward = x * r1 + (1-x) * r2\n",
    "stats = mdp.get_mdp_statistics(reward, gamma)\n",
    "gaps = stats.Delta\n",
    "gaps = gaps[gaps > 0]\n",
    "print(f'theta: 23/26 - Gap value: {gaps.min()} - Optimal policies: {stats.pi} ')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "reward-free-exploration",
   "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.11.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
