{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import os \n",
    "import glob \n",
    "import pandas as pd\n",
    "import seaborn as sns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(4, 3, 4)\n",
      "    width            cands           mu        std\n",
      "0   ind=0      1. NeuraLCB    33.543330   1.843439\n",
      "1   ind=1      1. NeuraLCB   124.968988   3.169119\n",
      "2   ind=2      1. NeuraLCB   476.506479   7.809151\n",
      "3   ind=3      1. NeuraLCB  3003.578659   8.332902\n",
      "4   ind=0      2. NeuralTS    35.603394   2.567020\n",
      "5   ind=1      2. NeuralTS   123.711264   3.376607\n",
      "6   ind=2      2. NeuralTS   473.722461   6.165894\n",
      "7   ind=3      2. NeuralTS  3002.639381  10.858014\n",
      "8   ind=0  3. Neural-PELPS     0.013522   0.001967\n",
      "9   ind=1  3. Neural-PELPS     0.010412   0.000867\n",
      "10  ind=2  3. Neural-PELPS     0.011260   0.002472\n",
      "11  ind=3  3. Neural-PELPS     0.010828   0.000735\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAT4AAADZCAYAAAC5Dly+AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAA1lklEQVR4nO3dd3xN9//A8dfNzRZkJ5KgtLYgtbdo7ZREjJhFrbaoUbVXRO2G2IpatSNt1Uy/pbbSGqG0SpEgIosksnN/f+TnElmX3Jsh7+fjkcfj3jM+933Ovd7O+Zxz3h+FSqVSIYQQxYheQQcghBD5TRKfEKLYkcQnhCh2JPEJIYodSXxCiGJHEp8QotiRxCeEKHb0CzqAx49jCjoEIYqU27dvMXnyeExMTHnyJBofn/ksXjwfPT09EhMT8fNbiZGRMSNGDMswzdzcAoDAwENMmvQVFy5c0VrbkZGRGdZbtGgpFSu+m9+7JgMbm5LZzlMU9A3MkviEeD3Xr/+FmZkZZcuW45tvFpCamoq5uTlDhnzK7t07CAkJpnRpc1JTUzJMGzNmPFFRkYwfP4bHj8P48ceDWmu7fftOGdZzcHDEy6tPAeydF3JKfHKqK0QRU61adRQKBV27unHy5HGCg+/h7FwHAGfn2gQFXeHatauZpgHMnDmVyZOnoVAotNr2q+t5eHTT5S7IM0l8QhRBTk5l2bv3Z9zcurB3725UqjT1PGNjY4BM0376KYBq1apTseJ7Wm/71fVWr16e943UIUl8QhQxfn6+/PrrLwDY25fBxMSUP//8A4BLl/6kZs1a1KpVO9O0Awd+5urVIEaOHM7Nm//g5/eN1tp+db2oqCjd7oQ8KtR9fKmpqURGRpKYmJCPEYnCyMjIGEtLS5RKZUGHUuDu3w/hyy+/wMTElJiYp/j6LsfbexopKakoFAqWLl2Bvr4Bo0YNzzDNzOxFn5e7e0d++OGA1tp+8uRJpvWcnMrm527JpEhe3Lh27SoREeGUKeOAiYlJPkclCpv4+HgePnyAlZU1NWrULOhwRBGQU+Ir8NtZshIbG8uzZ3G0aNGqoEMRhUilSpX5/fdzxMbGYmZmVtDhFDpKZdYXLLTJw8MNgICAn3NcLjW1cFe7K/DEZ2Fhir5+xtOX+PgoypZ1Ql9fuiBFRmXLOqJUJuf4v3lxNX3taR5FPHvj9atXtCTW/iRhsRHZLhOd+ASAWWcWZruMrZkVU1qOeuM48oPGiS8pKYl79+4RGRkJgIWFBeXLl8fQ0DBPAURFZf6iIiJiAUhJScs0TxRvqakqIiJiMTGR+z9fplQqeBTxjAfhcW/chq2lKU/NIngYG5btMlXGNALIcRmAyMjYAj/qy9Op7i+//MLWrVu5ePEiiYmJGeYZGRnh4uJC3759+fDDD/MeqRBC5INszyWDg4Pp0aMHM2bMoHr16vj5+fHrr79y8eJFLl26xK+//oqfnx81atRg5syZ9OzZk5CQkPyMvVBo1qwe+/b9oNPP6NWrKxs2rM1y3p9/XqBZs3qEhT3SaQxCvE2yPeLr1asXQ4YMoVevXlmezjo4OODg4EDLli354osv2LZtG15eXpw8eVKnAReEhIQE3N07kJycREDAAUqVKp2vn799+94M7zdtWk+/fgPR05M+UCHeRLb/cjZv3szHH3+sUR+eoaEhAwYMYMuWLVoNrrA4fPgA1tY2lC9fgf379xVoLLdu/cu3364iLU36P4V4U9ke8VWsWFH9+uHDhyxYsABfX18AFixYwM6dOylfvjyLFi1SL1uhQgUdh1sw9u7dTdu27TEyMiIgYA9eXn2yfNYxOTkZX98FBAYexsjIkC5dPHny5Al37txm+fL0U9Vbt/5l+XJf/vnnBkqlPlWrVmfkyDGULVsOgG7dPqJDBzfOnDlFbGwsO3bspVu3j2jbtgPOzrWZOHEsAG3btmDw4E+pWrUaAHfv3mHGjEn8/fffmJubM3bsBJo1a6Fu09OzJ3//fZ1Tp05QqlQpxo2bSHJyEqtWLSci4jF169Zn+vTZmJqWIDExkWXLfDlx4hixsTFYWlrx0Ufu9Os3MNtnPIUoSjQ6V5o+fbr6vqkzZ86wbds2pk2bxvvvv8/cuXN1GmBBu3z5Infu3KZDBzfatevEo0ehnDt3JstlN2/ewG+//cry5Wvx9/+Z5ORkjh4NVM9/+vQpI0YMpUKFiuze/RPbt/tTsmRJvvjiU5KSktTLHTiwj5Ejx7B9u3+G9hs3bsqECVMBOHLkOL1791PP27NnB9On+3Dw4K+4uNRl3rzZGY4K9+zZQefOHhw8+CsNGjRm3rzZnDjxGxs2bGHbNn+uX/+LAwfSj2Z37dpOUNAlNmzYyi+/nGT27Hns3r0j2+0WoqjRKPFdvnyZKVOmAHDo0CHatGmDu7s748eP58qVzDW93ib+/rto2LAxNja2mJub06xZSwICdme57NGjv9CmTQeqVKmKkZExQ4d+hpGRsXp+YOBBFAoFn346ClPTEpQoYcbIkWN5/DiMs2dPq5erVq06tWu7vNbRlYdHd8qUccDIyAhX1w+Jjo4iKipSPd/ZuTbvv18PfX19WrRoSWRkBIMGDcXUtAQ2NrbUqlWHO3f+AyAm5ikKhR5GRsYoFAqqVq3OTz8dplGjJq+7+4QolDRKfCqVSv2M5IkTJ3B1dU1fWU8vw5HK2yY8PJzjx4/i5uaunta5sztnzpwiNPRhpuUfPXqEo6OT+r2+vj7VqlVXvw8JCcHR0QkDAwP1NHNzc8zNLXj48L56moOD42vH+vI6RkZGABm+mzJlHF6an56M7e3LqKcZGxurb1fy9OwBgLt7e778chS7dm0jOrpwP3QuxOvQ6AZmZ2dnZs2ahYGBAbGxsbRq1QqA3bt38+67BVtlVZd+/NGflJQU5syZwddfvzj6SktL44cf/Bk+fESG5VWqNAwMMu7S5OTkV1rNfFOnSpWWYTl9fYNMy+Qmtyu8WR09ZreOnZ09Gzdu4/r1a5w/f45Dh/azfv0ali5dRdWq1bNcR4iiRKPEN336dGbPns3Tp09ZuHAhpqamREVFsWTJEpYvL9x1t95USkoKP/0UQM+efejWrWeGefv2/cBPPwUwaNDQDNOtrKx58OB+hjb+/fem+mjMyaksBw/+TGJiovqoLCIinOjoaMqWLa/jLdJcfHw8enoKqlWrQbVqNejXbyAjRw7j0KH9kvjEWyHbw4SwsBePpLzzzjusX7+e3bt307JlSyD9kbUTJ07QoEGDLNcp6n777Veio6Po0aMXZco4ZPjr3t2L2NgYjh79JcM6zZu34vDhA9y+fYvExES+/XYVKSkp6vlt23ZAqdRj1So/EhISePr0CX5+i7Gzs9e4/8zYOL1SzZ07//Hs2Zs/npSTSZPG8fXX3uo+wpCQYB49ekS5cu/o5POEyG/ZJr6uXbuyb1/O96w9P2oB2LdvH56entqLrIDt3bubJk2aYWdnn2mehYUlLVu6EhCwJ8P0QYOG4OJSj88+G4yXlwelS5tTt2599SllyZIlmT9/Cbdu/YuHR0f69u1BamoaK1asy7Avc1KvXgMqVarM4MH92LhxXd43NAtTpswkOTmZ3r278cEHTRk3biTt2nXA3f3t+X5F8ZZtPb5r164xdmz6PWM9evSgUaNGVKpUSX1Dc3JyMjdv3uTs2bPs3r2btLQ0fH19qV799U6FsqrHFxISDFDghQzfxMunsQAjRgzF3r4MU6fOKsCo3h5F+behS0qlgklrzuapSEGdyjY8dTqcawGC3JQxs2VG4/FFs0hBjRo12LdvH3v27GH79u0sXLgQhUKBsXH6LQ7x8fGoVCoqVapE//798fT0zHOllqJu+/atfP/9Jvz8VlG+fAXOnDnFlSuX6N69V0GHJoR4SY4XNwwNDenduze9e/cmPDycmzdvqmvpm5ubU6lSJWxsbPIl0KKge3cvwsPDGDPmc+Li4rC1teOLL8bRsqVrQYcmhHiJxvX4rK2tsba21mUsRZ6+vj4jR45l5MixBR2KECIHUt5DCFHsSOITQhQ7kviEEMXOayW+O3fucObMiwodBTwypRBCvBGNEl9ERAReXl506NCBoUPTH9N6+PAhbdu25fbt2zoN8GVKpUKnf0KI4kGjq7rTpk3j3XffZdWqVepH1uzt7XFzc2POnDmsX79ep0FCetJbsudKnobPy4mdlSmju9XS+KbLlJQUVq9ezo4dW9m7dz+2tna5rjNnzkzOnDnJ9u0BlCz54ubKbt0+YtmyNRkqqOjKiBFD+egjd9q165hpXnJyMt999y2BgYfR01OgUOjh6voBgwYNxcDAgPXr17B793YsLa3URQ+6dOlKjx69dR63ENqkUeI7e/YsJ0+exNTUVP2DVygUDB8+nObNm+s0wJfldfg8bZo4cewbPbBvYmLKd9+tZdSocTqIKm9mz55OQkI869dvplSp0jx9+gQfnxl8/fUsZszwAaBVqw+YOHEaAOHhj/n4Yy9q1XJRV4IWoijQ6FS3RIkSGR62fy4iIqLY9vMNGDCEwYOHv/Z6PXv25tixX7l3706W869cucTgwf3p2dOdoUMHcP9++sh169evYd682erlXn4/YsRQ1qxZQZ8+3QgKukxkZARjx46kd29PunfvzI4dW3ON6/btW5w5c4qpU2epB1MqVao0kyZNp1OnzlmuY21tQ7ly5TNUpBGiKNDoiK9Ro0ZMnjyZ0aNHAxAZGcnff//NokWLaN26dZ4CsLAwRV9fmWFafLwZT548Q1//RV7W09N9H5xSqYdCoVkir1Ontvq1vr5ehlizo1AoMDMzY/DgYaxYsYTFi/0yfHZSUgLTpk1k+nRvGjZsxJEjh5gxYxIbN37//6eeCvXnvPxeoVBw8+YNtm/fg56eHosWzcfR0RE/vxXcvx+Cl5cnbdq0xc7OHoVCgZ6eIlO8V65cpGZNZywtLTJMt7GxxsbGOtNnAty4cZ3Q0IfUrVtXo+3XBn19PUqXNs3xOUxR8CwtzQo6hBxp3Mc3ceJE3NzcAGjatCl6enq4ubkxderUPAUQFZW5zy4iIhaAlJQXY0bkx8WH1NS0N3qwOiUlLUOs2VGpVKSlqWjf3o09e3Zy6tQpGjZsrP7sP/64gKmpKXXrNiAlJY3WrduyYMHXhIQ8IC1NhUqlUn/Oy+9VKhUNGzYlLS29SOoXX3xJamoqKSlp2Nk5YGlpRXBwCFZWtuoYXo03JiYGCwvLHLcjLU3F0aO/cPnyRZKTUwgLC2XAgMGUKmWu0fZrQ0pKGhERsZiYZC5uUZwVtotzkZGxRbNIwctKlSrFypUriYyMJDg4GCMjI5ycnNQDEInXo6enx8iRY1m8eD5169ZXT4+JieXx4zB6935R/snAwFCjsu+lSpVSv75+/Rpr1qzg0aNQ9PT0iIgIz3U4SltbO37//Wyun/NyH9+zZ3EsWPA1K1f68fnnX+S6rhCFhcbnJ5GRkYSEhJCUlERMTAzXr1/n/PnznD9/XpfxvbVcXOpSvnx5fvzxxUhq1tbWlC9fgW3b/NV/+/YdoWrVaiiVygzJKybmabZte3tPp1WrD9i+fS/btvljbm6R7bLP1axZixs3/iI8/HGG6TExMaxbtzrLvlxT0xK0b9+J33+X0ddE0aLREd+KFStYsWJFlkcNCoWC69evaz2w4uCzz77gs88Gk5KSPt5GjRo1iYgI59q1q9SoUZP790PYsGENU6d6Y2VlzcmTx0lLS+Pp06ecPXuaOnXez7Ld6OhIKleuikKh4ODBn0lIiOfZs5xvA3J0dKJt2w7MmDGZ2bPnYWlpxdOnT5g1axplyjhkOWZHWloaJ08e5733Kud9ZwiRjzRKfJs2bcLHxwdXV1eNKwXrgp2VaaFoOzIyghEjXoy3MXLkMJRKJUuXruLx4zDWrVvNN9/kPhaJo6MT7dp1ZNu2zUD66Gc+PvNZsmQBz549Q1/fgCFDhqNQKHB1/ZDDhw/Qs6c75cq9g6vrhxmGj3zZ4MHDmTBhNJaWVnTp4knnzl2ZO3cWa9duAmDlSj82bXpx72Xnzh54efVlzJiv2LRpPZ99NuT/L4Do065dR3r1ejF+77Fj/+PKlUsApKamUq1aDcaOnaDxvhOiMMi2AvPLXF1dOXz4sE4Kjb5OBWZdd+AWdGesyJ1UYM6aVGDOLM8XN8aNG4ePjw8DBw7E1tY207CEJiYmeYtQQwW9I4UQbweNEp9CoSAwMJDdu3dnOV/6+IQQRYlGiW/u3Ll06tSJli1bFmgfnxBCaINGiS85OZmJEyeir69xpXohhCi0NLqPr3///uzatUvXsQghRL7Q6BDuypUrXLp0iZUrV2Z5cWPPnj3ZrCmEEIWPRonP2dkZZ2dnXccihBD5QqPEN2LECF3HoRG5j08IoQ3ZJj5fX1/GjBkDwIIFC3Js5KuvvtJuVFlQKhWsCtpAWGyETtq3NbPiU+dBGie/kyd/Y926NSQnJ1GqVGnGj59ExYrv5bhOYajA3KxZPfbu3c/ixfMIDr4HwL17d3F0dEKpVFKiRAm+/XYz0dHR+Pkt5vr1awAolfr06NGLzp09dB6jELqWbeK7evWq+nVQUFC2DWT1DKeuhMVG5Pmucm14/DgMH5+ZrFq1ngoVKrJ3724WLvyaVas25LpuYanAPH++r/p1s2b1WLZsTYby+b6+87GzK8P336fX+AsOvsfw4QOpWPFdatasVRAhC6E12Sa+l8fR8PHxoXz58pmWSUpKyjEpvq309fWZOXMOFSpUBKBWrTqsXbtCo3V79uzNtm1bcHf3pFy5dzLNv3LlEn5+3xAT85TSpc2ZMcMHR0cn1q9fw+PHYeqSUC+/HzFiKM7OtTl+/CgTJ07D0dEJH5+ZhIY+IDk5GU/PHnh59X2tbbx16xaurh+qL2SVLVuOTZt2YmGRe6UXIQo7jW5n6dw569Ljz549Y/DgwVoNqCiwsLCkUaMm6vdnz56ievWaGq1ralqCQYOGsHz5kkzznj17xrRpExg27DN27vyB7t29mD59kkbt/v33DbZs2YWzc202bVqPg4MD27b5s2TJSnVtvtfRuHFTFi2ax5YtG7l582/S0tKwtrZGqVTmvrIQhVyOFzd27drFzp07SUpKolu3bpnmh4eHY25urqvYioQLF35n167tLF26SuN1OnbszN69uzl37oy6AjPA5ct/Ympagvr1GwHQpk17Fi+eR2ho7kmrceOm6qOz0aPHk5qaCqRXgLG0tOLhwwfY2dlrHOOnn46kbNlyHDlykPXrV1OyZCk8PXvQv/+gTLczCVHU5Jj4OnToQOnSpRk7diytWrXKNN/IyIgPP/xQV7EVesePH2PJkoUsWOCrPu3VRGGswJxVjJ07e9C5swfx8fGcPn0SX98FmJtb4O7umXsDQhRiOSa+kiVL0q5dOxYsWECnTp3yK6Yi4fz5cyxduohvvlnOO+9UeO31c6rAvH79lkzLnz176rUqMPfs2Rt3d08UCgXu7h1eK7Znz55x8eIfNG2aPnSoiYkJH3zQhr/+usp//916rbaEKIw0OmeRpJdRQkICc+d6M2fOwjdKes999tkXbN78HfHx6dWRX67ADHD/fgizZ09DpVJhZWXN7du3SEtLIzo6mrNnT2fb7ptUYH6ZQqFg7txZHDiwTz0tMjKCCxfOUbt21lWfhShKilTVAVszq0LR9okTx4iOjsLbO+MIc8uXryU09GGhr8CcGxMTE5YsWcXq1cvYvDn9Fh19fQO6du1O69bFt2tDvD00qsCsS1KBWbwOqcCcNanAnFmeKzAXFgW9I4UQbweNEl9cXBwBAQHcunWLhISETPPnzp37xgFYWJiir5/x3rD4eDOePHmGvr7cNiEy0tfXo3Rp0xz/NxcFz9KycI+5rVHiGzt2LJcvX6ZWrVoYGxtrNYCoqMyd7hERsQCkpLzeLRji7ZeSkkZERCwmJpm7SIozXXcDva7IyNgCP0PL86nu77//zoEDByhTpozWghJCiIKi0bmkvb19hmoiQghRlGmU+KZOncqcOXP4559/iIuLIz4+PsOfEEIUJRqd6o4aNYr4+Hh++OGHLOfL8JJCiKJEo8S3apXmD+DrktzHJ4TQBo0SX4MGDdSvnz59SnJyMlZWunuKIitKpYKHfr4kPHqkk/aN7ewoM2qMxsnv2LH/sXHjepKSEild2rzIVWB+uegowJ9/XmDs2BE4ODgCkJaWhpNTWcaM+QpHR6dM81+2bZs/f/55gfnzfdi584dM859vd6lSpVGpVCgUClq2bM3gwcNRKpUkJiawfPlSLlw4h0KhIC1NRYcOnfj44090sg+E0CjxxcbG4uPjw5EjR9R9eiVKlMDd3Z0JEyZgYGCg0yCfS3j0iIQHD/Pls3ISGhrKokVzWbduC/b2Zdi1aztz53rz7bebc123sFRgzoqdnT3btr0omrB160ZmzZrK2rUbs5z/Orp182LAgPTajXFxsYwe/Tl2dna4u3djw4ZviY2NYfPmnRgYGBAZGcFnnw3B0dGJDz9sl+ftEuJVGl3c8PHx4e+//8bb2xt/f3/8/f2ZMWMGv//+O35+frqOsdDR19dnxgwf7O3Tb++pV68+9+7d1Wjdnj17c+zYr9y7dyfL+VeuXGLw4P707OnO0KEDuH8/BEivuDxv3mz1ci+/HzFiKGvWrKBPn24EBV0mMjKCsWNH0ru3J927d2bHjq1vtJ2enj3566+rxMbGvtH62SlRwowOHdz4/fdzANy+/S+VK1dV/wdqaWnFqlXraNmytVY/V4jnNL6Pb/v27djZvTg9ql69Oi4uLvTv359x4wrf0YsuWVtbY21tDUBKSgoHDvxMs2YtNVr35QrMCxYsyTDveQXmqVNnUb9+IwIDDzF9+qQsy1S96nkFZj09PXx9F+Dg4MA33yzj/v0Q+vbtjqvrh69ViBQgNTUVhUKBgYH2n2xMSUlRJ7pGjZqyevUyYmKe0qRJc6pWrYaFhaXWP1OI5zR+ZC2rsRZsbW21fjRQlOzatZ2NG9fh6OjE3LmLNV6vKFRgTk1N5fvvN9GoUROMjNKf1nn0KDRDkdT0z23GyJFjNG4XICoqkv37f1L34Xl69sDCwpL9+39i587vMTAwoGPHjxg2bARGRkav1bYQmtAo8dWoUYMlS5YwevRoDA0NgfSBhpYuXUqVKlV0GmBh1qNHL7p39+KXXw7z6aeD2Lp1lzpJ5KQwVGBevXo5x48fBWDq1FlA5sRWrVoNpkyZpX6flz6+PXt2cOTIQQCMjY356KMuGUpctW79Ia1bf0hSUhJ//HGeJUsWYmhoxPDhhWNMZ/F20SjxTZkyhU8++YSdO3fi5OSEQqEgJCSEUqVKsWzZMl3HWOjcufMfjx+HUb9+QxQKBW3atMfXdyH37t2lUiXN/iMo6ArMw4ePyJBU/vzzQp4SW25evrjxspSUFE6fPknTps1RKpUYGhrSuHFT7t8PVvcBCqFtGl3cePfddzly5Ajz58/Hw8MDd3d3FixYwKFDh6hRo4auYyx0oqOj8PGZQXj4YyD9gkRKSkqWt3rkpLBWYM5PSqWStWtXsmXLd+rT87i4WE6ePE6dOi4FHJ14W2nca21oaFjgAwsZ29nlvlA+tF2nzvv07z+Q0aM/Iy0tDQMDQ2bNmkOJEmb89dfVIl+BOTtZ9fFB9qfKAJs27cixTYVCwaJFfqxcuZQ+fboB6Tept2/fkZ49++QpXiGyk20F5latWnHs2DEAGjVqhEKR/VMTZ86ceeMApAKzeB1SgTlrUoE5szcqSzVmzIsrdRMmTNBuRG+ooHekEOLtkG3i69Kli/p1cHAwo0aNyrRMXFwcixcvxsPDQzfRCSGEDuTYxxcZGUlERATr1q2jU6dOvHpWfOfOHfbs2cP06dN1GqQQQmhTjonvt99+Y+7cuSQnJ2c7tm7btm11EpgQWXle5ECIvMgx8Xl4eNClSxfq1q3Lzz//nGm+sbGxTqq0mJtbcP36NenAFpk8fPiQ6tWL3y1UQrtyvZ1FT0+Pixcv8ujRI5RKpfoZ1du3b+vsf14zMzNMTUtw/Pgx7O3LYGJiIv/LF2MqlYr4+HhCQx9iZWWNmVnhHsFLFH4a3cD822+/0a5dOy5cuKCedv78eTp16sSJEyd0EliNGjVp2rQ5FhaWkvSKOYVCgYWFJU2bNqdGjZoFHY54C2h0A/PixYuZM2cO7du3V0/r2bMnVlZWLFq0iObNm+skOKVSiY2NjU7aFkIUXxolvuDg4AxJ77mWLVsyfvz4PAWQ1YDiQoii7a0YUPydd97h8OHDdOzYMcP0PXv24OTklKcAshpQXAjxemRA8czyPKD4l19+yYgRI1i1ahWOjo6oVCr+++8/wsLC+O6777QWqBBC5AeNEl/Tpk05dOgQBw8eJDg4GIVCQZMmTXBzc8v3QYeEECKvNK7OYmdnh5eXF2FhYZQrV06XMQkhhE5pdDvLs2fPGDduHHXr1lX380VGRtKvXz/CwvJWyUEIIfKbRolv9uzZxMbGsmvXLvW4DqamppQtWxYfHx+dBiiEENqm0anuL7/8QmBgIObm5uqbiY2NjZk8eXKBFycVQojXpdERn76+PsbGmQfRSUpKIjExUetBCSGELmmU+FxcXJg/fz5xcS+qu967d49JkybRuHHjHNYUQojCR6PEN336dC5dukSDBg1ITEykTp06tGvXjri4OGbMmKHrGIUQQqs06uOzt7cnICCAK1euEBISgpGREeXLl+e9997TdXxCCKF12Sa++Pj4TNMqVapEpUqVMi1jYmKig9CEEEI3sk18Li4uuZaDel4N9/r161oPTAghdCXbxLd58+b8jEMIIfJNtomvQYMGmaYlJCTII2tCiCJPo6u68fHx8siaEOKtoVHi8/b2lkfWhBBvDXlkTQhR7Mgja0KIYkceWRNCFDvyyJoQoth5rUfWgoKCCA4OlkfWhBBFmsal52/evImzszPOzs7cv3+fwMBAgoODcXV11WV8QgihdRolvq1bt7Js2TLOnTtHdHQ0PXr0wMzMjCdPnjBkyBA++eQTXccphBBao1Ef36ZNm1i3bh0AAQEBWFpacuDAAbZs2cLOnTt1GqAQQmibRkd84eHhODs7A3Dy5Ek6duyIUqmkUqVKPH78OE8BWFiYoq+vzFMbQojCxdLSrKBDyJFGic/CwoJ///0XY2Njzp07x1dffQXA/fv3MTU1zVMAUVHP8rS+EAKUypwrKeW3yMhYUlNVBRqDjU3JbOdplPh69eqFp6cnCoWCZs2aUaVKFWJiYvj8889p37691gIVQoj8oFHiGzJkCPXq1ePp06fqG5ZNTU3p2LEjAwcO1GmAQgihbRrfzuLi4pLhvVKpZOjQoVoPSAghdE2jq7pCCPE2kcQnhCh2JPEJIYodjfv4njx5wt27d7MsQ1W/fn2tBiWEELqkUeLbtGkTCxcuJCUlJdM8GWVNCFHUaJT41qxZw+TJk2nfvn2WBUmFEKIo0Sjxpaam0rNnT5RKebRMCFH0aXRxo2vXruzbt0/XsQghRL7Q6IgvKSmJBQsWsHnzZpycnNQDDj23dOlSnQQnhBC6oFHie/bsGS1bttR1LEIIkS80Snxz587VdRxCCJFvNL6P79y5cwQGBvLgwQOSk5MpX7487u7u1KxZU5fxCSGE1ml0cWPnzp0MHDiQ//77DwcHB8qXL89///2Hl5cXx48f13WMQgihVRod8W3bto2VK1fSqlWrDNMDAwNZsmQJLVq00EVsQgihExolvpCQkCyTW+vWrZk4caLWgxJCU4GBh5g06SsmTZrKjz8GAPD48SOaNWtJ1arVMk2bMkXGgRYanura29vzxx9/ZJp++fJlbGxstB6UEJqIiopk587tODo64unZg82bt7N583YcHcsyZMinWU57HYGBh6hXrxb+/rvo378X/fv3okOH1syZMyvTMqJo0eiIb8CAAQwdOhQ3NzfeffddFAoFt27d4ueff2bUqFG6jlGILM2cOZXJk6cxduyL3+C+fT9Sr159bG1tc5yWm1eTqqdnDwAGD/5YnUBfXkYULRod8XXv3p1vvvmGqKgoAgIC2Lt3L1FRUfj6+jJgwAAdhyhEZj/9FEC1atWpWPG9DNM3bFjLwIFDcp2Wm+dJ9eWb9V9NoFktI4oGjW9ncXV1xdXVVZexCKGxAwd+Rl9fn5Ejh3Pz5j/4+X2Dm1tnbG1tMTIyUi93+/a/mablJqekumPH3hyXEUVDtonP19eXMWPGALBgwYIcG3k+3KQQ+WX16vXq1+7uHRk1aiwHDvxMhQrvZljuxo0bmablRpOkmtUyo0aNzfuGiXyRbeK7evWq+nVQUFC2DchhvihoP/xwAICOHd3o2NEtw7yspuVGk6Sa1TKi6FCoVKpcR/29e/cu5cuXzzQ9KSmJoKAg6tat+8YBpKSkoq8v5a6EyKthc3/hQXjcG69fp7INT50O8zA2LE9xlDGzZWmnWbkvWIA06uPr3Lkzly9fzjT92bNnDB48mIsXL75xAFFRz954XSEAlEoFS/Zc4VFE9r+lM7unAdC4++ws51evaEms/UnCYiOybePY7J8AaDWtc7bL2JpZ8anzIFJTcz2e0CqlsnCdeUVGxub7PniVjU3JbOflmPh27drFzp07SUpKolu3bpnmh4eHY25unucAhcirRxHPcjzaKe+afqN9dsvYWpry1Cwix6OdKmMaAeT5iEgUvBwTX4cOHShdujRjx47N9LgagJGRER9++KGuYhNCCJ3IMfGVLFmSdu3asWDBAjp16pRfMQkhhE5pdANzo0aNGD58OP/73//U0zZu3MjQoUMJDw/XWXBCCKELGiW+mTNnoq+vT/Xq1dXT2rZtS8mSJfH29tZZcEIIoQsaXdU9d+4cx48fzzC0pIODAz4+Pln2/QkhRGGm0RGfkZERERGZL/M/ePAAPT2NmhBCiEJDoyM+Dw8PBg0ahJeXF46OjqSlpfHff/+xY8cO+vbtq+sYhRBCqzRKfKNHj8bS0pKAgADu3buHnp4eZcuWZfDgwfTr10/XMQohhFZplPj09PQYMGBAliWoHjx4gIODg7bjEkIInXmjDrrk5GQOHjzIJ598IjcwF5C0tDRWrVpO1arvEBERwePHj+nbtweffNIfT8/OhIWFsX//Pj74oLm6evCtWze11vZzUoFYFEUa1+MDuHnzJrt37+ann34iNTWVDh06sGPHDl3FJnIQHh6Os3MtqlZNv8Xo2rUghg37nObNW7Jy5TIOHdqPgYEBQ4YMx8urj9bb7t9/oFQgFkVWrkd8cXFx7Nq1i+7du+Ph4cHt27eJi4tj586deHt7U6uW/G9fEGxtbWnW7MUAUK1ataZ585akpqZy9uxpGjVqwpMn0QQE7GH48E8YN24UsbGxWmsbpAKxKLpyPOKbNGkShw4d4p133qFz586sWrUKa2trXFxcMDAwyK8YhYbCw8OZNOlLhg37jMqVq2BmZkaXLl0pU8aBtWtX8t136xg5crRW2pYKxKIoy/GILyAggFatWrFw4UIGDhyItbV1fsWlkdu3b+Hl1ZWBA/vStasbt2/fArTT75RV23PmzOLjj3tn+KzC4smTaMaM+Zzp071p2rQ5ADdu/EVycjIApUqVJiUlWWttHzjwM1evBmWoQCxEUZHjEd/mzZvZs2cP3bp1o0KFCnTp0gU3N7dCc2qTmJjIwoVLKFu2HN98s4Dffz+LhYWFVvqdXm3b338XoaEP2bRpG3fv3kGD+q06df78OZYtW8KNG38xYsRQLl++hJ2dPVOmTADSKw/XqOHMl19+QcmSpUhMTMDPb5XW2pYKxKIoyzHxNWjQgAYNGjBt2jR+/PFH/P39WbhwISqVitOnT9O1a9cCPeWtVq06ISHBdO2aXlp8+3Z/vvpqTKYhB7XRdvv2HTEyMuarr8YQExPD9Omv94xyfHw8I0YMQ09Pj8TERPz8VmJubgHA/v372Lx5A3p6enTp0hUvrz7cvPkPkyeP591332PevMWZ2qtfvyGbN28Hci5C6e//42vFCelFKRo10vyi1b59B9Wvcyo+qe19UBTJPigc+0Cj0vMvu3LlCnv27OHAgQPo6+vTpUsXJk2a9MYBPH4c88brvmzDhm+JioqkRIkSDB8+Anf3juqxGLTRdkREOElJSUyZMoP//e8Ihw4dZOFC39dqIzU1hSFDPmX37h2EhAQzZsx40tLSaN26GUeOHENfX5927Vz56adDnDhxDIVCwf/+F5jjl62N6sOQewVibVQf1uU+mLTmbKEpuz6j8XjZBwWwD16VUwXm176Pr1atWnh7e3PixAm+/PLLLEvS5xc/P19+/fUXAOzty3DlymWt9Tu92nZg4CHS0tIAKFGi5Gv3l127dhVn5zoAODvXJijoCgCPH4dhZWWNoaEhenp6lCtXnjt3/qNt2w6YmpbQqO3n1Yez+yvvOpHyrhNzXCY8OoGw2PQKxFn9VRnTiCpjGmU7/2FsWI5l23W9D4oK2QeFYx+81n18LzMxMaFbt25ZlqTPL56e3fnyyy/YunUTMTFP8fVdjpNTWSDv/U6vtr1+/RaWLv2GoUMHEB0dzZw5OQ+5mRWVKk39+uVKNy9Pf3Xe20b2gewDKPh98MaJrzBwdHRi+3b/LOfl9TQ3q7YXLVryxu3VqlWbP//8g8aNm3Lp0p/UrJl+1dnW1o6IiAgSExPR19cnOPiuOnm/bWQfyD6AwrEPinxNKaVSUWj+ctKzZ28uX/6TQYP6ERh4mFatWtO/fy8UCgWTJ0+nb98e9OnTnc8//wIDAwOmTPmKuXNn88svgfTv34snT6LzZ4fqkOwD2QdQOPbBa1/c0La8XNzQpGNfE5oMLZibghxWMK+d2qCdju3cOrV1pSh17OuK7IPM3nh4SfF69PTyfn/jm/xY7KxM8/y51ubGGJtZ5akNWzOrIrsPtLH9IPsACnYfaKrAj/iEECK/Ffk+PiGEeF2S+IQQxY4kPiFEsSOJTwhR7EjiE0IUO5L4hBDFjiQ+IUSxI4lPCFHsSOLLg8OHD9OgQQMmTpyYad7du3cZOHAgtWvXplmzZixfvrzAqzZrW0BAAJ06daJOnTq0bt2axYsXk5KSop6/Y8cOOnTogIuLCx07diQgIKAAo9WNuLg4pk6dSr169ahbty7jxo3LclCnR48e4eLiwrJlywogSu3L6bef0/ceGRnJV199RbNmzahbty69evXiwoUL+Rl6OpV4I3PmzFG5ubmpPD09VRMmTMgwLz4+XtW6dWvVsmXLVHFxcarr16+runTporp48WLBBKsDp06dUrm4uKjOnj2rSk1NVd24cUPVuHFj1XfffadSqVSqQ4cOqVxcXFTnzp1TJScnqw4dOqSqVq2a6vLlywUbuJaNGTNGNWzYMFV4eLgqLCxMNXz4cNXmzZszLTdixAhV3bp1VX5+fgUQpXbl9NvP7XsfOXKk6uOPP1ZFRESoEhMTVevWrVO5uLiooqOj83Ubis0RX5UqVdi3bx+enp7UqlWLgQMH8vDhQ4YNG4aLiwseHh4EBwcDMGjQIJydnbP8e87a2prdu3fj4OCQ6bMOHTqEoaEhI0aMwNTUlKpVq/LDDz9Qp06d/NrcLGlzH1hYWODr60vDhg3R09OjSpUqvP/++/z9998AJCQkMHbsWBo0aPD/1XTbUa5cOf74448C237Q7j64f/8+hw8fZtasWVhZWWFjY8OqVavo169fhs/87bffuHXrFq6urvm+vZC/v/3cvvegoCDatm2LpaUlhoaGeHh4EBcXp/78fJOvabYAVa5cWdWrVy9VaGio6t69e6o6deqo2rZtq7p8+bIqJiZG5ebmpvL29n7tdkeOHJnpf70pU6aoRo8erZo6daqqXr16qjZt2qi+//57bW3KG9PVPkhJSVGdOnVK1bBhQ9XRo0ezXCYxMVFVv3591f79+/O4FXmjzX3w448/qlxdXVUbN25UtWjRQtWkSROVt7e3KiEhQb3M86P/s2fPqiZMmFAgR3z5+dt/1avfu7e3t6p3796q0NBQVXx8vGrt2rWqDz74QJWYmPhG2/amilV1lk6dOmFnZwdApUqVcHBwUA+IXr9+fe7cuaOVzwkNDeX8+fPMmDGDKVOmcPz4cUaPHs0777xDkyZNtPIZb0rb+2Dr1q3MmTMHExMTJkyYQKtWrbJczsfHB1tbW9q0aZOX8LVCW/sgNDSU8PBwbt++zf79+wkJCWH48OGYmZkxZswYAFasWEG9evVo2LBhgfZx5tdv/1Wvfu8TJ05k2LBhtGiRPmC9tbU1a9aswdDQUCefn51ic6oLYG9vr35tZGSk/iE8f5+UlKSVz1GpVFSpUoWuXbtibGxM27ZtadGiBfv379dK+3mh7X3Qt29fgoKCWL16NStWrOD777/PMD81NZVp06Zx6tQp1qxZUygGotfmPkhOTmbChAmYmZlRtWpV+vfvz4ED6dW///33X/bu3cuECRO0F/wbyq/f/nPZfe8zZ84kLS2NY8eO8ccff9CnTx+GDx9OTIx2Bh3TVLE64tPT08vx/XODBg3i/PnzWc4LCgrK9XNsbGwyte3o6Mi9e/c0jFR3dLEP9PX1adCgAX369GHLli306dMHgKSkJEaOHMnjx4/Zvn07tra2WtiCvNPWPrC2Th8Yx9T0RR08R0dHwsLSC3nOnDmT0aNHY2lpqaXI31x+/fYh++/92bNn+Pv7s2XLFsqUKQPAp59+ysaNGzlx4gQdO3bUdHPyrFglPk1t2LAhT+tXr16d9evXk5qailKpBCAkJCTLzuDCKrd9MG/ePBISEpg5c6Z6mkKhyHBEN27cOOLj49myZQslShS9kcJy2wfVq1cnISGB27dvU7FiReDF93z//n3Onz/PzZs3WbRoEZD+D19PT49ff/210N7ak9ffPmT/vaelpaFSqUhNTc2w/Kvv80OxOtXNL8+vVPn5+ZGQkMDRo0c5efIknp6eBR2a1jRs2BB/f3+OHTtGSkoK//zzDzt27KB169YA/PzzzwQFBbFy5coimfQ0UbVqVRo0aMCcOXOIjo7m1q1bbNmyhW7dumFvb89vv/3Gjz/+qP5r3bo1Xl5erF27tqBD15mcvnczMzMaNGjA6tWrefz4MYmJiXz77bfo6enRsGHDfI1TjvjewP3792nfvj2A+obd/fv34+DgwOHDhylZsiRr167Fx8eHDRs2YGtry+LFi9WdyW8DV1dXZs+ezddff83Dhw+xsbGhU6dOfP755wDs3r2bsLAwGjdunGG9Ll264OPjUxAh68SiRYuYMWMGrq6uGBoa0rt3bwYMGIBSqczQrwbpQ7KamZlhY2NTQNHmXW6//dy+d19fX+bNm4eHhwcJCQlUrlyZtWvXYmWV95L3r0NKzwshih051RVCFDuS+IQQxY4kPiFEsSOJTwhR7EjiE0IUO5L4hBDFjiQ+UWi1a9eO7du3Zzu/SpUqHD16NMt5/fr1Y/78+boKTRRxkvhEvujatStz587NMC04OJgqVarg7++fYfrhw4epWbMm/v7+9OrVS6P2Q0JC1MUBhMiNJD6RL1q0aMGpU6cyTDt16hSmpqacPn06w/TTp0/z/vvvY2ZmpnH7R44c4dChQ1qJVbz9JPGJfNGiRQtu3rzJo0eP1NNOnz6Nh4cHp0+fzjAeyenTp2nRogWtW7dm69atQPoD/uPGjaNevXp88MEHBAYGqpdfu3YtCxcuJDAwEGdnZ3WJpbS0NGbPnk3dunVp1aoVP/zwQ/5srCj0JPGJfFG7dm1Kly6tPupLS0vj3Llz9OjRg7S0NHXJ+pCQEO7du6cuVPnc6tWruXbtGvv27SMgICDD0d3QoUPp0qULbdq0ISgoSF3U8sCBA7Ro0YIzZ87g4eGBt7c3iYmJ+bTFojCTxCfyhVKppEmTJurEd/XqVZRKJVWqVKFhw4bq6adPn8be3p7KlStnWD8wMJCePXtSpkwZSpUqxbBhw3L9zNq1a9OyZUsMDQ1xc3MjLi6O0NBQ7W+cKHIk8Yl806JFC/Vp7enTp2ncuDEKhYJGjRqp+/lOnz5N8+bNM60bGhqqLl4JUKFChVw/z8nJSf3ayMgIQI74BCCJT+Sj5s2bExUVxY0bNzh16pS6dFHjxo25cOECiYmJnD17NtNpLqSXeH+ZJglMoVBoJ3Dx1pHEJ/KNjY0N1apV4/Tp01y5ckU98FKFChUwNzdnz549xMTEZDkgk62tbYbT1Lt37+Zb3OLtI4lP5KsWLVqwY8cO7O3tM5Tib9y4MZs3b872NpbmzZuza9cuHj16RHR0NGvXrs1wRGdkZMSDBw94+vSpukCmENmRxCfyVfPmzbl3716mCr2NGjXizp07WfbvAYwfP5733nuPjh070rVrVzp06ICJiYl6/kcffURISAitWrXi4cOHOt0GUfRJBWYhRLEjR3xCiGJHEp8QotiRxCeEKHYk8Qkhih1JfEKIYkcSnxCi2JHEJ4QodiTxCSGKnf8DIRIC8z2eyycAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 360x216 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "data = 'quadratic'\n",
    "result_path = os.path.join('/results/width-effect-results/')\n",
    "algos = [ 'NeuraLCB', 'NeuralTS', 'NeuraLMC'] \n",
    "algos_labels = [ '1. NeuraLCB', '2. NeuralTS', '3. Neural-PELPS']\n",
    "\n",
    "hidden_sizes = [16, 32, 64, 128]\n",
    "\n",
    "T = 5 # -1\n",
    "n = 4\n",
    "xtickers = ['m={}'.format(m) for m in hidden_sizes]\n",
    "\n",
    "res_per_hidden = [] # (h, algo, trial)\n",
    "# data_frs = []\n",
    "agg_data = []\n",
    "for j,hidden_size in enumerate(hidden_sizes): \n",
    "    res_per_algo = []\n",
    "    agg_data_per_algo = []\n",
    "    for k, algo in enumerate(algos): \n",
    "        data_path = os.path.join(result_path, 'width={}'.format(hidden_size),data, algo)\n",
    "        data_per_trial = []\n",
    "        for trial in range(n):\n",
    "            tmp = np.load(os.path.join(data_path, 'trial={}.npz'.format(trial)))['arr_2'][:,1][T]\n",
    "            data_per_trial.append(tmp)\n",
    "        res_per_algo.append( data_per_trial)\n",
    " \n",
    "        # data_frs.append([hidden_size, algos_labels[k], tmp[T]])\n",
    "        agg_data_per_algo.append(np.mean(np.array(data_per_trial))) \n",
    "\n",
    "    res_per_hidden.append(res_per_algo) \n",
    "    agg_data.append(agg_data_per_algo)\n",
    "\n",
    "res_per_hidden = np.array(res_per_hidden) # (h, algo,t)\n",
    "\n",
    "print(res_per_hidden.shape)\n",
    "\n",
    "mu = np.mean(res_per_hidden, axis=-1).T.ravel() # (h, a) \n",
    "std = np.std(res_per_hidden, axis=-1).T.ravel() / np.sqrt(res_per_hidden.shape[-1]) # (h,a)\n",
    "\n",
    "n_groups = len(hidden_sizes)\n",
    "n_cands = len(algos) \n",
    "group = ['ind={}'.format(m) for  i in range(n_cands) for m in range(len(hidden_sizes))]\n",
    "cands = [a for a in algos_labels for i in range(n_groups)]\n",
    "# print(group)\n",
    "# print(cands)\n",
    "# print(mu)\n",
    "# print(std)\n",
    "\n",
    "data = {'width': group,\n",
    "        'cands': cands,\n",
    "        'mu': mu,\n",
    "        'std': std}\n",
    "df = pd.DataFrame(data)\n",
    "\n",
    "print(df)\n",
    "\n",
    "vals = df.pivot(index='width', columns='cands', values='mu')\n",
    "yerr = df.pivot(index='width', columns='cands', values='std')\n",
    "\n",
    "plt.style.use('seaborn')\n",
    "# fig = plt.figure(figsize=(6, 4))\n",
    "\n",
    "# plot vals with yerr\n",
    "ax = vals.plot(kind='bar', yerr=yerr, logy=False, figsize=(5, 3), rot=0, width=0.8,\\\n",
    "    sort_columns=True, fontsize=14)\n",
    "_ = ax.legend(title='Algorithms', loc='upper left', edgecolor='black', fontsize=12, \\\n",
    "    title_fontsize=15,fancybox=True, frameon=True)\n",
    "\n",
    "ax.set_xticklabels(xtickers)\n",
    "ax.set_yticklabels([])\n",
    "\n",
    "# ax.set_yticks(np.array([500 * i for i in range(10)]))\n",
    "# ax.set_yticklabels(np.arange(0, 10, 1000))\n",
    "\n",
    "\n",
    "for i in range(len(hidden_sizes)): \n",
    "    for j in range(len(algos)):\n",
    "        if j < 2:\n",
    "            ax.text( -0.35 + j*0.36 + i , int(agg_data[i][j]) + 50 , round(agg_data[i][j]), color='black', ha='center', fontsize=9)\n",
    "        else:\n",
    "            ax.text( -0.35 + j*0.36 + i , int(agg_data[i][j]) + 50 , round(agg_data[i][j], 2), color='black', ha='center', fontsize=9)\n",
    "        \n",
    "\n",
    "ax.set_ylabel('Action selection time (s)', fontsize=14)\n",
    "ax.set_xlabel('Width', fontsize=14)\n",
    "\n",
    "ax.grid(axis='x')\n",
    "\n",
    "\n",
    "\n",
    "# plt.gca().invert_xaxis()\n",
    "\n",
    "# _ = ax.legend(title='Sample Set', bbox_to_anchor=(1, 1.02), loc='upper left')\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "fname = os.path.join(result_path, 'action_select_time_neurips.png')\n",
    "ax.figure.savefig(fname, bbox_inches='tight', dpi=400)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.9.12 ('venv')",
   "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.9.12"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "cf155ea7873fa76cf4d2709f415475ad30d3f8dd7e6ecb302d8ace816f0c7efb"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
