{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "fd316aa1",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[nltk_data] Downloading package stopwords to /root/nltk_data...\n",
      "[nltk_data]   Package stopwords is already up-to-date!\n"
     ]
    }
   ],
   "source": [
    "import os, sys\n",
    "import fitz\n",
    "import re\n",
    "import json\n",
    "from datetime import datetime\n",
    "from typing import Optional, List, Callable, Any, Tuple, Dict, Self, Union, TypedDict\n",
    "from abc import abstractmethod, ABC\n",
    "import random\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import copy\n",
    "import nltk\n",
    "from nltk.corpus import stopwords\n",
    "import pickle\n",
    "from tqdm.autonotebook import tqdm\n",
    "import itertools\n",
    "from dotenv import load_dotenv\n",
    "import string\n",
    "\n",
    "sys.path.append(\"../\")\n",
    "\n",
    "load_dotenv(dotenv_path=\"../.env\")\n",
    "nltk.download('stopwords')\n",
    "\n",
    "random.seed(42)\n",
    "np.random.seed(42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "43823581",
   "metadata": {},
   "outputs": [],
   "source": [
    "MAIN_DIR = \"MRIe_sim\"\n",
    "MODEL = \"mistral-large\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "813de650",
   "metadata": {},
   "outputs": [],
   "source": [
    "from dataset.utils import file_handle\n",
    "\n",
    "asset_UO = file_handle.load_json(\"asset_action_space.json\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "ebd20aaf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "without_examples 110\n",
      "with_examples 990\n"
     ]
    }
   ],
   "source": [
    "eval_data = {}\n",
    "\n",
    "\n",
    "files = os.listdir(os.path.join(MAIN_DIR, \"without_examples\", MODEL))\n",
    "print(\"without_examples\",len(files))\n",
    "for f in files:\n",
    "    N,f_id = f.replace(\".json\", \"\").split(\"_\")\n",
    "    eval_data[f\"{f_id}_{N}_N0\"] = file_handle.load_json(os.path.join(MAIN_DIR, \"without_examples\", MODEL, f))\n",
    "\n",
    "files = os.listdir(os.path.join(MAIN_DIR, \"with_examples\", MODEL))\n",
    "print(\"with_examples\",len(files))\n",
    "for f in files:\n",
    "    N,f_id,ex_id = f.replace(\".json\", \"\").split(\"_\")\n",
    "    eval_data[f\"{f_id}_{N}_{ex_id}\"] = file_handle.load_json(os.path.join(MAIN_DIR, \"with_examples\", MODEL, f))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "1f5573ad",
   "metadata": {},
   "outputs": [],
   "source": [
    "def eval_at_k(_dict, n=10):\n",
    "    in_gt = []\n",
    "    for pred_r in _dict['ranking']:\n",
    "        if pred_r['text'] in _dict['data']['observations']:\n",
    "            in_gt.append(1)\n",
    "        else:\n",
    "            in_gt.append(0)\n",
    "\n",
    "    cumu = np.cumsum(in_gt)/(np.arange(len(in_gt))+1)\n",
    "    if 0<cumu.shape[0] and cumu.shape[0] <n:\n",
    "        cumu = np.array(cumu.tolist()+[cumu[-1] for _ in range(n-cumu.shape[0])])\n",
    "    \n",
    "    return cumu[:n]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "78a7a4ed",
   "metadata": {},
   "outputs": [],
   "source": [
    "results = []\n",
    "\n",
    "for k,v in eval_data.items():\n",
    "    f_id, N, ex_id = k.split(\"_\")\n",
    "    results.append({\n",
    "        \"rule\":f_id,\n",
    "        \"examples\":ex_id,\n",
    "        'try':N, \n",
    "        'error':v['error'],\n",
    "        'n_opt_space':len(asset_UO[v['data']['asset']]),\n",
    "        'n_obs':len(v['data']['observations']),\n",
    "        **{f\"TOPK@{ind+1}\":v for ind,v in enumerate(eval_at_k(v))}\n",
    "    })"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "e764790a",
   "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>rule</th>\n",
       "      <th>examples</th>\n",
       "      <th>try</th>\n",
       "      <th>error</th>\n",
       "      <th>n_opt_space</th>\n",
       "      <th>n_obs</th>\n",
       "      <th>TOPK@1</th>\n",
       "      <th>TOPK@2</th>\n",
       "      <th>TOPK@3</th>\n",
       "      <th>TOPK@4</th>\n",
       "      <th>TOPK@5</th>\n",
       "      <th>TOPK@6</th>\n",
       "      <th>TOPK@7</th>\n",
       "      <th>TOPK@8</th>\n",
       "      <th>TOPK@9</th>\n",
       "      <th>TOPK@10</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>BR00010</td>\n",
       "      <td>N0</td>\n",
       "      <td>9</td>\n",
       "      <td>None</td>\n",
       "      <td>27</td>\n",
       "      <td>3</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.333333</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.333333</td>\n",
       "      <td>0.285714</td>\n",
       "      <td>0.250</td>\n",
       "      <td>0.222222</td>\n",
       "      <td>0.20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>CR00015</td>\n",
       "      <td>N0</td>\n",
       "      <td>9</td>\n",
       "      <td>None</td>\n",
       "      <td>41</td>\n",
       "      <td>4</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.20</td>\n",
       "      <td>0.166667</td>\n",
       "      <td>0.142857</td>\n",
       "      <td>0.125</td>\n",
       "      <td>0.111111</td>\n",
       "      <td>0.10</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>CT00004</td>\n",
       "      <td>N0</td>\n",
       "      <td>4</td>\n",
       "      <td>None</td>\n",
       "      <td>15</td>\n",
       "      <td>4</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.666667</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.666667</td>\n",
       "      <td>0.571429</td>\n",
       "      <td>0.500</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.40</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>BR00010</td>\n",
       "      <td>N0</td>\n",
       "      <td>7</td>\n",
       "      <td>None</td>\n",
       "      <td>27</td>\n",
       "      <td>3</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.333333</td>\n",
       "      <td>0.285714</td>\n",
       "      <td>0.250</td>\n",
       "      <td>0.222222</td>\n",
       "      <td>0.20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>CR00014</td>\n",
       "      <td>N0</td>\n",
       "      <td>7</td>\n",
       "      <td>None</td>\n",
       "      <td>41</td>\n",
       "      <td>6</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.111111</td>\n",
       "      <td>0.10</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1095</th>\n",
       "      <td>CR00014</td>\n",
       "      <td>N4</td>\n",
       "      <td>1</td>\n",
       "      <td>None</td>\n",
       "      <td>41</td>\n",
       "      <td>6</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.20</td>\n",
       "      <td>0.166667</td>\n",
       "      <td>0.142857</td>\n",
       "      <td>0.125</td>\n",
       "      <td>0.222222</td>\n",
       "      <td>0.20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1096</th>\n",
       "      <td>CR00016</td>\n",
       "      <td>N6</td>\n",
       "      <td>3</td>\n",
       "      <td>None</td>\n",
       "      <td>41</td>\n",
       "      <td>7</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.333333</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.20</td>\n",
       "      <td>0.166667</td>\n",
       "      <td>0.142857</td>\n",
       "      <td>0.250</td>\n",
       "      <td>0.222222</td>\n",
       "      <td>0.20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1097</th>\n",
       "      <td>BR00011</td>\n",
       "      <td>N1</td>\n",
       "      <td>9</td>\n",
       "      <td>None</td>\n",
       "      <td>27</td>\n",
       "      <td>5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.333333</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.333333</td>\n",
       "      <td>0.428571</td>\n",
       "      <td>0.500</td>\n",
       "      <td>0.555556</td>\n",
       "      <td>0.50</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1098</th>\n",
       "      <td>CR00015</td>\n",
       "      <td>N1</td>\n",
       "      <td>2</td>\n",
       "      <td>None</td>\n",
       "      <td>41</td>\n",
       "      <td>4</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.20</td>\n",
       "      <td>0.166667</td>\n",
       "      <td>0.142857</td>\n",
       "      <td>0.250</td>\n",
       "      <td>0.222222</td>\n",
       "      <td>0.20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1099</th>\n",
       "      <td>PD00004</td>\n",
       "      <td>N8</td>\n",
       "      <td>1</td>\n",
       "      <td>None</td>\n",
       "      <td>4</td>\n",
       "      <td>3</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.666667</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.750</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.75</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1100 rows × 16 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "         rule examples try error  n_opt_space  n_obs  TOPK@1  TOPK@2  \\\n",
       "0     BR00010       N0   9  None           27      3     0.0     0.5   \n",
       "1     CR00015       N0   9  None           41      4     0.0     0.0   \n",
       "2     CT00004       N0   4  None           15      4     1.0     1.0   \n",
       "3     BR00010       N0   7  None           27      3     0.0     0.0   \n",
       "4     CR00014       N0   7  None           41      6     0.0     0.0   \n",
       "...       ...      ...  ..   ...          ...    ...     ...     ...   \n",
       "1095  CR00014       N4   1  None           41      6     0.0     0.0   \n",
       "1096  CR00016       N6   3  None           41      7     0.0     0.5   \n",
       "1097  BR00011       N1   9  None           27      5     0.0     0.5   \n",
       "1098  CR00015       N1   2  None           41      4     0.0     0.0   \n",
       "1099  PD00004       N8   1  None            4      3     0.0     0.5   \n",
       "\n",
       "        TOPK@3  TOPK@4  TOPK@5    TOPK@6    TOPK@7  TOPK@8    TOPK@9  TOPK@10  \n",
       "0     0.333333    0.25    0.40  0.333333  0.285714   0.250  0.222222     0.20  \n",
       "1     0.000000    0.00    0.20  0.166667  0.142857   0.125  0.111111     0.10  \n",
       "2     0.666667    0.75    0.60  0.666667  0.571429   0.500  0.444444     0.40  \n",
       "3     0.000000    0.25    0.40  0.333333  0.285714   0.250  0.222222     0.20  \n",
       "4     0.000000    0.00    0.00  0.000000  0.000000   0.000  0.111111     0.10  \n",
       "...        ...     ...     ...       ...       ...     ...       ...      ...  \n",
       "1095  0.000000    0.00    0.20  0.166667  0.142857   0.125  0.222222     0.20  \n",
       "1096  0.333333    0.25    0.20  0.166667  0.142857   0.250  0.222222     0.20  \n",
       "1097  0.333333    0.25    0.40  0.333333  0.428571   0.500  0.555556     0.50  \n",
       "1098  0.000000    0.00    0.20  0.166667  0.142857   0.250  0.222222     0.20  \n",
       "1099  0.666667    0.75    0.75  0.750000  0.750000   0.750  0.750000     0.75  \n",
       "\n",
       "[1100 rows x 16 columns]"
      ]
     },
     "execution_count": 54,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result_df = pd.DataFrame.from_dict(results)\n",
    "result_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "a7a22787",
   "metadata": {},
   "outputs": [],
   "source": [
    "result_df = result_df.loc[result_df['error'].isna()]\n",
    "result_df = result_df.drop(columns=['error'])\n",
    "result_df['try'] = result_df['try'].astype(int)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "a318b56f",
   "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>rule</th>\n",
       "      <th>examples</th>\n",
       "      <th>try</th>\n",
       "      <th>n_opt_space</th>\n",
       "      <th>n_obs</th>\n",
       "      <th>TOPK@1</th>\n",
       "      <th>TOPK@2</th>\n",
       "      <th>TOPK@3</th>\n",
       "      <th>TOPK@4</th>\n",
       "      <th>TOPK@5</th>\n",
       "      <th>TOPK@6</th>\n",
       "      <th>TOPK@7</th>\n",
       "      <th>TOPK@8</th>\n",
       "      <th>TOPK@9</th>\n",
       "      <th>TOPK@10</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>BR00010</td>\n",
       "      <td>N0</td>\n",
       "      <td>9</td>\n",
       "      <td>27</td>\n",
       "      <td>3</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.333333</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.333333</td>\n",
       "      <td>0.285714</td>\n",
       "      <td>0.250</td>\n",
       "      <td>0.222222</td>\n",
       "      <td>0.20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>CR00015</td>\n",
       "      <td>N0</td>\n",
       "      <td>9</td>\n",
       "      <td>41</td>\n",
       "      <td>4</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.20</td>\n",
       "      <td>0.166667</td>\n",
       "      <td>0.142857</td>\n",
       "      <td>0.125</td>\n",
       "      <td>0.111111</td>\n",
       "      <td>0.10</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>CT00004</td>\n",
       "      <td>N0</td>\n",
       "      <td>4</td>\n",
       "      <td>15</td>\n",
       "      <td>4</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.666667</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.666667</td>\n",
       "      <td>0.571429</td>\n",
       "      <td>0.500</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.40</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>BR00010</td>\n",
       "      <td>N0</td>\n",
       "      <td>7</td>\n",
       "      <td>27</td>\n",
       "      <td>3</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.333333</td>\n",
       "      <td>0.285714</td>\n",
       "      <td>0.250</td>\n",
       "      <td>0.222222</td>\n",
       "      <td>0.20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>CR00014</td>\n",
       "      <td>N0</td>\n",
       "      <td>7</td>\n",
       "      <td>41</td>\n",
       "      <td>6</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000</td>\n",
       "      <td>0.111111</td>\n",
       "      <td>0.10</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1095</th>\n",
       "      <td>CR00014</td>\n",
       "      <td>N4</td>\n",
       "      <td>1</td>\n",
       "      <td>41</td>\n",
       "      <td>6</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.20</td>\n",
       "      <td>0.166667</td>\n",
       "      <td>0.142857</td>\n",
       "      <td>0.125</td>\n",
       "      <td>0.222222</td>\n",
       "      <td>0.20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1096</th>\n",
       "      <td>CR00016</td>\n",
       "      <td>N6</td>\n",
       "      <td>3</td>\n",
       "      <td>41</td>\n",
       "      <td>7</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.333333</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.20</td>\n",
       "      <td>0.166667</td>\n",
       "      <td>0.142857</td>\n",
       "      <td>0.250</td>\n",
       "      <td>0.222222</td>\n",
       "      <td>0.20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1097</th>\n",
       "      <td>BR00011</td>\n",
       "      <td>N1</td>\n",
       "      <td>9</td>\n",
       "      <td>27</td>\n",
       "      <td>5</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.333333</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.333333</td>\n",
       "      <td>0.428571</td>\n",
       "      <td>0.500</td>\n",
       "      <td>0.555556</td>\n",
       "      <td>0.50</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1098</th>\n",
       "      <td>CR00015</td>\n",
       "      <td>N1</td>\n",
       "      <td>2</td>\n",
       "      <td>41</td>\n",
       "      <td>4</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.20</td>\n",
       "      <td>0.166667</td>\n",
       "      <td>0.142857</td>\n",
       "      <td>0.250</td>\n",
       "      <td>0.222222</td>\n",
       "      <td>0.20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1099</th>\n",
       "      <td>PD00004</td>\n",
       "      <td>N8</td>\n",
       "      <td>1</td>\n",
       "      <td>4</td>\n",
       "      <td>3</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.5</td>\n",
       "      <td>0.666667</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.750</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.75</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1096 rows × 15 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "         rule examples  try  n_opt_space  n_obs  TOPK@1  TOPK@2    TOPK@3  \\\n",
       "0     BR00010       N0    9           27      3     0.0     0.5  0.333333   \n",
       "1     CR00015       N0    9           41      4     0.0     0.0  0.000000   \n",
       "2     CT00004       N0    4           15      4     1.0     1.0  0.666667   \n",
       "3     BR00010       N0    7           27      3     0.0     0.0  0.000000   \n",
       "4     CR00014       N0    7           41      6     0.0     0.0  0.000000   \n",
       "...       ...      ...  ...          ...    ...     ...     ...       ...   \n",
       "1095  CR00014       N4    1           41      6     0.0     0.0  0.000000   \n",
       "1096  CR00016       N6    3           41      7     0.0     0.5  0.333333   \n",
       "1097  BR00011       N1    9           27      5     0.0     0.5  0.333333   \n",
       "1098  CR00015       N1    2           41      4     0.0     0.0  0.000000   \n",
       "1099  PD00004       N8    1            4      3     0.0     0.5  0.666667   \n",
       "\n",
       "      TOPK@4  TOPK@5    TOPK@6    TOPK@7  TOPK@8    TOPK@9  TOPK@10  \n",
       "0       0.25    0.40  0.333333  0.285714   0.250  0.222222     0.20  \n",
       "1       0.00    0.20  0.166667  0.142857   0.125  0.111111     0.10  \n",
       "2       0.75    0.60  0.666667  0.571429   0.500  0.444444     0.40  \n",
       "3       0.25    0.40  0.333333  0.285714   0.250  0.222222     0.20  \n",
       "4       0.00    0.00  0.000000  0.000000   0.000  0.111111     0.10  \n",
       "...      ...     ...       ...       ...     ...       ...      ...  \n",
       "1095    0.00    0.20  0.166667  0.142857   0.125  0.222222     0.20  \n",
       "1096    0.25    0.20  0.166667  0.142857   0.250  0.222222     0.20  \n",
       "1097    0.25    0.40  0.333333  0.428571   0.500  0.555556     0.50  \n",
       "1098    0.00    0.20  0.166667  0.142857   0.250  0.222222     0.20  \n",
       "1099    0.75    0.75  0.750000  0.750000   0.750  0.750000     0.75  \n",
       "\n",
       "[1096 rows x 15 columns]"
      ]
     },
     "execution_count": 56,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "fe146835",
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_std = result_df.groupby(['rule', 'examples']).agg(['mean','std'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "a7388946",
   "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 tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr:last-of-type th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th colspan=\"2\" halign=\"left\">try</th>\n",
       "      <th colspan=\"2\" halign=\"left\">n_opt_space</th>\n",
       "      <th colspan=\"2\" halign=\"left\">n_obs</th>\n",
       "      <th colspan=\"2\" halign=\"left\">TOPK@1</th>\n",
       "      <th colspan=\"2\" halign=\"left\">TOPK@2</th>\n",
       "      <th>...</th>\n",
       "      <th colspan=\"2\" halign=\"left\">TOPK@6</th>\n",
       "      <th colspan=\"2\" halign=\"left\">TOPK@7</th>\n",
       "      <th colspan=\"2\" halign=\"left\">TOPK@8</th>\n",
       "      <th colspan=\"2\" halign=\"left\">TOPK@9</th>\n",
       "      <th colspan=\"2\" halign=\"left\">TOPK@10</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>...</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>rule</th>\n",
       "      <th>examples</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",
       "      <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\">AC00003B?</th>\n",
       "      <th>N0</th>\n",
       "      <td>4.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>9.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.00</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>0.633333</td>\n",
       "      <td>0.070273</td>\n",
       "      <td>0.571429</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.5000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N1</th>\n",
       "      <td>4.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>9.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.8</td>\n",
       "      <td>0.421637</td>\n",
       "      <td>0.80</td>\n",
       "      <td>0.349603</td>\n",
       "      <td>...</td>\n",
       "      <td>0.583333</td>\n",
       "      <td>0.161971</td>\n",
       "      <td>0.514286</td>\n",
       "      <td>0.099887</td>\n",
       "      <td>0.4750</td>\n",
       "      <td>0.052705</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N2</th>\n",
       "      <td>4.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>9.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9</td>\n",
       "      <td>0.316228</td>\n",
       "      <td>0.85</td>\n",
       "      <td>0.337474</td>\n",
       "      <td>...</td>\n",
       "      <td>0.583333</td>\n",
       "      <td>0.117851</td>\n",
       "      <td>0.514286</td>\n",
       "      <td>0.099887</td>\n",
       "      <td>0.4875</td>\n",
       "      <td>0.039528</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N3</th>\n",
       "      <td>4.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>9.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.7</td>\n",
       "      <td>0.483046</td>\n",
       "      <td>0.70</td>\n",
       "      <td>0.483046</td>\n",
       "      <td>...</td>\n",
       "      <td>0.533333</td>\n",
       "      <td>0.189215</td>\n",
       "      <td>0.500000</td>\n",
       "      <td>0.121405</td>\n",
       "      <td>0.4625</td>\n",
       "      <td>0.060381</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N4</th>\n",
       "      <td>4.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>9.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.90</td>\n",
       "      <td>0.210819</td>\n",
       "      <td>...</td>\n",
       "      <td>0.616667</td>\n",
       "      <td>0.080508</td>\n",
       "      <td>0.528571</td>\n",
       "      <td>0.069007</td>\n",
       "      <td>0.4625</td>\n",
       "      <td>0.060381</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">PD00004</th>\n",
       "      <th>N5</th>\n",
       "      <td>4.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.3</td>\n",
       "      <td>0.483046</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.7500</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N6</th>\n",
       "      <td>4.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.2</td>\n",
       "      <td>0.421637</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.7500</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N7</th>\n",
       "      <td>4.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.2</td>\n",
       "      <td>0.421637</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.7500</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N8</th>\n",
       "      <td>4.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.1</td>\n",
       "      <td>0.316228</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.7500</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N9</th>\n",
       "      <td>4.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.1</td>\n",
       "      <td>0.316228</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.7500</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>110 rows × 26 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                    try          n_opt_space      n_obs      TOPK@1            \\\n",
       "                   mean      std        mean  std  mean  std   mean       std   \n",
       "rule      examples                                                              \n",
       "AC00003B? N0        4.5  3.02765         9.0  0.0   4.0  0.0    1.0  0.000000   \n",
       "          N1        4.5  3.02765         9.0  0.0   4.0  0.0    0.8  0.421637   \n",
       "          N2        4.5  3.02765         9.0  0.0   4.0  0.0    0.9  0.316228   \n",
       "          N3        4.5  3.02765         9.0  0.0   4.0  0.0    0.7  0.483046   \n",
       "          N4        4.5  3.02765         9.0  0.0   4.0  0.0    1.0  0.000000   \n",
       "...                 ...      ...         ...  ...   ...  ...    ...       ...   \n",
       "PD00004   N5        4.5  3.02765         4.0  0.0   3.0  0.0    0.3  0.483046   \n",
       "          N6        4.5  3.02765         4.0  0.0   3.0  0.0    0.2  0.421637   \n",
       "          N7        4.5  3.02765         4.0  0.0   3.0  0.0    0.2  0.421637   \n",
       "          N8        4.5  3.02765         4.0  0.0   3.0  0.0    0.1  0.316228   \n",
       "          N9        4.5  3.02765         4.0  0.0   3.0  0.0    0.1  0.316228   \n",
       "\n",
       "                   TOPK@2            ...    TOPK@6              TOPK@7  \\\n",
       "                     mean       std  ...      mean       std      mean   \n",
       "rule      examples                   ...                                 \n",
       "AC00003B? N0         1.00  0.000000  ...  0.633333  0.070273  0.571429   \n",
       "          N1         0.80  0.349603  ...  0.583333  0.161971  0.514286   \n",
       "          N2         0.85  0.337474  ...  0.583333  0.117851  0.514286   \n",
       "          N3         0.70  0.483046  ...  0.533333  0.189215  0.500000   \n",
       "          N4         0.90  0.210819  ...  0.616667  0.080508  0.528571   \n",
       "...                   ...       ...  ...       ...       ...       ...   \n",
       "PD00004   N5         0.50  0.000000  ...  0.750000  0.000000  0.750000   \n",
       "          N6         0.50  0.000000  ...  0.750000  0.000000  0.750000   \n",
       "          N7         0.50  0.000000  ...  0.750000  0.000000  0.750000   \n",
       "          N8         0.50  0.000000  ...  0.750000  0.000000  0.750000   \n",
       "          N9         0.50  0.000000  ...  0.750000  0.000000  0.750000   \n",
       "\n",
       "                              TOPK@8              TOPK@9        TOPK@10       \n",
       "                         std    mean       std      mean  std      mean  std  \n",
       "rule      examples                                                            \n",
       "AC00003B? N0        0.000000  0.5000  0.000000  0.444444  0.0  0.444444  0.0  \n",
       "          N1        0.099887  0.4750  0.052705  0.444444  0.0  0.444444  0.0  \n",
       "          N2        0.099887  0.4875  0.039528  0.444444  0.0  0.444444  0.0  \n",
       "          N3        0.121405  0.4625  0.060381  0.444444  0.0  0.444444  0.0  \n",
       "          N4        0.069007  0.4625  0.060381  0.444444  0.0  0.444444  0.0  \n",
       "...                      ...     ...       ...       ...  ...       ...  ...  \n",
       "PD00004   N5        0.000000  0.7500  0.000000  0.750000  0.0  0.750000  0.0  \n",
       "          N6        0.000000  0.7500  0.000000  0.750000  0.0  0.750000  0.0  \n",
       "          N7        0.000000  0.7500  0.000000  0.750000  0.0  0.750000  0.0  \n",
       "          N8        0.000000  0.7500  0.000000  0.750000  0.0  0.750000  0.0  \n",
       "          N9        0.000000  0.7500  0.000000  0.750000  0.0  0.750000  0.0  \n",
       "\n",
       "[110 rows x 26 columns]"
      ]
     },
     "execution_count": 58,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mean_std"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "78d3ac46",
   "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>rule</th>\n",
       "      <th>examples</th>\n",
       "      <th>try_mean</th>\n",
       "      <th>try_std</th>\n",
       "      <th>n_opt_space_mean</th>\n",
       "      <th>n_opt_space_std</th>\n",
       "      <th>n_obs_mean</th>\n",
       "      <th>n_obs_std</th>\n",
       "      <th>TOPK@1_mean</th>\n",
       "      <th>TOPK@1_std</th>\n",
       "      <th>...</th>\n",
       "      <th>TOPK@6_mean</th>\n",
       "      <th>TOPK@6_std</th>\n",
       "      <th>TOPK@7_mean</th>\n",
       "      <th>TOPK@7_std</th>\n",
       "      <th>TOPK@8_mean</th>\n",
       "      <th>TOPK@8_std</th>\n",
       "      <th>TOPK@9_mean</th>\n",
       "      <th>TOPK@9_std</th>\n",
       "      <th>TOPK@10_mean</th>\n",
       "      <th>TOPK@10_std</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>AC00003B?</td>\n",
       "      <td>N0</td>\n",
       "      <td>4.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>9.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>0.633333</td>\n",
       "      <td>0.070273</td>\n",
       "      <td>0.571429</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.5000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>AC00003B?</td>\n",
       "      <td>N1</td>\n",
       "      <td>4.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>9.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.8</td>\n",
       "      <td>0.421637</td>\n",
       "      <td>...</td>\n",
       "      <td>0.583333</td>\n",
       "      <td>0.161971</td>\n",
       "      <td>0.514286</td>\n",
       "      <td>0.099887</td>\n",
       "      <td>0.4750</td>\n",
       "      <td>0.052705</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>AC00003B?</td>\n",
       "      <td>N2</td>\n",
       "      <td>4.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>9.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.9</td>\n",
       "      <td>0.316228</td>\n",
       "      <td>...</td>\n",
       "      <td>0.583333</td>\n",
       "      <td>0.117851</td>\n",
       "      <td>0.514286</td>\n",
       "      <td>0.099887</td>\n",
       "      <td>0.4875</td>\n",
       "      <td>0.039528</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>AC00003B?</td>\n",
       "      <td>N3</td>\n",
       "      <td>4.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>9.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.7</td>\n",
       "      <td>0.483046</td>\n",
       "      <td>...</td>\n",
       "      <td>0.533333</td>\n",
       "      <td>0.189215</td>\n",
       "      <td>0.500000</td>\n",
       "      <td>0.121405</td>\n",
       "      <td>0.4625</td>\n",
       "      <td>0.060381</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>AC00003B?</td>\n",
       "      <td>N4</td>\n",
       "      <td>4.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>9.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>0.616667</td>\n",
       "      <td>0.080508</td>\n",
       "      <td>0.528571</td>\n",
       "      <td>0.069007</td>\n",
       "      <td>0.4625</td>\n",
       "      <td>0.060381</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>105</th>\n",
       "      <td>PD00004</td>\n",
       "      <td>N5</td>\n",
       "      <td>4.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.3</td>\n",
       "      <td>0.483046</td>\n",
       "      <td>...</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.7500</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>106</th>\n",
       "      <td>PD00004</td>\n",
       "      <td>N6</td>\n",
       "      <td>4.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.2</td>\n",
       "      <td>0.421637</td>\n",
       "      <td>...</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.7500</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>107</th>\n",
       "      <td>PD00004</td>\n",
       "      <td>N7</td>\n",
       "      <td>4.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.2</td>\n",
       "      <td>0.421637</td>\n",
       "      <td>...</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.7500</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>108</th>\n",
       "      <td>PD00004</td>\n",
       "      <td>N8</td>\n",
       "      <td>4.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.1</td>\n",
       "      <td>0.316228</td>\n",
       "      <td>...</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.7500</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>109</th>\n",
       "      <td>PD00004</td>\n",
       "      <td>N9</td>\n",
       "      <td>4.5</td>\n",
       "      <td>3.02765</td>\n",
       "      <td>4.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.1</td>\n",
       "      <td>0.316228</td>\n",
       "      <td>...</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.7500</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>110 rows × 28 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "          rule examples  try_mean  try_std  n_opt_space_mean  n_opt_space_std  \\\n",
       "0    AC00003B?       N0       4.5  3.02765               9.0              0.0   \n",
       "1    AC00003B?       N1       4.5  3.02765               9.0              0.0   \n",
       "2    AC00003B?       N2       4.5  3.02765               9.0              0.0   \n",
       "3    AC00003B?       N3       4.5  3.02765               9.0              0.0   \n",
       "4    AC00003B?       N4       4.5  3.02765               9.0              0.0   \n",
       "..         ...      ...       ...      ...               ...              ...   \n",
       "105    PD00004       N5       4.5  3.02765               4.0              0.0   \n",
       "106    PD00004       N6       4.5  3.02765               4.0              0.0   \n",
       "107    PD00004       N7       4.5  3.02765               4.0              0.0   \n",
       "108    PD00004       N8       4.5  3.02765               4.0              0.0   \n",
       "109    PD00004       N9       4.5  3.02765               4.0              0.0   \n",
       "\n",
       "     n_obs_mean  n_obs_std  TOPK@1_mean  TOPK@1_std  ...  TOPK@6_mean  \\\n",
       "0           4.0        0.0          1.0    0.000000  ...     0.633333   \n",
       "1           4.0        0.0          0.8    0.421637  ...     0.583333   \n",
       "2           4.0        0.0          0.9    0.316228  ...     0.583333   \n",
       "3           4.0        0.0          0.7    0.483046  ...     0.533333   \n",
       "4           4.0        0.0          1.0    0.000000  ...     0.616667   \n",
       "..          ...        ...          ...         ...  ...          ...   \n",
       "105         3.0        0.0          0.3    0.483046  ...     0.750000   \n",
       "106         3.0        0.0          0.2    0.421637  ...     0.750000   \n",
       "107         3.0        0.0          0.2    0.421637  ...     0.750000   \n",
       "108         3.0        0.0          0.1    0.316228  ...     0.750000   \n",
       "109         3.0        0.0          0.1    0.316228  ...     0.750000   \n",
       "\n",
       "     TOPK@6_std  TOPK@7_mean  TOPK@7_std  TOPK@8_mean  TOPK@8_std  \\\n",
       "0      0.070273     0.571429    0.000000       0.5000    0.000000   \n",
       "1      0.161971     0.514286    0.099887       0.4750    0.052705   \n",
       "2      0.117851     0.514286    0.099887       0.4875    0.039528   \n",
       "3      0.189215     0.500000    0.121405       0.4625    0.060381   \n",
       "4      0.080508     0.528571    0.069007       0.4625    0.060381   \n",
       "..          ...          ...         ...          ...         ...   \n",
       "105    0.000000     0.750000    0.000000       0.7500    0.000000   \n",
       "106    0.000000     0.750000    0.000000       0.7500    0.000000   \n",
       "107    0.000000     0.750000    0.000000       0.7500    0.000000   \n",
       "108    0.000000     0.750000    0.000000       0.7500    0.000000   \n",
       "109    0.000000     0.750000    0.000000       0.7500    0.000000   \n",
       "\n",
       "     TOPK@9_mean  TOPK@9_std  TOPK@10_mean  TOPK@10_std  \n",
       "0       0.444444         0.0      0.444444          0.0  \n",
       "1       0.444444         0.0      0.444444          0.0  \n",
       "2       0.444444         0.0      0.444444          0.0  \n",
       "3       0.444444         0.0      0.444444          0.0  \n",
       "4       0.444444         0.0      0.444444          0.0  \n",
       "..           ...         ...           ...          ...  \n",
       "105     0.750000         0.0      0.750000          0.0  \n",
       "106     0.750000         0.0      0.750000          0.0  \n",
       "107     0.750000         0.0      0.750000          0.0  \n",
       "108     0.750000         0.0      0.750000          0.0  \n",
       "109     0.750000         0.0      0.750000          0.0  \n",
       "\n",
       "[110 rows x 28 columns]"
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Flatten MultiIndex columns\n",
    "mean_std.columns = ['_'.join(col) for col in mean_std.columns]\n",
    "mean_std = mean_std.reset_index()\n",
    "\n",
    "mean_std"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "1e6f73a0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "n_opt_space_mean\n",
       "41.0    40\n",
       "27.0    30\n",
       "15.0    20\n",
       "9.0     10\n",
       "4.0     10\n",
       "Name: count, dtype: int64"
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mean_std['n_opt_space_mean'].value_counts()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "906ec7dc",
   "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>try_mean</th>\n",
       "      <th>try_std</th>\n",
       "      <th>n_opt_space_mean</th>\n",
       "      <th>n_opt_space_std</th>\n",
       "      <th>n_obs_mean</th>\n",
       "      <th>n_obs_std</th>\n",
       "      <th>TOPK@1_mean</th>\n",
       "      <th>TOPK@1_std</th>\n",
       "      <th>TOPK@2_mean</th>\n",
       "      <th>TOPK@2_std</th>\n",
       "      <th>...</th>\n",
       "      <th>TOPK@6_mean</th>\n",
       "      <th>TOPK@6_std</th>\n",
       "      <th>TOPK@7_mean</th>\n",
       "      <th>TOPK@7_std</th>\n",
       "      <th>TOPK@8_mean</th>\n",
       "      <th>TOPK@8_std</th>\n",
       "      <th>TOPK@9_mean</th>\n",
       "      <th>TOPK@9_std</th>\n",
       "      <th>TOPK@10_mean</th>\n",
       "      <th>TOPK@10_std</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>examples</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",
       "      <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>N0</th>\n",
       "      <td>4.500000</td>\n",
       "      <td>3.027650</td>\n",
       "      <td>41.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.100</td>\n",
       "      <td>0.129099</td>\n",
       "      <td>0.1125</td>\n",
       "      <td>0.039528</td>\n",
       "      <td>...</td>\n",
       "      <td>0.112500</td>\n",
       "      <td>0.096740</td>\n",
       "      <td>0.110714</td>\n",
       "      <td>0.092078</td>\n",
       "      <td>0.115625</td>\n",
       "      <td>0.097029</td>\n",
       "      <td>0.113889</td>\n",
       "      <td>0.087887</td>\n",
       "      <td>0.117500</td>\n",
       "      <td>0.076030</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N1</th>\n",
       "      <td>4.458333</td>\n",
       "      <td>3.061307</td>\n",
       "      <td>41.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.100</td>\n",
       "      <td>0.129099</td>\n",
       "      <td>0.0750</td>\n",
       "      <td>0.105409</td>\n",
       "      <td>...</td>\n",
       "      <td>0.126852</td>\n",
       "      <td>0.101498</td>\n",
       "      <td>0.123016</td>\n",
       "      <td>0.098035</td>\n",
       "      <td>0.129861</td>\n",
       "      <td>0.100798</td>\n",
       "      <td>0.132716</td>\n",
       "      <td>0.092759</td>\n",
       "      <td>0.131944</td>\n",
       "      <td>0.085050</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N2</th>\n",
       "      <td>4.597222</td>\n",
       "      <td>3.004355</td>\n",
       "      <td>41.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.125</td>\n",
       "      <td>0.131762</td>\n",
       "      <td>0.0875</td>\n",
       "      <td>0.060381</td>\n",
       "      <td>...</td>\n",
       "      <td>0.116667</td>\n",
       "      <td>0.083005</td>\n",
       "      <td>0.117857</td>\n",
       "      <td>0.085610</td>\n",
       "      <td>0.118750</td>\n",
       "      <td>0.068483</td>\n",
       "      <td>0.128395</td>\n",
       "      <td>0.079898</td>\n",
       "      <td>0.125833</td>\n",
       "      <td>0.070282</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N3</th>\n",
       "      <td>4.500000</td>\n",
       "      <td>3.027650</td>\n",
       "      <td>41.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.050</td>\n",
       "      <td>0.105409</td>\n",
       "      <td>0.0875</td>\n",
       "      <td>0.183135</td>\n",
       "      <td>...</td>\n",
       "      <td>0.129167</td>\n",
       "      <td>0.129241</td>\n",
       "      <td>0.121429</td>\n",
       "      <td>0.107013</td>\n",
       "      <td>0.118750</td>\n",
       "      <td>0.102615</td>\n",
       "      <td>0.119444</td>\n",
       "      <td>0.101315</td>\n",
       "      <td>0.127500</td>\n",
       "      <td>0.086261</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N4</th>\n",
       "      <td>4.500000</td>\n",
       "      <td>3.027650</td>\n",
       "      <td>41.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.100</td>\n",
       "      <td>0.129099</td>\n",
       "      <td>0.1000</td>\n",
       "      <td>0.123897</td>\n",
       "      <td>...</td>\n",
       "      <td>0.112500</td>\n",
       "      <td>0.098296</td>\n",
       "      <td>0.103571</td>\n",
       "      <td>0.082309</td>\n",
       "      <td>0.106250</td>\n",
       "      <td>0.073094</td>\n",
       "      <td>0.108333</td>\n",
       "      <td>0.072603</td>\n",
       "      <td>0.115000</td>\n",
       "      <td>0.064833</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N5</th>\n",
       "      <td>4.500000</td>\n",
       "      <td>3.027650</td>\n",
       "      <td>41.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.075</td>\n",
       "      <td>0.120761</td>\n",
       "      <td>0.1125</td>\n",
       "      <td>0.139438</td>\n",
       "      <td>...</td>\n",
       "      <td>0.116667</td>\n",
       "      <td>0.098900</td>\n",
       "      <td>0.114286</td>\n",
       "      <td>0.094718</td>\n",
       "      <td>0.115625</td>\n",
       "      <td>0.086655</td>\n",
       "      <td>0.113889</td>\n",
       "      <td>0.090769</td>\n",
       "      <td>0.115000</td>\n",
       "      <td>0.084513</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N6</th>\n",
       "      <td>4.500000</td>\n",
       "      <td>3.027650</td>\n",
       "      <td>41.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.100</td>\n",
       "      <td>0.129099</td>\n",
       "      <td>0.1125</td>\n",
       "      <td>0.039528</td>\n",
       "      <td>...</td>\n",
       "      <td>0.125000</td>\n",
       "      <td>0.106896</td>\n",
       "      <td>0.121429</td>\n",
       "      <td>0.102058</td>\n",
       "      <td>0.118750</td>\n",
       "      <td>0.093275</td>\n",
       "      <td>0.119444</td>\n",
       "      <td>0.102777</td>\n",
       "      <td>0.112500</td>\n",
       "      <td>0.091790</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N7</th>\n",
       "      <td>4.500000</td>\n",
       "      <td>3.027650</td>\n",
       "      <td>41.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.100</td>\n",
       "      <td>0.129099</td>\n",
       "      <td>0.1250</td>\n",
       "      <td>0.079057</td>\n",
       "      <td>...</td>\n",
       "      <td>0.129167</td>\n",
       "      <td>0.082562</td>\n",
       "      <td>0.128571</td>\n",
       "      <td>0.070387</td>\n",
       "      <td>0.128125</td>\n",
       "      <td>0.075056</td>\n",
       "      <td>0.122222</td>\n",
       "      <td>0.069127</td>\n",
       "      <td>0.125000</td>\n",
       "      <td>0.073628</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N8</th>\n",
       "      <td>4.500000</td>\n",
       "      <td>3.027650</td>\n",
       "      <td>41.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.025</td>\n",
       "      <td>0.079057</td>\n",
       "      <td>0.0875</td>\n",
       "      <td>0.084369</td>\n",
       "      <td>...</td>\n",
       "      <td>0.091667</td>\n",
       "      <td>0.090673</td>\n",
       "      <td>0.092857</td>\n",
       "      <td>0.082381</td>\n",
       "      <td>0.103125</td>\n",
       "      <td>0.086603</td>\n",
       "      <td>0.100000</td>\n",
       "      <td>0.089185</td>\n",
       "      <td>0.100000</td>\n",
       "      <td>0.085220</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N9</th>\n",
       "      <td>4.500000</td>\n",
       "      <td>3.027650</td>\n",
       "      <td>41.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.075</td>\n",
       "      <td>0.120761</td>\n",
       "      <td>0.0625</td>\n",
       "      <td>0.065881</td>\n",
       "      <td>...</td>\n",
       "      <td>0.087500</td>\n",
       "      <td>0.096915</td>\n",
       "      <td>0.082143</td>\n",
       "      <td>0.087989</td>\n",
       "      <td>0.087500</td>\n",
       "      <td>0.090136</td>\n",
       "      <td>0.091667</td>\n",
       "      <td>0.073025</td>\n",
       "      <td>0.110000</td>\n",
       "      <td>0.070551</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>10 rows × 26 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "          try_mean   try_std  n_opt_space_mean  n_opt_space_std  n_obs_mean  \\\n",
       "examples                                                                      \n",
       "N0        4.500000  3.027650              41.0              0.0         5.0   \n",
       "N1        4.458333  3.061307              41.0              0.0         5.0   \n",
       "N2        4.597222  3.004355              41.0              0.0         5.0   \n",
       "N3        4.500000  3.027650              41.0              0.0         5.0   \n",
       "N4        4.500000  3.027650              41.0              0.0         5.0   \n",
       "N5        4.500000  3.027650              41.0              0.0         5.0   \n",
       "N6        4.500000  3.027650              41.0              0.0         5.0   \n",
       "N7        4.500000  3.027650              41.0              0.0         5.0   \n",
       "N8        4.500000  3.027650              41.0              0.0         5.0   \n",
       "N9        4.500000  3.027650              41.0              0.0         5.0   \n",
       "\n",
       "          n_obs_std  TOPK@1_mean  TOPK@1_std  TOPK@2_mean  TOPK@2_std  ...  \\\n",
       "examples                                                               ...   \n",
       "N0              0.0        0.100    0.129099       0.1125    0.039528  ...   \n",
       "N1              0.0        0.100    0.129099       0.0750    0.105409  ...   \n",
       "N2              0.0        0.125    0.131762       0.0875    0.060381  ...   \n",
       "N3              0.0        0.050    0.105409       0.0875    0.183135  ...   \n",
       "N4              0.0        0.100    0.129099       0.1000    0.123897  ...   \n",
       "N5              0.0        0.075    0.120761       0.1125    0.139438  ...   \n",
       "N6              0.0        0.100    0.129099       0.1125    0.039528  ...   \n",
       "N7              0.0        0.100    0.129099       0.1250    0.079057  ...   \n",
       "N8              0.0        0.025    0.079057       0.0875    0.084369  ...   \n",
       "N9              0.0        0.075    0.120761       0.0625    0.065881  ...   \n",
       "\n",
       "          TOPK@6_mean  TOPK@6_std  TOPK@7_mean  TOPK@7_std  TOPK@8_mean  \\\n",
       "examples                                                                  \n",
       "N0           0.112500    0.096740     0.110714    0.092078     0.115625   \n",
       "N1           0.126852    0.101498     0.123016    0.098035     0.129861   \n",
       "N2           0.116667    0.083005     0.117857    0.085610     0.118750   \n",
       "N3           0.129167    0.129241     0.121429    0.107013     0.118750   \n",
       "N4           0.112500    0.098296     0.103571    0.082309     0.106250   \n",
       "N5           0.116667    0.098900     0.114286    0.094718     0.115625   \n",
       "N6           0.125000    0.106896     0.121429    0.102058     0.118750   \n",
       "N7           0.129167    0.082562     0.128571    0.070387     0.128125   \n",
       "N8           0.091667    0.090673     0.092857    0.082381     0.103125   \n",
       "N9           0.087500    0.096915     0.082143    0.087989     0.087500   \n",
       "\n",
       "          TOPK@8_std  TOPK@9_mean  TOPK@9_std  TOPK@10_mean  TOPK@10_std  \n",
       "examples                                                                  \n",
       "N0          0.097029     0.113889    0.087887      0.117500     0.076030  \n",
       "N1          0.100798     0.132716    0.092759      0.131944     0.085050  \n",
       "N2          0.068483     0.128395    0.079898      0.125833     0.070282  \n",
       "N3          0.102615     0.119444    0.101315      0.127500     0.086261  \n",
       "N4          0.073094     0.108333    0.072603      0.115000     0.064833  \n",
       "N5          0.086655     0.113889    0.090769      0.115000     0.084513  \n",
       "N6          0.093275     0.119444    0.102777      0.112500     0.091790  \n",
       "N7          0.075056     0.122222    0.069127      0.125000     0.073628  \n",
       "N8          0.086603     0.100000    0.089185      0.100000     0.085220  \n",
       "N9          0.090136     0.091667    0.073025      0.110000     0.070551  \n",
       "\n",
       "[10 rows x 26 columns]"
      ]
     },
     "execution_count": 69,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "exp = mean_std.drop(columns=['rule'])\n",
    "exp = exp.loc[(exp[\"n_opt_space_mean\"]>40)].groupby('examples').agg('mean')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6b975c40",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "2344ef16",
   "metadata": {},
   "outputs": [],
   "source": [
    "group_by = result_df.groupby([\"rule\",\"examples\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "30fd5fef",
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_data = pd.DataFrame()\n",
    "for k in range(1,11):\n",
    "    #print(group_by[f\"TOPK@{k}\"].agg(list).sort_index())\n",
    "    \n",
    "    mean_data[f\"TOPK@{k}@MEAN\"] = group_by[f\"TOPK@{k}\"].mean()\n",
    "    mean_data[f\"TOPK@{k}@STD\"] = group_by[f\"TOPK@{k}\"].std()\n",
    "\n",
    "#for k in range(1,6):\n",
    "#    if k == 1:\n",
    "#        avg_top = mean_data[f\"TOPK@{k}\"]\n",
    "#    else:\n",
    "#        avg_top += mean_data[f\"TOPK@{k}\"]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "33cbbe17",
   "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>TOPK@1@MEAN</th>\n",
       "      <th>TOPK@1@STD</th>\n",
       "      <th>TOPK@2@MEAN</th>\n",
       "      <th>TOPK@2@STD</th>\n",
       "      <th>TOPK@3@MEAN</th>\n",
       "      <th>TOPK@3@STD</th>\n",
       "      <th>TOPK@4@MEAN</th>\n",
       "      <th>TOPK@4@STD</th>\n",
       "      <th>TOPK@5@MEAN</th>\n",
       "      <th>TOPK@5@STD</th>\n",
       "      <th>TOPK@6@MEAN</th>\n",
       "      <th>TOPK@6@STD</th>\n",
       "      <th>TOPK@7@MEAN</th>\n",
       "      <th>TOPK@7@STD</th>\n",
       "      <th>TOPK@8@MEAN</th>\n",
       "      <th>TOPK@8@STD</th>\n",
       "      <th>TOPK@9@MEAN</th>\n",
       "      <th>TOPK@9@STD</th>\n",
       "      <th>TOPK@10@MEAN</th>\n",
       "      <th>TOPK@10@STD</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>rule</th>\n",
       "      <th>examples</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",
       "      <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\">AC00003B?</th>\n",
       "      <th>N0</th>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.00</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.925</td>\n",
       "      <td>0.120761</td>\n",
       "      <td>0.76</td>\n",
       "      <td>0.084327</td>\n",
       "      <td>0.633333</td>\n",
       "      <td>0.070273</td>\n",
       "      <td>0.571429</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.5000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N1</th>\n",
       "      <td>0.8</td>\n",
       "      <td>0.421637</td>\n",
       "      <td>0.80</td>\n",
       "      <td>0.349603</td>\n",
       "      <td>0.766667</td>\n",
       "      <td>0.316228</td>\n",
       "      <td>0.700</td>\n",
       "      <td>0.307318</td>\n",
       "      <td>0.62</td>\n",
       "      <td>0.239444</td>\n",
       "      <td>0.583333</td>\n",
       "      <td>0.161971</td>\n",
       "      <td>0.514286</td>\n",
       "      <td>0.099887</td>\n",
       "      <td>0.4750</td>\n",
       "      <td>0.052705</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N2</th>\n",
       "      <td>0.9</td>\n",
       "      <td>0.316228</td>\n",
       "      <td>0.85</td>\n",
       "      <td>0.337474</td>\n",
       "      <td>0.833333</td>\n",
       "      <td>0.283279</td>\n",
       "      <td>0.750</td>\n",
       "      <td>0.263523</td>\n",
       "      <td>0.70</td>\n",
       "      <td>0.141421</td>\n",
       "      <td>0.583333</td>\n",
       "      <td>0.117851</td>\n",
       "      <td>0.514286</td>\n",
       "      <td>0.099887</td>\n",
       "      <td>0.4875</td>\n",
       "      <td>0.039528</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N3</th>\n",
       "      <td>0.7</td>\n",
       "      <td>0.483046</td>\n",
       "      <td>0.70</td>\n",
       "      <td>0.483046</td>\n",
       "      <td>0.666667</td>\n",
       "      <td>0.471405</td>\n",
       "      <td>0.675</td>\n",
       "      <td>0.391755</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.282843</td>\n",
       "      <td>0.533333</td>\n",
       "      <td>0.189215</td>\n",
       "      <td>0.500000</td>\n",
       "      <td>0.121405</td>\n",
       "      <td>0.4625</td>\n",
       "      <td>0.060381</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N4</th>\n",
       "      <td>1.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.90</td>\n",
       "      <td>0.210819</td>\n",
       "      <td>0.933333</td>\n",
       "      <td>0.140546</td>\n",
       "      <td>0.875</td>\n",
       "      <td>0.131762</td>\n",
       "      <td>0.74</td>\n",
       "      <td>0.096609</td>\n",
       "      <td>0.616667</td>\n",
       "      <td>0.080508</td>\n",
       "      <td>0.528571</td>\n",
       "      <td>0.069007</td>\n",
       "      <td>0.4625</td>\n",
       "      <td>0.060381</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.444444</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">PD00004</th>\n",
       "      <th>N5</th>\n",
       "      <td>0.3</td>\n",
       "      <td>0.483046</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.666667</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.7500</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N6</th>\n",
       "      <td>0.2</td>\n",
       "      <td>0.421637</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.666667</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.7500</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N7</th>\n",
       "      <td>0.2</td>\n",
       "      <td>0.421637</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.666667</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.7500</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N8</th>\n",
       "      <td>0.1</td>\n",
       "      <td>0.316228</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.666667</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.7500</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>N9</th>\n",
       "      <td>0.1</td>\n",
       "      <td>0.316228</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.666667</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.7500</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.750000</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>110 rows × 20 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                    TOPK@1@MEAN  TOPK@1@STD  TOPK@2@MEAN  TOPK@2@STD  \\\n",
       "rule      examples                                                     \n",
       "AC00003B? N0                1.0    0.000000         1.00    0.000000   \n",
       "          N1                0.8    0.421637         0.80    0.349603   \n",
       "          N2                0.9    0.316228         0.85    0.337474   \n",
       "          N3                0.7    0.483046         0.70    0.483046   \n",
       "          N4                1.0    0.000000         0.90    0.210819   \n",
       "...                         ...         ...          ...         ...   \n",
       "PD00004   N5                0.3    0.483046         0.50    0.000000   \n",
       "          N6                0.2    0.421637         0.50    0.000000   \n",
       "          N7                0.2    0.421637         0.50    0.000000   \n",
       "          N8                0.1    0.316228         0.50    0.000000   \n",
       "          N9                0.1    0.316228         0.50    0.000000   \n",
       "\n",
       "                    TOPK@3@MEAN  TOPK@3@STD  TOPK@4@MEAN  TOPK@4@STD  \\\n",
       "rule      examples                                                     \n",
       "AC00003B? N0           1.000000    0.000000        0.925    0.120761   \n",
       "          N1           0.766667    0.316228        0.700    0.307318   \n",
       "          N2           0.833333    0.283279        0.750    0.263523   \n",
       "          N3           0.666667    0.471405        0.675    0.391755   \n",
       "          N4           0.933333    0.140546        0.875    0.131762   \n",
       "...                         ...         ...          ...         ...   \n",
       "PD00004   N5           0.666667    0.000000        0.750    0.000000   \n",
       "          N6           0.666667    0.000000        0.750    0.000000   \n",
       "          N7           0.666667    0.000000        0.750    0.000000   \n",
       "          N8           0.666667    0.000000        0.750    0.000000   \n",
       "          N9           0.666667    0.000000        0.750    0.000000   \n",
       "\n",
       "                    TOPK@5@MEAN  TOPK@5@STD  TOPK@6@MEAN  TOPK@6@STD  \\\n",
       "rule      examples                                                     \n",
       "AC00003B? N0               0.76    0.084327     0.633333    0.070273   \n",
       "          N1               0.62    0.239444     0.583333    0.161971   \n",
       "          N2               0.70    0.141421     0.583333    0.117851   \n",
       "          N3               0.60    0.282843     0.533333    0.189215   \n",
       "          N4               0.74    0.096609     0.616667    0.080508   \n",
       "...                         ...         ...          ...         ...   \n",
       "PD00004   N5               0.75    0.000000     0.750000    0.000000   \n",
       "          N6               0.75    0.000000     0.750000    0.000000   \n",
       "          N7               0.75    0.000000     0.750000    0.000000   \n",
       "          N8               0.75    0.000000     0.750000    0.000000   \n",
       "          N9               0.75    0.000000     0.750000    0.000000   \n",
       "\n",
       "                    TOPK@7@MEAN  TOPK@7@STD  TOPK@8@MEAN  TOPK@8@STD  \\\n",
       "rule      examples                                                     \n",
       "AC00003B? N0           0.571429    0.000000       0.5000    0.000000   \n",
       "          N1           0.514286    0.099887       0.4750    0.052705   \n",
       "          N2           0.514286    0.099887       0.4875    0.039528   \n",
       "          N3           0.500000    0.121405       0.4625    0.060381   \n",
       "          N4           0.528571    0.069007       0.4625    0.060381   \n",
       "...                         ...         ...          ...         ...   \n",
       "PD00004   N5           0.750000    0.000000       0.7500    0.000000   \n",
       "          N6           0.750000    0.000000       0.7500    0.000000   \n",
       "          N7           0.750000    0.000000       0.7500    0.000000   \n",
       "          N8           0.750000    0.000000       0.7500    0.000000   \n",
       "          N9           0.750000    0.000000       0.7500    0.000000   \n",
       "\n",
       "                    TOPK@9@MEAN  TOPK@9@STD  TOPK@10@MEAN  TOPK@10@STD  \n",
       "rule      examples                                                      \n",
       "AC00003B? N0           0.444444         0.0      0.444444          0.0  \n",
       "          N1           0.444444         0.0      0.444444          0.0  \n",
       "          N2           0.444444         0.0      0.444444          0.0  \n",
       "          N3           0.444444         0.0      0.444444          0.0  \n",
       "          N4           0.444444         0.0      0.444444          0.0  \n",
       "...                         ...         ...           ...          ...  \n",
       "PD00004   N5           0.750000         0.0      0.750000          0.0  \n",
       "          N6           0.750000         0.0      0.750000          0.0  \n",
       "          N7           0.750000         0.0      0.750000          0.0  \n",
       "          N8           0.750000         0.0      0.750000          0.0  \n",
       "          N9           0.750000         0.0      0.750000          0.0  \n",
       "\n",
       "[110 rows x 20 columns]"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mean_data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 153,
   "id": "f2e121ee",
   "metadata": {},
   "outputs": [],
   "source": [
    "avg= mean_data[\"TOPK@1@MEAN\"]\n",
    "\n",
    "for i in [1,2,3,4,5,6,7,8,9,10]:\n",
    "    avg += mean_data[f\"TOPK@{i}@MEAN\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 154,
   "id": "02259983",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "examples\n",
       "N0    0.385853\n",
       "N1    0.384216\n",
       "N2    0.355291\n",
       "N3    0.354442\n",
       "N4    0.356328\n",
       "N5    0.348369\n",
       "N6    0.351394\n",
       "N7    0.331548\n",
       "N8    0.340961\n",
       "N9    0.327531\n",
       "Name: TOPK@1@MEAN, dtype: float64"
      ]
     },
     "execution_count": 154,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "avg/10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "80e32e68",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.11.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
