{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os, json\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "from matplotlib import pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['true_reward', 'expected_reward', 'runtime', 'actions', 'seed', 'steps',\n",
       "       'exploration_coeff', 'rollout_depth'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data_path = \"./data/simulation_results/pouct_sweep/\"\n",
    "file_names = [f for f in os.listdir(data_path) if f.endswith('.json')]\n",
    "\n",
    "data = []\n",
    "for file_name in file_names:\n",
    "    with open(data_path+file_name, \"r\") as f:\n",
    "        content = json.load(f)\n",
    "    data.append(content)\n",
    "\n",
    "df = pd.DataFrame(data)\n",
    "df.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 2000x500 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes =plt.subplots(1,4, figsize=(20,5))\n",
    "axes = axes.flatten()\n",
    "\n",
    "g = sns.barplot(df[df['steps']==10], y=\"expected_reward\", x=\"exploration_coeff\", hue=\"rollout_depth\", ax=axes[0])\n",
    "g = sns.barplot(df[df['steps']==100], y=\"expected_reward\", x=\"exploration_coeff\", hue=\"rollout_depth\", ax=axes[1])\n",
    "g = sns.barplot(df[df['steps']==1000], y=\"expected_reward\", x=\"exploration_coeff\", hue=\"rollout_depth\", ax=axes[2])\n",
    "g = sns.barplot(df[df['steps']==5000], y=\"expected_reward\", x=\"exploration_coeff\", hue=\"rollout_depth\", ax=axes[3])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "steps  exploration_coeff  rollout_depth\n",
       "10     0.5                0                3.437838\n",
       "                          3                3.437308\n",
       "       1.0                0                3.437838\n",
       "                          3                3.437510\n",
       "       5.0                0                3.437838\n",
       "                          3                3.437000\n",
       "       10.0               0                3.437838\n",
       "                          3                3.435904\n",
       "       50.0               0                3.437838\n",
       "                          3                3.435360\n",
       "       100.0              0                3.437838\n",
       "                          3                3.433625\n",
       "100    0.5                0                3.650841\n",
       "                          3                3.624425\n",
       "       1.0                0                3.650841\n",
       "                          3                3.631018\n",
       "       5.0                0                3.650841\n",
       "                          3                3.630538\n",
       "       10.0               0                3.650841\n",
       "                          3                3.615472\n",
       "       50.0               0                3.650841\n",
       "                          3                3.631898\n",
       "       100.0              0                3.650841\n",
       "                          3                3.625876\n",
       "1000   0.5                0                3.675498\n",
       "                          3                3.686606\n",
       "       1.0                0                3.681398\n",
       "                          3                3.670048\n",
       "       5.0                0                3.686468\n",
       "                          3                3.674325\n",
       "       10.0               0                3.695109\n",
       "                          3                3.684620\n",
       "       50.0               0                3.682117\n",
       "                          3                3.688337\n",
       "       100.0              0                3.684054\n",
       "                          3                3.673895\n",
       "5000   0.5                0                3.694203\n",
       "                          3                3.687380\n",
       "       1.0                0                3.688449\n",
       "                          3                3.691484\n",
       "       5.0                0                3.701933\n",
       "                          3                3.689774\n",
       "       10.0               0                3.704249\n",
       "                          3                3.691121\n",
       "       50.0               0                3.683993\n",
       "                          3                3.679683\n",
       "       100.0              0                3.678904\n",
       "                          3                3.685752\n",
       "Name: expected_reward, dtype: float64"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.groupby([\"steps\", \"exploration_coeff\", \"rollout_depth\"])[\"expected_reward\"].mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "10 steps: c=0.5, depth=0 (score=3.4378383647496817)\n",
      "100 steps: c=0.5, depth=0 (score=3.6508409110380886)\n",
      "1000 steps: c=10, depth=0 (score=3.6951088300956654)\n",
      "5000 steps: c=10, depth=0 (score=3.704249016068181)\n"
     ]
    }
   ],
   "source": [
    "step_list = [10, 100, 1000, 5000]\n",
    "exploration_coeff_list = [0.5, 1, 5, 10, 50, 100]\n",
    "rollout_depth_list = [0, 3]\n",
    "\n",
    "for step in step_list:\n",
    "    max_score = df[(df[\"steps\"]==step) & (df[\"exploration_coeff\"]==exploration_coeff_list[0]) & (df[\"rollout_depth\"]==rollout_depth_list[0])][\"expected_reward\"].item()\n",
    "    best = (exploration_coeff_list[0], rollout_depth_list[0])\n",
    "    for exploration_coeff in exploration_coeff_list:\n",
    "        for rollout_depth in rollout_depth_list:\n",
    "            score = df[(df[\"steps\"]==step) & (df[\"exploration_coeff\"]==exploration_coeff) & (df[\"rollout_depth\"]==rollout_depth)][\"expected_reward\"].item()\n",
    "            if score > max_score:\n",
    "                max_score = score\n",
    "                best = (exploration_coeff, rollout_depth)\n",
    "    print(f\"{step} steps: c={best[0]}, depth={best[1]} (score={max_score})\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "jas",
   "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.10.6"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
