{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "89d9655c-154b-45d6-85e4-c8cc63c1044a",
   "metadata": {},
   "source": [
    "# Do Intermediate Representations Help?\n",
    "This notebook compares vision transformer representation methods to determine whether using intermediate layers improves classification performance over final layer only.\n",
    "\n",
    "- **Data**\n",
    "    - **Input**: aggregated results `all_runs_v11.pkl` with performance metrics\n",
    "    - **Models**:  9 vision transformers (OpenCLIP ViT, DINOv2, standard ViT)\n",
    "    - **Datasets**: 19 classification tasks\n",
    "- **Representation Sources:**\n",
    "    - Last layer: CLS token or all tokens\n",
    "    - Multi-layer: CLS + Average Pooling from:\n",
    "      - Middle & last blocks\n",
    "      - Quarterly blocks (1/4, 3/4 positions)\n",
    "      - All blocks\n",
    "- **Probing:**\n",
    "    - Linear classifiers on frozen features\n",
    "    - Attention mechanisms over token sequences\n",
    "- **Outputs**\n",
    "    1. **Performance tables**: Accuracy gains over CLS last layer baseline for each model (all sizes)\n",
    "    2. **Figure 2**: Boxplots of accuracy gains across *base models*\n",
    "    3. **Statistical tests**: Wilcoxon signed-rank tests with FDR correction"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c45e6113-57ca-416a-9644-b152011f534e",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "from pathlib import Path\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import sys\n",
    "\n",
    "from itertools import product\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.lines import Line2D\n",
    "import seaborn as sns\n",
    "from scipy.stats import wilcoxon\n",
    "from collections import defaultdict\n",
    "\n",
    "sys.path.append('..')\n",
    "sys.path.append('../..')\n",
    "\n",
    "from constants import base_model_name_mapping, BASE_PATH_PROJECT, experiment_with_probe_type_order_list, experiment_order_list\n",
    "from helper import style_multimodel_heatmap, init_plotting_params, save_or_show"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "4ca097eb-1d2d-475e-bb5c-220c16915e91",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{\n",
      "  \"agg.path.chunksize\": 0,\n",
      "  \"axes.labelsize\": 13.0,\n",
      "  \"axes.titlesize\": 14.0,\n",
      "  \"axes3d.trackballsize\": 0.667,\n",
      "  \"boxplot.flierprops.markersize\": 6.0,\n",
      "  \"boxplot.meanprops.markersize\": 6.0,\n",
      "  \"errorbar.capsize\": 0.0,\n",
      "  \"figure.figsize\": [\n",
      "    6.4,\n",
      "    4.8\n",
      "  ],\n",
      "  \"figure.labelsize\": \"large\",\n",
      "  \"figure.titlesize\": \"large\",\n",
      "  \"font.cursive\": [\n",
      "    \"Apple Chancery\",\n",
      "    \"Textile\",\n",
      "    \"Zapf Chancery\",\n",
      "    \"Sand\",\n",
      "    \"Script MT\",\n",
      "    \"Felipa\",\n",
      "    \"Comic Neue\",\n",
      "    \"Comic Sans MS\",\n",
      "    \"cursive\"\n",
      "  ],\n",
      "  \"font.family\": [\n",
      "    \"sans-serif\"\n",
      "  ],\n",
      "  \"font.fantasy\": [\n",
      "    \"Chicago\",\n",
      "    \"Charcoal\",\n",
      "    \"Impact\",\n",
      "    \"Western\",\n",
      "    \"xkcd script\",\n",
      "    \"fantasy\"\n",
      "  ],\n",
      "  \"font.monospace\": [\n",
      "    \"DejaVu Sans Mono\",\n",
      "    \"Bitstream Vera Sans Mono\",\n",
      "    \"Computer Modern Typewriter\",\n",
      "    \"Andale Mono\",\n",
      "    \"Nimbus Mono L\",\n",
      "    \"Courier New\",\n",
      "    \"Courier\",\n",
      "    \"Fixed\",\n",
      "    \"Terminal\",\n",
      "    \"monospace\"\n",
      "  ],\n",
      "  \"font.sans-serif\": [\n",
      "    \"DejaVu Sans\",\n",
      "    \"Bitstream Vera Sans\",\n",
      "    \"Computer Modern Sans Serif\",\n",
      "    \"Lucida Grande\",\n",
      "    \"Verdana\",\n",
      "    \"Geneva\",\n",
      "    \"Lucid\",\n",
      "    \"Arial\",\n",
      "    \"Helvetica\",\n",
      "    \"Avant Garde\",\n",
      "    \"sans-serif\"\n",
      "  ],\n",
      "  \"font.serif\": [\n",
      "    \"DejaVu Serif\",\n",
      "    \"Bitstream Vera Serif\",\n",
      "    \"Computer Modern Roman\",\n",
      "    \"New Century Schoolbook\",\n",
      "    \"Century Schoolbook L\",\n",
      "    \"Utopia\",\n",
      "    \"ITC Bookman\",\n",
      "    \"Bookman\",\n",
      "    \"Nimbus Roman No9 L\",\n",
      "    \"Times New Roman\",\n",
      "    \"Times\",\n",
      "    \"Palatino\",\n",
      "    \"Charter\",\n",
      "    \"serif\"\n",
      "  ],\n",
      "  \"font.size\": 10.0,\n",
      "  \"font.stretch\": \"normal\",\n",
      "  \"font.style\": \"normal\",\n",
      "  \"font.variant\": \"normal\",\n",
      "  \"font.weight\": \"normal\",\n",
      "  \"legend.fontsize\": 12.0,\n",
      "  \"legend.title_fontsize\": 13.0,\n",
      "  \"lines.markersize\": 6.0,\n",
      "  \"mathtext.fontset\": \"dejavusans\",\n",
      "  \"pdf.fonttype\": 42,\n",
      "  \"pdf.use14corefonts\": false,\n",
      "  \"pgf.rcfonts\": true,\n",
      "  \"ps.fonttype\": 42,\n",
      "  \"ps.papersize\": \"letter\",\n",
      "  \"svg.fonttype\": \"path\",\n",
      "  \"xtick.labelsize\": 12.0,\n",
      "  \"xtick.major.size\": 3.5,\n",
      "  \"xtick.minor.size\": 2.0,\n",
      "  \"ytick.labelsize\": 12.0,\n",
      "  \"ytick.major.size\": 3.5,\n",
      "  \"ytick.minor.size\": 2.0\n",
      "}\n"
     ]
    }
   ],
   "source": [
    "init_plotting_params()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "e1f93492-a1b6-4b56-8e0f-2c4af922cca3",
   "metadata": {},
   "outputs": [],
   "source": [
    "SAVE = 'both'\n",
    "\n",
    "base_storing_path = BASE_PATH_PROJECT / 'results_iclr_exp/plots'\n",
    "if SAVE:\n",
    "    base_storing_path.mkdir(parents=True, exist_ok=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "aa0308b8-cc24-4175-a63f-be8bccd1398c",
   "metadata": {},
   "outputs": [],
   "source": [
    "all_runs_path = BASE_PATH_PROJECT / 'results_iclr_exp/aggregated/all_runs_v11.pkl'\n",
    "all_runs = pd.read_pickle(all_runs_path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "a39cf79d-e529-4af8-a6fa-775caf6537ca",
   "metadata": {},
   "outputs": [],
   "source": [
    "all_runs = all_runs[~all_runs['dataset'].isin(['imagenet-subset-50k', 'wds/imagenet1k'])].reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "7943c2d0-3055-461c-a27b-a098ff6517d6",
   "metadata": {},
   "outputs": [],
   "source": [
    "check_runs = all_runs[['dataset', 'Experiment']].value_counts().sort_index().reset_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "3a6c8879-75dc-4e0a-98d8-9589f2bcd20a",
   "metadata": {},
   "outputs": [],
   "source": [
    "check_runs_pivot = pd.pivot(\n",
    "    check_runs,\n",
    "    index = 'dataset',\n",
    "    columns = 'Experiment',\n",
    "    values= 'count'\n",
    ").fillna(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "5caac2b7-5450-45cd-ac1c-dd7bc099c296",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Storing experiment\n",
      "(19, 10)\n"
     ]
    }
   ],
   "source": [
    "check_runs_pivot = check_runs_pivot[experiment_with_probe_type_order_list].sort_index()\n",
    "if SAVE:\n",
    "    fn = base_storing_path / \"per_experiment_eval_count\" / 'check_runs_pivot_v2.csv'\n",
    "    fn.parent.mkdir(parents=True, exist_ok=True)\n",
    "    check_runs_pivot.to_csv(fn)\n",
    "    print(f\"Storing experiment\")\n",
    "\n",
    "print(check_runs_pivot.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "330900ae-844b-4ead-93da-f7cb542735da",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<style type=\"text/css\">\n",
       "#T_228e8_row0_col0, #T_228e8_row0_col1, #T_228e8_row0_col2, #T_228e8_row0_col5, #T_228e8_row0_col6, #T_228e8_row0_col9, #T_228e8_row1_col0, #T_228e8_row1_col1, #T_228e8_row1_col2, #T_228e8_row1_col5, #T_228e8_row1_col6, #T_228e8_row1_col9, #T_228e8_row2_col0, #T_228e8_row2_col1, #T_228e8_row2_col2, #T_228e8_row2_col5, #T_228e8_row2_col6, #T_228e8_row2_col9, #T_228e8_row3_col0, #T_228e8_row3_col1, #T_228e8_row3_col2, #T_228e8_row3_col5, #T_228e8_row3_col6, #T_228e8_row3_col9, #T_228e8_row4_col0, #T_228e8_row4_col1, #T_228e8_row4_col2, #T_228e8_row4_col5, #T_228e8_row4_col6, #T_228e8_row4_col9, #T_228e8_row5_col0, #T_228e8_row5_col1, #T_228e8_row5_col2, #T_228e8_row5_col5, #T_228e8_row5_col6, #T_228e8_row5_col9, #T_228e8_row6_col0, #T_228e8_row6_col1, #T_228e8_row6_col2, #T_228e8_row6_col5, #T_228e8_row6_col6, #T_228e8_row6_col9, #T_228e8_row7_col0, #T_228e8_row7_col1, #T_228e8_row7_col2, #T_228e8_row7_col5, #T_228e8_row7_col6, #T_228e8_row7_col9, #T_228e8_row8_col0, #T_228e8_row8_col1, #T_228e8_row8_col2, #T_228e8_row8_col5, #T_228e8_row8_col6, #T_228e8_row8_col9, #T_228e8_row9_col0, #T_228e8_row9_col1, #T_228e8_row9_col2, #T_228e8_row9_col5, #T_228e8_row9_col6, #T_228e8_row9_col9, #T_228e8_row10_col0, #T_228e8_row10_col1, #T_228e8_row10_col2, #T_228e8_row10_col5, #T_228e8_row10_col6, #T_228e8_row10_col9, #T_228e8_row11_col0, #T_228e8_row11_col1, #T_228e8_row11_col2, #T_228e8_row11_col5, #T_228e8_row11_col6, #T_228e8_row11_col9, #T_228e8_row12_col0, #T_228e8_row12_col1, #T_228e8_row12_col2, #T_228e8_row12_col5, #T_228e8_row12_col6, #T_228e8_row12_col9, #T_228e8_row13_col0, #T_228e8_row13_col1, #T_228e8_row13_col2, #T_228e8_row13_col5, #T_228e8_row13_col6, #T_228e8_row13_col9, #T_228e8_row14_col0, #T_228e8_row14_col1, #T_228e8_row14_col2, #T_228e8_row14_col5, #T_228e8_row14_col6, #T_228e8_row14_col9, #T_228e8_row15_col0, #T_228e8_row15_col1, #T_228e8_row15_col2, #T_228e8_row15_col5, #T_228e8_row15_col6, #T_228e8_row15_col9, #T_228e8_row16_col0, #T_228e8_row16_col1, #T_228e8_row16_col2, #T_228e8_row16_col5, #T_228e8_row16_col6, #T_228e8_row16_col9, #T_228e8_row17_col0, #T_228e8_row17_col1, #T_228e8_row17_col2, #T_228e8_row17_col5, #T_228e8_row17_col6, #T_228e8_row17_col9, #T_228e8_row18_col0, #T_228e8_row18_col1, #T_228e8_row18_col2, #T_228e8_row18_col5, #T_228e8_row18_col6, #T_228e8_row18_col9 {\n",
       "  background-color: #fff5f0;\n",
       "  color: #000000;\n",
       "}\n",
       "#T_228e8_row0_col3, #T_228e8_row0_col4, #T_228e8_row1_col3, #T_228e8_row1_col4, #T_228e8_row2_col3, #T_228e8_row2_col4, #T_228e8_row3_col3, #T_228e8_row3_col4, #T_228e8_row4_col3, #T_228e8_row4_col4, #T_228e8_row5_col3, #T_228e8_row5_col4, #T_228e8_row6_col3, #T_228e8_row6_col4, #T_228e8_row7_col3, #T_228e8_row7_col4, #T_228e8_row8_col3, #T_228e8_row8_col4, #T_228e8_row9_col3, #T_228e8_row9_col4, #T_228e8_row10_col3, #T_228e8_row10_col4, #T_228e8_row11_col3, #T_228e8_row11_col4, #T_228e8_row12_col3, #T_228e8_row12_col4, #T_228e8_row13_col3, #T_228e8_row13_col4, #T_228e8_row14_col3, #T_228e8_row14_col4, #T_228e8_row15_col3, #T_228e8_row15_col4, #T_228e8_row15_col7, #T_228e8_row15_col8, #T_228e8_row16_col3, #T_228e8_row16_col4, #T_228e8_row17_col3, #T_228e8_row17_col4, #T_228e8_row18_col3, #T_228e8_row18_col4 {\n",
       "  background-color: #67000d;\n",
       "  color: #f1f1f1;\n",
       "}\n",
       "#T_228e8_row0_col7, #T_228e8_row0_col8, #T_228e8_row1_col7, #T_228e8_row1_col8, #T_228e8_row2_col7, #T_228e8_row2_col8, #T_228e8_row3_col7, #T_228e8_row3_col8, #T_228e8_row4_col7, #T_228e8_row4_col8, #T_228e8_row5_col7, #T_228e8_row5_col8, #T_228e8_row6_col7, #T_228e8_row6_col8, #T_228e8_row7_col7, #T_228e8_row7_col8, #T_228e8_row8_col7, #T_228e8_row8_col8, #T_228e8_row9_col7, #T_228e8_row9_col8, #T_228e8_row10_col7, #T_228e8_row10_col8, #T_228e8_row11_col7, #T_228e8_row11_col8, #T_228e8_row12_col7, #T_228e8_row12_col8, #T_228e8_row13_col7, #T_228e8_row13_col8, #T_228e8_row14_col7, #T_228e8_row14_col8, #T_228e8_row16_col7, #T_228e8_row16_col8, #T_228e8_row17_col7, #T_228e8_row17_col8, #T_228e8_row18_col7, #T_228e8_row18_col8 {\n",
       "  background-color: #b11218;\n",
       "  color: #f1f1f1;\n",
       "}\n",
       "</style>\n",
       "<table id=\"T_228e8\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th class=\"index_name level0\" >Experiment</th>\n",
       "      <th id=\"T_228e8_level0_col0\" class=\"col_heading level0 col0\" >CLS last layer</th>\n",
       "      <th id=\"T_228e8_level0_col1\" class=\"col_heading level0 col1\" >All tokens last layer (attentive)</th>\n",
       "      <th id=\"T_228e8_level0_col2\" class=\"col_heading level0 col2\" >CLS+AP last layer (linear)</th>\n",
       "      <th id=\"T_228e8_level0_col3\" class=\"col_heading level0 col3\" >CLS+AP layers from middle & last blocks (linear)</th>\n",
       "      <th id=\"T_228e8_level0_col4\" class=\"col_heading level0 col4\" >CLS+AP layers from quarterly blocks (linear)</th>\n",
       "      <th id=\"T_228e8_level0_col5\" class=\"col_heading level0 col5\" >CLS+AP layers from all blocks (linear)</th>\n",
       "      <th id=\"T_228e8_level0_col6\" class=\"col_heading level0 col6\" >CLS+AP last layer (attentive)</th>\n",
       "      <th id=\"T_228e8_level0_col7\" class=\"col_heading level0 col7\" >CLS+AP layers from middle & last blocks (attentive)</th>\n",
       "      <th id=\"T_228e8_level0_col8\" class=\"col_heading level0 col8\" >CLS+AP layers from quarterly blocks (attentive)</th>\n",
       "      <th id=\"T_228e8_level0_col9\" class=\"col_heading level0 col9\" >CLS+AP layers from all blocks (attentive)</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th class=\"index_name level0\" >dataset</th>\n",
       "      <th class=\"blank col0\" >&nbsp;</th>\n",
       "      <th class=\"blank col1\" >&nbsp;</th>\n",
       "      <th class=\"blank col2\" >&nbsp;</th>\n",
       "      <th class=\"blank col3\" >&nbsp;</th>\n",
       "      <th class=\"blank col4\" >&nbsp;</th>\n",
       "      <th class=\"blank col5\" >&nbsp;</th>\n",
       "      <th class=\"blank col6\" >&nbsp;</th>\n",
       "      <th class=\"blank col7\" >&nbsp;</th>\n",
       "      <th class=\"blank col8\" >&nbsp;</th>\n",
       "      <th class=\"blank col9\" >&nbsp;</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th id=\"T_228e8_level0_row0\" class=\"row_heading level0 row0\" >wds/cars</th>\n",
       "      <td id=\"T_228e8_row0_col0\" class=\"data row0 col0\" >9</td>\n",
       "      <td id=\"T_228e8_row0_col1\" class=\"data row0 col1\" >9</td>\n",
       "      <td id=\"T_228e8_row0_col2\" class=\"data row0 col2\" >9</td>\n",
       "      <td id=\"T_228e8_row0_col3\" class=\"data row0 col3\" >3</td>\n",
       "      <td id=\"T_228e8_row0_col4\" class=\"data row0 col4\" >3</td>\n",
       "      <td id=\"T_228e8_row0_col5\" class=\"data row0 col5\" >9</td>\n",
       "      <td id=\"T_228e8_row0_col6\" class=\"data row0 col6\" >9</td>\n",
       "      <td id=\"T_228e8_row0_col7\" class=\"data row0 col7\" >4</td>\n",
       "      <td id=\"T_228e8_row0_col8\" class=\"data row0 col8\" >4</td>\n",
       "      <td id=\"T_228e8_row0_col9\" class=\"data row0 col9\" >9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_228e8_level0_row1\" class=\"row_heading level0 row1\" >wds/country211</th>\n",
       "      <td id=\"T_228e8_row1_col0\" class=\"data row1 col0\" >9</td>\n",
       "      <td id=\"T_228e8_row1_col1\" class=\"data row1 col1\" >9</td>\n",
       "      <td id=\"T_228e8_row1_col2\" class=\"data row1 col2\" >9</td>\n",
       "      <td id=\"T_228e8_row1_col3\" class=\"data row1 col3\" >3</td>\n",
       "      <td id=\"T_228e8_row1_col4\" class=\"data row1 col4\" >3</td>\n",
       "      <td id=\"T_228e8_row1_col5\" class=\"data row1 col5\" >9</td>\n",
       "      <td id=\"T_228e8_row1_col6\" class=\"data row1 col6\" >9</td>\n",
       "      <td id=\"T_228e8_row1_col7\" class=\"data row1 col7\" >4</td>\n",
       "      <td id=\"T_228e8_row1_col8\" class=\"data row1 col8\" >4</td>\n",
       "      <td id=\"T_228e8_row1_col9\" class=\"data row1 col9\" >9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_228e8_level0_row2\" class=\"row_heading level0 row2\" >wds/fer2013</th>\n",
       "      <td id=\"T_228e8_row2_col0\" class=\"data row2 col0\" >9</td>\n",
       "      <td id=\"T_228e8_row2_col1\" class=\"data row2 col1\" >9</td>\n",
       "      <td id=\"T_228e8_row2_col2\" class=\"data row2 col2\" >9</td>\n",
       "      <td id=\"T_228e8_row2_col3\" class=\"data row2 col3\" >3</td>\n",
       "      <td id=\"T_228e8_row2_col4\" class=\"data row2 col4\" >3</td>\n",
       "      <td id=\"T_228e8_row2_col5\" class=\"data row2 col5\" >9</td>\n",
       "      <td id=\"T_228e8_row2_col6\" class=\"data row2 col6\" >9</td>\n",
       "      <td id=\"T_228e8_row2_col7\" class=\"data row2 col7\" >4</td>\n",
       "      <td id=\"T_228e8_row2_col8\" class=\"data row2 col8\" >4</td>\n",
       "      <td id=\"T_228e8_row2_col9\" class=\"data row2 col9\" >9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_228e8_level0_row3\" class=\"row_heading level0 row3\" >wds/fgvc_aircraft</th>\n",
       "      <td id=\"T_228e8_row3_col0\" class=\"data row3 col0\" >9</td>\n",
       "      <td id=\"T_228e8_row3_col1\" class=\"data row3 col1\" >9</td>\n",
       "      <td id=\"T_228e8_row3_col2\" class=\"data row3 col2\" >9</td>\n",
       "      <td id=\"T_228e8_row3_col3\" class=\"data row3 col3\" >3</td>\n",
       "      <td id=\"T_228e8_row3_col4\" class=\"data row3 col4\" >3</td>\n",
       "      <td id=\"T_228e8_row3_col5\" class=\"data row3 col5\" >9</td>\n",
       "      <td id=\"T_228e8_row3_col6\" class=\"data row3 col6\" >9</td>\n",
       "      <td id=\"T_228e8_row3_col7\" class=\"data row3 col7\" >4</td>\n",
       "      <td id=\"T_228e8_row3_col8\" class=\"data row3 col8\" >4</td>\n",
       "      <td id=\"T_228e8_row3_col9\" class=\"data row3 col9\" >9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_228e8_level0_row4\" class=\"row_heading level0 row4\" >wds/gtsrb</th>\n",
       "      <td id=\"T_228e8_row4_col0\" class=\"data row4 col0\" >9</td>\n",
       "      <td id=\"T_228e8_row4_col1\" class=\"data row4 col1\" >9</td>\n",
       "      <td id=\"T_228e8_row4_col2\" class=\"data row4 col2\" >9</td>\n",
       "      <td id=\"T_228e8_row4_col3\" class=\"data row4 col3\" >3</td>\n",
       "      <td id=\"T_228e8_row4_col4\" class=\"data row4 col4\" >3</td>\n",
       "      <td id=\"T_228e8_row4_col5\" class=\"data row4 col5\" >9</td>\n",
       "      <td id=\"T_228e8_row4_col6\" class=\"data row4 col6\" >9</td>\n",
       "      <td id=\"T_228e8_row4_col7\" class=\"data row4 col7\" >4</td>\n",
       "      <td id=\"T_228e8_row4_col8\" class=\"data row4 col8\" >4</td>\n",
       "      <td id=\"T_228e8_row4_col9\" class=\"data row4 col9\" >9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_228e8_level0_row5\" class=\"row_heading level0 row5\" >wds/stl10</th>\n",
       "      <td id=\"T_228e8_row5_col0\" class=\"data row5 col0\" >9</td>\n",
       "      <td id=\"T_228e8_row5_col1\" class=\"data row5 col1\" >9</td>\n",
       "      <td id=\"T_228e8_row5_col2\" class=\"data row5 col2\" >9</td>\n",
       "      <td id=\"T_228e8_row5_col3\" class=\"data row5 col3\" >3</td>\n",
       "      <td id=\"T_228e8_row5_col4\" class=\"data row5 col4\" >3</td>\n",
       "      <td id=\"T_228e8_row5_col5\" class=\"data row5 col5\" >9</td>\n",
       "      <td id=\"T_228e8_row5_col6\" class=\"data row5 col6\" >9</td>\n",
       "      <td id=\"T_228e8_row5_col7\" class=\"data row5 col7\" >4</td>\n",
       "      <td id=\"T_228e8_row5_col8\" class=\"data row5 col8\" >4</td>\n",
       "      <td id=\"T_228e8_row5_col9\" class=\"data row5 col9\" >9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_228e8_level0_row6\" class=\"row_heading level0 row6\" >wds/voc2007</th>\n",
       "      <td id=\"T_228e8_row6_col0\" class=\"data row6 col0\" >9</td>\n",
       "      <td id=\"T_228e8_row6_col1\" class=\"data row6 col1\" >9</td>\n",
       "      <td id=\"T_228e8_row6_col2\" class=\"data row6 col2\" >9</td>\n",
       "      <td id=\"T_228e8_row6_col3\" class=\"data row6 col3\" >3</td>\n",
       "      <td id=\"T_228e8_row6_col4\" class=\"data row6 col4\" >3</td>\n",
       "      <td id=\"T_228e8_row6_col5\" class=\"data row6 col5\" >9</td>\n",
       "      <td id=\"T_228e8_row6_col6\" class=\"data row6 col6\" >9</td>\n",
       "      <td id=\"T_228e8_row6_col7\" class=\"data row6 col7\" >4</td>\n",
       "      <td id=\"T_228e8_row6_col8\" class=\"data row6 col8\" >4</td>\n",
       "      <td id=\"T_228e8_row6_col9\" class=\"data row6 col9\" >9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_228e8_level0_row7\" class=\"row_heading level0 row7\" >wds/vtab/caltech101</th>\n",
       "      <td id=\"T_228e8_row7_col0\" class=\"data row7 col0\" >9</td>\n",
       "      <td id=\"T_228e8_row7_col1\" class=\"data row7 col1\" >9</td>\n",
       "      <td id=\"T_228e8_row7_col2\" class=\"data row7 col2\" >9</td>\n",
       "      <td id=\"T_228e8_row7_col3\" class=\"data row7 col3\" >3</td>\n",
       "      <td id=\"T_228e8_row7_col4\" class=\"data row7 col4\" >3</td>\n",
       "      <td id=\"T_228e8_row7_col5\" class=\"data row7 col5\" >9</td>\n",
       "      <td id=\"T_228e8_row7_col6\" class=\"data row7 col6\" >9</td>\n",
       "      <td id=\"T_228e8_row7_col7\" class=\"data row7 col7\" >4</td>\n",
       "      <td id=\"T_228e8_row7_col8\" class=\"data row7 col8\" >4</td>\n",
       "      <td id=\"T_228e8_row7_col9\" class=\"data row7 col9\" >9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_228e8_level0_row8\" class=\"row_heading level0 row8\" >wds/vtab/cifar10</th>\n",
       "      <td id=\"T_228e8_row8_col0\" class=\"data row8 col0\" >9</td>\n",
       "      <td id=\"T_228e8_row8_col1\" class=\"data row8 col1\" >9</td>\n",
       "      <td id=\"T_228e8_row8_col2\" class=\"data row8 col2\" >9</td>\n",
       "      <td id=\"T_228e8_row8_col3\" class=\"data row8 col3\" >3</td>\n",
       "      <td id=\"T_228e8_row8_col4\" class=\"data row8 col4\" >3</td>\n",
       "      <td id=\"T_228e8_row8_col5\" class=\"data row8 col5\" >9</td>\n",
       "      <td id=\"T_228e8_row8_col6\" class=\"data row8 col6\" >9</td>\n",
       "      <td id=\"T_228e8_row8_col7\" class=\"data row8 col7\" >4</td>\n",
       "      <td id=\"T_228e8_row8_col8\" class=\"data row8 col8\" >4</td>\n",
       "      <td id=\"T_228e8_row8_col9\" class=\"data row8 col9\" >9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_228e8_level0_row9\" class=\"row_heading level0 row9\" >wds/vtab/cifar100</th>\n",
       "      <td id=\"T_228e8_row9_col0\" class=\"data row9 col0\" >9</td>\n",
       "      <td id=\"T_228e8_row9_col1\" class=\"data row9 col1\" >9</td>\n",
       "      <td id=\"T_228e8_row9_col2\" class=\"data row9 col2\" >9</td>\n",
       "      <td id=\"T_228e8_row9_col3\" class=\"data row9 col3\" >3</td>\n",
       "      <td id=\"T_228e8_row9_col4\" class=\"data row9 col4\" >3</td>\n",
       "      <td id=\"T_228e8_row9_col5\" class=\"data row9 col5\" >9</td>\n",
       "      <td id=\"T_228e8_row9_col6\" class=\"data row9 col6\" >9</td>\n",
       "      <td id=\"T_228e8_row9_col7\" class=\"data row9 col7\" >4</td>\n",
       "      <td id=\"T_228e8_row9_col8\" class=\"data row9 col8\" >4</td>\n",
       "      <td id=\"T_228e8_row9_col9\" class=\"data row9 col9\" >9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_228e8_level0_row10\" class=\"row_heading level0 row10\" >wds/vtab/diabetic_retinopathy</th>\n",
       "      <td id=\"T_228e8_row10_col0\" class=\"data row10 col0\" >9</td>\n",
       "      <td id=\"T_228e8_row10_col1\" class=\"data row10 col1\" >9</td>\n",
       "      <td id=\"T_228e8_row10_col2\" class=\"data row10 col2\" >9</td>\n",
       "      <td id=\"T_228e8_row10_col3\" class=\"data row10 col3\" >3</td>\n",
       "      <td id=\"T_228e8_row10_col4\" class=\"data row10 col4\" >3</td>\n",
       "      <td id=\"T_228e8_row10_col5\" class=\"data row10 col5\" >9</td>\n",
       "      <td id=\"T_228e8_row10_col6\" class=\"data row10 col6\" >9</td>\n",
       "      <td id=\"T_228e8_row10_col7\" class=\"data row10 col7\" >4</td>\n",
       "      <td id=\"T_228e8_row10_col8\" class=\"data row10 col8\" >4</td>\n",
       "      <td id=\"T_228e8_row10_col9\" class=\"data row10 col9\" >9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_228e8_level0_row11\" class=\"row_heading level0 row11\" >wds/vtab/dmlab</th>\n",
       "      <td id=\"T_228e8_row11_col0\" class=\"data row11 col0\" >9</td>\n",
       "      <td id=\"T_228e8_row11_col1\" class=\"data row11 col1\" >9</td>\n",
       "      <td id=\"T_228e8_row11_col2\" class=\"data row11 col2\" >9</td>\n",
       "      <td id=\"T_228e8_row11_col3\" class=\"data row11 col3\" >3</td>\n",
       "      <td id=\"T_228e8_row11_col4\" class=\"data row11 col4\" >3</td>\n",
       "      <td id=\"T_228e8_row11_col5\" class=\"data row11 col5\" >9</td>\n",
       "      <td id=\"T_228e8_row11_col6\" class=\"data row11 col6\" >9</td>\n",
       "      <td id=\"T_228e8_row11_col7\" class=\"data row11 col7\" >4</td>\n",
       "      <td id=\"T_228e8_row11_col8\" class=\"data row11 col8\" >4</td>\n",
       "      <td id=\"T_228e8_row11_col9\" class=\"data row11 col9\" >9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_228e8_level0_row12\" class=\"row_heading level0 row12\" >wds/vtab/dtd</th>\n",
       "      <td id=\"T_228e8_row12_col0\" class=\"data row12 col0\" >9</td>\n",
       "      <td id=\"T_228e8_row12_col1\" class=\"data row12 col1\" >9</td>\n",
       "      <td id=\"T_228e8_row12_col2\" class=\"data row12 col2\" >9</td>\n",
       "      <td id=\"T_228e8_row12_col3\" class=\"data row12 col3\" >3</td>\n",
       "      <td id=\"T_228e8_row12_col4\" class=\"data row12 col4\" >3</td>\n",
       "      <td id=\"T_228e8_row12_col5\" class=\"data row12 col5\" >9</td>\n",
       "      <td id=\"T_228e8_row12_col6\" class=\"data row12 col6\" >9</td>\n",
       "      <td id=\"T_228e8_row12_col7\" class=\"data row12 col7\" >4</td>\n",
       "      <td id=\"T_228e8_row12_col8\" class=\"data row12 col8\" >4</td>\n",
       "      <td id=\"T_228e8_row12_col9\" class=\"data row12 col9\" >9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_228e8_level0_row13\" class=\"row_heading level0 row13\" >wds/vtab/eurosat</th>\n",
       "      <td id=\"T_228e8_row13_col0\" class=\"data row13 col0\" >9</td>\n",
       "      <td id=\"T_228e8_row13_col1\" class=\"data row13 col1\" >9</td>\n",
       "      <td id=\"T_228e8_row13_col2\" class=\"data row13 col2\" >9</td>\n",
       "      <td id=\"T_228e8_row13_col3\" class=\"data row13 col3\" >3</td>\n",
       "      <td id=\"T_228e8_row13_col4\" class=\"data row13 col4\" >3</td>\n",
       "      <td id=\"T_228e8_row13_col5\" class=\"data row13 col5\" >9</td>\n",
       "      <td id=\"T_228e8_row13_col6\" class=\"data row13 col6\" >9</td>\n",
       "      <td id=\"T_228e8_row13_col7\" class=\"data row13 col7\" >4</td>\n",
       "      <td id=\"T_228e8_row13_col8\" class=\"data row13 col8\" >4</td>\n",
       "      <td id=\"T_228e8_row13_col9\" class=\"data row13 col9\" >9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_228e8_level0_row14\" class=\"row_heading level0 row14\" >wds/vtab/flowers</th>\n",
       "      <td id=\"T_228e8_row14_col0\" class=\"data row14 col0\" >9</td>\n",
       "      <td id=\"T_228e8_row14_col1\" class=\"data row14 col1\" >9</td>\n",
       "      <td id=\"T_228e8_row14_col2\" class=\"data row14 col2\" >9</td>\n",
       "      <td id=\"T_228e8_row14_col3\" class=\"data row14 col3\" >3</td>\n",
       "      <td id=\"T_228e8_row14_col4\" class=\"data row14 col4\" >3</td>\n",
       "      <td id=\"T_228e8_row14_col5\" class=\"data row14 col5\" >9</td>\n",
       "      <td id=\"T_228e8_row14_col6\" class=\"data row14 col6\" >9</td>\n",
       "      <td id=\"T_228e8_row14_col7\" class=\"data row14 col7\" >4</td>\n",
       "      <td id=\"T_228e8_row14_col8\" class=\"data row14 col8\" >4</td>\n",
       "      <td id=\"T_228e8_row14_col9\" class=\"data row14 col9\" >9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_228e8_level0_row15\" class=\"row_heading level0 row15\" >wds/vtab/pcam</th>\n",
       "      <td id=\"T_228e8_row15_col0\" class=\"data row15 col0\" >9</td>\n",
       "      <td id=\"T_228e8_row15_col1\" class=\"data row15 col1\" >9</td>\n",
       "      <td id=\"T_228e8_row15_col2\" class=\"data row15 col2\" >9</td>\n",
       "      <td id=\"T_228e8_row15_col3\" class=\"data row15 col3\" >3</td>\n",
       "      <td id=\"T_228e8_row15_col4\" class=\"data row15 col4\" >3</td>\n",
       "      <td id=\"T_228e8_row15_col5\" class=\"data row15 col5\" >9</td>\n",
       "      <td id=\"T_228e8_row15_col6\" class=\"data row15 col6\" >9</td>\n",
       "      <td id=\"T_228e8_row15_col7\" class=\"data row15 col7\" >3</td>\n",
       "      <td id=\"T_228e8_row15_col8\" class=\"data row15 col8\" >3</td>\n",
       "      <td id=\"T_228e8_row15_col9\" class=\"data row15 col9\" >9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_228e8_level0_row16\" class=\"row_heading level0 row16\" >wds/vtab/pets</th>\n",
       "      <td id=\"T_228e8_row16_col0\" class=\"data row16 col0\" >9</td>\n",
       "      <td id=\"T_228e8_row16_col1\" class=\"data row16 col1\" >9</td>\n",
       "      <td id=\"T_228e8_row16_col2\" class=\"data row16 col2\" >9</td>\n",
       "      <td id=\"T_228e8_row16_col3\" class=\"data row16 col3\" >3</td>\n",
       "      <td id=\"T_228e8_row16_col4\" class=\"data row16 col4\" >3</td>\n",
       "      <td id=\"T_228e8_row16_col5\" class=\"data row16 col5\" >9</td>\n",
       "      <td id=\"T_228e8_row16_col6\" class=\"data row16 col6\" >9</td>\n",
       "      <td id=\"T_228e8_row16_col7\" class=\"data row16 col7\" >4</td>\n",
       "      <td id=\"T_228e8_row16_col8\" class=\"data row16 col8\" >4</td>\n",
       "      <td id=\"T_228e8_row16_col9\" class=\"data row16 col9\" >9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_228e8_level0_row17\" class=\"row_heading level0 row17\" >wds/vtab/resisc45</th>\n",
       "      <td id=\"T_228e8_row17_col0\" class=\"data row17 col0\" >9</td>\n",
       "      <td id=\"T_228e8_row17_col1\" class=\"data row17 col1\" >9</td>\n",
       "      <td id=\"T_228e8_row17_col2\" class=\"data row17 col2\" >9</td>\n",
       "      <td id=\"T_228e8_row17_col3\" class=\"data row17 col3\" >3</td>\n",
       "      <td id=\"T_228e8_row17_col4\" class=\"data row17 col4\" >3</td>\n",
       "      <td id=\"T_228e8_row17_col5\" class=\"data row17 col5\" >9</td>\n",
       "      <td id=\"T_228e8_row17_col6\" class=\"data row17 col6\" >9</td>\n",
       "      <td id=\"T_228e8_row17_col7\" class=\"data row17 col7\" >4</td>\n",
       "      <td id=\"T_228e8_row17_col8\" class=\"data row17 col8\" >4</td>\n",
       "      <td id=\"T_228e8_row17_col9\" class=\"data row17 col9\" >9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_228e8_level0_row18\" class=\"row_heading level0 row18\" >wds/vtab/svhn</th>\n",
       "      <td id=\"T_228e8_row18_col0\" class=\"data row18 col0\" >9</td>\n",
       "      <td id=\"T_228e8_row18_col1\" class=\"data row18 col1\" >9</td>\n",
       "      <td id=\"T_228e8_row18_col2\" class=\"data row18 col2\" >9</td>\n",
       "      <td id=\"T_228e8_row18_col3\" class=\"data row18 col3\" >3</td>\n",
       "      <td id=\"T_228e8_row18_col4\" class=\"data row18 col4\" >3</td>\n",
       "      <td id=\"T_228e8_row18_col5\" class=\"data row18 col5\" >9</td>\n",
       "      <td id=\"T_228e8_row18_col6\" class=\"data row18 col6\" >9</td>\n",
       "      <td id=\"T_228e8_row18_col7\" class=\"data row18 col7\" >4</td>\n",
       "      <td id=\"T_228e8_row18_col8\" class=\"data row18 col8\" >4</td>\n",
       "      <td id=\"T_228e8_row18_col9\" class=\"data row18 col9\" >9</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n"
      ],
      "text/plain": [
       "<pandas.io.formats.style.Styler at 0x7f7c939ecf70>"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "check_runs_pivot_styled = check_runs_pivot.style.background_gradient(cmap='Reds_r', axis=None)\n",
    "check_runs_pivot_styled"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "66178303-4b7d-43de-9e56-9d82f0d0bef6",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Experiment\n",
       "CLS last layer                                         171\n",
       "All tokens last layer (attentive)                      171\n",
       "CLS+AP last layer (linear)                             171\n",
       "CLS+AP layers from middle & last blocks (linear)        57\n",
       "CLS+AP layers from quarterly blocks (linear)            57\n",
       "CLS+AP layers from all blocks (linear)                 171\n",
       "CLS+AP last layer (attentive)                          171\n",
       "CLS+AP layers from middle & last blocks (attentive)     75\n",
       "CLS+AP layers from quarterly blocks (attentive)         75\n",
       "CLS+AP layers from all blocks (attentive)              171\n",
       "dtype: int64"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "check_runs_pivot.sum(axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "b7e34011-2df2-42d6-b57e-280a5a63d256",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['OpenCLIP_ViT-B-16_openai',\n",
       " 'OpenCLIP_ViT-B-32_openai',\n",
       " 'OpenCLIP_ViT-L-14_openai',\n",
       " 'dinov2-vit-base-p14',\n",
       " 'dinov2-vit-large-p14',\n",
       " 'dinov2-vit-small-p14',\n",
       " 'vit_base_patch16_224',\n",
       " 'vit_large_patch16_224',\n",
       " 'vit_small_patch16_224']"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "selected_models = sorted(all_runs['base_model'].unique())\n",
    "selected_models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "f9960874-1c44-4f23-a09f-24f0f5c7507a",
   "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>count</th>\n",
       "      <th>mean</th>\n",
       "      <th>std</th>\n",
       "      <th>min</th>\n",
       "      <th>25%</th>\n",
       "      <th>50%</th>\n",
       "      <th>75%</th>\n",
       "      <th>max</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Experiment</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>CLS last layer</th>\n",
       "      <td>171.0</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CLS+AP last layer (linear)</th>\n",
       "      <td>171.0</td>\n",
       "      <td>0.013571</td>\n",
       "      <td>0.020470</td>\n",
       "      <td>-0.041622</td>\n",
       "      <td>0.001939</td>\n",
       "      <td>0.009500</td>\n",
       "      <td>0.019644</td>\n",
       "      <td>0.108093</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CLS+AP last layer (attentive)</th>\n",
       "      <td>171.0</td>\n",
       "      <td>0.019313</td>\n",
       "      <td>0.022690</td>\n",
       "      <td>-0.011848</td>\n",
       "      <td>0.002453</td>\n",
       "      <td>0.013988</td>\n",
       "      <td>0.028811</td>\n",
       "      <td>0.132670</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CLS+AP layers from middle &amp; last blocks (linear)</th>\n",
       "      <td>57.0</td>\n",
       "      <td>0.026868</td>\n",
       "      <td>0.043907</td>\n",
       "      <td>-0.055419</td>\n",
       "      <td>0.001400</td>\n",
       "      <td>0.017186</td>\n",
       "      <td>0.037200</td>\n",
       "      <td>0.176592</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CLS+AP layers from quarterly blocks (linear)</th>\n",
       "      <td>57.0</td>\n",
       "      <td>0.034266</td>\n",
       "      <td>0.054669</td>\n",
       "      <td>-0.106123</td>\n",
       "      <td>0.001000</td>\n",
       "      <td>0.025687</td>\n",
       "      <td>0.055783</td>\n",
       "      <td>0.221853</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CLS+AP layers from middle &amp; last blocks (attentive)</th>\n",
       "      <td>75.0</td>\n",
       "      <td>0.038069</td>\n",
       "      <td>0.043331</td>\n",
       "      <td>-0.005437</td>\n",
       "      <td>0.007155</td>\n",
       "      <td>0.026317</td>\n",
       "      <td>0.052504</td>\n",
       "      <td>0.199972</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CLS+AP layers from all blocks (linear)</th>\n",
       "      <td>171.0</td>\n",
       "      <td>0.039445</td>\n",
       "      <td>0.061809</td>\n",
       "      <td>-0.090989</td>\n",
       "      <td>0.001358</td>\n",
       "      <td>0.031507</td>\n",
       "      <td>0.060615</td>\n",
       "      <td>0.326378</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CLS+AP layers from quarterly blocks (attentive)</th>\n",
       "      <td>75.0</td>\n",
       "      <td>0.049518</td>\n",
       "      <td>0.050481</td>\n",
       "      <td>-0.001538</td>\n",
       "      <td>0.013445</td>\n",
       "      <td>0.037346</td>\n",
       "      <td>0.070147</td>\n",
       "      <td>0.235521</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>All tokens last layer (attentive)</th>\n",
       "      <td>171.0</td>\n",
       "      <td>0.055441</td>\n",
       "      <td>0.081969</td>\n",
       "      <td>-0.032447</td>\n",
       "      <td>0.001438</td>\n",
       "      <td>0.025751</td>\n",
       "      <td>0.070328</td>\n",
       "      <td>0.364606</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CLS+AP layers from all blocks (attentive)</th>\n",
       "      <td>171.0</td>\n",
       "      <td>0.057651</td>\n",
       "      <td>0.066871</td>\n",
       "      <td>-0.010529</td>\n",
       "      <td>0.009079</td>\n",
       "      <td>0.040038</td>\n",
       "      <td>0.078231</td>\n",
       "      <td>0.349661</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                    count      mean       std  \\\n",
       "Experiment                                                                      \n",
       "CLS last layer                                      171.0  0.000000  0.000000   \n",
       "CLS+AP last layer (linear)                          171.0  0.013571  0.020470   \n",
       "CLS+AP last layer (attentive)                       171.0  0.019313  0.022690   \n",
       "CLS+AP layers from middle & last blocks (linear)     57.0  0.026868  0.043907   \n",
       "CLS+AP layers from quarterly blocks (linear)         57.0  0.034266  0.054669   \n",
       "CLS+AP layers from middle & last blocks (attent...   75.0  0.038069  0.043331   \n",
       "CLS+AP layers from all blocks (linear)              171.0  0.039445  0.061809   \n",
       "CLS+AP layers from quarterly blocks (attentive)      75.0  0.049518  0.050481   \n",
       "All tokens last layer (attentive)                   171.0  0.055441  0.081969   \n",
       "CLS+AP layers from all blocks (attentive)           171.0  0.057651  0.066871   \n",
       "\n",
       "                                                         min       25%  \\\n",
       "Experiment                                                               \n",
       "CLS last layer                                      0.000000  0.000000   \n",
       "CLS+AP last layer (linear)                         -0.041622  0.001939   \n",
       "CLS+AP last layer (attentive)                      -0.011848  0.002453   \n",
       "CLS+AP layers from middle & last blocks (linear)   -0.055419  0.001400   \n",
       "CLS+AP layers from quarterly blocks (linear)       -0.106123  0.001000   \n",
       "CLS+AP layers from middle & last blocks (attent... -0.005437  0.007155   \n",
       "CLS+AP layers from all blocks (linear)             -0.090989  0.001358   \n",
       "CLS+AP layers from quarterly blocks (attentive)    -0.001538  0.013445   \n",
       "All tokens last layer (attentive)                  -0.032447  0.001438   \n",
       "CLS+AP layers from all blocks (attentive)          -0.010529  0.009079   \n",
       "\n",
       "                                                         50%       75%  \\\n",
       "Experiment                                                               \n",
       "CLS last layer                                      0.000000  0.000000   \n",
       "CLS+AP last layer (linear)                          0.009500  0.019644   \n",
       "CLS+AP last layer (attentive)                       0.013988  0.028811   \n",
       "CLS+AP layers from middle & last blocks (linear)    0.017186  0.037200   \n",
       "CLS+AP layers from quarterly blocks (linear)        0.025687  0.055783   \n",
       "CLS+AP layers from middle & last blocks (attent...  0.026317  0.052504   \n",
       "CLS+AP layers from all blocks (linear)              0.031507  0.060615   \n",
       "CLS+AP layers from quarterly blocks (attentive)     0.037346  0.070147   \n",
       "All tokens last layer (attentive)                   0.025751  0.070328   \n",
       "CLS+AP layers from all blocks (attentive)           0.040038  0.078231   \n",
       "\n",
       "                                                         max  \n",
       "Experiment                                                    \n",
       "CLS last layer                                      0.000000  \n",
       "CLS+AP last layer (linear)                          0.108093  \n",
       "CLS+AP last layer (attentive)                       0.132670  \n",
       "CLS+AP layers from middle & last blocks (linear)    0.176592  \n",
       "CLS+AP layers from quarterly blocks (linear)        0.221853  \n",
       "CLS+AP layers from middle & last blocks (attent...  0.199972  \n",
       "CLS+AP layers from all blocks (linear)              0.326378  \n",
       "CLS+AP layers from quarterly blocks (attentive)     0.235521  \n",
       "All tokens last layer (attentive)                   0.364606  \n",
       "CLS+AP layers from all blocks (attentive)           0.349661  "
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "exp_gain = all_runs[['Experiment', 'abs_perf_gain_test_lp_bal_acc1']].copy()\n",
    "exp_gain['abs_perf_gain_test_lp_bal_acc1'] = exp_gain['abs_perf_gain_test_lp_bal_acc1'].astype(float)\n",
    "exp_gain.groupby(['Experiment'])['abs_perf_gain_test_lp_bal_acc1'].describe().sort_values('mean')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a369a3d4-228a-4c5a-bee1-14e7821f661a",
   "metadata": {},
   "source": [
    "## Big table performances"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "a431899e-51c7-4d9c-ad7e-1625fccedda9",
   "metadata": {},
   "outputs": [],
   "source": [
    "check_runs_pivot = pd.pivot(\n",
    "    all_runs,\n",
    "    index = 'dataset_fmt',\n",
    "    columns = ['base_model','Experiment'],\n",
    "    values= 'test_lp_bal_acc1'\n",
    ")\n",
    "curr_col_order = list(product(selected_models, experiment_with_probe_type_order_list))\n",
    "diff = set(curr_col_order) - set(check_runs_pivot.columns.tolist())\n",
    "for col in diff:\n",
    "    check_runs_pivot.loc[:, col] = np.nan\n",
    "\n",
    "check_runs_pivot = check_runs_pivot.loc[:, curr_col_order].apply(pd.to_numeric, errors='coerce')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "b2e1029d-4d57-4a9c-b198-db43b7c41607",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Stored model='OpenCLIP_ViT-B-16_openai' performance table ...\n",
      "\n",
      "Stored model='OpenCLIP_ViT-B-32_openai' performance table ...\n",
      "\n",
      "Stored model='OpenCLIP_ViT-L-14_openai' performance table ...\n",
      "\n",
      "Stored model='dinov2-vit-base-p14' performance table ...\n",
      "\n",
      "Stored model='dinov2-vit-large-p14' performance table ...\n",
      "\n",
      "Stored model='dinov2-vit-small-p14' performance table ...\n",
      "\n",
      "Stored model='vit_base_patch16_224' performance table ...\n",
      "\n",
      "Stored model='vit_large_patch16_224' performance table ...\n",
      "\n",
      "Stored model='vit_small_patch16_224' performance table ...\n",
      "\n"
     ]
    }
   ],
   "source": [
    "color_maps = [\n",
    "    'Greys', 'Purples', 'Blues', 'Greens', 'Oranges', 'Reds',\n",
    "    'YlOrBr', 'YlOrRd', 'OrRd', 'PuRd', 'RdPu', 'BuPu',\n",
    "    'GnBu', 'PuBu', 'YlGnBu', 'PuBuGn', 'BuGn', 'YlGn'\n",
    "    ]\n",
    "for i, model in enumerate(check_runs_pivot.columns.get_level_values(0).unique()):\n",
    "    tmp = check_runs_pivot.loc[:, [(model, col) for col in experiment_with_probe_type_order_list]].copy()\n",
    "    tmp *= 100\n",
    "    tmp2 = tmp.copy()\n",
    "    for row_idx, row_data in tmp2.iterrows():\n",
    "        tmp2.loc[row_idx, row_data.index] = row_data - row_data.loc[(model, 'CLS last layer')]\n",
    "    \n",
    "    tmp.loc[\"min perf. gain\", :] = tmp2.min(skipna=True, axis=0)\n",
    "    tmp.loc[\"median perf. gain\", :] =  tmp2.median(skipna=True, axis=0)\n",
    "    tmp.loc[\"max perf. gain\", :] =  tmp2.max(skipna=True, axis=0)\n",
    "    tmp.loc[\"mean perf. gain\", :] =  tmp2.mean(skipna=True, axis=0)\n",
    "    tmp.loc[\"std perf. gain\", :] =  tmp2.std(skipna=True, axis=0)\n",
    "    \n",
    "    styled_df = style_multimodel_heatmap(tmp, color_maps=color_maps[i:(i+1)])\n",
    "    \n",
    "    if SAVE:\n",
    "        fn = base_storing_path / \"per_model_all_performances\" / f'perf_table_{model}_v2.csv'\n",
    "        fn.parent.mkdir(parents=True, exist_ok=True)\n",
    "        tmp.to_csv(fn)\n",
    "        print(f\"Stored {model=} performance table ...\")\n",
    "        print()\n",
    "    else:\n",
    "        display(styled_df)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a95bf6eb-f3cb-4f9a-a1e5-4dc7519608ab",
   "metadata": {},
   "source": [
    "## Figure 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "89c87582-d437-4f0c-bf0b-ff6d6bf7fb91",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(570, 82)"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "allowed_ds = list(set(all_runs['dataset'].unique()) - set(['imagenet-subset-50k', 'wds/imagenet1k']))\n",
    "base_runs = all_runs[all_runs['model_size'] == 'base']\n",
    "base_runs = base_runs[base_runs['dataset'].isin(allowed_ds)].reset_index(drop=True).copy()\n",
    "base_runs.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "d58414a2-8301-47e8-9374-fee7b8f115c6",
   "metadata": {},
   "outputs": [],
   "source": [
    "base_runs['abs_perf_gain_test_lp_bal_acc1'] = base_runs['abs_perf_gain_test_lp_bal_acc1'] * 100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "7611f656-7855-48fc-9bd8-5ccd1fc4e3f5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(['CLS+AP last layer', 'CLS+AP layers from all blocks',\n",
       "       'CLS+AP layers from middle & last blocks',\n",
       "       'CLS+AP layers from quarterly blocks', 'CLS last layer',\n",
       "       'All tokens last layer'], dtype=object)"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "base_runs['experiment'].unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "af7109d1-d73d-4a2e-98f3-2bb88cd9ba80",
   "metadata": {},
   "outputs": [],
   "source": [
    "curr_order = experiment_order_list[1:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "4ac259bb-aa86-4778-bf0e-3bf2b3cb1593",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(513, 82)"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "base_runs = base_runs[base_runs['experiment'].isin(curr_order)]\n",
    "base_runs.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "361fadd1-3316-4c74-8943-f91d35bea420",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "task             Experiment                                         \n",
       "attentive_probe  All tokens last layer (attentive)                      57\n",
       "                 CLS+AP last layer (attentive)                          57\n",
       "                 CLS+AP layers from all blocks (attentive)              57\n",
       "                 CLS+AP layers from middle & last blocks (attentive)    57\n",
       "                 CLS+AP layers from quarterly blocks (attentive)        57\n",
       "linear_probe     CLS+AP last layer (linear)                             57\n",
       "                 CLS+AP layers from all blocks (linear)                 57\n",
       "                 CLS+AP layers from middle & last blocks (linear)       57\n",
       "                 CLS+AP layers from quarterly blocks (linear)           57\n",
       "Name: count, dtype: int64"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "base_runs[['task', 'Experiment']].value_counts().sort_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "70e8bb19-a73e-44d3-9e3a-f607c99b477c",
   "metadata": {},
   "outputs": [],
   "source": [
    "copy_for_attentive = base_runs[base_runs['experiment']=='CLS last layer'].copy().reset_index(drop=True)\n",
    "copy_for_attentive['task'] = \"attentive_probe\"\n",
    "\n",
    "base_runs = pd.concat([base_runs, copy_for_attentive]).reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "f51bf4cd-d197-4896-9a21-fbe06b2a3191",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "task             Experiment                                         \n",
       "attentive_probe  All tokens last layer (attentive)                      57\n",
       "                 CLS+AP last layer (attentive)                          57\n",
       "                 CLS+AP layers from all blocks (attentive)              57\n",
       "                 CLS+AP layers from middle & last blocks (attentive)    57\n",
       "                 CLS+AP layers from quarterly blocks (attentive)        57\n",
       "linear_probe     CLS+AP last layer (linear)                             57\n",
       "                 CLS+AP layers from all blocks (linear)                 57\n",
       "                 CLS+AP layers from middle & last blocks (linear)       57\n",
       "                 CLS+AP layers from quarterly blocks (linear)           57\n",
       "Name: count, dtype: int64"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "base_runs[['task', 'Experiment']].value_counts().sort_index()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "51b2abcd-c763-4a69-bb93-c4f1e7d687f1",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stored image.\n"
     ]
    },
    {
     "data": {
      "image/png": "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iIiI8koul7OYQUREHFODiIiIiIiIiIwTixpEREREREREZJRY1CAiIiIiIiIio8SiBhEREREREREZJRY1iIiIiIiIiMgosahBREREREREREaJRQ0iIiIiIiIiMkosahARERERERGRUWJRg4iIiIiIiIiMEosaRERERERERGSUWNQgIiIiIiIiIqPEogYREREVe4mJiTh37hwSExMNHQoREVGhKCnffSaGDoCIiIioIEVFRWHp0qVQqVSQSqUIDAyEt7e3ocMiIiIqMCXpu489NYiIiKjYSkxMxNKlS+Hl5YU1a9bAy8sLISEhxf6uFRERlVwl7buPRQ0iIiIqtuLj46FSqeDj4wOFQgEfHx9kZmYiPj7e0KEREREViJL23ZerooZMJtP5x8TEBL/++mtBvw8iIiIiLc7OzpBKpYiIiEBcXBwiIiIgk8ng7Oxs6NCIiIgKREn77svVmBpCCLRu3RpVq1bN085TUlKwZcsWnQIjIiIiyi+5XI7AwECEhIQgMjISMpkMAQEBkMvlhg6NiIioQJS07z6JEEK8q5FUKsXmzZsxYMCAPO384cOHcHR0RExMDNq1a6dzkEXNs2fPYGdnB6VSCVtbW0OHQ0RERO+QmJiI+Ph4ODs7F9uTOiIioteVlO++XPXU8PLy0qmrirm5Oby8vFC2bNk8b0tERESkL3K5vFif0BEREb2ppHz35aqnBmliTw0iIiIiIiIiw+PsJ0RERERERERklHL1+ElOUlNTcfjwYdy8eRMAULVqVbi7u8PCwkIvwRERERERERER5UTnosbGjRsxfvx4PHnyBFlPsEgkEpQuXRqLFi2Cn5+fvmIkPSspA8YQERERERFR8aZTUePnn3+Gn58fKlWqhIkTJ6JOnToAgH///RcrV67E0KFDYWlpib59++o1WMq/qKgoLF26FCqVClKpFIGBgfD29jZ0WERERERERER5ptNAoQ0bNkR6ejr++usvrYEylUolmjVrBnNzc5w7d05vgRYlxjpQaGJiInx9feHl5QUfHx9ERERg//79CA0NZY8NIiIiIiIiMjo6DRR65coVDB48ONsLejs7OwwePBhXr17Nd3CkX/Hx8VCpVPDx8YFCoYCPjw8yMzMRHx9v6NCIiIiIiIiI8kynooaTk9Nb10skEpQrV06ngKjgODs7QyqVIiIiAnFxcYiIiIBMJoOzs7Oh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iRg/fjxkMpk+DkdEREREJRgHcSYioiz5LmqoVCr88ssvWLduHSIjI5GRkYFWrVph+PDhMDc3x7Jly/D555/j9u3bWLZsmT5iJiIiIqISTi6Xs5hBRES6FzWuXbuGdevWYePGjXjw4AEcHBwQEBAAf39/1K5dW93uo48+wsiRI/HTTz+xqFFEcF53IiIiIiIiKg50Kmq0bt0ax44dgxAC7u7uWLRoEXr16gUzM7Mc269cuTJfgZJ+cF53IiIiIiIiKi50KmpcuXIF48ePx/Dhw1GjRo13tu/QoQMOHTqky6FIj16f193HxwcREREICQmBm5sbe2wQERERERGR0dGpqHH37l2Ymprmur1cLoe7u7suhyI9ym5e98jISMTHx7OoQUREREREpKOUlBTExcXlax8KhQIWFhZ6iqjk0Kmo8d9//+HChQvo1q1btuv37NmD+vXrw8XFJT+xkZ69Pq97Vk8NzutORCURTzyIiIhIn+Li4hAQEJCvfYSEhOTqSQjSpFNR44svvkBcXFyORY1FixahUqVK2LhxY76CI/3Kmtc9JCQEkZGRkMlknNediEoknngQERGRPikUCoSEhOS4Pi4uDsHBwZg8eTIUCkWO+6C806mo8ccff2D48OE5rvf09MTq1at1DooKDud1Jyo62FvAcHjiQURERPpkYWGRq5sdCoWCN0X0TKeiRkJCApycnHJc7+joiAcPHugcFBUszutOVDSwt4Dh8MSDiIiIqHjQqahRunRp3LhxI8f1169fh42Njc5BERGVBG/rLZCbngJZ+yAiIiIiKql0Kmq0bt0aa9aswZgxY7R6bNy/fx9r165FmzZt9BIgEVFxlZveAuwpQERERESUM50HCt2zZw8aNWqECRMmwNXVFQBw9uxZLFq0CM+fP8e0adP0GScRERERERERkQadihqurq7Ytm0bBg8ejMmTJ0MikQAAhBAoW7Ystm7diiZNmug1UCIiIiIiIiKi1+lU1ACArl274s6dO4iOjsa1a9cAADVr1oSnpycsLS31FiARERERERERUXZ0LmoAgKWlJXr27KmnUIiIiIiIiIiIck9q6ACIiIiIiIiIiHShc0+NGzdu4Ntvv8Xx48fx5MkTqFQqjfUSieSt075SwUpJSUFcXJzO2ysUClhYWOgxIiIiIiIiIiL90qmocf78ebRq1QqpqamoVasWbt68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",
      "text/plain": [
       "<Figure size 1100x550 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stored image.\n"
     ]
    },
    {
     "data": {
      "image/png": "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iYiIiIiIiKjwKtRJjaSkJHTp0gU3b97EkSNHUK1aNY3tZcqUgZubG86fP6+179mzZ1GnTh0DRUpEREREREREhlZobz9JS0tD37598fvvv2P79u1o0qRJpvV69uyJn376SePWkaNHj+LmzZvo3bu3ocIlIiIiIiIiIgMrtDM1PvnkE+zduxddunTBs2fPsHXrVo3tAwcOBABMnz4d27dvR8uWLTFu3Di8fPkSixcvRs2aNTF06FBjhE5EREREREREBlBokxqXLl0CAOzbtw/79u3T2p6R1JDL5fjll18wceJEfPrpp7CyskKnTp2wdOlSrpdBREREREREVIQV2qTGiRMncl23evXqiIqKKrhgiIiIiIiIiKjQKbRrahARERERERERZYdJDSIiIiIiIiIySUxqEBEREREREZFJYlKDiIiIiIiIiEwSkxpEREREREREZJKY1CAiIiIiIiIik8SkBhERERERERGZJCY1iIiIiIiIiMgkMalBRERERERERCaJSQ0iIiIiIiIiMkkWxg6AiIiIiIiIiPImKSkJsbGx+WpDLpfD2tpaTxEZB5MaRERERERERCYmNjYWwcHB+WojNDQUlSpV0lNExsGkBhEREREREZGJkcvlCA0NzXJ7bGwsQkJCMGXKFMjl8izbMHVMahARERERERGZGGtr61zNspDL5SY/GyM7XCiUiIiIiIiIiEwSkxpEREREREREZJKY1CAiIiIiIiIik8SkBhERERERERGZJCY1iIiIiIiIiMgkMalBRERERERERCaJSQ0iIiIiIiIiMklMahARERERERGRSWJSg4iIiIiIiIhMEpMaRERERERERGSSmNQgIiIiIiIiIpPEpAYRERERERERmSQmNYiIiIiIiIjIJDGpQUREREREREQmiUkNIiIiIiIiIjJJTGoQERERERERkUliUoOIiIiIiIiITBKTGkRERERERERkkpjUICIiIiIiIiKTlKukhrm5uc4/FhYWOHbsWEG/DyIiIiIiIiIqZixyU0kIAR8fH1SoUCFPjSclJWHbtm06BUZERERERERElJ1cJTUAYOTIkRgwYECeGo+Li8OPP/6Y56CIiIiIiIiIiHKSq9tP2rVrh9KlS+e5calUinbt2sHV1TXP+xIRERERERERZSdXMzUOHjyoU+P29vY670tERERERERElB0+/YSIiIiIiIiITFKu19TIjEqlwokTJ3Dnzh0AQIUKFeDr6wtra2u9BEdERERERERElBWdkxqbN2/GxIkT8fz5cwghAAASiQROTk5YunQpAgIC9BUjEREREREREZEWnZIaP/74IwICAlC2bFlMmjQJ1apVAwD8888/WLVqFYYPHw4bGxv07dtXr8ESEREREREREWXQKakxf/58VK1aFX/88QccHBzU5V27dsWoUaPQuHFjzJ8/n0kNIiIiIiIiIiowOi0UeuPGDQwdOlQjoZHB0dERQ4cOxc2bN/MdHBERERERERFRVnRKari7u2e7XSKRoFSpUjoFRERERERERESUGzolNQICArBhwwa8fPlSa9uLFy+wYcMGDB06NN/BERERERERERFlRac1NXx8fPDTTz+hZs2aGDVqFKpWrQoAuHbtGlauXAlXV1f4+Pjg119/1divRYsW+Y+YiIiIiIiIiAg6JjXatm2r/v+pU6dCIpEAgPrRrvfu3dOoI4SARCJBWlpafmIlIiIiIiIiIlLTKamxYcMGfcdBRERERERERJQnOiU1hgwZou84iIiIiIiIiIjyRKeFQomIiIiIiIiIjE3npEZSUhJCQkLQpEkTlCpVCqVKlUKTJk0QEhKCxMREfcZIRERERERERKRFp9tPnjx5glatWuGff/6Bg4MDKlSoAODN00/OnDmDzZs34/jx43Bzc9NrsEREREREREREGXSaqTF58mRcvXoVy5Ytg0KhwMWLF3Hx4kUoFAosXboU165dw+TJk/UdKxERERERERGRmk5JjX379mH48OEYP348rKys1OVWVlaYMGEChg4din379uU7uJcvX2LWrFlo3749XFxcIJFIsHHjRq16AQEBkEgkWj9Vq1bNdwxEREREREREVDjpdPtJcnIy6tWrl+X2Bg0a4Mcff9Q5qAxxcXGYO3cuypYti9q1a+PEiRNZ1pVKpVi3bp1GmaOjY75jICIiIiIiIqLCSaekRsOGDXHx4sUst1+4cAGNGjXSOagMHh4eePjwIdzd3XH+/Hk0bNgwy7oWFhYYOHBgvvskIiIiIiIiItOgU1Jj6dKlaN26NWrWrImPP/4YFhZvmklNTcW3336LyMhIHD16NN/BSaVSuLu757p+WloaXr16BQcHh3z3TURERERERESFm05JjU8++QQlS5bE+PHjMXPmTPXTT+7cuYMXL16gYsWKmDhxosY+EolEL4mOrLx+/RoODg54/fo1nJ2d0b9/fyxatAh2dnZZ7qNSqaBSqdSvX7x4UWDxEREREREREZF+6ZTUuHPnDiQSCcqWLQsAePbsGQDAyckJTk5OSElJwd27d/UXZQ48PDwwZcoU1KtXD+np6Th06BDCwsJw+fJlnDhxQj2T5F0LFizAnDlzDBYnEREREREREemPTkmNmJgYPYeRPwsWLNB43a9fP1SuXBmfffYZduzYgX79+mW637Rp0zRmlLx48QJyubxAYyUiIiIiIiIi/dDpka6mYMKECTAzM8ORI0eyrCOVSuHg4KDxQ0RERERERESmocgmNWxsbFCyZEn1rTFEREREREREVLTkKqnh7++P48eP57nxhIQE+Pv74/Lly3neN78SEhIQFxcHNzc3g/dNRERERERERAUvV0mNI0eO4OHDh3luPDk5GUeOHMHTp0/zvG9uJSUlISEhQav8iy++gBAC7du3L7C+iYiIiIiIiMh4cr1Q6Jo1a7JdnyIzKpUKEokkz0G9bcWKFYiPj8d///0HANi3bx/+/fdfAEBwcDCeP3+OunXron///qhatSoAICoqCgcOHED79u3RrVu3fPVPRERERERERIVTrpMav/76K3799deCjCVTS5Yswb1799SvIyMjERkZCQAYOHAgnJyc0LlzZxw+fBibNm1CWloavL29MX/+fEyaNAlmZkV22RAiIiIiIiKiYi1XSY309PSCjiNLuXl87JYtWwo+ECIiIiIiIiIqVDiNgYiIiIiIiIhMUq5vPyEiIiIiIiIiTUlJSYiNjc1XG3K5HNbW1nqKqHhhUoOIiIosHmQQERFRQYuNjUVwcHC+2ggNDUWlSpX0FFHxwqQGEREVWTzIICIiooIml8sRGhqa5fbY2FiEhIRgypQpkMvlWbZBumFSg4iIiqzsDjJyc4CR0QYRERFRVqytrXN1AUQul/NCSQFgUoOIqIDw1gfjy81BBg8wiIiIiEwXkxpERAWEtz4QERERERWsfCU1Xr9+jZiYGDx9+hRCCK3tLVq0yE/zREQmjfdXEhEREREVLJ2SGq9fv8bEiROxYcMGpKamam0XQkAikSAtLS3fARIRmSreX0lEREREVLB0SmqMGzcO69evR8eOHdGqVSuULFlS33EREREREREREWVLp6TGrl270L9/f4SHh+s7HiIiIiIiIiKiXDHTZaekpCT4+fnpORQiIiIiIiIiotzTKanRoEEDREdH6zsWIiIiIiIiIqJc0ympsXDhQmzYsAHnz5/XdzxERERERERERLmi05oaa9asgaenJ95//300adIEFSpUgLm5uUYdiUSC9evX6yVIIiIiIiIiIqJ36ZTU2Lhxo/r/T506hVOnTmnVYVKDiIiIiIiIiAqSTkmN9PR0fcdBRERERERERJQnOq2pQURERERERERkbExqEBEREREREZFJytXtJ8OGDYNEIsGaNWtgbm6OYcOG5bgP19QgIiIiIiIiooKUq6TGxo0bIZFIsHLlSpibm2ssFJoVJjWIiIiIiIiIqCDlKqnx7sKgXCjUOJKSkhAbG5uvNuRyOaytrfUUEREREREREZHx6PT0EzKO2NhYBAcH56uN0NBQVKpUSU8RERERERFRYZffi6O8MEqFGZMaJkQulyM0NDTL7bGxsQgJCcGUKVMgl8uzbIOIiIiIiIqP/F4c5YVRKsx0TmqkpqZi9+7dOHPmDJ4/f651SwrX1NA/a2vrXA0mcrmcgw4REREREQHI/uIoL4ySqdMpqfHs2TO0bNkSV65cgRACEokEQggAUP8/kxpERERERETGl5uLo7wwSqbKTJedZsyYgevXr2PdunW4ffs2hBCIiorCtWvX0L9/fzRs2BBPnz7Vd6xERERERERERGo6JTX279+PwYMHY+jQoXBwcAAAmJubo0qVKti6dStsbGwwbdo0vQZKRERERERERPQ2nZIajx49QsOGDQEAFhZv7mBJSkpSb+/evTv27t2rh/CIiIiIiIiIiDKnU1LDxcUFr169AgDY29vD0tJS4xFBlpaWeP78uX4iJCIiIiIiIiLKhE5JjcqVK+Pq1atvGjAzQ926dbFx40aoVCq8fv0amzdvRoUKFfQaKBERERERERHR23RKavj7+2PHjh1QqVQAgIkTJ+LMmTNwcXGBTCbD+fPnMWHCBL0GSkRERERERET0Np0e6Tp9+nRMmjQJUqkUANCnTx9YWFhg69atMDc3R69evdC3b1+9BkpERERERERE9DadkhoSiUSd0MjQo0cP9OjRQy9BERERERERERHlRKfbT4iIiIiIiIiIjE2nmRpz587NdrtEIoGNjQ3Kli0LPz8/yGQynYIjIiIiIiIiIsqKTkmN2bNnQyKRAACEEBrb3i23tLTE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Ij799FNYWVmhU6dOWLp0KdfMIJPA1d6JiIjIUBQKBZRKZZ72yThO0fV4xdHRETKZTKd9iYiyo1NSw8nJCbdv385y+61bt2Bvb69zUG+LiYnJVb3q1asjKipKL30SGRpXeyciIiJDUCgUCAwMRHJysk77Z3cLenasrKywbt06JjaISO90Smr4+Phg7dq1GDdunNaMjUePHmHdunVo0aKFXgIkKg642jsREREZglKpRHJyMurVq6e3i5A5SUhIwMWLF6FUKpnUICK90ymp8dlnn2Hfvn2oW7cuPvnkE/UTRi5duoSlS5fi5cuXmD59uj7jJCrSuNo7ERERGZK9vT2cnJyMHQYRUb7plNSoU6cOduzYgaFDh2LKlCmQSCQAACEEXF1dsX37djRo0ECvgRIRERERERERvU2npAYAdO7cGffv30dUVBSio6MBAJUrV4a/vz9sbGz0FiARERERERERUWZ0TmoAgI2NDbp3766nUIiIiIiIiIiIcs/M2AEQEREREREREelC55kat2/fxldffYUzZ87g+fPnSE9P19gukUiyfewrEREREREREVF+6JTU+Pvvv9G8eXOoVCpUqVIFd+7cQfXq1fH06VM8evQIFStWhKenp75jJSIiokImKSkJsbGxOu8vl8thbW2tx4iIiIioONEpqTFz5kxYWVnh7NmzKFmyJGQyGZYvX45WrVph7dq1mD59Ovbs2aPvWImIiKiQiY2NRXBwsM77h4aG8nHVREREpDOdkhq//fYbRowYgSpVquDp06cA3jzOFQCCgoJw8uRJfPrpp9i7d6/+IiUiyof8Xk0GeEWZKDNyuRyhoaGZbouNjUVISAimTJkCuVye5f5EREREutIpqZGQkICKFSsCAKysrAAAr169Um9v1qwZpk2bpofwiAyLJ75FV36vJgO8okyUGWtr6xz/LuRyOf92iIiIqEDolNQoVaoUHj16BACwt7eHra0tbt68qd7+/PlzpKWl6SdCIgPiiW/Rld+ryRltEBERERFR4aFTUqNOnTo4f/68+rWvry+WL1+ORo0aIT09HStWrEDt2rX1FiSRoWR34gtwKrUp49VkIiIiIqKiR6ekxoABA/Dtt98iMTERNjY2+OKLL+Dr64uWLVsCAGxsbDB//ny9BkpkCLk58QV48ktERERERFQY6JTU6Nu3L/r27at+XbduXfzzzz/Y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vfrZS/kLthmGodq1a6tWrVqSpLy8POcxBZWUNjc3VxaLxWXhN0/SGsYfD571Rr5lfUYFP3tHesfnVFpad/NNSUnRyJEjVZqy1khITExUbGysJPc+z8zMTB08eNBlW15envLy8mSxWHT48GFn3RzndOG0MTExCg4Odus88dZn7+20xX1G3jhPKpq24L7i2vzS2gigspT3WlL4eiiZ8713MAxD2dnZprURjvTevD64k9bb/YjK6EOW9L4XTuurG2gWi8X0fqaj3O8+mWd6uUFWq0JCQpSbm+v251m4r2fmeSLlfw8KLx5c1nc5KipK77+fv7ZVab81pKK/S1JSUvTGG284R02UlPbChQsyDEO1atVy1iE8PFyRkZFF6lvWd7kgb7YR7vQzpdL7momJic5Ai7ufpzfKnTp1qlq0aOH27xKz+5vu9Ls8CmrUrVtXq1atUkZGhoKDg4sU9M0335g6MuLIkSOKjo4ust2xzfHDobDz58/r/Pnzzv8zMjIkSa+//rqee+45hYaGSpL+85//aM2aNbriiit0++23O9O/9tprysnJ0eOPP67IyEhJ0g8//KAvv/xS7dq1U9++fZ1pp06dqrNnz+qhhx5yRhQ3b96slStX6uKLL9add97pTPvRRx8pPT1d999/v5o0aSJJ2rJli5YuXaq4uDjdc889zrTvvPOOUlNTNXToUOd7npeXp8WLF8tut+vee+91pn3//fd1+PBh3XXXXc4vzN69e7Vw4UI1atTIZbG9FStW6MiRI+rWrZvi4uIkSUePHtXy5csVERGhgQMHSvpjCFfLli116623qlWrVpKkEydO6OOPP1ZoaKgGDx7srMPXX3+tffv2qWPHjmrTpo0iIiIUEBCgiRMnymq1asyYMc60K1eu1M8//6xu3bqpY8eOkvJ/JL755ptFpst8+eWX+vHHH9W5c2fddNNNzs/3lVdekSQ999xzzgZo1apV2rBhgzp06KA//elPzvds4sSJkqS///3vzmjld999p2+++Ubt27d3GY00Z84chYSE6IknnnAG0/773//q66+/1mWXXabevXs7077xxhs6f/68Hn30UdWvX1+StHHjRn3xxRe69NJLNWDAAGfaxMREZWZm6sEHH1Tjxo0lSXv27JEk/fvf/1br1q2dad99912dPHlSw4cPV7NmzSRJv/76q5YsWaLY2FiXxXxnzpyp33//XXfffbcuuugiZ74LFy5UTEyMHnjgAWfaefPmKSUlRddff71z24EDB/TBBx+oYcOGevjhh53bFy1apH379qlPnz5KSEiQlP99nDFjhiIiIjRq1Chn2iVLlmjnzp3q1auXrrrqKklSamqqpk2bppCQED311FMun+msWbPUr18/XXfddZKk9PR0TZ06VYGBgXrmmWec6T7//HP99NNP6tKli2688UZJ+XeEXnvtNUnSuHHjJOVHoQcNGqStW7fqiiuu0NVXXy0p/yI1a9YsSdK9997rbMx/+OEH/fTTT2rXrp06dOjgzMNxnjz55JNlthEvv/yyfvrpJ5WltAtNu3btdNVVV7m0EW+//XaRNmLbtm3FthHvv/++s41wjKDbtWuXkpKSirQRc+bMcbYRju/yb7/9pg8//FCNGjXS//zP/zjTzp8/X/v371f//v3Vpk0bSdLBgwc1e/Zs1atXz+UCu3jxYu3evVt33HGHLr/8cknSsWPHNH36dIWHh7tMX1y6dKm2b9+uW2+91RmYPnnypP75z3+Wq42oVauWnn/+eWfa4toIR4dh1qxZmjRpUrnaCIeacNfxdNpx08oqjuXcKRllJ/NOWVnmTv0sTnn7EYsWLSqShxlthKOTfejQIWc/whttROvWrZWSklJsP8Jxp/Htt99Wt27dnPmmp6crKSlJQUFBGjZsmPOuY0XbiMrsR7zyyivKy8szpR+xdetWLVu2TPHx8Ro0aJBzgeX33ntP6enpuv32251p9+3bp6+//lrR0dH685//7Mz3448/1sGDB7Vnzx7nD9ADBw7oX//6lxo2bKg+ffo40y5fvlxHjx7Vn/70J+c5deTIES1fvlz16tVzqe/nn3+ugwcPqkuXLs6+aWpqqpYuXaqwsDANGjTI2dfs1KmTTp06pU6dOumSSy6RlD/l/aOPPpLNZtOQIUOc+a5Zs0a7d+9Whw4d1Lp1awUGBur06dNasGCBateu7XJef/vtt9qxY4euvvpqXXHFFZLy735Pnz7d5fVK0oYNG9zuR2zbtk0zZszQtddeqx49ejjLK60f0bRpUxVUWb81imsjpPzrYUJCQrnbCMd6D4V/a2RlZWnDhg36/PPPVb9+ffXr18+Z7xdffKF9+1zXxPj999+L/Naw2+365JNPivQjjh49qokTJxbbj9i6dauuvPLKYtuIrl27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fPPNev7557V//359+OGHpaatVauWnnvuOW3ZskVLly4tNe3HH3+sbdu2acyYMbr22mtd9gUEBGj69OmKjIzUCy+8IEn6/fffVbt2bb344otF8tq5c6csFov++c9/SpKuuuqqInco69evr06dOunXX38t6yWXKDIyUsHBwW61tZIUGxsri8Xidv7z5s3Ttm3b9NJLL3laRQB+JDg4WH379tWqVat07NixIvsXLFig8PBw3X777aasqUF/Ev6IoAZQyIoVKxQXF6frr7/e9LL37dungIAARUZGlpruwoULOn78uI4fP64jR45o9erVGjdunFq2bKmOHTt6rT7bt2/X4cOHlZCQoBEjRig0NFShoaFKSEjQmjVrvFYOgKrvnnvukSR99dVXZaYdNGiQ4uPjNX78+GLX1nBYsWKFJBU75FqSIiIidMcdd2jHjh3as2ePGjVqpM6dO2vx4sVF0iYlJSkgIEADBgwotW5Hjx5VgwYNynwNDunp6Tp+/LhSU1P1yy+/6KGHHtLp06d19913u52HuzIzM/X3v/9dzzzzjPOHBYDqb/DgwcrNzS3Stp08eVJffvml+vTpo+DgYK+XS38S1QVBDaCAjIwMHTp0SO3atav0sgpeSHbs2KHHH39cmzZt0m233VbmHMYdO3aoYcOGatiwoWJiYtS1a1fl5eXpq6++UlBQkNfquHv3bknSm2++qbVr12r69OmaPXu2srKy1KNHD23ZssVrZQGo2po2baqIiAjt3bu3zLQBAQF67rnn9PPPP+vTTz8tMd327dsVERGh2NjYEtNcdtllkuQcXTFw4EBt375d27Ztc0mXlJSkzp07q1GjRiXm9d1332nDhg0aOHBgma/BoVu3bmrYsKGioqLUtm1bzZkzR7NmzdItt9zidh7uGj9+vIKDg/XEE094PW8AVdfNN9+s6OhoLViwwGX7Rx99pJycHA0ePLhSyqU/ieqChUKBAjIyMiTlD6erbI4LiYPFYlHPnj01a9asMo9t3ry53n//fUlSbm6udu7cqcmTJ+vWW2/Vd99955JvRZw+fVpS/t3Dn376SXa7XVL+xbdly5aaPHlymUPRAVQfYWFhpa7QX9DgwYM1YcIEjR8/Xr179y52CkZmZmaZ7a1jv6N97tu3rx555BElJSWpbdu2kqRt27Zp+/btpU4NPHbsmAYNGqQWLVpo9OjRbr0GSXr77bfVqlUrSfnTXz788EPdf//9Cg8PV9++fd3Opyy7du3S1KlTtXDhQlmtVq/lC6DqCwgI0J133qk333xTycnJzieWLFiwQI0aNVLXrl0rpVz6k6guCGoABdSpU0eS3O60V4TjQuJ4dGJ8fLyioqKc+1NTU3XhwgXn/2FhYc754aGhoS4r9/fo0UM33HCD2rdvr0mTJun1119Xdna2Tp486VJmw4YNFRAQ4HYdHUMdO3bs6LwASVKzZs10ww03aP369eV70QD82unTp13aqdI4RmsMHTpUn376qfr06VMkTXh4uMsjYYvjaI8dwY0GDRqoa9euWrx4sf7xj39Iyh+lUbt27RKDDGfOnFGvXr2UmZmpdevWuay1cfr0aWeH21Hvgh35a665Ru3bt3f+f9ddd+mKK67Qo48+ql69eikoKKjU9tpdjz/+uK6//nq3nhgDoPoZPHiw3nzzTS1YsEDPPPOMDh48qO+++06PPfZYufpuhdGfRE3A9BOggDp16igmJqbIsObK4LiQdO3aVR07dizyQ+Hqq69WdHS08++1114rNb+rrrpKERER+vbbbyVJ69evdzk+Ojra7eeOO8TExEhSscO5o6KilJaWVq78APivgwcPKj09XS1btnT7mMGDB6tly5Ylrq1xySWXKD09XQcOHCgxD8ew5EsvvdS57c4779SuXbu0efNmSdLixYvVtWvXYtfKyM7OVt++fbVlyxYtW7bMObrD4bXXXnNpJ6+++upSX1OtWrXUpUsXHTlyxDmkurztdWGrV6/Wv/71Lz3++ONKTk52/uXm5urcuXNKTk52jlQBUD1dddVVat26tRYuXChJWrhwoQzDqPDUE/qTqAkYqQEU0qtXL7333nvasGGDOnTo4LN6zJ8/X+fOnXP+HxcXV+YxFy5ccN5xvOyyy/Tvf//bZX95F55r166dAgMDdejQoSL7Dh8+7LVhiQCqvnnz5kmSunfv7vYxjtEaw4YN07Jly4rs79WrlxYuXKi5c+fqueeeK7I/IyNDy5YtU+vWrV2CKb1799aDDz6opKQkSflTN55++ukix+fl5WnIkCFatWqVFi9erM6dOxdJM2TIEN1www3O/91ZjC83N1fSH0OqPWmvC3IEdYobaXLo0CG1aNFCb775pkaNGlWufAH4l8GDB+v555/Xli1btGDBAsXHx5cZaC0L/UnUBAQ1gEJGjx6t+fPn6/7779fq1auLRJX37t2rlStXVspjXQsq76rTa9as0enTp52L6tWtW9dlSKEnwsPDddttt2nlypXasWOHWrduLSl/wb7169frwQcfrFD+APzD6tWr9Y9//EMtWrQo913Du+++WxMmTCj2Maz9+/fXSy+9pEmTJqlHjx4u0zzy8vL00EMPKS0tTe+8847LcZGRkerevbsWL14swzAUFBSk3r17F8l/5MiRSkpK0vTp00ucmhIXF1euIEROTo5zEb1LLrlEUvnb68JuvvnmYh9/O2LECMXGxurZZ581ZQFrAL7lCGqMHTtWmzdvdj7OuiLoT6ImIKgBFHLRRRdpwYIFGjhwoC655BINGTJEbdu2VXZ2ttavX6+PPvpIw4YNc6bfs2ePJkyYUCSfK664Qj179qyUOqanpzsXVHIs7DRt2jQFBwdrzJgxbuXhqPMvv/wiKf8u7Lp16yTJ5Y7pyy+/rFWrVunmm2/WY489Jkl66623VK9ePT3zzDNee00AqoYvvvhCO3bsUG5urn7//XetXr1a//73vxUbG6vly5fLZrOVK7+AgAA9++yzGj58eJF9QUFBWrJkibp27aobbrhBw4cPV/v27XXq1CktWLBAmzZt0t/+9jfdeeedRY4dOHCg7r77br3zzjvq3r17kUdhT5kyRe+88446dOigkJCQIovQ9enTR6GhoW6/H1L+YqMLFizQ7t27NWbMGOc6TKVZsWKFfv75Z0n5AZEtW7Y429/bb79dCQkJatasmZo1a1bk2FGjRqlRo0bFBmwAVD8tWrTQ9ddf7xzZVllPPXGgP4lqwwBQrF27dhkPPPCA0bx5cyMoKMgIDw83OnbsaCQmJhpZWVmGYRhGbGysIanYv/vuu88wDMMYOnSoERoa6pJ3586djTZt2nhUr86dO7uUY7FYjHr16hm33367sXHjRrfzKanexTULGzduNLp162aEhoYa4eHhxh133GHs2rXLo/oDqJpmz57t0g4EBQUZjRs3Nm655RZj6tSpRkZGhkv6cePGGZKM1NRU57bi2jvDMIycnBzjoosuMiQZjzzySJH9x44dM/76178aLVu2NKxWqxEZGWl069bNWL58eYn1zcjIMIKDgw1Jxocfflhk/9ChQ0tt53777bdyvR+SDJvNZlx++eXGtGnTjLy8vFKPd6ces2fPLvXY2NhYo2fPnm6VA6B6ePvttw1JxjXXXFNkn6NdKqn9Cg0NNYYOHepWOfQnUZ1YDKOYlbsAAAAAAACqOJ5+AgAAAAAA/BJBDQAAAAAA4JcIagAAAAAAAL9EUAMAAAAAAPglghoAAAAAAMAvEdQAAAAAAAB+iaAGAAAAAADwSwQ1AAAAAACAXyKoAQAAAAAA/BJBDQAAAAAA4JcIagAAAAAAAL9EUAMAAAAAAPglghoAAAAAAMAv/R+9+UzekPVW0QAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1100x550 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "tab20c = plt.cm.tab20c.colors  \n",
    "palette_list = list(tab20c[:8])\n",
    "reversed_palette = []\n",
    "for group_start in [0, 4]:\n",
    "    group = palette_list[group_start:group_start+4]\n",
    "    reversed_group = group[::-1]  # reverse the group\n",
    "    reversed_palette.extend(reversed_group)\n",
    "\n",
    "reversed_palette = [tab20c[17]] + reversed_palette\n",
    "\n",
    "for showfliers in [True, False]:\n",
    "    plt.figure(figsize=(11, 5.5))\n",
    "\n",
    "    ax = sns.boxplot(\n",
    "        base_runs,\n",
    "        x=\"base_model_fmt\",\n",
    "        y=\"abs_perf_gain_test_lp_bal_acc1\",\n",
    "        hue=\"Experiment\",\n",
    "        hue_order=experiment_with_probe_type_order_list[1:],\n",
    "        palette=reversed_palette,\n",
    "        fliersize=3,\n",
    "        showfliers=showfliers\n",
    "    )\n",
    "    ax.set_xlabel(\"\")\n",
    "    ax.set_ylabel(\"Absolute accuracy gain [pp]\")\n",
    "    sns.move_legend(ax, bbox_to_anchor=(1.05, 1), loc='upper left', title=False)\n",
    "    \n",
    "    handles, labels = ax.get_legend_handles_labels()\n",
    "    new_handles = [\n",
    "        Line2D([0], [0], marker='', color='white', linestyle='', alpha=0),\n",
    "        handles[0],\n",
    "        Line2D([0], [0], marker='', color='white', linestyle='', alpha=0),\n",
    "        Line2D([0], [0], marker='', color='white', linestyle='', alpha=0),\n",
    "        Line2D([0], [0], marker='', color='white', linestyle='', alpha=0),\n",
    "        Line2D([0], [0], marker='', color='white', linestyle='', alpha=0)\n",
    "    ]\n",
    "    new_labels = [\n",
    "        \"Attentive probe (all tokens)\",\n",
    "        \"Last layer\",\n",
    "        \"\",\n",
    "        \"\",\n",
    "        \"\",\n",
    "        \"Linear probe (CLS & AP)\"\n",
    "    ]\n",
    "    \n",
    "    prev_name = None\n",
    "    for k, (curr_handle, curr_label) in enumerate(zip(handles, labels)):\n",
    "        if k==0:\n",
    "            continue\n",
    "    \n",
    "        if k>0 and prev_name is not None and (\"linear\" in prev_name and \"attentive\" in curr_label):\n",
    "            new_handles.append(Line2D([0], [0], marker='', color='white', linestyle='', alpha=0))\n",
    "            new_labels.append(\"Attentive probe (CLS & AP)\")\n",
    "    \n",
    "        new_handles.append(curr_handle)\n",
    "        full_label = curr_label\n",
    "        curr_label = curr_label.split(\" (\")[0]\n",
    "        curr_label = curr_label.replace(\"CLS+AP l\", \"L\")\n",
    "        if curr_label == \"Layers from middle & last blocks\":\n",
    "            curr_label = \"+ middle block\"\n",
    "        elif curr_label == \"Layers from quarterly blocks\":\n",
    "            curr_label = \"+ 1/4th and 3/4th blocks\"\n",
    "        elif curr_label == \"Layers from all blocks\":\n",
    "            curr_label = \"All blocks + last layer\"\n",
    "            \n",
    "        new_labels.append(curr_label)\n",
    "        prev_name = full_label\n",
    "\n",
    "    legend = ax.legend(new_handles, new_labels, bbox_to_anchor=(0.5, 0.935), loc='lower center', ncols=3, frameon=False)\n",
    "    \n",
    "    ax.axhline(0, ls=':', color=\"grey\", zorder=-1)\n",
    "    ax.spines['top'].set_visible(False)\n",
    "    ax.spines['right'].set_visible(False)\n",
    "    \n",
    "    plt.tight_layout()\n",
    "    suffix = \"_with_fliers\" if showfliers else \"_without_fliers\"\n",
    "    fn = base_storing_path / \"do_intermediate_reps_help\" / f'boxplot_base_models{suffix}_v7.pdf'\n",
    "    save_or_show(plt.gcf(), fn, SAVE)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "31e9fd9e-14e9-47e4-99f3-29195c40dd2d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Stored statistical testing at ...\n"
     ]
    }
   ],
   "source": [
    "def fdr_bh(pvals):\n",
    "    pvalues = np.array(pvals)\n",
    "    n_tests = len(pvals)\n",
    "    sorted_indices = np.argsort(pvals)\n",
    "    sorted_pvals = pvalues[sorted_indices]\n",
    "    \n",
    "    corrected_pvals = np.zeros_like(pvals)\n",
    "    for i in range(n_tests-1, -1, -1):\n",
    "        corrected_pvals[sorted_indices[i]] = min(1.0, sorted_pvals[i] * n_tests / (i + 1))\n",
    "        if i < n_tests - 1:\n",
    "            corrected_pvals[sorted_indices[i]] = min(corrected_pvals[sorted_indices[i]], \n",
    "                                                    corrected_pvals[sorted_indices[i+1]])\n",
    "    return corrected_pvals\n",
    "\n",
    "\n",
    "\n",
    "exp_pairs = [\n",
    "    (\"CLS+AP layers from all blocks (attentive)\", \"CLS+AP last layer (attentive)\"),\n",
    "    (\"CLS+AP layers from all blocks (linear)\", \"CLS+AP last layer (linear)\"),\n",
    "    (\"CLS+AP layers from all blocks (attentive)\", \"CLS+AP layers from all blocks (linear)\"),\n",
    "    (\"CLS+AP layers from all blocks (attentive)\", \"All tokens last layer (attentive)\"),\n",
    "    \n",
    "]\n",
    "alpha = 0.05\n",
    "\n",
    "pvalues = []\n",
    "comb_index = []                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   \n",
    "for mid, mid_data in base_runs.groupby(\"base_model\"):\n",
    "    for exp1, exp2 in exp_pairs:\n",
    "        exp1_data = pd.to_numeric(mid_data[mid_data['Experiment'] == exp1].sort_values('dataset')[\"abs_perf_gain_test_lp_bal_acc1\"]).values\n",
    "        exp2_data = pd.to_numeric(mid_data[mid_data['Experiment'] == exp2].sort_values('dataset')[\"abs_perf_gain_test_lp_bal_acc1\"]).values\n",
    "        statistic, pval = wilcoxon(exp1_data, exp2_data, alternative='greater')\n",
    "\n",
    "        pvalues.append(pval)\n",
    "        comb_index.append((mid, (exp1, exp2))) \n",
    "\n",
    "adj_pvalues = fdr_bh(pvalues)\n",
    "statistical_testing = pd.DataFrame({\n",
    "    \"adj_pvalues\": adj_pvalues, \n",
    "    \"regected\": adj_pvalues < alpha, \n",
    "    \"base_model\": [val[0] for val in comb_index],\n",
    "    \"exp1\": [val[1][0] for val in comb_index],\n",
    "    \"exp2\": [val[1][1] for val in comb_index],\n",
    "})\n",
    "if SAVE:\n",
    "    fn = base_storing_path / \"do_intermediate_reps_help\" / f'statistical_tests_v2.csv'\n",
    "    statistical_testing.sort_values('adj_pvalues').to_csv(fn)\n",
    "    print(f\"Stored statistical testing at ...\")\n",
    "else:\n",
    "    display(statistical_testing.sort_values('adj_pvalues'))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.10.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
