{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import time\n",
    "import pickle\n",
    "import numpy as np\n",
    "from environment import MDP, generate_mdp\n",
    "from PI import policy_iteration\n",
    "from sampling import omega_star_o, omega_star_g, oracle_policy\n",
    "from MDP_NaS import MDP_NaS\n",
    "from VRQL import VRQL, Delta_min, Mu_min"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 1) Generate a random MDP $\\mathcal{M}$, print $U_o(\\mathcal{M})$, save it in .pkl file "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Ns = 50\n",
    "# Na = 100\n",
    "# gamma= 0.7\n",
    "# mdp = generate_mdp(Ns,Na,gamma=gamma)\n",
    "# pi,V,Q = policy_iteration(mdp)\n",
    "# omega_o, U_o, H, H_star = omega_star_o(mdp,pi, V, Q, omega_0 = None, N_iter=100)\n",
    "# #omega_g, U_g, _, _ = omega_star_g(mdp,pi, V, Q) #oracle allocation and upper bound in case of generative model for comparison (not used here)\n",
    "# print(\"U_o = {}, \".format(U_o))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import pickle\n",
    "# with open(\"./Instances/Example.pkl\",\"wb\") as file:\n",
    "#     pickle.dump(mdp,file)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 2) Load $\\mathcal{M}$ from the .pkl file and print info again "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "S = 5 , A = 5, Gamma = 0.7\n",
      "$U_o \\log(1/\\delta)$ = 1.140035E+05\n"
     ]
    }
   ],
   "source": [
    "name = \"Ergodic\"\n",
    "file = open(\"./Instances/\"+name+\".pkl\", 'rb')\n",
    "mdp = pickle.load(file)\n",
    "file.close()\n",
    "print(\"S = {} , A = {}, Gamma = {}\".format(mdp.Ns, mdp.Na, mdp.gamma))\n",
    "pi,V,Q = policy_iteration(mdp)\n",
    "omega_o, U_o, H, H_star = omega_star_o(mdp,pi, V, Q, omega_0 = None, N_iter=100)\n",
    "#omega_g, U_g, _, _ = omega_star_g(mdp,pi, V, Q) #oracle allocation and upper bound in case of generative model for comparison (not used here)\n",
    "delta = 0.1\n",
    "print(\"$U_o \\log(1/\\delta)$ = {}\".format(format(U_o*np.log(1/delta), \"10E\")))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 3) Run parallelized Monte-Carlo simulations     "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def RunSim(procnum, REGISTER, name, mdp, Navigation = \"D\", delta= 1e-1, period = 1e4):\n",
    "    mdp_c = mdp.copy()\n",
    "    REGISTER[procnum] = MDP_NaS(mdp_c, Navigation, delta, period)\n",
    "    with open(\"./Results/\"+name+\"_\"+Navigation+ \"_\"+str(procnum)+\".pkl\",\"wb\") as file:\n",
    "        pickle.dump(REGISTER[procnum],file)\n",
    "    \n",
    "\n",
    "from multiprocessing import Process, Manager\n",
    "def RunExp(num, name, mdp, Navigation=\"D\",delta= 1e-1, period = 1e4):\n",
    "    start = time.time()\n",
    "    manager = Manager()\n",
    "    REGISTER = manager.dict()\n",
    "    jobs = [] \n",
    "    for i in range(num):\n",
    "        p = Process(target=RunSim, args = (i, REGISTER, name, mdp, Navigation, delta, period))\n",
    "        p.start()\n",
    "        jobs.append(p)\n",
    "    for p in jobs:\n",
    "        p.join()\n",
    "    end = time.time()\n",
    "    print('{:.4f} s'.format(end-start))\n",
    "    return REGISTER"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# num= 30\n",
    "# ALGOS = {\"name\":[\"D\", \"C\"], \"results\": []}\n",
    "# for alg in ALGOS[\"name\"]:\n",
    "#     REGISTER = RunExp(num, name, mdp, Navigation = alg,delta = 1e-1, period = 1e5)\n",
    "#     ALGOS[\"results\"].append(REGISTER)\n",
    "#     with open(\"./Results/results_\"+name+\"_\"+alg+\".pkl\",\"wb\") as file:\n",
    "#         pickle.dump(ALGOS,file)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 4) Plot relative distance between visit-frequencies and oracle allocation: "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "name = \"Ergodic\"\n",
    "num = 30\n",
    "ALGOS = {\"name\":[\"D\", \"C\"], \"results\": [0,0]}\n",
    "for i,alg in enumerate([\"C\", \"D\"]):\n",
    "    L = []\n",
    "    for exp in range(num):\n",
    "        file = open(\"./Results/\"+name+\"_\"+alg+ \"_\"+str(exp)+\".pkl\", 'rb')\n",
    "        REGISTER = pickle.load(file)\n",
    "        file.close()\n",
    "        L.append(REGISTER)\n",
    "    ALGOS[\"results\"][i] = L"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXgAAAERCAYAAABxZrw0AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/d3fzzAAAACXBIWXMAAAsTAAALEwEAmpwYAAA5oUlEQVR4nO3deXxV1b338c/aZ8hAgATCGIaAYtEwBERF6wC19VqqFlsHWp9e6SDXWqte9daq14r20dZWbfV6a6vW2vZalaKo1+rT0hbriBUQRVEZg4RAIIHMyZn2ev5Y+4wJZDo5U37v1+u8zsk++5yzGPLd6/z22msprTVCCCFyj5XuBgghhBgYEvBCCJGjJOCFECJHScALIUSOkoAXQogcJQEvhBA5qtuAV0pNVEqtUUp9qJT6QCl1dRf7LFBKNSqlNjq3HwxMc4UQQvSUuwf7BIHrtNYblFJDgfVKqdVa680J+72qtT6npx9cWlqqy8vLe9FUIYQQ69evr9Naj+rJvt0GvNZ6L7DXedyslPoQKAMSA75XysvLWbduXX/eQgghBh2l1K6e7turGrxSqhyYA7zVxdMnK6XeVUq9pJSq6M37CiGESL6elGgAUEoVAU8D12itmxKe3gBM1lq3KKUWAc8C07p4j2XAMoBJkyb1tc1CCCF6oEc9eKWUBxPuj2utn0l8XmvdpLVucR6/CHiUUqVd7PeQ1nqe1nreqFE9KiEJIYToo2578EopBfwa+FBrfe9h9hkL1GqttVLqRMyBoz6pLRVCDKhAIEB1dTUdHR3pbooA8vPzmTBhAh6Pp8/v0ZMSzaeBrwGblFIbnW03AZMAtNa/BC4Avq2UCgLtwBIt01QKkVWqq6sZOnQo5eXlmH6dSBetNfX19VRXVzNlypQ+v09PRtG8BhzxX1tr/QDwQJ9bIYRIu46ODgn3DKGUYuTIkRw4cKBf7yNXsgohIiTcM0cy/i0k4IUQGWPfvn0sWbKEo446iuOOO45FixaxZcuWuH2WL19OYWEh+/fvj2wrKirq82eecsopfX7tY489Rk1NTeTnb33rW2ze3K9LhJIqKwPeH7TT3QQhRJJprTn//PNZsGAB27dvZ/Pmzdx5553U1tZ22re0tJR77rknKZ/7xhtv9Pm1iQH/yCOPcNxxxyWjWUmRlQHf3BEgGJKQFyKXrFmzBo/Hw+WXXx7ZVllZyWmnndZp32984xs89dRTHDx4sNNzixcv5vjjj6eiooKHHnoIgAcffJDvfe97kX0ee+wxvvvd7wLR3r9t21xxxRVUVFRwzjnnsGjRIlauXAnA7bffzgknnMCMGTNYtmwZWmtWrlzJunXruOSSS6isrKS9vZ0FCxZErtB/4oknmDlzJjNmzOCGG26IfHZRURE333wzs2fPZv78+V0ewJIlKwNeA4faAuluhhAiid5//32OP/74Hu1bVFTEN77xDe67775Ozz366KOsX7+edevWcf/991NfX88FF1zAM89EL+F56qmnuPjii+Ne98wzz1BVVcWmTZt45JFHePPNNyPPXXnllbz99tu8//77tLe388ILL3DBBRcwb948Hn/8cTZu3EhBQUFk/5qaGm644Qb+/ve/s3HjRt5++22effZZAFpbW5k/fz7vvvsup59+Og8//HBv/pp6pcdXsmaa5o4Awws8eN1ZeYwSIqNdcw1s3Jjc96yshJ//PHnvd9VVV1FZWcl1110Xt/3+++9n1apVAOzevZutW7cyf/58pk6dytq1a5k2bRoff/wxn/70p+Ne99prr3HhhRdiWRZjx45l4cKFkefWrFnDT37yE9ra2jh48CAVFRWce+65h23b22+/zYIFCwhf0HnJJZfwyiuvsHjxYrxeL+ecY+ZlPP7441m9enVS/j66krUBD9DQ5mf0sPx0N0MIkQQVFRWRkkism2++mT/96U8AbIw56hQXF/PVr36VX/ziF5FtL7/8Mn/961958803KSwsZMGCBZELty6++GJWrFjB9OnTOf/88zuNUjncpTsdHR1cccUVrFu3jokTJ7J8+fJuLwY70mVAHo8n8tkul4tgMHjE9+qPrA74Fl+Q4cEQeW5XupsiRE5JZk+7pz7zmc9w00038fDDD3PZZZcBpid81llncccdd3T5mmuvvZYTTjghEpKNjY2UlJRQWFjIRx99xNq1ayP7fulLX+KOO+5g8uTJ3HXXXZ3e69RTT+W3v/0tl156KQcOHODll1/mq1/9aiTMS0tLaWlpYeXKlVxwwQUADB06lObm5k7vddJJJ3H11VdTV1dHSUkJTzzxRKTmn0pZX9841Cq1eCFygVKKVatWsXr1ao466igqKipYvnw548ePP+xrSktLOf/88/H5fACcffbZBINBZs2axS233ML8+fMj+5aUlHDc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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "#fig, axs = plt.subplots(2,2, figsize=(10,10))\n",
    "period = 1e5\n",
    "labels =[]\n",
    "Taus = []\n",
    "T = np.float('inf')\n",
    "for i,alg in enumerate([\"C\", \"D\"]):\n",
    "    labels.append(alg+\"-Navigation\")\n",
    "    REGISTER = ALGOS[\"results\"][i]\n",
    "    Taus_alg = []\n",
    "    for j in range(num):\n",
    "        X = REGISTER[j][\"time\"]\n",
    "        Taus_alg.append(X[-1])\n",
    "        if len(X) < T:\n",
    "            T = len(X)\n",
    "    Taus.append(Taus_alg)\n",
    "    \n",
    "Times = [period*j for j in range(T)]\n",
    "colors = [\"b\", \"r\"]\n",
    "for i,alg in enumerate([\"C\", \"D\"]):\n",
    "    REGISTER = ALGOS[\"results\"][i]\n",
    "    omega_d = np.array([REGISTER[j][\"omega_d\"][:T] for j in range(num)])\n",
    "    omega_d = np.log10(omega_d)\n",
    "    d10 = np.quantile(omega_d,0.1 ,axis=0)\n",
    "    d90 = np.quantile(omega_d,0.9 ,axis=0)\n",
    "    plt.plot(Times, np.mean(omega_d,axis = 0), label=alg+\"-Navigation\", color = colors[i])\n",
    "    plt.fill_between(Times, d10, d90, alpha=0.15)\n",
    "\n",
    "plt.xlabel(\"Time\",fontsize=20)\n",
    "#plt.ylabel(\"\" ,fontsize=24)\n",
    "plt.legend()\n",
    "ext = 'png'\n",
    "plt.savefig('omega_d.'+ext, format=ext)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 5) Plot average sample complexity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x720 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axs = plt.subplots(1,1, figsize=(10,10))\n",
    "axs.boxplot(Taus, notch = False, labels = labels, showfliers=True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    " "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    " "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 6) Compare with VRQL:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of samples = 2.653130E+08\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(True,\n",
       " '2.653130E+08',\n",
       " array([0, 0, 0, 0, 0]),\n",
       " array([[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.]]))"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Ns = mdp.Ns\n",
    "Na = mdp.Na\n",
    "gamma = mdp.gamma\n",
    "pi_u = np.ones((Ns,Na))/Na #uniform policy\n",
    "pi_b = pi_u #behavior policy\n",
    "hyperparameters = {\"c0\": 0.01, \"c1\": 10, \"c2\":10, \"c3\":10, \"mu_min\": Mu_min(mdp, pi_b)}\n",
    "VRQL(mdp, U_o, pi_b, hyperparameters, epsilon = Delta_min(V,Q, gamma), delta = 0.1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Code to see how much time i takes just to simulate following a trajectory for N steps\n",
    "# N = int(1e6)\n",
    "# from numpy.random import default_rng\n",
    "# rng = default_rng()\n",
    "# t0 = time.time()\n",
    "# for i in range(N):\n",
    "#     reward = rng.binomial(1, mdp.R[0,0])\n",
    "#     transition = rng.multinomial(1, mdp.P[0,0]) # P[s,a,s']\n",
    "#     pi = np.ones((5,10))/10\n",
    "#     a = np.where(rng.multinomial(1, pi[0,:])==1)[0][0]\n",
    "# # print('{:.4f} s'.format(end-start))  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "# num = 1\n",
    "# start = time.time()\n",
    "# for i in range(num):\n",
    "#     MDP_NaS(mdp, Navigation = \"C\", delta= 1e-1, period = 1e4)\n",
    "# end = time.time()\n",
    "# print('{:.4f} s'.format(end-start))   "
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python3UMPA",
   "language": "python",
   "name": "python3umpa"
  },
  "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.8.5"
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": false,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {},
   "toc_section_display": true,
   "toc_window_display": false
  },
  "varInspector": {
   "cols": {
    "lenName": 16,
    "lenType": 16,
    "lenVar": 40
   },
   "kernels_config": {
    "python": {
     "delete_cmd_postfix": "",
     "delete_cmd_prefix": "del ",
     "library": "var_list.py",
     "varRefreshCmd": "print(var_dic_list())"
    },
    "r": {
     "delete_cmd_postfix": ") ",
     "delete_cmd_prefix": "rm(",
     "library": "var_list.r",
     "varRefreshCmd": "cat(var_dic_list()) "
    }
   },
   "types_to_exclude": [
    "module",
    "function",
    "builtin_function_or_method",
    "instance",
    "_Feature"
   ],
   "window_display": false
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
