{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import os\n",
    "import shutil\n",
    "import glob\n",
    "import numpy as np\n",
    "\n",
    "folder_list = [\"/root/main/ranking/sim/random_1000_16_100\",\n",
    "               \"/root/main/ranking/sim/separated_32_100\",\n",
    "               \"/root/main/ranking/sim/g2_32_10_trunc\",\n",
    "               \"/root/main/ranking/sim/g2_32_30_trunc\",\n",
    "               \"/root/main/ranking/sim/g2_32_70_trunc\",\n",
    "               \"/root/main/ranking/sim/g2_32_100_trunc\"\n",
    "               ]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "def fmt_fn(ls):\n",
    "    if np.mean(ls) > 1:\n",
    "        return f\"{np.mean(ls):.0f} ({np.std(ls):.0f})\"\n",
    "    else:\n",
    "        return f\"{np.mean(ls):.3f} ({np.std(ls):.3f})\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/root/main/ranking/sim/random_1000_16_100/results_eps.csv\n",
      "/root/main/ranking/sim/random_1000_16_100/noinf_results_k.csv\n",
      "/root/main/ranking/sim/random_1000_16_100/dkwt_final_results_eps.csv\n",
      "/root/main/ranking/sim/random_1000_16_100/results_sharpness.csv\n",
      "/root/main/ranking/sim/random_1000_16_100/noinf_results_n.csv\n",
      "/root/main/ranking/sim/random_1000_16_100/dkwt_final_results_k.csv\n",
      "/root/main/ranking/sim/random_1000_16_100/noinf_results_eps.csv\n",
      "/root/main/ranking/sim/random_1000_16_100/noinf_results_sharpness.csv\n",
      "/root/main/ranking/sim/random_1000_16_100/results_n.csv\n",
      "/root/main/ranking/sim/random_1000_16_100/dkwt_final_results_sharpness.csv\n",
      "/root/main/ranking/sim/random_1000_16_100/dkwt_final_results_n.csv\n",
      "/root/main/ranking/sim/random_1000_16_100/results_k.csv\n",
      "12\n",
      "/root/main/ranking/sim/separated_32_100/results_eps.csv\n",
      "/root/main/ranking/sim/separated_32_100/dkwt_final_results_eps.csv\n",
      "/root/main/ranking/sim/separated_32_100/results_corr_noise.csv\n",
      "/root/main/ranking/sim/separated_32_100/noinf_results_eps.csv\n",
      "4\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_68380/2070249912.py:28: FutureWarning: In future versions `DataFrame.to_latex` is expected to utilise the base implementation of `Styler.to_latex` for formatting and rendering. The arguments signature may therefore change. It is recommended instead to use `DataFrame.style.to_latex` which also contains additional functionality.\n",
      "  out = df.to_latex(na_rep='', index=False, escape=False, column_format = 'l'*len(df.columns))\n",
      "/tmp/ipykernel_68380/2070249912.py:28: FutureWarning: In future versions `DataFrame.to_latex` is expected to utilise the base implementation of `Styler.to_latex` for formatting and rendering. The arguments signature may therefore change. It is recommended instead to use `DataFrame.style.to_latex` which also contains additional functionality.\n",
      "  out = df.to_latex(na_rep='', index=False, escape=False, column_format = 'l'*len(df.columns))\n"
     ]
    }
   ],
   "source": [
    "dataset_mapping = {'random_1000_16_100': '$N^{16}$', 'separated_32_100': 'DIM',\n",
    "                   'g2_32_10_trunc': 'g2: var=10',\n",
    "                   'g2_32_30_trunc': 'g2: var=30',\n",
    "                   'g2_32_70_trunc': 'g2: var=70',\n",
    "                   'g2_32_100_trunc': 'g2: var=100'}\n",
    "models = {'\\textit{DKWT}': 'dkwt_final_results', '\\textit{DEBC}': 'results', '\\textit{DE}': 'noinf_results'}\n",
    "name_mapping = {'num_steps': 'Sample Complexity', 'delta': '$\\delta$', 'eps':'$\\epsilon$', 'k':'$n_s$', 'num_items_pruned_from_inf': 'No. of pruned \\newline unplayed items', 'num_valid_items': 'No. of valid \\newline items'}\n",
    "fmt_dict = {k: fmt_fn for k in ['num_steps']}\n",
    "# fmt_dict.update({k:lambda x: f\"{np.mean(x):.3f}\" for k in ['num_items_pruned_from_inf', 'num_valid_items', 'success rate']})\n",
    "fmt_dict.update({k:lambda x: f\"{np.mean(x):.3f}\" for k in ['$\\\\frac{1}{2} - p_{i^{*}1}$', 'success rate']})\n",
    "for folder in folder_list[0:2]:\n",
    "    df_list = []\n",
    "    files = glob.glob(os.path.join(folder,'*.csv'))\n",
    "    for file in files:\n",
    "        df_tmp = pd.read_csv(file)\n",
    "        for k,v in models.items():\n",
    "            if file.split('/')[-1].startswith(v):\n",
    "                print(file)\n",
    "                df_tmp['Algorithm'] = k\n",
    "                df_tmp['$\\\\frac{1}{2} - p_{i^{*}1}$'] = -df_tmp['pr_diff']\n",
    "                df_tmp['success rate'] = df_tmp['pr_diff'].abs() <df_tmp['eps']\n",
    "                df_list.append(df_tmp)\n",
    "                break\n",
    "    print(len(df_list))\n",
    "    df = pd.concat(df_list, ignore_index=True)\n",
    "    df = df.groupby(['eps', 'k', 'n', 'delta', 'Algorithm'], as_index=False).agg(fmt_dict)\n",
    "    df = df.rename(name_mapping, axis = 1)\n",
    "    out = df.to_latex(na_rep='', index=False, escape=False, column_format = 'l'*len(df.columns))\n",
    "    with open(os.path.join(\"/root/main/ranking/tables\", f\"{folder.split('/')[-1]}.txt\"), \"w\") as text_file:\n",
    "        text_file.write(out)\n",
    "    \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_68380/1956879913.py:20: FutureWarning: In future versions `DataFrame.to_latex` is expected to utilise the base implementation of `Styler.to_latex` for formatting and rendering. The arguments signature may therefore change. It is recommended instead to use `DataFrame.style.to_latex` which also contains additional functionality.\n",
      "  out = df.to_latex(na_rep='', index=False, escape=False, column_format = 'l'*len(df.columns))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/root/main/ranking/sim/g2_32_10_trunc/results_eps.csv\n",
      "/root/main/ranking/sim/g2_32_10_trunc/dkwt_final_results_eps.csv\n",
      "/root/main/ranking/sim/g2_32_10_trunc/noinf_results_eps.csv\n",
      "3\n",
      "/root/main/ranking/sim/g2_32_30_trunc/results_eps.csv\n",
      "/root/main/ranking/sim/g2_32_30_trunc/dkwt_final_results_eps.csv\n",
      "/root/main/ranking/sim/g2_32_30_trunc/noinf_results_eps.csv\n",
      "/root/main/ranking/sim/g2_32_30_trunc/results_eps copy.csv\n",
      "7\n",
      "/root/main/ranking/sim/g2_32_70_trunc/results_eps.csv\n",
      "/root/main/ranking/sim/g2_32_70_trunc/dkwt_final_results_eps.csv\n",
      "/root/main/ranking/sim/g2_32_70_trunc/noinf_results_eps.csv\n",
      "10\n",
      "/root/main/ranking/sim/g2_32_100_trunc/results_eps.csv\n",
      "/root/main/ranking/sim/g2_32_100_trunc/dkwt_final_results_eps.csv\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_68380/1956879913.py:20: FutureWarning: In future versions `DataFrame.to_latex` is expected to utilise the base implementation of `Styler.to_latex` for formatting and rendering. The arguments signature may therefore change. It is recommended instead to use `DataFrame.style.to_latex` which also contains additional functionality.\n",
      "  out = df.to_latex(na_rep='', index=False, escape=False, column_format = 'l'*len(df.columns))\n",
      "/tmp/ipykernel_68380/1956879913.py:20: FutureWarning: In future versions `DataFrame.to_latex` is expected to utilise the base implementation of `Styler.to_latex` for formatting and rendering. The arguments signature may therefore change. It is recommended instead to use `DataFrame.style.to_latex` which also contains additional functionality.\n",
      "  out = df.to_latex(na_rep='', index=False, escape=False, column_format = 'l'*len(df.columns))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/root/main/ranking/sim/g2_32_100_trunc/noinf_results_eps.csv\n",
      "13\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_68380/1956879913.py:20: FutureWarning: In future versions `DataFrame.to_latex` is expected to utilise the base implementation of `Styler.to_latex` for formatting and rendering. The arguments signature may therefore change. It is recommended instead to use `DataFrame.style.to_latex` which also contains additional functionality.\n",
      "  out = df.to_latex(na_rep='', index=False, escape=False, column_format = 'l'*len(df.columns))\n"
     ]
    }
   ],
   "source": [
    "df_list = []\n",
    "for folder in folder_list[2:]:\n",
    "    files = glob.glob(os.path.join(folder,'*.csv'))\n",
    "    for file in files:\n",
    "        df_tmp = pd.read_csv(file)\n",
    "        for k,v in models.items():\n",
    "            if file.split('/')[-1].startswith(v):\n",
    "                print(file)\n",
    "                df_tmp['Algorithm'] = k\n",
    "                df_tmp['$\\\\frac{1}{2} - p_{i^{*}1}$'] = -df_tmp['pr_diff']\n",
    "                df_tmp['success rate'] = df_tmp['pr_diff'].abs() <df_tmp['eps']\n",
    "                var = folder.split('_')[-2]\n",
    "                df_tmp['var'] = int(var)\n",
    "                df_list.append(df_tmp)\n",
    "                break\n",
    "    print(len(df_list))\n",
    "    df = pd.concat(df_list, ignore_index=True)\n",
    "    df = df.groupby(['var', 'eps', 'k', 'n', 'delta', 'Algorithm'], as_index=False).agg(fmt_dict)\n",
    "    df = df.rename(name_mapping, axis = 1)\n",
    "    out = df.to_latex(na_rep='', index=False, escape=False, column_format = 'l'*len(df.columns))\n",
    "    with open(os.path.join(\"/root/main/ranking/tables\", \"g2.txt\"), \"w\") as text_file:\n",
    "        text_file.write(out)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "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>var</th>\n",
       "      <th>$\\epsilon$</th>\n",
       "      <th>$n_s$</th>\n",
       "      <th>n</th>\n",
       "      <th>$\\delta$</th>\n",
       "      <th>Algorithm</th>\n",
       "      <th>Sample Complexity</th>\n",
       "      <th>$\\frac{1}{2} - p_{i^{*}1}$</th>\n",
       "      <th>success rate</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>10</td>\n",
       "      <td>0.02</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DEBC}</td>\n",
       "      <td>570106 (241080)</td>\n",
       "      <td>0.008</td>\n",
       "      <td>0.908</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>10</td>\n",
       "      <td>0.02</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DE}</td>\n",
       "      <td>620582 (194788)</td>\n",
       "      <td>0.004</td>\n",
       "      <td>0.980</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>10</td>\n",
       "      <td>0.02</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DKWT}</td>\n",
       "      <td>16095899 (960872)</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>10</td>\n",
       "      <td>0.05</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DEBC}</td>\n",
       "      <td>140091 (48478)</td>\n",
       "      <td>0.014</td>\n",
       "      <td>0.990</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>10</td>\n",
       "      <td>0.05</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DE}</td>\n",
       "      <td>159971 (45508)</td>\n",
       "      <td>0.008</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>10</td>\n",
       "      <td>0.05</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DKWT}</td>\n",
       "      <td>4018854 (57767)</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>10</td>\n",
       "      <td>0.10</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DEBC}</td>\n",
       "      <td>36426 (10580)</td>\n",
       "      <td>0.019</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>10</td>\n",
       "      <td>0.10</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DE}</td>\n",
       "      <td>47141 (10466)</td>\n",
       "      <td>0.016</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>10</td>\n",
       "      <td>0.10</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DKWT}</td>\n",
       "      <td>940636 (7077)</td>\n",
       "      <td>0.002</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>30</td>\n",
       "      <td>0.02</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DEBC}</td>\n",
       "      <td>61441 (39533)</td>\n",
       "      <td>0.003</td>\n",
       "      <td>0.970</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>30</td>\n",
       "      <td>0.02</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DE}</td>\n",
       "      <td>73432 (40950)</td>\n",
       "      <td>0.002</td>\n",
       "      <td>0.980</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>30</td>\n",
       "      <td>0.02</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DKWT}</td>\n",
       "      <td>4846755 (2611789)</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>30</td>\n",
       "      <td>0.05</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DEBC}</td>\n",
       "      <td>45199 (27385)</td>\n",
       "      <td>0.013</td>\n",
       "      <td>0.879</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>30</td>\n",
       "      <td>0.05</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DE}</td>\n",
       "      <td>55288 (26533)</td>\n",
       "      <td>0.004</td>\n",
       "      <td>0.970</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>30</td>\n",
       "      <td>0.05</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DKWT}</td>\n",
       "      <td>1990971 (736651)</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>30</td>\n",
       "      <td>0.10</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DEBC}</td>\n",
       "      <td>24834 (11949)</td>\n",
       "      <td>0.040</td>\n",
       "      <td>0.793</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>30</td>\n",
       "      <td>0.10</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DE}</td>\n",
       "      <td>23816 (7679)</td>\n",
       "      <td>0.004</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>30</td>\n",
       "      <td>0.10</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DKWT}</td>\n",
       "      <td>688586 (166016)</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>70</td>\n",
       "      <td>0.02</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DEBC}</td>\n",
       "      <td>28707 (10207)</td>\n",
       "      <td>0.003</td>\n",
       "      <td>0.990</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>70</td>\n",
       "      <td>0.02</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DE}</td>\n",
       "      <td>28271 (10464)</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>70</td>\n",
       "      <td>0.02</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DKWT}</td>\n",
       "      <td>2111053 (1438009)</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>70</td>\n",
       "      <td>0.05</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DEBC}</td>\n",
       "      <td>18223 (11575)</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>70</td>\n",
       "      <td>0.05</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DE}</td>\n",
       "      <td>16690 (10883)</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>70</td>\n",
       "      <td>0.05</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DKWT}</td>\n",
       "      <td>913191 (491337)</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>70</td>\n",
       "      <td>0.10</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DEBC}</td>\n",
       "      <td>12007 (5589)</td>\n",
       "      <td>0.001</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>70</td>\n",
       "      <td>0.10</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DE}</td>\n",
       "      <td>12020 (6458)</td>\n",
       "      <td>0.001</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>70</td>\n",
       "      <td>0.10</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DKWT}</td>\n",
       "      <td>351023 (184430)</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>100</td>\n",
       "      <td>0.02</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DEBC}</td>\n",
       "      <td>25321 (12164)</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>100</td>\n",
       "      <td>0.02</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DE}</td>\n",
       "      <td>25316 (9172)</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>100</td>\n",
       "      <td>0.02</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DKWT}</td>\n",
       "      <td>1937737 (1431587)</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>100</td>\n",
       "      <td>0.05</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DEBC}</td>\n",
       "      <td>12502 (7960)</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>100</td>\n",
       "      <td>0.05</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DE}</td>\n",
       "      <td>12590 (8568)</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>100</td>\n",
       "      <td>0.05</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DKWT}</td>\n",
       "      <td>851744 (517000)</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>100</td>\n",
       "      <td>0.10</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DEBC}</td>\n",
       "      <td>9257 (4973)</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>100</td>\n",
       "      <td>0.10</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DE}</td>\n",
       "      <td>9989 (5647)</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>100</td>\n",
       "      <td>0.10</td>\n",
       "      <td>10</td>\n",
       "      <td>300</td>\n",
       "      <td>0.05</td>\n",
       "      <td>\\textit{DKWT}</td>\n",
       "      <td>339929 (160494)</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    var  $\\epsilon$  $n_s$    n  $\\delta$      Algorithm  Sample Complexity  \\\n",
       "0    10        0.02     10  300      0.05  \\textit{DEBC}    570106 (241080)   \n",
       "1    10        0.02     10  300      0.05    \\textit{DE}    620582 (194788)   \n",
       "2    10        0.02     10  300      0.05  \\textit{DKWT}  16095899 (960872)   \n",
       "3    10        0.05     10  300      0.05  \\textit{DEBC}     140091 (48478)   \n",
       "4    10        0.05     10  300      0.05    \\textit{DE}     159971 (45508)   \n",
       "5    10        0.05     10  300      0.05  \\textit{DKWT}    4018854 (57767)   \n",
       "6    10        0.10     10  300      0.05  \\textit{DEBC}      36426 (10580)   \n",
       "7    10        0.10     10  300      0.05    \\textit{DE}      47141 (10466)   \n",
       "8    10        0.10     10  300      0.05  \\textit{DKWT}      940636 (7077)   \n",
       "9    30        0.02     10  300      0.05  \\textit{DEBC}      61441 (39533)   \n",
       "10   30        0.02     10  300      0.05    \\textit{DE}      73432 (40950)   \n",
       "11   30        0.02     10  300      0.05  \\textit{DKWT}  4846755 (2611789)   \n",
       "12   30        0.05     10  300      0.05  \\textit{DEBC}      45199 (27385)   \n",
       "13   30        0.05     10  300      0.05    \\textit{DE}      55288 (26533)   \n",
       "14   30        0.05     10  300      0.05  \\textit{DKWT}   1990971 (736651)   \n",
       "15   30        0.10     10  300      0.05  \\textit{DEBC}      24834 (11949)   \n",
       "16   30        0.10     10  300      0.05    \\textit{DE}       23816 (7679)   \n",
       "17   30        0.10     10  300      0.05  \\textit{DKWT}    688586 (166016)   \n",
       "18   70        0.02     10  300      0.05  \\textit{DEBC}      28707 (10207)   \n",
       "19   70        0.02     10  300      0.05    \\textit{DE}      28271 (10464)   \n",
       "20   70        0.02     10  300      0.05  \\textit{DKWT}  2111053 (1438009)   \n",
       "21   70        0.05     10  300      0.05  \\textit{DEBC}      18223 (11575)   \n",
       "22   70        0.05     10  300      0.05    \\textit{DE}      16690 (10883)   \n",
       "23   70        0.05     10  300      0.05  \\textit{DKWT}    913191 (491337)   \n",
       "24   70        0.10     10  300      0.05  \\textit{DEBC}       12007 (5589)   \n",
       "25   70        0.10     10  300      0.05    \\textit{DE}       12020 (6458)   \n",
       "26   70        0.10     10  300      0.05  \\textit{DKWT}    351023 (184430)   \n",
       "27  100        0.02     10  300      0.05  \\textit{DEBC}      25321 (12164)   \n",
       "28  100        0.02     10  300      0.05    \\textit{DE}       25316 (9172)   \n",
       "29  100        0.02     10  300      0.05  \\textit{DKWT}  1937737 (1431587)   \n",
       "30  100        0.05     10  300      0.05  \\textit{DEBC}       12502 (7960)   \n",
       "31  100        0.05     10  300      0.05    \\textit{DE}       12590 (8568)   \n",
       "32  100        0.05     10  300      0.05  \\textit{DKWT}    851744 (517000)   \n",
       "33  100        0.10     10  300      0.05  \\textit{DEBC}        9257 (4973)   \n",
       "34  100        0.10     10  300      0.05    \\textit{DE}        9989 (5647)   \n",
       "35  100        0.10     10  300      0.05  \\textit{DKWT}    339929 (160494)   \n",
       "\n",
       "   $\\frac{1}{2} - p_{i^{*}1}$ success rate  \n",
       "0                       0.008        0.908  \n",
       "1                       0.004        0.980  \n",
       "2                       0.000        1.000  \n",
       "3                       0.014        0.990  \n",
       "4                       0.008        1.000  \n",
       "5                       0.000        1.000  \n",
       "6                       0.019        1.000  \n",
       "7                       0.016        1.000  \n",
       "8                       0.002        1.000  \n",
       "9                       0.003        0.970  \n",
       "10                      0.002        0.980  \n",
       "11                      0.000        1.000  \n",
       "12                      0.013        0.879  \n",
       "13                      0.004        0.970  \n",
       "14                      0.000        1.000  \n",
       "15                      0.040        0.793  \n",
       "16                      0.004        1.000  \n",
       "17                      0.000        1.000  \n",
       "18                      0.003        0.990  \n",
       "19                      0.000        1.000  \n",
       "20                      0.000        1.000  \n",
       "21                      0.000        1.000  \n",
       "22                      0.000        1.000  \n",
       "23                      0.000        1.000  \n",
       "24                      0.001        1.000  \n",
       "25                      0.001        1.000  \n",
       "26                      0.000        1.000  \n",
       "27                      0.000        1.000  \n",
       "28                      0.000        1.000  \n",
       "29                      0.000        1.000  \n",
       "30                      0.000        1.000  \n",
       "31                      0.000        1.000  \n",
       "32                      0.000        1.000  \n",
       "33                      0.000        1.000  \n",
       "34                      0.000        1.000  \n",
       "35                      0.000        1.000  "
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "9"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(df.columns)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
