{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "67bfa368-8bf9-4c6c-b9a5-04abf26f2027",
   "metadata": {},
   "outputs": [
    {
     "ename": "ModuleNotFoundError",
     "evalue": "No module named 'src'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mModuleNotFoundError\u001b[0m                       Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[1], line 10\u001b[0m\n\u001b[1;32m      8\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mrandom\u001b[39;00m\n\u001b[1;32m      9\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mtqdm\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mauto\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m tqdm\n\u001b[0;32m---> 10\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01msrc\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mdata_utils\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m load_model_checkpoint, load_dict, make_load_path\n\u001b[1;32m     11\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01msrc\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mpostprocessing_utils\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m (\n\u001b[1;32m     12\u001b[0m     get_metrics_results,\n\u001b[1;32m     13\u001b[0m     uq_funcs_with_names,\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m     22\u001b[0m     get_sampled_combinations_uncertainty_scores,\n\u001b[1;32m     23\u001b[0m )\n\u001b[1;32m     25\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mmatplotlib\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mpyplot\u001b[39;00m \u001b[38;5;28;01mas\u001b[39;00m \u001b[38;5;21;01mplt\u001b[39;00m\n",
      "\u001b[0;31mModuleNotFoundError\u001b[0m: No module named 'src'"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "import re\n",
    "import os\n",
    "\n",
    "sys.path.insert(0, \"src/\")\n",
    "sys.path.insert(1, \"external_repos/pytorch_cifar100/\")\n",
    "sys.path.insert(1, \"external_repos/pytorch_cifar10/\")\n",
    "import numpy as np\n",
    "import random\n",
    "from tqdm.auto import tqdm\n",
    "from src.data_utils import load_model_checkpoint, load_dict, make_load_path\n",
    "from src.postprocessing_utils import (\n",
    "    get_metrics_results,\n",
    "    uq_funcs_with_names,\n",
    "    get_uncertainty_scores,\n",
    "    get_predicted_labels,\n",
    "    make_aggregation,\n",
    "    get_missclassification_dataframe,\n",
    "    get_ood_detection_dataframe,\n",
    "    get_raw_scores_dataframe,\n",
    "    ravel_df,\n",
    "    create_gt_embeddings,\n",
    "    get_sampled_combinations_uncertainty_scores,\n",
    ")\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import pandas as pd\n",
    "from sklearn.metrics import roc_auc_score\n",
    "from itertools import combinations\n",
    "from IPython.display import display\n",
    "\n",
    "pd.set_option(\"display.max_rows\", None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c303ad2c-4713-4c5d-b0f0-f0f20cc484c9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d8a621f8-f93b-4217-a8c9-a577c2bda2bb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "af5b00b2-9b86-4413-84e0-fa8f58b13e74",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "14841219-db83-4d60-b7fd-702dd98b3e83",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "ebe15e4e-6489-42b8-b6de-85c2f839df52",
   "metadata": {},
   "outputs": [],
   "source": [
    "training_dataset_names = [\n",
    "    \"cifar10\",\n",
    "    \"cifar100\",\n",
    "    \"noisy_cifar100\",\n",
    "    \"missed_class_cifar10\",\n",
    "    \"noisy_cifar10\",\n",
    "]\n",
    "temperature = 1.0\n",
    "model_ids = np.arange(20)\n",
    "list_extraction_datasets = [\n",
    "    \"cifar10\",\n",
    "    \"cifar100\",\n",
    "    \"svhn\",\n",
    "    \"blurred_cifar100\",\n",
    "    \"blurred_cifar10\",\n",
    "]\n",
    "list_ood_datasets = [el for el in list_extraction_datasets]\n",
    "loss_function_names = [\"brier_score\", \"cross_entropy\", \"spherical_score\"]\n",
    "use_different_approximations = False\n",
    "gt_prob_approx = \"same\"\n",
    "\n",
    "full_dataframe = None\n",
    "full_ood_rocauc_dataframe = None\n",
    "full_mis_rocauc_dataframe = None"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "0aaaf68f-b779-4f06-98ac-b814ef7fa4c6",
   "metadata": {},
   "outputs": [],
   "source": [
    "# for training_dataset_name in training_dataset_names:\n",
    "#     if training_dataset_name not in ['missed_class_cifar10', 'noisy_cifar10', 'noisy_cifar100']:\n",
    "#         architectures = ['resnet18', 'vgg']\n",
    "#         training_dataset_name_aux = training_dataset_name\n",
    "#     else:\n",
    "#         architectures = ['resnet18']\n",
    "#         training_dataset_name_aux = training_dataset_name.split('_')[-1]\n",
    "#     for architecture in architectures:\n",
    "#         # try:\n",
    "#         uq_results, embeddings_per_dataset, targets_per_dataset = get_sampled_combinations_uncertainty_scores(\n",
    "#             loss_function_names=loss_function_names,\n",
    "#             training_dataset_name=training_dataset_name,\n",
    "#             architecture=architecture,\n",
    "#             list_extraction_datasets=list_extraction_datasets,\n",
    "#             use_different_approximations=use_different_approximations,\n",
    "#         )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5a143e5c-4b89-48cb-bfd7-0db1f04cc58a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3e361f11-7327-483c-9dfd-6a34fdddf097",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "8beff7c7-0987-4b52-b971-755fe0b21958",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res = load_dict(\n",
    "    \"./external_repos/pytorch_cifar10/checkpoints/resnet18/extracted_information_for_notebook_combinations.pkl\"\n",
    ")\n",
    "len(res[\"uq_results\"][\"Total Brier Outer\"][\"brier_score\"][\"cifar10\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "edcdbe6d-6f8b-4fd6-8917-fb4bd3db93c2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "443b5ccf-85d1-4ea1-8cf5-51e3dd514748",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_ood_detection_dataframe(\n",
    "    ind_dataset: str,\n",
    "    uq_results: dict,\n",
    "    list_ood_datasets: list[str],\n",
    ") -> pd.DataFrame:\n",
    "    \"\"\"\n",
    "    The function transforms uq_results dict into pd.Dataframe\n",
    "    with ROC AUC scores of OOD detection.\n",
    "    \"\"\"\n",
    "    roc_auc_dict = {}\n",
    "\n",
    "    for uq_name, _ in uq_funcs_with_names:\n",
    "        roc_auc_dict[uq_name] = {}\n",
    "\n",
    "        for ood_dataset in list_ood_datasets:\n",
    "            roc_auc_dict[uq_name][ood_dataset] = {}\n",
    "            for loss_ in uq_results[uq_name].keys():\n",
    "                roc_auc_dict[uq_name][ood_dataset][loss_] = []\n",
    "                for it_ in range(len(uq_results[uq_name][loss_][ood_dataset])):\n",
    "                    y_true = np.hstack(\n",
    "                        [\n",
    "                            np.ones(\n",
    "                                uq_results[uq_name][loss_][ood_dataset][it_].shape[0]\n",
    "                            ),\n",
    "                            np.zeros(\n",
    "                                uq_results[uq_name][loss_][ind_dataset][it_].shape[0]\n",
    "                            ),\n",
    "                        ]\n",
    "                    )\n",
    "                    y_score = np.hstack(\n",
    "                        [\n",
    "                            uq_results[uq_name][loss_][ood_dataset][it_],\n",
    "                            uq_results[uq_name][loss_][ind_dataset][it_],\n",
    "                        ]\n",
    "                    )\n",
    "                    score = roc_auc_score(y_true=y_true, y_score=y_score)\n",
    "                    roc_auc_dict[uq_name][ood_dataset][loss_].append(score)\n",
    "\n",
    "    data_list = []\n",
    "    for metric_name, datasets in roc_auc_dict.items():\n",
    "        for dataset_name, loss_functions in datasets.items():\n",
    "            for loss_function_name, values in loss_functions.items():\n",
    "                data_list.append(\n",
    "                    (metric_name, dataset_name, loss_function_name, values)\n",
    "                )\n",
    "\n",
    "    # Create a DataFrame\n",
    "    df = pd.DataFrame(\n",
    "        data_list, columns=[\"UQMetric\", \"Dataset\", \"LossFunction\", \"RocAucScores_array\"]\n",
    "    )\n",
    "\n",
    "    return df\n",
    "\n",
    "\n",
    "# def get_missclassification_dataframe(\n",
    "#     ind_dataset: str,\n",
    "#     uq_results: dict,\n",
    "#     true_labels: np.ndarray,\n",
    "#     pred_labels: np.ndarray,\n",
    "# ) -> pd.DataFrame:\n",
    "#     \"\"\"\n",
    "#     The function transforms uq_results dict into pd.Dataframe\n",
    "#     with ROC AUC scores of misclassification detection.\n",
    "#     \"\"\"\n",
    "#     roc_auc_dict = {}\n",
    "\n",
    "#     for uq_name, _ in uq_funcs_with_names:\n",
    "#         roc_auc_dict[uq_name] = {}\n",
    "#         for loss_ in uq_results[uq_name].keys():\n",
    "#             y_true = (true_labels != pred_labels[loss_]).astype(np.int32)\n",
    "#             y_score = uq_results[uq_name][loss_][ind_dataset]\n",
    "\n",
    "#             score = roc_auc_score(y_true=y_true, y_score=y_score)\n",
    "#             roc_auc_dict[uq_name][loss_] = score\n",
    "\n",
    "#             # print(\n",
    "#             #     f'InD: {ind_dataset} \\t loss: {loss_} \\t roc_auc: {score}')\n",
    "\n",
    "#     data_list_misclassification = []\n",
    "#     for metric_name, loss_function in roc_auc_dict.items():\n",
    "#         for loss_function_name, value in loss_function.items():\n",
    "#             data_list_misclassification.append((metric_name, loss_function_name, value))\n",
    "\n",
    "#     # Create a DataFrame\n",
    "#     df_misclassification = pd.DataFrame(\n",
    "#         data_list_misclassification,\n",
    "#         columns=[\n",
    "#             \"UQMetric\",\n",
    "#             \"LossFunction\",\n",
    "#             \"RocAucScore\",\n",
    "#         ],\n",
    "#     )\n",
    "#     return df_misclassification"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed22c2bb-0e77-47dd-8b47-294682c544e3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8147b18e-10f0-4eb2-aa2b-5f046882e27d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7feaaf0a-d321-4c0a-b35b-9277e0ce6779",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f5e9a3a8-e415-466e-be53-4de0bed60cfb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "248da76e-4ebe-4008-9f70-19d7adb5a4cd",
   "metadata": {},
   "outputs": [],
   "source": [
    "full_dataframe = None\n",
    "\n",
    "for training_dataset_name in training_dataset_names:\n",
    "    if training_dataset_name not in [\n",
    "        \"missed_class_cifar10\",\n",
    "        \"noisy_cifar10\",\n",
    "        \"noisy_cifar100\",\n",
    "    ]:\n",
    "        architectures = [\"resnet18\", \"vgg\"]\n",
    "        training_dataset_name_aux = training_dataset_name\n",
    "    else:\n",
    "        architectures = [\"resnet18\"]\n",
    "        training_dataset_name_aux = training_dataset_name.split(\"_\")[-1]\n",
    "    for architecture in architectures:\n",
    "        ###\n",
    "        folder_path = make_load_path(\n",
    "            architecture=architecture,\n",
    "            dataset_name=training_dataset_name,\n",
    "            loss_function_name=\"NaN\",\n",
    "            model_id=\"NaN\",\n",
    "        )\n",
    "        extracted_embeddings_file_path = os.path.join(\n",
    "            *folder_path.split(\"/\")[:-3],\n",
    "            \"extracted_information_for_notebook_combinations.pkl\",\n",
    "        )\n",
    "\n",
    "        res_dict = load_dict(extracted_embeddings_file_path)\n",
    "        uq_results, embeddings_per_dataset, targets_per_dataset = (\n",
    "            res_dict[\"uq_results\"],\n",
    "            res_dict[\"embeddings_per_dataset\"],\n",
    "            res_dict[\"targets_per_dataset\"],\n",
    "        )\n",
    "        ###\n",
    "\n",
    "        df_ood = get_ood_detection_dataframe(\n",
    "            ind_dataset=training_dataset_name_aux,\n",
    "            uq_results=uq_results,\n",
    "            list_ood_datasets=list_ood_datasets,\n",
    "        )\n",
    "        df_ood[\"architecture\"] = architecture\n",
    "        df_ood[\"training_dataset\"] = training_dataset_name\n",
    "\n",
    "        scores_df_unravel = get_raw_scores_dataframe(uq_results=uq_results)\n",
    "        scores_df_unravel[\"architecture\"] = architecture\n",
    "        scores_df_unravel[\"training_dataset\"] = training_dataset_name\n",
    "\n",
    "        if full_dataframe is None:\n",
    "            full_dataframe = scores_df_unravel\n",
    "            full_ood_rocauc_dataframe = df_ood\n",
    "        else:\n",
    "            full_dataframe = pd.concat([full_dataframe, scores_df_unravel])\n",
    "            full_ood_rocauc_dataframe = pd.concat([full_ood_rocauc_dataframe, df_ood])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5c35709a-2158-4c9e-acf5-36e523fdbc79",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7f3c0f74-d425-448f-9abc-80bd29298ab8",
   "metadata": {},
   "outputs": [],
   "source": [
    "full_ood_rocauc_dataframe[\"RocAucScoresMean\"] = full_ood_rocauc_dataframe[\n",
    "    \"RocAucScores_array\"\n",
    "].apply(lambda x: np.array(x).mean())\n",
    "full_ood_rocauc_dataframe[\"RocAucScoresStd\"] = full_ood_rocauc_dataframe[\n",
    "    \"RocAucScores_array\"\n",
    "].apply(lambda x: np.array(x).std())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e9f4bfad-75d2-49c1-a3c4-d2c12637f64b",
   "metadata": {},
   "outputs": [],
   "source": [
    "full_ood_rocauc_dataframe.sample(10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "73b8861e-92e9-4729-8e11-81ad67bfa295",
   "metadata": {},
   "outputs": [],
   "source": [
    "full_ood_rocauc_dataframe.reset_index(drop=True).loc[2576]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ef8fcb9b-68bd-46f8-acdf-4535e3a011da",
   "metadata": {},
   "outputs": [],
   "source": [
    "full_ood_rocauc_dataframe.reset_index(drop=True).loc[2872]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "16709503-2051-4ad5-8317-c09df02fe364",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "32cea077-b0ab-4685-bdda-20ee721550ff",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "45dc4b27-a121-4149-b1ae-556da875da81",
   "metadata": {},
   "outputs": [],
   "source": [
    "full_ood_rocauc_dataframe = full_ood_rocauc_dataframe.reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0dfa8f49-476d-4bb4-be0e-f82875e4b97f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b4288396-e7f2-4754-a52c-af5bdd76a476",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "65e5682a-a585-4f72-9317-59a688906d48",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dcb29c54-f117-499e-a22f-ecd9e98d6032",
   "metadata": {},
   "outputs": [],
   "source": [
    "full_ood_rocauc_dataframe[\"UQMetric\"].unique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dfe0a1a2-e61e-4e1e-b8d9-28e06bd1c175",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "3047125a-e50b-4feb-be9e-b5393a670724",
   "metadata": {},
   "outputs": [],
   "source": [
    "base_score_dict = {\n",
    "    \"cross_entropy\": \"Logscore\",\n",
    "    \"brier_score\": \"Brier\",\n",
    "    \"spherical_score\": \"Spherical\",\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "d2c2d6df-bb2e-4ea9-baad-4b0d91f48e6c",
   "metadata": {},
   "outputs": [],
   "source": [
    "pattern_baserule = r\"(Logscore|Brier|Neglog|Maxprob|Spherical)\"\n",
    "pattern_risk = r\"(Total|Bayes|Excess|Reverse Bregman Information|Bregman Information|Expected Pairwise Bregman Information|MVBI|MV|BiasBI|Bias)\"\n",
    "\n",
    "full_ood_rocauc_dataframe[\"base_rule\"] = full_ood_rocauc_dataframe[\n",
    "    \"UQMetric\"\n",
    "].str.extract(pattern_baserule)\n",
    "full_ood_rocauc_dataframe[\"RiskType\"] = full_ood_rocauc_dataframe[\n",
    "    \"UQMetric\"\n",
    "].str.extract(pattern_risk)\n",
    "full_ood_rocauc_dataframe[\"LossFunction\"] = full_ood_rocauc_dataframe[\n",
    "    \"LossFunction\"\n",
    "].replace(base_score_dict)\n",
    "\n",
    "\n",
    "full_dataframe[\"base_rule\"] = full_dataframe[\"UQMetric\"].str.extract(pattern_baserule)\n",
    "full_dataframe[\"RiskType\"] = full_dataframe[\"UQMetric\"].str.extract(pattern_risk)\n",
    "full_dataframe[\"LossFunction\"] = full_dataframe[\"LossFunction\"].replace(base_score_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "89dab9e8-1845-4a09-800e-77c734311517",
   "metadata": {},
   "outputs": [],
   "source": [
    "full_dataframe.to_csv(\"./tables/full_dataframe_with_std.csv\")\n",
    "full_ood_rocauc_dataframe.to_csv(\"./tables/full_ood_rocauc_with_std.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "781b5d65-fffd-4667-b7cf-59be3ed2265f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "6f37119f-fcb6-4364-a211-2fd6895c45ed",
   "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[~full_ood_rocauc.UQMetric.str.endswith(\"Inner Inner\")]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0abcebd7-51a5-4e39-84ad-8d278e7352fd",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "59a5f614-141f-470c-bd99-0e808b480ddb",
   "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>2178</th>\n",
       "      <td>BiasBI Spherical</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>Brier</td>\n",
       "      <td>[0.87530019, 0.8743967600000001, 0.869154215, ...</td>\n",
       "      <td>vgg</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.873934</td>\n",
       "      <td>2.521493e-03</td>\n",
       "      <td>Spherical</td>\n",
       "      <td>BiasBI</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5194</th>\n",
       "      <td>Reverse Bregman Information Logscore</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>Logscore</td>\n",
       "      <td>[0.49999999999999994, 0.5, 0.5, 0.500000000000...</td>\n",
       "      <td>resnet18</td>\n",
       "      <td>noisy_cifar100</td>\n",
       "      <td>0.500000</td>\n",
       "      <td>5.551115e-17</td>\n",
       "      <td>Logscore</td>\n",
       "      <td>Reverse Bregman Information</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6053</th>\n",
       "      <td>Excess Spherical Inner Outer</td>\n",
       "      <td>svhn</td>\n",
       "      <td>Spherical</td>\n",
       "      <td>[0.7608834146435157, 0.8440206822372465, 0.937...</td>\n",
       "      <td>resnet18</td>\n",
       "      <td>missed_class_cifar10</td>\n",
       "      <td>0.883869</td>\n",
       "      <td>7.169191e-02</td>\n",
       "      <td>Spherical</td>\n",
       "      <td>Excess</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>380</th>\n",
       "      <td>Excess Maxprob Outer Outer</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>Spherical</td>\n",
       "      <td>[0.7393491849999999, 0.7364092799999997, 0.740...</td>\n",
       "      <td>resnet18</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.738947</td>\n",
       "      <td>1.928681e-03</td>\n",
       "      <td>Maxprob</td>\n",
       "      <td>Excess</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7602</th>\n",
       "      <td>MV Logscore</td>\n",
       "      <td>blurred_cifar10</td>\n",
       "      <td>Brier</td>\n",
       "      <td>[0.7703630399999999, 0.82002716, 0.84421677, 0...</td>\n",
       "      <td>resnet18</td>\n",
       "      <td>noisy_cifar10</td>\n",
       "      <td>0.812146</td>\n",
       "      <td>2.419833e-02</td>\n",
       "      <td>Logscore</td>\n",
       "      <td>MV</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3042</th>\n",
       "      <td>Expected Pairwise Bregman Information Maxprob</td>\n",
       "      <td>blurred_cifar10</td>\n",
       "      <td>Brier</td>\n",
       "      <td>[0.7814324700000002, 0.7914582050000001, 0.786...</td>\n",
       "      <td>resnet18</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>0.786100</td>\n",
       "      <td>3.551094e-03</td>\n",
       "      <td>Maxprob</td>\n",
       "      <td>Expected Pairwise Bregman Information</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6573</th>\n",
       "      <td>Bias Maxprob</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>Brier</td>\n",
       "      <td>[0.23352607, 0.223433815, 0.175052895, 0.17497...</td>\n",
       "      <td>resnet18</td>\n",
       "      <td>missed_class_cifar10</td>\n",
       "      <td>0.197005</td>\n",
       "      <td>2.592040e-02</td>\n",
       "      <td>Maxprob</td>\n",
       "      <td>Bias</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7673</th>\n",
       "      <td>MVBI Brier</td>\n",
       "      <td>svhn</td>\n",
       "      <td>Spherical</td>\n",
       "      <td>[0.90416464159496, 0.8932192417025201, 0.88949...</td>\n",
       "      <td>resnet18</td>\n",
       "      <td>noisy_cifar10</td>\n",
       "      <td>0.888090</td>\n",
       "      <td>2.276114e-02</td>\n",
       "      <td>Brier</td>\n",
       "      <td>MVBI</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2328</th>\n",
       "      <td>Total Brier Inner</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>Brier</td>\n",
       "      <td>[0.5, 0.49999999999999994, 0.5, 0.5, 0.5]</td>\n",
       "      <td>resnet18</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>0.500000</td>\n",
       "      <td>2.482534e-17</td>\n",
       "      <td>Brier</td>\n",
       "      <td>Total</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3114</th>\n",
       "      <td>MVBI Logscore</td>\n",
       "      <td>blurred_cifar100</td>\n",
       "      <td>Brier</td>\n",
       "      <td>[0.7879475200000001, 0.7851096399999999, 0.784...</td>\n",
       "      <td>resnet18</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>0.787928</td>\n",
       "      <td>3.134457e-03</td>\n",
       "      <td>Logscore</td>\n",
       "      <td>MVBI</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                           UQMetric           Dataset  \\\n",
       "2178                               BiasBI Spherical          cifar100   \n",
       "5194           Reverse Bregman Information Logscore          cifar100   \n",
       "6053                   Excess Spherical Inner Outer              svhn   \n",
       "380                      Excess Maxprob Outer Outer          cifar100   \n",
       "7602                                    MV Logscore   blurred_cifar10   \n",
       "3042  Expected Pairwise Bregman Information Maxprob   blurred_cifar10   \n",
       "6573                                   Bias Maxprob          cifar100   \n",
       "7673                                     MVBI Brier              svhn   \n",
       "2328                              Total Brier Inner          cifar100   \n",
       "3114                                  MVBI Logscore  blurred_cifar100   \n",
       "\n",
       "     LossFunction                                 RocAucScores_array  \\\n",
       "2178        Brier  [0.87530019, 0.8743967600000001, 0.869154215, ...   \n",
       "5194     Logscore  [0.49999999999999994, 0.5, 0.5, 0.500000000000...   \n",
       "6053    Spherical  [0.7608834146435157, 0.8440206822372465, 0.937...   \n",
       "380     Spherical  [0.7393491849999999, 0.7364092799999997, 0.740...   \n",
       "7602        Brier  [0.7703630399999999, 0.82002716, 0.84421677, 0...   \n",
       "3042        Brier  [0.7814324700000002, 0.7914582050000001, 0.786...   \n",
       "6573        Brier  [0.23352607, 0.223433815, 0.175052895, 0.17497...   \n",
       "7673    Spherical  [0.90416464159496, 0.8932192417025201, 0.88949...   \n",
       "2328        Brier          [0.5, 0.49999999999999994, 0.5, 0.5, 0.5]   \n",
       "3114        Brier  [0.7879475200000001, 0.7851096399999999, 0.784...   \n",
       "\n",
       "     architecture      training_dataset  RocAucScoresMean  RocAucScoresStd  \\\n",
       "2178          vgg               cifar10          0.873934     2.521493e-03   \n",
       "5194     resnet18        noisy_cifar100          0.500000     5.551115e-17   \n",
       "6053     resnet18  missed_class_cifar10          0.883869     7.169191e-02   \n",
       "380      resnet18               cifar10          0.738947     1.928681e-03   \n",
       "7602     resnet18         noisy_cifar10          0.812146     2.419833e-02   \n",
       "3042     resnet18              cifar100          0.786100     3.551094e-03   \n",
       "6573     resnet18  missed_class_cifar10          0.197005     2.592040e-02   \n",
       "7673     resnet18         noisy_cifar10          0.888090     2.276114e-02   \n",
       "2328     resnet18              cifar100          0.500000     2.482534e-17   \n",
       "3114     resnet18              cifar100          0.787928     3.134457e-03   \n",
       "\n",
       "      base_rule                               RiskType  \n",
       "2178  Spherical                                 BiasBI  \n",
       "5194   Logscore            Reverse Bregman Information  \n",
       "6053  Spherical                                 Excess  \n",
       "380     Maxprob                                 Excess  \n",
       "7602   Logscore                                     MV  \n",
       "3042    Maxprob  Expected Pairwise Bregman Information  \n",
       "6573    Maxprob                                   Bias  \n",
       "7673      Brier                                   MVBI  \n",
       "2328      Brier                                  Total  \n",
       "3114   Logscore                                   MVBI  "
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "full_ood_rocauc.sample(10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "c3d952fb-b3ea-4896-a9f6-b9be5be81c21",
   "metadata": {},
   "outputs": [],
   "source": [
    "# full_ood_rocauc[\n",
    "# (full_ood_rocauc.base_rule == 'Neglog')\n",
    "# & (full_ood_rocauc.Dataset == 'svhn')\n",
    "# & (full_ood_rocauc.training_dataset == 'cifar10')\n",
    "# & (full_ood_rocauc.RiskType == 'Excess')\n",
    "# ].sort_values(by=['RocAucScoresMean'], ascending=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "535305cf-ab09-4054-9c4b-4c6763b3cb31",
   "metadata": {},
   "outputs": [],
   "source": [
    "# full_ood_rocauc[\n",
    "# # (full_ood_rocauc.base_rule != 'Neglog')\n",
    "# (full_ood_rocauc.Dataset == 'svhn')\n",
    "# & (full_ood_rocauc.training_dataset == 'cifar10')\n",
    "# & (full_ood_rocauc.RiskType == 'Excess')\n",
    "# ].sort_values(by=['RocAucScoresMean'], ascending=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "db1c281f-1612-4abb-9f33-17b26f558eeb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "71cbed29-9c03-44a2-8b99-311b9c6de11e",
   "metadata": {},
   "outputs": [],
   "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",
    "    extract_same_different_dataframes,\n",
    "    collect_scores_into_dict_with_std,\n",
    "    ood_detection_pairs_,\n",
    "    aggregate_over_measures,\n",
    ")\n",
    "\n",
    "from IPython.display import display\n",
    "\n",
    "pd.set_option(\"display.max_rows\", None)\n",
    "\n",
    "full_ood_rocauc = pd.read_csv(\"./tables/full_ood_rocauc_with_std.csv\", index_col=0)\n",
    "\n",
    "full_ood_rocauc = full_ood_rocauc[\n",
    "    full_ood_rocauc.Dataset != full_ood_rocauc.training_dataset\n",
    "]\n",
    "full_ood_rocauc = full_ood_rocauc[~full_ood_rocauc.UQMetric.str.endswith(\"Inner Inner\")]\n",
    "full_ood_rocauc = full_ood_rocauc[full_ood_rocauc.base_rule != \"Neglog\"]\n",
    "\n",
    "\n",
    "full_ood_rocauc.loc[\n",
    "    (full_ood_rocauc.RiskType == \"Bayes\")\n",
    "    & full_ood_rocauc.UQMetric.str.endswith(\"Outer\"),\n",
    "    \"RiskType\",\n",
    "] = \"Bayes Outer\"\n",
    "full_ood_rocauc.loc[\n",
    "    (full_ood_rocauc.RiskType == \"Bayes\")\n",
    "    & full_ood_rocauc.UQMetric.str.endswith(\"Inner\"),\n",
    "    \"RiskType\",\n",
    "] = \"Bayes Inner\"\n",
    "\n",
    "full_ood_rocauc.loc[\n",
    "    (full_ood_rocauc.RiskType == \"Total\")\n",
    "    & full_ood_rocauc.UQMetric.str.endswith(\"Outer\"),\n",
    "    \"RiskType\",\n",
    "] = \"Total Outer\"\n",
    "full_ood_rocauc.loc[\n",
    "    (full_ood_rocauc.RiskType == \"Total\")\n",
    "    & full_ood_rocauc.UQMetric.str.endswith(\"Inner\"),\n",
    "    \"RiskType\",\n",
    "] = \"Total Inner\"\n",
    "\n",
    "\n",
    "grouped_df = extract_same_different_dataframes(\n",
    "    dataframe_=full_ood_rocauc,\n",
    ")\n",
    "\n",
    "same_dict_mean, same_dict_std = collect_scores_into_dict_with_std(\n",
    "    dataframes_list=[\n",
    "        grouped_df.logscore_logscore,\n",
    "        grouped_df.brier_brier,\n",
    "        grouped_df.spherical_spherical,\n",
    "    ],\n",
    "    ood_detection_pairs=ood_detection_pairs_,\n",
    ")\n",
    "same_df_mean = pd.DataFrame.from_dict(same_dict_mean)\n",
    "same_df_std = pd.DataFrame.from_dict(same_dict_std)\n",
    "\n",
    "same_agg_df_mean = aggregate_over_measures(\n",
    "    dataframe_=same_df_mean,\n",
    "    agg_func_=\"mean\",\n",
    "    by_=[\"InD\", \"OOD\"],\n",
    ")\n",
    "\n",
    "same_agg_df_std = aggregate_over_measures(\n",
    "    dataframe_=same_df_std,\n",
    "    agg_func_=\"mean\",\n",
    "    by_=[\"InD\", \"OOD\"],\n",
    ")\n",
    "\n",
    "different_dict_mean, different_dict_std = collect_scores_into_dict_with_std(\n",
    "    dataframes_list=[\n",
    "        grouped_df.logscore_not_logscore,\n",
    "        grouped_df.brier_not_brier,\n",
    "        grouped_df.spherical_not_spherical,\n",
    "    ],\n",
    "    ood_detection_pairs=ood_detection_pairs_,\n",
    ")\n",
    "\n",
    "\n",
    "different_df_mean = pd.DataFrame.from_dict(different_dict_mean)\n",
    "different_df_std = pd.DataFrame.from_dict(different_dict_std)\n",
    "\n",
    "different_agg_df_mean = aggregate_over_measures(\n",
    "    dataframe_=different_df_mean,\n",
    "    agg_func_=\"mean\",\n",
    "    by_=[\"InD\", \"OOD\"],\n",
    ")\n",
    "different_agg_df_std = aggregate_over_measures(\n",
    "    dataframe_=different_df_std,\n",
    "    agg_func_=\"mean\",\n",
    "    by_=[\"InD\", \"OOD\"],\n",
    ")\n",
    "\n",
    "all_dict_mean, all_dict_std = collect_scores_into_dict_with_std(\n",
    "    dataframes_list=[\n",
    "        full_ood_rocauc,\n",
    "    ],\n",
    "    ood_detection_pairs=ood_detection_pairs_,\n",
    ")\n",
    "all_df_mean = pd.DataFrame.from_dict(all_dict_mean)\n",
    "all_df_std = pd.DataFrame.from_dict(all_dict_std)\n",
    "\n",
    "all_agg_df_mean = aggregate_over_measures(\n",
    "    dataframe_=all_df_mean,\n",
    "    agg_func_=\"mean\",\n",
    "    by_=[\"InD\", \"OOD\"],\n",
    ")\n",
    "all_agg_df_std = aggregate_over_measures(\n",
    "    dataframe_=all_df_std,\n",
    "    agg_func_=\"mean\",\n",
    "    by_=[\"InD\", \"OOD\"],\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "09e4a9bf-2e7a-49d2-80bd-74f3f1631915",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8d57017a-791b-42e9-9d03-36397342e423",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "191470b8-c2de-4f04-9234-5db97b863a01",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "992742b0-1b1b-42df-bb4a-600d8063faa3",
   "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 Outer</th>\n",
       "      <th>Total Inner</th>\n",
       "      <th>Bayes Inner</th>\n",
       "      <th>Bayes Outer</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",
       "      <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",
       "      <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.826072</td>\n",
       "      <td>0.821161</td>\n",
       "      <td>0.821161</td>\n",
       "      <td>0.800810</td>\n",
       "      <td>0.808991</td>\n",
       "      <td>0.808889</td>\n",
       "      <td>0.808158</td>\n",
       "      <td>0.809926</td>\n",
       "      <td>0.591934</td>\n",
       "      <td>0.753126</td>\n",
       "      <td>0.808991</td>\n",
       "      <td>0.692797</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>blurred_cifar100</th>\n",
       "      <td>0.934231</td>\n",
       "      <td>0.932439</td>\n",
       "      <td>0.932439</td>\n",
       "      <td>0.918125</td>\n",
       "      <td>0.906515</td>\n",
       "      <td>0.907438</td>\n",
       "      <td>0.904727</td>\n",
       "      <td>0.907381</td>\n",
       "      <td>0.620273</td>\n",
       "      <td>0.823016</td>\n",
       "      <td>0.907174</td>\n",
       "      <td>0.741044</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar100</th>\n",
       "      <td>0.892680</td>\n",
       "      <td>0.894875</td>\n",
       "      <td>0.894875</td>\n",
       "      <td>0.894342</td>\n",
       "      <td>0.848855</td>\n",
       "      <td>0.849681</td>\n",
       "      <td>0.847892</td>\n",
       "      <td>0.848992</td>\n",
       "      <td>0.600554</td>\n",
       "      <td>0.786962</td>\n",
       "      <td>0.849357</td>\n",
       "      <td>0.708305</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>svhn</th>\n",
       "      <td>0.929429</td>\n",
       "      <td>0.931731</td>\n",
       "      <td>0.931731</td>\n",
       "      <td>0.930334</td>\n",
       "      <td>0.885519</td>\n",
       "      <td>0.886415</td>\n",
       "      <td>0.884501</td>\n",
       "      <td>0.885640</td>\n",
       "      <td>0.611235</td>\n",
       "      <td>0.813256</td>\n",
       "      <td>0.886221</td>\n",
       "      <td>0.726453</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">cifar100</th>\n",
       "      <th>blurred_cifar10</th>\n",
       "      <td>0.881626</td>\n",
       "      <td>0.867802</td>\n",
       "      <td>0.867802</td>\n",
       "      <td>0.846440</td>\n",
       "      <td>0.791173</td>\n",
       "      <td>0.797296</td>\n",
       "      <td>0.782728</td>\n",
       "      <td>0.793494</td>\n",
       "      <td>0.568576</td>\n",
       "      <td>0.714237</td>\n",
       "      <td>0.794112</td>\n",
       "      <td>0.639677</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>blurred_cifar100</th>\n",
       "      <td>0.726530</td>\n",
       "      <td>0.707566</td>\n",
       "      <td>0.707566</td>\n",
       "      <td>0.687757</td>\n",
       "      <td>0.712594</td>\n",
       "      <td>0.710662</td>\n",
       "      <td>0.712087</td>\n",
       "      <td>0.715032</td>\n",
       "      <td>0.563700</td>\n",
       "      <td>0.664063</td>\n",
       "      <td>0.710781</td>\n",
       "      <td>0.621372</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar10</th>\n",
       "      <td>0.778428</td>\n",
       "      <td>0.781168</td>\n",
       "      <td>0.781168</td>\n",
       "      <td>0.777045</td>\n",
       "      <td>0.695321</td>\n",
       "      <td>0.700819</td>\n",
       "      <td>0.690131</td>\n",
       "      <td>0.695013</td>\n",
       "      <td>0.529135</td>\n",
       "      <td>0.646090</td>\n",
       "      <td>0.698315</td>\n",
       "      <td>0.582409</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>svhn</th>\n",
       "      <td>0.827033</td>\n",
       "      <td>0.830303</td>\n",
       "      <td>0.830303</td>\n",
       "      <td>0.828556</td>\n",
       "      <td>0.711152</td>\n",
       "      <td>0.717250</td>\n",
       "      <td>0.705897</td>\n",
       "      <td>0.710309</td>\n",
       "      <td>0.536091</td>\n",
       "      <td>0.656635</td>\n",
       "      <td>0.713821</td>\n",
       "      <td>0.583142</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                          Total Outer Total Inner Bayes Inner Bayes Outer  \\\n",
       "                                 mean        mean        mean        mean   \n",
       "InD      OOD                                                                \n",
       "cifar10  blurred_cifar10     0.826072    0.821161    0.821161    0.800810   \n",
       "         blurred_cifar100    0.934231    0.932439    0.932439    0.918125   \n",
       "         cifar100            0.892680    0.894875    0.894875    0.894342   \n",
       "         svhn                0.929429    0.931731    0.931731    0.930334   \n",
       "cifar100 blurred_cifar10     0.881626    0.867802    0.867802    0.846440   \n",
       "         blurred_cifar100    0.726530    0.707566    0.707566    0.687757   \n",
       "         cifar10             0.778428    0.781168    0.781168    0.777045   \n",
       "         svhn                0.827033    0.830303    0.830303    0.828556   \n",
       "\n",
       "                             Excess Bregman Information  \\\n",
       "                               mean                mean   \n",
       "InD      OOD                                              \n",
       "cifar10  blurred_cifar10   0.808991            0.808889   \n",
       "         blurred_cifar100  0.906515            0.907438   \n",
       "         cifar100          0.848855            0.849681   \n",
       "         svhn              0.885519            0.886415   \n",
       "cifar100 blurred_cifar10   0.791173            0.797296   \n",
       "         blurred_cifar100  0.712594            0.710662   \n",
       "         cifar10           0.695321            0.700819   \n",
       "         svhn              0.711152            0.717250   \n",
       "\n",
       "                          Reverse Bregman Information  \\\n",
       "                                                 mean   \n",
       "InD      OOD                                            \n",
       "cifar10  blurred_cifar10                     0.808158   \n",
       "         blurred_cifar100                    0.904727   \n",
       "         cifar100                            0.847892   \n",
       "         svhn                                0.884501   \n",
       "cifar100 blurred_cifar10                     0.782728   \n",
       "         blurred_cifar100                    0.712087   \n",
       "         cifar10                             0.690131   \n",
       "         svhn                                0.705897   \n",
       "\n",
       "                          Expected Pairwise Bregman Information      Bias  \\\n",
       "                                                           mean      mean   \n",
       "InD      OOD                                                                \n",
       "cifar10  blurred_cifar10                               0.809926  0.591934   \n",
       "         blurred_cifar100                              0.907381  0.620273   \n",
       "         cifar100                                      0.848992  0.600554   \n",
       "         svhn                                          0.885640  0.611235   \n",
       "cifar100 blurred_cifar10                               0.793494  0.568576   \n",
       "         blurred_cifar100                              0.715032  0.563700   \n",
       "         cifar10                                       0.695013  0.529135   \n",
       "         svhn                                          0.710309  0.536091   \n",
       "\n",
       "                                 MV      MVBI    BiasBI  \n",
       "                               mean      mean      mean  \n",
       "InD      OOD                                             \n",
       "cifar10  blurred_cifar10   0.753126  0.808991  0.692797  \n",
       "         blurred_cifar100  0.823016  0.907174  0.741044  \n",
       "         cifar100          0.786962  0.849357  0.708305  \n",
       "         svhn              0.813256  0.886221  0.726453  \n",
       "cifar100 blurred_cifar10   0.714237  0.794112  0.639677  \n",
       "         blurred_cifar100  0.664063  0.710781  0.621372  \n",
       "         cifar10           0.646090  0.698315  0.582409  \n",
       "         svhn              0.656635  0.713821  0.583142  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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 Outer</th>\n",
       "      <th>Total Inner</th>\n",
       "      <th>Bayes Inner</th>\n",
       "      <th>Bayes Outer</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",
       "      <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",
       "      <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.006415</td>\n",
       "      <td>0.006481</td>\n",
       "      <td>0.006481</td>\n",
       "      <td>0.006797</td>\n",
       "      <td>0.006056</td>\n",
       "      <td>0.006032</td>\n",
       "      <td>0.006000</td>\n",
       "      <td>0.006135</td>\n",
       "      <td>0.004187</td>\n",
       "      <td>0.004690</td>\n",
       "      <td>0.006036</td>\n",
       "      <td>0.006137</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>blurred_cifar100</th>\n",
       "      <td>0.003436</td>\n",
       "      <td>0.003705</td>\n",
       "      <td>0.003705</td>\n",
       "      <td>0.004326</td>\n",
       "      <td>0.003167</td>\n",
       "      <td>0.003259</td>\n",
       "      <td>0.003132</td>\n",
       "      <td>0.003111</td>\n",
       "      <td>0.002425</td>\n",
       "      <td>0.001907</td>\n",
       "      <td>0.003237</td>\n",
       "      <td>0.002907</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar100</th>\n",
       "      <td>0.001489</td>\n",
       "      <td>0.001515</td>\n",
       "      <td>0.001515</td>\n",
       "      <td>0.001695</td>\n",
       "      <td>0.001965</td>\n",
       "      <td>0.002019</td>\n",
       "      <td>0.001965</td>\n",
       "      <td>0.001911</td>\n",
       "      <td>0.001302</td>\n",
       "      <td>0.001297</td>\n",
       "      <td>0.002017</td>\n",
       "      <td>0.001651</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>svhn</th>\n",
       "      <td>0.008176</td>\n",
       "      <td>0.008330</td>\n",
       "      <td>0.008330</td>\n",
       "      <td>0.009112</td>\n",
       "      <td>0.011637</td>\n",
       "      <td>0.011788</td>\n",
       "      <td>0.011355</td>\n",
       "      <td>0.011767</td>\n",
       "      <td>0.007671</td>\n",
       "      <td>0.006089</td>\n",
       "      <td>0.011729</td>\n",
       "      <td>0.008419</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">cifar100</th>\n",
       "      <th>blurred_cifar10</th>\n",
       "      <td>0.002317</td>\n",
       "      <td>0.002433</td>\n",
       "      <td>0.002433</td>\n",
       "      <td>0.002545</td>\n",
       "      <td>0.003470</td>\n",
       "      <td>0.003476</td>\n",
       "      <td>0.003417</td>\n",
       "      <td>0.003516</td>\n",
       "      <td>0.002312</td>\n",
       "      <td>0.002784</td>\n",
       "      <td>0.003490</td>\n",
       "      <td>0.003398</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>blurred_cifar100</th>\n",
       "      <td>0.003205</td>\n",
       "      <td>0.002980</td>\n",
       "      <td>0.002980</td>\n",
       "      <td>0.003141</td>\n",
       "      <td>0.003653</td>\n",
       "      <td>0.003621</td>\n",
       "      <td>0.003675</td>\n",
       "      <td>0.003662</td>\n",
       "      <td>0.002686</td>\n",
       "      <td>0.002767</td>\n",
       "      <td>0.003651</td>\n",
       "      <td>0.003565</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar10</th>\n",
       "      <td>0.001997</td>\n",
       "      <td>0.002047</td>\n",
       "      <td>0.002047</td>\n",
       "      <td>0.002158</td>\n",
       "      <td>0.002774</td>\n",
       "      <td>0.002697</td>\n",
       "      <td>0.002816</td>\n",
       "      <td>0.002809</td>\n",
       "      <td>0.002243</td>\n",
       "      <td>0.002042</td>\n",
       "      <td>0.002689</td>\n",
       "      <td>0.002703</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>svhn</th>\n",
       "      <td>0.012803</td>\n",
       "      <td>0.013264</td>\n",
       "      <td>0.013264</td>\n",
       "      <td>0.014041</td>\n",
       "      <td>0.012970</td>\n",
       "      <td>0.013166</td>\n",
       "      <td>0.012606</td>\n",
       "      <td>0.013139</td>\n",
       "      <td>0.011632</td>\n",
       "      <td>0.009907</td>\n",
       "      <td>0.013077</td>\n",
       "      <td>0.014107</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                          Total Outer Total Inner Bayes Inner Bayes Outer  \\\n",
       "                                 mean        mean        mean        mean   \n",
       "InD      OOD                                                                \n",
       "cifar10  blurred_cifar10     0.006415    0.006481    0.006481    0.006797   \n",
       "         blurred_cifar100    0.003436    0.003705    0.003705    0.004326   \n",
       "         cifar100            0.001489    0.001515    0.001515    0.001695   \n",
       "         svhn                0.008176    0.008330    0.008330    0.009112   \n",
       "cifar100 blurred_cifar10     0.002317    0.002433    0.002433    0.002545   \n",
       "         blurred_cifar100    0.003205    0.002980    0.002980    0.003141   \n",
       "         cifar10             0.001997    0.002047    0.002047    0.002158   \n",
       "         svhn                0.012803    0.013264    0.013264    0.014041   \n",
       "\n",
       "                             Excess Bregman Information  \\\n",
       "                               mean                mean   \n",
       "InD      OOD                                              \n",
       "cifar10  blurred_cifar10   0.006056            0.006032   \n",
       "         blurred_cifar100  0.003167            0.003259   \n",
       "         cifar100          0.001965            0.002019   \n",
       "         svhn              0.011637            0.011788   \n",
       "cifar100 blurred_cifar10   0.003470            0.003476   \n",
       "         blurred_cifar100  0.003653            0.003621   \n",
       "         cifar10           0.002774            0.002697   \n",
       "         svhn              0.012970            0.013166   \n",
       "\n",
       "                          Reverse Bregman Information  \\\n",
       "                                                 mean   \n",
       "InD      OOD                                            \n",
       "cifar10  blurred_cifar10                     0.006000   \n",
       "         blurred_cifar100                    0.003132   \n",
       "         cifar100                            0.001965   \n",
       "         svhn                                0.011355   \n",
       "cifar100 blurred_cifar10                     0.003417   \n",
       "         blurred_cifar100                    0.003675   \n",
       "         cifar10                             0.002816   \n",
       "         svhn                                0.012606   \n",
       "\n",
       "                          Expected Pairwise Bregman Information      Bias  \\\n",
       "                                                           mean      mean   \n",
       "InD      OOD                                                                \n",
       "cifar10  blurred_cifar10                               0.006135  0.004187   \n",
       "         blurred_cifar100                              0.003111  0.002425   \n",
       "         cifar100                                      0.001911  0.001302   \n",
       "         svhn                                          0.011767  0.007671   \n",
       "cifar100 blurred_cifar10                               0.003516  0.002312   \n",
       "         blurred_cifar100                              0.003662  0.002686   \n",
       "         cifar10                                       0.002809  0.002243   \n",
       "         svhn                                          0.013139  0.011632   \n",
       "\n",
       "                                 MV      MVBI    BiasBI  \n",
       "                               mean      mean      mean  \n",
       "InD      OOD                                             \n",
       "cifar10  blurred_cifar10   0.004690  0.006036  0.006137  \n",
       "         blurred_cifar100  0.001907  0.003237  0.002907  \n",
       "         cifar100          0.001297  0.002017  0.001651  \n",
       "         svhn              0.006089  0.011729  0.008419  \n",
       "cifar100 blurred_cifar10   0.002784  0.003490  0.003398  \n",
       "         blurred_cifar100  0.002767  0.003651  0.003565  \n",
       "         cifar10           0.002042  0.002689  0.002703  \n",
       "         svhn              0.009907  0.013077  0.014107  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "display(all_agg_df_mean)\n",
    "display(all_agg_df_std)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "38a79d71-a034-4c8a-96ea-cfc75489c174",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "05a0fa16-acb0-4c0c-b445-1f3e060ed3e9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8a435aeb-2087-426c-80e4-3dba08e37340",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8f64dc0b-9833-473b-ace3-585b8a1e5aed",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "e95e61e6-e1d0-415e-893f-63c74bd61a61",
   "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 Outer</th>\n",
       "      <th>Total Inner</th>\n",
       "      <th>Bayes Inner</th>\n",
       "      <th>Bayes Outer</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",
       "      <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",
       "      <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.827607</td>\n",
       "      <td>0.821493</td>\n",
       "      <td>0.821493</td>\n",
       "      <td>0.801022</td>\n",
       "      <td>0.839059</td>\n",
       "      <td>0.838089</td>\n",
       "      <td>0.839734</td>\n",
       "      <td>0.839354</td>\n",
       "      <td>0.715337</td>\n",
       "      <td>0.838250</td>\n",
       "      <td>0.838372</td>\n",
       "      <td>0.839060</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>blurred_cifar100</th>\n",
       "      <td>0.935158</td>\n",
       "      <td>0.933333</td>\n",
       "      <td>0.933333</td>\n",
       "      <td>0.918944</td>\n",
       "      <td>0.931900</td>\n",
       "      <td>0.931995</td>\n",
       "      <td>0.931698</td>\n",
       "      <td>0.932009</td>\n",
       "      <td>0.777801</td>\n",
       "      <td>0.931217</td>\n",
       "      <td>0.931735</td>\n",
       "      <td>0.931397</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar100</th>\n",
       "      <td>0.892287</td>\n",
       "      <td>0.895729</td>\n",
       "      <td>0.895729</td>\n",
       "      <td>0.895145</td>\n",
       "      <td>0.883591</td>\n",
       "      <td>0.884482</td>\n",
       "      <td>0.882807</td>\n",
       "      <td>0.883482</td>\n",
       "      <td>0.745695</td>\n",
       "      <td>0.883531</td>\n",
       "      <td>0.883995</td>\n",
       "      <td>0.883079</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>svhn</th>\n",
       "      <td>0.929480</td>\n",
       "      <td>0.932688</td>\n",
       "      <td>0.932688</td>\n",
       "      <td>0.931244</td>\n",
       "      <td>0.918413</td>\n",
       "      <td>0.919206</td>\n",
       "      <td>0.917672</td>\n",
       "      <td>0.918360</td>\n",
       "      <td>0.769165</td>\n",
       "      <td>0.918459</td>\n",
       "      <td>0.918871</td>\n",
       "      <td>0.917842</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">cifar100</th>\n",
       "      <th>blurred_cifar10</th>\n",
       "      <td>0.886792</td>\n",
       "      <td>0.870221</td>\n",
       "      <td>0.870221</td>\n",
       "      <td>0.848485</td>\n",
       "      <td>0.812526</td>\n",
       "      <td>0.815845</td>\n",
       "      <td>0.808197</td>\n",
       "      <td>0.813536</td>\n",
       "      <td>0.696163</td>\n",
       "      <td>0.806982</td>\n",
       "      <td>0.813343</td>\n",
       "      <td>0.814094</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>blurred_cifar100</th>\n",
       "      <td>0.732984</td>\n",
       "      <td>0.709404</td>\n",
       "      <td>0.709404</td>\n",
       "      <td>0.689309</td>\n",
       "      <td>0.733840</td>\n",
       "      <td>0.729821</td>\n",
       "      <td>0.736137</td>\n",
       "      <td>0.735560</td>\n",
       "      <td>0.656341</td>\n",
       "      <td>0.729202</td>\n",
       "      <td>0.731150</td>\n",
       "      <td>0.735573</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar10</th>\n",
       "      <td>0.777776</td>\n",
       "      <td>0.782585</td>\n",
       "      <td>0.782585</td>\n",
       "      <td>0.778405</td>\n",
       "      <td>0.715351</td>\n",
       "      <td>0.720717</td>\n",
       "      <td>0.710379</td>\n",
       "      <td>0.714956</td>\n",
       "      <td>0.624165</td>\n",
       "      <td>0.714004</td>\n",
       "      <td>0.717538</td>\n",
       "      <td>0.714874</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>svhn</th>\n",
       "      <td>0.827880</td>\n",
       "      <td>0.834085</td>\n",
       "      <td>0.834085</td>\n",
       "      <td>0.831620</td>\n",
       "      <td>0.732692</td>\n",
       "      <td>0.738770</td>\n",
       "      <td>0.726960</td>\n",
       "      <td>0.732347</td>\n",
       "      <td>0.642112</td>\n",
       "      <td>0.728872</td>\n",
       "      <td>0.734135</td>\n",
       "      <td>0.733829</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                          Total Outer Total Inner Bayes Inner Bayes Outer  \\\n",
       "                                 mean        mean        mean        mean   \n",
       "InD      OOD                                                                \n",
       "cifar10  blurred_cifar10     0.827607    0.821493    0.821493    0.801022   \n",
       "         blurred_cifar100    0.935158    0.933333    0.933333    0.918944   \n",
       "         cifar100            0.892287    0.895729    0.895729    0.895145   \n",
       "         svhn                0.929480    0.932688    0.932688    0.931244   \n",
       "cifar100 blurred_cifar10     0.886792    0.870221    0.870221    0.848485   \n",
       "         blurred_cifar100    0.732984    0.709404    0.709404    0.689309   \n",
       "         cifar10             0.777776    0.782585    0.782585    0.778405   \n",
       "         svhn                0.827880    0.834085    0.834085    0.831620   \n",
       "\n",
       "                             Excess Bregman Information  \\\n",
       "                               mean                mean   \n",
       "InD      OOD                                              \n",
       "cifar10  blurred_cifar10   0.839059            0.838089   \n",
       "         blurred_cifar100  0.931900            0.931995   \n",
       "         cifar100          0.883591            0.884482   \n",
       "         svhn              0.918413            0.919206   \n",
       "cifar100 blurred_cifar10   0.812526            0.815845   \n",
       "         blurred_cifar100  0.733840            0.729821   \n",
       "         cifar10           0.715351            0.720717   \n",
       "         svhn              0.732692            0.738770   \n",
       "\n",
       "                          Reverse Bregman Information  \\\n",
       "                                                 mean   \n",
       "InD      OOD                                            \n",
       "cifar10  blurred_cifar10                     0.839734   \n",
       "         blurred_cifar100                    0.931698   \n",
       "         cifar100                            0.882807   \n",
       "         svhn                                0.917672   \n",
       "cifar100 blurred_cifar10                     0.808197   \n",
       "         blurred_cifar100                    0.736137   \n",
       "         cifar10                             0.710379   \n",
       "         svhn                                0.726960   \n",
       "\n",
       "                          Expected Pairwise Bregman Information      Bias  \\\n",
       "                                                           mean      mean   \n",
       "InD      OOD                                                                \n",
       "cifar10  blurred_cifar10                               0.839354  0.715337   \n",
       "         blurred_cifar100                              0.932009  0.777801   \n",
       "         cifar100                                      0.883482  0.745695   \n",
       "         svhn                                          0.918360  0.769165   \n",
       "cifar100 blurred_cifar10                               0.813536  0.696163   \n",
       "         blurred_cifar100                              0.735560  0.656341   \n",
       "         cifar10                                       0.714956  0.624165   \n",
       "         svhn                                          0.732347  0.642112   \n",
       "\n",
       "                                 MV      MVBI    BiasBI  \n",
       "                               mean      mean      mean  \n",
       "InD      OOD                                             \n",
       "cifar10  blurred_cifar10   0.838250  0.838372  0.839060  \n",
       "         blurred_cifar100  0.931217  0.931735  0.931397  \n",
       "         cifar100          0.883531  0.883995  0.883079  \n",
       "         svhn              0.918459  0.918871  0.917842  \n",
       "cifar100 blurred_cifar10   0.806982  0.813343  0.814094  \n",
       "         blurred_cifar100  0.729202  0.731150  0.735573  \n",
       "         cifar10           0.714004  0.717538  0.714874  \n",
       "         svhn              0.728872  0.734135  0.733829  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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 Outer</th>\n",
       "      <th>Total Inner</th>\n",
       "      <th>Bayes Inner</th>\n",
       "      <th>Bayes Outer</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",
       "      <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",
       "      <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.006417</td>\n",
       "      <td>0.006462</td>\n",
       "      <td>0.006462</td>\n",
       "      <td>0.006810</td>\n",
       "      <td>0.005856</td>\n",
       "      <td>0.005911</td>\n",
       "      <td>0.005798</td>\n",
       "      <td>0.005859</td>\n",
       "      <td>0.003263</td>\n",
       "      <td>0.005841</td>\n",
       "      <td>0.005891</td>\n",
       "      <td>0.005840</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>blurred_cifar100</th>\n",
       "      <td>0.003399</td>\n",
       "      <td>0.003772</td>\n",
       "      <td>0.003772</td>\n",
       "      <td>0.004382</td>\n",
       "      <td>0.002485</td>\n",
       "      <td>0.002530</td>\n",
       "      <td>0.002449</td>\n",
       "      <td>0.002477</td>\n",
       "      <td>0.002075</td>\n",
       "      <td>0.002433</td>\n",
       "      <td>0.002475</td>\n",
       "      <td>0.002541</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar100</th>\n",
       "      <td>0.001444</td>\n",
       "      <td>0.001510</td>\n",
       "      <td>0.001510</td>\n",
       "      <td>0.001698</td>\n",
       "      <td>0.001747</td>\n",
       "      <td>0.001761</td>\n",
       "      <td>0.001735</td>\n",
       "      <td>0.001745</td>\n",
       "      <td>0.000974</td>\n",
       "      <td>0.001703</td>\n",
       "      <td>0.001725</td>\n",
       "      <td>0.001822</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>svhn</th>\n",
       "      <td>0.008038</td>\n",
       "      <td>0.008332</td>\n",
       "      <td>0.008332</td>\n",
       "      <td>0.009214</td>\n",
       "      <td>0.008126</td>\n",
       "      <td>0.008119</td>\n",
       "      <td>0.008150</td>\n",
       "      <td>0.008109</td>\n",
       "      <td>0.007633</td>\n",
       "      <td>0.007980</td>\n",
       "      <td>0.008042</td>\n",
       "      <td>0.008101</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">cifar100</th>\n",
       "      <th>blurred_cifar10</th>\n",
       "      <td>0.002318</td>\n",
       "      <td>0.002317</td>\n",
       "      <td>0.002317</td>\n",
       "      <td>0.002414</td>\n",
       "      <td>0.003435</td>\n",
       "      <td>0.003389</td>\n",
       "      <td>0.003516</td>\n",
       "      <td>0.003399</td>\n",
       "      <td>0.002260</td>\n",
       "      <td>0.003363</td>\n",
       "      <td>0.003327</td>\n",
       "      <td>0.003477</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>blurred_cifar100</th>\n",
       "      <td>0.003155</td>\n",
       "      <td>0.002992</td>\n",
       "      <td>0.002992</td>\n",
       "      <td>0.003062</td>\n",
       "      <td>0.003618</td>\n",
       "      <td>0.003544</td>\n",
       "      <td>0.003660</td>\n",
       "      <td>0.003650</td>\n",
       "      <td>0.001972</td>\n",
       "      <td>0.003622</td>\n",
       "      <td>0.003600</td>\n",
       "      <td>0.003697</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar10</th>\n",
       "      <td>0.001825</td>\n",
       "      <td>0.001901</td>\n",
       "      <td>0.001901</td>\n",
       "      <td>0.002052</td>\n",
       "      <td>0.002597</td>\n",
       "      <td>0.002567</td>\n",
       "      <td>0.002613</td>\n",
       "      <td>0.002611</td>\n",
       "      <td>0.001739</td>\n",
       "      <td>0.002475</td>\n",
       "      <td>0.002513</td>\n",
       "      <td>0.002716</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>svhn</th>\n",
       "      <td>0.012098</td>\n",
       "      <td>0.013432</td>\n",
       "      <td>0.013432</td>\n",
       "      <td>0.014082</td>\n",
       "      <td>0.012588</td>\n",
       "      <td>0.012673</td>\n",
       "      <td>0.012575</td>\n",
       "      <td>0.012515</td>\n",
       "      <td>0.010591</td>\n",
       "      <td>0.011824</td>\n",
       "      <td>0.012057</td>\n",
       "      <td>0.013231</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                          Total Outer Total Inner Bayes Inner Bayes Outer  \\\n",
       "                                 mean        mean        mean        mean   \n",
       "InD      OOD                                                                \n",
       "cifar10  blurred_cifar10     0.006417    0.006462    0.006462    0.006810   \n",
       "         blurred_cifar100    0.003399    0.003772    0.003772    0.004382   \n",
       "         cifar100            0.001444    0.001510    0.001510    0.001698   \n",
       "         svhn                0.008038    0.008332    0.008332    0.009214   \n",
       "cifar100 blurred_cifar10     0.002318    0.002317    0.002317    0.002414   \n",
       "         blurred_cifar100    0.003155    0.002992    0.002992    0.003062   \n",
       "         cifar10             0.001825    0.001901    0.001901    0.002052   \n",
       "         svhn                0.012098    0.013432    0.013432    0.014082   \n",
       "\n",
       "                             Excess Bregman Information  \\\n",
       "                               mean                mean   \n",
       "InD      OOD                                              \n",
       "cifar10  blurred_cifar10   0.005856            0.005911   \n",
       "         blurred_cifar100  0.002485            0.002530   \n",
       "         cifar100          0.001747            0.001761   \n",
       "         svhn              0.008126            0.008119   \n",
       "cifar100 blurred_cifar10   0.003435            0.003389   \n",
       "         blurred_cifar100  0.003618            0.003544   \n",
       "         cifar10           0.002597            0.002567   \n",
       "         svhn              0.012588            0.012673   \n",
       "\n",
       "                          Reverse Bregman Information  \\\n",
       "                                                 mean   \n",
       "InD      OOD                                            \n",
       "cifar10  blurred_cifar10                     0.005798   \n",
       "         blurred_cifar100                    0.002449   \n",
       "         cifar100                            0.001735   \n",
       "         svhn                                0.008150   \n",
       "cifar100 blurred_cifar10                     0.003516   \n",
       "         blurred_cifar100                    0.003660   \n",
       "         cifar10                             0.002613   \n",
       "         svhn                                0.012575   \n",
       "\n",
       "                          Expected Pairwise Bregman Information      Bias  \\\n",
       "                                                           mean      mean   \n",
       "InD      OOD                                                                \n",
       "cifar10  blurred_cifar10                               0.005859  0.003263   \n",
       "         blurred_cifar100                              0.002477  0.002075   \n",
       "         cifar100                                      0.001745  0.000974   \n",
       "         svhn                                          0.008109  0.007633   \n",
       "cifar100 blurred_cifar10                               0.003399  0.002260   \n",
       "         blurred_cifar100                              0.003650  0.001972   \n",
       "         cifar10                                       0.002611  0.001739   \n",
       "         svhn                                          0.012515  0.010591   \n",
       "\n",
       "                                 MV      MVBI    BiasBI  \n",
       "                               mean      mean      mean  \n",
       "InD      OOD                                             \n",
       "cifar10  blurred_cifar10   0.005841  0.005891  0.005840  \n",
       "         blurred_cifar100  0.002433  0.002475  0.002541  \n",
       "         cifar100          0.001703  0.001725  0.001822  \n",
       "         svhn              0.007980  0.008042  0.008101  \n",
       "cifar100 blurred_cifar10   0.003363  0.003327  0.003477  \n",
       "         blurred_cifar100  0.003622  0.003600  0.003697  \n",
       "         cifar10           0.002475  0.002513  0.002716  \n",
       "         svhn              0.011824  0.012057  0.013231  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "display(same_agg_df_mean)\n",
    "display(same_agg_df_std)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2c95684a-2c59-46aa-92e8-f87db748b8fb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a25df320-748a-45be-acd5-f42c1faeeec9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "02881548-7aba-4658-9795-729b8ccad2bb",
   "metadata": {},
   "outputs": [],
   "source": [
    "# different_df_mean[(different_df_mean.InD == 'cifar100') & (different_df_mean.OOD == 'svhn')]\n",
    "# # ['Bregman Information'].mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "4eab64aa-99eb-4e18-9782-d828f7274210",
   "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 Outer</th>\n",
       "      <th>Total Inner</th>\n",
       "      <th>Bayes Inner</th>\n",
       "      <th>Bayes Outer</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",
       "      <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",
       "      <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>82.556083</td>\n",
       "      <td>82.105015</td>\n",
       "      <td>82.105015</td>\n",
       "      <td>80.073907</td>\n",
       "      <td>79.896830</td>\n",
       "      <td>79.915545</td>\n",
       "      <td>79.763263</td>\n",
       "      <td>80.011682</td>\n",
       "      <td>55.079938</td>\n",
       "      <td>72.475101</td>\n",
       "      <td>79.919804</td>\n",
       "      <td>64.404253</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>blurred_cifar100</th>\n",
       "      <td>93.392257</td>\n",
       "      <td>93.214160</td>\n",
       "      <td>93.214160</td>\n",
       "      <td>91.785211</td>\n",
       "      <td>89.805376</td>\n",
       "      <td>89.925251</td>\n",
       "      <td>89.573662</td>\n",
       "      <td>89.917215</td>\n",
       "      <td>56.776332</td>\n",
       "      <td>78.694960</td>\n",
       "      <td>89.898727</td>\n",
       "      <td>67.759256</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar100</th>\n",
       "      <td>89.281045</td>\n",
       "      <td>89.459031</td>\n",
       "      <td>89.459031</td>\n",
       "      <td>89.407397</td>\n",
       "      <td>83.727651</td>\n",
       "      <td>83.808053</td>\n",
       "      <td>83.625335</td>\n",
       "      <td>83.749566</td>\n",
       "      <td>55.217397</td>\n",
       "      <td>75.477256</td>\n",
       "      <td>83.781139</td>\n",
       "      <td>65.004756</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>svhn</th>\n",
       "      <td>92.941238</td>\n",
       "      <td>93.141148</td>\n",
       "      <td>93.141148</td>\n",
       "      <td>93.003108</td>\n",
       "      <td>87.455446</td>\n",
       "      <td>87.548474</td>\n",
       "      <td>87.344466</td>\n",
       "      <td>87.473398</td>\n",
       "      <td>55.859244</td>\n",
       "      <td>77.818846</td>\n",
       "      <td>87.533718</td>\n",
       "      <td>66.265669</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">cifar100</th>\n",
       "      <th>blurred_cifar10</th>\n",
       "      <td>87.990377</td>\n",
       "      <td>86.699530</td>\n",
       "      <td>86.699530</td>\n",
       "      <td>84.575823</td>\n",
       "      <td>78.405500</td>\n",
       "      <td>79.111291</td>\n",
       "      <td>77.423796</td>\n",
       "      <td>78.681413</td>\n",
       "      <td>52.604696</td>\n",
       "      <td>68.332133</td>\n",
       "      <td>78.770181</td>\n",
       "      <td>58.153821</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>blurred_cifar100</th>\n",
       "      <td>72.437877</td>\n",
       "      <td>70.695318</td>\n",
       "      <td>70.695318</td>\n",
       "      <td>68.724034</td>\n",
       "      <td>70.551176</td>\n",
       "      <td>70.427490</td>\n",
       "      <td>70.407049</td>\n",
       "      <td>70.818989</td>\n",
       "      <td>53.281973</td>\n",
       "      <td>64.235048</td>\n",
       "      <td>70.399112</td>\n",
       "      <td>58.330516</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar10</th>\n",
       "      <td>77.864512</td>\n",
       "      <td>78.069548</td>\n",
       "      <td>78.069548</td>\n",
       "      <td>77.659245</td>\n",
       "      <td>68.864436</td>\n",
       "      <td>69.418649</td>\n",
       "      <td>68.338109</td>\n",
       "      <td>68.836548</td>\n",
       "      <td>49.745784</td>\n",
       "      <td>62.345218</td>\n",
       "      <td>69.190725</td>\n",
       "      <td>53.825417</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>svhn</th>\n",
       "      <td>82.675010</td>\n",
       "      <td>82.904258</td>\n",
       "      <td>82.904258</td>\n",
       "      <td>82.753503</td>\n",
       "      <td>70.397161</td>\n",
       "      <td>71.007626</td>\n",
       "      <td>69.887592</td>\n",
       "      <td>70.296264</td>\n",
       "      <td>50.075038</td>\n",
       "      <td>63.255620</td>\n",
       "      <td>70.705020</td>\n",
       "      <td>53.291298</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                          Total Outer Total Inner Bayes Inner Bayes Outer  \\\n",
       "                                 mean        mean        mean        mean   \n",
       "InD      OOD                                                                \n",
       "cifar10  blurred_cifar10    82.556083   82.105015   82.105015   80.073907   \n",
       "         blurred_cifar100   93.392257   93.214160   93.214160   91.785211   \n",
       "         cifar100           89.281045   89.459031   89.459031   89.407397   \n",
       "         svhn               92.941238   93.141148   93.141148   93.003108   \n",
       "cifar100 blurred_cifar10    87.990377   86.699530   86.699530   84.575823   \n",
       "         blurred_cifar100   72.437877   70.695318   70.695318   68.724034   \n",
       "         cifar10            77.864512   78.069548   78.069548   77.659245   \n",
       "         svhn               82.675010   82.904258   82.904258   82.753503   \n",
       "\n",
       "                              Excess Bregman Information  \\\n",
       "                                mean                mean   \n",
       "InD      OOD                                               \n",
       "cifar10  blurred_cifar10   79.896830           79.915545   \n",
       "         blurred_cifar100  89.805376           89.925251   \n",
       "         cifar100          83.727651           83.808053   \n",
       "         svhn              87.455446           87.548474   \n",
       "cifar100 blurred_cifar10   78.405500           79.111291   \n",
       "         blurred_cifar100  70.551176           70.427490   \n",
       "         cifar10           68.864436           69.418649   \n",
       "         svhn              70.397161           71.007626   \n",
       "\n",
       "                          Reverse Bregman Information  \\\n",
       "                                                 mean   \n",
       "InD      OOD                                            \n",
       "cifar10  blurred_cifar10                    79.763263   \n",
       "         blurred_cifar100                   89.573662   \n",
       "         cifar100                           83.625335   \n",
       "         svhn                               87.344466   \n",
       "cifar100 blurred_cifar10                    77.423796   \n",
       "         blurred_cifar100                   70.407049   \n",
       "         cifar10                            68.338109   \n",
       "         svhn                               69.887592   \n",
       "\n",
       "                          Expected Pairwise Bregman Information       Bias  \\\n",
       "                                                           mean       mean   \n",
       "InD      OOD                                                                 \n",
       "cifar10  blurred_cifar10                              80.011682  55.079938   \n",
       "         blurred_cifar100                             89.917215  56.776332   \n",
       "         cifar100                                     83.749566  55.217397   \n",
       "         svhn                                         87.473398  55.859244   \n",
       "cifar100 blurred_cifar10                              78.681413  52.604696   \n",
       "         blurred_cifar100                             70.818989  53.281973   \n",
       "         cifar10                                      68.836548  49.745784   \n",
       "         svhn                                         70.296264  50.075038   \n",
       "\n",
       "                                  MV       MVBI     BiasBI  \n",
       "                                mean       mean       mean  \n",
       "InD      OOD                                                \n",
       "cifar10  blurred_cifar10   72.475101  79.919804  64.404253  \n",
       "         blurred_cifar100  78.694960  89.898727  67.759256  \n",
       "         cifar100          75.477256  83.781139  65.004756  \n",
       "         svhn              77.818846  87.533718  66.265669  \n",
       "cifar100 blurred_cifar10   68.332133  78.770181  58.153821  \n",
       "         blurred_cifar100  64.235048  70.399112  58.330516  \n",
       "         cifar10           62.345218  69.190725  53.825417  \n",
       "         svhn              63.255620  70.705020  53.291298  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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 Outer</th>\n",
       "      <th>Total Inner</th>\n",
       "      <th>Bayes Inner</th>\n",
       "      <th>Bayes Outer</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",
       "      <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",
       "      <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.641360</td>\n",
       "      <td>0.648745</td>\n",
       "      <td>0.648745</td>\n",
       "      <td>0.679279</td>\n",
       "      <td>0.612233</td>\n",
       "      <td>0.607246</td>\n",
       "      <td>0.606701</td>\n",
       "      <td>0.622751</td>\n",
       "      <td>0.449538</td>\n",
       "      <td>0.430631</td>\n",
       "      <td>0.608419</td>\n",
       "      <td>0.623522</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>blurred_cifar100</th>\n",
       "      <td>0.344847</td>\n",
       "      <td>0.368220</td>\n",
       "      <td>0.368220</td>\n",
       "      <td>0.430788</td>\n",
       "      <td>0.339475</td>\n",
       "      <td>0.350243</td>\n",
       "      <td>0.336003</td>\n",
       "      <td>0.332180</td>\n",
       "      <td>0.254200</td>\n",
       "      <td>0.173220</td>\n",
       "      <td>0.349077</td>\n",
       "      <td>0.302865</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar100</th>\n",
       "      <td>0.150432</td>\n",
       "      <td>0.151687</td>\n",
       "      <td>0.151687</td>\n",
       "      <td>0.169361</td>\n",
       "      <td>0.203820</td>\n",
       "      <td>0.210545</td>\n",
       "      <td>0.204206</td>\n",
       "      <td>0.196710</td>\n",
       "      <td>0.141170</td>\n",
       "      <td>0.116228</td>\n",
       "      <td>0.211458</td>\n",
       "      <td>0.159480</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>svhn</th>\n",
       "      <td>0.822190</td>\n",
       "      <td>0.832888</td>\n",
       "      <td>0.832888</td>\n",
       "      <td>0.907787</td>\n",
       "      <td>1.280697</td>\n",
       "      <td>1.301131</td>\n",
       "      <td>1.242319</td>\n",
       "      <td>1.298642</td>\n",
       "      <td>0.768351</td>\n",
       "      <td>0.545820</td>\n",
       "      <td>1.295872</td>\n",
       "      <td>0.852563</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">cifar100</th>\n",
       "      <th>blurred_cifar10</th>\n",
       "      <td>0.231606</td>\n",
       "      <td>0.247200</td>\n",
       "      <td>0.247200</td>\n",
       "      <td>0.258823</td>\n",
       "      <td>0.348147</td>\n",
       "      <td>0.350501</td>\n",
       "      <td>0.338397</td>\n",
       "      <td>0.355543</td>\n",
       "      <td>0.232981</td>\n",
       "      <td>0.259172</td>\n",
       "      <td>0.354400</td>\n",
       "      <td>0.337180</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>blurred_cifar100</th>\n",
       "      <td>0.322124</td>\n",
       "      <td>0.297611</td>\n",
       "      <td>0.297611</td>\n",
       "      <td>0.316740</td>\n",
       "      <td>0.366424</td>\n",
       "      <td>0.364672</td>\n",
       "      <td>0.367984</td>\n",
       "      <td>0.366616</td>\n",
       "      <td>0.292408</td>\n",
       "      <td>0.248264</td>\n",
       "      <td>0.366815</td>\n",
       "      <td>0.352114</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar10</th>\n",
       "      <td>0.205425</td>\n",
       "      <td>0.209574</td>\n",
       "      <td>0.209574</td>\n",
       "      <td>0.219357</td>\n",
       "      <td>0.283305</td>\n",
       "      <td>0.273978</td>\n",
       "      <td>0.288408</td>\n",
       "      <td>0.287527</td>\n",
       "      <td>0.241052</td>\n",
       "      <td>0.189713</td>\n",
       "      <td>0.274806</td>\n",
       "      <td>0.269855</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>svhn</th>\n",
       "      <td>1.303775</td>\n",
       "      <td>1.320850</td>\n",
       "      <td>1.320850</td>\n",
       "      <td>1.402769</td>\n",
       "      <td>1.309750</td>\n",
       "      <td>1.332998</td>\n",
       "      <td>1.261580</td>\n",
       "      <td>1.334671</td>\n",
       "      <td>1.197875</td>\n",
       "      <td>0.926753</td>\n",
       "      <td>1.341707</td>\n",
       "      <td>1.439931</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                          Total Outer Total Inner Bayes Inner Bayes Outer  \\\n",
       "                                 mean        mean        mean        mean   \n",
       "InD      OOD                                                                \n",
       "cifar10  blurred_cifar10     0.641360    0.648745    0.648745    0.679279   \n",
       "         blurred_cifar100    0.344847    0.368220    0.368220    0.430788   \n",
       "         cifar100            0.150432    0.151687    0.151687    0.169361   \n",
       "         svhn                0.822190    0.832888    0.832888    0.907787   \n",
       "cifar100 blurred_cifar10     0.231606    0.247200    0.247200    0.258823   \n",
       "         blurred_cifar100    0.322124    0.297611    0.297611    0.316740   \n",
       "         cifar10             0.205425    0.209574    0.209574    0.219357   \n",
       "         svhn                1.303775    1.320850    1.320850    1.402769   \n",
       "\n",
       "                             Excess Bregman Information  \\\n",
       "                               mean                mean   \n",
       "InD      OOD                                              \n",
       "cifar10  blurred_cifar10   0.612233            0.607246   \n",
       "         blurred_cifar100  0.339475            0.350243   \n",
       "         cifar100          0.203820            0.210545   \n",
       "         svhn              1.280697            1.301131   \n",
       "cifar100 blurred_cifar10   0.348147            0.350501   \n",
       "         blurred_cifar100  0.366424            0.364672   \n",
       "         cifar10           0.283305            0.273978   \n",
       "         svhn              1.309750            1.332998   \n",
       "\n",
       "                          Reverse Bregman Information  \\\n",
       "                                                 mean   \n",
       "InD      OOD                                            \n",
       "cifar10  blurred_cifar10                     0.606701   \n",
       "         blurred_cifar100                    0.336003   \n",
       "         cifar100                            0.204206   \n",
       "         svhn                                1.242319   \n",
       "cifar100 blurred_cifar10                     0.338397   \n",
       "         blurred_cifar100                    0.367984   \n",
       "         cifar10                             0.288408   \n",
       "         svhn                                1.261580   \n",
       "\n",
       "                          Expected Pairwise Bregman Information      Bias  \\\n",
       "                                                           mean      mean   \n",
       "InD      OOD                                                                \n",
       "cifar10  blurred_cifar10                               0.622751  0.449538   \n",
       "         blurred_cifar100                              0.332180  0.254200   \n",
       "         cifar100                                      0.196710  0.141170   \n",
       "         svhn                                          1.298642  0.768351   \n",
       "cifar100 blurred_cifar10                               0.355543  0.232981   \n",
       "         blurred_cifar100                              0.366616  0.292408   \n",
       "         cifar10                                       0.287527  0.241052   \n",
       "         svhn                                          1.334671  1.197875   \n",
       "\n",
       "                                 MV      MVBI    BiasBI  \n",
       "                               mean      mean      mean  \n",
       "InD      OOD                                             \n",
       "cifar10  blurred_cifar10   0.430631  0.608419  0.623522  \n",
       "         blurred_cifar100  0.173220  0.349077  0.302865  \n",
       "         cifar100          0.116228  0.211458  0.159480  \n",
       "         svhn              0.545820  1.295872  0.852563  \n",
       "cifar100 blurred_cifar10   0.259172  0.354400  0.337180  \n",
       "         blurred_cifar100  0.248264  0.366815  0.352114  \n",
       "         cifar10           0.189713  0.274806  0.269855  \n",
       "         svhn              0.926753  1.341707  1.439931  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "display(different_agg_df_mean * 100)\n",
    "display(different_agg_df_std * 100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "11f0ead9-6143-4689-95c0-41ff85178168",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7079519f-e021-46ee-83ff-c113d73e3f5b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1301ab64-a1d9-4b59-9a50-36d661d30cf7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "37906ddc-6ac5-43bc-bce4-b69cd01b941d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# full_scores = pd.read_csv('./tables/full_dataframe_with_std.csv', )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "61d9a003-355c-4d28-b606-6a37bd2b2322",
   "metadata": {},
   "outputs": [],
   "source": [
    "# full_scores.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9d528e83-cabf-49be-a67c-2e2aae4eeb77",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "e693b7c7-9d4b-478b-afb8-8c6de3240b99",
   "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": 14,
   "id": "7843167c-6f37-46f9-addf-52d6f12a7939",
   "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": 15,
   "id": "a09cc0ef-e9d3-4aca-b7c6-289c8d8aae0f",
   "metadata": {},
   "outputs": [],
   "source": [
    "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",
    "\n",
    "\n",
    "# measures = [\n",
    "#     'Bayes',\n",
    "#     'Excess',\n",
    "#     'Total'\n",
    "# ]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "cda12896-9536-43de-a651-ba982d14923b",
   "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(O)</th>\n",
       "      <th>Bayes(I)</th>\n",
       "      <th>Total(O)</th>\n",
       "      <th>Total(I)</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",
       "      <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>80.10</td>\n",
       "      <td>82.15</td>\n",
       "      <td>82.76</td>\n",
       "      <td>82.15</td>\n",
       "      <td>83.81</td>\n",
       "      <td>83.97</td>\n",
       "      <td>83.94</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Blurred CIFAR100</th>\n",
       "      <td>91.89</td>\n",
       "      <td>93.33</td>\n",
       "      <td>93.52</td>\n",
       "      <td>93.33</td>\n",
       "      <td>93.20</td>\n",
       "      <td>93.17</td>\n",
       "      <td>93.20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CIFAR100</th>\n",
       "      <td>89.51</td>\n",
       "      <td>89.57</td>\n",
       "      <td>89.23</td>\n",
       "      <td>89.57</td>\n",
       "      <td>88.45</td>\n",
       "      <td>88.28</td>\n",
       "      <td>88.35</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SVHN</th>\n",
       "      <td>93.12</td>\n",
       "      <td>93.27</td>\n",
       "      <td>92.95</td>\n",
       "      <td>93.27</td>\n",
       "      <td>91.92</td>\n",
       "      <td>91.77</td>\n",
       "      <td>91.84</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">CIFAR100</th>\n",
       "      <th>Blurred CIFAR10</th>\n",
       "      <td>84.85</td>\n",
       "      <td>87.02</td>\n",
       "      <td>88.68</td>\n",
       "      <td>87.02</td>\n",
       "      <td>81.58</td>\n",
       "      <td>80.82</td>\n",
       "      <td>81.35</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Blurred CIFAR100</th>\n",
       "      <td>68.93</td>\n",
       "      <td>70.94</td>\n",
       "      <td>73.30</td>\n",
       "      <td>70.94</td>\n",
       "      <td>72.98</td>\n",
       "      <td>73.61</td>\n",
       "      <td>73.56</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CIFAR10</th>\n",
       "      <td>77.84</td>\n",
       "      <td>78.26</td>\n",
       "      <td>77.78</td>\n",
       "      <td>78.26</td>\n",
       "      <td>72.07</td>\n",
       "      <td>71.04</td>\n",
       "      <td>71.50</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SVHN</th>\n",
       "      <td>83.16</td>\n",
       "      <td>83.41</td>\n",
       "      <td>82.79</td>\n",
       "      <td>83.41</td>\n",
       "      <td>73.88</td>\n",
       "      <td>72.70</td>\n",
       "      <td>73.23</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                           Bayes(O)  Bayes(I)  Total(O)  Total(I)     BI  \\\n",
       "InD      OOD                                                               \n",
       "CIFAR10  Blurred CIFAR10      80.10     82.15     82.76     82.15  83.81   \n",
       "         Blurred CIFAR100     91.89     93.33     93.52     93.33  93.20   \n",
       "         CIFAR100             89.51     89.57     89.23     89.57  88.45   \n",
       "         SVHN                 93.12     93.27     92.95     93.27  91.92   \n",
       "CIFAR100 Blurred CIFAR10      84.85     87.02     88.68     87.02  81.58   \n",
       "         Blurred CIFAR100     68.93     70.94     73.30     70.94  72.98   \n",
       "         CIFAR10              77.84     78.26     77.78     78.26  72.07   \n",
       "         SVHN                 83.16     83.41     82.79     83.41  73.88   \n",
       "\n",
       "                             RBI   EPBI  \n",
       "InD      OOD                             \n",
       "CIFAR10  Blurred CIFAR10   83.97  83.94  \n",
       "         Blurred CIFAR100  93.17  93.20  \n",
       "         CIFAR100          88.28  88.35  \n",
       "         SVHN              91.77  91.84  \n",
       "CIFAR100 Blurred CIFAR10   80.82  81.35  \n",
       "         Blurred CIFAR100  73.61  73.56  \n",
       "         CIFAR10           71.04  71.50  \n",
       "         SVHN              72.70  73.23  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{center}\n",
      "\\begin{tabular}{llrrrrrrr}\n",
      "\\toprule\n",
      "\\multicolumn{2}{c}{Dataset} & \\multicolumn{5}{c}{Metrics} \\\\\n",
      "\\cmidrule(lr){1-2} \\cmidrule(lr){3-7}\n",
      " &  & Bayes(O) & Bayes(I) & Total(O) & Total(I) & BI & RBI & EPBI \\\\\n",
      "InD & OOD &  &  &  &  &  &  &  \\\\\n",
      "\\midrule\n",
      "\\rowcolor{gray!10}\n",
      "\\multirow[t]{4}{*}{CIFAR10} & Blurred CIFAR10 & 80.10 & 82.15 & 82.76 & 82.15 & 83.81 & 83.97 & 83.94 \\\\\n",
      " & Blurred CIFAR100 & 91.89 & 93.33 & 93.52 & 93.33 & 93.20 & 93.17 & 93.20 \\\\\n",
      " & CIFAR100 & 89.51 & 89.57 & 89.23 & 89.57 & 88.45 & 88.28 & 88.35 \\\\\n",
      " & SVHN & 93.12 & 93.27 & 92.95 & 93.27 & 91.92 & 91.77 & 91.84 \\\\\n",
      "\\cline{1-9}\n",
      "\\multirow[t]{4}{*}{CIFAR100} & Blurred CIFAR10 & 84.85 & 87.02 & 88.68 & 87.02 & 81.58 & 80.82 & 81.35 \\\\\n",
      " & Blurred CIFAR100 & 68.93 & 70.94 & 73.30 & 70.94 & 72.98 & 73.61 & 73.56 \\\\\n",
      " & CIFAR10 & 77.84 & 78.26 & 77.78 & 78.26 & 72.07 & 71.04 & 71.50 \\\\\n",
      " & SVHN & 83.16 & 83.41 & 82.79 & 83.41 & 73.88 & 72.70 & 73.23 \\\\\n",
      "\\cline{1-9}\n",
      "\\end{tabular}\n",
      "\\end{center}\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "nice_same = get_nice_df(same_agg_df_mean[measures].copy())\n",
    "enhanced_latex = enhance_latex_table(nice_same[1])\n",
    "print(enhanced_latex)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "ca952e11-66d0-4495-a11f-e91bef7eeddd",
   "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(O)</th>\n",
       "      <th>Bayes(I)</th>\n",
       "      <th>Total(O)</th>\n",
       "      <th>Total(I)</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",
       "      <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.68</td>\n",
       "      <td>0.65</td>\n",
       "      <td>0.64</td>\n",
       "      <td>0.65</td>\n",
       "      <td>0.59</td>\n",
       "      <td>0.58</td>\n",
       "      <td>0.59</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Blurred CIFAR100</th>\n",
       "      <td>0.44</td>\n",
       "      <td>0.38</td>\n",
       "      <td>0.34</td>\n",
       "      <td>0.38</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.24</td>\n",
       "      <td>0.25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CIFAR100</th>\n",
       "      <td>0.17</td>\n",
       "      <td>0.15</td>\n",
       "      <td>0.14</td>\n",
       "      <td>0.15</td>\n",
       "      <td>0.18</td>\n",
       "      <td>0.17</td>\n",
       "      <td>0.17</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SVHN</th>\n",
       "      <td>0.92</td>\n",
       "      <td>0.83</td>\n",
       "      <td>0.80</td>\n",
       "      <td>0.83</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.81</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.23</td>\n",
       "      <td>0.23</td>\n",
       "      <td>0.23</td>\n",
       "      <td>0.34</td>\n",
       "      <td>0.35</td>\n",
       "      <td>0.34</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Blurred CIFAR100</th>\n",
       "      <td>0.31</td>\n",
       "      <td>0.30</td>\n",
       "      <td>0.32</td>\n",
       "      <td>0.30</td>\n",
       "      <td>0.35</td>\n",
       "      <td>0.37</td>\n",
       "      <td>0.37</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CIFAR10</th>\n",
       "      <td>0.21</td>\n",
       "      <td>0.19</td>\n",
       "      <td>0.18</td>\n",
       "      <td>0.19</td>\n",
       "      <td>0.26</td>\n",
       "      <td>0.26</td>\n",
       "      <td>0.26</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SVHN</th>\n",
       "      <td>1.41</td>\n",
       "      <td>1.34</td>\n",
       "      <td>1.21</td>\n",
       "      <td>1.34</td>\n",
       "      <td>1.27</td>\n",
       "      <td>1.26</td>\n",
       "      <td>1.25</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                           Bayes(O)  Bayes(I)  Total(O)  Total(I)    BI   RBI  \\\n",
       "InD      OOD                                                                    \n",
       "CIFAR10  Blurred CIFAR10       0.68      0.65      0.64      0.65  0.59  0.58   \n",
       "         Blurred CIFAR100      0.44      0.38      0.34      0.38  0.25  0.24   \n",
       "         CIFAR100              0.17      0.15      0.14      0.15  0.18  0.17   \n",
       "         SVHN                  0.92      0.83      0.80      0.83  0.81  0.81   \n",
       "CIFAR100 Blurred CIFAR10       0.24      0.23      0.23      0.23  0.34  0.35   \n",
       "         Blurred CIFAR100      0.31      0.30      0.32      0.30  0.35  0.37   \n",
       "         CIFAR10               0.21      0.19      0.18      0.19  0.26  0.26   \n",
       "         SVHN                  1.41      1.34      1.21      1.34  1.27  1.26   \n",
       "\n",
       "                           EPBI  \n",
       "InD      OOD                     \n",
       "CIFAR10  Blurred CIFAR10   0.59  \n",
       "         Blurred CIFAR100  0.25  \n",
       "         CIFAR100          0.17  \n",
       "         SVHN              0.81  \n",
       "CIFAR100 Blurred CIFAR10   0.34  \n",
       "         Blurred CIFAR100  0.37  \n",
       "         CIFAR10           0.26  \n",
       "         SVHN              1.25  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{center}\n",
      "\\begin{tabular}{llrrrrrrr}\n",
      "\\toprule\n",
      "\\multicolumn{2}{c}{Dataset} & \\multicolumn{5}{c}{Metrics} \\\\\n",
      "\\cmidrule(lr){1-2} \\cmidrule(lr){3-7}\n",
      " &  & Bayes(O) & Bayes(I) & Total(O) & Total(I) & BI & RBI & EPBI \\\\\n",
      "InD & OOD &  &  &  &  &  &  &  \\\\\n",
      "\\midrule\n",
      "\\rowcolor{gray!10}\n",
      "\\multirow[t]{4}{*}{CIFAR10} & Blurred CIFAR10 & 0.68 & 0.65 & 0.64 & 0.65 & 0.59 & 0.58 & 0.59 \\\\\n",
      " & Blurred CIFAR100 & 0.44 & 0.38 & 0.34 & 0.38 & 0.25 & 0.24 & 0.25 \\\\\n",
      " & CIFAR100 & 0.17 & 0.15 & 0.14 & 0.15 & 0.18 & 0.17 & 0.17 \\\\\n",
      " & SVHN & 0.92 & 0.83 & 0.80 & 0.83 & 0.81 & 0.81 & 0.81 \\\\\n",
      "\\cline{1-9}\n",
      "\\multirow[t]{4}{*}{CIFAR100} & Blurred CIFAR10 & 0.24 & 0.23 & 0.23 & 0.23 & 0.34 & 0.35 & 0.34 \\\\\n",
      " & Blurred CIFAR100 & 0.31 & 0.30 & 0.32 & 0.30 & 0.35 & 0.37 & 0.37 \\\\\n",
      " & CIFAR10 & 0.21 & 0.19 & 0.18 & 0.19 & 0.26 & 0.26 & 0.26 \\\\\n",
      " & SVHN & 1.41 & 1.34 & 1.21 & 1.34 & 1.27 & 1.26 & 1.25 \\\\\n",
      "\\cline{1-9}\n",
      "\\end{tabular}\n",
      "\\end{center}\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "nice_same = get_nice_df(same_agg_df_std[measures].copy())\n",
    "enhanced_latex = enhance_latex_table(nice_same[1])\n",
    "print(enhanced_latex)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "5f374d2c-c080-4976-bdd4-567fbb97f130",
   "metadata": {},
   "outputs": [],
   "source": [
    "# different_agg_df_mean"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "374eccd8-2273-410c-b75e-87bf53fc6aef",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "b69fd8dc-4340-46c3-b035-436028987b42",
   "metadata": {},
   "outputs": [],
   "source": [
    "# display(full_ood_rocauc[(full_ood_rocauc.training_dataset == 'cifar100') & (full_ood_rocauc.Dataset == 'svhn') & full_ood_rocauc.UQMetric.str.endswith('Inner Outer')].head(10))\n",
    "# # full_ood_rocauc[full_ood_rocauc.RocAucScoresMean.values.isclose(0.666047)]\n",
    "# display(full_ood_rocauc[(full_ood_rocauc.training_dataset == 'cifar100') & (full_ood_rocauc.Dataset == 'svhn') & (full_ood_rocauc.RiskType == 'Reverse Bregman Information')].head(10))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "d4378f39-d279-47ac-b149-283b506242ea",
   "metadata": {},
   "outputs": [],
   "source": [
    "# full_ood_rocauc.loc[2586]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "aa8e1305-6052-48b4-bf39-d83b42337998",
   "metadata": {},
   "outputs": [],
   "source": [
    "# full_ood_rocauc.loc[2872]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "747d31b8-c583-43e9-b143-379679dd06b5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "710b2032-93cf-468f-ad06-1fd43084030b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "9e9f067a-17e3-4e45-b83a-fac3f807bea9",
   "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>Total Outer</th>\n",
       "      <th>Total Inner</th>\n",
       "      <th>Bayes Inner</th>\n",
       "      <th>Bayes Outer</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",
       "      <th>OOD</th>\n",
       "      <th>InD</th>\n",
       "      <th>ScoringRule</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>0.880747</td>\n",
       "      <td>0.863043</td>\n",
       "      <td>0.863043</td>\n",
       "      <td>0.839023</td>\n",
       "      <td>0.728368</td>\n",
       "      <td>0.735029</td>\n",
       "      <td>0.720185</td>\n",
       "      <td>0.729890</td>\n",
       "      <td>0.483691</td>\n",
       "      <td>0.632492</td>\n",
       "      <td>0.733130</td>\n",
       "      <td>0.526921</td>\n",
       "      <td>blurred_cifar10</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>[Spherical]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>0.827065</td>\n",
       "      <td>0.826300</td>\n",
       "      <td>0.826300</td>\n",
       "      <td>0.825795</td>\n",
       "      <td>0.729555</td>\n",
       "      <td>0.737446</td>\n",
       "      <td>0.723678</td>\n",
       "      <td>0.727542</td>\n",
       "      <td>0.554977</td>\n",
       "      <td>0.658624</td>\n",
       "      <td>0.732065</td>\n",
       "      <td>0.563549</td>\n",
       "      <td>svhn</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>[Brier]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>0.892713</td>\n",
       "      <td>0.894592</td>\n",
       "      <td>0.894592</td>\n",
       "      <td>0.894228</td>\n",
       "      <td>0.839297</td>\n",
       "      <td>0.840440</td>\n",
       "      <td>0.838064</td>\n",
       "      <td>0.839388</td>\n",
       "      <td>0.634593</td>\n",
       "      <td>0.755594</td>\n",
       "      <td>0.839954</td>\n",
       "      <td>0.651157</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>[Brier]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>0.889302</td>\n",
       "      <td>0.891456</td>\n",
       "      <td>0.891456</td>\n",
       "      <td>0.890634</td>\n",
       "      <td>0.832077</td>\n",
       "      <td>0.833074</td>\n",
       "      <td>0.831182</td>\n",
       "      <td>0.831974</td>\n",
       "      <td>0.516087</td>\n",
       "      <td>0.749927</td>\n",
       "      <td>0.832907</td>\n",
       "      <td>0.646047</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>[Spherical]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>0.935122</td>\n",
       "      <td>0.933238</td>\n",
       "      <td>0.933238</td>\n",
       "      <td>0.919937</td>\n",
       "      <td>0.899281</td>\n",
       "      <td>0.900697</td>\n",
       "      <td>0.896842</td>\n",
       "      <td>0.900303</td>\n",
       "      <td>0.660454</td>\n",
       "      <td>0.787430</td>\n",
       "      <td>0.900233</td>\n",
       "      <td>0.678079</td>\n",
       "      <td>blurred_cifar100</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>[Brier]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.936491</td>\n",
       "      <td>0.935840</td>\n",
       "      <td>0.935840</td>\n",
       "      <td>0.921372</td>\n",
       "      <td>0.899925</td>\n",
       "      <td>0.900809</td>\n",
       "      <td>0.897790</td>\n",
       "      <td>0.901177</td>\n",
       "      <td>0.515921</td>\n",
       "      <td>0.788833</td>\n",
       "      <td>0.900720</td>\n",
       "      <td>0.677800</td>\n",
       "      <td>blurred_cifar100</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>[Logscore]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>0.826246</td>\n",
       "      <td>0.832356</td>\n",
       "      <td>0.832356</td>\n",
       "      <td>0.833322</td>\n",
       "      <td>0.733237</td>\n",
       "      <td>0.738160</td>\n",
       "      <td>0.727778</td>\n",
       "      <td>0.733774</td>\n",
       "      <td>0.488891</td>\n",
       "      <td>0.659003</td>\n",
       "      <td>0.736238</td>\n",
       "      <td>0.557753</td>\n",
       "      <td>svhn</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>[Logscore]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>0.881782</td>\n",
       "      <td>0.875221</td>\n",
       "      <td>0.875221</td>\n",
       "      <td>0.850487</td>\n",
       "      <td>0.815520</td>\n",
       "      <td>0.822300</td>\n",
       "      <td>0.803278</td>\n",
       "      <td>0.820982</td>\n",
       "      <td>0.496525</td>\n",
       "      <td>0.710530</td>\n",
       "      <td>0.820096</td>\n",
       "      <td>0.606594</td>\n",
       "      <td>blurred_cifar10</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>[Logscore]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>0.731760</td>\n",
       "      <td>0.722372</td>\n",
       "      <td>0.722372</td>\n",
       "      <td>0.700992</td>\n",
       "      <td>0.715151</td>\n",
       "      <td>0.714932</td>\n",
       "      <td>0.712523</td>\n",
       "      <td>0.717998</td>\n",
       "      <td>0.503697</td>\n",
       "      <td>0.650679</td>\n",
       "      <td>0.714556</td>\n",
       "      <td>0.586516</td>\n",
       "      <td>blurred_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>[Logscore]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>0.720087</td>\n",
       "      <td>0.703382</td>\n",
       "      <td>0.703382</td>\n",
       "      <td>0.688986</td>\n",
       "      <td>0.712488</td>\n",
       "      <td>0.709476</td>\n",
       "      <td>0.712777</td>\n",
       "      <td>0.715210</td>\n",
       "      <td>0.584775</td>\n",
       "      <td>0.648712</td>\n",
       "      <td>0.709260</td>\n",
       "      <td>0.593182</td>\n",
       "      <td>blurred_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>[Brier]</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    Total Outer  Total Inner  Bayes Inner  Bayes Outer    Excess  \\\n",
       "23     0.880747     0.863043     0.863043     0.839023  0.728368   \n",
       "13     0.827065     0.826300     0.826300     0.825795  0.729555   \n",
       "8      0.892713     0.894592     0.894592     0.894228  0.839297   \n",
       "16     0.889302     0.891456     0.891456     0.890634  0.832077   \n",
       "11     0.935122     0.933238     0.933238     0.919937  0.899281   \n",
       "3      0.936491     0.935840     0.935840     0.921372  0.899925   \n",
       "5      0.826246     0.832356     0.832356     0.833322  0.733237   \n",
       "7      0.881782     0.875221     0.875221     0.850487  0.815520   \n",
       "6      0.731760     0.722372     0.722372     0.700992  0.715151   \n",
       "14     0.720087     0.703382     0.703382     0.688986  0.712488   \n",
       "\n",
       "    Bregman Information  Reverse Bregman Information  \\\n",
       "23             0.735029                     0.720185   \n",
       "13             0.737446                     0.723678   \n",
       "8              0.840440                     0.838064   \n",
       "16             0.833074                     0.831182   \n",
       "11             0.900697                     0.896842   \n",
       "3              0.900809                     0.897790   \n",
       "5              0.738160                     0.727778   \n",
       "7              0.822300                     0.803278   \n",
       "6              0.714932                     0.712523   \n",
       "14             0.709476                     0.712777   \n",
       "\n",
       "    Expected Pairwise Bregman Information      Bias        MV      MVBI  \\\n",
       "23                               0.729890  0.483691  0.632492  0.733130   \n",
       "13                               0.727542  0.554977  0.658624  0.732065   \n",
       "8                                0.839388  0.634593  0.755594  0.839954   \n",
       "16                               0.831974  0.516087  0.749927  0.832907   \n",
       "11                               0.900303  0.660454  0.787430  0.900233   \n",
       "3                                0.901177  0.515921  0.788833  0.900720   \n",
       "5                                0.733774  0.488891  0.659003  0.736238   \n",
       "7                                0.820982  0.496525  0.710530  0.820096   \n",
       "6                                0.717998  0.503697  0.650679  0.714556   \n",
       "14                               0.715210  0.584775  0.648712  0.709260   \n",
       "\n",
       "      BiasBI               OOD       InD  ScoringRule  \n",
       "23  0.526921   blurred_cifar10  cifar100  [Spherical]  \n",
       "13  0.563549              svhn  cifar100      [Brier]  \n",
       "8   0.651157          cifar100   cifar10      [Brier]  \n",
       "16  0.646047          cifar100   cifar10  [Spherical]  \n",
       "11  0.678079  blurred_cifar100   cifar10      [Brier]  \n",
       "3   0.677800  blurred_cifar100   cifar10   [Logscore]  \n",
       "5   0.557753              svhn  cifar100   [Logscore]  \n",
       "7   0.606594   blurred_cifar10  cifar100   [Logscore]  \n",
       "6   0.586516  blurred_cifar100  cifar100   [Logscore]  \n",
       "14  0.593182  blurred_cifar100  cifar100      [Brier]  "
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "different_df_mean.sample(10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "cc7dde46-b78f-4238-97b8-559a02a7f06b",
   "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(O)</th>\n",
       "      <th>Bayes(I)</th>\n",
       "      <th>Total(O)</th>\n",
       "      <th>Total(I)</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",
       "      <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>80.07</td>\n",
       "      <td>82.11</td>\n",
       "      <td>82.56</td>\n",
       "      <td>82.11</td>\n",
       "      <td>79.92</td>\n",
       "      <td>79.76</td>\n",
       "      <td>80.01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Blurred CIFAR100</th>\n",
       "      <td>91.79</td>\n",
       "      <td>93.21</td>\n",
       "      <td>93.39</td>\n",
       "      <td>93.21</td>\n",
       "      <td>89.93</td>\n",
       "      <td>89.57</td>\n",
       "      <td>89.92</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CIFAR100</th>\n",
       "      <td>89.41</td>\n",
       "      <td>89.46</td>\n",
       "      <td>89.28</td>\n",
       "      <td>89.46</td>\n",
       "      <td>83.81</td>\n",
       "      <td>83.63</td>\n",
       "      <td>83.75</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SVHN</th>\n",
       "      <td>93.00</td>\n",
       "      <td>93.14</td>\n",
       "      <td>92.94</td>\n",
       "      <td>93.14</td>\n",
       "      <td>87.55</td>\n",
       "      <td>87.34</td>\n",
       "      <td>87.47</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">CIFAR100</th>\n",
       "      <th>Blurred CIFAR10</th>\n",
       "      <td>84.58</td>\n",
       "      <td>86.70</td>\n",
       "      <td>87.99</td>\n",
       "      <td>86.70</td>\n",
       "      <td>79.11</td>\n",
       "      <td>77.42</td>\n",
       "      <td>78.68</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Blurred CIFAR100</th>\n",
       "      <td>68.72</td>\n",
       "      <td>70.70</td>\n",
       "      <td>72.44</td>\n",
       "      <td>70.70</td>\n",
       "      <td>70.43</td>\n",
       "      <td>70.41</td>\n",
       "      <td>70.82</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CIFAR10</th>\n",
       "      <td>77.66</td>\n",
       "      <td>78.07</td>\n",
       "      <td>77.86</td>\n",
       "      <td>78.07</td>\n",
       "      <td>69.42</td>\n",
       "      <td>68.34</td>\n",
       "      <td>68.84</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SVHN</th>\n",
       "      <td>82.75</td>\n",
       "      <td>82.90</td>\n",
       "      <td>82.68</td>\n",
       "      <td>82.90</td>\n",
       "      <td>71.01</td>\n",
       "      <td>69.89</td>\n",
       "      <td>70.30</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                           Bayes(O)  Bayes(I)  Total(O)  Total(I)     BI  \\\n",
       "InD      OOD                                                               \n",
       "CIFAR10  Blurred CIFAR10      80.07     82.11     82.56     82.11  79.92   \n",
       "         Blurred CIFAR100     91.79     93.21     93.39     93.21  89.93   \n",
       "         CIFAR100             89.41     89.46     89.28     89.46  83.81   \n",
       "         SVHN                 93.00     93.14     92.94     93.14  87.55   \n",
       "CIFAR100 Blurred CIFAR10      84.58     86.70     87.99     86.70  79.11   \n",
       "         Blurred CIFAR100     68.72     70.70     72.44     70.70  70.43   \n",
       "         CIFAR10              77.66     78.07     77.86     78.07  69.42   \n",
       "         SVHN                 82.75     82.90     82.68     82.90  71.01   \n",
       "\n",
       "                             RBI   EPBI  \n",
       "InD      OOD                             \n",
       "CIFAR10  Blurred CIFAR10   79.76  80.01  \n",
       "         Blurred CIFAR100  89.57  89.92  \n",
       "         CIFAR100          83.63  83.75  \n",
       "         SVHN              87.34  87.47  \n",
       "CIFAR100 Blurred CIFAR10   77.42  78.68  \n",
       "         Blurred CIFAR100  70.41  70.82  \n",
       "         CIFAR10           68.34  68.84  \n",
       "         SVHN              69.89  70.30  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{center}\n",
      "\\begin{tabular}{llrrrrrrr}\n",
      "\\toprule\n",
      "\\multicolumn{2}{c}{Dataset} & \\multicolumn{5}{c}{Metrics} \\\\\n",
      "\\cmidrule(lr){1-2} \\cmidrule(lr){3-7}\n",
      " &  & Bayes(O) & Bayes(I) & Total(O) & Total(I) & BI & RBI & EPBI \\\\\n",
      "InD & OOD &  &  &  &  &  &  &  \\\\\n",
      "\\midrule\n",
      "\\rowcolor{gray!10}\n",
      "\\multirow[t]{4}{*}{CIFAR10} & Blurred CIFAR10 & 80.07 & 82.11 & 82.56 & 82.11 & 79.92 & 79.76 & 80.01 \\\\\n",
      " & Blurred CIFAR100 & 91.79 & 93.21 & 93.39 & 93.21 & 89.93 & 89.57 & 89.92 \\\\\n",
      " & CIFAR100 & 89.41 & 89.46 & 89.28 & 89.46 & 83.81 & 83.63 & 83.75 \\\\\n",
      " & SVHN & 93.00 & 93.14 & 92.94 & 93.14 & 87.55 & 87.34 & 87.47 \\\\\n",
      "\\cline{1-9}\n",
      "\\multirow[t]{4}{*}{CIFAR100} & Blurred CIFAR10 & 84.58 & 86.70 & 87.99 & 86.70 & 79.11 & 77.42 & 78.68 \\\\\n",
      " & Blurred CIFAR100 & 68.72 & 70.70 & 72.44 & 70.70 & 70.43 & 70.41 & 70.82 \\\\\n",
      " & CIFAR10 & 77.66 & 78.07 & 77.86 & 78.07 & 69.42 & 68.34 & 68.84 \\\\\n",
      " & SVHN & 82.75 & 82.90 & 82.68 & 82.90 & 71.01 & 69.89 & 70.30 \\\\\n",
      "\\cline{1-9}\n",
      "\\end{tabular}\n",
      "\\end{center}\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "nice_same = get_nice_df(different_agg_df_mean[measures].copy())\n",
    "enhanced_latex = enhance_latex_table(nice_same[1])\n",
    "print(enhanced_latex)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "1b40bbc8-4ff5-4dd9-8fb4-f1f0e2b4a6bb",
   "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(O)</th>\n",
       "      <th>Bayes(I)</th>\n",
       "      <th>Total(O)</th>\n",
       "      <th>Total(I)</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",
       "      <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.68</td>\n",
       "      <td>0.65</td>\n",
       "      <td>0.64</td>\n",
       "      <td>0.65</td>\n",
       "      <td>0.61</td>\n",
       "      <td>0.61</td>\n",
       "      <td>0.62</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Blurred CIFAR100</th>\n",
       "      <td>0.43</td>\n",
       "      <td>0.37</td>\n",
       "      <td>0.34</td>\n",
       "      <td>0.37</td>\n",
       "      <td>0.35</td>\n",
       "      <td>0.34</td>\n",
       "      <td>0.33</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CIFAR100</th>\n",
       "      <td>0.17</td>\n",
       "      <td>0.15</td>\n",
       "      <td>0.15</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.91</td>\n",
       "      <td>0.83</td>\n",
       "      <td>0.82</td>\n",
       "      <td>0.83</td>\n",
       "      <td>1.30</td>\n",
       "      <td>1.24</td>\n",
       "      <td>1.30</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"4\" valign=\"top\">CIFAR100</th>\n",
       "      <th>Blurred CIFAR10</th>\n",
       "      <td>0.26</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.23</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.35</td>\n",
       "      <td>0.34</td>\n",
       "      <td>0.36</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Blurred CIFAR100</th>\n",
       "      <td>0.32</td>\n",
       "      <td>0.30</td>\n",
       "      <td>0.32</td>\n",
       "      <td>0.30</td>\n",
       "      <td>0.36</td>\n",
       "      <td>0.37</td>\n",
       "      <td>0.37</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>CIFAR10</th>\n",
       "      <td>0.22</td>\n",
       "      <td>0.21</td>\n",
       "      <td>0.21</td>\n",
       "      <td>0.21</td>\n",
       "      <td>0.27</td>\n",
       "      <td>0.29</td>\n",
       "      <td>0.29</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>SVHN</th>\n",
       "      <td>1.40</td>\n",
       "      <td>1.32</td>\n",
       "      <td>1.30</td>\n",
       "      <td>1.32</td>\n",
       "      <td>1.33</td>\n",
       "      <td>1.26</td>\n",
       "      <td>1.33</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                           Bayes(O)  Bayes(I)  Total(O)  Total(I)    BI   RBI  \\\n",
       "InD      OOD                                                                    \n",
       "CIFAR10  Blurred CIFAR10       0.68      0.65      0.64      0.65  0.61  0.61   \n",
       "         Blurred CIFAR100      0.43      0.37      0.34      0.37  0.35  0.34   \n",
       "         CIFAR100              0.17      0.15      0.15      0.15  0.21  0.20   \n",
       "         SVHN                  0.91      0.83      0.82      0.83  1.30  1.24   \n",
       "CIFAR100 Blurred CIFAR10       0.26      0.25      0.23      0.25  0.35  0.34   \n",
       "         Blurred CIFAR100      0.32      0.30      0.32      0.30  0.36  0.37   \n",
       "         CIFAR10               0.22      0.21      0.21      0.21  0.27  0.29   \n",
       "         SVHN                  1.40      1.32      1.30      1.32  1.33  1.26   \n",
       "\n",
       "                           EPBI  \n",
       "InD      OOD                     \n",
       "CIFAR10  Blurred CIFAR10   0.62  \n",
       "         Blurred CIFAR100  0.33  \n",
       "         CIFAR100          0.20  \n",
       "         SVHN              1.30  \n",
       "CIFAR100 Blurred CIFAR10   0.36  \n",
       "         Blurred CIFAR100  0.37  \n",
       "         CIFAR10           0.29  \n",
       "         SVHN              1.33  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{center}\n",
      "\\begin{tabular}{llrrrrrrr}\n",
      "\\toprule\n",
      "\\multicolumn{2}{c}{Dataset} & \\multicolumn{5}{c}{Metrics} \\\\\n",
      "\\cmidrule(lr){1-2} \\cmidrule(lr){3-7}\n",
      " &  & Bayes(O) & Bayes(I) & Total(O) & Total(I) & BI & RBI & EPBI \\\\\n",
      "InD & OOD &  &  &  &  &  &  &  \\\\\n",
      "\\midrule\n",
      "\\rowcolor{gray!10}\n",
      "\\multirow[t]{4}{*}{CIFAR10} & Blurred CIFAR10 & 0.68 & 0.65 & 0.64 & 0.65 & 0.61 & 0.61 & 0.62 \\\\\n",
      " & Blurred CIFAR100 & 0.43 & 0.37 & 0.34 & 0.37 & 0.35 & 0.34 & 0.33 \\\\\n",
      " & CIFAR100 & 0.17 & 0.15 & 0.15 & 0.15 & 0.21 & 0.20 & 0.20 \\\\\n",
      " & SVHN & 0.91 & 0.83 & 0.82 & 0.83 & 1.30 & 1.24 & 1.30 \\\\\n",
      "\\cline{1-9}\n",
      "\\multirow[t]{4}{*}{CIFAR100} & Blurred CIFAR10 & 0.26 & 0.25 & 0.23 & 0.25 & 0.35 & 0.34 & 0.36 \\\\\n",
      " & Blurred CIFAR100 & 0.32 & 0.30 & 0.32 & 0.30 & 0.36 & 0.37 & 0.37 \\\\\n",
      " & CIFAR10 & 0.22 & 0.21 & 0.21 & 0.21 & 0.27 & 0.29 & 0.29 \\\\\n",
      " & SVHN & 1.40 & 1.32 & 1.30 & 1.32 & 1.33 & 1.26 & 1.33 \\\\\n",
      "\\cline{1-9}\n",
      "\\end{tabular}\n",
      "\\end{center}\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "nice_same = get_nice_df(different_agg_df_std[measures].copy())\n",
    "enhanced_latex = enhance_latex_table(nice_same[1])\n",
    "print(enhanced_latex)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4c5fd164-669c-4e71-85d6-c6cc629cfa66",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "830d62ce-dbfb-4ace-a20c-164bee6cd658",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "132ac309-eb00-4994-9419-0ed18ac1afd8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "60d6ab2e-7521-41c5-9fda-6f84d1cd9d15",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6f03a2e8-cae4-4a16-a770-a93ccc5a0c14",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "93b2eca4-23cb-4dc6-a53b-64410ab9e7a0",
   "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
}
