{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "d0974be6",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import os\n",
    "import pandas as pd\n",
    "\n",
    "plt.rcParams[\"font.family\"] = \"Times New Roman\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "4287a007",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_values(method, reward, metric, test_set):\n",
    "    \"\"\"\n",
    "    Parameters:\n",
    "    method: str, one of 'A2C', 'PPO'\n",
    "    reward: stf, one of 'Default', 'DREST'\n",
    "    metric: str, one of 'usefulness', 'neutrality', 'weighted_av'\n",
    "    test_set: bool, True: test set, False: train set\n",
    "    \"\"\"\n",
    "\n",
    "    train_or_test = 'test' if test_set else 'train'\n",
    "    path = f\"./data/metrics_overtime/{method}/{reward}/{train_or_test}_{metric}\"\n",
    "\n",
    "    values = []\n",
    "    for run_file in os.listdir(path):\n",
    "        df = pd.read_csv(f'{path}/{run_file}')\n",
    "        steps = df[\"custom_step\"] # These are the \"t\" values\n",
    "        metric_values = df[df.columns[-1]]\n",
    "        metric_values = np.nan_to_num(metric_values)\n",
    "        values.append(float(metric_values[-1]))\n",
    "\n",
    "    return float(np.mean(values)), float(np.std(values))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "644b7bec",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "PPO DREST: Train Usefulness: 0.8860 ± 0.0029, Test Usefulness: 0.7419 ± 0.0037\n",
      "A2C DREST: Train Usefulness: 0.9212 ± 0.0055, Test Usefulness: 0.7419 ± 0.0060\n",
      "PPO Default: Train Usefulness: 0.9470 ± 0.0184, Test Usefulness: 0.6671 ± 0.0164\n",
      "A2C Default: Train Usefulness: 0.9113 ± 0.0195, Test Usefulness: 0.6348 ± 0.0135\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Test Usefulness')"
      ]
     },
     "execution_count": 39,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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T7aaNWtarVo5c+EsACAPtjhvvfVWGzRokG3ZssVmzJhhZcqUserVq9vkyZN9vU7Hjh2tSZMmNnjwYKtTp4717t07zfNWrlxp7dq1szvvvNO9N6EJAMhRwZmYmGj9+/d3rcMOHTpY165dbc2aNbZ8+fKIX2PdunU2depUu+qqq9xjfR09erTt2rUrxXn79++3f/7zn/bMM8/YCSfk3HU/AIA8HJyXX36565pV12qpUqVs4MCB7vimTZsifo158+a5lmqge7ds2bIuiBcuXJjivJdeesmdM2XKFNc61Xt6npfu6ypoFeyhNwAAsjU4NSZ5/fXX24gRI9y44+7du+2pp56yMWPGRPwaa9eutdKlS6c4Vrx4cdcSDaXu38suu8z69u3rWqSPPfaYC9P0qNtX1xe4VaqUcxfZAgBySXC2b9/e3njjDVu/fr1deumlVrBgQbvpppvs559/jvg10ppMdODAAfdaoZYuXereQ+dXq1bNWrZsaRMmTEj3dTVOunPnzuBt9erVmfgJAQCI4qzaX375xX2tWLGimw07fPhw133avXv3iF+jQoUKLthCqeWq46GSk5Pt4MGDwceaGPTf//433ddVd296M3MBAMiWFudFF11kX3/9teXPn9/atGljr7/+uhujDIx1RqJRo0ZuQpFamRLooq1Xr16K8xSUv/76a/BxgQIF7Oyzz87MZQMAkD3Bef/991vr1q1t0aJFNmvWLJs2bZp16dIlVWsxI+XLl7dmzZrZ/Pnz3eM5c+ZYp06dXGuxT58+rhtYunXrZm+99Vbw+7744gt74IEHMnPZAAActTgvoymq6VDL8tprr3XrKv/xj3/YCy+84LpZNYlHYRoprQPt1auXValSxbZt22ZDhgxx3bI1atRwk4Lq16/vztNM2g0bNrhWrSYU3X333RG/h2bVapKQuoVLlizp90cFAOQCiVHMgkwFp7pVn332WTcLtmfPni7UNKNWx1999VWLJQQnACAxu4NT9u7daxs3brSqVau6sUpthReLCE4AQGIUsyBTY5zvv/++m1HbuXPn4IQdjU/+9NNPR3UxAADEukwFp/apHTdunDVo0MA9LleunFtfedttt0X7+gAAyPnBqa3vmjdv7sY4A5YsWeJrr1oAAPLMBgglSpSwBQsW2KFDh9w4p5aLaMcerekEACA3y9TkIO3mM3ToULf1nba0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/v3Bc5OSkrwOHTp4pUqV8i644AJvyZIl7vi8efO8ChUqeOedd573ySefeMnJyd6VV17pnXjiid4TTzzh3X333e5aNm/e7J674oorvHLlynnjx49379OpUydvzZo13rhx49zPMmDAAPde3333nXuNjh07ZvrPOppZEKf/WC6m3TDi4+Pd+qf0ZpcByL327dvnJs5UrVo1op1v0qV1moElJ5o8lAVjmsi6P+toZgGTgwAgEgrKgSk3IEDexBgnAAA+EJwAAPhAcAIA4APBCSBPyOXzIGHH7s+Y4ASQq+XPn9991TpH5G57/9oY4kilz44Ws2oB5Grar1Vbzmlxvf5BPdqSV4jNlqZCc9OmTW6Lv8AvS1mF4ASQq2kzcW0Rp/V9KmeF3KtUqVJWrly5LH8fghNArqct27TpOd21uVfBggWzvKUZQHACyBPURXtUOwcBsRCce/bssR49erhtkHR/2LBhVrhw6g2Vx44daz/99JPb5Pf++++38847L1uuFwCAbB0l79ixozVp0sQGDx7sSs707t071TmffPKJvffee/bUU0/Zc889Z23atHEhCwBAngrOdevWucrgV111lXusr6NHj3YlbEKpFXr99de7+yVKlLBTTjnF1aMDACBPddXOmzfPypQpExxzKFu2rOumVfHWyy+/3B1TkdP58+e77tyA008/3R2766670nzd/fv3u1uAdsIP7IwPAMibEv/KgGhskpBtwbl27VorXbp0imPFixd3LdEAFSxVmZjQ83TODz/8kO7rqttXRVXDVapUKWrXDgDImVRUW/NqcmRwam1V+Aw3TRUP3fFB50joeeHnhNM4qSqeB+zYscN17/7xxx9H/WHlpd/M9IuGKrJTwzRyfG7+8ZllDp+bf+p9rFy5cqoGW44KzgoVKgS7UQN2797tjgeccMIJrvs29DyNgYaeE07npzUzV6HJXzB/9HnxmfnH5+Yfn1nm8Ln5F42do7JtclCjRo1szZo1wQXJgS7aevXqpWhx6rxff/01eOy3335zxwAAyA7ZFpzaAqtZs2Zuoo/MmTPHOnXq5FqLffr0sfXr17vjnTt3tg8//DDYPaGx0ZYtW2bXZQMA8rhs3QBBy0969eplX331lZsINGTIEDcZSMtNtARF4XrttdfakiVL7JFHHnHn6Dk/u38oiAcMGJBm9y3SxmeWOXxu/vGZZQ6f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",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(5,5))\n",
    "\n",
    "for i, reward in enumerate(['DREST', 'Default']):\n",
    "    # PPO\n",
    "    method = 'PPO'\n",
    "    train_mean, train_std = get_values(method, reward, 'usefulness', False)\n",
    "    test_mean , test_std  = get_values(method, reward, 'usefulness', True )\n",
    "    plt.errorbar(train_mean, test_mean, xerr=train_std, yerr=test_std, fmt='o', label=f'{method} {reward}', color=f'C{i}')\n",
    "    print(f'{method} {reward}: Train Usefulness: {train_mean:0.4f} ± {train_std:0.4f}, Test Usefulness: {test_mean:0.4f} ± {test_std:0.4f}')\n",
    "\n",
    "    # A2C\n",
    "    method = 'A2C'\n",
    "    train_mean, train_std = get_values(method, reward, 'usefulness', False)\n",
    "    test_mean , test_std  = get_values(method, reward, 'usefulness', True )\n",
    "    plt.errorbar(train_mean, test_mean, xerr=train_std, yerr=test_std, fmt='s', label=f'{method} {reward}', color=f'C{i}')\n",
    "    print(f'{method} {reward}: Train Usefulness: {train_mean:0.4f} ± {train_std:0.4f}, Test Usefulness: {test_mean:0.4f} ± {test_std:0.4f}')\n",
    "\n",
    "plt.legend(loc='lower right')\n",
    "plt.axis([0, 1, 0, 1])\n",
    "plt.xlabel('Train Usefulness')\n",
    "plt.ylabel('Test Usefulness')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "95e46816",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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f3Xt2lW1a9d2rOcRBQAAoCq5HGSMMTLGqKSkRCUlJapZs6bTclFRkV577TV31goAAODE5SDz0ksvqVatWvLx8ZGPj48WL17stOzr66unn37anbUCAAA4cXmy7+DBgzVmzBjVrFmzzO1FRUVasWJFZdUFAABwUS4Hmb/97W8XfXBkkyZNLrsgAAAAV7l8aamoqEhJSUll3kfmu+++09y5c3X48OFKLQ4AAOBCXB6RGTBggN5//335+Pjo3XffVU5Ojnx8fNSlSxfdcMMNCg0N1S233EKYAQAAVaZCQebmm2+WdO6eMl27dtXHH3+sq6++WpJUv3593X333e6pEgAAoAwuX1r6/f1ifH191bNnT0eI+f16AACAquJykPmjsr69ZIy5rGIAAAAqwuVLS5s2bdLJkycdy998842OHTvmWDbG6LPPPtOCBQsqt0IAAIByuBxk8vPzZYxRrVrndrnllluctpeUlDhdfgIAAHA3l4PMokWL1K9fvwu2Wb9+/WUXBAAA4CqX58hcLMRI577NBAAAUFVcDjIrV67UypUrtWrVKv3000+SpL1796pdu3by9/fXwIED9dtvv7mrTgAAgFJcDjIPP/ywvvjiC911111q3ry5MjIy1LNnT506dUpLlixRp06dNGXKFDeWCgAA4MzlOTJt27bV0qVLHcszZsxQZmamtm3bphtuuEGSNGrUqMqvEAAAoBwuj8h07NjR8XrXrl1asWKF/vKXvzhCjKQyn8MEAADgLi6PyPz666/at2+f6tSpo2HDhumaa67RU0895dielpamjz76yC1FAgAAlMXlEZlnnnlGDzzwgFq0aCGbzaaNGzfK399fR48e1XPPPafOnTsrMzOzQifPzc3VxIkTFR0drUmTJqmgoOCC7efNm6eHH364QucAAADey+Ugc/z4cR04cEAnTpzQDz/8oOuvv16SdM011+jRRx/VwYMHdebMmQqdfMKECerVq5diY2PVoUMHRUdHl9s2KSlJS5YsqdDxAQCAd3P50tLEiRP1wAMPOO7sK0k2m0116tTRtddeqz59+qhu3bounzgtLU1r1651hJPIyEiNHz9eMTExqlevnlPbwsJCLV26VMOGDdPPP//s8jkAAIB3cznI9O3bVyNGjHAKMtK5y0M//fSThg4dqvnz56tly5YuHW/79u0KDg52PDG7YcOGstvtSkxMVM+ePZ3aPvfcc5o2bZpWrFhx0eMWFBQ4XaLKyspyqR4AAGA9LgeZyZMnq2nTpmVuu/7669WlSxc9+uijeuutt1w6XmpqqoKCgpzW+fv7Ky0tzWnd//7v/6pJkyZq1qyZS8eNjY1VTEyMS20BAIC1uTxHprwQc15QUJBq1qzp8oltNptjNOa8wsJC+fj4OJZzc3P1wQcf6KGHHnL5uNHR0crMzHT8pKSkuLwvAACwFpdHZFxRkfvIhIaGlvqWU05OjkJDQx3L7733nuLi4rR8+XJJ0pkzZ1RSUqKkpCTt3r27zOPa7XbZ7fZLqB4AAFiNyyMyF3uy9c6dO5Wenu7yiSMiInTs2DEVFhZKkuOSUqdOnRxt7r//fu3fv1/ffPONvvnmG40fP15RUVH6+OOPXT4PAADwXhX61tI777xTarJvXl6eUlNTtXfvXn344YcunzgkJER9+/ZVQkKCevXqpc2bN2vixImy2+2aOXOmHn30UYWEhKhOnTqOfQICAlSnTh01btzY5fMAAADv5XKQsdlsqlGjhtM8GJvNpqCgIN10001atWqVmjdvXqGTx8XFacaMGdq1a5dOnTqlefPmKT8/X/Hx8YqKilJISEiFjgcAAK4sLgeZ1157TQMGDKjUkwcHB2vZsmWl1icnJ5fZfs6cOZV6fgAAYG0uz5Gp7BADAABwuVwOMgAAANUNQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFgWQQYAAFiWR4NMbm6uJk6cqOjoaE2aNEkFBQWl2pw4cUL9+vVTvXr11K1bN/3www8eqBQAAFRHHg0yEyZMUK9evRQbG6sOHTooOjq6VJt58+ZpzJgx2rJli4qLi3X//fd7oFIAAFAdeSzIpKWlae3atYqMjJQkRUZGKi4uTtnZ2Y42xhj9+c9/1r333qtbb71Vy5cv13fffaeMjAxPlQ0AAKoRjwWZ7du3Kzg4WL6+vpKkhg0bym63KzEx0dHGZrPpzjvvdCyHhYXJ399fV111VbnHLSgoUFZWltMPAADwTh4LMqmpqQoKCnJa5+/vr7S0tHL32bVrlx555BH5+PiU2yY2NlaBgYGOn/Dw8EqrGQAAVC8eCzI2m80xGnNeYWHhBUPK6tWr9be//e2Cx42OjlZmZqbjJyUlpVLqBQAA1U8tT504NDRUmZmZTutycnIUGhpaZvt33nlHY8aMUYMGDS54XLvdLrvdXml1AgCA6stjIzIRERE6duyYCgsLJclxSalTp06l2u7atUs1a9ZU165dq7RGAABQvXksyISEhKhv375KSEiQJG3evFkTJ06U3W7XzJkzlZ6eLknau3ev1q9fr44dO+rIkSPatWuXVq5c6amyAQBANeKxS0uSFBcXpxkzZmjXrl06deqU5s2bp/z8fMXHxysqKkpnzpxRz549lZGRob///e+O/f797397sGoAAFBdeDTIBAcHa9myZaXWJycnO17/8ssvVVkSAACwEJ61BAAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAALIsgAwAA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Jvt6mfT0dL344ov68ccfNXDgQE2dOtWxbevWrfrll190+PBhbdy4UX369FFiYqKk8h9uVrNmTdWsWbNKakf53nrrLQ0dOlSSNHr0aL388sv6v//7P91yyy1O7ZKTk1W/fn3dfPPNkuSYBIrqjc+td+JzWzX4L+VlQkJC9D//8z9lbuvRo4dGjx7ttK5ly5aqUaOGjh49WuY+x48fLzXTHlXv3XffVZs2bbRu3TpJ0tVXX61ly5Y5/YNYUlKi119/XfPnz3esu+6663Ty5EmdOXOGv+KqMT633onPbdXg0tIV7qqrrtKAAQP0ySeflNp29OhRpaSk6OGHH676wuCQmJio/v37a+HChY6fOXPmKD4+XmfOnHG0W7hwoaZMmeJ0SWLQoEHy8fHRBx98UOq4xhh9++23VfEWUMn43FZ/fG6rDkHGixQXF+vs2bMV3vbKK6/o66+/1kcffeRYV1RUpEmTJmnBggVq1aqVW+qFaxYvXqyRI0c6rRs6dKjy8vK0evVqSdILL7ygVq1aqbCwUIcPH9by5ct16NAhNWrUSH//+981depUff311479S0pKtGjRIl1zzTVV+l5QGp9b78Tntgp59ktTqCzbtm0zbdu2NfXq1TPx8fGmoKDAGGNMVlaWWbJkialRo4a56667zK5du8rc/9ixY+aRRx4xo0ePNo8//rgZPny4ee+996ryLaAMixYtMr6+vmbVqlVO6z/66CPj6+trGjVqZF566SUjyemndevWTu3XrFljOnXqZCIiIszo0aPNrFmzTFpaWlW+FZSBz6134nNbtWzGlDNbDAAAoJrj0hIAALAsggwAALAsggwAALAsggwAALAsgswV5MCBA3rqqafUoUMHRUdHV3j/vXv3auDAgZo7d64bqsPloG8BXKkIMhaxfft2tWvXTgEBAbrvvvs0efJkRUZGasSIEdq/f79Lx3j44YcVHR2tt956Sx9++GG5tzcvT/PmzZWZmVnufS1waehb7+RKv65fv17h4eFq0qSJxo4dq759++quu+7Svn37XDpHVlaWRo4cqVGjRql3796qUaOG40Z4c+bM0U033aShQ4fq9ttvV926dTVs2DD1799fderU0ZEjR9z0zr0ffVvNePbb36iIWbNmmS5dujiWS0pKzDPPPGP8/PxMYmLiBfc9ePCgCQ8Pv+waHnroITN79mzH8ssvv3zZxwR9661c6dehQ4eaoUOHOrYPGjTIhIeHO+4pcyFjx441CxcudCyvWLHCjBgxwhhjzJIlS0xeXp4xxpg33njDhIWFOdq98847Jjk5+XLf3hWNvq0+GJGxkD8+RMxms2nmzJllPovlj44fP64aNS6/u202m+N1UlKSnnzyycs+Juhbb+VKv/6+jc1m05AhQ5SSkqK9e/de9PhffPGF6tat61geMWKErrvuOknSvffeW+oJ2udFRUWpYcOGFX4/+A/6tvogyHiBUaNGKSkpSXv37tUnn3yip556Sn369NFf//pXlZSU6IsvvtDrr7+u06dPa8aMGUpISFBaWppGjhyp+fPnq1u3btq6davOnj2rV155RTabTUeOHFFaWpoeeOAB3XnnnaXOWVBQoBUrVigrK0szZszQF198UfVv/ApA33qn3/frH/3222+SpAYNGjjWHTx4UE8++aRGjhypvn376pdffpEk3XbbbZoyZYpWrFjhaDto0CBJUnBwcLnn9/Pzc/olicpD33qAp4eE4LrZs2c7DWWet3//fiPJPP/882b8+PHGGGPOnDljGjVqZFauXGmMOXcr9KZNmzr2mTZtmomJiTHGGDN//nxz9913G2PODX9KcgxNvvHGG6Z79+6O/UaMGOG4/JCcnGz4v1DloG+908X6dd26dWbEiBGOyw8///yzadWqlRk1apSjbVFRkYmKijJFRUXGGGMGDBhgHnnkEWPMuUcZdO/e3UgyXbt2NXv27Cmzjj9efsDlo2+rj1rlBRxYx/lLAtnZ2Tp16pQWLlwoSerevbtyc3PL3Gfs2LGqW7eu0tPTtX//fuXk5DgdC9UDfeudzvfF+cnVSUlJGjNmjFavXq2XX37Z6XJiYmKijh07pkWLFkmSwsLCHPvXq1dPW7du1eLFizVr1ix17NhRy5Yt04gRI6r4HeE8+rbqEWS8wMGDByWdm0nfu3dvTZkyRZIc/1uWJk2a6Nlnn9V1112n2267TcnJyVVQKSqKvvVO5/v1+uuv18aNG/WnP/1Jr732mr799lt9/PHHGjNmjKNtSkqKgoODy+zzQ4cOqUWLFpowYYIGDRqkQYMGaezYserdu7dCQkKq6u3gd+jbqsccGS/w5ptvqkOHDoqIiNB7773ntC0xMbHMfcaPH69mzZpp2LBhstvtTttsNhtfw60m6FvvdL5fb7jhBsc6Hx8frVmzRtu2bdOrr77qWB8SEqIdO3boxIkTjnXn+z4+Pt6xrkGDBlq5cqUKCwuVkpJSBe8CZaFvqx5BxkKKi4tLrVu0aJG2bdumf/zjHxo0aJD27NmjIUOGaOvWrXrqqacc+xQXF6uoqMix3549e5SRkaEzZ85o586dysvLc/zl3qhRI3355Zc6fvy4Pv30U508edKxrzHGcY+S2rVrS5JOnz6tH374wa3v3dvRt97pYv16vs35cHnttddq2bJleuyxx/TVV19JOjfps1GjRurXr582btyo1atXO7Z9+umn2rZtm+PYqampCgsL00033eR0zrNnz5ZZCy4dfVuNeHaKDly1detW07ZtWxMUFGQmTJhgZsyYYQYPHmxGjRplDh8+7Gi3Zs0a06xZM3P11VebRYsWGWOMSUlJMYMHDzY2m82sWLHCZGRkmCVLlpiAgAATFRVl1q5da4KCgsyGDRuMMefuUVCvXj0zZMgQExcXZ7p37242b95sDhw4YFq2bGm6dOlifvzxR1NSUmJ69epl2rZtaw4dOuSR/y7egL71Tq7064cffmiaNGliGjdubNatW+fYd/z48aZ+/fpm/vz55vTp0yYpKcl07NjRBAYGmtGjRzvuQ3LrrbeaWrVqmbvvvtuMHTvWDBgwwHz77bdOdXz99demd+/exmazmaVLl5rMzMyq+4/gpejb6sVmTAVvAQoAAFBNcGkJAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABYFkEGAABY1v8HfUtfRbY8UocAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "train_bars = []\n",
    "test_bars = []\n",
    "train_labels = []\n",
    "test_labels = []\n",
    "train_errors = []\n",
    "test_errors = []\n",
    "train_colors = []\n",
    "test_colors = []\n",
    "\n",
    "### Train\n",
    "# Default\n",
    "for method in ['PPO', 'A2C']:\n",
    "    reward = 'Default'\n",
    "    mean, std = get_values(method, reward, 'usefulness', False)\n",
    "    train_bars.append(mean)\n",
    "    train_labels.append(f'{method}\\n{reward}\\nTrain')\n",
    "    train_errors.append(std)\n",
    "    train_colors.append('C1')\n",
    "\n",
    "### Test\n",
    "# Default\n",
    "for method in ['PPO', 'A2C']:\n",
    "    reward = 'Default'\n",
    "    mean, std = get_values(method, reward, 'usefulness', True)\n",
    "    test_bars.append(mean)\n",
    "    test_labels.append(f'{method}\\n{reward}\\nTest')\n",
    "    test_errors.append(std)\n",
    "    test_colors.append('C1')\n",
    "\n",
    "### Train\n",
    "# DREST\n",
    "for method in ['PPO', 'A2C']:\n",
    "    reward = 'DREST'\n",
    "    mean, std = get_values(method, reward, 'usefulness', False)\n",
    "    train_bars.append(mean)\n",
    "    train_labels.append(f'{method}\\nDReST\\nTrain')\n",
    "    train_errors.append(std)\n",
    "    train_colors.append('C0')\n",
    "\n",
    "### Test\n",
    "# DREST\n",
    "for method in ['PPO', 'A2C']:\n",
    "    reward = 'DREST'\n",
    "    mean, std = get_values(method, reward, 'usefulness', True)\n",
    "    test_bars.append(mean)\n",
    "    test_labels.append(f'{method}\\nDReST\\nTest')\n",
    "    test_errors.append(std)\n",
    "    test_colors.append('C0')\n",
    "\n",
    "x = np.arange(len(train_labels))\n",
    "plt.bar(x, train_bars, yerr=train_errors, capsize=5, color=[ \"#fec48d\", '#fec48d',\"#a0d8ff\", '#a0d8ff'], width=0.4)\n",
    "plt.bar(x + 0.4, test_bars, yerr=test_errors, capsize=5, color=[ \"C1\", \"C1\", \"C0\", \"C0\"], width=0.4)\n",
    "# plt.xticks(x+0.2, [s + '      Test  ' for s in train_labels])\n",
    "plt.xticks(x+0.2, [\n",
    "    'Train     Test  \\nPPO\\nDefault',\n",
    "    'Train     Test  \\nA2C\\nDefault',\n",
    "    'Train     Test  \\nPPO\\nDReST',\n",
    "    'Train     Test  \\nA2C\\nDReST',\n",
    "])\n",
    "plt.ylabel('USEFULNESS', )\n",
    "plt.ylim(0, 1)\n",
    "plt.savefig('comparison_usefulness.png', dpi=300, bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7defbd1c",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ipp_env3 (3.12.9)",
   "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.12.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
