{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Data Loading"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "evaluation_data = pd.read_csv('./results/results_09_04_2024_19_10_29.csv')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Results Analysis"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "evaluation_data.drop('Unnamed: 0', axis = 1, inplace = True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1500\n"
     ]
    },
    {
     "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>Algorithm</th>\n",
       "      <th>Instance</th>\n",
       "      <th>Number of States</th>\n",
       "      <th>Extracted Number of States</th>\n",
       "      <th>RunNumber</th>\n",
       "      <th>Time(s)</th>\n",
       "      <th>LastTokenQuery</th>\n",
       "      <th>EquivalenceQuery</th>\n",
       "      <th>Tree Depth</th>\n",
       "      <th>Inner Nodes</th>\n",
       "      <th>Accuracy_in_target</th>\n",
       "      <th>Accuracy_anywhere</th>\n",
       "      <th>IsEquivalentExact</th>\n",
       "      <th>IsEquivalentOmitZero</th>\n",
       "      <th>IsMinimal</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1490</th>\n",
       "      <td>QuantNaryTreeLearner_Standard_Teacher_exact_te...</td>\n",
       "      <td>random_PDFA_nominal_size_0_98_9</td>\n",
       "      <td>501</td>\n",
       "      <td>501</td>\n",
       "      <td>1</td>\n",
       "      <td>334.080285</td>\n",
       "      <td>688989</td>\n",
       "      <td>72</td>\n",
       "      <td>16</td>\n",
       "      <td>16</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1491</th>\n",
       "      <td>QuantNaryTreeLearner_Standard_Teacher_exact_te...</td>\n",
       "      <td>random_PDFA_nominal_size_0_98_9</td>\n",
       "      <td>501</td>\n",
       "      <td>501</td>\n",
       "      <td>2</td>\n",
       "      <td>335.863449</td>\n",
       "      <td>688989</td>\n",
       "      <td>72</td>\n",
       "      <td>16</td>\n",
       "      <td>16</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1492</th>\n",
       "      <td>QuantNaryTreeLearner_Standard_Teacher_exact_te...</td>\n",
       "      <td>random_PDFA_nominal_size_0_98_9</td>\n",
       "      <td>501</td>\n",
       "      <td>501</td>\n",
       "      <td>3</td>\n",
       "      <td>334.376774</td>\n",
       "      <td>688989</td>\n",
       "      <td>72</td>\n",
       "      <td>16</td>\n",
       "      <td>16</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1493</th>\n",
       "      <td>QuantNaryTreeLearner_Standard_Teacher_exact_te...</td>\n",
       "      <td>random_PDFA_nominal_size_0_98_9</td>\n",
       "      <td>501</td>\n",
       "      <td>501</td>\n",
       "      <td>4</td>\n",
       "      <td>334.983923</td>\n",
       "      <td>688989</td>\n",
       "      <td>72</td>\n",
       "      <td>16</td>\n",
       "      <td>16</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1494</th>\n",
       "      <td>QuantNaryTreeLearner_Standard_Teacher_exact_te...</td>\n",
       "      <td>random_PDFA_nominal_size_0_98_9</td>\n",
       "      <td>501</td>\n",
       "      <td>501</td>\n",
       "      <td>5</td>\n",
       "      <td>339.801847</td>\n",
       "      <td>688989</td>\n",
       "      <td>72</td>\n",
       "      <td>16</td>\n",
       "      <td>16</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1495</th>\n",
       "      <td>QuantNaryTreeLearner_Standard_Teacher_exact_te...</td>\n",
       "      <td>random_PDFA_nominal_size_0_98_9</td>\n",
       "      <td>501</td>\n",
       "      <td>501</td>\n",
       "      <td>6</td>\n",
       "      <td>335.539221</td>\n",
       "      <td>688989</td>\n",
       "      <td>72</td>\n",
       "      <td>16</td>\n",
       "      <td>16</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1496</th>\n",
       "      <td>QuantNaryTreeLearner_Standard_Teacher_exact_te...</td>\n",
       "      <td>random_PDFA_nominal_size_0_98_9</td>\n",
       "      <td>501</td>\n",
       "      <td>501</td>\n",
       "      <td>7</td>\n",
       "      <td>336.278840</td>\n",
       "      <td>688989</td>\n",
       "      <td>72</td>\n",
       "      <td>16</td>\n",
       "      <td>16</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1497</th>\n",
       "      <td>QuantNaryTreeLearner_Standard_Teacher_exact_te...</td>\n",
       "      <td>random_PDFA_nominal_size_0_98_9</td>\n",
       "      <td>501</td>\n",
       "      <td>501</td>\n",
       "      <td>8</td>\n",
       "      <td>337.365689</td>\n",
       "      <td>688989</td>\n",
       "      <td>72</td>\n",
       "      <td>16</td>\n",
       "      <td>16</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1498</th>\n",
       "      <td>QuantNaryTreeLearner_Standard_Teacher_exact_te...</td>\n",
       "      <td>random_PDFA_nominal_size_0_98_9</td>\n",
       "      <td>501</td>\n",
       "      <td>501</td>\n",
       "      <td>9</td>\n",
       "      <td>337.097750</td>\n",
       "      <td>688989</td>\n",
       "      <td>72</td>\n",
       "      <td>16</td>\n",
       "      <td>16</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1499</th>\n",
       "      <td>QuantNaryTreeLearner_Standard_Teacher_exact_te...</td>\n",
       "      <td>random_PDFA_nominal_size_0_98_9</td>\n",
       "      <td>501</td>\n",
       "      <td>501</td>\n",
       "      <td>10</td>\n",
       "      <td>334.838432</td>\n",
       "      <td>688989</td>\n",
       "      <td>72</td>\n",
       "      <td>16</td>\n",
       "      <td>16</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                              Algorithm  \\\n",
       "1490  QuantNaryTreeLearner_Standard_Teacher_exact_te...   \n",
       "1491  QuantNaryTreeLearner_Standard_Teacher_exact_te...   \n",
       "1492  QuantNaryTreeLearner_Standard_Teacher_exact_te...   \n",
       "1493  QuantNaryTreeLearner_Standard_Teacher_exact_te...   \n",
       "1494  QuantNaryTreeLearner_Standard_Teacher_exact_te...   \n",
       "1495  QuantNaryTreeLearner_Standard_Teacher_exact_te...   \n",
       "1496  QuantNaryTreeLearner_Standard_Teacher_exact_te...   \n",
       "1497  QuantNaryTreeLearner_Standard_Teacher_exact_te...   \n",
       "1498  QuantNaryTreeLearner_Standard_Teacher_exact_te...   \n",
       "1499  QuantNaryTreeLearner_Standard_Teacher_exact_te...   \n",
       "\n",
       "                             Instance  Number of States  \\\n",
       "1490  random_PDFA_nominal_size_0_98_9               501   \n",
       "1491  random_PDFA_nominal_size_0_98_9               501   \n",
       "1492  random_PDFA_nominal_size_0_98_9               501   \n",
       "1493  random_PDFA_nominal_size_0_98_9               501   \n",
       "1494  random_PDFA_nominal_size_0_98_9               501   \n",
       "1495  random_PDFA_nominal_size_0_98_9               501   \n",
       "1496  random_PDFA_nominal_size_0_98_9               501   \n",
       "1497  random_PDFA_nominal_size_0_98_9               501   \n",
       "1498  random_PDFA_nominal_size_0_98_9               501   \n",
       "1499  random_PDFA_nominal_size_0_98_9               501   \n",
       "\n",
       "      Extracted Number of States  RunNumber     Time(s)  LastTokenQuery  \\\n",
       "1490                         501          1  334.080285          688989   \n",
       "1491                         501          2  335.863449          688989   \n",
       "1492                         501          3  334.376774          688989   \n",
       "1493                         501          4  334.983923          688989   \n",
       "1494                         501          5  339.801847          688989   \n",
       "1495                         501          6  335.539221          688989   \n",
       "1496                         501          7  336.278840          688989   \n",
       "1497                         501          8  337.365689          688989   \n",
       "1498                         501          9  337.097750          688989   \n",
       "1499                         501         10  334.838432          688989   \n",
       "\n",
       "      EquivalenceQuery  Tree Depth  Inner Nodes  Accuracy_in_target  \\\n",
       "1490                72          16           16                 1.0   \n",
       "1491                72          16           16                 1.0   \n",
       "1492                72          16           16                 1.0   \n",
       "1493                72          16           16                 1.0   \n",
       "1494                72          16           16                 1.0   \n",
       "1495                72          16           16                 1.0   \n",
       "1496                72          16           16                 1.0   \n",
       "1497                72          16           16                 1.0   \n",
       "1498                72          16           16                 1.0   \n",
       "1499                72          16           16                 1.0   \n",
       "\n",
       "      Accuracy_anywhere  IsEquivalentExact  IsEquivalentOmitZero  IsMinimal  \n",
       "1490                1.0               True                  True       True  \n",
       "1491                1.0               True                  True       True  \n",
       "1492                1.0               True                  True       True  \n",
       "1493                1.0               True                  True       True  \n",
       "1494                1.0               True                  True       True  \n",
       "1495                1.0               True                  True       True  \n",
       "1496                1.0               True                  True       True  \n",
       "1497                1.0               True                  True       True  \n",
       "1498                1.0               True                  True       True  \n",
       "1499                1.0               True                  True       True  "
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(len(evaluation_data))\n",
    "evaluation_data.tail(10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['Algorithm', 'Instance', 'Number of States',\n",
       "       'Extracted Number of States', 'RunNumber', 'Time(s)', 'LastTokenQuery',\n",
       "       'EquivalenceQuery', 'Tree Depth', 'Inner Nodes', 'Accuracy_in_target',\n",
       "       'Accuracy_anywhere', 'IsEquivalentExact', 'IsEquivalentOmitZero',\n",
       "       'IsMinimal'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "evaluation_data.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "QuantNaryTreeLearner_Omit_Zero_Transitions_exact_teacher    500\n",
       "QuantNaryTreeLearner_Teacher_Filter_exact                   500\n",
       "QuantNaryTreeLearner_Standard_Teacher_exact_teacher         500\n",
       "Name: Algorithm, dtype: int64"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "evaluation_data['Algorithm'].value_counts()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_prob(x):\n",
    "    splitted = x.split('_')\n",
    "    return float(\"0.\"+splitted[5])\n",
    "\n",
    "evaluation_data['Zero_Probability'] = evaluation_data['Instance'].apply(lambda x: get_prob(x))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "import math\n",
    "\n",
    "evaluation_data['TREE_SIZE'] = evaluation_data['Inner Nodes']+evaluation_data['Extracted Number of States']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "def IQR(data):\n",
    "    Q1 = data.quantile(0.25)\n",
    "    Q3 = data.quantile(0.75)\n",
    "    res = Q3 - Q1\n",
    "    return res\n",
    "\n",
    "cols_to_agg = ['Time(s)', 'LastTokenQuery', 'EquivalenceQuery', 'Extracted Number of States', 'Accuracy_in_target', 'Accuracy_anywhere', 'TREE_SIZE']\n",
    "funcs =  ['median', IQR]  \n",
    "names = ['median', 'IQR']  \n",
    "grouped_multiple = evaluation_data.groupby(['Algorithm', 'Zero_Probability']).agg({x:funcs for x in cols_to_agg})\n",
    "col_names = [x+\"_\"+fun_name for x in cols_to_agg for fun_name in names]\n",
    "grouped_multiple.columns = col_names\n",
    "#grouped_multiple.columns = ['Time(s)_median','Time(s)_IQR', 'MembershipQuery_median', 'MembershipQuery_IQR', \n",
    "#'EquivalenceQuery_median', 'EquivalenceQuery_IQR', 'Extracted Number of States_median', 'Extracted Number of States_IQR',]\n",
    "grouped_multiple.reset_index(inplace = True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['Algorithm', 'Instance', 'Number of States',\n",
       "       'Extracted Number of States', 'RunNumber', 'Time(s)', 'LastTokenQuery',\n",
       "       'EquivalenceQuery', 'Tree Depth', 'Inner Nodes', 'Accuracy_in_target',\n",
       "       'Accuracy_anywhere', 'IsEquivalentExact', 'IsEquivalentOmitZero',\n",
       "       'IsMinimal', 'Zero_Probability', 'TREE_SIZE'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "evaluation_data.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "evaluation_data_exact = evaluation_data[evaluation_data[\"Algorithm\"].apply(lambda x: 'exact' in str(x))]\n",
    "evaluation_data_sampling =  evaluation_data[evaluation_data[\"Algorithm\"].apply(lambda x: 'exact' not in str(x))]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Km9+vI+kdCsRwWamPtKV6KiAShOot99+m2PHjrF48WIaNGiALMts3LiRUaNGsWrVKqKiokpd1wcffKBEi9yzZ0+h59x///3cf//9yvvNmzczc+ZMJcZ7ZRIQEMCGDRuAa4Hv8t5XNc8995zyet++fcTGxhYoVymZS1mJBexMP1/4jfiMC8r7O5reSqOA0n9Py0q9Eqd1353i823HsDncxZ43+e9d+HDD7ySle6auSelW3vx4H+OHtuetT38u9lqzUcv9/Vtxb+/YIs+5cuUKX3zxBd999x2BgZ67jkajYdiwYRw5coTFixfz+uuv07dvXwYPHsxPP/1EZmYm48eP55dffuGPP/5Ap9OxcOFCIiMj6du3L2+//bbizzRu3DiWLFlCgwYNCm3/t99+Y9q0aSxatEiJGPDLL78wd+5crFYrGo2Gp59+mj59+hSI7bR06VL++9//smXLFrRaLc2aNeO1117zigNfEn379qVDhw4cP36cF198EZ1Ox+LFi3E4HKSlpTFs2DCef/559u3bx7///W+io6M5efIkLpeL6dOn06lTJw4cOMDs2bORZc/+rQkTJjBgwABeeeUV4uLiMJlMHDlyhDlz5qDVatmxYwdxcXH84x//KDaO1TfffINGoyE+Ph6TycTbb79NTEwMX3/9NQsXLkSSJLRaLS+//DK33nprqcdcm0jLyeBcxnnkfJtHjiaf4nDitfyBHSJb0Tq86O94ZVCvbE7rd50qUZgA/H30ijDlkZRuxd+n5F31Vrub9btOFXvOb7/9RvPmzRVhyk/37t294i/b7XZWrlzJc889x7Rp0xg3bhwbN26kQYMGStqtPGbNmgXA//73vyKFKTExkaeeeopXXnlF2eSbmZnJq6++ypw5c1i3bh3vv/8+//znP7l06RIAp06dYunSpSxdupQ1a9bwww8/sHr1ajZt2kRcXByvvPJKiX+X64mLi+Orr76iX79+fPzxx8yePZu1a9eyYsUKlixZomxePnLkCI888gjr169n+PDhzJs3D4B3332Xhx9+mLVr1/LWW2/x008/edX/wAMP0K5dO15++WUldAt4Nj8/++yzTJkyhU2bNvH2228zceJEzp8/D8D+/ft57bXX2Lx5MzfffDNLliwBYM6cObz++uusXbuW5557jn379pV5zLWBPDuTI5+d6eLVK+xO2K+8jw5qTJfG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kZiYyCuvvEJSUhINGzb0Cvq2evVqVqxYgdPpJDMzk0cffZQxY8awdu1aVq9ejdVqxc/Pj48//pg333yTvXv3EhoaSmhoqBKl83pWrlxJt27dGDBgAPPnz2f06NEFjKput5s5c+awc+dO/P396dChA6dPn2bp0qVcuXKFf/7zn1y8eBEhBMOGDWP8+PFcunSJ8ePHExMTw8WLF5k9ezaPPPIIBw4cYOrUqSQmJvKPf/yD6dOn43a7mTZtGr///jtZWVlMnDiRAQMG8O6775KQkEBiYiLJycm0bduWrl27sn79ei5cuMDEiROViA01HYfbyZm0BH65dITfE48p5R0iW9MqPLZMdTXMTUig09bMOUqJ04BDhw7Rr18/JkyYQGJiIr179+aXX34p6bIayebj20sUJvBEB8wTpjySc9LwK0X8GpvLzubj24s9JzAwkIkTJzJ+/HjuvPNOJk6cyJo1a+jevTsGg4FZs2YB8L///Y+oqCg+/vhjZs+ezdq1a1mxYgVLlixRlkmHDx/mkUceYfny5QwfPpx58+YB8MYbb3DzzTezZcsWpk6dqswwLBYLq1atYsmSJaxfv5558+bxr3/9S+nbqVOnWLp0KUuXLuXzzz/n3LlzbNmyhY8//pjLly9TGC6Xi5UrV3LPPffQt29fUlNT+f777wuct2rVKv744w82b97MF198wfnz55VjL730El27dmXTpk0sX76cjRs3KuGLr1y5wpNPPsm2bduUDeJarZY333yTpk2bKpvQ7XY7t99+O+vWrWPSpEle4zp48CD//e9/WbduHd9//z2nT59m2bJlvPbaa7z77rvFfl41BSEE5zMvcejKH+yO36+U3xTUmK6NO5aprii/CGJCKzchQWVTojjNmTOHTz/9lKCgIKKiopgzZw4zZ86sjr5VOoNb9sOkLTnWcbYjh3Afb5f9cJ8Qsh0l7yk06YwMbln0rCmPhx9+mD179jB16lTCw8P54IMPGDZsmOKykYckSSxatIg//viD9957j9mzZyOEUOw6DRs2VIK7tWnThsxMTwD7vXv3Mnz4cMCzp61r164A+Pr6smjRInbt2sU777zDokWLvGZwLVu2xM/PExLjxx9/ZPDgwRgMBnx8fBgyZEihY9mxYweyLNOjRw8MBgN33XUXn332WYHzdu3axdChQzEajRgMBsWBNycnh19++YUH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/P39C5TXenGSZRmLxYJery+TX5SKisqNRQiB0+nE19cXjaaghanWi5OKikrdRDWIq6io1EhUcVJRUamRqOKkoqJSI1HFSUVFpUaiipOKikqNRBUnFRWVGokqTioqKjUSVZxUVFRqJHVKnDZt2sRdd91F//79WbZsWYHju3btUiIf/N///R8WiwWAS5cu8cADDzBw4ECeeOIJpbymUN5xHTx4kJEjRzJ06FDGjRvHxYsXq7vrxVLeceXx559/0q5du+rqbpko79iSkpJ47LHHGDZsGKNHj+bChQvV3fViKe+4Lly4wAMPPMDQoUMZO3Zs6b6Loo5w5coV0adPH5Geni4sFosYMmSIOHnypHI8MzNT3HbbbUrZkiVLxIwZM4QQQjz22GNi8+bNQggh3nvvPTFnzpzqH0ARVGRcffr0EUePHhVCCLFq1Srx+OOPV/8AiqAi4xJCiJycHDF69GjRokWLau97SVRkbOPGjROff/65EEKIzz//XDz33HPV3v+iqMi4XnrpJbFs2TIhhBCfffaZ+L//+78S26szM6f82Vt8fHyU7C15nDt3joYNGyqppvr06cP27dtxOp3s37+fAQMGADB8+HCv62405R2Xw+Hgueeeo1WrVgC0bNmSy5cv35AxFEZ5x5XH7NmzGTduXLX3uzSUd2xpaWkcO3aM0aNHAzBixAief/75GzGEQqnIZybLMtnZ2QBYrVZMppIzstQZcSose0tiYqLy/qabbuLKlSscO3YMgK+++oqUlBTS09Px8/NDp/NEjwkPD/e67kZT3nEZDAaGDh0KeL4Y7733Hv369avezhdDeccFsGPHDmw2GwMHDqzeTpeS8o7t/PnzNGzYkNmzZzNixAieffZZ9PqakzKqIp/Zc889x6effkqPHj34+OOPefTRR0tsr86IU0nZWwICAnj77bd57bXXGDFiBBEREej1+kKzvNSk6AblHVceDoeDl156CZfLxYQJE6q178VR3nElJyezcOFCXnvttRvR7VJR3rG5XC7+/PNPbrvtNtasWcOdd97JK6+8ciOGUCgV+S5OmjSJN954gx9++IHp06fz9NNPFxnHKY9aH2wuj5Kyt7jdbqKioli1ahUAhw8fpkmTJoSEhJCVlYXb7Uar1ZY560tVU95xAVgsFp544gmCgoJYuHBhjboLl3dc3333HRkZGV6p6ocOHcqy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",
      "text/plain": [
       "<Figure size 308.16x238.176 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set(rc={'figure.figsize':(10.7/2.5,8.27/2.5)})\n",
    "sns.set_style(\"whitegrid\")\n",
    "# Compute quartiles\n",
    "quartiles = evaluation_data_exact.groupby(['Algorithm', 'Zero_Probability'])['Time(s)'].quantile([0.25, 0.5, 0.75]).unstack(level=0)\n",
    "\n",
    "# Calculate means\n",
    "means = evaluation_data_exact.groupby(['Algorithm', 'Zero_Probability'])['Time(s)'].median().unstack(level=0)\n",
    "\n",
    "# Plot quartiles with error bars\n",
    "for algo in evaluation_data_exact['Algorithm'].unique():\n",
    "    sns.lineplot(data=means[algo], marker='o', label=algo, linewidth = 3)\n",
    "    #plt.errorbar(x=means.index, y=means[algo], yerr=[means[algo] - quartiles[algo].loc[:,0.25], quartiles[algo].loc[:,0.75] - means[algo]], fmt='o')\n",
    "    plt.fill_between(x=means.index, y1=quartiles[algo].loc[:,0.25], y2= quartiles[algo].loc[:,0.75], alpha = 0.4)\n",
    "\n",
    "plt.legend(title='Algorithm', fontsize=12, frameon=True, loc = 'upper left')\n",
    "plt.xlabel(\"Zero Probability\", fontsize=12)\n",
    "plt.ylabel(\"Learning Time (s)\", fontsize=12)\n",
    "\n",
    "new_labels = [\"Omit Zero Transitions\",\" Teacher Filter\",\"Standard Algorithm\"]\n",
    "for t, l in zip(plt.gca().get_legend().get_texts(), new_labels):\n",
    "    t.set_text(l)\n",
    "\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "ccd85e264f409eb34496ed1f618ace649acf293164c04c6c014b744b9959793c"
  },
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
