{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from MDP_util import (\n",
    "    generate_toy_cmdp,\n",
    "    solve_cmdp,\n",
    "    policy_evaluation,\n",
    "    ope_practical,\n",
    "    compute_occupancy_measure,\n",
    "    critic,\n",
    "    policy_mixture,\n",
    "    MDP,\n",
    "    CMDP,\n",
    "    generate_trajectory,\n",
    ")\n",
    "import numpy as np\n",
    "import sys\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "optimal 0.8430077994824069 0.10000000137465727 0\n",
      "behavior 0.6699049938317626 0.2759924932445466\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/pengxy1/project/rwrl_tabular/MDP_util.py:580: OptimizeWarning: Unknown solver options: tol\n",
      "  res = scipy.optimize.linprog(\n"
     ]
    }
   ],
   "source": [
    "def generate_data(cmdp: CMDP, mu: np.ndarray, n: int):\n",
    "    ret = np.zeros((cmdp.num_states, cmdp.num_actions, cmdp.num_states))\n",
    "    for _ in range(n):\n",
    "        i = np.random.choice(np.arange(cmdp.num_states * cmdp.num_actions), p=mu.flatten())\n",
    "        state = i // cmdp.num_actions\n",
    "        action = i % cmdp.num_actions\n",
    "        next_state = np.random.choice(np.arange(cmdp.num_states), p=cmdp.transition[state, action, :])\n",
    "        ret[state, action, next_state] += 1\n",
    "    return ret\n",
    "\n",
    "\n",
    "num_states = 10\n",
    "num_next_states = 2\n",
    "num_actions = 5\n",
    "gamma = 0.8\n",
    "n = 200\n",
    "\n",
    "cmdp = generate_toy_cmdp(num_states, num_actions, gamma, num_next_states)\n",
    "\n",
    "pi_star = solve_cmdp(cmdp)\n",
    "pi_uniform = np.ones((num_states, num_actions)) / num_actions\n",
    "\n",
    "pi_mu_p5 = policy_mixture(pi_star, pi_uniform, alpha=0.5)\n",
    "d_mu = compute_occupancy_measure(cmdp, pi_mu_p5)\n",
    "dataset_p5 = generate_data(cmdp, d_mu, n)\n",
    "\n",
    "v_r, q_r, v_c, q_c = policy_evaluation(cmdp, pi_star)\n",
    "v_opt_p5 = v_r[cmdp.initial_state]\n",
    "c_opt_p5 = v_c[0][cmdp.initial_state]\n",
    "print(\"optimal\", v_opt_p5, c_opt_p5, 0)\n",
    "v_r, q_r, v_c, q_c = policy_evaluation(cmdp, pi_mu_p5)\n",
    "v_mu_p5 = v_r[cmdp.initial_state]\n",
    "c_mu_p5 = v_c[0][cmdp.initial_state]\n",
    "print(\"behavior\", v_mu_p5, c_mu_p5)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# from run_pdca_tabular import run_pdca_tabular\n",
    "# pdca_log_p5 = run_pdca_tabular(dataset_p5, cmdp, pi_uniform)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/499 [00:00<?, ?it/s]/home/pengxy1/anaconda3/envs/LPCMDP/lib/python3.8/site-packages/cvxpy/reductions/solvers/solving_chain.py:336: FutureWarning: \n",
      "    Your problem is being solved with the ECOS solver by default. Starting in \n",
      "    CVXPY 1.5.0, Clarabel will be used as the default solver instead. To continue \n",
      "    using ECOS, specify the ECOS solver explicitly using the ``solver=cp.ECOS`` \n",
      "    argument to the ``problem.solve`` method.\n",
      "    \n",
      "  warnings.warn(ECOS_DEPRECATION_MSG, FutureWarning)\n",
      "100%|██████████| 499/499 [02:23<00:00,  3.47it/s]\n",
      "100%|██████████| 499/499 [02:19<00:00,  3.58it/s]\n",
      "100%|██████████| 499/499 [02:22<00:00,  3.51it/s]\n"
     ]
    }
   ],
   "source": [
    "from run_wsac_tabular import run_wsac_tabular\n",
    "wsac_log_p5_beta005 = run_wsac_tabular(dataset_p5, cmdp, pi_uniform, beta=0.05)\n",
    "# wsac_log_p5_beta2 = run_wsac_tabular(dataset_p5, cmdp, pi_uniform, beta=2)\n",
    "wsac_log_p5_beta1 = run_wsac_tabular(dataset_p5, cmdp, pi_uniform, beta=1)\n",
    "wsac_log_p5_beta05 = run_wsac_tabular(dataset_p5, cmdp, pi_uniform, beta=0.5)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'cost')"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAzoAAAHDCAYAAADss29MAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8WgzjOAAAACXBIWXMAAA9hAAAPYQGoP6dpAABAIElEQVR4nO3de1yUdf7//+eAMngCDygHl694ykMpGARhmX22WbFcN7fN0PyEcSvdNTst20E6QK4VVuZayebmarptKbWddssP1bLxWUuSDfRmeSpLxbTh4Caj+AmKef/+6NfYrKAMDjBcPu6323WTec/7uuZ1vb1m3jy5Zq6xGWOMAAAAAMBCgjq6AAAAAADwN4IOAAAAAMsh6AAAAACwHIIOAAAAAMsh6AAAAACwHIIOAAAAAMsh6AAAAACwHIIOAAAAAMsh6AAAAACwHIIOYBFr1qyRzWbTvn37OroUAACADkfQAQAAwClt2rRJDzzwgI4cOdLRpQAtRtABAADAKW3atEkLFy4k6KBTIegAP1BXV9fRJTTL7Xbr66+/7ugyAAAAOgWCDs5aDzzwgGw2m3bs2KFrr71Wffr00cUXXyxJ+vOf/6zExER169ZNffv21YwZM3TgwAHPuk8++aSCg4O9/rL1+OOPy2azKSsry9PW2NioXr166e677/a0LVmyROPHj1e/fv3UrVs3JSYm6i9/+ctJ9dlsNt188816/vnnde6558put6uwsFCStH37dv34xz9Wt27d9KMf/UgPPvig3G63v4cIABDgDh48qBtuuEExMTGy2+0aPHiw5s2bp4aGBknS559/runTp6tv377q3r27LrzwQr355psnbeepp57Sueeeq+7du6tPnz5KSkrSCy+8IOm7+fLOO++UJA0ePFg2m43PhKJT6NLRBQAdbfr06Ro+fLgefvhhGWP00EMP6f7779c111yjG2+8UdXV1Xrqqad0ySWXaMuWLerdu7cmTJggt9ut9957Tz/96U8lSRs3blRQUJA2btzo2faWLVt07NgxXXLJJZ62J554Qj/72c80a9YsNTQ0aP369Zo+fbreeOMNTZkyxau2f/zjH3rxxRd18803KyIiQnFxcXI6nfqv//ovffvtt1qwYIF69OihZ555Rt26dWufAQMABIRDhw4pOTlZR44c0dy5czVy5EgdPHhQf/nLX3T8+HF99dVX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",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 2, figsize=(10, 5))\n",
    "\n",
    "reward_p5 = [v_mu_p5,\n",
    "            # pdca_log_p5[\"reward_value\"][-1],\n",
    "            wsac_log_p5_beta05[\"reward_value\"][-1],\n",
    "            wsac_log_p5_beta1[\"reward_value\"][-1],\n",
    "            wsac_log_p5_beta005[\"reward_value\"][-1],]\n",
    "cost_p5 = [ c_mu_p5,\n",
    "            # pdca_log_p5[\"cost_value\"][-1],\n",
    "            wsac_log_p5_beta05[\"cost_value\"][-1],\n",
    "            wsac_log_p5_beta1[\"cost_value\"][-1],\n",
    "            wsac_log_p5_beta005[\"cost_value\"][-1],]\n",
    "ax[0].bar(range(len(reward_p5)) ,reward_p5, tick_label=[\"behavior\", \"0.5\", \"1\", \"0.05\"], color=[\"r\", \"b\", \"b\", \"b\"])\n",
    "ax[0].set_title(\"reward\")\n",
    "ax[1].bar(range(len(cost_p5)), cost_p5, tick_label=[\"behavior\",\"0.5\", \"1\", \"0.05\"], color=[\"r\", \"b\", \"b\", \"b\"])\n",
    "ax[1].set_title(\"cost\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "optimal 0.8430077994824069 0.10000000137465727 0\n",
      "behavior 0.7718961206640405 0.1883805101527533\n"
     ]
    }
   ],
   "source": [
    "pi_mu_p8 = policy_mixture(pi_star, pi_uniform, alpha=0.8)\n",
    "d_mu = compute_occupancy_measure(cmdp, pi_mu_p5)\n",
    "dataset_p8 = generate_data(cmdp, d_mu, n)\n",
    "\n",
    "v_r, q_r, v_c, q_c = policy_evaluation(cmdp, pi_star)\n",
    "v_opt_p8 = v_r[cmdp.initial_state]\n",
    "c_opt_p8 = v_c[0][cmdp.initial_state]\n",
    "print(\"optimal\", v_opt_p8, c_opt_p8, 0)\n",
    "v_r, q_r, v_c, q_c = policy_evaluation(cmdp, pi_mu_p8)\n",
    "v_mu_p8 = v_r[cmdp.initial_state]\n",
    "c_mu_p8 = v_c[0][cmdp.initial_state]\n",
    "print(\"behavior\", v_mu_p8, c_mu_p8)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "# pdca_log_p8 = run_pdca_tabular(dataset_p8, cmdp, pi_uniform)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 499/499 [02:29<00:00,  3.34it/s]\n",
      " 25%|██▌       | 125/499 [00:36<01:48,  3.44it/s]/home/pengxy1/anaconda3/envs/LPCMDP/lib/python3.8/site-packages/cvxpy/problems/problem.py:1403: UserWarning: Solution may be inaccurate. Try another solver, adjusting the solver settings, or solve with verbose=True for more information.\n",
      "  warnings.warn(\n",
      "100%|██████████| 499/499 [02:27<00:00,  3.38it/s]\n",
      "100%|██████████| 499/499 [02:30<00:00,  3.31it/s]\n"
     ]
    }
   ],
   "source": [
    "wsac_log_p8_beta005 = run_wsac_tabular(dataset_p8, cmdp, pi_uniform, beta=0.05)\n",
    "# wsac_log_p5_beta2 = run_wsac_tabular(dataset_p5, cmdp, pi_uniform, beta=2)\n",
    "wsac_log_p8_beta1 = run_wsac_tabular(dataset_p8, cmdp, pi_uniform, beta=1)\n",
    "wsac_log_p8_beta05 = run_wsac_tabular(dataset_p8, cmdp, pi_uniform, beta=0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'cost')"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAzoAAAHDCAYAAADss29MAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8WgzjOAAAACXBIWXMAAA9hAAAPYQGoP6dpAABKqUlEQVR4nO3df1hUZcL/8c8MyuAvIEVBWRJ/lZo/MBDETWk3Nky3cjNDc9N8TKvVSudpS1qD3LZwN3PZNsutR8tnN9O1zDb1ocfYLE2SAr3Mn2WbYiqglqD4CMrc3z/6NjYLKIMDA8f367rO5cw99znnPjfD3Hw8Z+5jM8YYAQAAAICF2P3dAAAAAADwNYIOAAAAAMsh6AAAAACwHIIOAAAAAMsh6AAAAACwHIIOAAAAAMsh6AAAAACwHIIOAAAAAMsh6AAAAACwHIIOYBGvvvqqbDab9u/f7++mAAAA+B1BBwAAABe0efNmPfHEEzpx4oS/mwLUGUEHAAAAF7R582bNnTuXoINmhaAD/EB5ebm/m1Arl8ulM2fO+LsZAAAAzQJBB5etJ554QjabTbt27dKdd96pK664Qtddd50k6W9/+5tiY2PVqlUrtW/fXuPGjdPBgwfd6z733HMKCAjw+J+tZ599VjabTU6n011WVVWldu3a6dFHH3WXzZ8/X0OHDlWHDh3UqlUrxcbG6o033qjWPpvNphkzZui1117TNddcI4fDoezsbEnSzp079dOf/lStWrXSj370I/3ud7+Ty+XydRcBAJq4Q4cOacqUKerSpYscDoe6deum+++/X5WVlZKkf/3rXxo7dqzat2+v1q1ba8iQIVq7dm217fz5z3/WNddco9atW+uKK65QXFycli1bJum78fLXv/61JKlbt26y2Wx8JxTNQgt/NwDwt7Fjx6pXr156+umnZYzRU089pccff1x33HGH7rnnHh09elR//vOfNXz4cG3dulWhoaEaNmyYXC6XNm3apJ///OeSpI0bN8put2vjxo3ubW/dulWnTp3S8OHD3WV/+tOfdMstt2jChAmqrKzU8uXLNXbsWK1Zs0ajRo3yaNs///lP/f3vf9eMGTMUFham6OhoFRUV6Sc/+YnOnTun2bNnq02bNnrppZfUqlWrxukwAECTcPjwYcXHx+vEiROaNm2aevfurUOHDumNN97Q6dOn9e2332ro0KE6ffq0HnzwQXXo0EFLly7VLbfcojfeeEO/+MUvJEkvv/yyHnzwQd1+++166KGHdObMGW3fvl1btmzRnXfeqdtuu02ff/65Xn/9df3xj39UWFiYJKljx47+PHzg4gxwmcrIyDCSzPjx491l+/fvNwEBAeapp57yqPvZZ5+ZFi1auMurqqpMcHCweeSRR4wxxrhcLtOhQwczduxYExAQYE6ePGmMMWbBggXGbrebb7/91r2t06dPe2y7srLS9OvXz/z0pz/1KJdk7Ha72blzp0f5zJkzjSSzZcsWd1lJSYkJCQkxksxXX31Vvw4BADQrEydONHa73XzyySfVXnO5XO7xYuPGje7ykydPmm7dupno6GhTVVVljDHm1ltvNddcc80F9/XMM88wxqDZ4dI1XPbuu+8+9+NVq1bJ5XLpjjvu0LFjx9xLRESEevXqpffff1+SZLfbNXToUH344YeSpN27d+v48eOaPXu2jDHKzc2V9N1Znn79+ik0NNS9jx+eefn2229VWlqqYcOGqaCgoFrbkpKS1LdvX4+ydevWaciQIYqPj3eXdezYURMmTLj0zgAANAsul0urV6/WzTffrLi4uGqv22w2rVu3TvHx8e7LsiWpbdu2mjZtmvbv369du3ZJkkJDQ/X111/rk08+abT2A42BoIPLXrdu3dyPv/jiCxlj1KtXL3Xs2NFj2b17t0pKStx1hw0bpvz8fP3f//2fNm7cqM6dO+vaa6/VwIED3Zevbdq0ScOGDfPY35o1azRkyBAFBQWpffv26tixo1588UWVlpZesG3fO3DggHr16lWt/Oqrr653HwAAmpejR4+qrKxM/fr1q7XOgQMHahwb+vTp435dkh599FG1bdtW8fHx6tWrl6ZPn66PPvqoYRoONCK+o4PL3g/PsLhcLtlsNv3P//yPAgICqtVt27at+/F1112ns2fPKjc3Vxs3bnQHmmHDhmnjxo3as2ePjh496hF0Nm7cqFtuuUXDhw/XCy+8oM6dO6tly5Z65ZVX3F/6rK1tAAA0hD59+mjv3r1as2aNsrOz9eabb+qFF15Qenq65s6d6+/mAfVG0AF+oEePHjLGqFu3brrqqqsuWDc+Pl6BgYHauHGjNm7c6J6RZvjw4Xr55ZeVk5Pjfv69N998U0FBQXr33XflcDjc5a+88kqd29i1a1d98cUX1cr37t1b520AAJq3jh07Kjg4WDt27Ki1TteuXWscG/bs2eN+/Xtt2rRRamqqUlNTVVlZqdtuu01PPfWU0tLSFBQUJJvN5vuDABoYl64BP3DbbbcpICBAc+fOlTHG4zVjjI4fP+5+HhQUpMGDB+v1119XYWGhxxmd//u//9Nzzz2nHj16qHPnzu51AgICZLPZVFVV5S7bv3+/Vq9eXec2jhw5Uh9//LHy8vLcZUePHtVrr73m7eECAJopu92u0aNH65133tGnn35a7XVjjEaOHKm8vDz390al7+4X99JLLyk6Otr9HdAfjm2SFBgYqL59+8oYo7Nnz0r6LghJ4oahaFY4owP8QI8ePfS73/1OaWlp2r9/v0aPHq127drpq6++0ltvvaVp06bp4YcfdtcfNmyY5s2bp5CQEPXv31+S1KlTJ1199dXau3ev7r77bo/tjxo1SgsWLNCIESN05513qqSkRAsXLlTPnj21ffv2OrXxkUce0V//+leNGDFCDz30kHt66a5du9Z5GwCA5u/pp5/W//7v/yopKUnTpk1Tnz59dOTIEa1cuVKbNm3S7Nmz9frrr+umm27Sgw8+qPbt22vp0qX66quv9Oabb8pu/+7/u2+88UZFREToxz/+scLDw7V79249//zzGjVqlNq1aydJio2NlST95je/0bhx49SyZUvdfPPN7gAENEl+nPEN8Kvvp5c+evRotdfefPNNc91115k2bdqYNm3amN69e5vp06ebvXv3etRbu3atkWRuuukmj/J77rnHSDKLFy+utu3FixebXr16GYfDYXr37m1eeeUVd1t+SJKZPn16jW3fvn27SUpKMkFBQSYyMtI8+eSTZvHixUz9CQCXmQMHDpiJEyeajh07GofDYbp3726mT59uKioqjDHGfPnll+b22283oaGhJigoyMTHx5s1a9Z4bOMvf/mLGT58uOnQoYNxOBymR48e5te//rUpLS31qPfkk0+ayMhIY7fbGW/QLNiM+bfrcwAAAACgmeM7OgAAAAAsh6ADAAAAwHIIOgAAAAAsh6ADAAAAwHIIOgAAAAAsh6ADAAAAwHKaxQ1DXS6XDh8+rHbt2slms/m7OQBw2TDG6OTJk+rSpYv75oJgXAIAf6rr2NQsgs7hw4cVFRXl72YAwGXr4MGD+tGPfuTvZjQZjEsA4H8XG5uaRdBp166dpO8OJjg42M+tAYDL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jh07POqNGDHC4z37+uuvN8bhAJfkch2bGJcaD2NT3TA2XYS5TCUlJZnp06eb6dOnm+DgYNOhQwczZ84c43K5jDHGnDlzxvznf/6n6dKli2ndurWJj48377//vnv9V155xYSEhJjs7GzTu3dv06ZNG5OSkmIOHz7srpOXl2eSk5NNhw4dTHBwsBk+fLjJz893vz5+/Hhzxx13eLSrsrLSdOjQwSxdutTdzoceesj9+jfffGPuuusuExoaalq1amVGjBhhPv/882rtevvtt02fPn1MQECA+eqrr3zYc40nPj7eTJ8+3f28qqrKdOnSxWRmZtZY//tjR/1JMm+99Za/m9Ekeft+vOOOO8yoUaM8yhISEsy9997rfj5p0iRz6623Nkh70TwxNjVtjEv+wdhUO8amC7usz+gsXbpULVq0UF5env70pz9pwYIF+q//+i9J0owZM5Sbm6vly5dr+/btGjt2rEaMGKEvvvjCvf7p06c1f/58/fWvf9WHH36owsJCPfzww+7XT548qUmTJmnTpk36+OOP1atXL40cOVInT56UJE2YMEHvvPOOTp065V7n3Xff1enTp/WLX/yixjbffffd+vTTT/WPf/xDubm5MsZo5MiROnv2rEe7fv/73+u//uu/tHPnTnXq1Mmn/dYYKisrlZ+fr+TkZHeZ3W5XcnKycnNza13v1KlT6tq1q6KionTrrbdq586djdFcWFx93o+5ubke9SUpJSWlWv0NGzaoU6dOuvrqq3X//ffr+PHjvj8ANCuMTU0T4xKaGsamOvB30vKXpKQk06dPH/f/khljzKOPPmr69OljDhw4YAICAsyhQ4c81rnhhhtMWlqaMea7/6WRZPbt2+d+feHChSY8PLzWfVZVVZl27dqZd955xxhjzNmzZ01YWJj57//+b3ed8ePHm9TUVI92fv+/Zp9//rmRZD766CP368eOHTOtWrUyf//73z3atW3bNm+7pEk5dOiQkWQ2b97sUf7rX//axMfH17jO5s2bzdKlS83WrVvNhg0bzM9//nMTHBxsDh482BhNtgTxv2Y1qs/7sWXLlmbZsmUeZQsXLjSdOnVyP3/99dfN22+/bbZv327eeust06dPHzN48GBz7tw53x8EmgXGpqaLccl/GJtqxth0cS38E6+ahiFDhshms7mfJyYm6tlnn9Vnn32mqqoqXXXVVR71Kyoq1KFDB/fz1q1bq0ePHu7nnTt39rgmsri4WHPmzNGGDRtUUlKiqqoqnT59WoWFhZKkFi1a6I477tBrr72mu+66S+Xl5Xr77be1fPnyGtu7e/dutWjRQgkJCe6yDh066Oqrr9bu3bvdZYGBgRowYEA9e6X5SkxMVGJiovv50KFD1adPH/3lL3+5bL80i6Zt3Lhx7sf9+/fXgAED1KNHD23YsEE33HCDH1sGf2Jssg7GJTRHVhqbLuugU5tTp04pICBA+fn5CggI8Hitbdu27sctW7b0eM1ms8kY434+adIkHT9+XH/605/UtWtXORwOJSYmqrKy0l1nwoQJSkpKUklJidavX69WrVpd8swWrVq18hgkm6OwsDAFBASouLjYo7y4uFgRERF12kbLli01aNAg7du3ryGaiMtIfd6PERERXr9/u3fvrrCwMO3bt6/ZDSZoeIxN/sW4hKaGseniLuvv6GzZssXj+ffXKg8aNEhVVVUqKSlRz549PZa6fphJ0kcffaQHH3xQI0eO1DXXXCOHw6Fjx4551Bk6dKiioqK0YsUKvfbaaxo7dmy1Qep7ffr00blz5zzaffz4ce3du1d9+/b14sibvsDAQMXGxionJ8dd5nK5lJOT4/G/YxdSVVWlzz77TJ07d26oZuIyUZ/3Y2Jiokd9SVq/fv0F379ff/21jh8/znv2MsfY1DQxLqGpYWyqA39fO+cvSUlJpm3btmbWrFlmz549ZtmyZaZNmzZm0aJFxhhjJkyYYKKjo82bb75p/vWvf5ktW7aYp59+2qxZs8YYU/NMKm+99Zb5YZcOGjTI/OxnPzO7du0yH3/8sRk2bJhp1aqV+eMf/+ix3m9+8xvTt29f06JFC7Nx48Zq7fzhzDa33nqr6du3r9m4caPZtm2bGTFihOnZs6eprKystV3N1fLly43D4TCvvvqq2bVrl5k2bZoJDQ01RUVFxhhj7rrrLjN79mx3/blz55p3333XfPnllyY/P9+MGzfOBAUFmZ07d/rrEJqFkydPmq1bt5qtW7caSWbBggVm69at5sCBA/5uWpPi7fvxo48+Mi1atDDz5883u3fvNhkZGaZly5bms88+M8Z81+8PP/ywyc3NNV999ZV57733zLXXXmt69eplzpw545djhP8xNjVtjEuNh7GpbhibLuyyDjq/+tWvzH333WeCg4PNFVdcYR577DH3F0ArKytNenq6iY6ONi1btjSdO3c2v/jFL8z27duNMXUbTAoKCkxcXJwJCgoyvXr1MitXrjRdu3atNpjs2rXLSDJdu3b1+ALq9+2saQrPkJAQ06pVK5OSklLjFJ5W8ec//9lceeWVJjAw0MTHx5uPP/7Y/VpSUpKZNGmS+/nMmTPddcPDw83IkSNNQUGBH1rdvLz//vtGUrXlh32L73jzfjTGmL///e/mqquuMoGBgeaaa64xa9eudb92+vRpc+ONN5qOHTuali1bmq5du5qpU6e6Bydcnhibmj7GpcbB2FR3jE21sxnzgwt3AQAAAMACLuvv6AAAAACwJoIOAAAAAMsh6AAAAACwHIIOAAAAAMsh6AAAAACwHIIOAAAAAMsh6AAAAACwHIIOAAAAAMsh6AAAAACwHIIOAAAAAMsh6AAAAACwHIIOAAAAAMv5f0Dy1RkBiIQHAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 2, figsize=(10, 5))\n",
    "\n",
    "reward_p8 = [v_mu_p8,\n",
    "            # pdca_log_p8[\"reward_value\"][-1],\n",
    "            wsac_log_p8_beta05[\"reward_value\"][-1],\n",
    "            wsac_log_p8_beta1[\"reward_value\"][-1],\n",
    "            wsac_log_p8_beta005[\"reward_value\"][-1],]\n",
    "cost_p8 = [ c_mu_p8,\n",
    "            # pdca_log_p8[\"cost_value\"][-1],\n",
    "            wsac_log_p8_beta05[\"cost_value\"][-1],\n",
    "            wsac_log_p8_beta1[\"cost_value\"][-1],\n",
    "            wsac_log_p8_beta005[\"cost_value\"][-1],]\n",
    "ax[0].bar(range(len(reward_p8)) ,reward_p8, tick_label=[\"behavior\", \"0.5\", \"1\", \"0.05\"], color=[\"r\", \"b\", \"b\", \"b\"])\n",
    "ax[0].set_title(\"reward\")\n",
    "ax[1].bar(range(len(cost_p8)), cost_p8, tick_label=[\"behavior\",\"0.5\", \"1\", \"0.05\"], color=[\"r\", \"b\", \"b\", \"b\"])\n",
    "ax[1].set_title(\"cost\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "optimal 0.8430077994824069 0.10000000137465727 0\n",
      "behavior 0.5739594949734528 0.333738154728606\n"
     ]
    }
   ],
   "source": [
    "pi_mu_p2 = policy_mixture(pi_star, pi_uniform, alpha=0.2)\n",
    "d_mu = compute_occupancy_measure(cmdp, pi_mu_p2)\n",
    "dataset_p2 = generate_data(cmdp, d_mu, n)\n",
    "\n",
    "v_r, q_r, v_c, q_c = policy_evaluation(cmdp, pi_star)\n",
    "v_opt_p2 = v_r[cmdp.initial_state]\n",
    "c_opt_p2 = v_c[0][cmdp.initial_state]\n",
    "print(\"optimal\", v_opt_p2, c_opt_p2, 0)\n",
    "v_r, q_r, v_c, q_c = policy_evaluation(cmdp, pi_mu_p2)\n",
    "v_mu_p2 = v_r[cmdp.initial_state]\n",
    "c_mu_p2 = v_c[0][cmdp.initial_state]\n",
    "print(\"behavior\", v_mu_p2, c_mu_p2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "# pdca_log_p2 = run_pdca_tabular(dataset_p2, cmdp, pi_uniform)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 499/499 [03:00<00:00,  2.77it/s]\n",
      "100%|██████████| 499/499 [02:57<00:00,  2.82it/s]\n",
      "100%|██████████| 499/499 [03:00<00:00,  2.76it/s]\n"
     ]
    }
   ],
   "source": [
    "wsac_log_p2_beta005 = run_wsac_tabular(dataset_p2, cmdp, pi_uniform, beta=0.05)\n",
    "# wsac_log_p5_beta2 = run_wsac_tabular(dataset_p5, cmdp, pi_uniform, beta=2)\n",
    "wsac_log_p2_beta1 = run_wsac_tabular(dataset_p2, cmdp, pi_uniform, beta=1)\n",
    "wsac_log_p2_beta05 = run_wsac_tabular(dataset_p2, cmdp, pi_uniform, beta=0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'cost')"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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/qbf/va3gd0TAIAlBXrdsdlsuv322/Xggw9q/PjxGj16tO6//37FxcVpzpw5vbWbAIAA8zvoZGdnq76+XgUFBXK73UpKSlJZWZn3S501NTUKCTl+oGj69OlavXq17rvvPt1zzz0aP3683njjDZ177rmB24s+wOFwqLCw8IRTH9B1zGlgMZ+BxXwGTnesO3fddZeam5u1YMECHTp0SBdccIHKysoUFhbW4/vXm3ifBhbzGXjMaWCdafNpM711zVAAAAAA6CZ+fUcHAAAAAPoCgg4AAAAAyyHoAAAAALCcMzboXHTRRbr99tu73P7555/vkXsonO44AQB9B2sTAATOGRt0+orXXntNS5Ys6e1h9JqSkhIlJiYqLCxMaWlpqqys7LDu888/L5vN5rOdaVdQ6oo///nPuvzyyxUXFyebzaY33nijt4cUtPx5P0rSyy+/rAkTJigsLEyTJ0/W+vXrfZ6/4YYbTnjPZmVldecuAAFxJq9NrEs9g7Wp81ibOkbQCXLDhg3T4MGDu9y+ra1NHo8ngCPqOevWrZPT6VRhYaGqq6s1depUZWZmqq6ursM2ERER+vLLL73b3r17e3DEfVNzc7OmTp2qkpKS3h5KUPP3/bhx40bNmzdPN954ozZv3qw5c+Zozpw5+uijj3zqZWVl+bxn16xZ0xO7A5yWM3VtYl3qOaxNncPadArmDDVz5kyzcOFCs3DhQhMREWGGDx9u7rvvPuPxeIwxxnz11Vfml7/8pYmLizMDBgwwqamp5r333vO2//3vf28iIyNNWVmZmTBhghk4cKDJzMw0X3zxhbdOZWWlycjIMMOHDzcRERHmwgsvNFVVVd7n582bZ6655hqfcbW2tprhw4ebVatWecd52223eZ//+9//bq6//nozZMgQEx4ebrKysswnn3xywrj++Mc/mokTJxq73W52794dwJnrOampqWbhwoXex21tbSYuLs4UFRW1W//YvqPrJJnXX3+9t4cRlPx9P15zzTVm9uzZPmVpaWnmP/7jP7yPc3NzzRVXXNEt40XfxNoU3FiXegdrU8dYm07ujD6is2rVKvXr10+VlZX69a9/reXLl+t3v/udJOnWW29VRUWF1q5dq61bt+rqq69WVlaWPv30U2/7o0ePatmyZXrhhRf05z//WTU1Nbrjjju8zx8+fFi5ubl6//339cEHH2j8+PG6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",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 2, figsize=(10, 5))\n",
    "\n",
    "reward_p2 = [v_mu_p2,\n",
    "            # pdca_log_p2[\"reward_value\"][-1],\n",
    "            wsac_log_p2_beta05[\"reward_value\"][-1],\n",
    "            wsac_log_p2_beta1[\"reward_value\"][-1],\n",
    "            wsac_log_p2_beta005[\"reward_value\"][-1],]\n",
    "cost_p2 = [ c_mu_p2,\n",
    "            # pdca_log_p2[\"cost_value\"][-1],\n",
    "            wsac_log_p2_beta05[\"cost_value\"][-1],\n",
    "            wsac_log_p2_beta1[\"cost_value\"][-1],\n",
    "            wsac_log_p2_beta005[\"cost_value\"][-1],]\n",
    "ax[0].bar(range(len(reward_p2)) ,reward_p2, tick_label=[\"behavior\", \"0.5\", \"1\", \"0.05\"], color=[\"r\", \"b\", \"b\", \"b\"])\n",
    "ax[0].set_title(\"reward\")\n",
    "ax[1].bar(range(len(cost_p2)), cost_p2, tick_label=[\"behavior\",\"0.5\", \"1\", \"0.05\"], color=[\"r\", \"b\", \"b\", \"b\"])\n",
    "ax[1].set_title(\"cost\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 0, 'mixture percentage')"
      ]
     },
     "execution_count": 41,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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AAAAYNcKCgrk6Oio9evXy9HR0WaZu7u7+f9/joZmsVjMe3wkaciQITp06JDmzJmjpk2bytnZWZGRkSouLjbL3HvvvYqKitL+/fv11VdfydXVVT179ryg9ru6utoEOJQPQQcAAAB2Ye3atTavz9xH06lTJ5WUlGj//v3q1q1bpetfvXq1XnvtNd1yyy2SpD179ujgwYM2Zbp06aLAwEAtWrRIX3zxhfr371/mcNJt2rTRqVOntHbtWvPStUOHDikrK0tt27atdDtxGpeuAQAAwC5kZ2crPj5eWVlZ+uijj/TKK69o3Lhxatmype69914NHjxYS5Ys0c6dO7Vu3TolJSVp6dKl5a4/JCRE77//vrZu3aq1a9fq3nvvlaur61nl7rnnHiUnJ+urr74q87K1M/X16dNHw4cP16pVq7Rp0ybdd999atKkifr06VOp9wD/wxkdAAAAnFNtGeBi8ODBOn78uDp37ixHR0eNGzdOI0aMkCS98847mjZtmh555BH9+eef8vX11bXXXqvbbrut3PW//fbbGjFihK6++moFBgbqueeesxmV7Yx7771Xzz77rJo2barrrrvunHW+8847GjdunG677TYVFxere/fuWrZsGQ8VvQgshlGV40FdHPn5+fL09FReXp48PDwudXNgpxh17WyMugY+f0t3Md4XRl1DTXTixAnt3LlTwcHBcnFxudTNwWXsXD+L5f0M5tI1AAAAAHaHoAMAAADA7hB0AAAAANidSg1GMHfuXL344ovKyclRx44d9corr6hz585llp89e7Zef/11ZWdny9fXV3fddZeSkpLs5trPqrq34/pR2VVTsaTm7d3PX6iSuK8DAAAAl1qFg86iRYsUHx+v5ORkRUREaPbs2YqJiVFWVpYaNWp0VvkPP/xQTzzxhFJSUtSlSxf99ttvGjp0qCwWi2bOnHlRdgIAajsGlQAA4OKq8KVrM2fO1PDhwxUbG6u2bdsqOTlZbm5uSklJKbX8mjVrdN111+mee+5RUFCQbr75Zg0aNEjr1q274MYDwD9ZLFU3AQCA2qNCZ3SKi4u1fv16TZw40Zzn4OCg6OhoZWRklLpOly5d9MEHH2jdunXq3LmzduzYoWXLlun+++8vcztFRUUqKioyX+fn51ekmQBQJW4YXTsvJwUA4HJUoaBz8OBBlZSUyM/Pz2a+n5+ffv3111LX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xscff2yW2bp1qyHJyMjIMAzDMHr16mW8/vrrhmEYxpYtWww3NzfDMAyjuLjY6Nixo/HDDz9U815cfhITE42OHTuWuoxjWHvceuutxr/+9S+beXfeeadx7733GoZhGFar1fD39zdefPFFc/mRI0cMZ2dn46OPPjIMwzBGjRplPP7444ZhGMaxY8cMScb+/fsNwzj9B+SSJUuqY1eAi4Z+qfaib7IP9E3lw6VrtUBeXp4kqUGDBpKk9evX6+TJk4qOjjbLtG7dWldeeaUyMjIkSR07dtQ333yjU6dOafny5erQoYMk6YUXXlCPHj0UHh5ezXtxedq2bZsaN26sZs2a6d5771V2drYkjmFt0qVLF6Wlpem3336TJG3atEmrVq1Sr169JEk7d+5UTk6OzbH09PRURESEzbFctWqVjh8/ruXLlysgIEC+vr5asGCBXFxcdMcdd1T/jgEXgH6pdqNvqv3om8rpUictnFtJSYlx6623Gtddd505b8GCBYaTk9NZZa+55hrjscceMwzjdGofNGiQceWVVxrdu3c3fvnlF+O3334zQkJCjIMHDxoPPvigERwcbPTv3984cuRIte3P5WTZsmXG4sWLjU2bNhmpqalGZGSkceWVVxr5+fkcw1qkpKTEePzxxw2LxWLUqVPHsFgsxnPPPWcuX716tSHJ2Lt3r816/fv3NwYMGGAYxulvOkePHm0EBQUZ4eHhxsqVK41Dhw4ZzZo1M7Kzs42nnnrKaN68uXHzzTcbf/zxR7XuH1BR9Eu1G32TfaBvKp86lzpo4dzGjBmjn3/+WatWrarQep6envrwww9t5t1www168cUXtWDBAu3YsUNZWVkaPny4pkyZwo2DVeDMtyqS1KFDB0VERKhp06ZavHixXF1dz7s+x7BmWLx4sRYsWKAPP/xQ7dq1U2ZmpsaPH6/GjRtryJAh5aqjbt26mjt3rs282NhYjR07Vhs3btRnn32mTZs26YUXXtDYsWP16aefVsWuABcF/VLtRt9kH+ibyodL12qwuLg4ff755/r22291xRVXmPP9/f1VXFysI0eO2JTPzc2Vv79/qXW988478vLyUp8+fZSenq6+ffuqbt266t+/v9LT06twL3CGl5eXWrZsqe3bt3MMa5FHH31UTzzxhO6++25dddVVuv/++/Xwww8rKSlJkszj9fdRic68LutYfvvt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MUP5+fkaO3asBgwYIH9/f0nS5MmTNXbsWHl6eqpnz54qKirSjz/+qMOHDys+Pr7MeidNmqSRI0eqUaNG6tWrl44eParVq1froYceUnR0tCIjI9W3b1+98MILatmypfbu3aulS5fqjjvuOOvSh7IEBQVp7dq12rVrl9zd3dWgQQOFhITovffe0/LlyxUcHKz3339fP/zwgzmSkCQ99NBDSkpKUosWLdS6dWu98sorOnz4sPlNaP369TVhwgQ9/PDDslqt6tq1q/Ly8rR69Wp5eHhoyJAh5WofANQ09E30Tag9GF4aNdKJEyd03333aejQoerdu7ckacSIEbr++ut1//33q6SkRHXq1NHLL7+sN954Q40bN1afPn0knR76c8iQIRo8eLDZ8ZzvGzPp9HXbK1as0G+//aZu3bqpU6dOSkhIML8NK0uLFi1055136pZbbtHNN9+sDh062AzR+cADD+itt97SO++8o6uuukpRUVGaP3++zYdzaYYMGaLZs2frtddeU7t27XTbbbdp27Ztkk6f5l+2bJm6d++u2NhYtWzZUnfffbd2795tXl9eHhMmTJCjo6Patm2rhg0bKjs7Ww8++KDuvPNODRw4UBERETp06JDNN2jS6Y530KBBGjx4sCIjI+Xu7q6YmBi5uLiYZaZOnapnnnlGSUlJatOmjXr27KmlS5eed78BoKaib6JvQu1iMf55wSiAcps0aZI+++yzy/4J2FarVW3atNGAAQM0derUS90cALis0TedRt8ELl0DUGG7d+/Wl19+qaioKBUVFenVV1/Vzp07dc8991zqpgEALlP0TfgnLl0DUGEODg6aP3++rrnmGl133XXavHmzvv766zKHOQUAoKrRN+GfuHQNAAAAgN3hjA4AAAAAu0PQAQAAAGB3CDoAAAAA7A5BBwAAAIDdIegAAAAAsDsEHQAAAAB2h6ADAAAAwO4QdAAAAADYnf8HQufcnzx5hzQAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = [0, 1, 2]\n",
    "width = 0.2\n",
    "fig, ax = plt.subplots(1, 2, figsize=(10, 5))\n",
    "ax[0].bar(x, [v_mu_p2, v_mu_p5, v_mu_p8], width, label=\"behavior\", color=\"darkorchid\")\n",
    "# ax[0].bar([xx + width for xx in x], [pdca_log_p2[\"reward_value\"][-1], pdca_log_p5[\"reward_value\"][-1], pdca_log_p8[\"reward_value\"][-1]], width, label=\"pdca\", color=\"g\")\n",
    "ax[0].bar([xx + width for xx in x], [wsac_log_p2_beta1[\"reward_value\"][-1], wsac_log_p5_beta1[\"reward_value\"][-1], wsac_log_p8_beta1[\"reward_value\"][-1]], width, label=\"wsac beta=1.0\", color=\"blue\")\n",
    "ax[0].bar([xx + width * 2 for xx in x], [wsac_log_p2_beta05[\"reward_value\"][-1], wsac_log_p5_beta05[\"reward_value\"][-1], wsac_log_p8_beta05[\"reward_value\"][-1]], width, label=\"wsac beta=0.5\", color=\"royalblue\")\n",
    "ax[0].bar([xx + width * 3 for xx in x], [wsac_log_p2_beta005[\"reward_value\"][-1], wsac_log_p5_beta005[\"reward_value\"][-1], wsac_log_p8_beta005[\"reward_value\"][-1]], width, label=\"wsac beta=0.05\", color=\"cornflowerblue\")\n",
    "ax[0].set_title(\"reward\")\n",
    "ax[0].set_xticks([xx + width * 2 for xx in x], [\"20%\", \"50%\", \"80%\"])\n",
    "# ax[0].legend()\n",
    "ax[0].set_xlabel(\"mixture percentage\")\n",
    "\n",
    "ax[1].axhline(y=0.10, color='grey', linestyle='--')\n",
    "ax[1].bar(x, [c_mu_p2, c_mu_p5, c_mu_p8], width, label=\"behavior\", color=\"darkorchid\")\n",
    "# ax[1].bar([xx + width for xx in x], [pdca_log_p2[\"cost_value\"][-1], pdca_log_p5[\"cost_value\"][-1], pdca_log_p8[\"cost_value\"][-1]], width, label=\"pdca\", color=\"g\")\n",
    "ax[1].bar([xx + width for xx in x], [wsac_log_p2_beta1[\"cost_value\"][-1], wsac_log_p5_beta1[\"cost_value\"][-1], wsac_log_p8_beta1[\"cost_value\"][-1]], width, label=\"wsac beta=1.0\", color=\"blue\")\n",
    "ax[1].bar([xx + width * 2 for xx in x], [wsac_log_p2_beta05[\"cost_value\"][-1], wsac_log_p5_beta05[\"cost_value\"][-1], wsac_log_p8_beta05[\"cost_value\"][-1]], width, label=\"wsac beta=0.5\", color=\"royalblue\")\n",
    "ax[1].bar([xx + width * 3 for xx in x], [wsac_log_p2_beta005[\"cost_value\"][-1], wsac_log_p5_beta005[\"cost_value\"][-1], wsac_log_p8_beta005[\"cost_value\"][-1]], width, label=\"wsac beta=0.05\", color=\"cornflowerblue\")\n",
    "\n",
    "ax[1].set_title(\"cost\")\n",
    "ax[1].set_xticks([xx + width * 2 for xx in x], [\"20%\", \"50%\", \"80%\"])\n",
    "ax[1].legend()\n",
    "ax[1].set_xlabel(\"mixture percentage\")\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "LPCMDP",
   "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.8.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
