{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os, json\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "from matplotlib import pyplot as plt\n",
    "import math\n",
    "\n",
    "sns.set_theme()\n",
    "\n",
    "order = [\"PO-UCT: 10\", \"PO-UCT: 100\", \"PO-UCT: 1000\", \"PO-UCT: 5000\", \"Ours\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Unnamed: 0</th>\n",
       "      <th>reward</th>\n",
       "      <th>actions</th>\n",
       "      <th>seed</th>\n",
       "      <th>runtime</th>\n",
       "      <th>true_reward</th>\n",
       "      <th>expected_reward</th>\n",
       "      <th>steps</th>\n",
       "      <th>exploration_coeff</th>\n",
       "      <th>rollout_depth</th>\n",
       "      <th>type</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>3.732784</td>\n",
       "      <td>5</td>\n",
       "      <td>5000</td>\n",
       "      <td>1.707762</td>\n",
       "      <td>4.035003</td>\n",
       "      <td>3.732784</td>\n",
       "      <td>1000</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0</td>\n",
       "      <td>PO-UCT: 1000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>3.642689</td>\n",
       "      <td>5</td>\n",
       "      <td>5001</td>\n",
       "      <td>1.815193</td>\n",
       "      <td>4.204752</td>\n",
       "      <td>3.642689</td>\n",
       "      <td>1000</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0</td>\n",
       "      <td>PO-UCT: 1000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>3.707361</td>\n",
       "      <td>5</td>\n",
       "      <td>5002</td>\n",
       "      <td>1.933776</td>\n",
       "      <td>4.891583</td>\n",
       "      <td>3.707361</td>\n",
       "      <td>1000</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0</td>\n",
       "      <td>PO-UCT: 1000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>3.758194</td>\n",
       "      <td>5</td>\n",
       "      <td>5003</td>\n",
       "      <td>2.119002</td>\n",
       "      <td>5.131884</td>\n",
       "      <td>3.758194</td>\n",
       "      <td>1000</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0</td>\n",
       "      <td>PO-UCT: 1000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>3.922327</td>\n",
       "      <td>5</td>\n",
       "      <td>5004</td>\n",
       "      <td>2.121899</td>\n",
       "      <td>4.297647</td>\n",
       "      <td>3.922327</td>\n",
       "      <td>1000</td>\n",
       "      <td>10.0</td>\n",
       "      <td>0</td>\n",
       "      <td>PO-UCT: 1000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Unnamed: 0    reward  actions  seed   runtime  true_reward  \\\n",
       "0           0  3.732784        5  5000  1.707762     4.035003   \n",
       "1           1  3.642689        5  5001  1.815193     4.204752   \n",
       "2           2  3.707361        5  5002  1.933776     4.891583   \n",
       "3           3  3.758194        5  5003  2.119002     5.131884   \n",
       "4           4  3.922327        5  5004  2.121899     4.297647   \n",
       "\n",
       "   expected_reward  steps  exploration_coeff  rollout_depth          type  \n",
       "0         3.732784   1000               10.0              0  PO-UCT: 1000  \n",
       "1         3.642689   1000               10.0              0  PO-UCT: 1000  \n",
       "2         3.707361   1000               10.0              0  PO-UCT: 1000  \n",
       "3         3.758194   1000               10.0              0  PO-UCT: 1000  \n",
       "4         3.922327   1000               10.0              0  PO-UCT: 1000  "
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Load PO-UCT results\n",
    "data_path = \"./data/simulation_results/pouct_eval/\"\n",
    "file_names = [f for f in os.listdir(data_path) if f.endswith('.csv')]\n",
    "\n",
    "data = []\n",
    "for file_name in file_names:\n",
    "    data.append(pd.read_csv(data_path+file_name))\n",
    "\n",
    "\n",
    "pouct_data = pd.concat(data)\n",
    "pouct_data[\"type\"] = \"PO-UCT: \" + pouct_data[\"steps\"].astype(str)\n",
    "pouct_data.head()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Unnamed: 0</th>\n",
       "      <th>reward</th>\n",
       "      <th>actions</th>\n",
       "      <th>seed</th>\n",
       "      <th>runtime</th>\n",
       "      <th>true_reward</th>\n",
       "      <th>expected_reward</th>\n",
       "      <th>type</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>3.821586</td>\n",
       "      <td>3</td>\n",
       "      <td>5000</td>\n",
       "      <td>0.765625</td>\n",
       "      <td>4.039003</td>\n",
       "      <td>3.821586</td>\n",
       "      <td>Ours</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>3.819586</td>\n",
       "      <td>4</td>\n",
       "      <td>5001</td>\n",
       "      <td>0.890625</td>\n",
       "      <td>3.173295</td>\n",
       "      <td>3.819586</td>\n",
       "      <td>Ours</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>3.716219</td>\n",
       "      <td>5</td>\n",
       "      <td>5002</td>\n",
       "      <td>0.875000</td>\n",
       "      <td>4.638325</td>\n",
       "      <td>3.716219</td>\n",
       "      <td>Ours</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>3.821586</td>\n",
       "      <td>3</td>\n",
       "      <td>5003</td>\n",
       "      <td>0.718750</td>\n",
       "      <td>5.135884</td>\n",
       "      <td>3.821586</td>\n",
       "      <td>Ours</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>3.658340</td>\n",
       "      <td>5</td>\n",
       "      <td>5004</td>\n",
       "      <td>0.890625</td>\n",
       "      <td>4.297647</td>\n",
       "      <td>3.658340</td>\n",
       "      <td>Ours</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Unnamed: 0    reward  actions  seed   runtime  true_reward  \\\n",
       "0           0  3.821586        3  5000  0.765625     4.039003   \n",
       "1           1  3.819586        4  5001  0.890625     3.173295   \n",
       "2           2  3.716219        5  5002  0.875000     4.638325   \n",
       "3           3  3.821586        3  5003  0.718750     5.135884   \n",
       "4           4  3.658340        5  5004  0.890625     4.297647   \n",
       "\n",
       "   expected_reward  type  \n",
       "0         3.821586  Ours  \n",
       "1         3.819586  Ours  \n",
       "2         3.716219  Ours  \n",
       "3         3.821586  Ours  \n",
       "4         3.658340  Ours  "
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "project_data = pd.read_csv(\"./data/simulation_results/eval_voc.csv\")\n",
    "project_data[\"type\"] = \"Ours\"\n",
    "project_data.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "type                object\n",
       "expected_reward    float64\n",
       "true_reward        float64\n",
       "actions              int64\n",
       "runtime            float64\n",
       "seed                 int64\n",
       "dtype: object"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "merge_col = [\"type\", \"expected_reward\", \"true_reward\", \"actions\", \"runtime\", \"seed\"]\n",
    "temp1 = project_data[merge_col]\n",
    "temp2 = pouct_data[merge_col]\n",
    "\n",
    "df = pd.concat([temp1, temp2])\n",
    "df.dtypes\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 0, '')"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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D11THQAAADzmq6++Us2aNYt/Pnv2rAIDA/kiFQAAoAzlCtX69u3r7joAAADgZTVr1tR//vMfzZw5U1999ZVOnz6tN954Q2+88YYiIyM1ePBgb5cIAADgM8oVqqWlpbm7DgAAAHjZ9u3bdf/99ys8PFy9e/fW8uXLJUlVqlTR5MmTVaNGDb5sBQAA+D9XdE81AAAAXD1eeOEF3XDDDVqwYIEkadmyZZKkZ555RmfOnNGSJUsI1QAAAP6P1dsFAAAAwDdkZmYqISFBAQEBpe6jdvvtt2vv3r3eKQwAAMAHEaoBAABAklS1alWdOXOmzGUnT54s9dAqAACAyoxQDQAAAJKkLl26aObMmTpy5EjxPIvFol9//VULFizQzTff7MXqAAAAfAv3VAMAAIAkadSoURowYID++Mc/KioqShaLRc8//7z27NkjwzA0depUb5cIAADgM8oVqm3cuNHUSjt06FChYgAAAOA99evX19tvv61Fixbp66+/1rXXXqv8/HzdcccdevDBB1WnTh1vlwgAAOAzyhWqDR48uNTNai8wDEOSSizfvn27C0oDAACAp4WFhenJJ58sc9mZM2cUFBTk4YoAAAB8U7lCtSVLlhRPHzp0SOPGjdOf/vQn9erVS7Vr19bJkyf18ccf67XXXtPEiRPdViwAAADc4+eff5YkRUZGlrl83bp1+tvf/qZ///vfHqwKAADAd5UrVOvYsWPx9ODBg5WQkKCRI0eWGNO+fXsFBQVp4cKFuv32211bJQAAANwiOztbSUlJ+v777yVJbdu2VXp6usLCwiRJu3fvVmpqqjZs2KDq1at7s1QAAACfYvrpn1u2bFHnzp3LXBYdHa2dO3decVEAAADwjBdffFE//vijhgwZoieffFL79u3TlClTJEnz589X3759tWHDBvXp00f//Oc/vVwtAACA7zD99M969erp3//+d5mPVP/nP/+pa6+91iWFAQAAwP3Wr1+voUOH6rHHHpN0/vLPv/zlL6pXr55mz56tVq1aafz48WrXrp2XKwUAAPAtpkO1Bx98UCkpKTp27Jh69OihWrVq6fjx4/rnP/+pf//73zxqHQAAwI9kZ2crJiam+OcOHTooNzdX8+bN0+OPP65HH31UVqvpixsAAACueqZDtYEDB6qoqEhz587Ve++9Vzy/fv36mjJlinr16uXSAgEAAOA+586d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8YfY/zp58qRq1qxZ/HN0dLQyMzPLHOt0OvXoo4/qrrvu0u2333653bti9erV04cfflhi3rlz53Ty5EnVrVvXLdukJ5d2uZ6EhoYqODhYWVlZJcZkZWWVOt3ZDPpyaa7oy5X+vlX2HlWpUkVVqlQpMa9FixbKz89Xbm6uT/TIFzRu3Fi1a9fWhg0b9Ic//KHMMd98841q164ti8UiSSUuDygsLCw1PigoqMTPTZo00fvvv68NGzboyy+/1EcffaT09HSlpaWpb9++Ltwb4NIq++fi5XCcd54/9YTjvPP8sS8c510ZjvPKh+O8iuGeam720EMP6dNPP9X69etLLTt69KgWLVqkPn36qGbNmgoNDVXjxo2L/11Ia9u0aaM9e/YoOzu71Do2bdqkNm3aFP98zz336KefftLHH39cauw//vEPffrppx5LgTt06KAjR45o3759xfMu3MjwUtdpuxs9uXhPLBaL2rdvrw0bNpR43TfffKObbrrJrbXRlyvriyd+367WHjmdTvXo0UNz584tMf+HH37QNddco7CwML/pkbvZbDY98MADWrVqlXbt2lVq+U8//aQ1a9bovvvuK/5W97ffev/yyy+X3caSJUv0/vvvq0uXLho9erTWrl2rzp07a926da7bEcBFrtbPxfLw1c80esJxnnT19YXjvIrjOK/8OM6rGM5Uc7Pbb79d3377rR599FENHz5ct956qwIDA7V582bNmDFD9evX15///OdLrqNHjx5q0qSJhg0bpqeeekqNGzdWdna23nnnHX355ZdasmRJ8dguXbpo4MCBSk5OVlJSknr27ClJ+vjjjzV79mzde++9F72J5v86ceKEqlSpUuJ0TTPatWun9u3b68knn1RKSory8/M1fvx43XXXXV5N6+nJpXvy4IMPaujQoWrVqpVuueUWrV69Wtu3b9dzzz1XoW2WF325sr544vftau2R1WrVbbfdpldeeUVNmjRR69attX79er3yyivFN731lx55wsMPP6wffvhBgwYN0uOPP664uDhJ0hdffKGZM2eqU6dOGjp0qGw2mxo1aqSFCxeqSZMmKigoUFpaWpn3G/mt7OxszZ49W0FBQYqKitLPP/+sbdu2KT4+3hO7B5hytX4uloevfqbRE47zpKuvLxznXRrHea7DcV4FGKiQ7t27GzNnziz3+A8++MCIj483Onbs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wenTp8t9zY2//e1vatCggd58800NGzZMGzdu1H//939rwYIFeuedd5SQkKCkpCSv/8IH2FXVXhdZ55VPMPWEdd4VwdgX1nmlY53nHazzKqaavwsIZitXrtSLL74oScrPz1dubq5atmyphQsXqkmTJsrIyJDH41G9evWuOUZERIQk6fvvv/dKTZmZmddM4O2qX79+pT7/4sWLhX/5+LEaNWro8uXLlRr7WuhJ6crqyaVLlySp2DGV7Rl9KZ03+lLZ51tV79GxY8d07tw59e3bV+PGjVNqaqrmzZunrKwsTZw4MSB6FAgyMzMl/dDrklTk+2DChAmqW7euJOnll19W7dq11bRpU0VGRiohIUE33XSTWrRoUfHCgQqo6q+LZWGdd0Uw9YR1XsUEQl9Y55WOdZ53sM6rGEK1SnjggQcK727icrlUr169wm8WSYUvSufPn7/mGNnZ2ZKufHOuWLFCK1euLNzXr18/Pfnkk6pWrVphiv5THo+n8NRd6coLytUng7/VrFlTubm5xbZfvny53H91sIuelK6sntSoUUOSih1z+fJl1apVq8Lz0pfSeaMvlX2+VfUevfTSS7p8+bJCQ0MlXTl1/cKFC1q+fLnGjx8fED0KBFe/D0p760dWVpak0hdkP9agQYMi32tDhgzRrl271KNHD7Vv317du3fX3XffrQYNGlS8cKACqvrrYllY510RTD1hnecfgbCGqOo9Yp1XPqzzKoZQrRLCw8NLfK/xVTVq1FCHDh2UkpKi4cOHl3jMgQMHFBISonbt2qlt27a6++67C/ddfdKHh4cXvoj9VGZmpsLDwws/7tSpkw4dOlTisR6PR6NHj1b//v3Vt2/fsr68SouKitKuXbuKbMvNzVVmZqYaNWrkkznpSenK6km9evVUu3ZtnT59usgxp0+fLna6sx30pXTe6Etln29VvUfVq1dX9erVi2yLjo5WTk6OsrKyAqJHgaBZs2aKjIzUhx9+qF/84hclHpOSkqLIyEhZliVJRd4ekJeXV+z4mjVrFvm4efPmevfdd/Xhhx9q37592r17t1asWKGnn35aAwYM8OJXA5Suqr8uloV13hXB1BPWeVcEY19Y51UO67zyYZ1XMVxTzcceeugh7d27V/v37y+2LyMjQ2vWrNG9996r8PBw1atXT82aNSv8dzWt7dChg9LT03XmzJliY6SmpqpDhw6FHw8aNEhHjx7Vnj17ih27fft27d2717EUODY2VqdOndLXX39duO3qhQxLe5+2r9GTa/fEsix17txZH374YZHPS0lJ0W233ebT2uhL5frixPPteu2Rx+NRXFycli9fXmT73//+dzVs2FARERFB0yNfc7vdevDBB/X666/r2LFjxfYfPXpUW7du1X/+538W/lX3x3/1/uabb8qcY926dXr33XfVvXt3Pf7449q2bZtuv/12/fnPf/beFwJ4yfX6ulgegfqaRk9Y50nXX19Y51Uc67zyY51XMZyp5mN9+/bVxx9/rNGjR2vMmDG68847FRISooMHD+q5555T48aNNW3atFLHiIuLU/PmzfXII48oMTFRzZo105kzZ/TWW29p3759WrduXeGx3bt31wMPPKDHHntMY8eOVXx8vCRpz549Wrp0qf7jP/7jmhfR/Knvv/9e1atXL3K6ph0dO3ZU586d9dvf/lZJSUnKycnR7Nmz1b9/f7+m9fSk9J4MHz5cDz/8sNq2basePXpo8+bNSktL05w5cyo0Z3nRl8r1xYnn2/XaI5fLpbvuukurVq1S8+bN1a5dO+3fv1+rVq0qvOhtsPTICSNGjNDf//53JSQkaMKECbrjjjskSX/961+1aNEide3aVQ8//LDcbreaNm2ql156Sc2bN9fFixf19NNPl3i9kR87c+aMli5dqpo1a6p169b64osvdOTIEQ0bNsyJLw+w5Xp9XSyPQH1Noyes86Trry+s80rHOs97WOdVgEGF9O7d2yxatKjcx+/cudMMGzbMdOnSxdx6662mf//+ZvXq1eby5cvl+vzvv//eJCUlmd69e5t27dqZrl27mlGjRpm//e1vJR6/efNmM3jwYBMbG2s6depkBg4caDZt2mQKCgpKPD4hIcFMmTKl2Nf4023XsnnzZhMdHV1s+3fffWfGjx9vbr31VtO1a1cze/Zsc+nSpXKNaRc9KT5fRXvyxhtvmD59+pgOHTqYAQMGmA8++KBcc5aEvhSfz1d9qejzjR4Zk5eXZ5YtW2bi4+NNu3btzF133WX+9Kc/FTnGnz0KNB6Px7z++utm8ODB5rbbbjOdO3c2gwcPNq+99prxeDyFx3388cfmV7/6lWnXrp3p06eP2bZtm7nzzjvN5s2bjTHGLFq0yPTu3bvI2Lm5uea//uu/TM+ePU27du1Mr169zMKFC01+fr6jXyOqNl4Xi8/HOu/66QnrvODsC+u8K1jn+R7rPHssY8p5L1QAAAAAAAAAkrimGgAAAAAAAGAboRoAAAAAAABgE6EaAAAAAAAAYBOhGgAAAAAAAGAToRoAAAAAAABgE6EaAAAAAAAAYBOhGgAAAAAAAGAToRoAAAAAAABgE6EaAAAAAAAAYBOhGgAAAAAAAGAToRoAAAAAAABg0/8Hhl5Tc3jj1mEAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1500x1000 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "order = [\"PO-UCT: 10\", \"PO-UCT: 100\", \"PO-UCT: 1000\", \"PO-UCT: 5000\", \"Ours\"]\n",
    "\n",
    "fig, axes =plt.subplots(2,2, figsize=(15,10))\n",
    "axes = axes.flatten()\n",
    "\n",
    "g = sns.barplot(df, y=\"expected_reward\", x=\"type\", ax=axes[0], order=order)\n",
    "g.set_ylim((3.3, 3.8))\n",
    "g.set_ylabel(\"Expected Reward\")\n",
    "g.set_xlabel(\"\")\n",
    "g = sns.barplot(df, y=\"true_reward\", x=\"type\", ax=axes[1], order=order)\n",
    "g.set_ylim((3.3, 4))\n",
    "g.set_ylabel(\"True Reward\")\n",
    "g.set_xlabel(\"\")\n",
    "g = sns.barplot(df, y=\"actions\", x=\"type\", ax=axes[2], order=order)\n",
    "g.set_ylabel(\"Number of actions\")\n",
    "g.set_xlabel(\"\")\n",
    "g = sns.barplot(df, y=\"runtime\", x=\"type\", ax=axes[3], order=order)\n",
    "g.set_ylabel(\"Runtime\")\n",
    "g.set_xlabel(\"\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "#df.to_csv(\"./data/simulation_results/simulation_data.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.read_csv(\"./data/simulation_results/simulation_data.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['Unnamed: 0', 'type', 'expected_reward', 'true_reward', 'actions',\n",
       "       'runtime'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mean    0.61283\n",
      "std     1.00000\n",
      "Name: normalized_reward, dtype: float64\n"
     ]
    }
   ],
   "source": [
    "baseline_df = pd.read_csv(\"./data/simulation_results/random_baseline.csv\")\n",
    "mean = baseline_df[\"reward\"].mean()\n",
    "std = df[\"expected_reward\"].std()\n",
    "df[\"normalized_reward\"] = (df[\"expected_reward\"] - mean) / std\n",
    "print(df[\"normalized_reward\"].agg([\"mean\", \"std\"]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Z-scored expected reward')"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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q1f1+hw9elT0799f+Pv7ixdffFEcOnSoSncTHTt2TLz55psiICBAtGvXTrz99tsiOTlZCHHvlvTg4GAxZMgQvXW++OILoVKpxPbt24UQ9+4mmzNnjhgzZowICAgQERERYvHixXp3eAkhxHfffSf69u0rWrduLUJDQ8WIESNEWlqaXp/U1FQRFRUlAgICRPv27UVsbKzeXWDx8fGiTZs2Ijg4WJSUlDx0H8r9/fffYvjw4aJNmzaiQ4cOYu3ateLVV1+t0t1k6enpBsuqsi83btwQ3t7eYtCgQbq23Nxc4e3tLQYOHKjXNyMjQwwfPly0a9dOtGvXTvTv31988803YvDgwaJ///5CiP/dTXb8+HGDeqo7/0S1QSYE/6IgET3avL29MWrUKIwePdrSpRCRFeI1Q0RERCRpDENEREQkaTxNRkRERJLGI0NEREQkaQxDREREJGkMQ0RERCRpDENEREQkaXwCdRUJIaDV8lpzIiKiukIul0Emkz20H8NQFWm1Ajk5dy1dBhEREVWRm1t9KBQPD0M8TUZERESSxjBEREREksYwRERERJLGMERERESSxjBEREREksYwRERERJLGMERERESSxjBEREREksYwRERERJLGMERERESSxjBEREREksYwRERERJLGMERERESSxr9aT0RERDrXrl3FunUrAQDvvDMUjz/e1MIVmV+dOzK0ZMkSvPXWW5X2yc3NxYQJExASEoKQkBBMmzYNhYWFtVQhERFR3bV+/WqcOXMaZ86cxoYNqy1dTq2oU2Fo3bp1SEhIeGi/mJgYpKen6/ofPXoUM2fOrIUKiYiI6rarV9N1rzMy0ivp+eioE6fJsrKy8MEHHyAlJQUtW7astG9qaipOnDiBvXv3wsvLCwAwa9YsDBkyBOPHj4e7u3ttlExERER1RJ04MnT27Fk4Ozvj22+/RWBgYKV9T548iUaNGumCEACEhoZCJpMhJSXF3KUSERFRHVMnjgx16dIFXbp0qVLfrKwsNGnSRK9NqVTCxcUFmZmZNarDxqZOZEciIqJqk8lkeq+l8LuvToQhYxQVFUGpVBq029nZoaSkpNrblctlcHWtX5PSiIiIrJ5cLtN7LYXffY9cGLK3t4darTZoLykpQb169aq9Xa1WoKCAd6QREZFpyGQyODWwh1zx6B95MQetRouC28UQQjywj5OTAxRVGN9H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PvsMycnJOH36dIXr7Nq1C40bN8b777+PJ598EsHBwZgxYwaSkpKQnp5euztAREREVs+qw1BKSgoAICwsTNfWsmVLuLu7Izk5ucJ1evfujblz50Imkxks46kyIiIi+icbSxdQmaysLLi6usLOzk6vvXHjxsjMzKxwHS8vL4O2lStXolGjRvDx8TFLnURERFR3WTQMZWRkoGvXrg9cPmbMGCiVSoN2Ozs7lJSUVOk9Pv74Yxw+fBgJCQmwtbWtdq0AYGNT+YE0hcKqD7TVCRxDIiKqbRYNQ+7u7ti7d+8Dlx8+fBhqtdqgvaSkBA4ODpVuu7S0FNOnT8fOnTsxY8YMPP/88zWqVS6XwdW1fo22QQ/n5FT5vBIREZmaRcOQra1thae1yl24cAF5eXlQq9V6R4iys7Ph4eHxwPXu3LmDUaNG4eTJk/j000/Rs2fPGteq1QoUFBRW2kehkPOXeQ0VFBRBo9FaugwiInoEODk5VOmMg1VfM9SuXTtotVqkpKSgffv2AIC//voLWVlZCA4OrnAdtVqN4cOHIy0tDatWrUJ4eLjJ6ikr4y9pc9NotBxnIiKqVVZ9gYa7uzt69uyJqVOnIikpCWfOnMGECRMQGhqKNm3aALgXfm7cuKE7nbZ8+XKkpKRg1qxZ8PLywo0bN3T/KjrlRkRERNJm1WEIAD788EO0b98eo0aNwuDBg/Hkk08iISFBtzw1NRUdO3ZEamoqAGDPnj0QQmD8+PHo2LGj3r/yPkRERETlZEIIYeki6gKNRoucnLuV9rGxkcPVtT7eX7gXl6/m1lJlj4YWTV0xZ0wP5Obe5WkyIiIyCTe3+lW6ZsjqjwwRERERmRPDEBEREUkawxARERFJGsMQERERSRrDEBEREUkawxARERFJGsMQERERSRrDEBEREUkawxARERFJGsMQERERSRrDEBEREUkawxARERFJGsMQERERSRrDEBEREUkawxARERFJGsMQERERSRrDEBEREUkawxARERFJGsMQERERSRrDEBEREUkawxARERFJGsMQERERSRrDEBEREUkawxARERFJGsMQERERSRrDEBEREUkawxARERFJGsMQERERSRrDEBEREUkawxARERFJGsMQERERSRrDEBEREUkawxARERFJGsMQERERSZrVh6GSkhLMnDkT7du3R1BQEGJiYnDr1q0qr7906VJ4e3ubsUIiIiKqy6w+DMXFxeHo0aNYtGgR1q9fj/T0dIwZM6ZK6545cwaJiYlmrpCIiIjqMqsOQ1lZWdi1axemTp2K4OBgBAQE4LPPPkNycjJOnz5d6bqFhYWYOHEigoODa6dYIiIiqpOsOgylpKQAAMLCwnRtLVu2hLu7O5KTkytd96OPPoJKpcLLL79s1hqJiIiobrPqMJSVlQVXV1fY2dnptTdu3BiZmZkPXG///v04fPgwZs2aZe4SiYiIqI6zseSbZ2RkoGvXrg9cPmbMGCiVSoN2Ozs7lJSUVLhOVlYWpk2bhk8++QSurq4mqxUAbGwqz44KhVVnyzqBY0hERLXNomHI3d0de/fufeDyw4cPQ61WG7SXlJTAwcHBoF0IgdjYWLz44ovo3LmzSWuVy2Vwda1v0m2SIScnw3klIiIyJ4uGIVtbW3h5eT1w+YULF5CXlwe1Wq13hCg7OxseHh4G/a9du4Zjx47h1KlT2LVrFwCgrKwMABAUFIThw4djxIgR1apVqxUoKCistI9CIecv8xoqKCiCRqO1dBlERPQIcHJyqNIZB4uGoYdp164dtFotUlJS0L59ewDAX3/9haysrArvEnN3d8e+ffv02vbt24f58+dj165dcHZ2rlE9ZWX8JW1uGo2W40xERLXKqsOQu7s7evbsialTp2LOnDlwcHDAjBkzEBoaijZt2gAA1Go18vPz4ezsDKVSCU9PT71tNGzYEAAM2qWkrDgft9OPAwAaNA+HjX3NQiEREdGjxOqvVv3www/Rvn17jBo1CoMHD8aTTz6JhIQE3fLU1FR07NgRqampFqzSut1OPw51wVWoC67idnqSpcshIiKyKjIhhLB0EXWBRqNFTs7dSvvY2Mjh6lof7y/ci8tXc2upsoe78etX0KrvAADkSkc08n/NwhUZatHUFXPG9EBu7l2eJiMiIpNwc6tf968ZqquaNrau01C55+QovyfPRiFHi6amfeSAKVjbmBERkXTwyFAVVeXIkFwug4tLPat7Vs6bb76JrKwsAPeuw9q8ebOFK6qYRqNFXl4htFp+SxIRUc3xyJAFaLUCeXmFkMtlli5Fz/3hQqsVyM2tPNRZilYrGISIiKjWMQyZmDX+Qr//4J8QgtfkEBER3ce6zueQWTRt2lz3ulmz5pX0JCIikh4eGZKA6OjBWLfu3tGgt98ebOFqiIiIrAsvoK6iqlxATURERNajqhdQ8zQZERERSRrDEBEREUkawxARERFJGsMQERERSRrDEBEREUkawxARERFJGsMQERERSRrDEBEREUkawxARERFJGsMQERERSRrDEBEREUkawxARERFJGsMQERERSRr/an0VCSGg1XKoiIiI6gq5XAaZTPbQfgxDREREJGk8TUZERESSxjBEREREksYwRERERJLGMERERESSxjBEREREksYwRERERJLGMERERESSxjBEREREksYwRERERJLGMERERESSxjBEREREksYwRERERJLGMGRCXbp0gbe3t+5fq1atEBwcjLfeegsnT5406P/dd98hKioK7dq1Q1BQEPr164f169ejtLT0oe8VGxuLt956q8JlX3/9Nby9vQ3aDx48iMGDByM8PBxBQUHo27cvtmzZAq1Wq7deZf+SkpKqPB7Jyclo1aqVQXtubi4mTJiAkJAQhISEYNq0aSgsLKzydivCsddXk7H//vvv0aNHD/j7+6NXr1748ccfK30vjr0+c479w7bBuah4HLy9vfHee+9VeRyBms+FNdFoNNi8eTNeeeUVBAUFITg4GK+//jp27twJ/q32/yPIZCIjI8XHH38ssrOzRXZ2tsjKyhIXLlwQw4cPF4GBgSIzM1PXd+rUqaJNmzZi+fLl4o8//hCXLl0S27ZtE507dxYDBgwQd+7cqfS9Jk+eLKKioipctmPHDqFSqfTa5s6dKwICAsTSpUvF+fPnxaVLl8SmTZtEYGCgeP/994UQQhQVFelqz87OFgMGDBBjxozRayspKanSWBw/flwEBwcb1CGEEFFRUeLVV18Vv/32mzh27JiIjIwUkyZNqtJ2H4Rj/z81Gfuff/5Z+Pn5iY0bN4qLFy+Kjz/+WLRu3VpcvHjxge/Hsf8fc4/9w7bBuRDi9u3bwtvbW/zwww966xUUFNTqXFiL0tJSMXToUBEeHi42bdokLl26JC5evCjWr18vgoODxciRI0VZWZmly7Q4hiETioyMFAkJCQbt169fFyqVSqxfv14IIcTOnTtFq1atREpKSoV9Q0NDxfTp0yt9L2N+EB0+fFioVCpx8OBBg767du0SKpVKnDx50mBZVFSUmDx5cqV1/FNpaan48MMPha+vr+jbt6/BD8RTp04JlUql90Plp59+Et7e3uL69etGvdf9OPamGftBgwaJ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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "g = sns.barplot(df, y=\"normalized_reward\", x=\"type\", order=order)\n",
    "g.set_ylabel(\"Normalized Reward\")\n",
    "g.set_xlabel(\"\")\n",
    "g.set_title(\"Z-scored expected reward\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr:last-of-type th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th colspan=\"2\" halign=\"left\">expected_reward</th>\n",
       "      <th colspan=\"2\" halign=\"left\">normalized_reward</th>\n",
       "      <th colspan=\"2\" halign=\"left\">runtime</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>type</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Ours</th>\n",
       "      <td>3.7037</td>\n",
       "      <td>0.1550</td>\n",
       "      <td>0.9942</td>\n",
       "      <td>0.8433</td>\n",
       "      <td>0.9079</td>\n",
       "      <td>0.1886</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PO-UCT: 10</th>\n",
       "      <td>3.4411</td>\n",
       "      <td>0.0703</td>\n",
       "      <td>-0.4344</td>\n",
       "      <td>0.3823</td>\n",
       "      <td>0.0175</td>\n",
       "      <td>0.0135</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PO-UCT: 100</th>\n",
       "      <td>3.6553</td>\n",
       "      <td>0.2001</td>\n",
       "      <td>0.7309</td>\n",
       "      <td>1.0891</td>\n",
       "      <td>0.1972</td>\n",
       "      <td>0.0285</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PO-UCT: 1000</th>\n",
       "      <td>3.6805</td>\n",
       "      <td>0.1697</td>\n",
       "      <td>0.8681</td>\n",
       "      <td>0.9233</td>\n",
       "      <td>2.3567</td>\n",
       "      <td>0.1013</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PO-UCT: 5000</th>\n",
       "      <td>3.6873</td>\n",
       "      <td>0.1535</td>\n",
       "      <td>0.9054</td>\n",
       "      <td>0.8354</td>\n",
       "      <td>10.8913</td>\n",
       "      <td>0.6240</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "             expected_reward         normalized_reward          runtime  \\\n",
       "                        mean     std              mean     std     mean   \n",
       "type                                                                      \n",
       "Ours                  3.7037  0.1550            0.9942  0.8433   0.9079   \n",
       "PO-UCT: 10            3.4411  0.0703           -0.4344  0.3823   0.0175   \n",
       "PO-UCT: 100           3.6553  0.2001            0.7309  1.0891   0.1972   \n",
       "PO-UCT: 1000          3.6805  0.1697            0.8681  0.9233   2.3567   \n",
       "PO-UCT: 5000          3.6873  0.1535            0.9054  0.8354  10.8913   \n",
       "\n",
       "                      \n",
       "                 std  \n",
       "type                  \n",
       "Ours          0.1886  \n",
       "PO-UCT: 10    0.0135  \n",
       "PO-UCT: 100   0.0285  \n",
       "PO-UCT: 1000  0.1013  \n",
       "PO-UCT: 5000  0.6240  "
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.groupby(\"type\").agg([\"mean\", \"std\"])[[\"expected_reward\", \"normalized_reward\", \"runtime\"]].round(4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>count</th>\n",
       "      <th>std</th>\n",
       "      <th>ci95</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>type</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Ours</th>\n",
       "      <td>0.9942</td>\n",
       "      <td>5000</td>\n",
       "      <td>0.8433</td>\n",
       "      <td>0.0234</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PO-UCT: 10</th>\n",
       "      <td>-0.4344</td>\n",
       "      <td>5000</td>\n",
       "      <td>0.3823</td>\n",
       "      <td>0.0106</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PO-UCT: 100</th>\n",
       "      <td>0.7309</td>\n",
       "      <td>5000</td>\n",
       "      <td>1.0891</td>\n",
       "      <td>0.0302</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PO-UCT: 1000</th>\n",
       "      <td>0.8681</td>\n",
       "      <td>5000</td>\n",
       "      <td>0.9233</td>\n",
       "      <td>0.0256</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PO-UCT: 5000</th>\n",
       "      <td>0.9054</td>\n",
       "      <td>5000</td>\n",
       "      <td>0.8354</td>\n",
       "      <td>0.0232</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                mean  count     std    ci95\n",
       "type                                       \n",
       "Ours          0.9942   5000  0.8433  0.0234\n",
       "PO-UCT: 10   -0.4344   5000  0.3823  0.0106\n",
       "PO-UCT: 100   0.7309   5000  1.0891  0.0302\n",
       "PO-UCT: 1000  0.8681   5000  0.9233  0.0256\n",
       "PO-UCT: 5000  0.9054   5000  0.8354  0.0232"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "def ci(column):\n",
    "    stats = df.groupby(\"type\").agg([\"mean\", \"count\", \"std\"])[column]\n",
    "    ci95 = []\n",
    "\n",
    "    for i in stats.index:\n",
    "        m, c, s = stats.loc[i]\n",
    "        ci95.append(1.96*s/math.sqrt(c))\n",
    "    \n",
    "    stats['ci95'] = ci95\n",
    "    return stats.round(4)\n",
    "\n",
    "ci(\"normalized_reward\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>count</th>\n",
       "      <th>std</th>\n",
       "      <th>ci95</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>type</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Ours</th>\n",
       "      <td>0.9079</td>\n",
       "      <td>5000</td>\n",
       "      <td>0.1886</td>\n",
       "      <td>0.0052</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PO-UCT: 10</th>\n",
       "      <td>0.0175</td>\n",
       "      <td>5000</td>\n",
       "      <td>0.0135</td>\n",
       "      <td>0.0004</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PO-UCT: 100</th>\n",
       "      <td>0.1972</td>\n",
       "      <td>5000</td>\n",
       "      <td>0.0285</td>\n",
       "      <td>0.0008</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PO-UCT: 1000</th>\n",
       "      <td>2.3567</td>\n",
       "      <td>5000</td>\n",
       "      <td>0.1013</td>\n",
       "      <td>0.0028</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PO-UCT: 5000</th>\n",
       "      <td>10.8913</td>\n",
       "      <td>5000</td>\n",
       "      <td>0.6240</td>\n",
       "      <td>0.0173</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                 mean  count     std    ci95\n",
       "type                                        \n",
       "Ours           0.9079   5000  0.1886  0.0052\n",
       "PO-UCT: 10     0.0175   5000  0.0135  0.0004\n",
       "PO-UCT: 100    0.1972   5000  0.0285  0.0008\n",
       "PO-UCT: 1000   2.3567   5000  0.1013  0.0028\n",
       "PO-UCT: 5000  10.8913   5000  0.6240  0.0173"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ci(\"runtime\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cohen's d between ours and 10 step: 2.181971302312702\n",
      "Cohen's d between ours and 100 step: 0.27028310530293115\n",
      "Cohen's d between ours and 1000 step: 0.14255795034112073\n",
      "Cohen's d between ours and 5000 step: 0.10575920004576697\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "def cohend(d1, d2):\n",
    "    # https://machinelearningmastery.com/effect-size-measures-in-python/\n",
    "    n1, n2 = len(d1), len(d2)\n",
    "    s1, s2 = np.var(d1, ddof=1), np.var(d2, ddof=1)\n",
    "    s = np.sqrt(((n1 - 1) * s1 + (n2 - 1) * s2) / (n1 + n2 - 2))\n",
    "    u1, u2 = np.mean(d1), np.mean(d2)\n",
    "    return (u1 - u2) / s\n",
    "\n",
    "ours = df[df[\"type\"]==\"Ours\"][\"expected_reward\"]\n",
    "po_10 = df[df[\"type\"]==\"PO-UCT: 10\"][\"expected_reward\"]\n",
    "po_100 = df[df[\"type\"]==\"PO-UCT: 100\"][\"expected_reward\"]\n",
    "po_1000 = df[df[\"type\"]==\"PO-UCT: 1000\"][\"expected_reward\"]\n",
    "po_5000 = df[df[\"type\"]==\"PO-UCT: 5000\"][\"expected_reward\"]\n",
    "\n",
    "print(\"Cohen's d between ours and 10 step:\", cohend(ours, po_10))\n",
    "print(\"Cohen's d between ours and 100 step:\", cohend(ours, po_100))\n",
    "print(\"Cohen's d between ours and 1000 step:\", cohend(ours, po_1000))\n",
    "print(\"Cohen's d between ours and 5000 step:\", cohend(ours, po_5000))"
   ]
  },
  {
   "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
}
