{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c4e2befa-2e0e-407e-9ada-662ca04a5e0e",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/nkotelevskii/github/uncertainty_from_proper_scoring_rules/.venv/lib/python3.11/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n",
      "stty: 'standard input': Inappropriate ioctl for device\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "import os\n",
    "import re\n",
    "import numpy as np\n",
    "\n",
    "sys.path.insert(0, \"./src/\")\n",
    "\n",
    "import pandas as pd\n",
    "from src.table_utils import (\n",
    "    collect_scores_into_dict_with_std,\n",
    "    extract_same_different_dataframes,\n",
    "    ood_detection_pairs_,\n",
    "    aggregate_over_measures,\n",
    ")\n",
    "from IPython.display import display\n",
    "\n",
    "pd.set_option(\"display.max_rows\", None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c541d208-ad33-46f4-84ba-ee8a0b1f7f45",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e9304cda-312e-4db8-984f-a6641cf4293b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "58851b59-be21-4c83-9411-ed386bd334ad",
   "metadata": {},
   "outputs": [],
   "source": [
    "full_ood_rocauc = pd.read_csv(\"./tables/full_ood_rocauc_with_std.csv\", index_col=0)\n",
    "full_ood_rocauc = full_ood_rocauc[\n",
    "    full_ood_rocauc.Dataset != full_ood_rocauc.training_dataset\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "11af68d4-bece-48fd-95b4-80c13f4b1e77",
   "metadata": {},
   "outputs": [],
   "source": [
    "# full_ood_rocauc[full_ood_rocauc.Dataset == full_ood_rocauc.training_dataset]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "5f1d7c5a-784a-4347-8008-45f9fa282e2d",
   "metadata": {},
   "outputs": [],
   "source": [
    "full_ood_rocauc = full_ood_rocauc[~full_ood_rocauc.UQMetric.str.endswith(\"Inner Inner\")]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "b6457425-8644-4b93-af65-9c5bd445d165",
   "metadata": {},
   "outputs": [],
   "source": [
    "# DROP NEGLOG\n",
    "\n",
    "full_ood_rocauc = full_ood_rocauc[full_ood_rocauc.base_rule != \"Neglog\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "42ac51f1-0633-4558-86e0-99b606d5b02b",
   "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>UQMetric</th>\n",
       "      <th>Dataset</th>\n",
       "      <th>LossFunction</th>\n",
       "      <th>RocAucScores_array</th>\n",
       "      <th>architecture</th>\n",
       "      <th>training_dataset</th>\n",
       "      <th>RocAucScoresMean</th>\n",
       "      <th>RocAucScoresStd</th>\n",
       "      <th>base_rule</th>\n",
       "      <th>RiskType</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>3825</th>\n",
       "      <td>Excess Brier Outer Inner</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>Brier</td>\n",
       "      <td>[0.6841748200000001, 0.68315293, 0.688826285, ...</td>\n",
       "      <td>vgg</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>0.684690</td>\n",
       "      <td>2.281753e-03</td>\n",
       "      <td>Brier</td>\n",
       "      <td>Excess</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5631</th>\n",
       "      <td>Total Brier Outer</td>\n",
       "      <td>svhn</td>\n",
       "      <td>Brier</td>\n",
       "      <td>[0.8029762081284573, 0.8798006472802705, 0.957...</td>\n",
       "      <td>resnet18</td>\n",
       "      <td>missed_class_cifar10</td>\n",
       "      <td>0.911637</td>\n",
       "      <td>6.230155e-02</td>\n",
       "      <td>Brier</td>\n",
       "      <td>Total</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7040</th>\n",
       "      <td>Bayes Spherical Outer</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>Spherical</td>\n",
       "      <td>[0.79899081, 0.8179104799999999, 0.812788505, ...</td>\n",
       "      <td>resnet18</td>\n",
       "      <td>noisy_cifar10</td>\n",
       "      <td>0.802757</td>\n",
       "      <td>1.074237e-02</td>\n",
       "      <td>Spherical</td>\n",
       "      <td>Bayes</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5123</th>\n",
       "      <td>Bregman Information Logscore</td>\n",
       "      <td>svhn</td>\n",
       "      <td>Spherical</td>\n",
       "      <td>[0.6168736247695144, 0.6062281057928702, 0.595...</td>\n",
       "      <td>resnet18</td>\n",
       "      <td>noisy_cifar100</td>\n",
       "      <td>0.599064</td>\n",
       "      <td>1.941959e-02</td>\n",
       "      <td>Logscore</td>\n",
       "      <td>Bregman Information</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3152</th>\n",
       "      <td>MV Brier</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>Spherical</td>\n",
       "      <td>[0.425494355, 0.42838627500000004, 0.434354665...</td>\n",
       "      <td>resnet18</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>0.429337</td>\n",
       "      <td>3.128977e-03</td>\n",
       "      <td>Brier</td>\n",
       "      <td>MV</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3036</th>\n",
       "      <td>Expected Pairwise Bregman Information Maxprob</td>\n",
       "      <td>svhn</td>\n",
       "      <td>Brier</td>\n",
       "      <td>[0.6614998982022126, 0.6889206073294406, 0.674...</td>\n",
       "      <td>resnet18</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>0.675549</td>\n",
       "      <td>1.157423e-02</td>\n",
       "      <td>Maxprob</td>\n",
       "      <td>Expected Pairwise Bregman Information</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3156</th>\n",
       "      <td>MV Brier</td>\n",
       "      <td>svhn</td>\n",
       "      <td>Brier</td>\n",
       "      <td>[0.6434261812384757, 0.66129835010756, 0.68803...</td>\n",
       "      <td>resnet18</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>0.666047</td>\n",
       "      <td>1.475335e-02</td>\n",
       "      <td>Brier</td>\n",
       "      <td>MV</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4165</th>\n",
       "      <td>Expected Pairwise Bregman Information Maxprob</td>\n",
       "      <td>blurred_cifar100</td>\n",
       "      <td>Logscore</td>\n",
       "      <td>[0.6833198849999998, 0.6869936799999999, 0.685...</td>\n",
       "      <td>vgg</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>0.684365</td>\n",
       "      <td>1.673220e-03</td>\n",
       "      <td>Maxprob</td>\n",
       "      <td>Expected Pairwise Bregman Information</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6446</th>\n",
       "      <td>Expected Pairwise Bregman Information Spherical</td>\n",
       "      <td>blurred_cifar100</td>\n",
       "      <td>Spherical</td>\n",
       "      <td>[0.7639298950000001, 0.862209495, 0.941516805,...</td>\n",
       "      <td>resnet18</td>\n",
       "      <td>missed_class_cifar10</td>\n",
       "      <td>0.890847</td>\n",
       "      <td>7.073152e-02</td>\n",
       "      <td>Spherical</td>\n",
       "      <td>Expected Pairwise Bregman Information</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5285</th>\n",
       "      <td>Expected Pairwise Bregman Information Maxprob</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>Spherical</td>\n",
       "      <td>[0.5, 0.49999999999999994, 0.49999999999999983...</td>\n",
       "      <td>resnet18</td>\n",
       "      <td>noisy_cifar100</td>\n",
       "      <td>0.500000</td>\n",
       "      <td>8.233634e-17</td>\n",
       "      <td>Maxprob</td>\n",
       "      <td>Expected Pairwise Bregman Information</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                             UQMetric           Dataset  \\\n",
       "3825                         Excess Brier Outer Inner           cifar10   \n",
       "5631                                Total Brier Outer              svhn   \n",
       "7040                            Bayes Spherical Outer          cifar100   \n",
       "5123                     Bregman Information Logscore              svhn   \n",
       "3152                                         MV Brier           cifar10   \n",
       "3036    Expected Pairwise Bregman Information Maxprob              svhn   \n",
       "3156                                         MV Brier              svhn   \n",
       "4165    Expected Pairwise Bregman Information Maxprob  blurred_cifar100   \n",
       "6446  Expected Pairwise Bregman Information Spherical  blurred_cifar100   \n",
       "5285    Expected Pairwise Bregman Information Maxprob          cifar100   \n",
       "\n",
       "     LossFunction                                 RocAucScores_array  \\\n",
       "3825        Brier  [0.6841748200000001, 0.68315293, 0.688826285, ...   \n",
       "5631        Brier  [0.8029762081284573, 0.8798006472802705, 0.957...   \n",
       "7040    Spherical  [0.79899081, 0.8179104799999999, 0.812788505, ...   \n",
       "5123    Spherical  [0.6168736247695144, 0.6062281057928702, 0.595...   \n",
       "3152    Spherical  [0.425494355, 0.42838627500000004, 0.434354665...   \n",
       "3036        Brier  [0.6614998982022126, 0.6889206073294406, 0.674...   \n",
       "3156        Brier  [0.6434261812384757, 0.66129835010756, 0.68803...   \n",
       "4165     Logscore  [0.6833198849999998, 0.6869936799999999, 0.685...   \n",
       "6446    Spherical  [0.7639298950000001, 0.862209495, 0.941516805,...   \n",
       "5285    Spherical  [0.5, 0.49999999999999994, 0.49999999999999983...   \n",
       "\n",
       "     architecture      training_dataset  RocAucScoresMean  RocAucScoresStd  \\\n",
       "3825          vgg              cifar100          0.684690     2.281753e-03   \n",
       "5631     resnet18  missed_class_cifar10          0.911637     6.230155e-02   \n",
       "7040     resnet18         noisy_cifar10          0.802757     1.074237e-02   \n",
       "5123     resnet18        noisy_cifar100          0.599064     1.941959e-02   \n",
       "3152     resnet18              cifar100          0.429337     3.128977e-03   \n",
       "3036     resnet18              cifar100          0.675549     1.157423e-02   \n",
       "3156     resnet18              cifar100          0.666047     1.475335e-02   \n",
       "4165          vgg              cifar100          0.684365     1.673220e-03   \n",
       "6446     resnet18  missed_class_cifar10          0.890847     7.073152e-02   \n",
       "5285     resnet18        noisy_cifar100          0.500000     8.233634e-17   \n",
       "\n",
       "      base_rule                               RiskType  \n",
       "3825      Brier                                 Excess  \n",
       "5631      Brier                                  Total  \n",
       "7040  Spherical                                  Bayes  \n",
       "5123   Logscore                    Bregman Information  \n",
       "3152      Brier                                     MV  \n",
       "3036    Maxprob  Expected Pairwise Bregman Information  \n",
       "3156      Brier                                     MV  \n",
       "4165    Maxprob  Expected Pairwise Bregman Information  \n",
       "6446  Spherical  Expected Pairwise Bregman Information  \n",
       "5285    Maxprob  Expected Pairwise Bregman Information  "
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "full_ood_rocauc.sample(10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "1e112b04-1368-4a44-a1ef-5a14bb90d6fa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(['Brier', 'Logscore', 'Maxprob', 'Spherical'], dtype=object)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "full_ood_rocauc.base_rule.unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "31dc4ede-46c5-4473-b027-7b3a2286e63b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2ec57035-1010-4537-8dbf-de379ded928e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "24e54532-cd52-4d3a-872b-056ea8549e99",
   "metadata": {},
   "outputs": [],
   "source": [
    "from collections import namedtuple\n",
    "\n",
    "\n",
    "def extract_logscore_others_dataframes_modified(\n",
    "    dataframe_: pd.DataFrame,\n",
    "):\n",
    "    df = dataframe_.copy()\n",
    "    df_logscore = df[(df[\"base_rule\"] == \"Logscore\")]\n",
    "    df_others = df[(df[\"base_rule\"] != \"Logscore\")]\n",
    "\n",
    "    dataframes_ = namedtuple(\n",
    "        \"SameDiffDF\",\n",
    "        [\n",
    "            \"logscore\",\n",
    "            \"others\",\n",
    "        ],\n",
    "    )\n",
    "    return dataframes_(\n",
    "        logscore=df_logscore,\n",
    "        others=df_others,\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "8d6525a4-9522-480b-81a9-d39bf41f29a8",
   "metadata": {},
   "outputs": [],
   "source": [
    "grouped_df = extract_logscore_others_dataframes_modified(\n",
    "    dataframe_=full_ood_rocauc,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "96efd219-ec95-4d7c-94f5-e3e84f92ff5e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b799d8a9-5d12-4e1f-b2ad-b6db36f409da",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a6f03c7a-877a-4d50-96c3-b858652dd79a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8159002d-9c59-42b4-8677-d70043f53f07",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "90b24f95-0633-4d93-97b1-268b2061e452",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "cf6a4d6b-d0bf-4366-8b14-7506d684c6f0",
   "metadata": {},
   "outputs": [],
   "source": [
    "def enhance_latex_table(input_latex):\n",
    "    lines = input_latex.split(\"\\n\")\n",
    "    enhanced_lines = []\n",
    "\n",
    "    for i, line in enumerate(lines):\n",
    "        if \"\\\\begin{tabular}\" in line:\n",
    "            # Start centering the table\n",
    "            enhanced_lines.append(r\"\\begin{center}\")\n",
    "\n",
    "        if \"\\\\toprule\" in line:\n",
    "            # Add multicolumn headers\n",
    "            enhanced_lines.append(line)\n",
    "            enhanced_lines.append(\n",
    "                r\"\\multicolumn{2}{c}{Dataset} & \\multicolumn{5}{c}{Metrics} \\\\\"\n",
    "            )\n",
    "            enhanced_lines.append(r\"\\cmidrule(lr){1-2} \\cmidrule(lr){3-7}\")\n",
    "            continue\n",
    "\n",
    "        # Add row coloring\n",
    "        if \"\\\\midrule\" in line:\n",
    "            enhanced_lines.append(line)\n",
    "            enhanced_lines.append(r\"\\rowcolor{gray!10}\")\n",
    "        elif \"\\\\bottomrule\" in line:\n",
    "            enhanced_lines.append(r\"\\end{tabular}\")\n",
    "            enhanced_lines.append(r\"\\end{center}\")\n",
    "        else:\n",
    "            enhanced_lines.append(line)\n",
    "\n",
    "    return \"\\n\".join(enhanced_lines)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "8b656f80-68f7-42d7-82ca-33bae3db8bdb",
   "metadata": {},
   "outputs": [],
   "source": [
    "index_pairs = [\n",
    "    (\"CIFAR10\", \"Blurred CIFAR10\"),\n",
    "    (\"CIFAR10\", \"Blurred CIFAR100\"),\n",
    "    (\"CIFAR10\", \"CIFAR100\"),\n",
    "    (\"CIFAR10\", \"SVHN\"),\n",
    "    (\"CIFAR100\", \"Blurred CIFAR10\"),\n",
    "    (\"CIFAR100\", \"Blurred CIFAR100\"),\n",
    "    (\"CIFAR100\", \"CIFAR10\"),\n",
    "    (\"CIFAR100\", \"SVHN\"),\n",
    "]\n",
    "\n",
    "\n",
    "def get_nice_df(df_):\n",
    "    df_.index = pd.MultiIndex.from_tuples(index_pairs, names=[\"InD\", \"OOD\"])\n",
    "    df_.columns = [\n",
    "        \"Bayes\",\n",
    "        \"Excess\",\n",
    "        \"Total\",\n",
    "        # 'Bayes(O)',\n",
    "        # 'Bayes(I)',\n",
    "        # 'Total(O)',\n",
    "        # 'Total(I)',\n",
    "        \"BI\",\n",
    "        \"RBI\",\n",
    "        \"EPBI\",\n",
    "        # 'Bias',\n",
    "        # 'MV',\n",
    "        # 'MVBI',\n",
    "        # 'BiasBI',\n",
    "    ]\n",
    "    # df_ = df_[['Bayes', 'Excess', 'Total', 'BI', 'RBI']]\n",
    "    df_ = (100 * df_).round(2)\n",
    "\n",
    "    display(df_)\n",
    "\n",
    "    return df_, df_.to_latex(float_format=\"%.2f\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "a7305e73-22b7-4cc5-9fac-b4514221df16",
   "metadata": {},
   "outputs": [],
   "source": [
    "# measures = [c for c in same_agg_df.columns if c not in ['OOD', 'InD', 'ScoringRule']]\n",
    "# measures\n",
    "\n",
    "# measures = [\n",
    "#     'Bayes Outer',\n",
    "#     'Bayes Inner',\n",
    "#     'Total Outer',\n",
    "#     'Total Inner',\n",
    "#     'Bregman Information',\n",
    "#     'Reverse Bregman Information',\n",
    "#     'Expected Pairwise Bregman Information']\n",
    "\n",
    "measures = [\n",
    "    \"Bayes\",\n",
    "    \"Excess\",\n",
    "    \"Total\",\n",
    "    \"Bregman Information\",\n",
    "    \"Reverse Bregman Information\",\n",
    "    \"Expected Pairwise Bregman Information\",\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d6358c48-8fa8-4ce9-bad0-e68107254d44",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "22786c85-37f6-4145-a52d-c863c1800f9c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fd93f60a-a3fa-40a2-84af-4e1717d5b92e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "2341eedc-4c17-42aa-804d-d6101846ac0e",
   "metadata": {},
   "outputs": [],
   "source": [
    "logscore_dict_mean, logscore_dict_std = collect_scores_into_dict_with_std(\n",
    "    dataframes_list=[\n",
    "        grouped_df.logscore,\n",
    "    ],\n",
    "    ood_detection_pairs=ood_detection_pairs_,\n",
    ")\n",
    "logscore_df_mean = pd.DataFrame.from_dict(logscore_dict_mean)\n",
    "logscore_df_std = pd.DataFrame.from_dict(logscore_dict_std)\n",
    "\n",
    "logscore_agg_df_mean = aggregate_over_measures(\n",
    "    dataframe_=logscore_df_mean,\n",
    "    agg_func_=\"mean\",\n",
    "    by_=[\"InD\", \"OOD\"],\n",
    ")\n",
    "\n",
    "logscore_agg_df_std = aggregate_over_measures(\n",
    "    dataframe_=logscore_df_std,\n",
    "    agg_func_=\"mean\",\n",
    "    by_=[\"InD\", \"OOD\"],\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "75d0011c-0585-4628-a5e8-19e4bf94cac1",
   "metadata": {},
   "outputs": [],
   "source": [
    "other_dict_mean, other_dict_std = collect_scores_into_dict_with_std(\n",
    "    dataframes_list=[\n",
    "        grouped_df.others,\n",
    "    ],\n",
    "    ood_detection_pairs=ood_detection_pairs_,\n",
    ")\n",
    "other_df_mean = pd.DataFrame.from_dict(other_dict_mean)\n",
    "other_df_std = pd.DataFrame.from_dict(other_dict_std)\n",
    "\n",
    "other_agg_df_mean = aggregate_over_measures(\n",
    "    dataframe_=other_df_mean,\n",
    "    agg_func_=\"mean\",\n",
    "    by_=[\"InD\", \"OOD\"],\n",
    ")\n",
    "\n",
    "other_agg_df_std = aggregate_over_measures(\n",
    "    dataframe_=other_df_std,\n",
    "    agg_func_=\"mean\",\n",
    "    by_=[\"InD\", \"OOD\"],\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "326aed35-f6d4-4b41-aebf-2ffd1c4ce32c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "aff501d1-0070-43c6-9d88-825a8424c318",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr:last-of-type th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Total</th>\n",
       "      <th>Bayes</th>\n",
       "      <th>Excess</th>\n",
       "      <th>Bregman Information</th>\n",
       "      <th>Reverse Bregman Information</th>\n",
       "      <th>Expected Pairwise Bregman Information</th>\n",
       "      <th>Bias</th>\n",
       "      <th>MV</th>\n",
       "      <th>MVBI</th>\n",
       "      <th>BiasBI</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>InD</th>\n",
       "      <th>OOD</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">cifar10</th>\n",
       "      <th>blurred_cifar10</th>\n",
       "      <td>0.826258</td>\n",
       "      <td>0.810427</td>\n",
       "      <td>0.842324</td>\n",
       "      <td>0.841220</td>\n",
       "      <td>0.842985</td>\n",
       "      <td>0.842767</td>\n",
       "      <td>0.839513</td>\n",
       "      <td>0.841107</td>\n",
       "      <td>0.841453</td>\n",
       "      <td>0.842880</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>blurred_cifar100</th>\n",
       "      <td>0.935675</td>\n",
       "      <td>0.926451</td>\n",
       "      <td>0.934064</td>\n",
       "      <td>0.934770</td>\n",
       "      <td>0.933366</td>\n",
       "      <td>0.934055</td>\n",
       "      <td>0.919269</td>\n",
       "      <td>0.933596</td>\n",
       "      <td>0.934144</td>\n",
       "      <td>0.933189</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar100</th>\n",
       "      <td>0.895048</td>\n",
       "      <td>0.896381</td>\n",
       "      <td>0.883373</td>\n",
       "      <td>0.884946</td>\n",
       "      <td>0.882108</td>\n",
       "      <td>0.883065</td>\n",
       "      <td>0.868268</td>\n",
       "      <td>0.884068</td>\n",
       "      <td>0.884295</td>\n",
       "      <td>0.881935</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>svhn</th>\n",
       "      <td>0.932190</td>\n",
       "      <td>0.933032</td>\n",
       "      <td>0.918104</td>\n",
       "      <td>0.919379</td>\n",
       "      <td>0.917037</td>\n",
       "      <td>0.917895</td>\n",
       "      <td>0.900413</td>\n",
       "      <td>0.919156</td>\n",
       "      <td>0.919196</td>\n",
       "      <td>0.916232</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">cifar100</th>\n",
       "      <th>blurred_cifar10</th>\n",
       "      <td>0.884984</td>\n",
       "      <td>0.861705</td>\n",
       "      <td>0.840902</td>\n",
       "      <td>0.843844</td>\n",
       "      <td>0.837527</td>\n",
       "      <td>0.841336</td>\n",
       "      <td>0.815185</td>\n",
       "      <td>0.835672</td>\n",
       "      <td>0.840057</td>\n",
       "      <td>0.842064</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>blurred_cifar100</th>\n",
       "      <td>0.727264</td>\n",
       "      <td>0.701509</td>\n",
       "      <td>0.747029</td>\n",
       "      <td>0.742435</td>\n",
       "      <td>0.749579</td>\n",
       "      <td>0.749073</td>\n",
       "      <td>0.737171</td>\n",
       "      <td>0.743822</td>\n",
       "      <td>0.744725</td>\n",
       "      <td>0.749647</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar10</th>\n",
       "      <td>0.780929</td>\n",
       "      <td>0.779954</td>\n",
       "      <td>0.709738</td>\n",
       "      <td>0.716799</td>\n",
       "      <td>0.703844</td>\n",
       "      <td>0.708572</td>\n",
       "      <td>0.665579</td>\n",
       "      <td>0.709412</td>\n",
       "      <td>0.712118</td>\n",
       "      <td>0.706327</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>svhn</th>\n",
       "      <td>0.839809</td>\n",
       "      <td>0.836841</td>\n",
       "      <td>0.747345</td>\n",
       "      <td>0.754318</td>\n",
       "      <td>0.741123</td>\n",
       "      <td>0.746592</td>\n",
       "      <td>0.709460</td>\n",
       "      <td>0.744240</td>\n",
       "      <td>0.748289</td>\n",
       "      <td>0.747261</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                              Total     Bayes    Excess Bregman Information  \\\n",
       "                               mean      mean      mean                mean   \n",
       "InD      OOD                                                                  \n",
       "cifar10  blurred_cifar10   0.826258  0.810427  0.842324            0.841220   \n",
       "         blurred_cifar100  0.935675  0.926451  0.934064            0.934770   \n",
       "         cifar100          0.895048  0.896381  0.883373            0.884946   \n",
       "         svhn              0.932190  0.933032  0.918104            0.919379   \n",
       "cifar100 blurred_cifar10   0.884984  0.861705  0.840902            0.843844   \n",
       "         blurred_cifar100  0.727264  0.701509  0.747029            0.742435   \n",
       "         cifar10           0.780929  0.779954  0.709738            0.716799   \n",
       "         svhn              0.839809  0.836841  0.747345            0.754318   \n",
       "\n",
       "                          Reverse Bregman Information  \\\n",
       "                                                 mean   \n",
       "InD      OOD                                            \n",
       "cifar10  blurred_cifar10                     0.842985   \n",
       "         blurred_cifar100                    0.933366   \n",
       "         cifar100                            0.882108   \n",
       "         svhn                                0.917037   \n",
       "cifar100 blurred_cifar10                     0.837527   \n",
       "         blurred_cifar100                    0.749579   \n",
       "         cifar10                             0.703844   \n",
       "         svhn                                0.741123   \n",
       "\n",
       "                          Expected Pairwise Bregman Information      Bias  \\\n",
       "                                                           mean      mean   \n",
       "InD      OOD                                                                \n",
       "cifar10  blurred_cifar10                               0.842767  0.839513   \n",
       "         blurred_cifar100                              0.934055  0.919269   \n",
       "         cifar100                                      0.883065  0.868268   \n",
       "         svhn                                          0.917895  0.900413   \n",
       "cifar100 blurred_cifar10                               0.841336  0.815185   \n",
       "         blurred_cifar100                              0.749073  0.737171   \n",
       "         cifar10                                       0.708572  0.665579   \n",
       "         svhn                                          0.746592  0.709460   \n",
       "\n",
       "                                 MV      MVBI    BiasBI  \n",
       "                               mean      mean      mean  \n",
       "InD      OOD                                             \n",
       "cifar10  blurred_cifar10   0.841107  0.841453  0.842880  \n",
       "         blurred_cifar100  0.933596  0.934144  0.933189  \n",
       "         cifar100          0.884068  0.884295  0.881935  \n",
       "         svhn              0.919156  0.919196  0.916232  \n",
       "cifar100 blurred_cifar10   0.835672  0.840057  0.842064  \n",
       "         blurred_cifar100  0.743822  0.744725  0.749647  \n",
       "         cifar10           0.709412  0.712118  0.706327  \n",
       "         svhn              0.744240  0.748289  0.747261  "
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "logscore_agg_df_mean"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "bb3d4780-be20-487b-89e7-4823df5923f8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr:last-of-type th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Total</th>\n",
       "      <th>Bayes</th>\n",
       "      <th>Excess</th>\n",
       "      <th>Bregman Information</th>\n",
       "      <th>Reverse Bregman Information</th>\n",
       "      <th>Expected Pairwise Bregman Information</th>\n",
       "      <th>Bias</th>\n",
       "      <th>MV</th>\n",
       "      <th>MVBI</th>\n",
       "      <th>BiasBI</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>InD</th>\n",
       "      <th>OOD</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">cifar10</th>\n",
       "      <th>blurred_cifar10</th>\n",
       "      <td>0.006467</td>\n",
       "      <td>0.006724</td>\n",
       "      <td>0.006419</td>\n",
       "      <td>0.006456</td>\n",
       "      <td>0.006384</td>\n",
       "      <td>0.006417</td>\n",
       "      <td>0.005935</td>\n",
       "      <td>0.006469</td>\n",
       "      <td>0.006471</td>\n",
       "      <td>0.006354</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>blurred_cifar100</th>\n",
       "      <td>0.003595</td>\n",
       "      <td>0.004193</td>\n",
       "      <td>0.002656</td>\n",
       "      <td>0.002730</td>\n",
       "      <td>0.002605</td>\n",
       "      <td>0.002633</td>\n",
       "      <td>0.002529</td>\n",
       "      <td>0.002650</td>\n",
       "      <td>0.002663</td>\n",
       "      <td>0.002673</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar100</th>\n",
       "      <td>0.001487</td>\n",
       "      <td>0.001616</td>\n",
       "      <td>0.001789</td>\n",
       "      <td>0.001781</td>\n",
       "      <td>0.001793</td>\n",
       "      <td>0.001793</td>\n",
       "      <td>0.002242</td>\n",
       "      <td>0.001736</td>\n",
       "      <td>0.001753</td>\n",
       "      <td>0.001910</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>svhn</th>\n",
       "      <td>0.008434</td>\n",
       "      <td>0.009187</td>\n",
       "      <td>0.008702</td>\n",
       "      <td>0.008786</td>\n",
       "      <td>0.008664</td>\n",
       "      <td>0.008657</td>\n",
       "      <td>0.008815</td>\n",
       "      <td>0.008525</td>\n",
       "      <td>0.008603</td>\n",
       "      <td>0.008708</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">cifar100</th>\n",
       "      <th>blurred_cifar10</th>\n",
       "      <td>0.002484</td>\n",
       "      <td>0.002702</td>\n",
       "      <td>0.003909</td>\n",
       "      <td>0.003865</td>\n",
       "      <td>0.003955</td>\n",
       "      <td>0.003907</td>\n",
       "      <td>0.004143</td>\n",
       "      <td>0.003817</td>\n",
       "      <td>0.003808</td>\n",
       "      <td>0.004041</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>blurred_cifar100</th>\n",
       "      <td>0.003390</td>\n",
       "      <td>0.003293</td>\n",
       "      <td>0.004043</td>\n",
       "      <td>0.003933</td>\n",
       "      <td>0.004110</td>\n",
       "      <td>0.004087</td>\n",
       "      <td>0.004602</td>\n",
       "      <td>0.003968</td>\n",
       "      <td>0.003976</td>\n",
       "      <td>0.004217</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar10</th>\n",
       "      <td>0.002233</td>\n",
       "      <td>0.002290</td>\n",
       "      <td>0.003403</td>\n",
       "      <td>0.003187</td>\n",
       "      <td>0.003593</td>\n",
       "      <td>0.003430</td>\n",
       "      <td>0.004710</td>\n",
       "      <td>0.003142</td>\n",
       "      <td>0.003130</td>\n",
       "      <td>0.003693</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>svhn</th>\n",
       "      <td>0.013626</td>\n",
       "      <td>0.014056</td>\n",
       "      <td>0.017502</td>\n",
       "      <td>0.016796</td>\n",
       "      <td>0.018008</td>\n",
       "      <td>0.017701</td>\n",
       "      <td>0.021066</td>\n",
       "      <td>0.016531</td>\n",
       "      <td>0.016631</td>\n",
       "      <td>0.018819</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                              Total     Bayes    Excess Bregman Information  \\\n",
       "                               mean      mean      mean                mean   \n",
       "InD      OOD                                                                  \n",
       "cifar10  blurred_cifar10   0.006467  0.006724  0.006419            0.006456   \n",
       "         blurred_cifar100  0.003595  0.004193  0.002656            0.002730   \n",
       "         cifar100          0.001487  0.001616  0.001789            0.001781   \n",
       "         svhn              0.008434  0.009187  0.008702            0.008786   \n",
       "cifar100 blurred_cifar10   0.002484  0.002702  0.003909            0.003865   \n",
       "         blurred_cifar100  0.003390  0.003293  0.004043            0.003933   \n",
       "         cifar10           0.002233  0.002290  0.003403            0.003187   \n",
       "         svhn              0.013626  0.014056  0.017502            0.016796   \n",
       "\n",
       "                          Reverse Bregman Information  \\\n",
       "                                                 mean   \n",
       "InD      OOD                                            \n",
       "cifar10  blurred_cifar10                     0.006384   \n",
       "         blurred_cifar100                    0.002605   \n",
       "         cifar100                            0.001793   \n",
       "         svhn                                0.008664   \n",
       "cifar100 blurred_cifar10                     0.003955   \n",
       "         blurred_cifar100                    0.004110   \n",
       "         cifar10                             0.003593   \n",
       "         svhn                                0.018008   \n",
       "\n",
       "                          Expected Pairwise Bregman Information      Bias  \\\n",
       "                                                           mean      mean   \n",
       "InD      OOD                                                                \n",
       "cifar10  blurred_cifar10                               0.006417  0.005935   \n",
       "         blurred_cifar100                              0.002633  0.002529   \n",
       "         cifar100                                      0.001793  0.002242   \n",
       "         svhn                                          0.008657  0.008815   \n",
       "cifar100 blurred_cifar10                               0.003907  0.004143   \n",
       "         blurred_cifar100                              0.004087  0.004602   \n",
       "         cifar10                                       0.003430  0.004710   \n",
       "         svhn                                          0.017701  0.021066   \n",
       "\n",
       "                                 MV      MVBI    BiasBI  \n",
       "                               mean      mean      mean  \n",
       "InD      OOD                                             \n",
       "cifar10  blurred_cifar10   0.006469  0.006471  0.006354  \n",
       "         blurred_cifar100  0.002650  0.002663  0.002673  \n",
       "         cifar100          0.001736  0.001753  0.001910  \n",
       "         svhn              0.008525  0.008603  0.008708  \n",
       "cifar100 blurred_cifar10   0.003817  0.003808  0.004041  \n",
       "         blurred_cifar100  0.003968  0.003976  0.004217  \n",
       "         cifar10           0.003142  0.003130  0.003693  \n",
       "         svhn              0.016531  0.016631  0.018819  "
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "logscore_agg_df_std"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "81bb4a3b-a7c2-4617-96fc-3ab9acf52d57",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "9a435747-e7db-422e-a2f2-7568b1ca1991",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr:last-of-type th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Total</th>\n",
       "      <th>Bayes</th>\n",
       "      <th>Excess</th>\n",
       "      <th>Bregman Information</th>\n",
       "      <th>Reverse Bregman Information</th>\n",
       "      <th>Expected Pairwise Bregman Information</th>\n",
       "      <th>Bias</th>\n",
       "      <th>MV</th>\n",
       "      <th>MVBI</th>\n",
       "      <th>BiasBI</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>InD</th>\n",
       "      <th>OOD</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">cifar10</th>\n",
       "      <th>blurred_cifar10</th>\n",
       "      <td>0.822736</td>\n",
       "      <td>0.811172</td>\n",
       "      <td>0.797880</td>\n",
       "      <td>0.798112</td>\n",
       "      <td>0.796549</td>\n",
       "      <td>0.798979</td>\n",
       "      <td>0.509407</td>\n",
       "      <td>0.723799</td>\n",
       "      <td>0.798171</td>\n",
       "      <td>0.642769</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>blurred_cifar100</th>\n",
       "      <td>0.932556</td>\n",
       "      <td>0.924893</td>\n",
       "      <td>0.897333</td>\n",
       "      <td>0.898327</td>\n",
       "      <td>0.895181</td>\n",
       "      <td>0.898490</td>\n",
       "      <td>0.520607</td>\n",
       "      <td>0.786157</td>\n",
       "      <td>0.898185</td>\n",
       "      <td>0.676995</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar100</th>\n",
       "      <td>0.893354</td>\n",
       "      <td>0.894017</td>\n",
       "      <td>0.837349</td>\n",
       "      <td>0.837926</td>\n",
       "      <td>0.836487</td>\n",
       "      <td>0.837635</td>\n",
       "      <td>0.511316</td>\n",
       "      <td>0.754593</td>\n",
       "      <td>0.837711</td>\n",
       "      <td>0.650429</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>svhn</th>\n",
       "      <td>0.930043</td>\n",
       "      <td>0.930366</td>\n",
       "      <td>0.874657</td>\n",
       "      <td>0.875427</td>\n",
       "      <td>0.873656</td>\n",
       "      <td>0.874889</td>\n",
       "      <td>0.514843</td>\n",
       "      <td>0.777956</td>\n",
       "      <td>0.875229</td>\n",
       "      <td>0.663193</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">cifar100</th>\n",
       "      <th>blurred_cifar10</th>\n",
       "      <td>0.871290</td>\n",
       "      <td>0.855593</td>\n",
       "      <td>0.774596</td>\n",
       "      <td>0.781780</td>\n",
       "      <td>0.764461</td>\n",
       "      <td>0.777547</td>\n",
       "      <td>0.486373</td>\n",
       "      <td>0.673758</td>\n",
       "      <td>0.778797</td>\n",
       "      <td>0.572215</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>blurred_cifar100</th>\n",
       "      <td>0.713643</td>\n",
       "      <td>0.696379</td>\n",
       "      <td>0.701115</td>\n",
       "      <td>0.700070</td>\n",
       "      <td>0.699590</td>\n",
       "      <td>0.703686</td>\n",
       "      <td>0.505876</td>\n",
       "      <td>0.637477</td>\n",
       "      <td>0.699466</td>\n",
       "      <td>0.578614</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar10</th>\n",
       "      <td>0.779421</td>\n",
       "      <td>0.778824</td>\n",
       "      <td>0.690515</td>\n",
       "      <td>0.695493</td>\n",
       "      <td>0.685560</td>\n",
       "      <td>0.690493</td>\n",
       "      <td>0.483653</td>\n",
       "      <td>0.624983</td>\n",
       "      <td>0.693714</td>\n",
       "      <td>0.541103</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>svhn</th>\n",
       "      <td>0.824954</td>\n",
       "      <td>0.826959</td>\n",
       "      <td>0.699088</td>\n",
       "      <td>0.704894</td>\n",
       "      <td>0.694155</td>\n",
       "      <td>0.698214</td>\n",
       "      <td>0.478301</td>\n",
       "      <td>0.627434</td>\n",
       "      <td>0.702332</td>\n",
       "      <td>0.528436</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                              Total     Bayes    Excess Bregman Information  \\\n",
       "                               mean      mean      mean                mean   \n",
       "InD      OOD                                                                  \n",
       "cifar10  blurred_cifar10   0.822736  0.811172  0.797880            0.798112   \n",
       "         blurred_cifar100  0.932556  0.924893  0.897333            0.898327   \n",
       "         cifar100          0.893354  0.894017  0.837349            0.837926   \n",
       "         svhn              0.930043  0.930366  0.874657            0.875427   \n",
       "cifar100 blurred_cifar10   0.871290  0.855593  0.774596            0.781780   \n",
       "         blurred_cifar100  0.713643  0.696379  0.701115            0.700070   \n",
       "         cifar10           0.779421  0.778824  0.690515            0.695493   \n",
       "         svhn              0.824954  0.826959  0.699088            0.704894   \n",
       "\n",
       "                          Reverse Bregman Information  \\\n",
       "                                                 mean   \n",
       "InD      OOD                                            \n",
       "cifar10  blurred_cifar10                     0.796549   \n",
       "         blurred_cifar100                    0.895181   \n",
       "         cifar100                            0.836487   \n",
       "         svhn                                0.873656   \n",
       "cifar100 blurred_cifar10                     0.764461   \n",
       "         blurred_cifar100                    0.699590   \n",
       "         cifar10                             0.685560   \n",
       "         svhn                                0.694155   \n",
       "\n",
       "                          Expected Pairwise Bregman Information      Bias  \\\n",
       "                                                           mean      mean   \n",
       "InD      OOD                                                                \n",
       "cifar10  blurred_cifar10                               0.798979  0.509407   \n",
       "         blurred_cifar100                              0.898490  0.520607   \n",
       "         cifar100                                      0.837635  0.511316   \n",
       "         svhn                                          0.874889  0.514843   \n",
       "cifar100 blurred_cifar10                               0.777547  0.486373   \n",
       "         blurred_cifar100                              0.703686  0.505876   \n",
       "         cifar10                                       0.690493  0.483653   \n",
       "         svhn                                          0.698214  0.478301   \n",
       "\n",
       "                                 MV      MVBI    BiasBI  \n",
       "                               mean      mean      mean  \n",
       "InD      OOD                                             \n",
       "cifar10  blurred_cifar10   0.723799  0.798171  0.642769  \n",
       "         blurred_cifar100  0.786157  0.898185  0.676995  \n",
       "         cifar100          0.754593  0.837711  0.650429  \n",
       "         svhn              0.777956  0.875229  0.663193  \n",
       "cifar100 blurred_cifar10   0.673758  0.778797  0.572215  \n",
       "         blurred_cifar100  0.637477  0.699466  0.578614  \n",
       "         cifar10           0.624983  0.693714  0.541103  \n",
       "         svhn              0.627434  0.702332  0.528436  "
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "other_agg_df_mean"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "36a029b7-1026-4d6e-a24e-79345525b0ae",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr:last-of-type th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Total</th>\n",
       "      <th>Bayes</th>\n",
       "      <th>Excess</th>\n",
       "      <th>Bregman Information</th>\n",
       "      <th>Reverse Bregman Information</th>\n",
       "      <th>Expected Pairwise Bregman Information</th>\n",
       "      <th>Bias</th>\n",
       "      <th>MV</th>\n",
       "      <th>MVBI</th>\n",
       "      <th>BiasBI</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "      <th>mean</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>InD</th>\n",
       "      <th>OOD</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">cifar10</th>\n",
       "      <th>blurred_cifar10</th>\n",
       "      <td>0.006442</td>\n",
       "      <td>0.006611</td>\n",
       "      <td>0.005935</td>\n",
       "      <td>0.005891</td>\n",
       "      <td>0.005872</td>\n",
       "      <td>0.006041</td>\n",
       "      <td>0.003605</td>\n",
       "      <td>0.004097</td>\n",
       "      <td>0.005891</td>\n",
       "      <td>0.006064</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>blurred_cifar100</th>\n",
       "      <td>0.003562</td>\n",
       "      <td>0.003956</td>\n",
       "      <td>0.003338</td>\n",
       "      <td>0.003436</td>\n",
       "      <td>0.003308</td>\n",
       "      <td>0.003270</td>\n",
       "      <td>0.002391</td>\n",
       "      <td>0.001660</td>\n",
       "      <td>0.003428</td>\n",
       "      <td>0.002985</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar100</th>\n",
       "      <td>0.001507</td>\n",
       "      <td>0.001601</td>\n",
       "      <td>0.002024</td>\n",
       "      <td>0.002099</td>\n",
       "      <td>0.002023</td>\n",
       "      <td>0.001951</td>\n",
       "      <td>0.000989</td>\n",
       "      <td>0.001151</td>\n",
       "      <td>0.002105</td>\n",
       "      <td>0.001565</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>svhn</th>\n",
       "      <td>0.008192</td>\n",
       "      <td>0.008565</td>\n",
       "      <td>0.012615</td>\n",
       "      <td>0.012789</td>\n",
       "      <td>0.012252</td>\n",
       "      <td>0.012804</td>\n",
       "      <td>0.007289</td>\n",
       "      <td>0.005276</td>\n",
       "      <td>0.012772</td>\n",
       "      <td>0.008323</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">cifar100</th>\n",
       "      <th>blurred_cifar10</th>\n",
       "      <td>0.002339</td>\n",
       "      <td>0.002418</td>\n",
       "      <td>0.003323</td>\n",
       "      <td>0.003347</td>\n",
       "      <td>0.003238</td>\n",
       "      <td>0.003386</td>\n",
       "      <td>0.001702</td>\n",
       "      <td>0.002440</td>\n",
       "      <td>0.003384</td>\n",
       "      <td>0.003184</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>blurred_cifar100</th>\n",
       "      <td>0.002993</td>\n",
       "      <td>0.002983</td>\n",
       "      <td>0.003523</td>\n",
       "      <td>0.003517</td>\n",
       "      <td>0.003530</td>\n",
       "      <td>0.003520</td>\n",
       "      <td>0.002047</td>\n",
       "      <td>0.002367</td>\n",
       "      <td>0.003543</td>\n",
       "      <td>0.003348</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar10</th>\n",
       "      <td>0.001952</td>\n",
       "      <td>0.002040</td>\n",
       "      <td>0.002564</td>\n",
       "      <td>0.002533</td>\n",
       "      <td>0.002558</td>\n",
       "      <td>0.002602</td>\n",
       "      <td>0.001420</td>\n",
       "      <td>0.001675</td>\n",
       "      <td>0.002542</td>\n",
       "      <td>0.002373</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>svhn</th>\n",
       "      <td>0.012836</td>\n",
       "      <td>0.013518</td>\n",
       "      <td>0.011459</td>\n",
       "      <td>0.011956</td>\n",
       "      <td>0.010805</td>\n",
       "      <td>0.011618</td>\n",
       "      <td>0.008487</td>\n",
       "      <td>0.007698</td>\n",
       "      <td>0.011892</td>\n",
       "      <td>0.012537</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                              Total     Bayes    Excess Bregman Information  \\\n",
       "                               mean      mean      mean                mean   \n",
       "InD      OOD                                                                  \n",
       "cifar10  blurred_cifar10   0.006442  0.006611  0.005935            0.005891   \n",
       "         blurred_cifar100  0.003562  0.003956  0.003338            0.003436   \n",
       "         cifar100          0.001507  0.001601  0.002024            0.002099   \n",
       "         svhn              0.008192  0.008565  0.012615            0.012789   \n",
       "cifar100 blurred_cifar10   0.002339  0.002418  0.003323            0.003347   \n",
       "         blurred_cifar100  0.002993  0.002983  0.003523            0.003517   \n",
       "         cifar10           0.001952  0.002040  0.002564            0.002533   \n",
       "         svhn              0.012836  0.013518  0.011459            0.011956   \n",
       "\n",
       "                          Reverse Bregman Information  \\\n",
       "                                                 mean   \n",
       "InD      OOD                                            \n",
       "cifar10  blurred_cifar10                     0.005872   \n",
       "         blurred_cifar100                    0.003308   \n",
       "         cifar100                            0.002023   \n",
       "         svhn                                0.012252   \n",
       "cifar100 blurred_cifar10                     0.003238   \n",
       "         blurred_cifar100                    0.003530   \n",
       "         cifar10                             0.002558   \n",
       "         svhn                                0.010805   \n",
       "\n",
       "                          Expected Pairwise Bregman Information      Bias  \\\n",
       "                                                           mean      mean   \n",
       "InD      OOD                                                                \n",
       "cifar10  blurred_cifar10                               0.006041  0.003605   \n",
       "         blurred_cifar100                              0.003270  0.002391   \n",
       "         cifar100                                      0.001951  0.000989   \n",
       "         svhn                                          0.012804  0.007289   \n",
       "cifar100 blurred_cifar10                               0.003386  0.001702   \n",
       "         blurred_cifar100                              0.003520  0.002047   \n",
       "         cifar10                                       0.002602  0.001420   \n",
       "         svhn                                          0.011618  0.008487   \n",
       "\n",
       "                                 MV      MVBI    BiasBI  \n",
       "                               mean      mean      mean  \n",
       "InD      OOD                                             \n",
       "cifar10  blurred_cifar10   0.004097  0.005891  0.006064  \n",
       "         blurred_cifar100  0.001660  0.003428  0.002985  \n",
       "         cifar100          0.001151  0.002105  0.001565  \n",
       "         svhn              0.005276  0.012772  0.008323  \n",
       "cifar100 blurred_cifar10   0.002440  0.003384  0.003184  \n",
       "         blurred_cifar100  0.002367  0.003543  0.003348  \n",
       "         cifar10           0.001675  0.002542  0.002373  \n",
       "         svhn              0.007698  0.011892  0.012537  "
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "other_agg_df_std"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ddf31a8b-f1da-4e2e-93db-8b1cc2253c8a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7dfbc2b8-36fb-49fa-a739-4b5a5d48a1b6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "e8d4cea9-c214-43b2-811c-99e04efcb8ab",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Bayes</th>\n",
       "      <th>Excess</th>\n",
       "      <th>Total</th>\n",
       "      <th>BI</th>\n",
       "      <th>RBI</th>\n",
       "      <th>EPBI</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>InD</th>\n",
       "      <th>OOD</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">CIFAR10</th>\n",
       "      <th>Blurred CIFAR10</th>\n",
       "      <td>81.04</td>\n",
       "      <td>84.23</td>\n",
       "      <td>82.63</td>\n",
       "      <td>84.12</td>\n",
       "      <td>84.30</td>\n",
       "      <td>84.28</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Blurred CIFAR100</th>\n",
       "      <td>92.65</td>\n",
       "      <td>93.41</td>\n",
       "      <td>93.57</td>\n",
       "      <td>93.48</td>\n",
       "      <td>93.34</td>\n",
       "      <td>93.41</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CIFAR100</th>\n",
       "      <td>89.64</td>\n",
       "      <td>88.34</td>\n",
       "      <td>89.50</td>\n",
       "      <td>88.49</td>\n",
       "      <td>88.21</td>\n",
       "      <td>88.31</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SVHN</th>\n",
       "      <td>93.30</td>\n",
       "      <td>91.81</td>\n",
       "      <td>93.22</td>\n",
       "      <td>91.94</td>\n",
       "      <td>91.70</td>\n",
       "      <td>91.79</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">CIFAR100</th>\n",
       "      <th>Blurred CIFAR10</th>\n",
       "      <td>86.17</td>\n",
       "      <td>84.09</td>\n",
       "      <td>88.50</td>\n",
       "      <td>84.38</td>\n",
       "      <td>83.75</td>\n",
       "      <td>84.13</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Blurred CIFAR100</th>\n",
       "      <td>70.15</td>\n",
       "      <td>74.70</td>\n",
       "      <td>72.73</td>\n",
       "      <td>74.24</td>\n",
       "      <td>74.96</td>\n",
       "      <td>74.91</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CIFAR10</th>\n",
       "      <td>78.00</td>\n",
       "      <td>70.97</td>\n",
       "      <td>78.09</td>\n",
       "      <td>71.68</td>\n",
       "      <td>70.38</td>\n",
       "      <td>70.86</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SVHN</th>\n",
       "      <td>83.68</td>\n",
       "      <td>74.73</td>\n",
       "      <td>83.98</td>\n",
       "      <td>75.43</td>\n",
       "      <td>74.11</td>\n",
       "      <td>74.66</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                           Bayes  Excess  Total     BI    RBI   EPBI\n",
       "InD      OOD                                                        \n",
       "CIFAR10  Blurred CIFAR10   81.04   84.23  82.63  84.12  84.30  84.28\n",
       "         Blurred CIFAR100  92.65   93.41  93.57  93.48  93.34  93.41\n",
       "         CIFAR100          89.64   88.34  89.50  88.49  88.21  88.31\n",
       "         SVHN              93.30   91.81  93.22  91.94  91.70  91.79\n",
       "CIFAR100 Blurred CIFAR10   86.17   84.09  88.50  84.38  83.75  84.13\n",
       "         Blurred CIFAR100  70.15   74.70  72.73  74.24  74.96  74.91\n",
       "         CIFAR10           78.00   70.97  78.09  71.68  70.38  70.86\n",
       "         SVHN              83.68   74.73  83.98  75.43  74.11  74.66"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{center}\n",
      "\\begin{tabular}{llrrrrrr}\n",
      "\\toprule\n",
      "\\multicolumn{2}{c}{Dataset} & \\multicolumn{5}{c}{Metrics} \\\\\n",
      "\\cmidrule(lr){1-2} \\cmidrule(lr){3-7}\n",
      " &  & Bayes & Excess & Total & BI & RBI & EPBI \\\\\n",
      "InD & OOD &  &  &  &  &  &  \\\\\n",
      "\\midrule\n",
      "\\rowcolor{gray!10}\n",
      "\\multirow[t]{4}{*}{CIFAR10} & Blurred CIFAR10 & 81.04 & 84.23 & 82.63 & 84.12 & 84.30 & 84.28 \\\\\n",
      " & Blurred CIFAR100 & 92.65 & 93.41 & 93.57 & 93.48 & 93.34 & 93.41 \\\\\n",
      " & CIFAR100 & 89.64 & 88.34 & 89.50 & 88.49 & 88.21 & 88.31 \\\\\n",
      " & SVHN & 93.30 & 91.81 & 93.22 & 91.94 & 91.70 & 91.79 \\\\\n",
      "\\cline{1-8}\n",
      "\\multirow[t]{4}{*}{CIFAR100} & Blurred CIFAR10 & 86.17 & 84.09 & 88.50 & 84.38 & 83.75 & 84.13 \\\\\n",
      " & Blurred CIFAR100 & 70.15 & 74.70 & 72.73 & 74.24 & 74.96 & 74.91 \\\\\n",
      " & CIFAR10 & 78.00 & 70.97 & 78.09 & 71.68 & 70.38 & 70.86 \\\\\n",
      " & SVHN & 83.68 & 74.73 & 83.98 & 75.43 & 74.11 & 74.66 \\\\\n",
      "\\cline{1-8}\n",
      "\\end{tabular}\n",
      "\\end{center}\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "nice_logscore = get_nice_df(logscore_agg_df_mean[measures].copy())\n",
    "enhanced_latex = enhance_latex_table(nice_logscore[1])\n",
    "print(enhanced_latex)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "f67b65aa-a388-468c-9948-3341ff663c41",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Bayes</th>\n",
       "      <th>Excess</th>\n",
       "      <th>Total</th>\n",
       "      <th>BI</th>\n",
       "      <th>RBI</th>\n",
       "      <th>EPBI</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>InD</th>\n",
       "      <th>OOD</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">CIFAR10</th>\n",
       "      <th>Blurred CIFAR10</th>\n",
       "      <td>0.67</td>\n",
       "      <td>0.64</td>\n",
       "      <td>0.65</td>\n",
       "      <td>0.65</td>\n",
       "      <td>0.64</td>\n",
       "      <td>0.64</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Blurred CIFAR100</th>\n",
       "      <td>0.42</td>\n",
       "      <td>0.27</td>\n",
       "      <td>0.36</td>\n",
       "      <td>0.27</td>\n",
       "      <td>0.26</td>\n",
       "      <td>0.26</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CIFAR100</th>\n",
       "      <td>0.16</td>\n",
       "      <td>0.18</td>\n",
       "      <td>0.15</td>\n",
       "      <td>0.18</td>\n",
       "      <td>0.18</td>\n",
       "      <td>0.18</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SVHN</th>\n",
       "      <td>0.92</td>\n",
       "      <td>0.87</td>\n",
       "      <td>0.84</td>\n",
       "      <td>0.88</td>\n",
       "      <td>0.87</td>\n",
       "      <td>0.87</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">CIFAR100</th>\n",
       "      <th>Blurred CIFAR10</th>\n",
       "      <td>0.27</td>\n",
       "      <td>0.39</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.39</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.39</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Blurred CIFAR100</th>\n",
       "      <td>0.33</td>\n",
       "      <td>0.40</td>\n",
       "      <td>0.34</td>\n",
       "      <td>0.39</td>\n",
       "      <td>0.41</td>\n",
       "      <td>0.41</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CIFAR10</th>\n",
       "      <td>0.23</td>\n",
       "      <td>0.34</td>\n",
       "      <td>0.22</td>\n",
       "      <td>0.32</td>\n",
       "      <td>0.36</td>\n",
       "      <td>0.34</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SVHN</th>\n",
       "      <td>1.41</td>\n",
       "      <td>1.75</td>\n",
       "      <td>1.36</td>\n",
       "      <td>1.68</td>\n",
       "      <td>1.80</td>\n",
       "      <td>1.77</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                           Bayes  Excess  Total    BI   RBI  EPBI\n",
       "InD      OOD                                                     \n",
       "CIFAR10  Blurred CIFAR10    0.67    0.64   0.65  0.65  0.64  0.64\n",
       "         Blurred CIFAR100   0.42    0.27   0.36  0.27  0.26  0.26\n",
       "         CIFAR100           0.16    0.18   0.15  0.18  0.18  0.18\n",
       "         SVHN               0.92    0.87   0.84  0.88  0.87  0.87\n",
       "CIFAR100 Blurred CIFAR10    0.27    0.39   0.25  0.39  0.40  0.39\n",
       "         Blurred CIFAR100   0.33    0.40   0.34  0.39  0.41  0.41\n",
       "         CIFAR10            0.23    0.34   0.22  0.32  0.36  0.34\n",
       "         SVHN               1.41    1.75   1.36  1.68  1.80  1.77"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{center}\n",
      "\\begin{tabular}{llrrrrrr}\n",
      "\\toprule\n",
      "\\multicolumn{2}{c}{Dataset} & \\multicolumn{5}{c}{Metrics} \\\\\n",
      "\\cmidrule(lr){1-2} \\cmidrule(lr){3-7}\n",
      " &  & Bayes & Excess & Total & BI & RBI & EPBI \\\\\n",
      "InD & OOD &  &  &  &  &  &  \\\\\n",
      "\\midrule\n",
      "\\rowcolor{gray!10}\n",
      "\\multirow[t]{4}{*}{CIFAR10} & Blurred CIFAR10 & 0.67 & 0.64 & 0.65 & 0.65 & 0.64 & 0.64 \\\\\n",
      " & Blurred CIFAR100 & 0.42 & 0.27 & 0.36 & 0.27 & 0.26 & 0.26 \\\\\n",
      " & CIFAR100 & 0.16 & 0.18 & 0.15 & 0.18 & 0.18 & 0.18 \\\\\n",
      " & SVHN & 0.92 & 0.87 & 0.84 & 0.88 & 0.87 & 0.87 \\\\\n",
      "\\cline{1-8}\n",
      "\\multirow[t]{4}{*}{CIFAR100} & Blurred CIFAR10 & 0.27 & 0.39 & 0.25 & 0.39 & 0.40 & 0.39 \\\\\n",
      " & Blurred CIFAR100 & 0.33 & 0.40 & 0.34 & 0.39 & 0.41 & 0.41 \\\\\n",
      " & CIFAR10 & 0.23 & 0.34 & 0.22 & 0.32 & 0.36 & 0.34 \\\\\n",
      " & SVHN & 1.41 & 1.75 & 1.36 & 1.68 & 1.80 & 1.77 \\\\\n",
      "\\cline{1-8}\n",
      "\\end{tabular}\n",
      "\\end{center}\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "nice_logscore = get_nice_df(logscore_agg_df_std[measures].copy())\n",
    "enhanced_latex = enhance_latex_table(nice_logscore[1])\n",
    "print(enhanced_latex)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7fbe9b98-3564-4b10-891f-7dc8fd884ac9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7dd398f9-0eee-49ca-bb81-82ddce26e760",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "737587b4-3997-4ee4-96be-0e8e678feacb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "26499db7-1408-4840-ac55-e5e8783d78ff",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Bayes</th>\n",
       "      <th>Excess</th>\n",
       "      <th>Total</th>\n",
       "      <th>BI</th>\n",
       "      <th>RBI</th>\n",
       "      <th>EPBI</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>InD</th>\n",
       "      <th>OOD</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">CIFAR10</th>\n",
       "      <th>Blurred CIFAR10</th>\n",
       "      <td>81.12</td>\n",
       "      <td>79.79</td>\n",
       "      <td>82.27</td>\n",
       "      <td>79.81</td>\n",
       "      <td>79.65</td>\n",
       "      <td>79.90</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Blurred CIFAR100</th>\n",
       "      <td>92.49</td>\n",
       "      <td>89.73</td>\n",
       "      <td>93.26</td>\n",
       "      <td>89.83</td>\n",
       "      <td>89.52</td>\n",
       "      <td>89.85</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CIFAR100</th>\n",
       "      <td>89.40</td>\n",
       "      <td>83.73</td>\n",
       "      <td>89.34</td>\n",
       "      <td>83.79</td>\n",
       "      <td>83.65</td>\n",
       "      <td>83.76</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SVHN</th>\n",
       "      <td>93.04</td>\n",
       "      <td>87.47</td>\n",
       "      <td>93.00</td>\n",
       "      <td>87.54</td>\n",
       "      <td>87.37</td>\n",
       "      <td>87.49</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">CIFAR100</th>\n",
       "      <th>Blurred CIFAR10</th>\n",
       "      <td>85.56</td>\n",
       "      <td>77.46</td>\n",
       "      <td>87.13</td>\n",
       "      <td>78.18</td>\n",
       "      <td>76.45</td>\n",
       "      <td>77.75</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Blurred CIFAR100</th>\n",
       "      <td>69.64</td>\n",
       "      <td>70.11</td>\n",
       "      <td>71.36</td>\n",
       "      <td>70.01</td>\n",
       "      <td>69.96</td>\n",
       "      <td>70.37</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CIFAR10</th>\n",
       "      <td>77.88</td>\n",
       "      <td>69.05</td>\n",
       "      <td>77.94</td>\n",
       "      <td>69.55</td>\n",
       "      <td>68.56</td>\n",
       "      <td>69.05</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SVHN</th>\n",
       "      <td>82.70</td>\n",
       "      <td>69.91</td>\n",
       "      <td>82.50</td>\n",
       "      <td>70.49</td>\n",
       "      <td>69.42</td>\n",
       "      <td>69.82</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                           Bayes  Excess  Total     BI    RBI   EPBI\n",
       "InD      OOD                                                        \n",
       "CIFAR10  Blurred CIFAR10   81.12   79.79  82.27  79.81  79.65  79.90\n",
       "         Blurred CIFAR100  92.49   89.73  93.26  89.83  89.52  89.85\n",
       "         CIFAR100          89.40   83.73  89.34  83.79  83.65  83.76\n",
       "         SVHN              93.04   87.47  93.00  87.54  87.37  87.49\n",
       "CIFAR100 Blurred CIFAR10   85.56   77.46  87.13  78.18  76.45  77.75\n",
       "         Blurred CIFAR100  69.64   70.11  71.36  70.01  69.96  70.37\n",
       "         CIFAR10           77.88   69.05  77.94  69.55  68.56  69.05\n",
       "         SVHN              82.70   69.91  82.50  70.49  69.42  69.82"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{center}\n",
      "\\begin{tabular}{llrrrrrr}\n",
      "\\toprule\n",
      "\\multicolumn{2}{c}{Dataset} & \\multicolumn{5}{c}{Metrics} \\\\\n",
      "\\cmidrule(lr){1-2} \\cmidrule(lr){3-7}\n",
      " &  & Bayes & Excess & Total & BI & RBI & EPBI \\\\\n",
      "InD & OOD &  &  &  &  &  &  \\\\\n",
      "\\midrule\n",
      "\\rowcolor{gray!10}\n",
      "\\multirow[t]{4}{*}{CIFAR10} & Blurred CIFAR10 & 81.12 & 79.79 & 82.27 & 79.81 & 79.65 & 79.90 \\\\\n",
      " & Blurred CIFAR100 & 92.49 & 89.73 & 93.26 & 89.83 & 89.52 & 89.85 \\\\\n",
      " & CIFAR100 & 89.40 & 83.73 & 89.34 & 83.79 & 83.65 & 83.76 \\\\\n",
      " & SVHN & 93.04 & 87.47 & 93.00 & 87.54 & 87.37 & 87.49 \\\\\n",
      "\\cline{1-8}\n",
      "\\multirow[t]{4}{*}{CIFAR100} & Blurred CIFAR10 & 85.56 & 77.46 & 87.13 & 78.18 & 76.45 & 77.75 \\\\\n",
      " & Blurred CIFAR100 & 69.64 & 70.11 & 71.36 & 70.01 & 69.96 & 70.37 \\\\\n",
      " & CIFAR10 & 77.88 & 69.05 & 77.94 & 69.55 & 68.56 & 69.05 \\\\\n",
      " & SVHN & 82.70 & 69.91 & 82.50 & 70.49 & 69.42 & 69.82 \\\\\n",
      "\\cline{1-8}\n",
      "\\end{tabular}\n",
      "\\end{center}\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "nice_other = get_nice_df(other_agg_df_mean[measures].copy())\n",
    "enhanced_latex = enhance_latex_table(nice_other[1])\n",
    "print(enhanced_latex)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "b17014ce-f27f-42d5-90d0-91b16eef7eb2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>Bayes</th>\n",
       "      <th>Excess</th>\n",
       "      <th>Total</th>\n",
       "      <th>BI</th>\n",
       "      <th>RBI</th>\n",
       "      <th>EPBI</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>InD</th>\n",
       "      <th>OOD</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">CIFAR10</th>\n",
       "      <th>Blurred CIFAR10</th>\n",
       "      <td>0.66</td>\n",
       "      <td>0.59</td>\n",
       "      <td>0.64</td>\n",
       "      <td>0.59</td>\n",
       "      <td>0.59</td>\n",
       "      <td>0.60</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Blurred CIFAR100</th>\n",
       "      <td>0.40</td>\n",
       "      <td>0.33</td>\n",
       "      <td>0.36</td>\n",
       "      <td>0.34</td>\n",
       "      <td>0.33</td>\n",
       "      <td>0.33</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CIFAR100</th>\n",
       "      <td>0.16</td>\n",
       "      <td>0.20</td>\n",
       "      <td>0.15</td>\n",
       "      <td>0.21</td>\n",
       "      <td>0.20</td>\n",
       "      <td>0.20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SVHN</th>\n",
       "      <td>0.86</td>\n",
       "      <td>1.26</td>\n",
       "      <td>0.82</td>\n",
       "      <td>1.28</td>\n",
       "      <td>1.23</td>\n",
       "      <td>1.28</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">CIFAR100</th>\n",
       "      <th>Blurred CIFAR10</th>\n",
       "      <td>0.24</td>\n",
       "      <td>0.33</td>\n",
       "      <td>0.23</td>\n",
       "      <td>0.33</td>\n",
       "      <td>0.32</td>\n",
       "      <td>0.34</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Blurred CIFAR100</th>\n",
       "      <td>0.30</td>\n",
       "      <td>0.35</td>\n",
       "      <td>0.30</td>\n",
       "      <td>0.35</td>\n",
       "      <td>0.35</td>\n",
       "      <td>0.35</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CIFAR10</th>\n",
       "      <td>0.20</td>\n",
       "      <td>0.26</td>\n",
       "      <td>0.20</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.26</td>\n",
       "      <td>0.26</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SVHN</th>\n",
       "      <td>1.35</td>\n",
       "      <td>1.15</td>\n",
       "      <td>1.28</td>\n",
       "      <td>1.20</td>\n",
       "      <td>1.08</td>\n",
       "      <td>1.16</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                           Bayes  Excess  Total    BI   RBI  EPBI\n",
       "InD      OOD                                                     \n",
       "CIFAR10  Blurred CIFAR10    0.66    0.59   0.64  0.59  0.59  0.60\n",
       "         Blurred CIFAR100   0.40    0.33   0.36  0.34  0.33  0.33\n",
       "         CIFAR100           0.16    0.20   0.15  0.21  0.20  0.20\n",
       "         SVHN               0.86    1.26   0.82  1.28  1.23  1.28\n",
       "CIFAR100 Blurred CIFAR10    0.24    0.33   0.23  0.33  0.32  0.34\n",
       "         Blurred CIFAR100   0.30    0.35   0.30  0.35  0.35  0.35\n",
       "         CIFAR10            0.20    0.26   0.20  0.25  0.26  0.26\n",
       "         SVHN               1.35    1.15   1.28  1.20  1.08  1.16"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{center}\n",
      "\\begin{tabular}{llrrrrrr}\n",
      "\\toprule\n",
      "\\multicolumn{2}{c}{Dataset} & \\multicolumn{5}{c}{Metrics} \\\\\n",
      "\\cmidrule(lr){1-2} \\cmidrule(lr){3-7}\n",
      " &  & Bayes & Excess & Total & BI & RBI & EPBI \\\\\n",
      "InD & OOD &  &  &  &  &  &  \\\\\n",
      "\\midrule\n",
      "\\rowcolor{gray!10}\n",
      "\\multirow[t]{4}{*}{CIFAR10} & Blurred CIFAR10 & 0.66 & 0.59 & 0.64 & 0.59 & 0.59 & 0.60 \\\\\n",
      " & Blurred CIFAR100 & 0.40 & 0.33 & 0.36 & 0.34 & 0.33 & 0.33 \\\\\n",
      " & CIFAR100 & 0.16 & 0.20 & 0.15 & 0.21 & 0.20 & 0.20 \\\\\n",
      " & SVHN & 0.86 & 1.26 & 0.82 & 1.28 & 1.23 & 1.28 \\\\\n",
      "\\cline{1-8}\n",
      "\\multirow[t]{4}{*}{CIFAR100} & Blurred CIFAR10 & 0.24 & 0.33 & 0.23 & 0.33 & 0.32 & 0.34 \\\\\n",
      " & Blurred CIFAR100 & 0.30 & 0.35 & 0.30 & 0.35 & 0.35 & 0.35 \\\\\n",
      " & CIFAR10 & 0.20 & 0.26 & 0.20 & 0.25 & 0.26 & 0.26 \\\\\n",
      " & SVHN & 1.35 & 1.15 & 1.28 & 1.20 & 1.08 & 1.16 \\\\\n",
      "\\cline{1-8}\n",
      "\\end{tabular}\n",
      "\\end{center}\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "nice_other = get_nice_df(other_agg_df_std[measures].copy())\n",
    "enhanced_latex = enhance_latex_table(nice_other[1])\n",
    "print(enhanced_latex)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e7f20e3f-51e0-4739-bc64-0bd005a150e6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4ff2bae5-cca2-45fa-b1bb-52cde1144165",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "61e23aa9-6693-4398-a07b-918dfcd482bd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8b484935-7520-4e96-a68b-7d8391396c9b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "fa601829-851f-4753-ad42-527563924669",
   "metadata": {},
   "outputs": [],
   "source": [
    "def collect_scores_into_dict_miss_with_std(\n",
    "    dataframes_list_,\n",
    "):\n",
    "    scores_dict_ = defaultdict(\n",
    "        list, {val: [] for val in dataframes_list_[0].RiskType.unique()}\n",
    "    )\n",
    "    std_dict_ = defaultdict(\n",
    "        list, {val: [] for val in dataframes_list_[0].RiskType.unique()}\n",
    "    )\n",
    "\n",
    "    for dataframe_ in dataframes_list_:\n",
    "        for ind in dataframe_.training_dataset.unique():\n",
    "            df_aux_ = dataframe_[(dataframe_[\"training_dataset\"] == ind)]\n",
    "\n",
    "            mean_rocauc_dict = dict(\n",
    "                df_aux_.groupby(by=[\"RiskType\"])\n",
    "                .agg({\"RocAucScoresMean\": [\"mean\"]})[(\"RocAucScoresMean\", \"mean\")]\n",
    "                .reset_index()\n",
    "                .values\n",
    "            )\n",
    "            std_rocauc_dict = dict(\n",
    "                df_aux_.groupby(by=[\"RiskType\"])\n",
    "                .agg({\"RocAucScoresStd\": [\"mean\"]})[(\"RocAucScoresStd\", \"mean\")]\n",
    "                .reset_index()\n",
    "                .values\n",
    "            )\n",
    "            next_iter = True\n",
    "            for k in mean_rocauc_dict:\n",
    "                if k in scores_dict_:\n",
    "                    scores_dict_[k].append(mean_rocauc_dict[k])\n",
    "                    std_dict_[k].append(std_rocauc_dict[k])\n",
    "                    next_iter = False\n",
    "            if next_iter:\n",
    "                continue\n",
    "\n",
    "            scores_dict_[\"InD\"].append(ind)\n",
    "            scores_dict_[\"ScoringRule\"].append(df_aux_[\"LossFunction\"].unique())\n",
    "\n",
    "            std_dict_[\"InD\"].append(ind)\n",
    "            std_dict_[\"ScoringRule\"].append(df_aux_[\"LossFunction\"].unique())\n",
    "    return scores_dict_, std_dict_"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "03846156-d9de-4c29-8951-41066931e718",
   "metadata": {},
   "outputs": [],
   "source": [
    "from collections import defaultdict"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "ed239a3c-2f41-468c-978d-7d70149f6927",
   "metadata": {},
   "outputs": [],
   "source": [
    "full_mis_rocauc = pd.read_csv(\"./tables/full_mis_rocauc_with_std.csv\", index_col=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "577d03d7-6929-4ff2-b40e-7051829bec07",
   "metadata": {},
   "outputs": [],
   "source": [
    "full_mis_rocauc = full_mis_rocauc[~full_mis_rocauc.UQMetric.str.endswith(\"Inner Inner\")]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "dfcc6f11-cb8d-449c-9821-259f39c3ef78",
   "metadata": {},
   "outputs": [],
   "source": [
    "# DROP NEGLOG\n",
    "\n",
    "full_mis_rocauc = full_mis_rocauc[full_mis_rocauc.base_rule != \"Neglog\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "21244113-c407-477b-b915-01da43bc1d47",
   "metadata": {},
   "outputs": [],
   "source": [
    "grouped_df = extract_logscore_others_dataframes_modified(\n",
    "    dataframe_=full_mis_rocauc,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2921e040-fe9f-40d4-930e-7ebe7595c292",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "2af9fbb1-764c-46f5-aa05-9670db2521fc",
   "metadata": {},
   "outputs": [],
   "source": [
    "logscore_dict_mean, logscore_dict_std = collect_scores_into_dict_miss_with_std(\n",
    "    dataframes_list_=[\n",
    "        grouped_df.logscore,\n",
    "    ],\n",
    ")\n",
    "logscore_df_mean = pd.DataFrame.from_dict(logscore_dict_mean)\n",
    "logscore_df_std = pd.DataFrame.from_dict(logscore_dict_std)\n",
    "\n",
    "logscore_agg_df_mean = aggregate_over_measures(\n",
    "    dataframe_=logscore_df_mean,\n",
    "    agg_func_=\"mean\",\n",
    "    by_=[\"InD\"],\n",
    ")\n",
    "\n",
    "logscore_agg_df_std = aggregate_over_measures(\n",
    "    dataframe_=logscore_df_std,\n",
    "    agg_func_=\"mean\",\n",
    "    by_=[\"InD\"],\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "05150300-ce9c-4689-b61e-d497cb9a24d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "other_dict_mean, other_dict_std = collect_scores_into_dict_miss_with_std(\n",
    "    dataframes_list_=[\n",
    "        grouped_df.others,\n",
    "    ],\n",
    ")\n",
    "other_df_mean = pd.DataFrame.from_dict(other_dict_mean)\n",
    "other_df_std = pd.DataFrame.from_dict(other_dict_std)\n",
    "\n",
    "other_agg_df_mean = aggregate_over_measures(\n",
    "    dataframe_=other_df_mean,\n",
    "    agg_func_=\"mean\",\n",
    "    by_=[\"InD\"],\n",
    ")\n",
    "\n",
    "other_agg_df_std = aggregate_over_measures(\n",
    "    dataframe_=other_df_std,\n",
    "    agg_func_=\"mean\",\n",
    "    by_=[\"InD\"],\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "825d511b-5a79-4a08-8d61-18fd3d14cad2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "c70820ee-dd78-4457-b806-3df6a10e69dc",
   "metadata": {},
   "outputs": [],
   "source": [
    "def enhance_latex_table(input_latex):\n",
    "    lines = input_latex.split(\"\\n\")\n",
    "    enhanced_lines = []\n",
    "\n",
    "    for i, line in enumerate(lines):\n",
    "        if \"\\\\toprule\" in line:\n",
    "            # Add multicolumn headers\n",
    "            enhanced_lines.append(line)\n",
    "            enhanced_lines.append(\n",
    "                r\"\\multicolumn{2}{c}{Dataset} & \\multicolumn{5}{c}{Metrics} \\\\\"\n",
    "            )\n",
    "            enhanced_lines.append(r\"\\cmidrule(lr){1-2} \\cmidrule(lr){3-7}\")\n",
    "            continue\n",
    "\n",
    "        # Add row coloring\n",
    "        if \"\\\\midrule\" in line:\n",
    "            enhanced_lines.append(line)\n",
    "            enhanced_lines.append(r\"\\rowcolor{gray!10}\")\n",
    "        elif \"\\\\bottomrule\" in line:\n",
    "            enhanced_lines.append(r\"\\end{tabular}\")\n",
    "        else:\n",
    "            enhanced_lines.append(line)\n",
    "\n",
    "    return \"\\n\".join(enhanced_lines)\n",
    "\n",
    "\n",
    "def get_nice_df(df_):\n",
    "    df_.index = pd.Index(\n",
    "        data=[\n",
    "            \"CIFAR10\",\n",
    "            \"CIFAR100\",\n",
    "            \"Missed class CIFAR10\",\n",
    "            \"Noisy CIFAR10\",\n",
    "            \"Noisy CIFAR100\",\n",
    "        ],\n",
    "        name=\"InD\",\n",
    "    )\n",
    "    df_.columns = [\n",
    "        \"Bayes\",\n",
    "        \"Excess\",\n",
    "        \"Total\",\n",
    "        # 'Bayes(O)',\n",
    "        # 'Bayes(I)',\n",
    "        # 'Total(O)',\n",
    "        # 'Total(I)',\n",
    "        \"BI\",\n",
    "        \"RBI\",\n",
    "        \"EPBI\",\n",
    "        # 'Bias',\n",
    "        # 'MV',\n",
    "        # 'MVBI',\n",
    "        # 'BiasBI',\n",
    "    ]\n",
    "    # df_ = df_[['Bayes', 'Excess', 'Total', 'BI', 'RBI']]\n",
    "    df_ = (100 * df_).round(2)\n",
    "\n",
    "    display(df_)\n",
    "\n",
    "    return df_, df_.to_latex(float_format=\"%.2f\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d10eb58d-5e42-46f0-95a5-c7e1659f493f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "c7025ed6-5f7f-4306-9149-4b9375300644",
   "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>Bayes</th>\n",
       "      <th>Excess</th>\n",
       "      <th>Total</th>\n",
       "      <th>BI</th>\n",
       "      <th>RBI</th>\n",
       "      <th>EPBI</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>InD</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>CIFAR10</th>\n",
       "      <td>93.57</td>\n",
       "      <td>92.97</td>\n",
       "      <td>93.77</td>\n",
       "      <td>93.05</td>\n",
       "      <td>92.89</td>\n",
       "      <td>92.95</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CIFAR100</th>\n",
       "      <td>85.63</td>\n",
       "      <td>80.21</td>\n",
       "      <td>85.93</td>\n",
       "      <td>81.10</td>\n",
       "      <td>79.48</td>\n",
       "      <td>80.06</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Missed class CIFAR10</th>\n",
       "      <td>90.05</td>\n",
       "      <td>90.72</td>\n",
       "      <td>91.27</td>\n",
       "      <td>90.44</td>\n",
       "      <td>90.87</td>\n",
       "      <td>90.86</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Noisy CIFAR10</th>\n",
       "      <td>79.33</td>\n",
       "      <td>66.75</td>\n",
       "      <td>78.45</td>\n",
       "      <td>67.30</td>\n",
       "      <td>66.27</td>\n",
       "      <td>66.68</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Noisy CIFAR100</th>\n",
       "      <td>80.94</td>\n",
       "      <td>68.96</td>\n",
       "      <td>80.87</td>\n",
       "      <td>69.75</td>\n",
       "      <td>68.25</td>\n",
       "      <td>68.88</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                      Bayes  Excess  Total     BI    RBI   EPBI\n",
       "InD                                                            \n",
       "CIFAR10               93.57   92.97  93.77  93.05  92.89  92.95\n",
       "CIFAR100              85.63   80.21  85.93  81.10  79.48  80.06\n",
       "Missed class CIFAR10  90.05   90.72  91.27  90.44  90.87  90.86\n",
       "Noisy CIFAR10         79.33   66.75  78.45  67.30  66.27  66.68\n",
       "Noisy CIFAR100        80.94   68.96  80.87  69.75  68.25  68.88"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{lrrrrrr}\n",
      "\\toprule\n",
      "\\multicolumn{2}{c}{Dataset} & \\multicolumn{5}{c}{Metrics} \\\\\n",
      "\\cmidrule(lr){1-2} \\cmidrule(lr){3-7}\n",
      " & Bayes & Excess & Total & BI & RBI & EPBI \\\\\n",
      "InD &  &  &  &  &  &  \\\\\n",
      "\\midrule\n",
      "\\rowcolor{gray!10}\n",
      "CIFAR10 & 93.57 & 92.97 & 93.77 & 93.05 & 92.89 & 92.95 \\\\\n",
      "CIFAR100 & 85.63 & 80.21 & 85.93 & 81.10 & 79.48 & 80.06 \\\\\n",
      "Missed class CIFAR10 & 90.05 & 90.72 & 91.27 & 90.44 & 90.87 & 90.86 \\\\\n",
      "Noisy CIFAR10 & 79.33 & 66.75 & 78.45 & 67.30 & 66.27 & 66.68 \\\\\n",
      "Noisy CIFAR100 & 80.94 & 68.96 & 80.87 & 69.75 & 68.25 & 68.88 \\\\\n",
      "\\end{tabular}\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "nice_logscore = get_nice_df(logscore_agg_df_mean[measures].copy())\n",
    "enhanced_latex = enhance_latex_table(nice_logscore[1])\n",
    "print(enhanced_latex)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "75431a95-9c85-41a6-be6c-417334297401",
   "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>Bayes</th>\n",
       "      <th>Excess</th>\n",
       "      <th>Total</th>\n",
       "      <th>BI</th>\n",
       "      <th>RBI</th>\n",
       "      <th>EPBI</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>InD</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>CIFAR10</th>\n",
       "      <td>0.22</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.21</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CIFAR100</th>\n",
       "      <td>0.24</td>\n",
       "      <td>0.31</td>\n",
       "      <td>0.22</td>\n",
       "      <td>0.31</td>\n",
       "      <td>0.32</td>\n",
       "      <td>0.31</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Missed class CIFAR10</th>\n",
       "      <td>6.01</td>\n",
       "      <td>3.90</td>\n",
       "      <td>4.05</td>\n",
       "      <td>4.39</td>\n",
       "      <td>3.62</td>\n",
       "      <td>3.69</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Noisy CIFAR10</th>\n",
       "      <td>3.55</td>\n",
       "      <td>6.35</td>\n",
       "      <td>3.78</td>\n",
       "      <td>6.36</td>\n",
       "      <td>6.35</td>\n",
       "      <td>6.34</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Noisy CIFAR100</th>\n",
       "      <td>0.52</td>\n",
       "      <td>0.91</td>\n",
       "      <td>0.54</td>\n",
       "      <td>0.91</td>\n",
       "      <td>0.92</td>\n",
       "      <td>0.91</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                      Bayes  Excess  Total    BI   RBI  EPBI\n",
       "InD                                                         \n",
       "CIFAR10                0.22    0.25   0.21  0.25  0.25  0.25\n",
       "CIFAR100               0.24    0.31   0.22  0.31  0.32  0.31\n",
       "Missed class CIFAR10   6.01    3.90   4.05  4.39  3.62  3.69\n",
       "Noisy CIFAR10          3.55    6.35   3.78  6.36  6.35  6.34\n",
       "Noisy CIFAR100         0.52    0.91   0.54  0.91  0.92  0.91"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{lrrrrrr}\n",
      "\\toprule\n",
      "\\multicolumn{2}{c}{Dataset} & \\multicolumn{5}{c}{Metrics} \\\\\n",
      "\\cmidrule(lr){1-2} \\cmidrule(lr){3-7}\n",
      " & Bayes & Excess & Total & BI & RBI & EPBI \\\\\n",
      "InD &  &  &  &  &  &  \\\\\n",
      "\\midrule\n",
      "\\rowcolor{gray!10}\n",
      "CIFAR10 & 0.22 & 0.25 & 0.21 & 0.25 & 0.25 & 0.25 \\\\\n",
      "CIFAR100 & 0.24 & 0.31 & 0.22 & 0.31 & 0.32 & 0.31 \\\\\n",
      "Missed class CIFAR10 & 6.01 & 3.90 & 4.05 & 4.39 & 3.62 & 3.69 \\\\\n",
      "Noisy CIFAR10 & 3.55 & 6.35 & 3.78 & 6.36 & 6.35 & 6.34 \\\\\n",
      "Noisy CIFAR100 & 0.52 & 0.91 & 0.54 & 0.91 & 0.92 & 0.91 \\\\\n",
      "\\end{tabular}\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "nice_logscore = get_nice_df(logscore_agg_df_std[measures].copy())\n",
    "enhanced_latex = enhance_latex_table(nice_logscore[1])\n",
    "print(enhanced_latex)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "28962b2f-3f23-4d88-a0bf-802df919e727",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "72319cd6-8c8d-40a0-820a-da1920add368",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "542c1b08-fd3f-4c65-88e2-70bdb2dad4f9",
   "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>Bayes</th>\n",
       "      <th>Excess</th>\n",
       "      <th>Total</th>\n",
       "      <th>BI</th>\n",
       "      <th>RBI</th>\n",
       "      <th>EPBI</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>InD</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>CIFAR10</th>\n",
       "      <td>93.64</td>\n",
       "      <td>89.25</td>\n",
       "      <td>93.96</td>\n",
       "      <td>89.38</td>\n",
       "      <td>89.03</td>\n",
       "      <td>89.35</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CIFAR100</th>\n",
       "      <td>86.62</td>\n",
       "      <td>79.25</td>\n",
       "      <td>87.21</td>\n",
       "      <td>80.24</td>\n",
       "      <td>78.07</td>\n",
       "      <td>79.44</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Missed class CIFAR10</th>\n",
       "      <td>90.21</td>\n",
       "      <td>87.70</td>\n",
       "      <td>91.48</td>\n",
       "      <td>87.83</td>\n",
       "      <td>87.52</td>\n",
       "      <td>87.74</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Noisy CIFAR10</th>\n",
       "      <td>79.13</td>\n",
       "      <td>75.47</td>\n",
       "      <td>80.36</td>\n",
       "      <td>75.77</td>\n",
       "      <td>74.91</td>\n",
       "      <td>75.71</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Noisy CIFAR100</th>\n",
       "      <td>84.11</td>\n",
       "      <td>72.51</td>\n",
       "      <td>84.14</td>\n",
       "      <td>73.27</td>\n",
       "      <td>71.83</td>\n",
       "      <td>72.42</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                      Bayes  Excess  Total     BI    RBI   EPBI\n",
       "InD                                                            \n",
       "CIFAR10               93.64   89.25  93.96  89.38  89.03  89.35\n",
       "CIFAR100              86.62   79.25  87.21  80.24  78.07  79.44\n",
       "Missed class CIFAR10  90.21   87.70  91.48  87.83  87.52  87.74\n",
       "Noisy CIFAR10         79.13   75.47  80.36  75.77  74.91  75.71\n",
       "Noisy CIFAR100        84.11   72.51  84.14  73.27  71.83  72.42"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{lrrrrrr}\n",
      "\\toprule\n",
      "\\multicolumn{2}{c}{Dataset} & \\multicolumn{5}{c}{Metrics} \\\\\n",
      "\\cmidrule(lr){1-2} \\cmidrule(lr){3-7}\n",
      " & Bayes & Excess & Total & BI & RBI & EPBI \\\\\n",
      "InD &  &  &  &  &  &  \\\\\n",
      "\\midrule\n",
      "\\rowcolor{gray!10}\n",
      "CIFAR10 & 93.64 & 89.25 & 93.96 & 89.38 & 89.03 & 89.35 \\\\\n",
      "CIFAR100 & 86.62 & 79.25 & 87.21 & 80.24 & 78.07 & 79.44 \\\\\n",
      "Missed class CIFAR10 & 90.21 & 87.70 & 91.48 & 87.83 & 87.52 & 87.74 \\\\\n",
      "Noisy CIFAR10 & 79.13 & 75.47 & 80.36 & 75.77 & 74.91 & 75.71 \\\\\n",
      "Noisy CIFAR100 & 84.11 & 72.51 & 84.14 & 73.27 & 71.83 & 72.42 \\\\\n",
      "\\end{tabular}\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "nice_logscore = get_nice_df(other_agg_df_mean[measures].copy())\n",
    "enhanced_latex = enhance_latex_table(nice_logscore[1])\n",
    "print(enhanced_latex)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "26701e36-4983-4e60-a8ab-f413779218c6",
   "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>Bayes</th>\n",
       "      <th>Excess</th>\n",
       "      <th>Total</th>\n",
       "      <th>BI</th>\n",
       "      <th>RBI</th>\n",
       "      <th>EPBI</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>InD</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>CIFAR10</th>\n",
       "      <td>0.23</td>\n",
       "      <td>0.42</td>\n",
       "      <td>0.22</td>\n",
       "      <td>0.45</td>\n",
       "      <td>0.41</td>\n",
       "      <td>0.41</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CIFAR100</th>\n",
       "      <td>0.22</td>\n",
       "      <td>0.32</td>\n",
       "      <td>0.20</td>\n",
       "      <td>0.32</td>\n",
       "      <td>0.32</td>\n",
       "      <td>0.32</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Missed class CIFAR10</th>\n",
       "      <td>5.95</td>\n",
       "      <td>2.81</td>\n",
       "      <td>4.05</td>\n",
       "      <td>2.83</td>\n",
       "      <td>2.73</td>\n",
       "      <td>2.87</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Noisy CIFAR10</th>\n",
       "      <td>2.97</td>\n",
       "      <td>3.73</td>\n",
       "      <td>2.98</td>\n",
       "      <td>3.90</td>\n",
       "      <td>3.65</td>\n",
       "      <td>3.64</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Noisy CIFAR100</th>\n",
       "      <td>0.36</td>\n",
       "      <td>0.73</td>\n",
       "      <td>0.39</td>\n",
       "      <td>0.71</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.73</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                      Bayes  Excess  Total    BI   RBI  EPBI\n",
       "InD                                                         \n",
       "CIFAR10                0.23    0.42   0.22  0.45  0.41  0.41\n",
       "CIFAR100               0.22    0.32   0.20  0.32  0.32  0.32\n",
       "Missed class CIFAR10   5.95    2.81   4.05  2.83  2.73  2.87\n",
       "Noisy CIFAR10          2.97    3.73   2.98  3.90  3.65  3.64\n",
       "Noisy CIFAR100         0.36    0.73   0.39  0.71  0.75  0.73"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{lrrrrrr}\n",
      "\\toprule\n",
      "\\multicolumn{2}{c}{Dataset} & \\multicolumn{5}{c}{Metrics} \\\\\n",
      "\\cmidrule(lr){1-2} \\cmidrule(lr){3-7}\n",
      " & Bayes & Excess & Total & BI & RBI & EPBI \\\\\n",
      "InD &  &  &  &  &  &  \\\\\n",
      "\\midrule\n",
      "\\rowcolor{gray!10}\n",
      "CIFAR10 & 0.23 & 0.42 & 0.22 & 0.45 & 0.41 & 0.41 \\\\\n",
      "CIFAR100 & 0.22 & 0.32 & 0.20 & 0.32 & 0.32 & 0.32 \\\\\n",
      "Missed class CIFAR10 & 5.95 & 2.81 & 4.05 & 2.83 & 2.73 & 2.87 \\\\\n",
      "Noisy CIFAR10 & 2.97 & 3.73 & 2.98 & 3.90 & 3.65 & 3.64 \\\\\n",
      "Noisy CIFAR100 & 0.36 & 0.73 & 0.39 & 0.71 & 0.75 & 0.73 \\\\\n",
      "\\end{tabular}\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "nice_logscore = get_nice_df(other_agg_df_std[measures].copy())\n",
    "enhanced_latex = enhance_latex_table(nice_logscore[1])\n",
    "print(enhanced_latex)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "047affe0-260c-452f-901f-0414db864774",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.11.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
