{
 "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_10_04_2024_07_49_18.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": [
      "1200\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>1195</th>\n",
       "      <td>QuantNaryTreeLearner_Standard_Teacher_exact_te...</td>\n",
       "      <td>random_PDFA_nominal_size_500_5</td>\n",
       "      <td>501</td>\n",
       "      <td>501</td>\n",
       "      <td>6</td>\n",
       "      <td>193.496870</td>\n",
       "      <td>108471</td>\n",
       "      <td>98</td>\n",
       "      <td>5</td>\n",
       "      <td>5</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>1196</th>\n",
       "      <td>QuantNaryTreeLearner_Standard_Teacher_exact_te...</td>\n",
       "      <td>random_PDFA_nominal_size_500_5</td>\n",
       "      <td>501</td>\n",
       "      <td>501</td>\n",
       "      <td>7</td>\n",
       "      <td>194.374816</td>\n",
       "      <td>108471</td>\n",
       "      <td>98</td>\n",
       "      <td>5</td>\n",
       "      <td>5</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>1197</th>\n",
       "      <td>QuantNaryTreeLearner_Standard_Teacher_exact_te...</td>\n",
       "      <td>random_PDFA_nominal_size_500_5</td>\n",
       "      <td>501</td>\n",
       "      <td>501</td>\n",
       "      <td>8</td>\n",
       "      <td>192.846274</td>\n",
       "      <td>108471</td>\n",
       "      <td>98</td>\n",
       "      <td>5</td>\n",
       "      <td>5</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>1198</th>\n",
       "      <td>QuantNaryTreeLearner_Standard_Teacher_exact_te...</td>\n",
       "      <td>random_PDFA_nominal_size_500_5</td>\n",
       "      <td>501</td>\n",
       "      <td>501</td>\n",
       "      <td>9</td>\n",
       "      <td>193.441047</td>\n",
       "      <td>108471</td>\n",
       "      <td>98</td>\n",
       "      <td>5</td>\n",
       "      <td>5</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>1199</th>\n",
       "      <td>QuantNaryTreeLearner_Standard_Teacher_exact_te...</td>\n",
       "      <td>random_PDFA_nominal_size_500_5</td>\n",
       "      <td>501</td>\n",
       "      <td>501</td>\n",
       "      <td>10</td>\n",
       "      <td>192.974353</td>\n",
       "      <td>108471</td>\n",
       "      <td>98</td>\n",
       "      <td>5</td>\n",
       "      <td>5</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",
       "1195  QuantNaryTreeLearner_Standard_Teacher_exact_te...   \n",
       "1196  QuantNaryTreeLearner_Standard_Teacher_exact_te...   \n",
       "1197  QuantNaryTreeLearner_Standard_Teacher_exact_te...   \n",
       "1198  QuantNaryTreeLearner_Standard_Teacher_exact_te...   \n",
       "1199  QuantNaryTreeLearner_Standard_Teacher_exact_te...   \n",
       "\n",
       "                            Instance  Number of States  \\\n",
       "1195  random_PDFA_nominal_size_500_5               501   \n",
       "1196  random_PDFA_nominal_size_500_5               501   \n",
       "1197  random_PDFA_nominal_size_500_5               501   \n",
       "1198  random_PDFA_nominal_size_500_5               501   \n",
       "1199  random_PDFA_nominal_size_500_5               501   \n",
       "\n",
       "      Extracted Number of States  RunNumber     Time(s)  LastTokenQuery  \\\n",
       "1195                         501          6  193.496870          108471   \n",
       "1196                         501          7  194.374816          108471   \n",
       "1197                         501          8  192.846274          108471   \n",
       "1198                         501          9  193.441047          108471   \n",
       "1199                         501         10  192.974353          108471   \n",
       "\n",
       "      EquivalenceQuery  Tree Depth  Inner Nodes  Accuracy_in_target  \\\n",
       "1195                98           5            5                 1.0   \n",
       "1196                98           5            5                 1.0   \n",
       "1197                98           5            5                 1.0   \n",
       "1198                98           5            5                 1.0   \n",
       "1199                98           5            5                 1.0   \n",
       "\n",
       "      Accuracy_anywhere  IsEquivalentExact  IsEquivalentOmitZero  IsMinimal  \n",
       "1195                1.0               True                  True       True  \n",
       "1196                1.0               True                  True       True  \n",
       "1197                1.0               True                  True       True  \n",
       "1198                1.0               True                  True       True  \n",
       "1199                1.0               True                  True       True  "
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(len(evaluation_data))\n",
    "evaluation_data.tail(5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def nearest_value(x, values):\n",
    "    return min(values, key=lambda y: abs(y - x))\n",
    "\n",
    "evaluation_data['Nominal_Size'] = evaluation_data['Number of States'].apply(lambda x: nearest_value(x, [250, 500,750,1000] ))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "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": 7,
   "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', 'Nominal_Size']).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": 8,
   "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', 'Nominal_Size', 'TREE_SIZE'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "evaluation_data.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "12"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(grouped_multiple)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "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": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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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', 'Nominal_Size'])['Time(s)'].quantile([0.25, 0.5, 0.75]).unstack(level=0)\n",
    "\n",
    "# Calculate means\n",
    "means = evaluation_data_exact.groupby(['Algorithm', 'Nominal_Size'])['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(\"Nominal Size\", 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
}
