{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sample complexity for Divide-and-Battle: 7724814.817560616\n",
      "Sample complexity for Trace-the-Best: 76009.02459542081\n",
      "Sample complexity for Divide-and-Battle: 36439340.104411595\n",
      "Sample complexity for Trace-the-Best: 359487.87282647885\n",
      "Sample complexity for Divide-and-Battle: 91098350.26102899\n",
      "Sample complexity for Trace-the-Best: 990348.7552536125\n",
      "Sample complexity for Divide-and-Battle: 182196700.52205798\n",
      "Sample complexity for Trace-the-Best: 2119326.946619214\n"
     ]
    }
   ],
   "source": [
    "from matplotlib import pyplot as plt\n",
    "import pandas as pd\n",
    "import os\n",
    "from sim.benchmark import Benchmark\n",
    "from copy import deepcopy\n",
    "\n",
    "folder = '/root/main/ranking/sim/random_1000_16_100'\n",
    "models = {'DKWT': 'dkwt_results', 'PBR': 'results', 'PBR-lite': 'noinf_results'}\n",
    "if False:\n",
    "    arg = 'eps'\n",
    "    filt_vals = {'n':1000, 'k': 10}\n",
    "elif False:\n",
    "    arg = 'k'\n",
    "    filt_vals = {'n':1000, 'eps': 0.1}\n",
    "elif True:\n",
    "    arg = 'n'\n",
    "    filt_vals = {'k':10, 'eps': 0.1}\n",
    "\n",
    "col_mapping = {'num_steps': 'sample_complexity',\n",
    "               'eps': '$\\epsilon$',\n",
    "               'k': '$k$',\n",
    "               'n': '$n$'}\n",
    "\n",
    "df_list = []\n",
    "\n",
    "for k,v in models.items():\n",
    "    df = pd.read_csv(os.path.join(folder, f'{v}_{arg}.csv'))\n",
    "    df['model'] = k\n",
    "    df_list.append(df)\n",
    "    if arg == 'n':\n",
    "        df = pd.read_csv(os.path.join(folder, f'{v}_{\"eps\"}.csv'))\n",
    "        df['model'] = k\n",
    "        df_list.append(df)\n",
    "df_all = pd.concat(df_list, ignore_index=True)\n",
    "df_all = df_all.loc[(df_all[list(filt_vals)] == pd.Series(filt_vals)).all(axis=1)]\n",
    "\n",
    "def add_baseline_results(df_all):\n",
    "\n",
    "    df_tmp = df_all[['n','k', 'delta', 'eps']].drop_duplicates()\n",
    "\n",
    "    class Dummy:\n",
    "\n",
    "        def __init__(self) -> None:\n",
    "            pass\n",
    "\n",
    "    def get_benchmark(args):\n",
    "        obj = Dummy()\n",
    "        obj.__dict__.update(args)\n",
    "        bm = Benchmark(pbr = obj)\n",
    "        return bm.sample_complexity_divide_and_battle, bm.sample_complexity_trace_the_best\n",
    "\n",
    "    df_ = df_tmp.apply(get_benchmark, axis=1, result_type='expand')\n",
    "    df_1 = deepcopy(df_tmp)\n",
    "    df_1['model'] = 'Trace-the-Best'\n",
    "    df_1['num_steps'] = df_[1]\n",
    "    df_2 = deepcopy(df_tmp)\n",
    "    df_2['model'] = 'Divide-and-Battle'\n",
    "    df_2['num_steps'] = df_[0]\n",
    "    df_all = pd.concat([df_all, df_1,df_2], ignore_index=True)\n",
    "    return df_all\n",
    "\n",
    "df_all = add_baseline_results(df_all)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "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>n</th>\n",
       "      <th>d</th>\n",
       "      <th>k</th>\n",
       "      <th>num_steps</th>\n",
       "      <th>eps</th>\n",
       "      <th>delta</th>\n",
       "      <th>eff_eps</th>\n",
       "      <th>num_valid_items</th>\n",
       "      <th>max_corr</th>\n",
       "      <th>sharpness</th>\n",
       "      <th>q_idx</th>\n",
       "      <th>model</th>\n",
       "      <th>pr_diff</th>\n",
       "      <th>num_items_pruned_from_inf</th>\n",
       "      <th>update_inf</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1190</th>\n",
       "      <td>1000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>10</td>\n",
       "      <td>2.119327e+06</td>\n",
       "      <td>0.1</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>Trace-the-Best</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1191</th>\n",
       "      <td>50</td>\n",
       "      <td>NaN</td>\n",
       "      <td>10</td>\n",
       "      <td>7.724815e+06</td>\n",
       "      <td>0.1</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>Divide-and-Battle</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1192</th>\n",
       "      <td>200</td>\n",
       "      <td>NaN</td>\n",
       "      <td>10</td>\n",
       "      <td>3.643934e+07</td>\n",
       "      <td>0.1</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>Divide-and-Battle</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1193</th>\n",
       "      <td>500</td>\n",
       "      <td>NaN</td>\n",
       "      <td>10</td>\n",
       "      <td>9.109835e+07</td>\n",
       "      <td>0.1</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>Divide-and-Battle</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1194</th>\n",
       "      <td>1000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>10</td>\n",
       "      <td>1.821967e+08</td>\n",
       "      <td>0.1</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>Divide-and-Battle</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "         n   d   k     num_steps  eps  delta  eff_eps  num_valid_items  \\\n",
       "1190  1000 NaN  10  2.119327e+06  0.1   0.05      NaN              NaN   \n",
       "1191    50 NaN  10  7.724815e+06  0.1   0.05      NaN              NaN   \n",
       "1192   200 NaN  10  3.643934e+07  0.1   0.05      NaN              NaN   \n",
       "1193   500 NaN  10  9.109835e+07  0.1   0.05      NaN              NaN   \n",
       "1194  1000 NaN  10  1.821967e+08  0.1   0.05      NaN              NaN   \n",
       "\n",
       "      max_corr  sharpness  q_idx              model  pr_diff  \\\n",
       "1190       NaN        NaN    NaN     Trace-the-Best      NaN   \n",
       "1191       NaN        NaN    NaN  Divide-and-Battle      NaN   \n",
       "1192       NaN        NaN    NaN  Divide-and-Battle      NaN   \n",
       "1193       NaN        NaN    NaN  Divide-and-Battle      NaN   \n",
       "1194       NaN        NaN    NaN  Divide-and-Battle      NaN   \n",
       "\n",
       "      num_items_pruned_from_inf update_inf  \n",
       "1190                        NaN        NaN  \n",
       "1191                        NaN        NaN  \n",
       "1192                        NaN        NaN  \n",
       "1193                        NaN        NaN  \n",
       "1194                        NaN        NaN  "
      ]
     },
     "execution_count": 55,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_all.tail()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/lib/python3.9/site-packages/seaborn/categorical.py:1728: UserWarning: You passed a edgecolor/edgecolors ((0.2980392156862745, 0.4470588235294118, 0.6901960784313725)) for an unfilled marker ('_').  Matplotlib is ignoring the edgecolor in favor of the facecolor.  This behavior may change in the future.\n",
      "  ax.scatter(x, y, label=hue_level,\n",
      "/opt/conda/lib/python3.9/site-packages/seaborn/categorical.py:1728: UserWarning: You passed a edgecolor/edgecolors ((0.8666666666666667, 0.5176470588235295, 0.3215686274509804)) for an unfilled marker ('_').  Matplotlib is ignoring the edgecolor in favor of the facecolor.  This behavior may change in the future.\n",
      "  ax.scatter(x, y, label=hue_level,\n",
      "/opt/conda/lib/python3.9/site-packages/seaborn/categorical.py:1728: UserWarning: You passed a edgecolor/edgecolors ((0.3333333333333333, 0.6588235294117647, 0.40784313725490196)) for an unfilled marker ('_').  Matplotlib is ignoring the edgecolor in favor of the facecolor.  This behavior may change in the future.\n",
      "  ax.scatter(x, y, label=hue_level,\n",
      "/opt/conda/lib/python3.9/site-packages/seaborn/categorical.py:1728: UserWarning: You passed a edgecolor/edgecolors ((0.7686274509803922, 0.3058823529411765, 0.3215686274509804)) for an unfilled marker ('_').  Matplotlib is ignoring the edgecolor in favor of the facecolor.  This behavior may change in the future.\n",
      "  ax.scatter(x, y, label=hue_level,\n",
      "/opt/conda/lib/python3.9/site-packages/seaborn/categorical.py:1728: UserWarning: You passed a edgecolor/edgecolors ((0.5058823529411764, 0.4470588235294118, 0.7019607843137254)) for an unfilled marker ('_').  Matplotlib is ignoring the edgecolor in favor of the facecolor.  This behavior may change in the future.\n",
      "  ax.scatter(x, y, label=hue_level,\n"
     ]
    },
    {
     "data": {
      "image/png": "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NKQRnXj8zW9+k8ceewyAM888k+22226IRySEEEKI4WLEzuTMnz+fZ599lp/97Gecd955XHPNNUM9JCGEEEIMIyM2yBkzZgz5fB5rLe3t7YwZM2aohySEEEKIYWTIg5xbbrmFQw89lO22246vfOUrPa5rb2/nxBNPZOedd2bGjBn85Cc/6b6uqamJCRMmsP/++3PyySfzX//1X2t45EIIIYQYzoY8J2f8+PEce+yxPPTQQ7S1tfW47vzzz8daywMPPMC8efM46qijmDx5MtOmTePBBx+kVCrx+9//nhdffJELL7yQG264YYgehRBCCCGGmyEPcmbOnAnAM8880yPIKZfL3H333dxxxx00NzezzTbbMHv2bG677TamTZuGtZbRo0ejlGL06NF0dnYO1UMQQgghxDA05EHOirz88ssAbL755t2XTZkyhRtvvBGA6dOnc+edd/LJT36SWq3GiSeeuFr3p9Tyvx6ujjvuaJ5++kmMCdBaMWHCBkyfvgef/OSRFItN/OtfD3Puud/gzjt/D2SVdr/1rYt46qknOPLIz3Lddd/nF7+4s/t4559/Fn/5y/389rd/6O5EfuWV3+PVV18hjmMef/wRAJIkwXtPFEUA7LDDznz725ev4Uc/8ik1Mv7OhBgoznmsdVl3agXG6CHpZSTWLsM2yCmXyzQ19SzZ3NraSqlUAsAYw7e//e0Bua93l4a21vLWW5og0MO29L5SipNOOpVDDz0M5xz//vdzXHXV5RxzzOf44Q9/jDHZuINAk6YpF1xwFvPnz+Oaa35AkiScd95rvP32AiZMWB+Axx9/hHXXXZcXXniObbfdrvuymTP34+Mf/2T3/V511eUsXLiQs88+b80/6AbgXNbHa9y45u6+X0I0OmcdSeKWuTwMNdoMz/dY0RiGbZBTLBa7A5ouHR0dywQ+A6GtrZSdYdQ553DOkaaOYRrj4L3vHiPA5MlbcsEFl3DEER/hV7/6FZtuuhkA5XKVs876Kh0dHVx22dU0NTUDMGnSRjz88MPst9+BvPbaqwRBxAc+8EH++c+H2WqrbSiXyzz77FxOO+2Md/X18njve1wm+q7rb2vhws5hG0ALMZAef/hVHn/4lWwG590UKLLZnO13ncgOu05cs4MTI5YxfetdNWyDnE022QSAF154gcmTJwMwd+5ctthii0G5v6XblI7UlqVNTc1Mnbobjz32CJtuuhlpmnLaaSehteI737mSfD7ffduddtqFRx/9F/vtdyCPPfYIO+20MzvttDO/+MXP+MQnjuSJJx6jWGxi8uTB+X2v7bwfuX9nQvRHtZzQ3lbt0+3kNSEG2pCfSqZpSq1WI01TnHPUajWSJKFYLDJr1iwuu+wyOjs7mTt3LrfffjuHHnroUA95WBs3bl3a25cAUKmUefzxR5g164AeAQ7AzjtnQQ7AI4/8kx133JntttuRp556Auccjz76L3bccSeZbRBCrJZ8IaR1TJ7W0cv5NybPqDEFRo0pkC+EQz1U0YCGfCbn6quv5sorr+z+/u6772b27NlccsklnHPOOZx55pnMmDGDpqYmTjjhBHbfffchHO2K3fvwfP7wz1d6vd0Hd9mQfXadNGjjWLjwLVpbRwHQ0tLKV796Juec83VyuRx77bVP9+123vk9vPLKfN5++y0ee+wRjjrqCxQKBTbYYEP+/e/nePTRf7HnnnsN2jiFEGuH7XedyLbv2YA0sctcF4RGko/FoBryIOf444/n+OOPX+51ra2tXH75yNi501lJWNBW6dPtBkup1MnDD/8fRx75ue7L3v/+GZx77kWce+430Fqz5557A7DuuuPZcMNJ3HPP3SRJwvrrbwDATju9h7///SHmzn2ak046bdDGKoRYe2itCEIju6vEGjfkQU6jaC6ErDem0KfbDTTvPc8//2+uueZKWltHceCBH+Lpp5/svn769D0566wLuOCCs1BKs8ceHwCygOZnP7uFXXfdrfu2O+64M9/61kXkcjm22GLLAR+rEGLtpLVCa9lRKNYsCXIGyD67ThrUZajlufzy73DVVZfX6+Ssz/veN4Pzzrt4mfwbgD333Avvz+P888/k3HMvYvr0Pdl551349a9/xY477tx9ux122InFi9uYNu39ko8jhBBiRFPeSz57W1vpXdukHW++OZ/x4yfJB70YUPK3JYQQqy8I+raFXN5lhRBCCNGQJMgRQgghREOSIEcIIYQQDUmCHCGEEEI0JAlyhBBCCNGQJMgRQgghREOSIEcIIYQQDUmCHCGEEEI0JAlyhBBCCNGQJMgRQgghREOS3lUj1HHHHc3TTz+JMYYwjNhmm2058cRTeeKJx7jkkgvI5XIANDe3cNBBH+Zzn/ti989On74r+XwepRTFYpHdd5/OiSeeSqHQe4NRIYQQYqSQmZwR7IQTTmbOnAe49da7aGpq5qKLzgVgypRtmDPnAebMeYArr7yOu+66gz/96d4eP/vDH97CnDkP8IMf3MwzzzzFzTffMASPQAghhBg8EuQ0gGKxyKxZB/DCC88vc93EiRuy/fY78vLLLy33Z9dddzy77bY7//73s4M9TCGEEGKNkiCnAZRKnfz+979hyy23Wua6efP+wxNPPMa2226/3J994403+OtfH2TixEmDPUwhhBBijZKcnAESPzmH+Kl7e71dtO0+RNvtOyD3ecUV3+Waa64il4vYZpvt+cY3zuXRR//Fs88+w377fQBrHZVKmb322odddpna42e/8IXP4L2jUqkwdep7e+TsCLEmOOex1oEHFBij0VoN9bCEEA1EgpwB4qud+CUL+nS7gXL88V/hkEMO63HZo4/+i6222prrrrsRgEWLFnLeeWdy1VXf44QTTum+3fXX/5iNNtqYhx/+OxdddB7t7UtoaWkZsLEJsTLOedLEvnOBh9RZgtBIoCOEGDAS5AwQlW9GjVqvT7dbk8aOHccee+zFHXfcuuxYlGLq1GnMnLk/V175Pb75zf9Zo2MTa6cnHn6Vx//5SjaD824KFFmQs/0uE9l+14lrdnBCiIYiQc4Aibbbd8CWoQbSkiWLuf/+P7PZZpNXeJuPf/yTHH74h3juublsueWUNTg6sTaqVhLa26p9up0QQqwOCXIa0Ny5T7PvvjMAyOXy7LLLVE466dQV3n7s2HHst9+B3HDD9Xzzm99eU8MUa6l8IaR1TL7XmZx8IVyzAxNCNBzlvV/eW81apa2tRJq67u+dc7z55nzGj5+E1rIBTQwc+dvKLJOTUyc5OUKIvggCzZgxTb3fbg2MRQghetBaEYRGdlcJIQaVBDlCiCGhtUJrM9TDEEI0sLV3vlwIIYQQDU2CHCGEEEI0JAlyhBBCCNGQJMgRQgghREOSIEcIIYQQDUmCHCGEEEI0JAlyRK8uuuhcrr76CgAee+wRPvrRDw/xiIQQQojeSZ2cEeq4447m6aefxBhDGEZss822nHjiqTzxxGNccskF5HI5AJqbWzjooA/zuc99sftnp0/flXw+j1KKYrHI7rtP58QTT6VQKPR6vzvuuDP/7//9qvv7ww47mFNP/TrTpr1v4B+kEEIIsRpkJmcEO+GEk5kz5wFuvfUumpqaueiicwGYMmUb5sx5gDlzHuDKK6/jrrvu4E9/urfHz/7wh7cwZ84D/OAHN/PMM09x8803DMEjEEIIIQaPBDkNoFgsMmvWAbzwwvPLXDdx4oZsv/2OvPzyS8v92XXXHc9uu+3Ov//9bJ/u61//epgPfWgWABdccBYLFrzBGWecxr77zuDaa68CYP78eZxyygkceOAH+ehHP8ztt/9iFR+ZEEIIsepkuaoBlEqd/P73v2HLLbda5rp58/7DE088xsEHH7Lcn33jjTf4618fZNddd+v3/Z511gU89tijPZarqtUqJ510LJ/61H9x6aXf4bXXXuGkk77MpEmTmDp1Wr/vQwghhFhVEuQMkD/Pf5D7Xnmw19vtueH7+cCk9w/IfV5xxXe55pqryOUittlme77xjXN59NF/8eyzz7Dffh/AWkelUmavvfZhl12m9vjZL3zhM3jvqFQqTJ363h45O6vjwQcfYOzYccyefRgAG220CR/60GzmzPm9BDlCCCHWKAlyBkgpKfFm5e0+3W6gHH/8VzjkkMN6XPboo/9iq6225rrrbgRg0aKFnHfemVx11fc44YRTum93/fU/ZqONNubhh//ORRedR3v7ElpaWvjv/76Ye+75HQAzZ+7Paaed0a8xvfHGa/z738+y334f6L7MWseOO+60So9RCCGEWFUS5AyQprCJ8YV1+nS7NWns2HHsscde3HHHrctcp5Ri6tRpzJy5P1de+T2++c3/4bTTzuhXYKOU6vH9eutNYLvtduDKK69b7bELIYQQq0OCnAHygUkDtww1kJYsWcz99/+ZzTabvMLbfPzjn+Twwz/Ec8/NZcstp/Tr+GPGjOXVV1/p/v5975vBNddcya9/fQczZx6A1pr//Odl4rjG1ltvu8qPQwghhOgv2V3VgObOfZp9953BvvvO4JOfPJzRo0dz0kmnrfD2Y8eOY7/9DuSGG67v9319+tP/xf/+703st98HuP76qykWi3z3u1fxl7/cz6GHHshBB+3Lt751EaXSwC3TCSGEEH2hvPd+qAcx1NraSqSp6/7eOcebb85n/PhJaC1xoBg48rclhBCrLwg0Y8b0nv4h77JCCCGEaEgS5AghhBCiIUmQI4QQQoiGJEGOEEIIIRqSBDlCCCGEaEgS5AghhBCiIY3YYoDPPPMMF198MQCLFy9m44035sorrxziUQkhhBBiuBixQc7WW2/NzTffDMB3v/tdNt100yEekRBCCCGGk4ZYrvrjH//IPvvsM9TDEMtx2GEH87e/PTTUwxBCCLEWGvIg55ZbbuHQQw9lu+224ytf+UqP69rb2znxxBPZeeedmTFjBj/5yU+W+fknn3ySjTfemObm5jU15CHX1bJh331nsMceu7H33u/r/v6mm340ZOM67rijl9sIdKD89rd3scceu3U/1tmzD+CHP7x2tY/7r389zIc+NGsARiiEEGI4GfLlqvHjx3Psscfy0EMP0dbW1uO6888/H2stDzzwAPPmzeOoo45i8uTJTJs2rfs2v/3tbznggAPW9LCH1Jw5D3R/ffTR/8Uhh3yEAw44eJnbpWlKEAz5UzygpkzZhuuuuxGAV199hS9/+Qtsttlk9tpLZvKEEEL0NOSfgDNnzgSyROKlg5xyuczdd9/NHXfcQXNzM9tssw2zZ8/mtttu6xHk3HfffRx//PGrPQ6llv/1SPL6669x+OEf4mtfO4sbb/wB+XyBW275f1xxxXf405/+QEdHB5MmTeL4409m5513AbJeSj//+f/yq1/dzsKFb7PeehM466zz2WqrKZRKnVx11WX89a8PYq3lAx/Ymy9/+SRyudwy933ttVfx+OOP8vTTT3LVVZexxx4f4KyzLgDgpZde5Lrrvs8rr8xnhx125OyzL6S1tRWAZ555iiuu+C4vvvgC48aN4+ijj2XPPffu0+OdOHFDtt9+R15++aXuy1Z2vL/+9S9cddVlLFiwgGKxyEc+8lEOP/wITj31RJIkZt99ZwBw/fU3sckmg5vjpdTI/TsTQoiRYsiDnBV5+eWXAdh88827L5syZQo33nhj9/ePPvooW221FYVCYbXu691Nvqy1vPWWJgj0sG+iqBRorQgCjTHZWP/xj7/xk5/8HGMCgkCz9dbbcNRRn6O5uYWf//ynnH321/jlL39NPl/gZz/7Kb/+9R1ceun/sNlmk5k/fx5hGBIEmm9+83yKxSZ+9rNbcc5z5plf5aabfsgxxxy3zDi+/OXjefLJx9l331kceuhhPa679967+e///g4tLa2ceOKx3HrrTzn66GN4++23OOWUE/jGN85m+vQ9eOaZpzn55OPZbLPN2HTTzZa5D60VSmWN2QDmzfsPTz75GIccMpsg0L0e75JLLuSiiy5hp53eQ3t7O6+++gotLU1897tXcNZZX+e3v50zCM9QT86B1ppx45oxxgz6/QkhxNps2AY55XKZpqaewUdrayulUqn7+5122omddtppte+rra2EtT27kDvnSFPHMI9x8B6c86Sp634Mn/3sF8nligCkqWOfffbrvv3HPvZJbrjhBzz//ItMmbI1t99+K1/4wjFsvPFmWOvZYINJALz11ts88MB9/O53f+w+1pFHfo4LLzyXL3zh2BWMxXf/3pb2kY98jHHjxgOw5557869/PUyaOn7zm1+z66678f7374n3MGXKtsyY8QHuvXcORx31hWWO75xn7txn2GefPbDWUamU2Wuvfdhpp137dDxjDM8//wKbbro5TU3NbLHFlB6/t3ePezB0/W0tXNg57ANoIYQYrozpWxfyYRvkFIvFHgENQEdHxzKBz0Dxfvlf91XbH+aw+I/39nq70Xvvw5gP7tv/O+iH9dab0OP7n/70Fn796zt4++23UEpRKpVYsmQxAAsWvMGGG05a5hivv/4azjkOPfTA7su6ghiAU045gccffwSAT3/6KI488rMrHM/YseO6v87n85TL5fp9vM5f/nIf++33ge7rrbXMmnUAb7zxBp/+9OHdl9988y8A2GqrrbtzchYtWsh5553JVVd9jxNOOGWlxwO46KJvcdNNP+Kaa65ks80m88Uvfpkdd9x5heMeTN6v2t+ZEEKIvhu2Qc4mm2wCwAsvvMDkyZMBmDt3LltsscUQjmrFbGcnyYIFfbrdYFNLJXs89tgj3HzzDVx++TVsttlktNbst99e+Pon7HrrTeCVV+azxRZb9TjGeutNwBjDXXfNIQzDZe7j29++fKX32xfrrTeBD35wJt/4xrnLvX7pBOvlGTt2HHvssVf3jq7ejrf11tvyzW9+mzRNueOOW/nGN07j17++t9/jFkIIMTIM+Xx5mqbUajXSNMU5R61WI0kSisUis2bN4rLLLqOzs5O5c+dy++23c+ihhw71kJfLNDcTrrder//MGt7qXi6XMMYwevRorLX8+Mc/pFx+Z4bsQx+azQ9/eC0vvfQi3nvmz5/HG2+8zrhx67D77tO57LL/ob29He89Cxa8sdKaN2PHjuXVV1/t89hmzdqfv/3tIf7yl/tJ05Q4jnnyySd48cUXcc53B2IrsmTJYu6//89sttnk5R4vSRKeeupJXn75JZIk4Z57fkdnZydBEFAoFNHa1Mc9jo6Odtrb2/s8diGEEMPfkM/kXH311T3aMdx9993Mnj2bSy65hHPOOYczzzyTGTNm0NTUxAknnMDuu+8+hKNdsTEf3HfQl6FWxW677c773jedT3ziMAqFPB/96CcYP3697usPP/wIkiTlq1/9Cm1tbay//vqceeZ5TJiwPmeeeS7XXfd9jjrqE3R0dDB+/Hg+/OGPMG3a+5Z7X4cffgQXXXQud911B9On78GZZ5630rGNH78e//3f3+Pqq6/g4ouz206evAXHHXcS0LWc43vMtMyd+3T3LqhcLs8uu0zlpJNOXeHxNt98C44/Pqu/dPfdv+W73/1vrLVsuOEkzj33IgA23ngTZs7cn49/fDbOWa655oZB310lhBBi8Cnf2+nyWqCtrdQj6dQ5x5tvzmf8+EmSHLoGlEsxlXIMy/tLVN3/R6EYUmyK1uTQBpz8bQkhxOoLghGeeCzWHt55bLqyWNt3304IIYToKwlyxJBTWmEC1etMjtKSICyEEKLvJMgRQ67YFFEohsvdUp1VBpbgRgghRP9JUoAYFpRSy7Q5kABHCCHE6pCZHDFsLC/QEUIIIVaVzOQIIYQQoiFJkCOEEEKIhiRBjhBCCCEakgQ5Deqee37HCSd8qU+3PeWUE/j1r+9Y7nW1Wo3p03fl9ddfG8DRrZrhMpbDDjt4pe0thBBCDA+SeDxCHXfc0Tz99JMYE6C1YsKEDZg+fQ8++ckjKRabmDlzf2bO3L9Px1pes82R6Le/vYtLLrmAXC4HQHNzCwcd9GE+97kv9unnL7roXMaOHccxxxzffdlxxx3NPvvM5JBDDhuUMQshhBg8EuSMYCeccDKHHHIYzjmef/45rr76Co455nNce+2N5PP5oR7ekJgyZRuuu+5GAF599RW+/OUvsNlmk9lrr32GdmBCCCHWOAlyGoDWmi23nMKFF17KEUd8hN/85k4KhQJ33HEb1113I//zP99Ea83JJ3+1+2cuvfQicrkcJ510ao/ZCucc1133fX796zuIohyf/ewXetxXkiT88IfXcu+9v6dSKTN16jROPvmrtLa2Lndsf/3rg1x//fd55ZVXaG5uZv/9D+Lzn/8SSilef/01Dj/8Q5x55nn88IfX0tHRwQEHHMQJJ5wC0OtYejNx4oZsv/2OvPzyS92XnXPOGTz66D+pVqtMnrwFp5zyNSZP3pxf/ep27rnndyiluP32/8eWW05hhx124vHHH+Xpp5/kqqsuY489PsBZZ13Q4z689/zsZz/hV7+6nSVLFrPttttx+unf6NEEVQghxNCQnJwG0tTUzNSpu/HYY4/0uHzmzP354x/vJU1TIAtU/vznPzBr1rLLWb/+9a/405/u5dprb+SWW/4fDz74QI/rr7nmSp577lmuv/7H3H77bwjDkO9+91srHFOhUOCMM87l7rv/xLe+9T3uvPOX/PnPf+hxm3/962Fuuunn/PCHN/Pb397FP//5jz6NpTfz5v2HJ554jG233b77st12m8b//u9t3HXXHLbaamvOPfcMAD784UOZOXN/PvaxTzJnzgNcddX1fPGLX2aHHXbihBNOZs6cB5YJcABuu+3nzJlzN9/97pXcddc9bLnlFM455+v9GqcQQojBIUFOgxk3bl3a25f0uGyHHXaiWCzyj3/8DchmV0aPHs3WW2+7zM/fe+/vOfzwjzNx4oYUi0189rPv5LN477nzzts54YSTGTNmLLlcns9//kv86U/vBFDvttNO72HzzbdAa83mm2/BPvvM4tFH/9XjNkcd9QUKhQITJ27IjjvuzLPPzu11LCvy7LPPsN9+H2DffffgE5/4CNtvvyO77DK1+/oDD/wQTU3NRFHEZz97NC+99CJLlizu9bgrcscdt/GFLxzD+utvQBAEfPazRzN37jO88cYbq3xMIYQQA0OWqwbIEw+/yhP/fLXX222/y0S233XioI1j4cK3aG0dtczl++67H3Pm/J7dd5/OPff8jlmzDljuz7/99lust96E7u8nTFi/++vFi9uoVCp86UtH9fgZrTVtbYu48cYfcM89vwOy2aPTTjuDp556kmuuuYKXXnqBJElIkoQZMz7Q4+fHjh3X/XU+n6dSKfc6ljfeeINPf/rw7u9vvvkXAGy11dbdOTmLFi3kvPPO5KqrvscJJ5yCtZbrrvs+f/rTvSxevBhdb/i5ZMliRo0avdzfR29ef/01zjnnjO5jASileeutBUyYMGElPymEEGKwSZAzQKqVhCVtlT7dbrCUSp08/PD/ceSRn1vmulmzDuBzn/sUb7/9Nn/961967CBa2jrrrMuCBe/MQiz99ahRo8nlctxww/+y/vobLPOzp512BqeddkaPy8477xsccshh/M//XEYul+fyy7/NwoVv9+nxrGwsEyZMYM6clS9f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+NCHPsRXv/rV7tYOTz/9NF/72tdIkoTf/e53gzLQwSTLVUIIIazLgpk4tZSrKc570tThPeRzhqZ8QBQERKFebqNqseYM2hby++67jz333HOZy+M45qqrruIrX/lKfw43LEiQI4QQAqCWWKpxSpparMuqHjvvKUQhQWBoLoy8MimNaNDr5CxYsID58+ezww47EEXRqhxitT3yyCNcccUVJEnC/vvvzyc+8YlVOo4EOUIIISCbzWnrqFGqJJQqNVIPUWAItKalKWTdUQW0llo5Q23QEo8XL17MaaedxgMPPIBSinvuuYdJkyZx9tlnM2rUKE455ZRVGnB/xXHMtddey9VXX00ul1sj9ymEEKKxVWsW5zyd5RqLO2Os94SBpikXYp2jEAW0NslnzkjR73D0wgsvxBjDfffdRz6f77581qxZ/OEPfxjQwa3MI488Qi6X47jjjuPzn/88L7300hq7byGEEI0nsZZqnFCqxry9pMqSUkxHKaGjHNNZiUmso6MS45zM/I8U/Q5y/vKXv3Dqqaey3nrr9bh8o4024rXXXuv3AG655RYOPfRQtttuu2Xyedrb2znxxBPZeeedmTFjBj/5yU+6r3vrrbd48cUXueKKKzj11FO58MIL+33fQgghRJckdcSppxY7Eutw1mOto1xNqVQTSqWYSs3hBqwZkhhs/V6usnb5Ja0XLFhAsVjs9wDGjx/Psccey0MPPURbW1uP684//3ystTzwwAPMmzePo446ismTJzNt2jRaWlp4z3veQz6fZ8qUKSxatKjf9y2EEH2ROketluI8aAVG63r5fzBaEQQa3YC7bUZSV+qB4F2Wk5PaFGc9XmWVjlPniVNPObYUazFJYgmkh9WI0O9naY899uC6667rMV23aNEivvOd77D33nv3ewAzZ85kn332YcyYMT0uL5fL3H333Zx00kk0NzezzTbbMHv2bG677TYAdtxxR1588UWcc7z22mu0trb2+76FEKI3ibUsWlxfuijXWFLK/qX1Ez7rsj5HA9jreFjw1uKTOPvkx4N3+CTGr+BEtxEEgcZZSzXOdlaVygkdlRpJnBKnFu8chTAgTh2plSWrkaDfMznf+MY3OPHEE9ljjz2o1WocffTRvP7662y55ZacfvrpAzawl19+GYDNN9+8+7IpU6Zw4403AjB69GgOOuggPvWpT+Gc46yzzlqt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noiIyNFi1Pu2MzM7wtciIiIisuE0hSEiIiJTSUGOiIiITCUFOSIiIjKVFOSIiIjIVFKQIyIiIlNJQY6IiIhMJQU5IiIiMpUU5IiIiMhUUpAjIiIiU0lBjoiIiEwlBTkiIiIylRTkTLEvfelLbN++nbPOOmv16x//+Mfq8bm5Oa666irOPPNMPvShD/HYY4+N8WrlYA0GA77yla9wwQUXcNZZZ3HppZdy//33rx5fa3wffPBBPvCBD7Bjxw4+/elP89xzz230S5CDsN73s8Z78u3atYudO3eyfft2rr/++gOOrXd8b731Vs477zzOOeccbrzxRuq6PuKvZyKYTK0bbrjBvvnNb77qscFgYBdccIHddddd1u/37ec//7m9+93vtv/85z8bfJVyqBYXF+22226zZ555xmKM9uijj9rZZ59tv//979cc3z//+c+2Y8cOe/jhh215edm+/vWv29VXXz3mVySvZz3vZ4330eGXv/yl/frXv7abbrrJrrvuutXH1zu+P/nJT+zCCy+0v/3tb/bvf//brrzySrv99ts3/PWNg2ZyjlGPPPIIvV6Pz3zmM1RVxYc//GFOOeUUfvWrX4370mRE3W6Xa6+9lje96U147znnnHM4++yzefzxx9cc3/vvv5/3v//9vOc976HdbnPttdfy+OOP88wzz4z5Vcmh0HhPh4suuogLL7yQ448//oDH1zu+9957L5/85Cc55ZRTOOGEE7jmmmu49957N/z1jYOCnCn3k5/8hHPPPZfLLruMn/3sZ6uP79mzh23btuH9Sz8Cp59+Onv27BnHZcphsLS0xB//+Ee2bt265vjOzc1x+umnrx477rjjOPnkk5mbm9vw65bRHer7WeN9dFvv+O7Zs+eA429729t49tlnmZ+f36BXMD7FuC9AjpyPf/zjfPGLX2TLli089thjfO5zn2PTpk1cfPHFLC4usmnTpgOev3nz5mPih34amRlf/vKXOeOMM3jve9/LH/7wh9cd36WlpVc9vri4uGHXLAdnPe9njffRbb3j+/LjK39+tfNOG83kTLF3vOMdnHDCCYQQOO+887j66qt58MEHAZiZmWFhYeGA58/PzzMzMzOOS5V1MDNuvPFGnnvuOW699Vacc2uOb7fb1fgfZdbzftZ4H93WO74vP77y52Nh/BXkHEO895gZAFu3bmVubo6U0urxJ598kq1bt47r8uQQmBk33XQTf/rTn/jud79Lt9sF1h7fbdu2sXv37tVjL774Iv/85z/Ztm3bxr4AOWQH837WeB/d1ju+W7duPeD4k08+yUknnTT1szigIGeqPfDAAywsLJBS4rHHHmPXrl188IMfBODcc8+lqiq+//3vMxgM+MUvfsHevXtXj8vR4eabb+aJJ57ge9/7HrOzs6uPrzW+l112Gb/5zW/47W9/S6/X44477mDHjh2ceuqp43opsob1vJ813keHpmno9/s0TUNKiX6/T13X6x7fnTt38sMf/pC///3vPP/889x5551cccUV43ypG2ese7vkiPrYxz5m73rXu2zHjh12ySWX2I9+9KMDju/evduuvPJKe+c732mXXHKJPfLII2O6UjkUe/futW3bttn27dttx44dq1933nmnma09vg888IBdcMEFdsYZZ9inPvUpe/bZZ8fxMmRE630/a7wn3x133GHbtm074OuGG24ws/WNb0rJbrnlFjv33HPt7LPPtq997Ws2GAw29LWNizMbzneKiIiITBEtV4mIiMhUUpAjIiIiU0lBjoiIiEwlBTkiIiIylRTkiIiIyFRSkCMiIiJTSUGOiIiITCUFOSIiIjKVFOSIiIjIVFKQIyIiIlNJQY6IiIhMJQU5IjJVnnjiCbZv387DDz/MFVdcwZlnnsknPvEJ9u3bN+5LE5ENpiBHRKbK3NwcIQR27drFTTfdxN13383TTz/NfffdN+5LE5ENVoz7AkREDqennnqKN77xjdx22220Wi0AzjzzTF544YUxX5mIbDTN5IjIVJmbm+PSSy9dDXAA9u7dy6mnnjrGqxKRcVCQIyJTZc+ePZxxxhmrf6/rmqeffppt27aN8apEZBwU5IjI1PjXv/7F888/z+mnn7762F/+8hdSSmzdunWMVyYi46AgR0SmxtzcHLOzs5xyyimrjz311FOceuqptNvtMV6ZiIyDghwRmRpzc3OcdtppBzz21FNPveIxETk2ODOzcV+EiIiIyOGmmRwRERGZSgpyREREZCopyBEREZGppCBHREREppKCHBEREZlKCnJERERkKinIERERkamkIEdERESmkoIcERERmUoKckRERGQqKcgRERGRqaQgR0RERKbS/wdPPzgu8labVQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "sns.set_style('whitegrid')\n",
    "sns.set_theme('paper')\n",
    "sns.stripplot(\n",
    "    data=df_all, x=arg, y=\"num_steps\", hue=\"model\",\n",
    "    dodge=True, alpha=.05, legend=False,\n",
    ")\n",
    "sns.pointplot(\n",
    "    data=df_all, x=arg, y=\"num_steps\", hue=\"model\",\n",
    "    dodge=.65, linestyles=\"none\", errorbar=None,\n",
    "    markers=\"_\",\n",
    "    scale=1.2\n",
    ")\n",
    "plt.yscale('log')\n",
    "plt.ylabel('sample complexity')\n",
    "plt.xlabel(col_mapping[arg])\n",
    "plt.title(', '.join([f'{col_mapping[k]} = {v}' for k,v in filt_vals.items()]))\n",
    "plot_folder = \"/root/main/ranking/plots\"\n",
    "plt.savefig(os.path.join(plot_folder, f\"{folder.split('/')[-1]}_{arg}.png\"), transparent=False, pad_inches = 0.1, bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "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></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>d</th>\n",
       "      <th>num_steps</th>\n",
       "      <th>delta</th>\n",
       "      <th>eff_eps</th>\n",
       "      <th>num_valid_items</th>\n",
       "      <th>max_corr</th>\n",
       "      <th>sharpness</th>\n",
       "      <th>q_idx</th>\n",
       "      <th>pr_diff</th>\n",
       "      <th>num_items_pruned_from_inf</th>\n",
       "      <th>pass</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>n</th>\n",
       "      <th>k</th>\n",
       "      <th>eps</th>\n",
       "      <th>model</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">50</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">10</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">0.1</th>\n",
       "      <th>DKWT</th>\n",
       "      <td>16.0</td>\n",
       "      <td>9.350045e+04</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.035714</td>\n",
       "      <td>1.660000</td>\n",
       "      <td>0.551541</td>\n",
       "      <td>3.0</td>\n",
       "      <td>49.500000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Divide-and-Battle</th>\n",
       "      <td>NaN</td>\n",
       "      <td>7.724815e+06</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PBR</th>\n",
       "      <td>16.0</td>\n",
       "      <td>1.785180e+03</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>3.190000</td>\n",
       "      <td>0.551541</td>\n",
       "      <td>3.0</td>\n",
       "      <td>49.500000</td>\n",
       "      <td>-0.003963</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.99</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PBR-lite</th>\n",
       "      <td>16.0</td>\n",
       "      <td>1.826560e+03</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>3.190000</td>\n",
       "      <td>0.551541</td>\n",
       "      <td>3.0</td>\n",
       "      <td>49.500000</td>\n",
       "      <td>-0.001989</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Trace-the-Best</th>\n",
       "      <td>NaN</td>\n",
       "      <td>7.600902e+04</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">200</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">10</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">0.1</th>\n",
       "      <th>DKWT</th>\n",
       "      <td>16.0</td>\n",
       "      <td>2.654861e+05</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.035714</td>\n",
       "      <td>1.650000</td>\n",
       "      <td>0.682692</td>\n",
       "      <td>3.0</td>\n",
       "      <td>49.500000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Divide-and-Battle</th>\n",
       "      <td>NaN</td>\n",
       "      <td>3.643934e+07</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PBR</th>\n",
       "      <td>16.0</td>\n",
       "      <td>6.390101e+03</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>4.383838</td>\n",
       "      <td>0.683180</td>\n",
       "      <td>3.0</td>\n",
       "      <td>49.474747</td>\n",
       "      <td>-0.006575</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PBR-lite</th>\n",
       "      <td>16.0</td>\n",
       "      <td>6.465033e+03</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>4.252747</td>\n",
       "      <td>0.689801</td>\n",
       "      <td>3.0</td>\n",
       "      <td>50.351648</td>\n",
       "      <td>-0.003739</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Trace-the-Best</th>\n",
       "      <td>NaN</td>\n",
       "      <td>3.594879e+05</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">500</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">10</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">0.1</th>\n",
       "      <th>DKWT</th>\n",
       "      <td>16.0</td>\n",
       "      <td>5.416509e+05</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.035714</td>\n",
       "      <td>1.740000</td>\n",
       "      <td>0.811377</td>\n",
       "      <td>3.0</td>\n",
       "      <td>49.500000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Divide-and-Battle</th>\n",
       "      <td>NaN</td>\n",
       "      <td>9.109835e+07</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PBR</th>\n",
       "      <td>16.0</td>\n",
       "      <td>1.389968e+04</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>4.580000</td>\n",
       "      <td>0.811377</td>\n",
       "      <td>3.0</td>\n",
       "      <td>49.500000</td>\n",
       "      <td>-0.006349</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PBR-lite</th>\n",
       "      <td>16.0</td>\n",
       "      <td>1.393671e+04</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>4.616162</td>\n",
       "      <td>0.810048</td>\n",
       "      <td>3.0</td>\n",
       "      <td>49.262626</td>\n",
       "      <td>-0.005573</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Trace-the-Best</th>\n",
       "      <td>NaN</td>\n",
       "      <td>9.903488e+05</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">1000</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">10</th>\n",
       "      <th rowspan=\"5\" valign=\"top\">0.1</th>\n",
       "      <th>DKWT</th>\n",
       "      <td>16.0</td>\n",
       "      <td>6.801793e+05</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.035714</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.930799</td>\n",
       "      <td>3.0</td>\n",
       "      <td>49.500000</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Divide-and-Battle</th>\n",
       "      <td>NaN</td>\n",
       "      <td>1.821967e+08</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PBR</th>\n",
       "      <td>16.0</td>\n",
       "      <td>2.013295e+04</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.050505</td>\n",
       "      <td>0.930849</td>\n",
       "      <td>3.0</td>\n",
       "      <td>49.454545</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>PBR-lite</th>\n",
       "      <td>16.0</td>\n",
       "      <td>2.115366e+04</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.050505</td>\n",
       "      <td>0.930742</td>\n",
       "      <td>3.0</td>\n",
       "      <td>49.303030</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Trace-the-Best</th>\n",
       "      <td>NaN</td>\n",
       "      <td>2.119327e+06</td>\n",
       "      <td>0.05</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.00</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                  d     num_steps  delta   eff_eps  \\\n",
       "n    k  eps model                                                    \n",
       "50   10 0.1 DKWT               16.0  9.350045e+04   0.05  0.035714   \n",
       "            Divide-and-Battle   NaN  7.724815e+06   0.05       NaN   \n",
       "            PBR                16.0  1.785180e+03   0.05       NaN   \n",
       "            PBR-lite           16.0  1.826560e+03   0.05       NaN   \n",
       "            Trace-the-Best      NaN  7.600902e+04   0.05       NaN   \n",
       "200  10 0.1 DKWT               16.0  2.654861e+05   0.05  0.035714   \n",
       "            Divide-and-Battle   NaN  3.643934e+07   0.05       NaN   \n",
       "            PBR                16.0  6.390101e+03   0.05       NaN   \n",
       "            PBR-lite           16.0  6.465033e+03   0.05       NaN   \n",
       "            Trace-the-Best      NaN  3.594879e+05   0.05       NaN   \n",
       "500  10 0.1 DKWT               16.0  5.416509e+05   0.05  0.035714   \n",
       "            Divide-and-Battle   NaN  9.109835e+07   0.05       NaN   \n",
       "            PBR                16.0  1.389968e+04   0.05       NaN   \n",
       "            PBR-lite           16.0  1.393671e+04   0.05       NaN   \n",
       "            Trace-the-Best      NaN  9.903488e+05   0.05       NaN   \n",
       "1000 10 0.1 DKWT               16.0  6.801793e+05   0.05  0.035714   \n",
       "            Divide-and-Battle   NaN  1.821967e+08   0.05       NaN   \n",
       "            PBR                16.0  2.013295e+04   0.05       NaN   \n",
       "            PBR-lite           16.0  2.115366e+04   0.05       NaN   \n",
       "            Trace-the-Best      NaN  2.119327e+06   0.05       NaN   \n",
       "\n",
       "                               num_valid_items  max_corr  sharpness  \\\n",
       "n    k  eps model                                                     \n",
       "50   10 0.1 DKWT                      1.660000  0.551541        3.0   \n",
       "            Divide-and-Battle              NaN       NaN        NaN   \n",
       "            PBR                       3.190000  0.551541        3.0   \n",
       "            PBR-lite                  3.190000  0.551541        3.0   \n",
       "            Trace-the-Best                 NaN       NaN        NaN   \n",
       "200  10 0.1 DKWT                      1.650000  0.682692        3.0   \n",
       "            Divide-and-Battle              NaN       NaN        NaN   \n",
       "            PBR                       4.383838  0.683180        3.0   \n",
       "            PBR-lite                  4.252747  0.689801        3.0   \n",
       "            Trace-the-Best                 NaN       NaN        NaN   \n",
       "500  10 0.1 DKWT                      1.740000  0.811377        3.0   \n",
       "            Divide-and-Battle              NaN       NaN        NaN   \n",
       "            PBR                       4.580000  0.811377        3.0   \n",
       "            PBR-lite                  4.616162  0.810048        3.0   \n",
       "            Trace-the-Best                 NaN       NaN        NaN   \n",
       "1000 10 0.1 DKWT                      1.000000  0.930799        3.0   \n",
       "            Divide-and-Battle              NaN       NaN        NaN   \n",
       "            PBR                       1.050505  0.930849        3.0   \n",
       "            PBR-lite                  1.050505  0.930742        3.0   \n",
       "            Trace-the-Best                 NaN       NaN        NaN   \n",
       "\n",
       "                                   q_idx   pr_diff  num_items_pruned_from_inf  \\\n",
       "n    k  eps model                                                               \n",
       "50   10 0.1 DKWT               49.500000       NaN                        NaN   \n",
       "            Divide-and-Battle        NaN       NaN                        NaN   \n",
       "            PBR                49.500000 -0.003963                        0.0   \n",
       "            PBR-lite           49.500000 -0.001989                        0.0   \n",
       "            Trace-the-Best           NaN       NaN                        NaN   \n",
       "200  10 0.1 DKWT               49.500000       NaN                        NaN   \n",
       "            Divide-and-Battle        NaN       NaN                        NaN   \n",
       "            PBR                49.474747 -0.006575                        0.0   \n",
       "            PBR-lite           50.351648 -0.003739                        0.0   \n",
       "            Trace-the-Best           NaN       NaN                        NaN   \n",
       "500  10 0.1 DKWT               49.500000       NaN                        NaN   \n",
       "            Divide-and-Battle        NaN       NaN                        NaN   \n",
       "            PBR                49.500000 -0.006349                        0.0   \n",
       "            PBR-lite           49.262626 -0.005573                        0.0   \n",
       "            Trace-the-Best           NaN       NaN                        NaN   \n",
       "1000 10 0.1 DKWT               49.500000       NaN                        NaN   \n",
       "            Divide-and-Battle        NaN       NaN                        NaN   \n",
       "            PBR                49.454545  0.000000                        0.0   \n",
       "            PBR-lite           49.303030  0.000000                        0.0   \n",
       "            Trace-the-Best           NaN       NaN                        NaN   \n",
       "\n",
       "                               pass  \n",
       "n    k  eps model                    \n",
       "50   10 0.1 DKWT               0.00  \n",
       "            Divide-and-Battle  0.00  \n",
       "            PBR                0.99  \n",
       "            PBR-lite           1.00  \n",
       "            Trace-the-Best     0.00  \n",
       "200  10 0.1 DKWT               0.00  \n",
       "            Divide-and-Battle  0.00  \n",
       "            PBR                1.00  \n",
       "            PBR-lite           1.00  \n",
       "            Trace-the-Best     0.00  \n",
       "500  10 0.1 DKWT               0.00  \n",
       "            Divide-and-Battle  0.00  \n",
       "            PBR                1.00  \n",
       "            PBR-lite           1.00  \n",
       "            Trace-the-Best     0.00  \n",
       "1000 10 0.1 DKWT               0.00  \n",
       "            Divide-and-Battle  0.00  \n",
       "            PBR                1.00  \n",
       "            PBR-lite           1.00  \n",
       "            Trace-the-Best     0.00  "
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# assess pass/fail\n",
    "df_all['pass'] = (-df_all['pr_diff'])<df_all['eps']\n",
    "df_all.groupby(['n', 'k', 'eps', 'model']).mean()"
   ]
  }
 ],
 "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
}
