{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Setup"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os, sys\n",
    "sys.path.append(os.path.dirname(os.path.dirname(os.getcwd())))\n",
    "from utils import DATA_DIR, ROOT_DIR, PLOT_DIR\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "from tqdm import tqdm\n",
    "\n",
    "from dataloader import get_nd_array, get_slice\n",
    "from download.hf import pull_predictions_from_hf\n",
    "\n",
    "import ladder_wrapper\n",
    "plt.close()\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\", category=RuntimeWarning)  # ignore fitting warnings"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "local_path = f'{DATA_DIR}/benchmarks.parquet'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded 810,570 model evaluations\n"
     ]
    }
   ],
   "source": [
    "df = pd.read_parquet(local_path)\n",
    "print(f'Loaded {len(df):,} model evaluations')\n",
    "\n",
    "# fix for the names of one of Ian's data mixes\n",
    "df.loc[df['mix'] == 'baseline', 'mix'] = 'dolma17'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def task_tag(task_name):\n",
    "    return task_name.split(\"::\")[0].replace(\":rc\", \"\") if \"::\" in task_name else task_name\n",
    "\n",
    "MODELS = list(df['model'].unique())\n",
    "MIXES = list(df['mix'].unique())\n",
    "STEPS = list(df['step'].unique())\n",
    "TASKS = sorted(list(df['task'].unique()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "from ladder_wrapper import sort_experiment_names\n",
    "from download.preprocess import is_excluded_from_lite\n",
    "from utils.constants_models import MODEL_LIST_MIXES\n",
    "from utils.constants_models import DDOS_MODEL_NAMES\n",
    "\n",
    "# Train models\n",
    "all_ladder_models = [model for model in MODELS if 'peteish-moreeval' in model]\n",
    "all_ladder_models = sort_experiment_names(all_ladder_models)\n",
    "\n",
    "# Ladder config\n",
    "ladder_config_path = f'{ROOT_DIR}/analysis/utils/ladder_config.json'\n",
    "\n",
    "# Eval models\n",
    "MODEL_LIST_MIXES = [model.split(\"/\")[-1] for model in MODEL_LIST_MIXES]\n",
    "BROKEN_MODELS = [\"gemma-2b\", \"gemma-7b\", \"gemma-2-2b\", \"gemma-2-9b\"] # gemma models broken in oe-eval\n",
    "LLAMA_3_MODELS = [model for model in MODELS if 'Meta-Llama-3' in model]\n",
    "\n",
    "all_models = sorted([model for model in MODELS if model not in DDOS_MODEL_NAMES + MODEL_LIST_MIXES + BROKEN_MODELS + all_ladder_models])\n",
    "\n",
    "external_models = [model for model in all_models if not is_excluded_from_lite(model)]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Select Tasks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "selected_tasks = [\n",
    "    t\n",
    "    for t in TASKS\n",
    "    if \":\" not in t \n",
    "    and \"bbh\" not in t and \"paloma\" not in t and \"llm_compression\" not in t \n",
    "    and \"custom_loss\" not in t and \"coqa\" not in t and \"deepmind\" not in t\n",
    "]\n",
    "\n",
    "selected_tasks += [\n",
    "    t\n",
    "    for t in TASKS\n",
    "    if \":mc\" in t\n",
    "    and \"bbh\" not in t and \"paloma\" not in t and \"llm_compression\" not in t\n",
    "    and \"custom_loss\" not in t and \"coqa\" not in t and \"deepmind\" not in t\n",
    "]\n",
    "\n",
    "mmlu      = [t for t in TASKS if 'mmlu' in t and ':' not in t and '_pro_' not in t]\n",
    "minerva   = [t for t in TASKS if 'minerva' in t and ':' not in t]\n",
    "mmlu_pro  = [t for t in TASKS if '_pro_' in t and ':rc' in t]\n",
    "mmlu_mc   = [t for t in TASKS if 'mmlu' in t and ':mc' in t and '_pro_' not in t]\n",
    "olmes     = ['arc_challenge', 'arc_easy', 'boolq', 'csqa', 'hellaswag', 'openbookqa', 'piqa', 'socialiqa', 'winogrande']\n",
    "olmes_mc  = [f'{task}:mc' for task in olmes]\n",
    "olmes_para        = [f'{task}:para' for task in olmes]\n",
    "olmes_distractors = [f'{task}:distractors' for task in olmes]\n",
    "olmes_enlarge     = [f'{task}:enlarge' for task in olmes]\n",
    "# olmes_gen = ['drop', 'gsm8k', 'jeopardy', 'naturalqs', 'squad', 'triviaqa']\n",
    "olmes_gen = ['drop', 'gsm8k', 'jeopardy', 'squad', 'triviaqa']\n",
    "agi_eval  = [t for t in TASKS if 'agi_eval' in t and ':rc' in t]\n",
    "bbh       = [t for t in TASKS if 'bbh' in t and ':' not in t]\n",
    "paloma    = [t for t in TASKS if 'paloma' in t]\n",
    "llm_compression = [t for t in TASKS if 'llm_compression' in t]\n",
    "custom_loss = [t for t in TASKS if 'custom_loss' in t]\n",
    "\n",
    "# # # selected_tasks = olmes + olmes_gen + [olmes, olmes_para, olmes_distractors, olmes_enlarge, mmlu, olmes_mc, mmlu_mc, olmes_gen, minerva]\n",
    "# # selected_tasks = olmes + olmes_gen + [olmes, mmlu, olmes_mc, mmlu_mc, olmes_gen, minerva]\n",
    "# # selected_tasks += ['gsm_symbolic_main', mmlu_pro, 'autobencher', 'autobencher:mc']\n",
    "# # # selected_tasks += ['minerva_math_500', 'mbpp', 'mbppplus', 'codex_humaneval', 'codex_humanevalplus', 'copycolors:mc']\n",
    "# # selected_tasks += ['minerva_math_500', 'mbpp', 'mbppplus', 'codex_humaneval', 'codex_humanevalplus']\n",
    "\n",
    "# # # selected_tasks = olmes + olmes_para + olmes_distractors + olmes_enlarge\n",
    "\n",
    "multitask_math = [\"gsm_plus\", \"gsm_symbolic_main\", \"gsm_symbolic_p1\", \"gsm_symbolic_p2\", \"minerva_math_500\", \"aime\"] # 6\n",
    "multitask_code = ['mbpp', 'mbppplus', 'codex_humaneval', 'codex_humanevalplus'] # 4\n",
    "multitask_knowledge = [\"medmcqa\", 'autobencher'] + olmes + mmlu + olmes_gen + mmlu_pro + agi_eval # 19\n",
    "multitask = multitask_knowledge + multitask_math + multitask_code + bbh # 30\n",
    "olmes_all = olmes + mmlu + olmes_gen\n",
    "\n",
    "olmes_all = ['jeopardy'] + list(set(olmes_all) - {'jeopardy'})\n",
    "multitask = ['boolq'] + list(set(multitask) - {'boolq'})\n",
    "\n",
    "# from utils import get_selected_tasks\n",
    "\n",
    "# # selected_tasks = get_selected_tasks(TASKS)\n",
    "\n",
    "# selected_tasks = [multitask_math, olmes_all]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "from utils import get_title_from_task\n",
    "\n",
    "def add_multitask_avg(df, task_set):\n",
    "    _slice = get_slice(df, task=task_set)\n",
    "\n",
    "    new_task = _slice.fillna('')\n",
    "    new_task = new_task.groupby(['model', 'step', 'mix', 'size'])[['model_config', 'primary_score', 'logits_per_byte_corr', 'logits_per_char_corr']]\n",
    "    new_task = new_task.agg(lambda x: x.iloc[0] if x.name == 'model_config' else x[pd.to_numeric(x, errors='coerce').notnull()].mean())\n",
    "    new_task = new_task.reset_index()\n",
    "\n",
    "    new_task['step'] = pd.to_numeric(new_task['step'], errors='coerce') \n",
    "    # new_task['size'] = pd.to_numeric(new_task['size'], errors='coerce')\n",
    "\n",
    "    new_task['task'] = get_title_from_task(task_set)\n",
    "\n",
    "    # Append the aggregate task entries to df\n",
    "    df = pd.concat([df, new_task], axis=0)\n",
    "\n",
    "    return df\n",
    "\n",
    "# new task suites\n",
    "multitask_math = [\"gsm_plus\", \"gsm_symbolic_main\", \"gsm_symbolic_p1\", \"gsm_symbolic_p2\", \"minerva_math_500\"] + ['gsm8k'] + ['minerva'] # 6 # \"aime\"\n",
    "multitask_code = ['mbpp', 'mbppplus', 'codex_humaneval', 'codex_humanevalplus'] # 4\n",
    "multitask_knowledge = [\"medmcqa\", 'autobencher'] + olmes + ['mmlu'] + olmes_gen + ['mmlu_pro'] + ['agi_eval'] # 19\n",
    "multitask = multitask_knowledge + multitask_math + multitask_code # 30 # bbh\n",
    "olmes_all = olmes + mmlu + olmes_gen\n",
    "\n",
    "# Re-order tasks so that the title logic works (a bit hacky, yes)\n",
    "olmes_all = ['jeopardy'] + list(set(olmes_all) - {'jeopardy'})\n",
    "multitask = ['boolq'] + list(set(multitask) - {'boolq'})\n",
    "\n",
    "df = add_multitask_avg(df, task_set=mmlu)\n",
    "df = add_multitask_avg(df, task_set=mmlu_pro)\n",
    "df = add_multitask_avg(df, task_set=agi_eval)\n",
    "df = add_multitask_avg(df, task_set=minerva)\n",
    "df = add_multitask_avg(df, task_set=multitask_math)\n",
    "df = add_multitask_avg(df, task_set=multitask_code)\n",
    "df = add_multitask_avg(df, task_set=multitask_knowledge)\n",
    "df = add_multitask_avg(df, task_set=multitask)\n",
    "\n",
    "selected_tasks = ['multitask_all', 'multitask_math', 'multitask_code', 'multitask_knowledge']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "from ladder_wrapper import run_ladder\n",
    "from metaanalysis import get_title_from_task, set_title_from_task\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Update model column to model_path for entries with -model-merged\n",
    "    # last-29-model-merged => peteish7-last-29-model-merged\n",
    "df[\"model_path\"] = df[\"model_config\"].apply(lambda x: x[\"model_path\"])\n",
    "mask = df['model_path'].str.contains('-model-merged', na=False)\n",
    "df.loc[mask, 'model'] = df.loc[mask, 'model_path'].str.split('/').str[-2:].str.join('-')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "merged_ladder_models = [\n",
    "    f'{model}-last-6-model-merged' for model in all_ladder_models \\\n",
    "    if model not in ['peteish-moreeval-1B-10xC']\n",
    "]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Decisions using Avg. of Last $n$ Ckpts"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "from metaanalysis import construct_2class_table"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'step1': (0.01676823411431616, 0.02543697393885967),\n",
       " 'step2': (0.0634119601820089, 0.09783082580076494),\n",
       " 'stacked': (0.08056766351789046, 0.12429833476476651)}"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "def _run_ladder(task, model_name, last_n, last_n_method_train, last_n_method_eval, last_n_resample=None):\n",
    "    _, (step_1_y, step_2_y, stacked_y), (step_1_y_pred, step_2_y_pred, stacked_y_pred) = run_ladder(\n",
    "        df,\n",
    "        task,\n",
    "        # train_models=all_ladder_models + LLAMA_3_MODELS,\n",
    "        train_models=all_ladder_models,\n",
    "        eval_models=[model_name],\n",
    "        config_path=ladder_config_path,\n",
    "        run_step1=True, run_step2=True, run_stacked=True,\n",
    "        return_reals=True,\n",
    "        last_n=last_n, last_n_method_train=last_n_method_train, last_n_method_eval=last_n_method_eval,\n",
    "        last_n_resample=last_n_resample\n",
    "    )\n",
    "\n",
    "    if last_n_resample is None:\n",
    "        step_1_y = [step_1_y]\n",
    "        step_1_y_pred = [step_1_y_pred]\n",
    "        step_2_y = [step_2_y]\n",
    "        step_2_y_pred = [step_2_y_pred]\n",
    "        stacked_y = [stacked_y]\n",
    "        stacked_y_pred = [stacked_y_pred]\n",
    "\n",
    "    step1_abs_errors = []\n",
    "    step1_rel_errors = []\n",
    "    step2_abs_errors = []\n",
    "    step2_rel_errors = []\n",
    "    stacked_abs_errors = []\n",
    "    stacked_rel_errors = []\n",
    "\n",
    "    for i in range(len(stacked_y)):\n",
    "        # Step 1\n",
    "        y1, y1_pred = step_1_y[i], step_1_y_pred[i]\n",
    "        abs_error = abs(y1 - y1_pred)\n",
    "        rel_error = abs(y1 - y1_pred) / y1\n",
    "        step1_abs_errors.append(abs_error)\n",
    "        step1_rel_errors.append(rel_error)\n",
    "\n",
    "        # Step 2\n",
    "        y2, y2_pred = step_2_y[i], step_2_y_pred[i]\n",
    "        abs_error = abs(y2 - y2_pred)\n",
    "        rel_error = abs(y2 - y2_pred) / y2\n",
    "        step2_abs_errors.append(abs_error)\n",
    "        step2_rel_errors.append(rel_error)\n",
    "\n",
    "        # Stacked\n",
    "        assert len(stacked_y_pred[i]) == 1\n",
    "        y, y_pred = stacked_y[i], stacked_y_pred[i][0]\n",
    "        abs_error = abs(y - y_pred)\n",
    "        rel_error = abs(y - y_pred) / y\n",
    "        stacked_abs_errors.append(abs_error)\n",
    "        stacked_rel_errors.append(rel_error)\n",
    "\n",
    "    errors = {\n",
    "        'step1': (np.mean(step1_abs_errors), np.mean(step1_rel_errors)),\n",
    "        'step2': (np.mean(step2_abs_errors), np.mean(step2_rel_errors)), \n",
    "        'stacked': (np.mean(stacked_abs_errors), np.mean(stacked_rel_errors))\n",
    "    }\n",
    "    \n",
    "    return errors\n",
    "\n",
    "_run_ladder(\n",
    "    task='arc_challenge', \n",
    "    model_name='peteish13-highlr', \n",
    "\n",
    "    # last_n=6, last_n_method_train='sample', last_n_method_eval='avg', last_n_resample=1000\n",
    "    last_n=6, last_n_method_train='final', last_n_method_eval='avg'\n",
    "    # last_n=6, last_n_method_train='avg', last_n_method_eval='final'\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Computing ladder fits: 100%|██████████| 1000/1000 [00:07<00:00, 133.96it/s]\n",
      "Computing ladder fits: 100%|██████████| 1000/1000 [00:07<00:00, 127.96it/s]\n",
      "Computing ladder fits: 100%|██████████| 1000/1000 [00:08<00:00, 113.73it/s]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "{'final_ckpt_step1_abs_error': 0.003268689697724181,\n",
       " 'final_ckpt_step2_abs_error': 0.02178356721159003,\n",
       " 'final_ckpt_stacked_abs_error': 0.019374217736854694,\n",
       " 'final_ckpt_step1_rel_error': 0.004370354335566588,\n",
       " 'final_ckpt_step2_rel_error': 0.04275524136397958,\n",
       " 'final_ckpt_stacked_rel_error': 0.03802634102723039,\n",
       " 'avg_train_step1_abs_error': 0.004929252580494597,\n",
       " 'avg_train_step2_abs_error': 0.022573932402056907,\n",
       " 'avg_train_stacked_abs_error': 0.017278415137779068,\n",
       " 'avg_train_step1_rel_error': 0.006628785190767774,\n",
       " 'avg_train_step2_rel_error': 0.04410982918271707,\n",
       " 'avg_train_stacked_rel_error': 0.03375006500561907,\n",
       " 'avg_target_step1_abs_error': 0.005482581239889803,\n",
       " 'avg_target_step2_abs_error': 0.022236100259788897,\n",
       " 'avg_target_stacked_abs_error': 0.01691666613175666,\n",
       " 'avg_target_step1_rel_error': 0.007363760937804517,\n",
       " 'avg_target_step2_rel_error': 0.043394347703972755,\n",
       " 'avg_target_stacked_rel_error': 0.033013328935243676,\n",
       " 'avg_both_step1_abs_error': 0.004890414750943761,\n",
       " 'avg_both_step2_abs_error': 0.02223060169801583,\n",
       " 'avg_both_stacked_abs_error': 0.017360288444225103,\n",
       " 'avg_both_step1_rel_error': 0.006568410669530999,\n",
       " 'avg_both_step2_rel_error': 0.043383617112787036,\n",
       " 'avg_both_stacked_rel_error': 0.03387906980938915,\n",
       " 'final_ckpt_weight_avg_step1_abs_error': 0.02435565147682739,\n",
       " 'final_ckpt_weight_avg_step2_abs_error': 0.026277168806483675,\n",
       " 'final_ckpt_weight_avg_stacked_abs_error': 0.0016265294806443453,\n",
       " 'final_ckpt_weight_avg_step1_rel_error': 0.03350901906456255,\n",
       " 'final_ckpt_weight_avg_step2_rel_error': 0.049911194262289585,\n",
       " 'final_ckpt_weight_avg_stacked_rel_error': 0.003089451130737871,\n",
       " 'avg_train_weight_avg_step1_abs_error': 0.15749439156412026,\n",
       " 'avg_train_weight_avg_step2_abs_error': 0.055330642657403506,\n",
       " 'avg_train_weight_avg_stacked_abs_error': 0.11099713396668887,\n",
       " 'avg_train_weight_avg_step1_rel_error': 0.2660686115296584,\n",
       " 'avg_train_weight_avg_step2_rel_error': 0.08634933626837213,\n",
       " 'avg_train_weight_avg_stacked_rel_error': 0.17322279997831747}"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "def ladder_variants(task, target_model):\n",
    "    task_results = {}\n",
    "\n",
    "    def add_results(task_results, prefix, results):\n",
    "        task_results[f'{prefix}_step1_abs_error'] = results['step1'][0]\n",
    "        task_results[f'{prefix}_step2_abs_error'] = results['step2'][0]\n",
    "        task_results[f'{prefix}_stacked_abs_error'] = results['stacked'][0]\n",
    "        task_results[f'{prefix}_step1_rel_error'] = results['step1'][1]\n",
    "        task_results[f'{prefix}_step2_rel_error'] = results['step2'][1]\n",
    "        task_results[f'{prefix}_stacked_rel_error'] = results['stacked'][1]\n",
    "        return task_results\n",
    "\n",
    "    # final ckpt of train + target\n",
    "    results = _run_ladder(\n",
    "        task=task, model_name=target_model, \n",
    "        # last_n=None, last_n_method_train=None, last_n_method_eval=None\n",
    "        last_n=6, last_n_method_train='sample', last_n_method_eval='final', last_n_resample=1000\n",
    "    )\n",
    "    add_results(task_results, 'final_ckpt', results)\n",
    "\n",
    "    # avg last n of train models\n",
    "    results = _run_ladder(\n",
    "        task=task, model_name=target_model, \n",
    "        # last_n=6, last_n_method_train='avg', last_n_method_eval='final'\n",
    "        last_n=6, last_n_method_train='avg', last_n_method_eval='sample', last_n_resample=1000\n",
    "    )\n",
    "    add_results(task_results, 'avg_train', results)\n",
    "\n",
    "    # avg last n of target models\n",
    "    results = _run_ladder(\n",
    "        task=task, model_name=target_model, \n",
    "        # last_n=6, last_n_method_train='final', last_n_method_eval='avg'\n",
    "        last_n=6, last_n_method_train='sample', last_n_method_eval='avg', last_n_resample=1000\n",
    "    )\n",
    "    add_results(task_results, 'avg_target', results)\n",
    "\n",
    "    # avg last n of train + target models\n",
    "    results = _run_ladder(\n",
    "        task=task, model_name=target_model, \n",
    "        last_n=6, last_n_method_train='avg', last_n_method_eval='avg'\n",
    "    )\n",
    "    add_results(task_results, 'avg_both', results)\n",
    "\n",
    "    if target_model == 'peteish13-highlr':\n",
    "        # final ckpt of train + weight space avg. target\n",
    "        results = _run_ladder(\n",
    "            task=task, model_name=f\"{target_model}-last-30-model-merged\", \n",
    "            last_n=None, last_n_method_train=None, last_n_method_eval=None\n",
    "        )\n",
    "        add_results(task_results, 'final_ckpt_weight_avg', results)\n",
    "\n",
    "        # avg last n of train models + weight space avg. target\n",
    "        results = _run_ladder(\n",
    "            task=task, model_name=f\"{target_model}-last-30-model-merged\", \n",
    "            last_n=6, last_n_method_train='avg', last_n_method_eval='final'\n",
    "        )\n",
    "        add_results(task_results, 'avg_train_weight_avg', results)\n",
    "\n",
    "    return task_results\n",
    "\n",
    "# ladder_variants('arc_challenge', 'peteish13-highlr')\n",
    "# ladder_variants('arc_easy', 'peteish13-highlr')\n",
    "# ladder_variants('arc_easy', 'peteish7')\n",
    "ladder_variants(mmlu, 'peteish13-highlr')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1000x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(1, 3, figsize=(10, 3))\n",
    "\n",
    "_, (step_1_y, step_2_y, stacked_y), (step_1_y_pred, step_2_y_pred, stacked_y_pred) = run_ladder(\n",
    "    df,\n",
    "    mmlu,\n",
    "    # train_models=all_ladder_models + LLAMA_3_MODELS,\n",
    "    train_models=all_ladder_models,\n",
    "    eval_models=['peteish13-highlr'],\n",
    "    config_path=ladder_config_path,\n",
    "    run_step1=True, run_step2=True, run_stacked=True,\n",
    "    return_reals=True,\n",
    "    axes=axes,\n",
    "\n",
    "    # last_n=6, last_n_method_train='avg', last_n_method_eval='avg',\n",
    "\n",
    "    # last_n=6, last_n_method_train='sample', last_n_method_eval='avg',\n",
    "    # last_n_resample=10\n",
    "    \n",
    "    last_n=6, last_n_method_train='final', last_n_method_eval='avg',\n",
    ")\n",
    "\n",
    "for ax in axes:\n",
    "    ax.set_title('mmlu')\n",
    "    ax.get_legend().remove()\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "# There are some duplicate evals for OLMo 2 7B. Only keep the first\n",
    "df = df[~((df['model'] == 'peteish7') & (df['step'] == 928646.0) & df.duplicated(['model', 'step', 'task'], keep='first'))]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'acc_final': 0.7466933333333334,\n",
       " 'acc_target_avg': 0.7429633333333334,\n",
       " 'acc_pred_avg': 0.7389233333333333,\n",
       " 'acc_both': 0.7366666666666667}"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "def decision_variants(task, size, small_metric, target_metric):\n",
    "    result = {}\n",
    "\n",
    "    two_class_sampled, _, _ = construct_2class_table(\n",
    "        df, [task], \n",
    "        small_metric=small_metric, target_metric=target_metric,\n",
    "        agg_method_pred='sample', # max_n, sample, mean\n",
    "        agg_method_target='sample', # max_n, sample, mean\n",
    "        model_sizes=[size]\n",
    "    )\n",
    "    avg_sampled_acc = np.mean(two_class_sampled[two_class_sampled['size'] == size]['accuracy'].values[0]) # mean of 1000 samples\n",
    "    result.update({\n",
    "        'acc_final': avg_sampled_acc, # avg neither\n",
    "    })\n",
    "\n",
    "    two_class_sampled, _, _ = construct_2class_table(\n",
    "        df, [task], \n",
    "        small_metric=small_metric, target_metric=target_metric,\n",
    "        agg_method_pred='mean', # max_n, sample, mean\n",
    "        agg_method_target='sample', # max_n, sample, mean\n",
    "        model_sizes=[size]\n",
    "    )\n",
    "    avg_sampled_acc = np.mean(two_class_sampled[two_class_sampled['size'] == size]['accuracy'].values[0]) # mean of 1000 samples\n",
    "    result.update({\n",
    "        'acc_target_avg': avg_sampled_acc, # avg just target\n",
    "    })\n",
    "\n",
    "    two_class_sampled, _, _ = construct_2class_table(\n",
    "        df, [task], \n",
    "        small_metric=small_metric, target_metric=target_metric,\n",
    "        agg_method_pred='sample', # max_n, sample, mean\n",
    "        agg_method_target='mean', # max_n, sample, mean\n",
    "        model_sizes=[size]\n",
    "    )\n",
    "    avg_sampled_acc = np.mean(two_class_sampled[two_class_sampled['size'] == size]['accuracy'].values[0]) # mean of 1000 samples\n",
    "    result.update({\n",
    "        'acc_pred_avg': avg_sampled_acc, # avg just prediction\n",
    "    })\n",
    "\n",
    "    two_class_mean, _, _ = construct_2class_table(\n",
    "        df, [task], \n",
    "        small_metric=small_metric, target_metric=target_metric,\n",
    "        agg_method_pred='mean', # max_n, sample, mean\n",
    "        agg_method_target='mean', # max_n, sample, mean\n",
    "        model_sizes=[size]\n",
    "    )\n",
    "    avg_last_n_acc = two_class_mean[two_class_mean['size'] == size]['accuracy'].values[0]\n",
    "    result.update({\n",
    "        'acc_both': avg_last_n_acc, # avg both\n",
    "    })\n",
    "\n",
    "    return result\n",
    "\n",
    "decision_variants(\n",
    "    # task='arc_challenge', \n",
    "    task=olmes,\n",
    "    size='150M', \n",
    "    small_metric='primary_score', # logits_per_byte_corr\n",
    "    target_metric='primary_score' # logits_per_byte_corr\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# selected_tasks = olmes\n",
    "# selected_tasks = ['arc_easy', 'arc_challenge']\n",
    "\n",
    "# selected_tasks = olmes + olmes_gen # + [olmes, mmlu, olmes_gen, minerva]\n",
    "# selected_tasks += ['gsm_symbolic_main', 'autobencher'] # mmlu_pro\n",
    "# selected_tasks += ['minerva_math_500', 'mbpp', 'mbppplus', 'codex_humaneval', 'codex_humanevalplus']\n",
    "\n",
    "# selected_tasks = [olmes, minerva, olmes_gen, mmlu, mmlu_pro, agi_eval, bbh] + olmes + olmes_gen + ['mbpp', 'mbppplus', 'codex_humaneval', 'codex_humanevalplus'] + ['autobencher'] + [\"gsm_plus\", \"gsm_symbolic_main\", \"gsm_symbolic_p1\", \"gsm_symbolic_p2\", \"medmcqa\", \"minerva_math_500\"] # aime\n",
    "\n",
    "# selected_tasks = [multitask_math] # olmes_all\n",
    "\n",
    "# selected_tasks = multitask_knowledge + ['multitask_all', 'multitask_math', 'multitask_code', 'multitask_knowledge']\n",
    "\n",
    "from utils import get_selected_tasks\n",
    "\n",
    "selected_tasks = get_selected_tasks(TASKS)\n",
    "selected_tasks += ['multitask_all', 'multitask_math', 'multitask_code', 'multitask_knowledge']\n",
    "\n",
    "\n",
    "size = '150M' # decision acc at 150M\n",
    "target_model = 'peteish13-highlr' # prediction error at 13B\n",
    "\n",
    "small_metric = target_metric = 'logits_per_byte_corr'\n",
    "# small_metric = target_metric = 'primary_score'\n",
    "\n",
    "ladder_results = []\n",
    "decision_results_bpb = []\n",
    "decision_results_primary = []\n",
    "pbar = tqdm(enumerate(selected_tasks), total=len(selected_tasks))\n",
    "for i, task in pbar:\n",
    "    task_name = get_title_from_task(task)\n",
    "    pbar.set_description(task_name)\n",
    "\n",
    "    metadata = {}\n",
    "    metadata['size'] = size\n",
    "    metadata['task'] = task\n",
    "    metadata['target_model'] = target_model\n",
    "\n",
    "    ladder_result   = ladder_variants(task, target_model)\n",
    "    decision_result_bpb = decision_variants(task, size, 'logits_per_byte_corr', 'logits_per_byte_corr')\n",
    "    decision_result_primary = decision_variants(task, size, 'primary_score', 'primary_score')\n",
    "\n",
    "    ladder_result.update(metadata)\n",
    "    decision_result_bpb.update(metadata)\n",
    "    decision_result_primary.update(metadata)\n",
    "\n",
    "    ladder_results += [ladder_result]\n",
    "    decision_results_bpb += [decision_result_bpb]\n",
    "    decision_results_primary += [decision_result_primary]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[{'final_ckpt_step1_abs_error': 0.05169820453831855,\n",
       "  'final_ckpt_step2_abs_error': 0.03421095392721176,\n",
       "  'final_ckpt_stacked_abs_error': 0.07782307611463035,\n",
       "  'final_ckpt_step1_rel_error': 0.05449561439399977,\n",
       "  'final_ckpt_step2_rel_error': 0.08757920457620978,\n",
       "  'final_ckpt_stacked_rel_error': 0.19922516975979118,\n",
       "  'avg_train_step1_abs_error': 0.05401918544455911,\n",
       "  'avg_train_step2_abs_error': 0.03417375545184797,\n",
       "  'avg_train_stacked_abs_error': 0.07981074604780776,\n",
       "  'avg_train_step1_rel_error': 0.05692825787438716,\n",
       "  'avg_train_step2_rel_error': 0.08742891988533873,\n",
       "  'avg_train_stacked_rel_error': 0.20412643840022232,\n",
       "  'avg_target_step1_abs_error': 0.05090014218389054,\n",
       "  'avg_target_step2_abs_error': 0.03437402233075436,\n",
       "  'avg_target_stacked_abs_error': 0.07729154269248849,\n",
       "  'avg_target_step1_rel_error': 0.05370926220728411,\n",
       "  'avg_target_step2_rel_error': 0.08787117666095667,\n",
       "  'avg_target_stacked_rel_error': 0.19758231192667303,\n",
       "  'avg_both_step1_abs_error': 0.05375135482908544,\n",
       "  'avg_both_step2_abs_error': 0.034322676699933885,\n",
       "  'avg_both_stacked_abs_error': 0.0798474820427077,\n",
       "  'avg_both_step1_rel_error': 0.05671782998330819,\n",
       "  'avg_both_step2_rel_error': 0.08773992053523533,\n",
       "  'avg_both_stacked_rel_error': 0.2041161238855039,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.013734078307568787,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.04968949490716795,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.06157402475076407,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.01495267458353788,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.12423858768480785,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.15395346415567607,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.02455681689120537,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.049425423496455234,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.07108184334639728,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.026735692309207488,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.12357833023650462,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.17772585219245654,\n",
       "  'size': '150M',\n",
       "  'task': 'medmcqa',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.027261891256199513,\n",
       "  'final_ckpt_step2_abs_error': 0.0006832794739870342,\n",
       "  'final_ckpt_stacked_abs_error': 0.03483061596240365,\n",
       "  'final_ckpt_step1_rel_error': 0.04407286555554138,\n",
       "  'final_ckpt_step2_rel_error': 0.0013144546499805323,\n",
       "  'final_ckpt_stacked_rel_error': 0.06700518141766455,\n",
       "  'avg_train_step1_abs_error': 0.02777427806709874,\n",
       "  'avg_train_step2_abs_error': 0.0068323095865836896,\n",
       "  'avg_train_stacked_abs_error': 0.03698509935748557,\n",
       "  'avg_train_step1_rel_error': 0.04475484766824962,\n",
       "  'avg_train_step2_rel_error': 0.013282105523782886,\n",
       "  'avg_train_stacked_rel_error': 0.07181217021608452,\n",
       "  'avg_target_step1_abs_error': 0.029019089304308333,\n",
       "  'avg_target_step2_abs_error': 0.0019758215131156576,\n",
       "  'avg_target_stacked_abs_error': 0.038460079833409794,\n",
       "  'avg_target_step1_rel_error': 0.0467904857386376,\n",
       "  'avg_target_step2_rel_error': 0.003825996583056817,\n",
       "  'avg_target_stacked_rel_error': 0.07447440624061306,\n",
       "  'avg_both_step1_abs_error': 0.02782386495590794,\n",
       "  'avg_both_step2_abs_error': 0.0019306599373395406,\n",
       "  'avg_both_stacked_abs_error': 0.03688609454461422,\n",
       "  'avg_both_step1_rel_error': 0.044863301627453306,\n",
       "  'avg_both_step2_rel_error': 0.0037385453464659083,\n",
       "  'avg_both_stacked_rel_error': 0.07142652853671186,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.014862624487220977,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.005335208247490342,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.024080934081526895,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.024550937821814917,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.010024021779166763,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.04524430846901853,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.013010865160801854,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.00465513848636534,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.021063903947007967,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.021492095278698067,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.008746277072561082,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.039575780761398824,\n",
       "  'size': '150M',\n",
       "  'task': 'autobencher',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.01784649030289956,\n",
       "  'final_ckpt_step2_abs_error': 0.06239651351596971,\n",
       "  'final_ckpt_stacked_abs_error': 0.08037353256968074,\n",
       "  'final_ckpt_step1_rel_error': 0.026952098041040738,\n",
       "  'final_ckpt_step2_rel_error': 0.0968592236300881,\n",
       "  'final_ckpt_stacked_rel_error': 0.12476527175055077,\n",
       "  'avg_train_step1_abs_error': 0.020615947103090653,\n",
       "  'avg_train_step2_abs_error': 0.06356443482508742,\n",
       "  'avg_train_stacked_abs_error': 0.08398524908202777,\n",
       "  'avg_train_step1_rel_error': 0.03131870828155051,\n",
       "  'avg_train_step2_rel_error': 0.0979142220638923,\n",
       "  'avg_train_stacked_rel_error': 0.1294989479976351,\n",
       "  'avg_target_step1_abs_error': 0.020829331738036316,\n",
       "  'avg_target_step2_abs_error': 0.06342157527051329,\n",
       "  'avg_target_stacked_abs_error': 0.08441754123826303,\n",
       "  'avg_target_step1_rel_error': 0.03159755314555972,\n",
       "  'avg_target_step2_rel_error': 0.09784565978548693,\n",
       "  'avg_target_stacked_rel_error': 0.13023785651326586,\n",
       "  'avg_both_step1_abs_error': 0.020719061080774925,\n",
       "  'avg_both_step2_abs_error': 0.06344752276171206,\n",
       "  'avg_both_stacked_abs_error': 0.08433308753481505,\n",
       "  'avg_both_step1_rel_error': 0.03143027543367566,\n",
       "  'avg_both_step2_rel_error': 0.09788569110582694,\n",
       "  'avg_both_stacked_rel_error': 0.13010756286634917,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.030374231998223755,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.06331698088064619,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.09450395475793594,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.04704798576066721,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.09562822370118214,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.14273019971172798,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.03432505896468252,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.0635501847538733,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.09826937877486053,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.053167595661312,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.09598043367466433,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.14841715454141308,\n",
       "  'size': '150M',\n",
       "  'task': 'arc_challenge',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.009553020935771907,\n",
       "  'final_ckpt_step2_abs_error': 0.04436091328736478,\n",
       "  'final_ckpt_stacked_abs_error': 0.05038300528785805,\n",
       "  'final_ckpt_step1_rel_error': 0.020068143379033246,\n",
       "  'final_ckpt_step2_rel_error': 0.05082040982197624,\n",
       "  'final_ckpt_stacked_rel_error': 0.05771939275021733,\n",
       "  'avg_train_step1_abs_error': 0.013694486951622998,\n",
       "  'avg_train_step2_abs_error': 0.04274774489308569,\n",
       "  'avg_train_stacked_abs_error': 0.05123787576553289,\n",
       "  'avg_train_step1_rel_error': 0.029086189889240294,\n",
       "  'avg_train_step2_rel_error': 0.04890018480320417,\n",
       "  'avg_train_stacked_rel_error': 0.05861989208719949,\n",
       "  'avg_target_step1_abs_error': 0.013543130403261534,\n",
       "  'avg_target_step2_abs_error': 0.04279816251705674,\n",
       "  'avg_target_stacked_abs_error': 0.051297589718196264,\n",
       "  'avg_target_step1_rel_error': 0.02868753010126987,\n",
       "  'avg_target_step2_rel_error': 0.0489828680831054,\n",
       "  'avg_target_stacked_rel_error': 0.058710536209265085,\n",
       "  'avg_both_step1_abs_error': 0.01368560780751249,\n",
       "  'avg_both_step2_abs_error': 0.0426946992821472,\n",
       "  'avg_both_stacked_abs_error': 0.05127196667462375,\n",
       "  'avg_both_step1_rel_error': 0.028989330696959012,\n",
       "  'avg_both_step2_rel_error': 0.04886445351367136,\n",
       "  'avg_both_stacked_rel_error': 0.05868121041373123,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.015140177308264002,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.0462540904658475,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.05541130694921048,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.0325887893488634,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.05255844999849529,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.06296378063669254,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.021194424336286377,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.04441379201790496,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.05758509798775513,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.045620379207095135,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.05046732177644294,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.06543385596313064,\n",
       "  'size': '150M',\n",
       "  'task': 'arc_easy',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.012530783669898559,\n",
       "  'final_ckpt_step2_abs_error': 0.053146909270669354,\n",
       "  'final_ckpt_stacked_abs_error': 0.035892655006016655,\n",
       "  'final_ckpt_step1_rel_error': 0.07081908961939543,\n",
       "  'final_ckpt_step2_rel_error': 0.06258206457151198,\n",
       "  'final_ckpt_stacked_rel_error': 0.04226466758000521,\n",
       "  'avg_train_step1_abs_error': 0.01730625367633214,\n",
       "  'avg_train_step2_abs_error': 0.06677949993339402,\n",
       "  'avg_train_stacked_abs_error': 0.024166949161001518,\n",
       "  'avg_train_step1_rel_error': 0.1018767092632947,\n",
       "  'avg_train_step2_rel_error': 0.0797237789624699,\n",
       "  'avg_train_stacked_rel_error': 0.028946728249286863,\n",
       "  'avg_target_step1_abs_error': 0.017080563121890144,\n",
       "  'avg_target_step2_abs_error': 0.06782060764415665,\n",
       "  'avg_target_stacked_abs_error': 0.043638395910733624,\n",
       "  'avg_target_step1_rel_error': 0.09801670487707434,\n",
       "  'avg_target_step2_rel_error': 0.08068398750778276,\n",
       "  'avg_target_stacked_rel_error': 0.05191519086639545,\n",
       "  'avg_both_step1_abs_error': 0.01761005050850109,\n",
       "  'avg_both_step2_abs_error': 0.06648591270466297,\n",
       "  'avg_both_stacked_abs_error': 0.024842280455598775,\n",
       "  'avg_both_step1_rel_error': 0.10105516494066945,\n",
       "  'avg_both_step2_rel_error': 0.07909614402531455,\n",
       "  'avg_both_stacked_rel_error': 0.02955405909161096,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.035037441856391544,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.0707870879953536,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.0038079558626410437,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.22809035622710327,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.08208289990950576,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.004415608393913551,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.038259692404015666,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.08051456177671801,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.003027805430114605,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.2490668955039424,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.09336263014534321,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.0035109658710903396,\n",
       "  'size': '150M',\n",
       "  'task': 'boolq',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.05910987079609898,\n",
       "  'final_ckpt_step2_abs_error': 0.03243310523926506,\n",
       "  'final_ckpt_stacked_abs_error': 0.006256647138389745,\n",
       "  'final_ckpt_step1_rel_error': 0.08328170158477496,\n",
       "  'final_ckpt_step2_rel_error': 0.04112234838747938,\n",
       "  'final_ckpt_stacked_rel_error': 0.007932882820325938,\n",
       "  'avg_train_step1_abs_error': 0.05334065608154737,\n",
       "  'avg_train_step2_abs_error': 0.03148274379404154,\n",
       "  'avg_train_stacked_abs_error': 0.004618276427335619,\n",
       "  'avg_train_step1_rel_error': 0.07468716435291022,\n",
       "  'avg_train_step2_rel_error': 0.04003425410380717,\n",
       "  'avg_train_stacked_rel_error': 0.005860069894276772,\n",
       "  'avg_target_step1_abs_error': 0.06246822775721608,\n",
       "  'avg_target_step2_abs_error': 0.03163847882644175,\n",
       "  'avg_target_stacked_abs_error': 0.005860823291189965,\n",
       "  'avg_target_step1_rel_error': 0.08757345622509938,\n",
       "  'avg_target_step2_rel_error': 0.04024717761460536,\n",
       "  'avg_target_stacked_rel_error': 0.007455528986153446,\n",
       "  'avg_both_step1_abs_error': 0.05319721203400318,\n",
       "  'avg_both_step2_abs_error': 0.031664651395043264,\n",
       "  'avg_both_stacked_abs_error': 0.0045857893948485495,\n",
       "  'avg_both_step1_rel_error': 0.07457653092805977,\n",
       "  'avg_both_step2_rel_error': 0.040280471630506506,\n",
       "  'avg_both_stacked_rel_error': 0.0058335636580414095,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.03705097742381469,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.028302351297029738,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.009121268399891247,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.05257510249801283,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.03577346887543821,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.011529056642098565,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.044598221958173534,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.03221562115728582,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.009636294445353633,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.06328459473171677,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.040719744754705994,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.01218003676788487,\n",
       "  'size': '150M',\n",
       "  'task': 'csqa',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.007448805451418721,\n",
       "  'final_ckpt_step2_abs_error': 0.012426207109935078,\n",
       "  'final_ckpt_stacked_abs_error': 0.0013730978226698626,\n",
       "  'final_ckpt_step1_rel_error': 0.011413479026995589,\n",
       "  'final_ckpt_step2_rel_error': 0.014872940619543272,\n",
       "  'final_ckpt_stacked_rel_error': 0.0016434622568832849,\n",
       "  'avg_train_step1_abs_error': 0.007789679376939738,\n",
       "  'avg_train_step2_abs_error': 0.014900008063977488,\n",
       "  'avg_train_stacked_abs_error': 0.0018709624606254992,\n",
       "  'avg_train_step1_rel_error': 0.01195786357711538,\n",
       "  'avg_train_step2_rel_error': 0.01789284699169287,\n",
       "  'avg_train_stacked_rel_error': 0.002250338261764837,\n",
       "  'avg_target_step1_abs_error': 0.007409694731997384,\n",
       "  'avg_target_step2_abs_error': 0.014923970033500761,\n",
       "  'avg_target_stacked_abs_error': 0.002695185349495118,\n",
       "  'avg_target_step1_rel_error': 0.011353502427982054,\n",
       "  'avg_target_step2_rel_error': 0.017916614379104332,\n",
       "  'avg_target_stacked_rel_error': 0.003235640146604365,\n",
       "  'avg_both_step1_abs_error': 0.007989204062841648,\n",
       "  'avg_both_step2_abs_error': 0.014929339540431297,\n",
       "  'avg_both_stacked_abs_error': 0.0016383521104933463,\n",
       "  'avg_both_step1_rel_error': 0.012241455418321378,\n",
       "  'avg_both_step2_rel_error': 0.017923060611900587,\n",
       "  'avg_both_stacked_rel_error': 0.0019668843421025966,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.016436560792545962,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.018247718633818466,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.007967076522890859,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.025566060961617818,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.02161656134491035,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.009437935878597382,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.017718867741351008,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.018837746085971552,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.009547998550065828,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.027560610675419466,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.022315518012896815,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.011310723303027138,\n",
       "  'size': '150M',\n",
       "  'task': 'hellaswag',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.028737826630879718,\n",
       "  'final_ckpt_step2_abs_error': 0.049361225852667216,\n",
       "  'final_ckpt_stacked_abs_error': 0.025418328591472993,\n",
       "  'final_ckpt_step1_rel_error': 0.02539549259220451,\n",
       "  'final_ckpt_step2_rel_error': 0.07810320546308105,\n",
       "  'final_ckpt_stacked_rel_error': 0.04021887435359651,\n",
       "  'avg_train_step1_abs_error': 0.03928538315643895,\n",
       "  'avg_train_step2_abs_error': 0.06702695405758993,\n",
       "  'avg_train_stacked_abs_error': 0.03381330817351152,\n",
       "  'avg_train_step1_rel_error': 0.03458981579831395,\n",
       "  'avg_train_step2_rel_error': 0.10310225540558582,\n",
       "  'avg_train_stacked_rel_error': 0.0517179532891543,\n",
       "  'avg_target_step1_abs_error': 0.031262870168474614,\n",
       "  'avg_target_step2_abs_error': 0.06686175771204222,\n",
       "  'avg_target_stacked_abs_error': 0.04053440728134854,\n",
       "  'avg_target_step1_rel_error': 0.02754728413119316,\n",
       "  'avg_target_step2_rel_error': 0.10339447068872508,\n",
       "  'avg_target_stacked_rel_error': 0.06268207311548743,\n",
       "  'avg_both_step1_abs_error': 0.03923087947638915,\n",
       "  'avg_both_step2_abs_error': 0.06698928033846774,\n",
       "  'avg_both_stacked_abs_error': 0.03375197484017822,\n",
       "  'avg_both_step1_rel_error': 0.03456829708305109,\n",
       "  'avg_both_step2_rel_error': 0.10359167062649649,\n",
       "  'avg_both_stacked_rel_error': 0.05219377552604879,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.03211990024864719,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.06429917408062635,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.03613904879256735,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.028506070261472446,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.09861836515433489,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.05542798894565545,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.031124626597986316,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.06548475642092944,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.039085308173511524,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.027622775469287465,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.10043674297688564,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.059946791677164914,\n",
       "  'size': '150M',\n",
       "  'task': 'openbookqa',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.010592106688847917,\n",
       "  'final_ckpt_step2_abs_error': 0.0030692405822501626,\n",
       "  'final_ckpt_stacked_abs_error': 0.010348717900035477,\n",
       "  'final_ckpt_step1_rel_error': 0.012060418300271101,\n",
       "  'final_ckpt_step2_rel_error': 0.0037016169226875314,\n",
       "  'final_ckpt_stacked_rel_error': 0.012480934055292133,\n",
       "  'avg_train_step1_abs_error': 0.014077986137937579,\n",
       "  'avg_train_step2_abs_error': 0.003995690444476973,\n",
       "  'avg_train_stacked_abs_error': 0.010178506287276332,\n",
       "  'avg_train_step1_rel_error': 0.016079217481661728,\n",
       "  'avg_train_step2_rel_error': 0.004825524683581387,\n",
       "  'avg_train_stacked_rel_error': 0.012267062019859595,\n",
       "  'avg_target_step1_abs_error': 0.01237034560054812,\n",
       "  'avg_target_step2_abs_error': 0.0017089074124536472,\n",
       "  'avg_target_stacked_abs_error': 0.009034336778675236,\n",
       "  'avg_target_step1_rel_error': 0.014117973504230573,\n",
       "  'avg_target_step2_rel_error': 0.002064165492282456,\n",
       "  'avg_target_stacked_rel_error': 0.010912449725655037,\n",
       "  'avg_both_step1_abs_error': 0.013940595592022986,\n",
       "  'avg_both_step2_abs_error': 0.0002465677391231269,\n",
       "  'avg_both_stacked_abs_error': 0.01006298216685575,\n",
       "  'avg_both_step1_rel_error': 0.015910061493565174,\n",
       "  'avg_both_step2_rel_error': 0.00029782574228366296,\n",
       "  'avg_both_stacked_rel_error': 0.012154936181389396,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.02183116307997124,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.0007375293143131456,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.014293112823630216,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.025162346274449972,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.0008865787310055995,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.017181649031937436,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.02254077040045166,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.001742027540714064,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.014052826200225188,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.025980231471468822,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.002094078888052616,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.016892802194907713,\n",
       "  'size': '150M',\n",
       "  'task': 'piqa',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.00841139761890141,\n",
       "  'final_ckpt_step2_abs_error': 0.0033838228401564014,\n",
       "  'final_ckpt_stacked_abs_error': 0.00608270743628438,\n",
       "  'final_ckpt_step1_rel_error': 0.00953700903690573,\n",
       "  'final_ckpt_step2_rel_error': 0.005379975451314571,\n",
       "  'final_ckpt_stacked_rel_error': 0.0096709603991047,\n",
       "  'avg_train_step1_abs_error': 0.004323188345405613,\n",
       "  'avg_train_step2_abs_error': 0.010937923409108865,\n",
       "  'avg_train_stacked_abs_error': 0.006593084205156764,\n",
       "  'avg_train_step1_rel_error': 0.004903225261794073,\n",
       "  'avg_train_step2_rel_error': 0.01774373838990921,\n",
       "  'avg_train_stacked_rel_error': 0.010694178814491856,\n",
       "  'avg_target_step1_abs_error': 0.006685199099886894,\n",
       "  'avg_target_step2_abs_error': 0.010141534149704447,\n",
       "  'avg_target_stacked_abs_error': 0.0050178443274447575,\n",
       "  'avg_target_step1_rel_error': 0.007564270572554611,\n",
       "  'avg_target_step2_rel_error': 0.01635254385519666,\n",
       "  'avg_target_stacked_rel_error': 0.008090937545724429,\n",
       "  'avg_both_step1_abs_error': 0.0040590649032452575,\n",
       "  'avg_both_step2_abs_error': 0.010199155107042834,\n",
       "  'avg_both_stacked_abs_error': 0.005908106952713599,\n",
       "  'avg_both_step1_rel_error': 0.004592812381642725,\n",
       "  'avg_both_step2_rel_error': 0.016445453785582476,\n",
       "  'avg_both_stacked_rel_error': 0.009526426339377558,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.024864683652931485,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.01867777249960545,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.007270103351845969,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.028445407533449683,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.030062905654224918,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.01170163257784763,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.013725979353086837,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.019415401404379362,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.004799270378165743,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.015702635993450054,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.03125016008579677,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.007724690542780776,\n",
       "  'size': '150M',\n",
       "  'task': 'socialiqa',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.004731616180781338,\n",
       "  'final_ckpt_step2_abs_error': 0.08320853662533688,\n",
       "  'final_ckpt_stacked_abs_error': 0.08983495821007788,\n",
       "  'final_ckpt_step1_rel_error': 0.0038327982106317092,\n",
       "  'final_ckpt_step2_rel_error': 0.1050051951238066,\n",
       "  'final_ckpt_stacked_rel_error': 0.11336742236271778,\n",
       "  'avg_train_step1_abs_error': 0.013811868981251625,\n",
       "  'avg_train_step2_abs_error': 0.06689735220954027,\n",
       "  'avg_train_stacked_abs_error': 0.10810680987977833,\n",
       "  'avg_train_step1_rel_error': 0.011318790219133176,\n",
       "  'avg_train_step2_rel_error': 0.08325876412572754,\n",
       "  'avg_train_stacked_rel_error': 0.13464729473497186,\n",
       "  'avg_target_step1_abs_error': 0.010214785141160707,\n",
       "  'avg_target_step2_abs_error': 0.0700327841802465,\n",
       "  'avg_target_stacked_abs_error': 0.10002310863847239,\n",
       "  'avg_target_step1_rel_error': 0.008326607459410287,\n",
       "  'avg_target_step2_rel_error': 0.08726261683957283,\n",
       "  'avg_target_stacked_rel_error': 0.1246313181232039,\n",
       "  'avg_both_step1_abs_error': 0.013787273413940593,\n",
       "  'avg_both_step2_abs_error': 0.06721359108588898,\n",
       "  'avg_both_stacked_abs_error': 0.1082317769936958,\n",
       "  'avg_both_step1_rel_error': 0.011238730141356847,\n",
       "  'avg_both_step2_rel_error': 0.0837498310825976,\n",
       "  'avg_both_stacked_rel_error': 0.13485952609507873,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.016783859010290447,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.08775488813718657,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.13485299559611097,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.013652555681289629,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.10784233100855033,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.16572138256088517,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.011195048841230237,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.08623204702129073,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.11941304508104111,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.009106429431154273,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.10597090550531071,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.14674716597253065,\n",
       "  'size': '150M',\n",
       "  'task': 'winogrande',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.003127107293841139,\n",
       "  'final_ckpt_step2_abs_error': 0.021772543090121586,\n",
       "  'final_ckpt_stacked_abs_error': 0.019710023825921387,\n",
       "  'final_ckpt_step1_rel_error': 0.004181053627983054,\n",
       "  'final_ckpt_step2_rel_error': 0.04273360399992296,\n",
       "  'final_ckpt_stacked_rel_error': 0.03868543741167845,\n",
       "  'avg_train_step1_abs_error': 0.00496698123969324,\n",
       "  'avg_train_step2_abs_error': 0.022372556168600313,\n",
       "  'avg_train_stacked_abs_error': 0.01726886526290079,\n",
       "  'avg_train_step1_rel_error': 0.006679817290139729,\n",
       "  'avg_train_step2_rel_error': 0.04370276662001602,\n",
       "  'avg_train_stacked_rel_error': 0.033730597294921734,\n",
       "  'avg_target_step1_abs_error': 0.005873782671947491,\n",
       "  'avg_target_step2_abs_error': 0.02222773506000899,\n",
       "  'avg_target_stacked_abs_error': 0.016589889111547147,\n",
       "  'avg_target_step1_rel_error': 0.007889191149990024,\n",
       "  'avg_target_step2_rel_error': 0.04337802279161754,\n",
       "  'avg_target_stacked_rel_error': 0.03237561479153282,\n",
       "  'avg_both_step1_abs_error': 0.00489041471453977,\n",
       "  'avg_both_step2_abs_error': 0.022230601400668237,\n",
       "  'avg_both_stacked_abs_error': 0.017360288192395767,\n",
       "  'avg_both_step1_rel_error': 0.006568410620636092,\n",
       "  'avg_both_step2_rel_error': 0.04338361653250521,\n",
       "  'avg_both_stacked_rel_error': 0.033879069317937424,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.0034713360466253063,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.02152012728166941,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.01806376980380142,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.004642542792567212,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.04219291776044603,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.03541629395587373,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.0017028838968625726,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.021429813830996736,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.019738344057594226,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.0022774261136843032,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.042015846874804,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.03869950751912357,\n",
       "  'size': '150M',\n",
       "  'task': 'mmlu',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.481506250019966,\n",
       "  'final_ckpt_step2_abs_error': 0.3072553810031669,\n",
       "  'final_ckpt_stacked_abs_error': 0.34501627003449814,\n",
       "  'final_ckpt_step1_rel_error': 0.10916027566342935,\n",
       "  'final_ckpt_step2_rel_error': 0.6086287127023642,\n",
       "  'final_ckpt_stacked_rel_error': 0.6834276021688406,\n",
       "  'avg_train_step1_abs_error': 0.4820868783402522,\n",
       "  'avg_train_step2_abs_error': 0.3120431446544028,\n",
       "  'avg_train_stacked_abs_error': 0.3521266367253151,\n",
       "  'avg_train_step1_rel_error': 0.10936882048333464,\n",
       "  'avg_train_step2_rel_error': 0.6101271792289212,\n",
       "  'avg_train_stacked_rel_error': 0.6881379181559742,\n",
       "  'avg_target_step1_abs_error': 0.4749747078309872,\n",
       "  'avg_target_step2_abs_error': 0.3142247758443395,\n",
       "  'avg_target_stacked_abs_error': 0.3516826860816667,\n",
       "  'avg_target_step1_rel_error': 0.10749215240463339,\n",
       "  'avg_target_step2_rel_error': 0.6143775819401373,\n",
       "  'avg_target_stacked_rel_error': 0.6876159198601874,\n",
       "  'avg_both_step1_abs_error': 0.4819339511838123,\n",
       "  'avg_both_step2_abs_error': 0.31202202915326793,\n",
       "  'avg_both_stacked_abs_error': 0.3519976123265455,\n",
       "  'avg_both_step1_rel_error': 0.10906710794388495,\n",
       "  'avg_both_step2_rel_error': 0.6100707344547639,\n",
       "  'avg_both_stacked_rel_error': 0.6882316689662159,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.4587345860122163,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.33433558282740383,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.37775208575240404,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.10303791583436672,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.6236562146733018,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.704643621516372,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.4485309324862632,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.3403629806492682,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.37663495153236237,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.10074603895115697,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.6348994813280945,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.7025597640547723,\n",
       "  'size': '150M',\n",
       "  'task': 'drop',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.024397780422093788,\n",
       "  'final_ckpt_step2_abs_error': 0.1418149016455357,\n",
       "  'final_ckpt_stacked_abs_error': 0.0769283421630935,\n",
       "  'final_ckpt_step1_rel_error': 0.05917577873516319,\n",
       "  'final_ckpt_step2_rel_error': 0.38019076274484065,\n",
       "  'final_ckpt_stacked_rel_error': 0.20623675470146408,\n",
       "  'avg_train_step1_abs_error': 0.024726710510343235,\n",
       "  'avg_train_step2_abs_error': 0.14706237895535423,\n",
       "  'avg_train_stacked_abs_error': 0.038294777374068036,\n",
       "  'avg_train_step1_rel_error': 0.059916245212140194,\n",
       "  'avg_train_step2_rel_error': 0.4039100824668559,\n",
       "  'avg_train_stacked_rel_error': 0.10324878643071606,\n",
       "  'avg_target_step1_abs_error': 0.024397821499520148,\n",
       "  'avg_target_step2_abs_error': 0.13281005206615412,\n",
       "  'avg_target_stacked_abs_error': 0.0755268576404453,\n",
       "  'avg_target_step1_rel_error': 0.059170790500079964,\n",
       "  'avg_target_step2_rel_error': 0.3659675320513733,\n",
       "  'avg_target_stacked_rel_error': 0.2081196209493329,\n",
       "  'avg_both_step1_abs_error': 0.02476079696389072,\n",
       "  'avg_both_step2_abs_error': 0.1472641480238926,\n",
       "  'avg_both_stacked_abs_error': 0.03849695073772735,\n",
       "  'avg_both_step1_rel_error': 0.06005109635686978,\n",
       "  'avg_both_step2_rel_error': 0.40579682014661766,\n",
       "  'avg_both_stacked_rel_error': 0.10608108222088242,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.01391064874035719,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.143503349628053,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.07342071077550905,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.034605200539181286,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.34352253749437733,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.1757566561032603,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.014413440677913891,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.16059511371539514,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.09333647563032277,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.03585598446402838,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.3844373048831328,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.223431599557887,\n",
       "  'size': '150M',\n",
       "  'task': 'gsm8k',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.051177073875541615,\n",
       "  'final_ckpt_step2_abs_error': 0.027064003464387577,\n",
       "  'final_ckpt_stacked_abs_error': 0.008684698332632159,\n",
       "  'final_ckpt_step1_rel_error': 0.18601378437397187,\n",
       "  'final_ckpt_step2_rel_error': 0.032905207652536635,\n",
       "  'final_ckpt_stacked_rel_error': 0.010559110458692317,\n",
       "  'avg_train_step1_abs_error': 0.05134175673698318,\n",
       "  'avg_train_step2_abs_error': 0.030113670089297665,\n",
       "  'avg_train_stacked_abs_error': 0.006319900296791017,\n",
       "  'avg_train_step1_rel_error': 0.1868307179458124,\n",
       "  'avg_train_step2_rel_error': 0.03643417709712302,\n",
       "  'avg_train_stacked_rel_error': 0.007666133736974129,\n",
       "  'avg_target_step1_abs_error': 0.050866854630674994,\n",
       "  'avg_target_step2_abs_error': 0.02992738747140643,\n",
       "  'avg_target_stacked_abs_error': 0.0056379263160800264,\n",
       "  'avg_target_step1_rel_error': 0.18535569743743882,\n",
       "  'avg_target_step2_rel_error': 0.03623886481762011,\n",
       "  'avg_target_stacked_rel_error': 0.006826925665173187,\n",
       "  'avg_both_step1_abs_error': 0.05140580514155821,\n",
       "  'avg_both_step2_abs_error': 0.02993988079511245,\n",
       "  'avg_both_stacked_abs_error': 0.005412491399280128,\n",
       "  'avg_both_step1_rel_error': 0.18731960003283896,\n",
       "  'avg_both_step2_rel_error': 0.03625399289618486,\n",
       "  'avg_both_stacked_rel_error': 0.006553948096286215,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.047547713670986286,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.03993080769888413,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.007256016071816029,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.17512851160642146,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.04775865559495871,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.008678451364634705,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.04847931750240628,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.038047016197224615,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.0048464509215422336,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.17855980997614682,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.04550557445973837,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.005796526385472387,\n",
       "  'size': '150M',\n",
       "  'task': 'jeopardy',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.053653390793802574,\n",
       "  'final_ckpt_step2_abs_error': 0.065913028138969,\n",
       "  'final_ckpt_stacked_abs_error': 0.0290344602265179,\n",
       "  'final_ckpt_step1_rel_error': 0.3452022853656538,\n",
       "  'final_ckpt_step2_rel_error': 0.07603498327743193,\n",
       "  'final_ckpt_stacked_rel_error': 0.03349314634942946,\n",
       "  'avg_train_step1_abs_error': 0.049542356485217084,\n",
       "  'avg_train_step2_abs_error': 0.06570570324848515,\n",
       "  'avg_train_stacked_abs_error': 0.02786010544113181,\n",
       "  'avg_train_step1_rel_error': 0.32316258911430973,\n",
       "  'avg_train_step2_rel_error': 0.07563251864103589,\n",
       "  'avg_train_stacked_rel_error': 0.03206185260351687,\n",
       "  'avg_target_step1_abs_error': 0.05054861138264031,\n",
       "  'avg_target_step2_abs_error': 0.06584703204432267,\n",
       "  'avg_target_stacked_abs_error': 0.02981477170201423,\n",
       "  'avg_target_step1_rel_error': 0.3297935029941639,\n",
       "  'avg_target_step2_rel_error': 0.07579951746563857,\n",
       "  'avg_target_stacked_rel_error': 0.03432114156397587,\n",
       "  'avg_both_step1_abs_error': 0.049607398612704995,\n",
       "  'avg_both_step2_abs_error': 0.06574065246129601,\n",
       "  'avg_both_stacked_abs_error': 0.027884562411467972,\n",
       "  'avg_both_step1_rel_error': 0.32365276345712474,\n",
       "  'avg_both_step2_rel_error': 0.07567705908275824,\n",
       "  'avg_both_stacked_rel_error': 0.032099189741870725,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.03944922516775812,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.07187621060523819,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.04129752633608219,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.2602065532632377,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.0820515137781904,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.04714389535337134,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.04794122451508104,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.07165666172088125,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.03517352102642268,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.3162196655888641,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.08180088400572313,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.04015293267167122,\n",
       "  'size': '150M',\n",
       "  'task': 'squad',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.005570780053318097,\n",
       "  'final_ckpt_step2_abs_error': 0.01951554237646212,\n",
       "  'final_ckpt_stacked_abs_error': 0.021647225754864247,\n",
       "  'final_ckpt_step1_rel_error': 0.007987800279603607,\n",
       "  'final_ckpt_step2_rel_error': 0.02430528703609899,\n",
       "  'final_ckpt_stacked_rel_error': 0.026960154391701407,\n",
       "  'avg_train_step1_abs_error': 0.020696601025432294,\n",
       "  'avg_train_step2_abs_error': 0.014283971173653239,\n",
       "  'avg_train_stacked_abs_error': 0.026244193554705593,\n",
       "  'avg_train_step1_rel_error': 0.030318047013247286,\n",
       "  'avg_train_step2_rel_error': 0.017750269849866926,\n",
       "  'avg_train_stacked_rel_error': 0.03261442850594941,\n",
       "  'avg_target_step1_abs_error': 0.016246354091329757,\n",
       "  'avg_target_step2_abs_error': 0.014093663829172681,\n",
       "  'avg_target_stacked_abs_error': 0.023635789455344194,\n",
       "  'avg_target_step1_rel_error': 0.023696781154978946,\n",
       "  'avg_target_step2_rel_error': 0.01751821519914376,\n",
       "  'avg_target_stacked_rel_error': 0.029378935889141197,\n",
       "  'avg_both_step1_abs_error': 0.020459203738989018,\n",
       "  'avg_both_step2_abs_error': 0.01419936140033018,\n",
       "  'avg_both_stacked_abs_error': 0.026186501072267387,\n",
       "  'avg_both_step1_rel_error': 0.029841604515236056,\n",
       "  'avg_both_step2_rel_error': 0.0176495957131114,\n",
       "  'avg_both_stacked_rel_error': 0.032549432614323796,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.027961097908529187,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.03044108507817256,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.04654163210296747,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.04154054518267336,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.03678956704277594,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.05624787980242143,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.03294871293340218,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.030031779126503455,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.0491096574854234,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.04895042043050177,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.036294900419977565,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.05935146634451733,\n",
       "  'size': '150M',\n",
       "  'task': 'triviaqa',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.011441561530536853,\n",
       "  'final_ckpt_step2_abs_error': 0.005800587998364581,\n",
       "  'final_ckpt_stacked_abs_error': 0.015622304812620546,\n",
       "  'final_ckpt_step1_rel_error': 0.010743402969965078,\n",
       "  'final_ckpt_step2_rel_error': 0.024470743603882822,\n",
       "  'final_ckpt_stacked_rel_error': 0.0659052867880161,\n",
       "  'avg_train_step1_abs_error': 0.007238228487047411,\n",
       "  'avg_train_step2_abs_error': 0.011380181365348341,\n",
       "  'avg_train_stacked_abs_error': 0.017450462661280045,\n",
       "  'avg_train_step1_rel_error': 0.006815000066451823,\n",
       "  'avg_train_step2_rel_error': 0.048540808713667886,\n",
       "  'avg_train_stacked_rel_error': 0.07439386489927889,\n",
       "  'avg_target_step1_abs_error': 0.007609284196969934,\n",
       "  'avg_target_step2_abs_error': 0.01137666758727159,\n",
       "  'avg_target_stacked_abs_error': 0.017506280603284203,\n",
       "  'avg_target_step1_rel_error': 0.007171030379322568,\n",
       "  'avg_target_step2_rel_error': 0.048468196179713416,\n",
       "  'avg_target_stacked_rel_error': 0.07458228309372457,\n",
       "  'avg_both_step1_abs_error': 0.007088488309531238,\n",
       "  'avg_both_step2_abs_error': 0.011378425024281241,\n",
       "  'avg_both_stacked_abs_error': 0.01749285952802329,\n",
       "  'avg_both_step1_rel_error': 0.006680229532150069,\n",
       "  'avg_both_step2_rel_error': 0.04847568341629687,\n",
       "  'avg_both_stacked_rel_error': 0.07452510507531994,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.009821763620070145,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.015305792831987686,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.023852354795419084,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.009254966304963402,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.0661883738277719,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.10314712822797445,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.007216509279098782,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.014747910710287193,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.020971303847741873,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.006800056771987144,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.06377586826022154,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.09068831088770658,\n",
       "  'size': '150M',\n",
       "  'task': 'mmlu_pro',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.023301615974960478,\n",
       "  'final_ckpt_step2_abs_error': 0.045460018095293125,\n",
       "  'final_ckpt_stacked_abs_error': 0.025679732464290783,\n",
       "  'final_ckpt_step1_rel_error': 0.027672599359648296,\n",
       "  'final_ckpt_step2_rel_error': 0.13349524374262323,\n",
       "  'final_ckpt_stacked_rel_error': 0.07540960800719074,\n",
       "  'avg_train_step1_abs_error': 0.026439158023817712,\n",
       "  'avg_train_step2_abs_error': 0.042519880262603504,\n",
       "  'avg_train_stacked_abs_error': 0.019774073884766586,\n",
       "  'avg_train_step1_rel_error': 0.03156488623493318,\n",
       "  'avg_train_step2_rel_error': 0.12262883485122075,\n",
       "  'avg_train_stacked_rel_error': 0.057130403236795614,\n",
       "  'avg_target_step1_abs_error': 0.027648170576257278,\n",
       "  'avg_target_step2_abs_error': 0.04267605239957136,\n",
       "  'avg_target_stacked_abs_error': 0.01914466246790159,\n",
       "  'avg_target_step1_rel_error': 0.0329967500611482,\n",
       "  'avg_target_step2_rel_error': 0.12296480965645437,\n",
       "  'avg_target_stacked_rel_error': 0.0551625477038319,\n",
       "  'avg_both_step1_abs_error': 0.026614988420410435,\n",
       "  'avg_both_step2_abs_error': 0.04265410702447614,\n",
       "  'avg_both_stacked_abs_error': 0.019791306830751698,\n",
       "  'avg_both_step1_rel_error': 0.031763697289353146,\n",
       "  'avg_both_step2_rel_error': 0.12290157726452279,\n",
       "  'avg_both_stacked_rel_error': 0.057025758955163146,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.03147449537335012,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.03873605514272849,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.011850067655969077,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.03749946255123795,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.11042221509275343,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.0337801749494032,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.025188952796307618,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.037625209280226835,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.01605090061758474,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.030010717594850463,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.10725560299681111,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.045755201294937764,\n",
       "  'size': '150M',\n",
       "  'task': 'agi_eval',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.0042243577345317754,\n",
       "  'final_ckpt_step2_abs_error': 0.011111934723757183,\n",
       "  'final_ckpt_stacked_abs_error': 0.011070385929381445,\n",
       "  'final_ckpt_step1_rel_error': 0.005587546093430135,\n",
       "  'final_ckpt_step2_rel_error': 0.022660020464866832,\n",
       "  'final_ckpt_stacked_rel_error': 0.022575292057595692,\n",
       "  'avg_train_step1_abs_error': 0.0022840885368833105,\n",
       "  'avg_train_step2_abs_error': 0.007441707050466367,\n",
       "  'avg_train_stacked_abs_error': 0.008491946010436107,\n",
       "  'avg_train_step1_rel_error': 0.003039653954872373,\n",
       "  'avg_train_step2_rel_error': 0.015167486484513866,\n",
       "  'avg_train_stacked_rel_error': 0.01729561675168221,\n",
       "  'avg_target_step1_abs_error': 0.004430167139410655,\n",
       "  'avg_target_step2_abs_error': 0.007000846949124853,\n",
       "  'avg_target_stacked_abs_error': 0.010053990110421827,\n",
       "  'avg_target_step1_rel_error': 0.0058822271081218755,\n",
       "  'avg_target_step2_rel_error': 0.014310274854814254,\n",
       "  'avg_target_stacked_rel_error': 0.020551136585796364,\n",
       "  'avg_both_step1_abs_error': 0.0014738924987293123,\n",
       "  'avg_both_step2_abs_error': 0.0070421730710542585,\n",
       "  'avg_both_stacked_abs_error': 0.008620658296105255,\n",
       "  'avg_both_step1_rel_error': 0.001956984948345851,\n",
       "  'avg_both_step2_rel_error': 0.01439474865745427,\n",
       "  'avg_both_stacked_rel_error': 0.01762129504375497,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.004681721065630473,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.010344607788930926,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.015363748563011093,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.006257907499117094,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.02077449757762305,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.03085415743330651,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.006489579178754812,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.010376661964943412,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.017349890605400875,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.008674413883172022,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.020838870187538393,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.034842815475285886,\n",
       "  'size': '150M',\n",
       "  'task': 'multitask_all',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.021386449886936693,\n",
       "  'final_ckpt_step2_abs_error': 0.10307034889237093,\n",
       "  'final_ckpt_stacked_abs_error': 0.10965533096446084,\n",
       "  'final_ckpt_step1_rel_error': 0.0470299386474011,\n",
       "  'final_ckpt_step2_rel_error': 0.5905352725950374,\n",
       "  'final_ckpt_stacked_rel_error': 0.6282635254317062,\n",
       "  'avg_train_step1_abs_error': 0.020072621513739577,\n",
       "  'avg_train_step2_abs_error': 0.06960492145589427,\n",
       "  'avg_train_stacked_abs_error': 0.02278755300868235,\n",
       "  'avg_train_step1_rel_error': 0.044199578641187454,\n",
       "  'avg_train_step2_rel_error': 0.40185932988559914,\n",
       "  'avg_train_stacked_rel_error': 0.13034120735207402,\n",
       "  'avg_target_step1_abs_error': 0.02094426290240929,\n",
       "  'avg_target_step2_abs_error': 0.10609919928338521,\n",
       "  'avg_target_stacked_abs_error': 0.11564448853497211,\n",
       "  'avg_target_step1_rel_error': 0.04613681102441722,\n",
       "  'avg_target_step2_rel_error': 0.6135532953410817,\n",
       "  'avg_target_stacked_rel_error': 0.6687520500428251,\n",
       "  'avg_both_step1_abs_error': 0.02007893065449534,\n",
       "  'avg_both_step2_abs_error': 0.06990471303453913,\n",
       "  'avg_both_stacked_abs_error': 0.022961187467408467,\n",
       "  'avg_both_step1_rel_error': 0.04423062456269421,\n",
       "  'avg_both_step2_rel_error': 0.40424684947580597,\n",
       "  'avg_both_stacked_rel_error': 0.13278057073687016,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.021965101614304983,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.07622923138062437,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.02745489287106201,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.048381232525104394,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.4380843123734723,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.15778143957205976,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.020119469385552036,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.0710630987315975,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.024041225542344058,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.04431596737937115,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.4083948923414301,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.13816332094108397,\n",
       "  'size': '150M',\n",
       "  'task': 'multitask_math',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.04466377968006203,\n",
       "  'final_ckpt_step2_abs_error': 0.0842622551609461,\n",
       "  'final_ckpt_stacked_abs_error': 0.025761426435981886,\n",
       "  'final_ckpt_step1_rel_error': 0.08207629376355234,\n",
       "  'final_ckpt_step2_rel_error': 0.29789617310626865,\n",
       "  'final_ckpt_stacked_rel_error': 0.0910755395091125,\n",
       "  'avg_train_step1_abs_error': 0.03347652885549319,\n",
       "  'avg_train_step2_abs_error': 0.04762776987429092,\n",
       "  'avg_train_stacked_abs_error': 0.027815580310514627,\n",
       "  'avg_train_step1_rel_error': 0.06276924311633261,\n",
       "  'avg_train_step2_rel_error': 0.1748755833202302,\n",
       "  'avg_train_stacked_rel_error': 0.10378094796872989,\n",
       "  'avg_target_step1_abs_error': 0.032703509484504054,\n",
       "  'avg_target_step2_abs_error': 0.04804923087724702,\n",
       "  'avg_target_stacked_abs_error': 0.03227490683898879,\n",
       "  'avg_target_step1_rel_error': 0.06150523163877307,\n",
       "  'avg_target_step2_rel_error': 0.17702881056586678,\n",
       "  'avg_target_stacked_rel_error': 0.11891113061574363,\n",
       "  'avg_both_step1_abs_error': 0.03325787323259244,\n",
       "  'avg_both_step2_abs_error': 0.048600871079203356,\n",
       "  'avg_both_stacked_abs_error': 0.02754522137126353,\n",
       "  'avg_both_step1_rel_error': 0.06254781915539634,\n",
       "  'avg_both_step2_rel_error': 0.17906123037841548,\n",
       "  'avg_both_stacked_rel_error': 0.10148544913415819,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.03557105186115761,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.021177524861114128,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.0647302526860064,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.06746784569898497,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.08293061558296369,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.2534819218627464,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.02876842051938111,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.02312522187185173,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.04360124754138295,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.05456525053521294,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.09055774449103336,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.17074130817957364,\n",
       "  'size': '150M',\n",
       "  'task': 'multitask_code',\n",
       "  'target_model': 'peteish13-highlr'},\n",
       " {'final_ckpt_step1_abs_error': 0.010784471724270474,\n",
       "  'final_ckpt_step2_abs_error': 0.004472829945315031,\n",
       "  'final_ckpt_stacked_abs_error': 0.013790858276433145,\n",
       "  'final_ckpt_step1_rel_error': 0.012069344504359087,\n",
       "  'final_ckpt_step2_rel_error': 0.006942705248479599,\n",
       "  'final_ckpt_stacked_rel_error': 0.02140610425780163,\n",
       "  'avg_train_step1_abs_error': 0.00882063795760476,\n",
       "  'avg_train_step2_abs_error': 0.004943977386671575,\n",
       "  'avg_train_stacked_abs_error': 0.012002806281436613,\n",
       "  'avg_train_step1_rel_error': 0.009903450557120845,\n",
       "  'avg_train_step2_rel_error': 0.007651541715351574,\n",
       "  'avg_train_stacked_rel_error': 0.01857752687453064,\n",
       "  'avg_target_step1_abs_error': 0.012165180419560351,\n",
       "  'avg_target_step2_abs_error': 0.003910425764004135,\n",
       "  'avg_target_stacked_abs_error': 0.014624728306596092,\n",
       "  'avg_target_step1_rel_error': 0.013637351132504142,\n",
       "  'avg_target_step2_rel_error': 0.006063137295491342,\n",
       "  'avg_target_stacked_rel_error': 0.022675724072908635,\n",
       "  'avg_both_step1_abs_error': 0.008702126312249203,\n",
       "  'avg_both_step2_abs_error': 0.0036986827462892613,\n",
       "  'avg_both_stacked_abs_error': 0.011960412261772801,\n",
       "  'avg_both_step1_rel_error': 0.009755215132586963,\n",
       "  'avg_both_step2_rel_error': 0.005734828547225439,\n",
       "  'avg_both_stacked_rel_error': 0.018544686954893422,\n",
       "  'final_ckpt_weight_avg_step1_abs_error': 0.013878914277900556,\n",
       "  'final_ckpt_weight_avg_step2_abs_error': 0.02162151708993809,\n",
       "  'final_ckpt_weight_avg_stacked_abs_error': 0.03474018848824956,\n",
       "  'final_ckpt_weight_avg_step1_rel_error': 0.01561439937787204,\n",
       "  'final_ckpt_weight_avg_step2_rel_error': 0.03251695329932351,\n",
       "  'final_ckpt_weight_avg_stacked_rel_error': 0.05224633784868893,\n",
       "  'avg_train_weight_avg_step1_abs_error': 0.011897210721094065,\n",
       "  'avg_train_weight_avg_step2_abs_error': 0.02065049646630779,\n",
       "  'avg_train_weight_avg_stacked_abs_error': 0.03194012190032802,\n",
       "  'avg_train_weight_avg_step1_rel_error': 0.01338489423323714,\n",
       "  'avg_train_weight_avg_step2_rel_error': 0.031056619496661702,\n",
       "  'avg_train_weight_avg_stacked_rel_error': 0.04803527189546717,\n",
       "  'size': '150M',\n",
       "  'task': 'multitask_knowledge',\n",
       "  'target_model': 'peteish13-highlr'}]"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ladder_results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Have all decision accuracy numbers be [0.5, 1]\n",
    "decision_results_bpb = [\n",
    "    {\n",
    "        k: abs(v - 0.5) + 0.5 if isinstance(v, (int, float)) and k != \"size\" else v\n",
    "        for k, v in result.items()\n",
    "    }\n",
    "    for result in decision_results_bpb\n",
    "]\n",
    "\n",
    "decision_results_primary = [\n",
    "    {\n",
    "        k: abs(v - 0.5) + 0.5 if isinstance(v, (int, float)) and k != \"size\" else v\n",
    "        for k, v in result.items()\n",
    "    }\n",
    "    for result in decision_results_primary\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Task does not have pretty name: Average\n",
      "Task does not have pretty name: Average\n",
      "Task does not have pretty name: Average\n",
      "Task does not have pretty name: Average\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>Task</th>\n",
       "      <th>Avg. Target Stacked Abs. Error</th>\n",
       "      <th>Avg. Both Stacked Abs. Error</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>HumanEval+</td>\n",
       "      <td>$1.05$</td>\n",
       "      <td>$\\mathbf{0.04}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>HellaSwag</td>\n",
       "      <td>$0.31$</td>\n",
       "      <td>$\\mathbf{0.16}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>CommonsenseQA</td>\n",
       "      <td>$0.59$</td>\n",
       "      <td>$\\mathbf{0.46}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>Jeopardy</td>\n",
       "      <td>$0.57$</td>\n",
       "      <td>$\\mathbf{0.54}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>SocialIQA</td>\n",
       "      <td>$\\mathbf{0.50}$</td>\n",
       "      <td>$0.59$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>All Tasks</td>\n",
       "      <td>$1.03$</td>\n",
       "      <td>$\\mathbf{0.86}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>Minerva MATH</td>\n",
       "      <td>$1.08$</td>\n",
       "      <td>$\\mathbf{0.98}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>PIQA</td>\n",
       "      <td>$\\mathbf{0.89}$</td>\n",
       "      <td>$1.01$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>Knowledge Tasks</td>\n",
       "      <td>$1.43$</td>\n",
       "      <td>$\\mathbf{1.20}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>MMLU</td>\n",
       "      <td>$\\mathbf{1.68}$</td>\n",
       "      <td>$1.74$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>MMLU Pro</td>\n",
       "      <td>$1.76$</td>\n",
       "      <td>$\\mathbf{1.75}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>Minerva MATH 500</td>\n",
       "      <td>$17.35$</td>\n",
       "      <td>$\\mathbf{1.78}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>MBPP</td>\n",
       "      <td>$2.57$</td>\n",
       "      <td>$\\mathbf{1.79}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>AGI Eval</td>\n",
       "      <td>$\\mathbf{1.89}$</td>\n",
       "      <td>$1.98$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>OLMES Gen</td>\n",
       "      <td>$4.19$</td>\n",
       "      <td>$\\mathbf{2.16}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>Math Tasks</td>\n",
       "      <td>$11.33$</td>\n",
       "      <td>$\\mathbf{2.30}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>BoolQ</td>\n",
       "      <td>$4.13$</td>\n",
       "      <td>$\\mathbf{2.48}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>OLMES Core 9</td>\n",
       "      <td>$\\mathbf{2.47}$</td>\n",
       "      <td>$2.62$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>TriviaQA</td>\n",
       "      <td>$\\mathbf{2.33}$</td>\n",
       "      <td>$2.62$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>Code Tasks</td>\n",
       "      <td>$3.15$</td>\n",
       "      <td>$\\mathbf{2.75}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>SQuAD</td>\n",
       "      <td>$2.80$</td>\n",
       "      <td>$\\mathbf{2.79}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>OpenBookQA</td>\n",
       "      <td>$4.02$</td>\n",
       "      <td>$\\mathbf{3.38}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>GSM Symbolic P2</td>\n",
       "      <td>$7.46$</td>\n",
       "      <td>$\\mathbf{3.50}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>AutoBencher</td>\n",
       "      <td>$3.86$</td>\n",
       "      <td>$\\mathbf{3.69}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>GSM8K</td>\n",
       "      <td>$7.46$</td>\n",
       "      <td>$\\mathbf{3.85}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>ARC Easy</td>\n",
       "      <td>$5.13$</td>\n",
       "      <td>$\\mathbf{5.13}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>MedMCQA</td>\n",
       "      <td>$\\mathbf{7.72}$</td>\n",
       "      <td>$7.98$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>ARC Challenge</td>\n",
       "      <td>$8.44$</td>\n",
       "      <td>$\\mathbf{8.43}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>MBPP+</td>\n",
       "      <td>$9.08$</td>\n",
       "      <td>$\\mathbf{8.79}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>HumanEval</td>\n",
       "      <td>$\\mathbf{7.71}$</td>\n",
       "      <td>$8.85$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>WinoGrande</td>\n",
       "      <td>$\\mathbf{10.01}$</td>\n",
       "      <td>$10.82$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>GSM+</td>\n",
       "      <td>$29.14$</td>\n",
       "      <td>$\\mathbf{28.54}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>BBH</td>\n",
       "      <td>$33.09$</td>\n",
       "      <td>$\\mathbf{33.08}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>DROP</td>\n",
       "      <td>$\\mathbf{35.17}$</td>\n",
       "      <td>$35.20$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>GSM Symbolic</td>\n",
       "      <td>$39.88$</td>\n",
       "      <td>$\\mathbf{38.88}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>GSM Symbolic P1</td>\n",
       "      <td>$\\mathbf{27.15}$</td>\n",
       "      <td>$83.62$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>36</th>\n",
       "      <td>Average</td>\n",
       "      <td>$\\mathbf{8.29}$</td>\n",
       "      <td>$8.79$</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                Task Avg. Target Stacked Abs. Error  \\\n",
       "0         HumanEval+                         $1.05$   \n",
       "1          HellaSwag                         $0.31$   \n",
       "2      CommonsenseQA                         $0.59$   \n",
       "3           Jeopardy                         $0.57$   \n",
       "4          SocialIQA                $\\mathbf{0.50}$   \n",
       "5          All Tasks                         $1.03$   \n",
       "6       Minerva MATH                         $1.08$   \n",
       "7               PIQA                $\\mathbf{0.89}$   \n",
       "8    Knowledge Tasks                         $1.43$   \n",
       "9               MMLU                $\\mathbf{1.68}$   \n",
       "10          MMLU Pro                         $1.76$   \n",
       "11  Minerva MATH 500                        $17.35$   \n",
       "12              MBPP                         $2.57$   \n",
       "13          AGI Eval                $\\mathbf{1.89}$   \n",
       "14         OLMES Gen                         $4.19$   \n",
       "15        Math Tasks                        $11.33$   \n",
       "16             BoolQ                         $4.13$   \n",
       "17      OLMES Core 9                $\\mathbf{2.47}$   \n",
       "18          TriviaQA                $\\mathbf{2.33}$   \n",
       "19        Code Tasks                         $3.15$   \n",
       "20             SQuAD                         $2.80$   \n",
       "21        OpenBookQA                         $4.02$   \n",
       "22   GSM Symbolic P2                         $7.46$   \n",
       "23       AutoBencher                         $3.86$   \n",
       "24             GSM8K                         $7.46$   \n",
       "25          ARC Easy                         $5.13$   \n",
       "26           MedMCQA                $\\mathbf{7.72}$   \n",
       "27     ARC Challenge                         $8.44$   \n",
       "28             MBPP+                         $9.08$   \n",
       "29         HumanEval                $\\mathbf{7.71}$   \n",
       "30        WinoGrande               $\\mathbf{10.01}$   \n",
       "31              GSM+                        $29.14$   \n",
       "32               BBH                        $33.09$   \n",
       "33              DROP               $\\mathbf{35.17}$   \n",
       "34      GSM Symbolic                        $39.88$   \n",
       "35   GSM Symbolic P1               $\\mathbf{27.15}$   \n",
       "36           Average                $\\mathbf{8.29}$   \n",
       "\n",
       "   Avg. Both Stacked Abs. Error  \n",
       "0               $\\mathbf{0.04}$  \n",
       "1               $\\mathbf{0.16}$  \n",
       "2               $\\mathbf{0.46}$  \n",
       "3               $\\mathbf{0.54}$  \n",
       "4                        $0.59$  \n",
       "5               $\\mathbf{0.86}$  \n",
       "6               $\\mathbf{0.98}$  \n",
       "7                        $1.01$  \n",
       "8               $\\mathbf{1.20}$  \n",
       "9                        $1.74$  \n",
       "10              $\\mathbf{1.75}$  \n",
       "11              $\\mathbf{1.78}$  \n",
       "12              $\\mathbf{1.79}$  \n",
       "13                       $1.98$  \n",
       "14              $\\mathbf{2.16}$  \n",
       "15              $\\mathbf{2.30}$  \n",
       "16              $\\mathbf{2.48}$  \n",
       "17                       $2.62$  \n",
       "18                       $2.62$  \n",
       "19              $\\mathbf{2.75}$  \n",
       "20              $\\mathbf{2.79}$  \n",
       "21              $\\mathbf{3.38}$  \n",
       "22              $\\mathbf{3.50}$  \n",
       "23              $\\mathbf{3.69}$  \n",
       "24              $\\mathbf{3.85}$  \n",
       "25              $\\mathbf{5.13}$  \n",
       "26                       $7.98$  \n",
       "27              $\\mathbf{8.43}$  \n",
       "28              $\\mathbf{8.79}$  \n",
       "29                       $8.85$  \n",
       "30                      $10.82$  \n",
       "31             $\\mathbf{28.54}$  \n",
       "32             $\\mathbf{33.08}$  \n",
       "33                      $35.20$  \n",
       "34             $\\mathbf{38.88}$  \n",
       "35                      $83.62$  \n",
       "36                       $8.79$  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from utils import get_pretty_task_name\n",
    "\n",
    "decision_cols = {\n",
    "    'task': 'Task',\n",
    "    'acc_final': 'Final Ckpt',\n",
    "    'acc_pred_avg': 'Avg. Prediction',\n",
    "    'acc_target_avg': 'Avg. Target',\n",
    "    'acc_both': 'Avg. Both',\n",
    "}\n",
    "\n",
    "ladder_cols = {\n",
    "    'task': 'Task',\n",
    "    # \"avg_target_step1_abs_error\": \"Avg. Target Step 1 Abs. Error\",\n",
    "    # \"avg_both_step1_abs_error\": \"Avg. Both Step 1 Abs. Error\",\n",
    "    # \"avg_target_step2_abs_error\": \"Avg. Target Step 2 Abs. Error\",\n",
    "    # \"avg_both_step2_abs_error\": \"Avg. Both Step 2 Abs. Error\",\n",
    "    \"avg_target_stacked_abs_error\": \"Avg. Target Stacked Abs. Error\",\n",
    "    \"avg_both_stacked_abs_error\": \"Avg. Both Stacked Abs. Error\",\n",
    "}\n",
    "\n",
    "ladder_cols_large = {\n",
    "    # \"final_ckpt_step1_abs_error\": \"Final Ckpt Step 1 Abs. Error\",\n",
    "    # \"avg_train_step1_abs_error\": \"Avg. Train Step 1 Abs. Error\",\n",
    "    \"avg_target_step1_abs_error\": \"Avg. Target Step 1 Abs. Error\",\n",
    "    \"avg_both_step1_abs_error\": \"Avg. Both Step 1 Abs. Error\",\n",
    "\n",
    "    # \"final_ckpt_step1_rel_error\": \"Final Ckpt Step 1 Rel. Error\",\n",
    "    # \"avg_train_step1_rel_error\": \"Avg. Train Step 1 Rel. Error\",\n",
    "    \"avg_target_step1_rel_error\": \"Avg. Target Step 1 Rel. Error\",\n",
    "    \"avg_both_step1_rel_error\": \"Avg. Both Step 1 Rel. Error\",\n",
    "\n",
    "    # \"final_ckpt_step2_abs_error\": \"Final Ckpt Step 2 Abs. Error\",\n",
    "    # \"avg_train_step2_abs_error\": \"Avg. Train Step 2 Abs. Error\",\n",
    "    # \"avg_target_step2_abs_error\": \"Avg. Target Step 2 Abs. Error\",\n",
    "    # \"avg_both_step2_abs_error\": \"Avg. Both Step 2 Abs. Error\",\n",
    "\n",
    "    # \"final_ckpt_step2_rel_error\": \"Final Ckpt Step 2 Rel. Error\",\n",
    "    # \"avg_train_step2_rel_error\": \"Avg. Train Step 2 Rel. Error\",\n",
    "    # \"avg_target_step2_rel_error\": \"Avg. Target Step 2 Rel. Error\",\n",
    "    # \"avg_both_step2_rel_error\": \"Avg. Both Step 2 Rel. Error\",\n",
    "\n",
    "    # \"final_ckpt_stacked_abs_error\": \"Final Ckpt Stacked Abs. Error\",\n",
    "    # \"avg_train_stacked_abs_error\": \"Avg. Train Stacked Abs. Error\",\n",
    "    \"avg_target_stacked_abs_error\": \"Avg. Target Stacked Abs. Error\",\n",
    "    \"avg_both_stacked_abs_error\": \"Avg. Both Stacked Abs. Error\",\n",
    "    \n",
    "    # \"final_ckpt_stacked_rel_error\": \"Final Ckpt Stacked Rel. Error\",\n",
    "    # \"avg_train_stacked_rel_error\": \"Avg. Train Stacked Rel. Error\",\n",
    "    \"avg_target_stacked_rel_error\": \"Avg. Target Stacked Rel. Error\",\n",
    "    \"avg_both_stacked_rel_error\": \"Avg. Both Stacked Rel. Error\",\n",
    "    \n",
    "    # \"final_ckpt_weight_avg_step1_abs_error\": \"Final Ckpt Step 1 Abs. Error\",\n",
    "    # \"final_ckpt_weight_avg_step2_abs_error\": \"Final Ckpt Step 2 Abs. Error\",\n",
    "    # \"final_ckpt_weight_avg_stacked_abs_error\": \"Final Ckpt Stacked Abs. Error\",\n",
    "    # \"final_ckpt_weight_avg_step1_rel_error\": \"Final Ckpt Step 1 Rel. Error\",\n",
    "    # \"final_ckpt_weight_avg_step2_rel_error\": \"Final Ckpt Step 2 Rel. Error\",\n",
    "    # \"final_ckpt_weight_avg_stacked_rel_error\": \"Final Ckpt Stacked Rel. Error\",\n",
    "    # \"avg_train_weight_avg_step1_abs_error\": \"Avg. Train Step 1 Abs. Error\",\n",
    "    # \"avg_train_weight_avg_step2_abs_error\": \"Avg. Train Step 2 Abs. Error\",\n",
    "    # \"avg_train_weight_avg_stacked_abs_error\": \"Avg. Train Stacked Abs. Error\",\n",
    "    # \"avg_train_weight_avg_step1_rel_error\": \"Avg. Train Step 1 Rel. Error\",\n",
    "    # \"avg_train_weight_avg_step2_rel_error\": \"Avg. Train Step 2 Rel. Error\",\n",
    "    # \"avg_train_weight_avg_stacked_rel_error\": \"Avg. Train Stacked Rel. Error\",\n",
    "}\n",
    "\n",
    "def _format_df(results, sort_col, col_names, bold_best=True):\n",
    "    df_results = pd.DataFrame(results)\n",
    "\n",
    "    # Delete cols\n",
    "    df_results = df_results.drop(['size', 'target_model'], axis=1)\n",
    "\n",
    "    if 'error' in sort_col:\n",
    "        sort_ascending = True\n",
    "    elif 'acc' in sort_col:\n",
    "        sort_ascending = False\n",
    "    else:\n",
    "        raise ValueError()\n",
    "    \n",
    "    # Sort\n",
    "    ordered_cols = ['task'] + [c for c in col_names.keys() if c in df_results.columns and c != 'task']\n",
    "    df_results = df_results[ordered_cols]\n",
    "    df_results = df_results.sort_values(sort_col, ascending=sort_ascending)\n",
    "\n",
    "    # display(df_results)\n",
    "\n",
    "    # if 'error' in sort_col:\n",
    "    #     df_results = df_results[df_results[sort_col] <= 0.1]\n",
    "\n",
    "    # Add average row\n",
    "    avg_row = pd.Series({'task': 'Average'})\n",
    "    for col in df_results.columns:\n",
    "        if col == 'task':\n",
    "            continue\n",
    "        values = df_results[col]\n",
    "        avg_row[col] = values.mean()\n",
    "    df_results = pd.concat([df_results, avg_row.to_frame().T], ignore_index=True)\n",
    "\n",
    "    # Convert to percentages\n",
    "    percentage_cols = [col for col in df_results.columns if col != 'task']\n",
    "    df_results[percentage_cols] = (df_results[percentage_cols] * 100)\n",
    "   \n",
    "    # Bold the max of each row\n",
    "    for idx in df_results.index:\n",
    "        row_vals = df_results.loc[idx, percentage_cols]\n",
    "        for col in percentage_cols:\n",
    "            val = df_results.loc[idx, col]\n",
    "\n",
    "            if sort_ascending:\n",
    "                best_val = row_vals.min()\n",
    "                is_best_row = val == best_val\n",
    "                all_best = (np.round(row_vals, 2) == np.round(best_val, 2)).sum() == len(row_vals)\n",
    "            else:\n",
    "                best_val = row_vals.max() \n",
    "                is_best_row = val == best_val\n",
    "                # print(row_vals.to_numpy())\n",
    "                # print(np.round(row_vals.to_numpy(), 2))\n",
    "                TOL = 0.01\n",
    "                is_max = np.abs(best_val - row_vals.to_numpy()) < TOL\n",
    "                all_best = (is_max).sum() == len(row_vals)\n",
    "                # print(all_best)\n",
    "\n",
    "            if is_best_row and bold_best and not all_best:\n",
    "                df_results.loc[idx, col] = f'$\\\\mathbf{{{val:.2f}}}$'\n",
    "            else:\n",
    "                df_results.loc[idx, col] = f'${val:.2f}$'\n",
    "                \n",
    "            df_results.loc[idx, 'all_best'] = all_best\n",
    "\n",
    "            # df_results.loc[idx, col] = f'{val:.1f}%'\n",
    "\n",
    "    # Rename columns and tasks\n",
    "    df_results['task'] = df_results['task'].apply(get_pretty_task_name)\n",
    "    df_results = df_results.rename(columns=col_names)\n",
    "\n",
    "    # Add \"*\" to tasks with same value for all tasks\n",
    "    # df_results.loc[df_results['all_best'], 'Task'] = df_results.loc[df_results['all_best'], 'Task'] + '*'\n",
    "    df_results = df_results.drop('all_best', axis=1)\n",
    "\n",
    "    return df_results\n",
    "\n",
    "df_ladder       = _format_df(ladder_results, sort_col='avg_both_stacked_abs_error', col_names=ladder_cols)\n",
    "df_ladder_large = _format_df(ladder_results, sort_col='avg_both_stacked_abs_error', col_names=ladder_cols_large, bold_best=False)\n",
    "df_decision_bpb = _format_df(decision_results_bpb, sort_col='acc_both', col_names=decision_cols)\n",
    "df_decision_primary = _format_df(decision_results_primary, sort_col='acc_both', col_names=decision_cols)\n",
    "\n",
    "# display(df_decision_primary)\n",
    "# display(df_decision_bpb)\n",
    "display(df_ladder)\n",
    "# display(df_ladder_large)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{table*}\n",
      "\\tiny\n",
      "\\centering\n",
      "\\makebox[\\textwidth]{\n",
      "\\label{tab:avg-last-n}\n",
      "\\begin{tabular}{p{0.12\\textwidth}C{0.05\\textwidth}C{0.05\\textwidth}C{0.05\\textwidth}}\n",
      "\\toprule\n",
      "Task & Avg. Target Stacked Abs. Error & Avg. Both Stacked Abs. Error \\\\\n",
      "\\midrule\n",
      "HumanEval+ & $1.05$ & $\\mathbf{0.04}$ \\\\\n",
      "HellaSwag & $0.31$ & $\\mathbf{0.16}$ \\\\\n",
      "CommonsenseQA & $0.59$ & $\\mathbf{0.46}$ \\\\\n",
      "Jeopardy & $0.57$ & $\\mathbf{0.54}$ \\\\\n",
      "SocialIQA & $\\mathbf{0.50}$ & $0.59$ \\\\\n",
      "All Tasks & $1.03$ & $\\mathbf{0.86}$ \\\\\n",
      "Minerva MATH & $1.08$ & $\\mathbf{0.98}$ \\\\\n",
      "PIQA & $\\mathbf{0.89}$ & $1.01$ \\\\\n",
      "Knowledge Tasks & $1.43$ & $\\mathbf{1.20}$ \\\\\n",
      "MMLU & $\\mathbf{1.68}$ & $1.74$ \\\\\n",
      "MMLU Pro & $1.76$ & $\\mathbf{1.75}$ \\\\\n",
      "Minerva MATH 500 & $17.35$ & $\\mathbf{1.78}$ \\\\\n",
      "MBPP & $2.57$ & $\\mathbf{1.79}$ \\\\\n",
      "AGI Eval & $\\mathbf{1.89}$ & $1.98$ \\\\\n",
      "OLMES Gen & $4.19$ & $\\mathbf{2.16}$ \\\\\n",
      "Math Tasks & $11.33$ & $\\mathbf{2.30}$ \\\\\n",
      "BoolQ & $4.13$ & $\\mathbf{2.48}$ \\\\\n",
      "OLMES Core 9 & $\\mathbf{2.47}$ & $2.62$ \\\\\n",
      "TriviaQA & $\\mathbf{2.33}$ & $2.62$ \\\\\n",
      "Code Tasks & $3.15$ & $\\mathbf{2.75}$ \\\\\n",
      "SQuAD & $2.80$ & $\\mathbf{2.79}$ \\\\\n",
      "OpenBookQA & $4.02$ & $\\mathbf{3.38}$ \\\\\n",
      "GSM Symbolic P2 & $7.46$ & $\\mathbf{3.50}$ \\\\\n",
      "AutoBencher & $3.86$ & $\\mathbf{3.69}$ \\\\\n",
      "GSM8K & $7.46$ & $\\mathbf{3.85}$ \\\\\n",
      "ARC Easy & $5.13$ & $\\mathbf{5.13}$ \\\\\n",
      "MedMCQA & $\\mathbf{7.72}$ & $7.98$ \\\\\n",
      "ARC Challenge & $8.44$ & $\\mathbf{8.43}$ \\\\\n",
      "MBPP+ & $9.08$ & $\\mathbf{8.79}$ \\\\\n",
      "HumanEval & $\\mathbf{7.71}$ & $8.85$ \\\\\n",
      "WinoGrande & $\\mathbf{10.01}$ & $10.82$ \\\\\n",
      "GSM+ & $29.14$ & $\\mathbf{28.54}$ \\\\\n",
      "BBH & $33.09$ & $\\mathbf{33.08}$ \\\\\n",
      "DROP & $\\mathbf{35.17}$ & $35.20$ \\\\\n",
      "GSM Symbolic & $39.88$ & $\\mathbf{38.88}$ \\\\\n",
      "GSM Symbolic P1 & $\\mathbf{27.15}$ & $83.62$ \\\\\n",
      "\\midrule\n",
      "Average & $\\mathbf{8.29}$ & $8.79$ \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "}\n",
      "\\caption{Caption goes here}\n",
      "\\end{table*}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "def _format_latex(df):\n",
    "    CAPTION = \"Caption goes here\"\n",
    "    table_str = df.to_latex(\n",
    "        label=\"tab:avg-last-n\",\n",
    "        index=False, \n",
    "        float_format=lambda x: '%.2f' % x,\n",
    "        column_format='p{0.12\\\\textwidth}' + 'C{0.05\\\\textwidth}'*len(df.columns)\n",
    "    )\n",
    "    table_str = table_str.replace('%', '\\%')\n",
    "    table_str = table_str.replace('table', 'table*')\\\n",
    "        .replace('\\\\begin{table*}', '\\\\begin{table*}\\n\\\\tiny\\n\\\\centering\\n\\\\makebox[\\\\textwidth]{')\\\n",
    "        .replace('\\\\end{table*}', '}\\n\\\\caption{' + CAPTION + '}\\n\\\\end{table*}')\n",
    "    table_str = table_str.replace('Average', '\\\\midrule\\nAverage')\n",
    "    \n",
    "    return table_str\n",
    "\n",
    "print(_format_latex(df_ladder))\n",
    "# print(_format_latex(df_ladder_large))\n",
    "# print(_format_latex(df_decision_primary))\n",
    "# print(_format_latex(df_decision_bpb))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "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>Task</th>\n",
       "      <th>Final Ckpt_bpb</th>\n",
       "      <th>Avg. Prediction_bpb</th>\n",
       "      <th>Avg. Target_bpb</th>\n",
       "      <th>Avg. Both_bpb</th>\n",
       "      <th>Final Ckpt_primary</th>\n",
       "      <th>Avg. Prediction_primary</th>\n",
       "      <th>Avg. Target_primary</th>\n",
       "      <th>Avg. Both_primary</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Code Tasks</td>\n",
       "      <td>$96.67$</td>\n",
       "      <td>$96.67$</td>\n",
       "      <td>$96.67$</td>\n",
       "      <td>$96.67$</td>\n",
       "      <td>$\\mathbf{85.67}$</td>\n",
       "      <td>$\\mathbf{85.67}$</td>\n",
       "      <td>$\\mathbf{85.67}$</td>\n",
       "      <td>$80.33$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>HumanEval+</td>\n",
       "      <td>$96.33$</td>\n",
       "      <td>$96.33$</td>\n",
       "      <td>$96.33$</td>\n",
       "      <td>$96.33$</td>\n",
       "      <td>$\\mathbf{71.33}$</td>\n",
       "      <td>$\\mathbf{71.33}$</td>\n",
       "      <td>$\\mathbf{71.33}$</td>\n",
       "      <td>$66.00$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>HumanEval</td>\n",
       "      <td>$95.67$</td>\n",
       "      <td>$95.67$</td>\n",
       "      <td>$95.67$</td>\n",
       "      <td>$95.67$</td>\n",
       "      <td>$\\mathbf{80.00}$</td>\n",
       "      <td>$\\mathbf{80.00}$</td>\n",
       "      <td>$\\mathbf{80.00}$</td>\n",
       "      <td>$74.33$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>MBPP</td>\n",
       "      <td>$95.33$</td>\n",
       "      <td>$95.33$</td>\n",
       "      <td>$95.33$</td>\n",
       "      <td>$95.33$</td>\n",
       "      <td>$\\mathbf{76.00}$</td>\n",
       "      <td>$\\mathbf{76.00}$</td>\n",
       "      <td>$\\mathbf{76.00}$</td>\n",
       "      <td>$68.33$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>ARC Challenge</td>\n",
       "      <td>$94.56$</td>\n",
       "      <td>$\\mathbf{94.88}$</td>\n",
       "      <td>$94.38$</td>\n",
       "      <td>$94.67$</td>\n",
       "      <td>$82.91$</td>\n",
       "      <td>$82.27$</td>\n",
       "      <td>$\\mathbf{82.91}$</td>\n",
       "      <td>$82.00$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>HellaSwag</td>\n",
       "      <td>$92.42$</td>\n",
       "      <td>$93.19$</td>\n",
       "      <td>$93.21$</td>\n",
       "      <td>$\\mathbf{94.00}$</td>\n",
       "      <td>$71.05$</td>\n",
       "      <td>$71.26$</td>\n",
       "      <td>$\\mathbf{72.37}$</td>\n",
       "      <td>$72.33$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>MBPP+</td>\n",
       "      <td>$93.00$</td>\n",
       "      <td>$93.00$</td>\n",
       "      <td>$93.00$</td>\n",
       "      <td>$93.00$</td>\n",
       "      <td>$\\mathbf{70.67}$</td>\n",
       "      <td>$\\mathbf{70.67}$</td>\n",
       "      <td>$\\mathbf{70.67}$</td>\n",
       "      <td>$62.67$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>ARC Easy</td>\n",
       "      <td>$\\mathbf{92.23}$</td>\n",
       "      <td>$92.15$</td>\n",
       "      <td>$91.96$</td>\n",
       "      <td>$92.00$</td>\n",
       "      <td>$93.96$</td>\n",
       "      <td>$93.99$</td>\n",
       "      <td>$\\mathbf{94.05}$</td>\n",
       "      <td>$94.00$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>MMLU</td>\n",
       "      <td>$91.53$</td>\n",
       "      <td>$91.64$</td>\n",
       "      <td>$91.63$</td>\n",
       "      <td>$\\mathbf{91.67}$</td>\n",
       "      <td>$89.08$</td>\n",
       "      <td>$88.84$</td>\n",
       "      <td>$\\mathbf{89.60}$</td>\n",
       "      <td>$89.00$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>Minerva MATH 500</td>\n",
       "      <td>$90.33$</td>\n",
       "      <td>$90.33$</td>\n",
       "      <td>$90.33$</td>\n",
       "      <td>$90.33$</td>\n",
       "      <td>$\\mathbf{51.00}$</td>\n",
       "      <td>$\\mathbf{51.00}$</td>\n",
       "      <td>$\\mathbf{51.00}$</td>\n",
       "      <td>$50.67$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>Minerva MATH</td>\n",
       "      <td>$90.00$</td>\n",
       "      <td>$90.00$</td>\n",
       "      <td>$90.00$</td>\n",
       "      <td>$90.00$</td>\n",
       "      <td>$51.00$</td>\n",
       "      <td>$51.00$</td>\n",
       "      <td>$51.00$</td>\n",
       "      <td>$51.00$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>AutoBencher</td>\n",
       "      <td>$88.55$</td>\n",
       "      <td>$88.95$</td>\n",
       "      <td>$89.19$</td>\n",
       "      <td>$\\mathbf{89.67}$</td>\n",
       "      <td>$88.80$</td>\n",
       "      <td>$\\mathbf{89.05}$</td>\n",
       "      <td>$88.81$</td>\n",
       "      <td>$89.00$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>MMLU Pro</td>\n",
       "      <td>$90.00$</td>\n",
       "      <td>$89.40$</td>\n",
       "      <td>$\\mathbf{90.04}$</td>\n",
       "      <td>$89.33$</td>\n",
       "      <td>$83.34$</td>\n",
       "      <td>$83.77$</td>\n",
       "      <td>$84.20$</td>\n",
       "      <td>$\\mathbf{84.67}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>Math Tasks</td>\n",
       "      <td>$88.33$</td>\n",
       "      <td>$88.33$</td>\n",
       "      <td>$88.33$</td>\n",
       "      <td>$88.33$</td>\n",
       "      <td>$42.67$</td>\n",
       "      <td>$42.67$</td>\n",
       "      <td>$42.67$</td>\n",
       "      <td>$42.67$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>AGI Eval</td>\n",
       "      <td>$86.38$</td>\n",
       "      <td>$86.75$</td>\n",
       "      <td>$86.54$</td>\n",
       "      <td>$\\mathbf{87.00}$</td>\n",
       "      <td>$57.38$</td>\n",
       "      <td>$\\mathbf{58.60}$</td>\n",
       "      <td>$56.45$</td>\n",
       "      <td>$57.67$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>MedMCQA</td>\n",
       "      <td>$86.67$</td>\n",
       "      <td>$86.67$</td>\n",
       "      <td>$86.67$</td>\n",
       "      <td>$86.67$</td>\n",
       "      <td>$\\mathbf{61.33}$</td>\n",
       "      <td>$\\mathbf{61.33}$</td>\n",
       "      <td>$\\mathbf{61.33}$</td>\n",
       "      <td>$60.33$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>Jeopardy</td>\n",
       "      <td>$84.42$</td>\n",
       "      <td>$84.46$</td>\n",
       "      <td>$84.88$</td>\n",
       "      <td>$\\mathbf{85.00}$</td>\n",
       "      <td>$83.01$</td>\n",
       "      <td>$82.60$</td>\n",
       "      <td>$\\mathbf{83.74}$</td>\n",
       "      <td>$83.33$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>TriviaQA</td>\n",
       "      <td>$83.55$</td>\n",
       "      <td>$84.29$</td>\n",
       "      <td>$83.86$</td>\n",
       "      <td>$\\mathbf{84.67}$</td>\n",
       "      <td>$69.10$</td>\n",
       "      <td>$\\mathbf{69.54}$</td>\n",
       "      <td>$69.09$</td>\n",
       "      <td>$69.33$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>OpenBookQA</td>\n",
       "      <td>$81.53$</td>\n",
       "      <td>$81.75$</td>\n",
       "      <td>$81.68$</td>\n",
       "      <td>$\\mathbf{82.00}$</td>\n",
       "      <td>$66.82$</td>\n",
       "      <td>$66.98$</td>\n",
       "      <td>$68.05$</td>\n",
       "      <td>$\\mathbf{68.33}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>GSM Symbolic P1</td>\n",
       "      <td>$81.33$</td>\n",
       "      <td>$81.33$</td>\n",
       "      <td>$81.33$</td>\n",
       "      <td>$81.33$</td>\n",
       "      <td>$\\mathbf{41.67}$</td>\n",
       "      <td>$\\mathbf{41.67}$</td>\n",
       "      <td>$\\mathbf{41.67}$</td>\n",
       "      <td>$41.33$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>OLMES Core 9</td>\n",
       "      <td>$79.05$</td>\n",
       "      <td>$80.10$</td>\n",
       "      <td>$79.32$</td>\n",
       "      <td>$\\mathbf{80.33}$</td>\n",
       "      <td>$\\mathbf{74.67}$</td>\n",
       "      <td>$73.92$</td>\n",
       "      <td>$74.24$</td>\n",
       "      <td>$73.67$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>GSM Symbolic P2</td>\n",
       "      <td>$79.67$</td>\n",
       "      <td>$79.67$</td>\n",
       "      <td>$79.67$</td>\n",
       "      <td>$79.67$</td>\n",
       "      <td>$40.33$</td>\n",
       "      <td>$40.33$</td>\n",
       "      <td>$40.33$</td>\n",
       "      <td>$40.33$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>SocialIQA</td>\n",
       "      <td>$\\mathbf{79.92}$</td>\n",
       "      <td>$79.57$</td>\n",
       "      <td>$79.45$</td>\n",
       "      <td>$79.00$</td>\n",
       "      <td>$55.58$</td>\n",
       "      <td>$55.58$</td>\n",
       "      <td>$56.09$</td>\n",
       "      <td>$\\mathbf{56.67}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>GSM+</td>\n",
       "      <td>$79.00$</td>\n",
       "      <td>$79.00$</td>\n",
       "      <td>$79.00$</td>\n",
       "      <td>$79.00$</td>\n",
       "      <td>$59.67$</td>\n",
       "      <td>$59.67$</td>\n",
       "      <td>$59.67$</td>\n",
       "      <td>$59.67$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>GSM Symbolic</td>\n",
       "      <td>$78.33$</td>\n",
       "      <td>$78.33$</td>\n",
       "      <td>$78.33$</td>\n",
       "      <td>$78.33$</td>\n",
       "      <td>$\\mathbf{51.67}$</td>\n",
       "      <td>$\\mathbf{51.67}$</td>\n",
       "      <td>$\\mathbf{51.67}$</td>\n",
       "      <td>$51.00$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>GSM8K</td>\n",
       "      <td>$76.67$</td>\n",
       "      <td>$76.67$</td>\n",
       "      <td>$76.67$</td>\n",
       "      <td>$76.67$</td>\n",
       "      <td>$\\mathbf{46.33}$</td>\n",
       "      <td>$\\mathbf{46.33}$</td>\n",
       "      <td>$\\mathbf{46.33}$</td>\n",
       "      <td>$46.00$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>WinoGrande</td>\n",
       "      <td>$73.20$</td>\n",
       "      <td>$\\mathbf{74.29}$</td>\n",
       "      <td>$72.83$</td>\n",
       "      <td>$74.00$</td>\n",
       "      <td>$\\mathbf{50.52}$</td>\n",
       "      <td>$50.27$</td>\n",
       "      <td>$49.81$</td>\n",
       "      <td>$49.00$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>PIQA</td>\n",
       "      <td>$72.60$</td>\n",
       "      <td>$\\mathbf{72.91}$</td>\n",
       "      <td>$71.93$</td>\n",
       "      <td>$72.00$</td>\n",
       "      <td>$72.78$</td>\n",
       "      <td>$72.66$</td>\n",
       "      <td>$\\mathbf{73.09}$</td>\n",
       "      <td>$72.33$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>Knowledge Tasks</td>\n",
       "      <td>$71.39$</td>\n",
       "      <td>$71.49$</td>\n",
       "      <td>$71.62$</td>\n",
       "      <td>$\\mathbf{71.67}$</td>\n",
       "      <td>$70.70$</td>\n",
       "      <td>$75.82$</td>\n",
       "      <td>$72.65$</td>\n",
       "      <td>$\\mathbf{78.00}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>All Tasks</td>\n",
       "      <td>$68.57$</td>\n",
       "      <td>$70.63$</td>\n",
       "      <td>$69.78$</td>\n",
       "      <td>$\\mathbf{71.33}$</td>\n",
       "      <td>$62.15$</td>\n",
       "      <td>$68.88$</td>\n",
       "      <td>$67.29$</td>\n",
       "      <td>$\\mathbf{77.33}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>CommonsenseQA</td>\n",
       "      <td>$65.86$</td>\n",
       "      <td>$\\mathbf{66.25}$</td>\n",
       "      <td>$65.42$</td>\n",
       "      <td>$65.67$</td>\n",
       "      <td>$68.74$</td>\n",
       "      <td>$69.05$</td>\n",
       "      <td>$70.61$</td>\n",
       "      <td>$\\mathbf{71.00}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>BoolQ</td>\n",
       "      <td>$63.72$</td>\n",
       "      <td>$\\mathbf{64.19}$</td>\n",
       "      <td>$63.51$</td>\n",
       "      <td>$64.00$</td>\n",
       "      <td>$50.38$</td>\n",
       "      <td>$48.90$</td>\n",
       "      <td>$\\mathbf{50.66}$</td>\n",
       "      <td>$49.33$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>SQuAD</td>\n",
       "      <td>$60.93$</td>\n",
       "      <td>$60.59$</td>\n",
       "      <td>$\\mathbf{62.02}$</td>\n",
       "      <td>$61.67$</td>\n",
       "      <td>$58.69$</td>\n",
       "      <td>$58.35$</td>\n",
       "      <td>$\\mathbf{59.72}$</td>\n",
       "      <td>$59.33$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>OLMES Gen</td>\n",
       "      <td>$\\mathbf{61.16}$</td>\n",
       "      <td>$55.44$</td>\n",
       "      <td>$55.11$</td>\n",
       "      <td>$58.86$</td>\n",
       "      <td>$\\mathbf{62.06}$</td>\n",
       "      <td>$54.87$</td>\n",
       "      <td>$53.42$</td>\n",
       "      <td>$50.12$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>DROP</td>\n",
       "      <td>$56.67$</td>\n",
       "      <td>$56.48$</td>\n",
       "      <td>$\\mathbf{57.46}$</td>\n",
       "      <td>$57.33$</td>\n",
       "      <td>$57.77$</td>\n",
       "      <td>$59.06$</td>\n",
       "      <td>$57.80$</td>\n",
       "      <td>$\\mathbf{59.33}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>BBH</td>\n",
       "      <td>$57.48$</td>\n",
       "      <td>$57.25$</td>\n",
       "      <td>$\\mathbf{57.66}$</td>\n",
       "      <td>$57.33$</td>\n",
       "      <td>$59.15$</td>\n",
       "      <td>$59.88$</td>\n",
       "      <td>$60.85$</td>\n",
       "      <td>$\\mathbf{61.33}$</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>36</th>\n",
       "      <td>Average</td>\n",
       "      <td>$81.20$</td>\n",
       "      <td>$81.22$</td>\n",
       "      <td>$81.13$</td>\n",
       "      <td>$\\mathbf{81.40}$</td>\n",
       "      <td>$65.50$</td>\n",
       "      <td>$65.65$</td>\n",
       "      <td>$\\mathbf{65.69}$</td>\n",
       "      <td>$65.05$</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                Task    Final Ckpt_bpb Avg. Prediction_bpb   Avg. Target_bpb  \\\n",
       "0         Code Tasks           $96.67$             $96.67$           $96.67$   \n",
       "1         HumanEval+           $96.33$             $96.33$           $96.33$   \n",
       "2          HumanEval           $95.67$             $95.67$           $95.67$   \n",
       "3               MBPP           $95.33$             $95.33$           $95.33$   \n",
       "4      ARC Challenge           $94.56$    $\\mathbf{94.88}$           $94.38$   \n",
       "5          HellaSwag           $92.42$             $93.19$           $93.21$   \n",
       "6              MBPP+           $93.00$             $93.00$           $93.00$   \n",
       "7           ARC Easy  $\\mathbf{92.23}$             $92.15$           $91.96$   \n",
       "8               MMLU           $91.53$             $91.64$           $91.63$   \n",
       "9   Minerva MATH 500           $90.33$             $90.33$           $90.33$   \n",
       "10      Minerva MATH           $90.00$             $90.00$           $90.00$   \n",
       "11       AutoBencher           $88.55$             $88.95$           $89.19$   \n",
       "12          MMLU Pro           $90.00$             $89.40$  $\\mathbf{90.04}$   \n",
       "13        Math Tasks           $88.33$             $88.33$           $88.33$   \n",
       "14          AGI Eval           $86.38$             $86.75$           $86.54$   \n",
       "15           MedMCQA           $86.67$             $86.67$           $86.67$   \n",
       "16          Jeopardy           $84.42$             $84.46$           $84.88$   \n",
       "17          TriviaQA           $83.55$             $84.29$           $83.86$   \n",
       "18        OpenBookQA           $81.53$             $81.75$           $81.68$   \n",
       "19   GSM Symbolic P1           $81.33$             $81.33$           $81.33$   \n",
       "20      OLMES Core 9           $79.05$             $80.10$           $79.32$   \n",
       "21   GSM Symbolic P2           $79.67$             $79.67$           $79.67$   \n",
       "22         SocialIQA  $\\mathbf{79.92}$             $79.57$           $79.45$   \n",
       "23              GSM+           $79.00$             $79.00$           $79.00$   \n",
       "24      GSM Symbolic           $78.33$             $78.33$           $78.33$   \n",
       "25             GSM8K           $76.67$             $76.67$           $76.67$   \n",
       "26        WinoGrande           $73.20$    $\\mathbf{74.29}$           $72.83$   \n",
       "27              PIQA           $72.60$    $\\mathbf{72.91}$           $71.93$   \n",
       "28   Knowledge Tasks           $71.39$             $71.49$           $71.62$   \n",
       "29         All Tasks           $68.57$             $70.63$           $69.78$   \n",
       "30     CommonsenseQA           $65.86$    $\\mathbf{66.25}$           $65.42$   \n",
       "31             BoolQ           $63.72$    $\\mathbf{64.19}$           $63.51$   \n",
       "32             SQuAD           $60.93$             $60.59$  $\\mathbf{62.02}$   \n",
       "33         OLMES Gen  $\\mathbf{61.16}$             $55.44$           $55.11$   \n",
       "34              DROP           $56.67$             $56.48$  $\\mathbf{57.46}$   \n",
       "35               BBH           $57.48$             $57.25$  $\\mathbf{57.66}$   \n",
       "36           Average           $81.20$             $81.22$           $81.13$   \n",
       "\n",
       "       Avg. Both_bpb Final Ckpt_primary Avg. Prediction_primary  \\\n",
       "0            $96.67$   $\\mathbf{85.67}$        $\\mathbf{85.67}$   \n",
       "1            $96.33$   $\\mathbf{71.33}$        $\\mathbf{71.33}$   \n",
       "2            $95.67$   $\\mathbf{80.00}$        $\\mathbf{80.00}$   \n",
       "3            $95.33$   $\\mathbf{76.00}$        $\\mathbf{76.00}$   \n",
       "4            $94.67$            $82.91$                 $82.27$   \n",
       "5   $\\mathbf{94.00}$            $71.05$                 $71.26$   \n",
       "6            $93.00$   $\\mathbf{70.67}$        $\\mathbf{70.67}$   \n",
       "7            $92.00$            $93.96$                 $93.99$   \n",
       "8   $\\mathbf{91.67}$            $89.08$                 $88.84$   \n",
       "9            $90.33$   $\\mathbf{51.00}$        $\\mathbf{51.00}$   \n",
       "10           $90.00$            $51.00$                 $51.00$   \n",
       "11  $\\mathbf{89.67}$            $88.80$        $\\mathbf{89.05}$   \n",
       "12           $89.33$            $83.34$                 $83.77$   \n",
       "13           $88.33$            $42.67$                 $42.67$   \n",
       "14  $\\mathbf{87.00}$            $57.38$        $\\mathbf{58.60}$   \n",
       "15           $86.67$   $\\mathbf{61.33}$        $\\mathbf{61.33}$   \n",
       "16  $\\mathbf{85.00}$            $83.01$                 $82.60$   \n",
       "17  $\\mathbf{84.67}$            $69.10$        $\\mathbf{69.54}$   \n",
       "18  $\\mathbf{82.00}$            $66.82$                 $66.98$   \n",
       "19           $81.33$   $\\mathbf{41.67}$        $\\mathbf{41.67}$   \n",
       "20  $\\mathbf{80.33}$   $\\mathbf{74.67}$                 $73.92$   \n",
       "21           $79.67$            $40.33$                 $40.33$   \n",
       "22           $79.00$            $55.58$                 $55.58$   \n",
       "23           $79.00$            $59.67$                 $59.67$   \n",
       "24           $78.33$   $\\mathbf{51.67}$        $\\mathbf{51.67}$   \n",
       "25           $76.67$   $\\mathbf{46.33}$        $\\mathbf{46.33}$   \n",
       "26           $74.00$   $\\mathbf{50.52}$                 $50.27$   \n",
       "27           $72.00$            $72.78$                 $72.66$   \n",
       "28  $\\mathbf{71.67}$            $70.70$                 $75.82$   \n",
       "29  $\\mathbf{71.33}$            $62.15$                 $68.88$   \n",
       "30           $65.67$            $68.74$                 $69.05$   \n",
       "31           $64.00$            $50.38$                 $48.90$   \n",
       "32           $61.67$            $58.69$                 $58.35$   \n",
       "33           $58.86$   $\\mathbf{62.06}$                 $54.87$   \n",
       "34           $57.33$            $57.77$                 $59.06$   \n",
       "35           $57.33$            $59.15$                 $59.88$   \n",
       "36  $\\mathbf{81.40}$            $65.50$                 $65.65$   \n",
       "\n",
       "   Avg. Target_primary Avg. Both_primary  \n",
       "0     $\\mathbf{85.67}$           $80.33$  \n",
       "1     $\\mathbf{71.33}$           $66.00$  \n",
       "2     $\\mathbf{80.00}$           $74.33$  \n",
       "3     $\\mathbf{76.00}$           $68.33$  \n",
       "4     $\\mathbf{82.91}$           $82.00$  \n",
       "5     $\\mathbf{72.37}$           $72.33$  \n",
       "6     $\\mathbf{70.67}$           $62.67$  \n",
       "7     $\\mathbf{94.05}$           $94.00$  \n",
       "8     $\\mathbf{89.60}$           $89.00$  \n",
       "9     $\\mathbf{51.00}$           $50.67$  \n",
       "10             $51.00$           $51.00$  \n",
       "11             $88.81$           $89.00$  \n",
       "12             $84.20$  $\\mathbf{84.67}$  \n",
       "13             $42.67$           $42.67$  \n",
       "14             $56.45$           $57.67$  \n",
       "15    $\\mathbf{61.33}$           $60.33$  \n",
       "16    $\\mathbf{83.74}$           $83.33$  \n",
       "17             $69.09$           $69.33$  \n",
       "18             $68.05$  $\\mathbf{68.33}$  \n",
       "19    $\\mathbf{41.67}$           $41.33$  \n",
       "20             $74.24$           $73.67$  \n",
       "21             $40.33$           $40.33$  \n",
       "22             $56.09$  $\\mathbf{56.67}$  \n",
       "23             $59.67$           $59.67$  \n",
       "24    $\\mathbf{51.67}$           $51.00$  \n",
       "25    $\\mathbf{46.33}$           $46.00$  \n",
       "26             $49.81$           $49.00$  \n",
       "27    $\\mathbf{73.09}$           $72.33$  \n",
       "28             $72.65$  $\\mathbf{78.00}$  \n",
       "29             $67.29$  $\\mathbf{77.33}$  \n",
       "30             $70.61$  $\\mathbf{71.00}$  \n",
       "31    $\\mathbf{50.66}$           $49.33$  \n",
       "32    $\\mathbf{59.72}$           $59.33$  \n",
       "33             $53.42$           $50.12$  \n",
       "34             $57.80$  $\\mathbf{59.33}$  \n",
       "35             $60.85$  $\\mathbf{61.33}$  \n",
       "36    $\\mathbf{65.69}$           $65.05$  "
      ]
     },
     "execution_count": 62,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# (for appendix) Remove asterisks from Task column before merging\n",
    "df_decision_primary['Task'] = df_decision_primary['Task'].str.replace('*', '')\n",
    "df_decision_bpb['Task'] = df_decision_bpb['Task'].str.replace('*', '')\n",
    "\n",
    "# Merge the dataframes on Task column\n",
    "df_combined = pd.merge(df_decision_bpb, df_decision_primary, on='Task', suffixes=('_bpb', '_primary'))\n",
    "\n",
    "df_combined"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{table*}\n",
      "\\tiny\n",
      "\\centering\n",
      "\\makebox[\\textwidth]{\n",
      "\\label{tab:avg-last-n}\n",
      "\\begin{tabular}{p{0.12\\textwidth}C{0.05\\textwidth}C{0.05\\textwidth}C{0.05\\textwidth}C{0.05\\textwidth}C{0.05\\textwidth}C{0.05\\textwidth}C{0.05\\textwidth}C{0.05\\textwidth}C{0.05\\textwidth}}\n",
      "\\toprule\n",
      "Task & Final Ckpt_bpb & Avg. Prediction_bpb & Avg. Target_bpb & Avg. Both_bpb & Final Ckpt_primary & Avg. Prediction_primary & Avg. Target_primary & Avg. Both_primary \\\\\n",
      "\\midrule\n",
      "Code Tasks & $96.67$ & $96.67$ & $96.67$ & $96.67$ & $\\mathbf{85.67}$ & $\\mathbf{85.67}$ & $\\mathbf{85.67}$ & $80.33$ \\\\\n",
      "HumanEval+ & $96.33$ & $96.33$ & $96.33$ & $96.33$ & $\\mathbf{71.33}$ & $\\mathbf{71.33}$ & $\\mathbf{71.33}$ & $66.00$ \\\\\n",
      "HumanEval & $95.67$ & $95.67$ & $95.67$ & $95.67$ & $\\mathbf{80.00}$ & $\\mathbf{80.00}$ & $\\mathbf{80.00}$ & $74.33$ \\\\\n",
      "MBPP & $95.33$ & $95.33$ & $95.33$ & $95.33$ & $\\mathbf{76.00}$ & $\\mathbf{76.00}$ & $\\mathbf{76.00}$ & $68.33$ \\\\\n",
      "ARC Challenge & $94.56$ & $\\mathbf{94.88}$ & $94.38$ & $94.67$ & $82.91$ & $82.27$ & $\\mathbf{82.91}$ & $82.00$ \\\\\n",
      "HellaSwag & $92.42$ & $93.19$ & $93.21$ & $\\mathbf{94.00}$ & $71.05$ & $71.26$ & $\\mathbf{72.37}$ & $72.33$ \\\\\n",
      "MBPP+ & $93.00$ & $93.00$ & $93.00$ & $93.00$ & $\\mathbf{70.67}$ & $\\mathbf{70.67}$ & $\\mathbf{70.67}$ & $62.67$ \\\\\n",
      "ARC Easy & $\\mathbf{92.23}$ & $92.15$ & $91.96$ & $92.00$ & $93.96$ & $93.99$ & $\\mathbf{94.05}$ & $94.00$ \\\\\n",
      "MMLU & $91.53$ & $91.64$ & $91.63$ & $\\mathbf{91.67}$ & $89.08$ & $88.84$ & $\\mathbf{89.60}$ & $89.00$ \\\\\n",
      "Minerva MATH 500 & $90.33$ & $90.33$ & $90.33$ & $90.33$ & $\\mathbf{51.00}$ & $\\mathbf{51.00}$ & $\\mathbf{51.00}$ & $50.67$ \\\\\n",
      "Minerva MATH & $90.00$ & $90.00$ & $90.00$ & $90.00$ & $51.00$ & $51.00$ & $51.00$ & $51.00$ \\\\\n",
      "AutoBencher & $88.55$ & $88.95$ & $89.19$ & $\\mathbf{89.67}$ & $88.80$ & $\\mathbf{89.05}$ & $88.81$ & $89.00$ \\\\\n",
      "MMLU Pro & $90.00$ & $89.40$ & $\\mathbf{90.04}$ & $89.33$ & $83.34$ & $83.77$ & $84.20$ & $\\mathbf{84.67}$ \\\\\n",
      "Math Tasks & $88.33$ & $88.33$ & $88.33$ & $88.33$ & $42.67$ & $42.67$ & $42.67$ & $42.67$ \\\\\n",
      "AGI Eval & $86.38$ & $86.75$ & $86.54$ & $\\mathbf{87.00}$ & $57.38$ & $\\mathbf{58.60}$ & $56.45$ & $57.67$ \\\\\n",
      "MedMCQA & $86.67$ & $86.67$ & $86.67$ & $86.67$ & $\\mathbf{61.33}$ & $\\mathbf{61.33}$ & $\\mathbf{61.33}$ & $60.33$ \\\\\n",
      "Jeopardy & $84.42$ & $84.46$ & $84.88$ & $\\mathbf{85.00}$ & $83.01$ & $82.60$ & $\\mathbf{83.74}$ & $83.33$ \\\\\n",
      "TriviaQA & $83.55$ & $84.29$ & $83.86$ & $\\mathbf{84.67}$ & $69.10$ & $\\mathbf{69.54}$ & $69.09$ & $69.33$ \\\\\n",
      "OpenBookQA & $81.53$ & $81.75$ & $81.68$ & $\\mathbf{82.00}$ & $66.82$ & $66.98$ & $68.05$ & $\\mathbf{68.33}$ \\\\\n",
      "GSM Symbolic P1 & $81.33$ & $81.33$ & $81.33$ & $81.33$ & $\\mathbf{41.67}$ & $\\mathbf{41.67}$ & $\\mathbf{41.67}$ & $41.33$ \\\\\n",
      "OLMES Core 9 & $79.05$ & $80.10$ & $79.32$ & $\\mathbf{80.33}$ & $\\mathbf{74.67}$ & $73.92$ & $74.24$ & $73.67$ \\\\\n",
      "GSM Symbolic P2 & $79.67$ & $79.67$ & $79.67$ & $79.67$ & $40.33$ & $40.33$ & $40.33$ & $40.33$ \\\\\n",
      "SocialIQA & $\\mathbf{79.92}$ & $79.57$ & $79.45$ & $79.00$ & $55.58$ & $55.58$ & $56.09$ & $\\mathbf{56.67}$ \\\\\n",
      "GSM+ & $79.00$ & $79.00$ & $79.00$ & $79.00$ & $59.67$ & $59.67$ & $59.67$ & $59.67$ \\\\\n",
      "GSM Symbolic & $78.33$ & $78.33$ & $78.33$ & $78.33$ & $\\mathbf{51.67}$ & $\\mathbf{51.67}$ & $\\mathbf{51.67}$ & $51.00$ \\\\\n",
      "GSM8K & $76.67$ & $76.67$ & $76.67$ & $76.67$ & $\\mathbf{46.33}$ & $\\mathbf{46.33}$ & $\\mathbf{46.33}$ & $46.00$ \\\\\n",
      "WinoGrande & $73.20$ & $\\mathbf{74.29}$ & $72.83$ & $74.00$ & $\\mathbf{50.52}$ & $50.27$ & $49.81$ & $49.00$ \\\\\n",
      "PIQA & $72.60$ & $\\mathbf{72.91}$ & $71.93$ & $72.00$ & $72.78$ & $72.66$ & $\\mathbf{73.09}$ & $72.33$ \\\\\n",
      "Knowledge Tasks & $71.39$ & $71.49$ & $71.62$ & $\\mathbf{71.67}$ & $70.70$ & $75.82$ & $72.65$ & $\\mathbf{78.00}$ \\\\\n",
      "All Tasks & $68.57$ & $70.63$ & $69.78$ & $\\mathbf{71.33}$ & $62.15$ & $68.88$ & $67.29$ & $\\mathbf{77.33}$ \\\\\n",
      "CommonsenseQA & $65.86$ & $\\mathbf{66.25}$ & $65.42$ & $65.67$ & $68.74$ & $69.05$ & $70.61$ & $\\mathbf{71.00}$ \\\\\n",
      "BoolQ & $63.72$ & $\\mathbf{64.19}$ & $63.51$ & $64.00$ & $50.38$ & $48.90$ & $\\mathbf{50.66}$ & $49.33$ \\\\\n",
      "SQuAD & $60.93$ & $60.59$ & $\\mathbf{62.02}$ & $61.67$ & $58.69$ & $58.35$ & $\\mathbf{59.72}$ & $59.33$ \\\\\n",
      "OLMES Gen & $\\mathbf{61.16}$ & $55.44$ & $55.11$ & $58.86$ & $\\mathbf{62.06}$ & $54.87$ & $53.42$ & $50.12$ \\\\\n",
      "DROP & $56.67$ & $56.48$ & $\\mathbf{57.46}$ & $57.33$ & $57.77$ & $59.06$ & $57.80$ & $\\mathbf{59.33}$ \\\\\n",
      "BBH & $57.48$ & $57.25$ & $\\mathbf{57.66}$ & $57.33$ & $59.15$ & $59.88$ & $60.85$ & $\\mathbf{61.33}$ \\\\\n",
      "\\midrule\n",
      "Average & $81.20$ & $81.22$ & $81.13$ & $\\mathbf{81.40}$ & $65.50$ & $65.65$ & $\\mathbf{65.69}$ & $65.05$ \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "}\n",
      "\\caption{Caption goes here}\n",
      "\\end{table*}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(_format_latex(df_combined))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "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.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
