{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 102,
   "id": "a3892e90",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 54 runs in runs:\n"
     ]
    }
   ],
   "source": [
    "import inspect\n",
    "import os\n",
    "import sys\n",
    "from pathlib import Path\n",
    "\n",
    "import analysis\n",
    "import pandas as pd\n",
    "\n",
    "# In Jupyter, __file__ is not defined, so use the current working directory\n",
    "sys.path.insert(0, os.path.abspath(os.path.join(os.getcwd(), '..')))\n",
    "\n",
    "import matcher\n",
    "\n",
    "from frankenstein.tools import arithmetic, data_retrieval\n",
    "\n",
    "ARITHMETIC_TOOL_NAMES = [name for name, _ in inspect.getmembers(arithmetic, predicate=inspect.isfunction)]\n",
    "DATA_TOOL_NAMES = [name for name, _ in inspect.getmembers(data_retrieval, predicate=inspect.isfunction)]\n",
    "\n",
    "run_dir = Path('runs')\n",
    "dfs = {f.stem: pd.read_json(f, orient='records', lines=True, precise_float=True) for f in run_dir.iterdir()}\n",
    "print(f'Found {len(dfs)} runs in {run_dir}:')\n",
    "\n",
    "m = matcher.Matcher()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "id": "f948488c",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Processing runs: 100%|██████████| 54/54 [00:12<00:00,  4.38run/s]\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>run</th>\n",
       "      <th>n</th>\n",
       "      <th>accuracy</th>\n",
       "      <th>error_rate</th>\n",
       "      <th>correct_indicator_data_process</th>\n",
       "      <th>precision</th>\n",
       "      <th>coverage</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>Llama-3.3-70B-Instruct_answerable-full_all-too...</td>\n",
       "      <td>400</td>\n",
       "      <td>0.39</td>\n",
       "      <td>0.34</td>\n",
       "      <td>0.20</td>\n",
       "      <td>0.33$\\pm$0.39</td>\n",
       "      <td>0.28$\\pm$0.37</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>Llama-3.3-70B-Instruct_answerable-full_all-too...</td>\n",
       "      <td>400</td>\n",
       "      <td>0.37</td>\n",
       "      <td>0.28</td>\n",
       "      <td>0.16</td>\n",
       "      <td>0.4$\\pm$0.4</td>\n",
       "      <td>0.3$\\pm$0.37</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>37</th>\n",
       "      <td>Llama-3.3-70B-Instruct_answerable-full_all-too...</td>\n",
       "      <td>400</td>\n",
       "      <td>0.28</td>\n",
       "      <td>0.20</td>\n",
       "      <td>0.07</td>\n",
       "      <td>0.3$\\pm$0.38</td>\n",
       "      <td>0.19$\\pm$0.3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>52</th>\n",
       "      <td>Mistral-Small-3.1-24B_answerable-full_all-tool...</td>\n",
       "      <td>400</td>\n",
       "      <td>0.77</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.88$\\pm$0.21</td>\n",
       "      <td>0.88$\\pm$0.21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>42</th>\n",
       "      <td>Mistral-Small-3.1-24B_answerable-full_all-tool...</td>\n",
       "      <td>400</td>\n",
       "      <td>0.79</td>\n",
       "      <td>0.06</td>\n",
       "      <td>0.82</td>\n",
       "      <td>0.88$\\pm$0.21</td>\n",
       "      <td>0.87$\\pm$0.21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>51</th>\n",
       "      <td>Mistral-Small-3.1-24B_answerable-full_all-tool...</td>\n",
       "      <td>400</td>\n",
       "      <td>0.77</td>\n",
       "      <td>0.06</td>\n",
       "      <td>0.74</td>\n",
       "      <td>0.87$\\pm$0.22</td>\n",
       "      <td>0.85$\\pm$0.23</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>Qwen3-14B_answerable-full_all-tools_0-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.58</td>\n",
       "      <td>0.19</td>\n",
       "      <td>0.66</td>\n",
       "      <td>0.85$\\pm$0.26</td>\n",
       "      <td>0.72$\\pm$0.28</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>Qwen3-14B_answerable-full_all-tools_1-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.61</td>\n",
       "      <td>0.23</td>\n",
       "      <td>0.51</td>\n",
       "      <td>0.83$\\pm$0.28</td>\n",
       "      <td>0.71$\\pm$0.28</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>38</th>\n",
       "      <td>Qwen3-14B_answerable-full_all-tools_3-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.57</td>\n",
       "      <td>0.44</td>\n",
       "      <td>0.37</td>\n",
       "      <td>0.78$\\pm$0.29</td>\n",
       "      <td>0.67$\\pm$0.29</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>43</th>\n",
       "      <td>Qwen3-30B-A3B_answerable-full_all-tools_0-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.68</td>\n",
       "      <td>0.24</td>\n",
       "      <td>0.61</td>\n",
       "      <td>0.85$\\pm$0.27</td>\n",
       "      <td>0.71$\\pm$0.27</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>Qwen3-30B-A3B_answerable-full_all-tools_1-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.67</td>\n",
       "      <td>0.18</td>\n",
       "      <td>0.59</td>\n",
       "      <td>0.87$\\pm$0.25</td>\n",
       "      <td>0.74$\\pm$0.25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>47</th>\n",
       "      <td>Qwen3-30B-A3B_answerable-full_all-tools_3-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.66</td>\n",
       "      <td>0.22</td>\n",
       "      <td>0.52</td>\n",
       "      <td>0.87$\\pm$0.25</td>\n",
       "      <td>0.73$\\pm$0.25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>Qwen3-32B_answerable-full_all-tools_0-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.84</td>\n",
       "      <td>0.34</td>\n",
       "      <td>0.67</td>\n",
       "      <td>0.9$\\pm$0.21</td>\n",
       "      <td>0.81$\\pm$0.22</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>Qwen3-32B_answerable-full_all-tools_1-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.86</td>\n",
       "      <td>0.24</td>\n",
       "      <td>0.65</td>\n",
       "      <td>0.91$\\pm$0.2</td>\n",
       "      <td>0.81$\\pm$0.22</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>Qwen3-32B_answerable-full_all-tools_3-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.84</td>\n",
       "      <td>0.19</td>\n",
       "      <td>0.52</td>\n",
       "      <td>0.91$\\pm$0.19</td>\n",
       "      <td>0.79$\\pm$0.21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>Qwen3-4B_answerable-full_all-tools_0-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.67</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.76$\\pm$0.32</td>\n",
       "      <td>0.66$\\pm$0.31</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>Qwen3-4B_answerable-full_all-tools_1-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.77$\\pm$0.34</td>\n",
       "      <td>0.64$\\pm$0.31</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>Qwen3-4B_answerable-full_all-tools_3-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.53</td>\n",
       "      <td>0.56</td>\n",
       "      <td>0.37</td>\n",
       "      <td>0.67$\\pm$0.38</td>\n",
       "      <td>0.55$\\pm$0.35</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>gpt-4.1-mini_answerable-full_all-tools_0-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.70</td>\n",
       "      <td>0.53</td>\n",
       "      <td>0.48</td>\n",
       "      <td>0.84$\\pm$0.22</td>\n",
       "      <td>0.86$\\pm$0.2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>gpt-4.1-mini_answerable-full_all-tools_1-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.70</td>\n",
       "      <td>0.37</td>\n",
       "      <td>0.46</td>\n",
       "      <td>0.86$\\pm$0.2</td>\n",
       "      <td>0.87$\\pm$0.2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>39</th>\n",
       "      <td>gpt-4.1-mini_answerable-full_all-tools_3-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.70</td>\n",
       "      <td>0.36</td>\n",
       "      <td>0.38</td>\n",
       "      <td>0.85$\\pm$0.22</td>\n",
       "      <td>0.85$\\pm$0.21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45</th>\n",
       "      <td>gpt-4o-mini_answerable-full_all-tools_0-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.68</td>\n",
       "      <td>0.52</td>\n",
       "      <td>0.39</td>\n",
       "      <td>0.67$\\pm$0.3</td>\n",
       "      <td>0.74$\\pm$0.31</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>gpt-4o-mini_answerable-full_all-tools_1-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.64</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.24</td>\n",
       "      <td>0.63$\\pm$0.34</td>\n",
       "      <td>0.67$\\pm$0.34</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>gpt-4o-mini_answerable-full_all-tools_3-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.64</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.28</td>\n",
       "      <td>0.64$\\pm$0.33</td>\n",
       "      <td>0.67$\\pm$0.33</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                  run    n  accuracy  \\\n",
       "33  Llama-3.3-70B-Instruct_answerable-full_all-too...  400      0.39   \n",
       "16  Llama-3.3-70B-Instruct_answerable-full_all-too...  400      0.37   \n",
       "37  Llama-3.3-70B-Instruct_answerable-full_all-too...  400      0.28   \n",
       "52  Mistral-Small-3.1-24B_answerable-full_all-tool...  400      0.77   \n",
       "42  Mistral-Small-3.1-24B_answerable-full_all-tool...  400      0.79   \n",
       "51  Mistral-Small-3.1-24B_answerable-full_all-tool...  400      0.77   \n",
       "6          Qwen3-14B_answerable-full_all-tools_0-shot  400      0.58   \n",
       "15         Qwen3-14B_answerable-full_all-tools_1-shot  400      0.61   \n",
       "38         Qwen3-14B_answerable-full_all-tools_3-shot  400      0.57   \n",
       "43     Qwen3-30B-A3B_answerable-full_all-tools_0-shot  400      0.68   \n",
       "31     Qwen3-30B-A3B_answerable-full_all-tools_1-shot  400      0.67   \n",
       "47     Qwen3-30B-A3B_answerable-full_all-tools_3-shot  400      0.66   \n",
       "17         Qwen3-32B_answerable-full_all-tools_0-shot  400      0.84   \n",
       "2          Qwen3-32B_answerable-full_all-tools_1-shot  400      0.86   \n",
       "25         Qwen3-32B_answerable-full_all-tools_3-shot  400      0.84   \n",
       "26          Qwen3-4B_answerable-full_all-tools_0-shot  400      0.60   \n",
       "30          Qwen3-4B_answerable-full_all-tools_1-shot  400      0.60   \n",
       "13          Qwen3-4B_answerable-full_all-tools_3-shot  400      0.53   \n",
       "22      gpt-4.1-mini_answerable-full_all-tools_0-shot  400      0.70   \n",
       "7       gpt-4.1-mini_answerable-full_all-tools_1-shot  400      0.70   \n",
       "39      gpt-4.1-mini_answerable-full_all-tools_3-shot  400      0.70   \n",
       "45       gpt-4o-mini_answerable-full_all-tools_0-shot  400      0.68   \n",
       "23       gpt-4o-mini_answerable-full_all-tools_1-shot  400      0.64   \n",
       "0        gpt-4o-mini_answerable-full_all-tools_3-shot  400      0.64   \n",
       "\n",
       "    error_rate  correct_indicator_data_process      precision       coverage  \n",
       "33        0.34                            0.20  0.33$\\pm$0.39  0.28$\\pm$0.37  \n",
       "16        0.28                            0.16    0.4$\\pm$0.4   0.3$\\pm$0.37  \n",
       "37        0.20                            0.07   0.3$\\pm$0.38   0.19$\\pm$0.3  \n",
       "52        0.05                            0.81  0.88$\\pm$0.21  0.88$\\pm$0.21  \n",
       "42        0.06                            0.82  0.88$\\pm$0.21  0.87$\\pm$0.21  \n",
       "51        0.06                            0.74  0.87$\\pm$0.22  0.85$\\pm$0.23  \n",
       "6         0.19                            0.66  0.85$\\pm$0.26  0.72$\\pm$0.28  \n",
       "15        0.23                            0.51  0.83$\\pm$0.28  0.71$\\pm$0.28  \n",
       "38        0.44                            0.37  0.78$\\pm$0.29  0.67$\\pm$0.29  \n",
       "43        0.24                            0.61  0.85$\\pm$0.27  0.71$\\pm$0.27  \n",
       "31        0.18                            0.59  0.87$\\pm$0.25  0.74$\\pm$0.25  \n",
       "47        0.22                            0.52  0.87$\\pm$0.25  0.73$\\pm$0.25  \n",
       "17        0.34                            0.67   0.9$\\pm$0.21  0.81$\\pm$0.22  \n",
       "2         0.24                            0.65   0.91$\\pm$0.2  0.81$\\pm$0.22  \n",
       "25        0.19                            0.52  0.91$\\pm$0.19  0.79$\\pm$0.21  \n",
       "26        0.67                            0.60  0.76$\\pm$0.32  0.66$\\pm$0.31  \n",
       "30        0.50                            0.50  0.77$\\pm$0.34  0.64$\\pm$0.31  \n",
       "13        0.56                            0.37  0.67$\\pm$0.38  0.55$\\pm$0.35  \n",
       "22        0.53                            0.48  0.84$\\pm$0.22   0.86$\\pm$0.2  \n",
       "7         0.37                            0.46   0.86$\\pm$0.2   0.87$\\pm$0.2  \n",
       "39        0.36                            0.38  0.85$\\pm$0.22  0.85$\\pm$0.21  \n",
       "45        0.52                            0.39   0.67$\\pm$0.3  0.74$\\pm$0.31  \n",
       "23        0.40                            0.24  0.63$\\pm$0.34  0.67$\\pm$0.34  \n",
       "0         0.40                            0.28  0.64$\\pm$0.33  0.67$\\pm$0.33  "
      ]
     },
     "execution_count": 103,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from tqdm import tqdm\n",
    "\n",
    "summary_rows = []\n",
    "for run_name, run_df in tqdm(dfs.items(), desc='Processing runs', unit='run'):\n",
    "    # Compute tool call columns if not already present\n",
    "    # Keep only rows where df['answer_format'] is not bool\n",
    "    # run_df = run_df[run_df['answer_format'] != bool]\n",
    "    if 'gold_tool_calls' not in run_df.columns:\n",
    "        tools = DATA_TOOL_NAMES if 'data-tools' in run_name else []\n",
    "        run_df['gold_tool_calls'] = run_df.apply(lambda row: analysis.get_gold_tool_calls(row, tools), axis=1)\n",
    "    if 'pred_tool_calls' not in run_df.columns:\n",
    "        run_df['pred_tool_calls'] = run_df.apply(analysis.get_pred_tool_calls, axis=1)\n",
    "    if 'true_positives' not in run_df.columns:\n",
    "        run_df['true_positives'] = run_df.apply(analysis.get_true_positives, axis=1)\n",
    "    if 'false_positives' not in run_df.columns:\n",
    "        run_df['false_positives'] = run_df.apply(analysis.get_false_positives, axis=1)\n",
    "    if 'false_negatives' not in run_df.columns:\n",
    "        run_df['false_negatives'] = run_df.apply(analysis.get_false_negatives, axis=1)\n",
    "    if 'precision' not in run_df.columns:\n",
    "        run_df['precision'] = run_df.apply(analysis.get_precision, axis=1)\n",
    "    if 'coverage' not in run_df.columns:\n",
    "        run_df['coverage'] = run_df.apply(analysis.get_coverage, axis=1)\n",
    "    if 'error_made' not in run_df.columns:\n",
    "        run_df['error_made'] = run_df.apply(analysis.get_error_made, axis=1)\n",
    "    if 'correct_indicator_data_process' not in run_df.columns:\n",
    "        run_df['correct_indicator_data_process'] = run_df.apply(analysis.get_correct_indicator_data_process, axis=1)\n",
    "\n",
    "    summary = {\n",
    "        'run': run_name,\n",
    "        'n': len(run_df),\n",
    "        'accuracy': run_df['correct'].mean() if 'correct' in run_df.columns else None,\n",
    "        'precision_mean': run_df['precision'].mean(),\n",
    "        'precision_std': run_df['precision'].std(),\n",
    "        'coverage_mean': run_df['coverage'].mean(),\n",
    "        'coverage_std': run_df['coverage'].std(),\n",
    "        'error_rate': run_df['error_made'].mean(),\n",
    "        'correct_indicator_data_process': run_df['correct_indicator_data_process'].mean(),\n",
    "    }\n",
    "    summary_rows.append(summary)\n",
    "\n",
    "summary_df = pd.DataFrame(summary_rows)\n",
    "summary_df = summary_df.sort_values(by='run')\n",
    "summary_df = summary_df.round(2)  # Round to 2 decimal places\n",
    "\n",
    "# Drop certain rows from the summary depending on the run name\n",
    "summary_df = summary_df[~summary_df['run'].str.contains('Llama-3.1-70B|Llama-3.1-8B|Llama-3.2-3B')]\n",
    "# Currently I have 'mean' and 'std' for precision and coverage, can I put these in a single column with a format like '0.85 ± 0.05'?\n",
    "summary_df['precision'] = summary_df.apply(lambda row: rf'{row[\"precision_mean\"]}$\\pm${row[\"precision_std\"]}', axis=1)\n",
    "summary_df['coverage'] = summary_df.apply(lambda row: rf'{row[\"coverage_mean\"]}$\\pm${row[\"coverage_std\"]}', axis=1)\n",
    "summary_df = summary_df.drop(columns=['precision_mean', 'precision_std', 'coverage_mean', 'coverage_std'])\n",
    "normal_runs = summary_df[~summary_df['run'].str.contains('data-tools|partial')]\n",
    "zero_shot = normal_runs[normal_runs['run'].str.contains('0-shot')]\n",
    "one_shot = normal_runs[normal_runs['run'].str.contains('1-shot')]\n",
    "three_shot = normal_runs[normal_runs['run'].str.contains('3-shot')]\n",
    "partial_runs = summary_df[summary_df['run'].str.contains('partial')]\n",
    "data_tool_runs = summary_df[summary_df['run'].str.contains('data-tools')]\n",
    "normal_runs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "id": "d07fbafb",
   "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>run</th>\n",
       "      <th>n</th>\n",
       "      <th>accuracy</th>\n",
       "      <th>error_rate</th>\n",
       "      <th>correct_indicator_data_process</th>\n",
       "      <th>precision</th>\n",
       "      <th>coverage</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>41</th>\n",
       "      <td>Llama-3.3-70B-Instruct_answerable-full_data-to...</td>\n",
       "      <td>400</td>\n",
       "      <td>0.39</td>\n",
       "      <td>0.66</td>\n",
       "      <td>0.46</td>\n",
       "      <td>0.83$\\pm$0.25</td>\n",
       "      <td>0.74$\\pm$0.34</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>Mistral-Small-3.1-24B_answerable-full_data-too...</td>\n",
       "      <td>400</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.11</td>\n",
       "      <td>0.74</td>\n",
       "      <td>0.93$\\pm$0.19</td>\n",
       "      <td>0.92$\\pm$0.19</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>Qwen3-14B_answerable-full_data-tools_0-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.38</td>\n",
       "      <td>0.33</td>\n",
       "      <td>0.64</td>\n",
       "      <td>0.85$\\pm$0.27</td>\n",
       "      <td>0.82$\\pm$0.29</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>49</th>\n",
       "      <td>Qwen3-30B-A3B_answerable-full_data-tools_0-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.37</td>\n",
       "      <td>0.28</td>\n",
       "      <td>0.65</td>\n",
       "      <td>0.88$\\pm$0.23</td>\n",
       "      <td>0.88$\\pm$0.25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>Qwen3-32B_answerable-full_data-tools_0-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.74</td>\n",
       "      <td>0.29</td>\n",
       "      <td>0.70</td>\n",
       "      <td>0.92$\\pm$0.18</td>\n",
       "      <td>0.92$\\pm$0.19</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>Qwen3-4B_answerable-full_data-tools_0-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.28</td>\n",
       "      <td>0.42</td>\n",
       "      <td>0.65</td>\n",
       "      <td>0.82$\\pm$0.3</td>\n",
       "      <td>0.81$\\pm$0.32</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>gpt-4.1-mini_answerable-full_data-tools_0-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.20</td>\n",
       "      <td>0.53</td>\n",
       "      <td>0.9$\\pm$0.19</td>\n",
       "      <td>0.92$\\pm$0.16</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>gpt-4o-mini_answerable-full_data-tools_0-shot</td>\n",
       "      <td>400</td>\n",
       "      <td>0.36</td>\n",
       "      <td>0.52</td>\n",
       "      <td>0.35</td>\n",
       "      <td>0.69$\\pm$0.35</td>\n",
       "      <td>0.75$\\pm$0.33</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                  run    n  accuracy  \\\n",
       "41  Llama-3.3-70B-Instruct_answerable-full_data-to...  400      0.39   \n",
       "4   Mistral-Small-3.1-24B_answerable-full_data-too...  400      0.40   \n",
       "1         Qwen3-14B_answerable-full_data-tools_0-shot  400      0.38   \n",
       "49    Qwen3-30B-A3B_answerable-full_data-tools_0-shot  400      0.37   \n",
       "10        Qwen3-32B_answerable-full_data-tools_0-shot  400      0.74   \n",
       "24         Qwen3-4B_answerable-full_data-tools_0-shot  400      0.28   \n",
       "20     gpt-4.1-mini_answerable-full_data-tools_0-shot  400      0.50   \n",
       "11      gpt-4o-mini_answerable-full_data-tools_0-shot  400      0.36   \n",
       "\n",
       "    error_rate  correct_indicator_data_process      precision       coverage  \n",
       "41        0.66                            0.46  0.83$\\pm$0.25  0.74$\\pm$0.34  \n",
       "4         0.11                            0.74  0.93$\\pm$0.19  0.92$\\pm$0.19  \n",
       "1         0.33                            0.64  0.85$\\pm$0.27  0.82$\\pm$0.29  \n",
       "49        0.28                            0.65  0.88$\\pm$0.23  0.88$\\pm$0.25  \n",
       "10        0.29                            0.70  0.92$\\pm$0.18  0.92$\\pm$0.19  \n",
       "24        0.42                            0.65   0.82$\\pm$0.3  0.81$\\pm$0.32  \n",
       "20        0.20                            0.53   0.9$\\pm$0.19  0.92$\\pm$0.16  \n",
       "11        0.52                            0.35  0.69$\\pm$0.35  0.75$\\pm$0.33  "
      ]
     },
     "execution_count": 104,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data_tool_runs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "id": "734f8b94",
   "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>run</th>\n",
       "      <th>n</th>\n",
       "      <th>accuracy</th>\n",
       "      <th>error_rate</th>\n",
       "      <th>correct_indicator_data_process</th>\n",
       "      <th>precision</th>\n",
       "      <th>coverage</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>50</th>\n",
       "      <td>Llama-3.3-70B-Instruct_answerable-partial_all-...</td>\n",
       "      <td>260</td>\n",
       "      <td>0.38</td>\n",
       "      <td>0.54</td>\n",
       "      <td>0.37</td>\n",
       "      <td>0.41$\\pm$0.39</td>\n",
       "      <td>0.31$\\pm$0.38</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>Mistral-Small-3.1-24B_answerable-partial_all-t...</td>\n",
       "      <td>260</td>\n",
       "      <td>0.62</td>\n",
       "      <td>0.10</td>\n",
       "      <td>0.73</td>\n",
       "      <td>0.84$\\pm$0.24</td>\n",
       "      <td>0.82$\\pm$0.25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>Qwen3-14B_answerable-partial_all-tools_0-shot</td>\n",
       "      <td>260</td>\n",
       "      <td>0.49</td>\n",
       "      <td>0.24</td>\n",
       "      <td>0.66</td>\n",
       "      <td>0.83$\\pm$0.29</td>\n",
       "      <td>0.67$\\pm$0.3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>Qwen3-30B-A3B_answerable-partial_all-tools_0-shot</td>\n",
       "      <td>260</td>\n",
       "      <td>0.62</td>\n",
       "      <td>0.22</td>\n",
       "      <td>0.67</td>\n",
       "      <td>0.86$\\pm$0.28</td>\n",
       "      <td>0.69$\\pm$0.31</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>Qwen3-32B_answerable-partial_all-tools_0-shot</td>\n",
       "      <td>260</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.27</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.92$\\pm$0.19</td>\n",
       "      <td>0.79$\\pm$0.23</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>Qwen3-4B_answerable-partial_all-tools_0-shot</td>\n",
       "      <td>260</td>\n",
       "      <td>0.49</td>\n",
       "      <td>0.71</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.71$\\pm$0.36</td>\n",
       "      <td>0.59$\\pm$0.34</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>44</th>\n",
       "      <td>gpt-4.1-mini_answerable-partial_all-tools_0-shot</td>\n",
       "      <td>260</td>\n",
       "      <td>0.55</td>\n",
       "      <td>0.64</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.81$\\pm$0.21</td>\n",
       "      <td>0.84$\\pm$0.21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>53</th>\n",
       "      <td>gpt-4o-mini_answerable-partial_all-tools_0-shot</td>\n",
       "      <td>260</td>\n",
       "      <td>0.49</td>\n",
       "      <td>0.71</td>\n",
       "      <td>0.46</td>\n",
       "      <td>0.6$\\pm$0.31</td>\n",
       "      <td>0.68$\\pm$0.32</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                  run    n  accuracy  \\\n",
       "50  Llama-3.3-70B-Instruct_answerable-partial_all-...  260      0.38   \n",
       "12  Mistral-Small-3.1-24B_answerable-partial_all-t...  260      0.62   \n",
       "29      Qwen3-14B_answerable-partial_all-tools_0-shot  260      0.49   \n",
       "21  Qwen3-30B-A3B_answerable-partial_all-tools_0-shot  260      0.62   \n",
       "5       Qwen3-32B_answerable-partial_all-tools_0-shot  260      0.75   \n",
       "9        Qwen3-4B_answerable-partial_all-tools_0-shot  260      0.49   \n",
       "44   gpt-4.1-mini_answerable-partial_all-tools_0-shot  260      0.55   \n",
       "53    gpt-4o-mini_answerable-partial_all-tools_0-shot  260      0.49   \n",
       "\n",
       "    error_rate  correct_indicator_data_process      precision       coverage  \n",
       "50        0.54                            0.37  0.41$\\pm$0.39  0.31$\\pm$0.38  \n",
       "12        0.10                            0.73  0.84$\\pm$0.24  0.82$\\pm$0.25  \n",
       "29        0.24                            0.66  0.83$\\pm$0.29   0.67$\\pm$0.3  \n",
       "21        0.22                            0.67  0.86$\\pm$0.28  0.69$\\pm$0.31  \n",
       "5         0.27                            0.75  0.92$\\pm$0.19  0.79$\\pm$0.23  \n",
       "9         0.71                            0.60  0.71$\\pm$0.36  0.59$\\pm$0.34  \n",
       "44        0.64                            0.60  0.81$\\pm$0.21  0.84$\\pm$0.21  \n",
       "53        0.71                            0.46   0.6$\\pm$0.31  0.68$\\pm$0.32  "
      ]
     },
     "execution_count": 105,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "partial_runs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "id": "12ce2b6c",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Processing runs:   0%|          | 0/54 [00:00<?, ?run/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Processing runs: 100%|██████████| 54/54 [00:00<00:00, 1061.86run/s]\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>run</th>\n",
       "      <th>No error</th>\n",
       "      <th>Error</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>Llama 3.3 70B Instruct</td>\n",
       "      <td>0.33</td>\n",
       "      <td>0.50</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>52</th>\n",
       "      <td>Mistral Small 3.1 24B</td>\n",
       "      <td>0.78</td>\n",
       "      <td>0.71</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>Qwen3 14B</td>\n",
       "      <td>0.63</td>\n",
       "      <td>0.37</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>43</th>\n",
       "      <td>Qwen3 30B A3B</td>\n",
       "      <td>0.74</td>\n",
       "      <td>0.51</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>Qwen3 32B</td>\n",
       "      <td>0.85</td>\n",
       "      <td>0.84</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>Qwen3 4B</td>\n",
       "      <td>0.64</td>\n",
       "      <td>0.58</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>gpt 4.1 mini</td>\n",
       "      <td>0.69</td>\n",
       "      <td>0.72</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45</th>\n",
       "      <td>gpt 4o mini</td>\n",
       "      <td>0.66</td>\n",
       "      <td>0.70</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                        run  No error  Error\n",
       "33  Llama 3.3 70B Instruct       0.33   0.50\n",
       "52   Mistral Small 3.1 24B       0.78   0.71\n",
       "6                Qwen3 14B       0.63   0.37\n",
       "43           Qwen3 30B A3B       0.74   0.51\n",
       "17               Qwen3 32B       0.85   0.84\n",
       "26                Qwen3 4B       0.64   0.58\n",
       "22            gpt 4.1 mini       0.69   0.72\n",
       "45             gpt 4o mini       0.66   0.70"
      ]
     },
     "execution_count": 106,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "error_rows = []\n",
    "for run_name, run_df in tqdm(dfs.items(), desc='Processing runs', unit='run'):\n",
    "    if 'error_made' not in run_df.columns:\n",
    "        run_df['error_made'] = run_df.apply(analysis.get_error_made, axis=1)\n",
    "    if 'correct' not in run_df.columns:\n",
    "        run_df['correct'] = run_df.apply(lambda row: analysis.get_correct(row, m), axis=1)\n",
    "    errors = {\n",
    "        'run': run_name,\n",
    "        # 'correct-and-error': ((run_df['correct'] == True) & (run_df['error_made'] == True)).sum(),\n",
    "        # 'correct-and-no-error': ((run_df['correct'] == True) & (run_df['error_made'] == False)).sum(),\n",
    "        # 'incorrect-and-error': ((run_df['correct'] == False) & (run_df['error_made'] == True)).sum(),\n",
    "        # 'incorrect-and-no-error': ((run_df['correct'] == False) & (run_df['error_made'] == False)).sum(),\n",
    "        'p_correct_given_no_error': ((run_df['correct'] == True) & (run_df['error_made'] == False)).sum()\n",
    "        / ((run_df['error_made'] == False).sum() or 1),\n",
    "        'p_correct_given_error': ((run_df['correct'] == True) & (run_df['error_made'] == True)).sum()\n",
    "        / ((run_df['error_made'] == True).sum() or 1),\n",
    "    }\n",
    "    error_rows.append(errors)\n",
    "error_df = pd.DataFrame(error_rows)\n",
    "error_df = error_df.round(2)  # Round to 2 decimal places\n",
    "error_df = error_df.sort_values(by='run')\n",
    "error_df = error_df[~error_df['run'].str.contains('Llama-3.1-70B|Llama-3.1-8B|Llama-3.2-3B')]\n",
    "error_df = error_df[error_df['run'].str.contains('answerable-full_all-tools_0-shot')]\n",
    "# Remove 'answerable-full_all-tools_0-shot' from the run names\n",
    "error_df['run'] = error_df['run'].str.replace('answerable-full_all-tools_0-shot', '', regex=False)\n",
    "# Replace '-' and '_' with ' ' in the run names\n",
    "error_df['run'] = error_df['run'].str.replace('-', ' ', regex=False)\n",
    "error_df['run'] = error_df['run'].str.replace('_', ' ', regex=False)\n",
    "# Replace column names with latex formatting p(correct | error) and p(correct | no error)\n",
    "error_df = error_df.rename(\n",
    "    columns={\n",
    "        'p_correct_given_error': 'Error',\n",
    "        'p_correct_given_no_error': 'No error',\n",
    "    }\n",
    ")\n",
    "# error_df = error_df.rename(\n",
    "#     columns={\n",
    "#         'p_correct_given_error': r'$P(\\text{correct} | \\text{error})$',\n",
    "#         'p_correct_given_no_error': r'$P(\\text{correct} | \\text{no error})$',\n",
    "#     }\n",
    "# )\n",
    "error_df\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "id": "ff13f809",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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vqxc9urVKzRr1gyPHj0CAJw7dw7t27fH+fPnZY0M1aFDB4wcORJz5sxBgwYN4O/vDysrK+zfvx/Pnz+Ht7c3vv/++0zbJCQk4Nq1a3j9+nWW+pYtW4amTZviypUrqFSpEho0aAAHBwdcuXIFly5dAgD06dMHvXv3znOsRERERESFnazE4siRIyhXrhwqVKigXLZmzRo8evQIHTp0wNSpU7Ft2zZ8++23mDdvHoKCgmQFFxQUBG9vb8yfPx8nTpxAamoqPD09MWHCBIwePTpPU5FXrVoVFy9exG+//YZ///0XYWFhSElJQbFixfDJJ5+gf//+6Natm6w4yfC4T9ipk3pjfmqjk3qJiIiI9J0kFBNQ5IGjoyNq166NXbt2KZd17twZW7ZswZ07d5R9GipVqgQTExNcuHBBexHrmcTERNjZ2SEhIUHtoW8p/zGxIKL36ey6YKGjV2ynJuimXiKid+TlXldWH4tnz57B3t4+07JTp06hcuXKmTpKV6tWLUs/DCIiIiIiKnhkJRZWVlZ48uSJ8ntMTAwePHgAb2/vTOVMTEyQlpamWYRERERERKT3ZCUWlStXxrFjx5TJxZo1ayBJEho3bpypXGxsLBwdHTWPkoiIiIiI9JqsztsBAQE4efIk6tSpAy8vL+zatQs2NjZo3769sszr168REREBPz8/rQVLRERERET6SVZiMWjQIJw6dQorVqxAbGwsbGxssGzZMtjY2CjLbNu2DcnJyfj444+1FiwREREREeknWYmFJElYtmwZpk2bhkePHqFixYqwtrbOVKZ8+fIIDg5GgwYNtBIoERERERHpL1mJhYKLiwtcXFxUrqtZsyZq1qypSfVERERERGQgZHXeJiIiIiIiepdGTyxCQ0MREhKCe/fu4fXr1yrLSJKEpUuXarIbIiIiIiLSc7ISizdv3qBnz57YsmULACCnybuZWBARERERFXyyEovvv/8ewcHBsLKywmeffYZKlSrlOsU3EREREREVXLISi3/++QeWlpYIDQ1F5cqVtR0TEREREREZGFmdt+/evQtvb28mFUREREREBEBmYlGsWDHY29trOxYiIiIiIjJQshKLZs2aITQ0NMdO20REREREVHjI7rxds2ZNTJ06FdOmTdN2TERElA33CTt1Um/MT210Ui8RERUeshKLI0eOoF+/fvjhhx+we/dutGnTBq6urjAyUv0ApG/fvhoFSURERERE+k1WYhEYGAhJkiCEQFhYGMLDw3Msz8SCiIiIiKhgk5VY9O3bF5IkaTsWIiIiIiIyULISixUrVmg5DCIiIiIiMmSyRoXKizdv3uh6F0RERERElM90llicP38eo0aNgpOTk652QUREREREekLWq1DZSUxMxOrVq7F06VJERkZCCMG+GEREREREhYBWEouDBw9i2bJl2Lx5M16/fg0hBMzMzNC2bVuOCEVERERkiKba6ajeBN3US/lOdmJx7949rFixAsuXL0d0dLRyFm5JkrBgwQL06NEDRYsW1VacRERERESkx/KUWKSlpWHr1q1YunQp9u3bh4yMDAghULx4cfTu3Rt79+7FtWvXMHToUF3FS0REREREekitxOLy5ctYunQp/v77b8TFxUEIASMjI7Ro0QIDBgzAp59+ClNTUzRu3FjX8RIRERERkR5SK7GoWrWqcqbtsmXLol+/fggMDOSIT0Tv4/uoREREVEjl6VUoZ2dnzJgxAx07doSJiVYHlCIiIiIiIgOm1jwWbdu2hZGREe7evYsePXqgTJkyGDNmDC5cuKDr+IiIiIiIyAColVhs27YNsbGxmD59Ojw9PREXF4egoCDUrFkT9erVw6JFi5CYmKjrWImIiIiISE+p/T5TqVKlMGHCBEyYMAFHjhzBn3/+iU2bNiE8PBxnzpzBmDFj+HoUEREREVFuCmifTLWeWLzv448/xqpVq/DgwQMsWLAAtWrVQnJyMl68eAEAcHFxwaRJk3D16lWtBktERERERPpJVmKhYGtri6FDhyI8PBxnz57F8OHDUaxYMdy7dw8///wzqlSpggYNGmgrViIiIiIi0lMaJRbvql69OubMmYP79+9j9erVaNq0KQAgLCxMW7sgIiIiIiI9pfVOEWZmZujZsyd69uyJ6OhorFixQtu7ICIiIqL/5z5hp07qjbHQSbVUgGntiYUqHh4emDZtmi53QUREREREekCniQURERERERUOTCyIiIiIiEhjTCyIiIiIiEhjTCyIiIiIiEhjTCyIiIiIiEhjTCyIiIiIiEhjshKL7777Dtu2bcu13Pbt2/Hdd9/J2QURERERERkQWYnF1KlTsWXLllzLbdu2jfNYEBEREREVAjp9FSojIwOSJOlyF0REREREpAd0mljExsbC2tpal7sgIiIiIiI9YKJu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xo0bERERgTNnzqB27do4c+YM5s6dq+2YiYiIiIhIz8hKLNatWwdbW1vs2bMHXl5eWdbXqlULu3btgo2NDdauXatxkEREREREpN9kJRbXr19H06ZNUbx48WzLODg4oGnTprh27Zrs4IiIiIiIyDDISizS09NhamqaazlTU9MsHbuJiIiIiKjgkZVYeHh44MiRI0hOTs62THJyMo4cOQIPDw/ZwRERERERkWGQlVi0b98ejx8/Ru/evfHkyZMs6588eaJc16FDB01jJCIiIiIiPSdruNmvv/4aa9aswdatW7Fv3z60bNlS+WQiKioKu3fvRnJyMtzc3PDVV19pNWAiIiIiItI/shKLYsWK4eDBg+jZsydOnz6NTZs2QZIkAIAQAgBQv359rFmzBkWLFtVasEREREREpJ9kz7zt4eGBU6dO4fjx4zh06BDu3bsHAHBycoKvry+8vb21FiQREREREek32YmFgre3N5MIIiIiIqJCTlbnbSIiIiIionep9cRCCIEGDRrg1q1b2LJlC3x8fHIsf+zYMXTs2BEVKlTAsWPHtBIoERHp0FQ7HdWboJt6iYhI76j1xGL79u0ICwtDt27dck0qAMDHxwfdu3fHyZMnsXv3bo2DJCIiIiIi/aZWYrFhwwZIkoRJkyapXbGi7Nq1a+VFRkREREREBkOtxCIsLAw1atSAs7Oz2hWXKVMGNWrUQGhoqOzgiIiIiIjIMKjVx+LevXto2bJlniv39PTkq1D6hu9RExEREZEOqPXEIjU1FSYmeR+Z1sTEBGlpaXnejoiIiIiIDItaiUXx4sVx+/btPFd++/Zt2Nvb53k7IiIiIiIyLGolFtWrV8eZM2cQFxendsVPnjxBeHg4qlWrJjs4IiIiIiIyDGolFq1atUJqamqeR4VKT09H69atZQdHRERERESGQa3EYuDAgXBwcMDSpUsxZswYpKamZls2NTUVY8aMwdKlS+Hg4ICBAwdqLVgiIiIiItJPavXItrS0xN9//402bdogKCgI//zzD7p37466deuiZMmSAIDHjx8jLCwM69atw+PHj2FkZIRVq1bB0tJSpwdARERERET5T+2hnlq0aIEtW7agT58+ePToEebOnauynBACdnZ2WLVqFT755BOtBUpERERERPpLrVehFNq0aYNbt25hypQpqFmzJiRJghACQghIkoQaNWpgypQp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IU6cOIFdu3bB2dkZP/30Ew4cOIAiRYpobV9ERERERCSfrMSidOnSmDZtGu7cuYM1a9agUaNGePjwIb777ju4ubmhZ8+eOHbsmFYC7NatGw4fPoyEhAQkJSXhwoULGD9+PMzMzLKUDQwMhBACMTExatev2CYkJEQr8RIRERERFUYaTZBnYmKCHj164OjRozh37hwGDhwIMzMzrFu3Dk2aNEGtWrWwdOlSjrJERERERFTAaW3m7WrVqmHRokW4e/cuvvrqKwghcP78eQwePBhOTk6YPHkyEhMTtbU7IiIiIiLSI1pLLADg6NGjGDx4MIKCggAAZmZmqFevHp4/f47p06ejcuXKuHTpkjZ3SUREREREekDjCfKSk5Px119/Yf78+bh48SKEEChdujQ+//xzDBkyBCVKlMCNGzcwefJkrF+/HmPHjsXu3bu1ETsRFSZT7XIvI6veBN3US0REVMjITixu3ryJ+fPnY+XKlUhISIAQAvXq1cPIkSPRrVs3mJj8V3W5cuWwdu1a3L59G6dOndJK4EREREREpD9kJRatWrXCvn37kJGRAVNTU/To0QMjR45E/fr1c9yucuXKOH36tKxAiYiIiIhIf8lKLPbs2YMSJUpg8ODBGDZsGEqXLq3Wdh06dICrq6ucXRIRERERkR6TlVgsW7YMvXr1UjmXRE7atWuHdu3aydklERERERHpMVmjQpUtW1atSehu3LiBI0eOyNkFEREREREZEFmJRdOmTfHzzz/nWm7mzJlo2rSpnF0QEREREZEBkZVYCCEghNB2LEREREREZKC0OkHe+549ewYLCwtd7oKIiIiIiPSA2p2379y5k+n7y5cvsyxTSEtLw6VLl7B37154enpqFiEREREREek9tRMLd3d3SJKk/L5p0yZs2rQpx22EEOjTp4/86IiIiIiIyCConVi4uroqE4s7d+7A0tISDg4OKsuamZnB2dkZnTt3xueff66dSImIiIiISG+pnVi8O7yskZERunbtimXLlukiJiIiIiIiMjCyJshbvnw5PvroI23HQkREREREBkpWYhEQEKDtOIiIiIiIyIDpdLhZIiIiIiIqHNR6YlG2bFlIkoSQkBB4eHigbNmyau9AkiTcunVLdoCFmfuEnVqvM4bTihARERGRDqiVWMTExECSJKSmpiq/q+vdIWqJiIiIiKhgUiuxiI6OBgA4OTll+k5ERERERASomVi4ubnl+J2IiIiIiAo3dt4mIiIiIiKNMbEgIiIiIiKNqfUqVP/+/WXvQJIkLF26VPb2RERERESk/9RKLFasWCF7B0wsiIiIiIgKPrUSi+XLl+s6DiIiIiIiMmBqJRYBAQG6joOIiIiIiAwYO28TEREREZHGmFgQEREREZHG1HoVatWqVQCAjh07wsbGRvldXX379s17ZEREREREZDDUSiwCAwMhSRIaNGgAGxsb5Xd1MbEgIiIiIirY1Eos+vbtC0mSYGdnl+k7ERERERERIHMeC03mtSAiIiIiooKHnbeJiIiIiEhjTCyIiIiIiEhjGiUWly9fxtChQ1GxYkVYW1vDysoKFSpUwNChQ3Hx4kVtxUhERERERHpOdmIxf/581KpVC0uWLMH169eRlJSE5ORk3LhxA4sXL0bt2rUxZ84cbcZKRERERER6SlZi8e+//2LEiBFIS0tDp06dsG3bNly4cAEXLlzA9u3b0aVLF6Snp2P06NH4999/tR0zERERERHpGbVGhXrfzJkzIUkS1q5di65du2ZaV6VKFbRp0wYbN25Et27dMHPmTLRq1UorwRIRERERkX6S9cTizJkzqFevXpak4l1dunRB/fr1cebMGdnBERERERGRYZCVWEiSBE9Pz1zLeXp6ciI9IiIiIqJCQFZiUb16ddy4cSPXcjdu3EC1atXk7IKIiIiIiAyIrMRizJgxCAsLw9q1a7Mts27dOoSFhWH06NGygyMiIiIiIsOgVuftO3fuZPpeu3ZtjB49Gn369MHGjRvRt29feHh4AACio6Px119/ITg4GKNHj0bdunW1HzUREREREekVtRILd3d3lX0lhBAIDg5GcHCwynW///47goKCkJaWpnmkRERERESkt9RKLFxdXdkJm4iIiIiIsqVWYhETE6PjMIiIiIiIyJDJ6rxNRERERET0LiYWRERERESkMbVehcpNQkICEhMTIYRQud7V1VUbuyEiIiIiIj0lO7F49uwZvv32W2zYsAFPnjzJtpwkSRwVioiIiIiogJOVWCQkJKBBgwa4efMmjI2NUaRIESQlJaF06dJ4+PAhhBCQJIlPKoiIiIiICglZfSx++eUX3LhxA3379kVCQgK6dOkCSZJw7949vHjxAgsXLkTRokXRpEkTREdHaztmIiIiIiLSM7KeWGzbtg0ODg5Y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EREREWlM7eFmb968iVWrVsla37dv37xHRkREREREBkPtxOL48eM4fvy4ynWSJGW7XpIkJhZERERERAWcWomFq6srJEnSdSxERERERGSg1EosYmJidBwGEREREREZMnbeJiIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijTGxICIiIiIijel9YrFhwwb4+vqiWLFisLKyQo0aNTBz5kykpqbKqu/MmTPo2rUrHB0dYWFhAQ8PD4wYMQKPHz/WcuRERERERIWHXicWX375Jbp164bjx4+jXr16aNmyJe7cuYPx48fDz88PycnJeapv48aNaNCgATZu3Ag3Nzd8+umnMDIywrx581C9enXcvHlTR0dCRERERFSw6W1isWXLFgQFBcHa2hqhoaHYs2cPNm3ahBs3bqBatWo4duwYJk+erHZ99+/fR0BAANLS0rBo0SKcPn0a69atw/Xr19GnTx88evQIvXr1ghBCh0dFRERERFQw6W1iMX36dADAhAkT4OXlpVzu4OCABQsWAADmzZuHhIQEter7/fffkZSUhGbNmmHw4MHK5cbGxli4cCHs7OwQFhaGvXv3avEoiIiIiIgKB71MLO7du4ewsDAAQK9evbKs9/HxgYuLC1JSUrBr1y616gwODs62Pmtra7Rv3x4AsHnzZrlhExEREREVWnqZWERGRgIA7O3t4eHhobJMnTp1MpXNyYsXL5T9JxTbaVIfERERERFlZpLfAagSHR0NAHB1dc22jIuLS6ayOYmJiVH+O7s61a0vJSUFKSkpyu+KV7ESExNzjSOvMlKStF5n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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# ...existing code...\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(8, 6))\n",
    "error_df['run'] = error_df['run'].apply(lambda x: x.replace(' ', '\\n') if isinstance(x, str) else x)\n",
    "\n",
    "error_df.plot(\n",
    "    x='run',\n",
    "    y=['No error', 'Error'],\n",
    "    kind='bar',\n",
    "    ax=ax,\n",
    "    # color=['C2', 'C3'],\n",
    ")\n",
    "# Set x limit of 1.0 to avoid overlap of bars\n",
    "ax.set_ylim(0, 1.0)\n",
    "ax.set_ylabel('Probability of Correct Answer')\n",
    "ax.set_xlabel('Model')\n",
    "# Increase font size of the x-axis labels\n",
    "ax.tick_params(axis='x', labelsize=16)\n",
    "# Increase font size of the y-axis labels\n",
    "ax.tick_params(axis='y', labelsize=16)\n",
    "# Increase font size of y axis label\n",
    "ax.set_ylabel('Probability of Correct Answer', fontsize=16)\n",
    "# Increase font size of x axis label\n",
    "ax.set_xlabel('Model', fontsize=16)\n",
    "# Increase font size of the legend\n",
    "ax.legend(fontsize=16)\n",
    "# # Increase width of bars\n",
    "# for bar in ax.patches:\n",
    "#     bar.set_width(0.4)\n",
    "# bar.set_x(bar.get_x() + 0.3)  # Adjust x position to center the bars\n",
    "\n",
    "# ax.set_title('Effect of Error on Correct Answer Probability', fontsize=16)\n",
    "plt.xticks(rotation=0)\n",
    "plt.tight_layout()\n",
    "plt.savefig('correct_answer_probability_with_and_without_error.png', dpi=300)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7b7222e7",
   "metadata": {},
   "source": [
    "### [results.ipynb](vscode-remote://wsl/home/njf/code/frankenstein/eval/results.ipynb)\n",
    "\n",
    "Add a new cell at the end to plot a bar chart comparing overall accuracy for `zero_shot` and `data_tool_runs`.\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 118,
   "id": "1f3619bf",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_22816/2846645967.py:4: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  zero_shot['run'] = zero_shot['run'].str.replace('answerable-full_all-tools_0-shot', '', regex=False)\n",
      "/tmp/ipykernel_22816/2846645967.py:5: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  zero_shot['run'] = zero_shot['run'].str.replace('-', ' ', regex=False)\n",
      "/tmp/ipykernel_22816/2846645967.py:6: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  zero_shot['run'] = zero_shot['run'].str.replace('_', ' ', regex=False)\n",
      "/tmp/ipykernel_22816/2846645967.py:8: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  data_tool_runs['run'] = data_tool_runs['run'].str.replace('answerable-full_data-tools_0-shot', '', regex=False)\n",
      "/tmp/ipykernel_22816/2846645967.py:9: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  data_tool_runs['run'] = data_tool_runs['run'].str.replace('-', ' ', regex=False)\n",
      "/tmp/ipykernel_22816/2846645967.py:10: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  data_tool_runs['run'] = data_tool_runs['run'].str.replace('_', ' ', regex=False)\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>run</th>\n",
       "      <th>All tools</th>\n",
       "      <th>Data retrieval\\ntools only</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>Llama 3.3 70B Instruct</td>\n",
       "      <td>0.39</td>\n",
       "      <td>0.39</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>52</th>\n",
       "      <td>Mistral Small 3.1 24B</td>\n",
       "      <td>0.77</td>\n",
       "      <td>0.40</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>Qwen3 14B</td>\n",
       "      <td>0.58</td>\n",
       "      <td>0.38</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>43</th>\n",
       "      <td>Qwen3 30B A3B</td>\n",
       "      <td>0.68</td>\n",
       "      <td>0.37</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>Qwen3 32B</td>\n",
       "      <td>0.84</td>\n",
       "      <td>0.74</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>Qwen3 4B</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.28</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>gpt 4.1 mini</td>\n",
       "      <td>0.70</td>\n",
       "      <td>0.50</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45</th>\n",
       "      <td>gpt 4o mini</td>\n",
       "      <td>0.68</td>\n",
       "      <td>0.36</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                        run  All tools  Data retrieval\\ntools only\n",
       "33  Llama 3.3 70B Instruct        0.39                        0.39\n",
       "52   Mistral Small 3.1 24B        0.77                        0.40\n",
       "6                Qwen3 14B        0.58                        0.38\n",
       "43           Qwen3 30B A3B        0.68                        0.37\n",
       "17               Qwen3 32B        0.84                        0.74\n",
       "26                Qwen3 4B        0.60                        0.28\n",
       "22            gpt 4.1 mini        0.70                        0.50\n",
       "45             gpt 4o mini        0.68                        0.36"
      ]
     },
     "execution_count": 118,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# ...existing code...\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "zero_shot['run'] = zero_shot['run'].str.replace('answerable-full_all-tools_0-shot', '', regex=False)\n",
    "zero_shot['run'] = zero_shot['run'].str.replace('-', ' ', regex=False)\n",
    "zero_shot['run'] = zero_shot['run'].str.replace('_', ' ', regex=False)\n",
    "\n",
    "data_tool_runs['run'] = data_tool_runs['run'].str.replace('answerable-full_data-tools_0-shot', '', regex=False)\n",
    "data_tool_runs['run'] = data_tool_runs['run'].str.replace('-', ' ', regex=False)\n",
    "data_tool_runs['run'] = data_tool_runs['run'].str.replace('_', ' ', regex=False)\n",
    "\n",
    "# Prepare accuracy data for zero_shot and data_tool_runs\n",
    "accuracy_df = pd.DataFrame(\n",
    "    {\n",
    "        # run is same in both zero_shot and data_tool_runs\n",
    "        'run': zero_shot['run'],\n",
    "        'All tools': list(zero_shot['accuracy']),\n",
    "        'Data retrieval\\ntools only': list(data_tool_runs['accuracy']),\n",
    "    }\n",
    ")\n",
    "accuracy_df\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 119,
   "id": "b0de0548",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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QCKRIDw8vEjHRjqaWDx+/BgXLlwAAAQEBCis9/b2RpUqVZCRkVHof3QTE5NClbOzsyt8oERERERFUL16dQQGBsLc3BwA0K1bNwQGBso+FSpUkJVdu3YtmjVrhuDgYFSoUAHdu3dHjRo1sH//frRt2xazZs1SqD8jIwPt27fHiBEjEBMTAy8vL3Tp0gUZGRlYunQpGjRogOjo6ELFmp6eDm9vb8yZMwfPnj2Dn58funbtipo1a+LevXuYPXs20tLSCn3sFy5cQP369bFs2TJkZmaiS5cuaN68OaKjozF8+HB06NABmZmZeW6bnJyM5s2bY9WqVahduzbat28PIQQ2b94MLy+vQn3R7OLigg4dOuD169fYunVrnmWOHz+OGzduwMXFBe3bty/0sdF7OjnGIiYmBgBQpkwZODs751nGw8MD8fHxiImJwddff11gne3bt8fFixfx888/w8/PT+6pRXh4OI4fP44KFSqgc+fOmjkIIiIiUm5m4XocfGq8vb3h7e2NEydOIC0tDQsWLMhz5qJr165h5MiRspvnfv36ydYdOHAAXbp0wcyZM9G8eXO0adNGtm7GjBk4cuQIXFxccOTIEVndWVlZGDFiBNatW4fu3bsjNjYWRkZG+ca6a9cu/PXXX2jfvj327NkDQ0ND2brc3FxERETAzMysUMedkZGBHj164OXLlxg+fDiWLFkiq+/evXvw8/PDoUOHMGvWLMyZM0dh+927d+OLL75AREQErKysAACvXr2Cr68vLl++jBUrVmDq1KkFxjFmzBjs27cPy5cvx5AhQxTWL1++HAAwcuRISCSSQh0b/UMnn1jExcUBABwdHZWWqVKlilzZgkyePBlffPEFLl26hKpVq6Jdu3bo3bs3PDw80KFDBzRp0gQnTpyAtbV1vvVkZGQgJSVF7kNERESkSYsXL0Z2dja++uoruaQCeP9l6dChQwEAv/76q2z5u3fvZDfGixYtkktYDA0NsWTJEtjb2yMuLg67du0qMIZnz54BANq0aSOXVACAnp4efHx8CkxOpIKDg/HgwQNUqlQJv/32m1x91apVw4IFCwAAS5cuxbt37xS2Nzc3x4YNG2RJBQDY2tpiypQpAIAjR44UKo7WrVujTp06uHLlCk6fPi237tGjR9izZw/MzMwwcODAQtVH8nQysUhNTQUA2WPCvFhYWABAoW/szc3N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X/H06VMcPHgQenp6Bb7DjAqPiQURERERlQoJCQlYt24djIyMUKdOHcycORPNmzcv7rA+GUwsqFRilwciIqLSp2XLluAoAO3R2elmiYiIiIio5GBiQUREREREamNiQUREREREamNiQURERBrHfuxEuktbv59MLIiIiEhjpG9OzsjIKOZIiEgZ6e+npt90zsSCiIiINMbAwADm5uZ4+fIlcnJyijscIvqXnJwcvHz5Eubm5hpPLDjdLBEREWmUnZ0d4uPjERcXB2tra5iamkJfXx8SiaS4QyMqlYQQyMnJwdu3b5GcnIzc3FxUrFhR4/thYkFEREQaZWZmBmdnZzx//hyvXr1CYmJicYdERAD09fVhZmaG8uXLw8jISOP1M7EgIiIijTMyMoKDgwOEEMjKykJubm5xh0RUqunp6cHQ0FCrTw6ZWBAREZHWSCQSrXwzSkS6h4O3iYiIiIhIbUwsiIiIiIhIbewKRUREpE0zrbVUb7J26iUiUhGfWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdoMijsAIiIiIlKd05QwrdR7f34HrdRLny4+sSAiIiIiIrUxsSAiIiIiIrUxsSAiIiIiIrUxsSAiIiIiIrUxsSAiIiIiIrUxsSAiIiIiIrUxsSAiIiIiIrXxPRZERCUI56snIvp4eM0tGj6xICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitTGxICIiIiIitamUWOTm5mo6DqWCg4PRsmVL2NrawtzcHPXr18cvv/yCrKwslevcs2cPOnfujAoVKsDIyAjly5dH8+bN8eOPP2owciIiIiKi0kOlxKJq1aqYM2cOnj9/rul45IwbNw49e/bEmTNn0LhxY7Rr1w4PHz7E5MmT4evri7dv3xapvszMTPTs2RNdunTBkSNHUKdOHXTv3h1169bF3bt3sWTJEi0dCRERERHRp02lxOLx48f44Ycf4OjoiH79+uHcuXOajgu7d+/G4sWLYWFhgfPnz+PQoUMICQnB7du34ebmhtOnT2P69OlFqnPIkCEIDg5Gly5d8PDhQxw9ehTbtm3DsWPHkJCQgP3792v8OIiIiIiISgOVEovz58+jb9++kEgk2Lp1K7y8vODp6YlNmzYhIyNDI4HNnTsXADBlyhS4u7vLltvZ2WHFihUAgGXLliE5OblQ9R09ehSbN29G3bp1sXPnTtjZ2cmt19PTQ9OmTTUSOxERERFRaaNSYiFNIh49eoS5c+eiSpUquHTpEgYOHAgHBwdMnToVDx8+VDmox48f48KFCwCAgIAAhfXe3t6oUqUKMjIyEB4eXqg6ly5dCuB99ypDQ0OVYyMiIiIiIkVqzQpVtmxZTJkyBXFxcdi9ezdat26Nly9f4ueff4aLiwu++uorHD16tMj1xsTEAADKlCkDZ2fnPMt4eHjIlc1PTk6OLI7PP/8cT58+xW+//YYRI0Zg3Lhx2LRpE968eVPkOImIiIiI6D2NTDcrkUjQuXNnHDp0CLGxsRg6dChycnKwd+9etG3bFnXq1MG6desKPZtUXFwcAMDR0VFpmSpVqsiVzc+9e/dkicO5c+dQo0YNjB8/HqtWrcLixYsRFBSEatWq4dixYwXWlZGRgZSUFLkPEREREVFpZ6DJyh48eID/+7//Q0hICABACIEKFSrg5s2bGDp0KJYtW4Z9+/bBwcEh33pSU1MBAObm5krLWFhYAEChbuyTkpJk/z9o0CA0b94cCxYsgKurK+7evYtp06YhPDwcX375JaKjo1GjRg2ldc2bNw+zZs0qcJ9ERET0D6cpYRqv8/78Dhqvk4hUp5EnFocPH0bnzp1RvXp1/Prrr0hLS8PAgQNx+fJlPHnyBIcPH0bTpk1x5coVjB8/XhO7LBIhhOz/K1eujEOHDsHDwwMWFhaoX78+9u7di7p16+LNmzeYP39+vnVNnToVycnJsk98fLy2wyciIiIi0nkqP7FISUnBhg0bsHLlSty+fRtCCFSuXBkjRozAsGHDULZsWVnZ1q1bw9fXFw0aNChUdyNLS0sAQFpamtIy0q5NVlZWha4PAIKCgmBsbCy3Xl9fH8OGDcPo0aNx5MiRfOsyNjZW2J6IiIiIqLRTKbEYMWIEtm7dirS0NAgh0KxZM4wZMwbdu3eHvr5+ntvo6enBw8MD169fL7B+JycnAMj3aYB0nbRsQfVJJBIIIVCtWrU8y0iXJyQkFFgfERERERHJUymxWL16NYyMjBAQEICxY8fKZmgqyOeffy7XLUmZhg0bAng/NiIuLi7PmaEuXrwIAHLvuFDGwsICNWvWRGxsLBITE/MsI10uHbtBRERERESFp9IYix9++AEPHjzA77//XuikAnjfDWnDhg0FlnNwcICnpycAYNu2bQrrT58+jfj4eBgbG8Pf379Q++7RowcAKO3q9OeffwIAGjduXKj6iIiIiIjoHyolFjNnzoS9vb2mY5Ezbdo0AMD8+fMRHR0tW56UlISRI0cCAEaNGgVra2vZutDQULi6usLPz0+hvjFjxsDW1hbh4eFYvXq13Lrt27dj69atsnJERERERFQ0KiUWr169wqlTp/D48WOlZR4/foxTp07h9evXKgXWpUsXjBkzBm/evEHTpk3Rvn17dO/eHdWrV8e1a9fg5eWF2bNny22TnJyMW7du4e7duwr12dnZYceOHTAxMcHw4cNRt25d9OjRA+7u7vj6668hhMD06dML/QSEiIiIiIj+odIYi8WLF2P27Nk4f/48KleunGeZhIQEtGrVCj/++CO+++47lYJbvHgxvLy8sHz5ckRGRiIrKwsuLi6YMmUKxo8fDyMjoyLV16ZNG1y5cgVz587FkSNHsGfPHlhZWcHf3x9jx45F27ZtVYqTiP6hjbnqAc5XT0REpOtUSizCw8NRrVq1fMdXeHh4wNnZGfv371c5sQCAnj17omfPnoUqGxQUhKCgoHzLfPbZZ9i4caPK8RARERERkSKVukLdv38fNWvWLLCcq6sr4uLiVNkFERERERGVIColFikpKXKDppWxsrJSeYwFERERERGVHColFuXKlUNsbGyB5W7duoUyZcqosgsiIiIiIipBVEosmjZtisuXL+PUqVNKy0RERCAmJgZNmzZVOTgiIiIiIioZVEosRowYASEEunfvjj179iis37NnD7p37w6JRILhw4erHSQREREREek2lWaF8vX1xahRo7Bs2TJ07doVdnZ2ssHcf//9N168eAEhBEaMGMEpXImIiIiISgGVEgsAWLJkCWrUqIHZs2fjxYsXePHihWydnZ0dvvvuO4wdO1YjQRIRERERkW5TObEAgNGjR2PkyJG4dOkSHjx4AABwdHSEh4cH9PX1NRIgERERERHpPrUSCwDQ19dH48aN0bhxY03EQ0REREREJZBKg7eJiIiIiIg+pPYTi9jYWNy6dQspKSkQQuRZpn///uruhoiIiIiIdJjKicW5c+cwdOhQXL9+XWkZIQQkEgkTCyIiIiKiT5xKicXff/+NNm3aIC0tDc2aNcOzZ88QFxeH3r174/bt27h8+TJycnLw1VdfwcrKStMxExERERGRjlFpjMXPP/+MtLQ0rFixAmfOnEGLFi0AAFu3bkVUVBRiYmLQoEED3L59G8uWLdNowEREREREpHtUSiyOHz8OFxcXpW/VrlOnDvbv34+7d+9izpw5agVIRERERES6T6XEIiEhAXXr1pX9LH1nRWZmpmxZxYoV4ePjgz/++EPNEImIiIiISNeplFiYmprCwOCf4RmWlpYAgGfPnsmVs7KyQnx8vBrhERERERFRSaBSYlG5cmU8fPhQ9nP16tUBAGfPnpUtE0IgOjoatra2aoZIRERERES6TqXEokmTJrhx4wbevn0LAGjXrh0AYPz48QgLC8O1a9cwYsQI3L17F56enpqLloiIiIiIdJJKiYW/vz/evXuH/fv3AwBcXFwwdOhQJCQkoHPnzmjQoAHWrFkDIyMj/PTTTxoNmIiIiIiIdI9K77Ho2rUrsrKy5JYtX74cNWrUQHBwMF6+fIlatWph2rRpqFOnjkYCJSIiIiIi3aXym7f/TU9PDxMmTMCECRM0VSUREREREZUQKnWFGjhwICZNmqTpWIiIiIiIqIRSKbHYsmUL4uLiNB0LERERERGVUColFhUqVIBEItF0LEREREREVEKplFi0adMGZ86cURjATUREREREpZNKicXMmTORkZGBIUOGIDU1VdMxERERERFRCaPSrFAbNmxAu3btsHnzZoSFhaF169ZwcnKCqampQlmJRILp06erHSgREREREekulRKLmTNnysZYJCUlYceOHQplJBIJhBBMLIiIiIiISgGVEosffviBg7eJiIiIiEhG5ScWREREREREUhp78zYRERERfUJmWmup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iIiIiKi00cnB23FxcQAAR0dHpWWqVKkiV1ZVQghZV6iOHTsqdJX6t4yMDGRkZMh+TklJUWv/RERERESfAp18YpGamgoAMDc3V1rGwsICgPo39rNmzcLZs2dhYWGB+fPnF1h+3rx5sLa2ln2kCQ4RERERUWmmk4nFx7J582b8+OOP0NPTw/r161GjRo0Ct5k6dSqSk5Nln/j4+I8QKRERERGRbtPJrlCWlpYAgLS0NKVl3rx5AwCwsrJSaR/BwcEYOHAgAGDt2rXo0aNHobYzNjYusLsUEREREVFpo5NPLJycnAAg36cB0nXSskXxxx9/ICAgALm5uVi9erUswSAiIiIiItXoZGIhnf41KSlJ6eDsixcvAoDcOy4KY/fu3ejduzdycnKwcuVKDBkyRL1giYiIiIhINxMLBwcHeHp6AgC2bdumsP706dOIj4+HsbEx/P39C13vvn370LNnT2RnZ2PlypUYNmyYxmImIiIiIirNdDKxAIBp06YBAObPn4/o6GjZ8qSkJIwcORIAMGrUKFhbW8vWhYaGwtXVFX5+fgr1hYeHo3v37sjOzsaqVauYVBARERERaZBODt4GgC5dumDMmDFYsmQJmjZtCj8/P5ibm+Po0aN4/fo1vLy8MHv2bLltkpOTcevWLbx7905u+fPnz9G1a1dkZmbCwcEBkZGRiIyMzHO/CxYsgJ2dndaOi4iIiIjoU6SziQUALF68GF5eXli+fDkiIyORlZUFFxcXTJkyBePHj4eRkVGh6klPT5e91O7Ro0fYtGmT0rIzZ85kYkFEREREVEQ6nVgAQM+ePdGzZ89ClQ0KCkJQUJDCcicnJwghNBwZERERERFJ6ewYCyIiIiIiKjmYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdqYWBARERERkdp0PrEIDg5Gy5YtYWtrC3Nzc9SvXx+//PILsrKyVKrv0qVL6NGjB+zt7WFiYgJnZ2eMHj0az58/13DkRERERESlh04nFuPGjUPPnj1x5swZNG7cGO3atcPDhw8xefJk+Pr64u3bt0Wqb9euXWjatCl27dqFqlWr4ssvv4Senh6WLVuGevXq4c6dO1o6EiIiIiKiT5vOJha7d+/G4sWLYWFhgfPnz+PQoUMICQnB7du34ebmhtOnT2P69OmFru/JkycIDAxEdnY2Vq9ejaioKOzYsQN///03+vbti2fPniEgIABCCC0eFRERERHRp0lnE4u5c+cCAKZMmQJ3d3fZcjs7O6xYsQIAsGzZMiQnJxeqvt9++w3p6elo3bo1hg4dKluur6+PlStXwtraGhcuXMDhw4c1eBRERERERKWDTiYWjx8/xoULFwAAAQEBCuu9vb1RpUoVZGRkIDw8vFB1hoaGKq3PwsICnTt3BgD88ccfqoZNRERERFRq6WRiERMTAwAoU6YMnJ2d8yzj4eEhVzY/qampsvET0u3UqY+IiIiIiOQZFHcAeYmLiwMAODo6Ki1TpUoVubL5uX//vuz/ldVZ2PoyMjKQkZEh+1naFSslJaXAOIoqNyNd43WmSLQ0hkQLx69N2mhbgO0LsG21je2rPWxb7eLfNO3huas9bNt/7nELMw5ZJxOL1NRUAIC5ubnSMhYWFgAKd0MvrS+/Ogtb37x58zBr1iyF5dLERNdZa6vi+Vqr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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Add line breaks to run names for readability\n",
    "accuracy_df['run'] = accuracy_df['run'].apply(lambda x: x.replace(' ', '\\n') if isinstance(x, str) else x)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(8, 6))\n",
    "accuracy_df.plot(\n",
    "    x='run',\n",
    "    y=['All tools', 'Data retrieval\\ntools only'],\n",
    "    kind='bar',\n",
    "    ax=ax,\n",
    "    # color=['C2', 'C3'],  # C2 is green, C3 is red\n",
    ")\n",
    "ax.set_ylim(0, 1.0)\n",
    "ax.set_ylabel('Accuracy', fontsize=16)\n",
    "ax.set_xlabel('Model', fontsize=16)\n",
    "ax.tick_params(axis='x', labelsize=16)\n",
    "ax.tick_params(axis='y', labelsize=16)\n",
    "ax.legend(fontsize=16)\n",
    "plt.xticks(rotation=0)\n",
    "plt.tight_layout()\n",
    "plt.savefig('overall_accuracy_zero_shot_vs_data_tools.png', dpi=300)\n",
    "plt.show()\n",
    "# ...existing code..."
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "frankenstein",
   "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.12.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
