{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "89932425-2b6b-4bb1-af99-f194630178a7",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "stty: 'standard input': Inappropriate ioctl for device\n",
      "/home/nkotelevskii/github/uncertainty_from_proper_scoring_rules/.venv/lib/python3.11/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "from source.source.postprocessing_utils import (\n",
    "    get_sampled_combinations_uncertainty_scores,\n",
    "    ENSEMBLE_COMBINATIONS,\n",
    ")\n",
    "from source.notebook.reliability_diagrams import (\n",
    "    reliability_diagram,\n",
    "    compute_calibration,\n",
    ")\n",
    "from source.datasets.constants import DatasetName\n",
    "from source.losses.constants import LossName\n",
    "from source.models.constants import ModelName\n",
    "from source.metrics import (\n",
    "    ApproximationType,\n",
    "    GName,\n",
    "    RiskType,\n",
    "    get_central_prediction,\n",
    "    posterior_predictive,\n",
    ")\n",
    "from source.metrics.utils import safe_softmax\n",
    "\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "\n",
    "pd.set_option(\"display.max_rows\", None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "ff5cc24e-1687-40c4-89c8-13cfb1da42af",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_accuracy(true_labels, pred_labels):\n",
    "    return np.mean(pred_labels == true_labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "99220921-4a76-4e21-b2dc-d01084e3321a",
   "metadata": {},
   "outputs": [],
   "source": [
    "architecture = ModelName.RESNET18\n",
    "model_ids = np.arange(20)\n",
    "list_extraction_datasets = [\n",
    "    \"cifar10\",\n",
    "    \"cifar100\",\n",
    "    \"svhn\",\n",
    "    \"blurred_cifar100\",\n",
    "    \"blurred_cifar10\",\n",
    "]\n",
    "temperature = 1.0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "36323a85-e57c-43aa-aca1-c33472879acb",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_ece_and_accuracy(\n",
    "    logits_,\n",
    "    temperature_,\n",
    "    true_labels_,\n",
    "):\n",
    "    accuracies_bma = []\n",
    "    ece_bma = []\n",
    "\n",
    "    accuracies_central = []\n",
    "    ece_central = []\n",
    "\n",
    "    accuracies_raw = []\n",
    "    ece_raw = []\n",
    "\n",
    "    for comb in ENSEMBLE_COMBINATIONS:\n",
    "        comb = list(comb)\n",
    "        selected_logits = logits_[comb]\n",
    "\n",
    "        prob_bma = np.squeeze(\n",
    "            posterior_predictive(logits_=selected_logits, T=temperature_)\n",
    "        )\n",
    "        pred_bma = np.argmax(prob_bma, axis=-1)\n",
    "\n",
    "        for central_name in [el for el in GName]:\n",
    "            prob_central = np.squeeze(\n",
    "                get_central_prediction(g_name=central_name)(\n",
    "                    logits=selected_logits, T=temperature_\n",
    "                )\n",
    "            )\n",
    "            pred_central = np.argmax(prob_central, axis=-1)\n",
    "\n",
    "            accuracy_central = get_accuracy(\n",
    "                true_labels=true_labels_, pred_labels=pred_central\n",
    "            )\n",
    "            accuracies_central.append({central_name.value: float(accuracy_central)})\n",
    "\n",
    "            ece_central.append(\n",
    "                {\n",
    "                    central_name.value: float(\n",
    "                        compute_calibration(\n",
    "                            true_labels=true_labels_,\n",
    "                            pred_labels=np.argmax(prob_central, axis=-1),\n",
    "                            confidences=np.max(prob_central, axis=-1),\n",
    "                        )[\"expected_calibration_error\"]\n",
    "                    )\n",
    "                }\n",
    "            )\n",
    "\n",
    "        accuracy_bma = get_accuracy(true_labels=true_labels_, pred_labels=pred_bma)\n",
    "        accuracy_raw = get_accuracy(\n",
    "            true_labels=true_labels_, pred_labels=np.argmax(selected_logits, axis=-1)\n",
    "        )\n",
    "\n",
    "        accuracies_bma.append(float(accuracy_bma))\n",
    "\n",
    "        accuracies_raw.append(float(accuracy_raw))\n",
    "\n",
    "        ece_bma.append(\n",
    "            float(\n",
    "                compute_calibration(\n",
    "                    true_labels=true_labels_,\n",
    "                    pred_labels=np.argmax(prob_bma, axis=-1),\n",
    "                    confidences=np.max(prob_bma, axis=-1),\n",
    "                )[\"expected_calibration_error\"]\n",
    "            )\n",
    "        )\n",
    "\n",
    "        ece_raw.append(\n",
    "            float(\n",
    "                np.mean(\n",
    "                    [\n",
    "                        compute_calibration(\n",
    "                            true_labels=true_labels_,\n",
    "                            pred_labels=np.argmax(safe_softmax(el), axis=-1),\n",
    "                            confidences=np.max(safe_softmax(el), axis=-1),\n",
    "                        )[\"expected_calibration_error\"]\n",
    "                        for el in selected_logits\n",
    "                    ]\n",
    "                )\n",
    "            )\n",
    "        )\n",
    "\n",
    "    return (\n",
    "        accuracies_bma,\n",
    "        ece_bma,\n",
    "        accuracies_central,\n",
    "        ece_central,\n",
    "        accuracies_raw,\n",
    "        ece_raw,\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "26cfc05a-3c94-4da1-aa3c-84af192b765e",
   "metadata": {},
   "outputs": [],
   "source": [
    "accuracy_dict = {}\n",
    "ece_dict = {}\n",
    "\n",
    "for (training_dataset_name,) in [\n",
    "    (\"cifar10\",),\n",
    "    (\"cifar100\",),\n",
    "]:\n",
    "    accuracy_dict[training_dataset_name] = {}\n",
    "    ece_dict[training_dataset_name] = {}\n",
    "\n",
    "    for loss_function_names in [\n",
    "        LossName.CROSS_ENTROPY,\n",
    "        LossName.BRIER_SCORE,\n",
    "        LossName.SPHERICAL_SCORE,\n",
    "    ]:\n",
    "        accuracy_dict[training_dataset_name][loss_function_names.value] = {}\n",
    "        ece_dict[training_dataset_name][loss_function_names.value] = {}\n",
    "\n",
    "        uq_results, embeddings_per_dataset, targets_per_dataset = (\n",
    "            get_sampled_combinations_uncertainty_scores(\n",
    "                loss_function_names=[loss_function_names],\n",
    "                training_dataset_name=training_dataset_name,\n",
    "                architecture=architecture,\n",
    "                model_ids=model_ids,\n",
    "                list_extraction_datasets=list_extraction_datasets,\n",
    "                temperature=temperature,\n",
    "                use_cached=True,\n",
    "            )\n",
    "        )\n",
    "\n",
    "        logits = embeddings_per_dataset[loss_function_names.value][\n",
    "            training_dataset_name\n",
    "        ]\n",
    "        max_ind = int(\n",
    "            targets_per_dataset[training_dataset_name].shape[0] / len(model_ids)\n",
    "        )\n",
    "        true_labels = targets_per_dataset[training_dataset_name][:max_ind]\n",
    "\n",
    "        #######\n",
    "\n",
    "        (\n",
    "            accuracies_bma,\n",
    "            ece_bma,\n",
    "            accuracies_central,\n",
    "            ece_central,\n",
    "            accuracies_raw,\n",
    "            ece_raw,\n",
    "        ) = get_ece_and_accuracy(\n",
    "            logits_=logits,\n",
    "            temperature_=temperature,\n",
    "            true_labels_=true_labels,\n",
    "        )\n",
    "\n",
    "        accuracy_dict[training_dataset_name][loss_function_names.value][\"bma\"] = (\n",
    "            accuracies_bma\n",
    "        )\n",
    "        accuracy_dict[training_dataset_name][loss_function_names.value][\"central\"] = (\n",
    "            accuracies_central\n",
    "        )\n",
    "        accuracy_dict[training_dataset_name][loss_function_names.value][\"raw\"] = (\n",
    "            accuracies_raw\n",
    "        )\n",
    "\n",
    "        ece_dict[training_dataset_name][loss_function_names.value][\"bma\"] = ece_bma\n",
    "        ece_dict[training_dataset_name][loss_function_names.value][\"central\"] = (\n",
    "            ece_central\n",
    "        )\n",
    "        ece_dict[training_dataset_name][loss_function_names.value][\"raw\"] = ece_raw\n",
    "\n",
    "\n",
    "def ravel_dict(dict_):\n",
    "    for dataset_name, dataset in dict_.items():\n",
    "        for loss_name, loss in dataset.items():\n",
    "            central = loss[\"central\"]\n",
    "\n",
    "            logscore_list = [el[\"LogScore\"] for el in central if \"LogScore\" in el]\n",
    "            # brier_list = [el['BrierScore'] for el in central if \"BrierScore\" in el]\n",
    "            # zeroone_list = [el['ZeroOneScore'] for el in central if \"ZeroOneScore\" in el]\n",
    "            spherical_list = [\n",
    "                el[\"SphericalScore\"] for el in central if \"SphericalScore\" in el\n",
    "            ]\n",
    "\n",
    "            central = {\n",
    "                \"LogScore\": logscore_list,\n",
    "                # \"BrierScore\": brier_list,\n",
    "                # \"ZeroOneScore\": zeroone_list,\n",
    "                \"SphericalScore\": spherical_list,\n",
    "            }\n",
    "\n",
    "            dict_[dataset_name][loss_name][\"central\"] = central\n",
    "    return dict_\n",
    "\n",
    "\n",
    "accuracy_dict = ravel_dict(accuracy_dict)\n",
    "ece_dict = ravel_dict(ece_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f066b1ea-f8b5-4003-aed4-ac1a47e8a36a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "c1bdab2f-7adf-4494-8687-01d164caba4f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'LogScore': [0.01827602108120918,\n",
       "  0.01711895966231823,\n",
       "  0.019362305691838264,\n",
       "  0.018171447694301606,\n",
       "  0.019430832040309907],\n",
       " 'SphericalScore': [0.023966585083305837,\n",
       "  0.022483455276489258,\n",
       "  0.02184618239402771,\n",
       "  0.023699307112395762,\n",
       "  0.022297505536675453]}"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ece_dict[\"cifar10\"][\"CrossEntropy\"][\"central\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "73d791ba-0757-4db1-9b55-4f87fc8ddd5c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def mean_std_df(dict_):\n",
    "    # Initialize a dictionary to store results\n",
    "    rows = []\n",
    "    rows_std = []\n",
    "\n",
    "    # Loop through the datasets, loss functions, and estimation methods\n",
    "    for dataset_name, loss_functions in dict_.items():\n",
    "        row = {\"Dataset\": dataset_name}\n",
    "        row_std = {\"Dataset\": dataset_name}\n",
    "        for loss_func_name, estimations in loss_functions.items():\n",
    "            # Calculate the mean for 'bma' and 'raw' lists\n",
    "            bma_mean = np.mean(estimations.get(\"bma\", []))\n",
    "            raw_mean = np.mean(estimations.get(\"raw\", []))\n",
    "\n",
    "            bma_std = np.std(estimations.get(\"bma\", []))\n",
    "            raw_std = np.std(estimations.get(\"raw\", []))\n",
    "\n",
    "            # Add 'BMA' and 'Raw' means to the row\n",
    "            row[(loss_func_name, \"BMA\")] = bma_mean\n",
    "            row[(loss_func_name, \"Raw\")] = raw_mean\n",
    "\n",
    "            row_std[(loss_func_name, \"BMA\")] = bma_std\n",
    "            row_std[(loss_func_name, \"Raw\")] = raw_std\n",
    "\n",
    "            # Handle 'central' dict by calculating the mean for each function\n",
    "            if \"central\" in estimations:\n",
    "                for func_name, values in estimations[\"central\"].items():\n",
    "                    row[(loss_func_name, f\"central_{func_name}\")] = np.mean(values)\n",
    "                    row_std[(loss_func_name, f\"central_{func_name}\")] = np.std(values)\n",
    "\n",
    "        rows.append(row)\n",
    "        rows_std.append(row_std)\n",
    "\n",
    "    # Create a DataFrame with multi-index columns\n",
    "    df = pd.DataFrame(rows)\n",
    "    df_std = pd.DataFrame(rows_std)\n",
    "\n",
    "    # Set 'Dataset' as the index\n",
    "    df.set_index(\"Dataset\", inplace=True)\n",
    "    df_std.set_index(\"Dataset\", inplace=True)\n",
    "\n",
    "    return df, df_std"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "02ea12ff-605c-411d-8a89-ab492d2e6f09",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_acc, df_acc_std = mean_std_df(accuracy_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "03a23437-f633-4294-a94b-4454988cf7f7",
   "metadata": {},
   "outputs": [],
   "source": [
    "# # Display the resulting DataFrame\n",
    "# import ace_tools as tools\n",
    "\n",
    "# tools.display_dataframe_to_user(name=\"Multi-Level Loss Estimation Table\", dataframe=df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "ca34ce20-f2bc-4359-8c43-f58ba9e86b9d",
   "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>(CrossEntropy, BMA)</th>\n",
       "      <th>(CrossEntropy, Raw)</th>\n",
       "      <th>(CrossEntropy, central_LogScore)</th>\n",
       "      <th>(CrossEntropy, central_SphericalScore)</th>\n",
       "      <th>(BrierScore, BMA)</th>\n",
       "      <th>(BrierScore, Raw)</th>\n",
       "      <th>(BrierScore, central_LogScore)</th>\n",
       "      <th>(BrierScore, central_SphericalScore)</th>\n",
       "      <th>(SphericalScore, BMA)</th>\n",
       "      <th>(SphericalScore, Raw)</th>\n",
       "      <th>(SphericalScore, central_LogScore)</th>\n",
       "      <th>(SphericalScore, central_SphericalScore)</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dataset</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>cifar10</th>\n",
       "      <td>0.96184</td>\n",
       "      <td>0.95460</td>\n",
       "      <td>0.96232</td>\n",
       "      <td>0.96166</td>\n",
       "      <td>0.96090</td>\n",
       "      <td>0.952390</td>\n",
       "      <td>0.96078</td>\n",
       "      <td>0.96072</td>\n",
       "      <td>0.96094</td>\n",
       "      <td>0.951345</td>\n",
       "      <td>0.96074</td>\n",
       "      <td>0.96080</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar100</th>\n",
       "      <td>0.78998</td>\n",
       "      <td>0.75943</td>\n",
       "      <td>0.79154</td>\n",
       "      <td>0.78940</td>\n",
       "      <td>0.78968</td>\n",
       "      <td>0.754185</td>\n",
       "      <td>0.79066</td>\n",
       "      <td>0.78998</td>\n",
       "      <td>0.79134</td>\n",
       "      <td>0.757240</td>\n",
       "      <td>0.79272</td>\n",
       "      <td>0.79234</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          (CrossEntropy, BMA)  (CrossEntropy, Raw)  \\\n",
       "Dataset                                              \n",
       "cifar10               0.96184              0.95460   \n",
       "cifar100              0.78998              0.75943   \n",
       "\n",
       "          (CrossEntropy, central_LogScore)  \\\n",
       "Dataset                                      \n",
       "cifar10                            0.96232   \n",
       "cifar100                           0.79154   \n",
       "\n",
       "          (CrossEntropy, central_SphericalScore)  (BrierScore, BMA)  \\\n",
       "Dataset                                                               \n",
       "cifar10                                  0.96166            0.96090   \n",
       "cifar100                                 0.78940            0.78968   \n",
       "\n",
       "          (BrierScore, Raw)  (BrierScore, central_LogScore)  \\\n",
       "Dataset                                                       \n",
       "cifar10            0.952390                         0.96078   \n",
       "cifar100           0.754185                         0.79066   \n",
       "\n",
       "          (BrierScore, central_SphericalScore)  (SphericalScore, BMA)  \\\n",
       "Dataset                                                                 \n",
       "cifar10                                0.96072                0.96094   \n",
       "cifar100                               0.78998                0.79134   \n",
       "\n",
       "          (SphericalScore, Raw)  (SphericalScore, central_LogScore)  \\\n",
       "Dataset                                                               \n",
       "cifar10                0.951345                             0.96074   \n",
       "cifar100               0.757240                             0.79272   \n",
       "\n",
       "          (SphericalScore, central_SphericalScore)  \n",
       "Dataset                                             \n",
       "cifar10                                    0.96080  \n",
       "cifar100                                   0.79234  "
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_acc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "ec7d1cf6-2766-41c2-8333-77abae18cfd8",
   "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>(CrossEntropy, BMA)</th>\n",
       "      <th>(CrossEntropy, Raw)</th>\n",
       "      <th>(CrossEntropy, central_LogScore)</th>\n",
       "      <th>(CrossEntropy, central_SphericalScore)</th>\n",
       "      <th>(BrierScore, BMA)</th>\n",
       "      <th>(BrierScore, Raw)</th>\n",
       "      <th>(BrierScore, central_LogScore)</th>\n",
       "      <th>(BrierScore, central_SphericalScore)</th>\n",
       "      <th>(SphericalScore, BMA)</th>\n",
       "      <th>(SphericalScore, Raw)</th>\n",
       "      <th>(SphericalScore, central_LogScore)</th>\n",
       "      <th>(SphericalScore, central_SphericalScore)</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dataset</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>cifar10</th>\n",
       "      <td>0.000840</td>\n",
       "      <td>0.000512</td>\n",
       "      <td>0.000605</td>\n",
       "      <td>0.000605</td>\n",
       "      <td>0.000812</td>\n",
       "      <td>0.000473</td>\n",
       "      <td>0.000898</td>\n",
       "      <td>0.000730</td>\n",
       "      <td>0.000476</td>\n",
       "      <td>0.000472</td>\n",
       "      <td>0.000463</td>\n",
       "      <td>0.000610</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar100</th>\n",
       "      <td>0.000806</td>\n",
       "      <td>0.000714</td>\n",
       "      <td>0.000731</td>\n",
       "      <td>0.000932</td>\n",
       "      <td>0.001491</td>\n",
       "      <td>0.001447</td>\n",
       "      <td>0.001003</td>\n",
       "      <td>0.001342</td>\n",
       "      <td>0.000706</td>\n",
       "      <td>0.001630</td>\n",
       "      <td>0.001462</td>\n",
       "      <td>0.001347</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          (CrossEntropy, BMA)  (CrossEntropy, Raw)  \\\n",
       "Dataset                                              \n",
       "cifar10              0.000840             0.000512   \n",
       "cifar100             0.000806             0.000714   \n",
       "\n",
       "          (CrossEntropy, central_LogScore)  \\\n",
       "Dataset                                      \n",
       "cifar10                           0.000605   \n",
       "cifar100                          0.000731   \n",
       "\n",
       "          (CrossEntropy, central_SphericalScore)  (BrierScore, BMA)  \\\n",
       "Dataset                                                               \n",
       "cifar10                                 0.000605           0.000812   \n",
       "cifar100                                0.000932           0.001491   \n",
       "\n",
       "          (BrierScore, Raw)  (BrierScore, central_LogScore)  \\\n",
       "Dataset                                                       \n",
       "cifar10            0.000473                        0.000898   \n",
       "cifar100           0.001447                        0.001003   \n",
       "\n",
       "          (BrierScore, central_SphericalScore)  (SphericalScore, BMA)  \\\n",
       "Dataset                                                                 \n",
       "cifar10                               0.000730               0.000476   \n",
       "cifar100                              0.001342               0.000706   \n",
       "\n",
       "          (SphericalScore, Raw)  (SphericalScore, central_LogScore)  \\\n",
       "Dataset                                                               \n",
       "cifar10                0.000472                            0.000463   \n",
       "cifar100               0.001630                            0.001462   \n",
       "\n",
       "          (SphericalScore, central_SphericalScore)  \n",
       "Dataset                                             \n",
       "cifar10                                   0.000610  \n",
       "cifar100                                  0.001347  "
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_acc_std"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "45086825-ec4a-4f1b-bccd-5afb9619ac1b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "bc4698db-30a7-4fce-b1de-d5750cfda8ea",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_ece, df_ece_std = mean_std_df(ece_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "3bf52301-d975-4435-8a92-dfd54230af9e",
   "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>(CrossEntropy, BMA)</th>\n",
       "      <th>(CrossEntropy, Raw)</th>\n",
       "      <th>(CrossEntropy, central_LogScore)</th>\n",
       "      <th>(CrossEntropy, central_SphericalScore)</th>\n",
       "      <th>(BrierScore, BMA)</th>\n",
       "      <th>(BrierScore, Raw)</th>\n",
       "      <th>(BrierScore, central_LogScore)</th>\n",
       "      <th>(BrierScore, central_SphericalScore)</th>\n",
       "      <th>(SphericalScore, BMA)</th>\n",
       "      <th>(SphericalScore, Raw)</th>\n",
       "      <th>(SphericalScore, central_LogScore)</th>\n",
       "      <th>(SphericalScore, central_SphericalScore)</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dataset</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>cifar10</th>\n",
       "      <td>0.007725</td>\n",
       "      <td>0.024922</td>\n",
       "      <td>0.018472</td>\n",
       "      <td>0.022859</td>\n",
       "      <td>0.015652</td>\n",
       "      <td>0.008664</td>\n",
       "      <td>0.011266</td>\n",
       "      <td>0.034835</td>\n",
       "      <td>0.068188</td>\n",
       "      <td>0.049359</td>\n",
       "      <td>0.060973</td>\n",
       "      <td>0.085518</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar100</th>\n",
       "      <td>0.030184</td>\n",
       "      <td>0.051327</td>\n",
       "      <td>0.037578</td>\n",
       "      <td>0.170132</td>\n",
       "      <td>0.084922</td>\n",
       "      <td>0.040935</td>\n",
       "      <td>0.058025</td>\n",
       "      <td>0.216458</td>\n",
       "      <td>0.301348</td>\n",
       "      <td>0.257491</td>\n",
       "      <td>0.297075</td>\n",
       "      <td>0.374534</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          (CrossEntropy, BMA)  (CrossEntropy, Raw)  \\\n",
       "Dataset                                              \n",
       "cifar10              0.007725             0.024922   \n",
       "cifar100             0.030184             0.051327   \n",
       "\n",
       "          (CrossEntropy, central_LogScore)  \\\n",
       "Dataset                                      \n",
       "cifar10                           0.018472   \n",
       "cifar100                          0.037578   \n",
       "\n",
       "          (CrossEntropy, central_SphericalScore)  (BrierScore, BMA)  \\\n",
       "Dataset                                                               \n",
       "cifar10                                 0.022859           0.015652   \n",
       "cifar100                                0.170132           0.084922   \n",
       "\n",
       "          (BrierScore, Raw)  (BrierScore, central_LogScore)  \\\n",
       "Dataset                                                       \n",
       "cifar10            0.008664                        0.011266   \n",
       "cifar100           0.040935                        0.058025   \n",
       "\n",
       "          (BrierScore, central_SphericalScore)  (SphericalScore, BMA)  \\\n",
       "Dataset                                                                 \n",
       "cifar10                               0.034835               0.068188   \n",
       "cifar100                              0.216458               0.301348   \n",
       "\n",
       "          (SphericalScore, Raw)  (SphericalScore, central_LogScore)  \\\n",
       "Dataset                                                               \n",
       "cifar10                0.049359                            0.060973   \n",
       "cifar100               0.257491                            0.297075   \n",
       "\n",
       "          (SphericalScore, central_SphericalScore)  \n",
       "Dataset                                             \n",
       "cifar10                                   0.085518  \n",
       "cifar100                                  0.374534  "
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_ece"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "2745e98e-2449-44c4-a980-eca91f618d78",
   "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>(CrossEntropy, BMA)</th>\n",
       "      <th>(CrossEntropy, Raw)</th>\n",
       "      <th>(CrossEntropy, central_LogScore)</th>\n",
       "      <th>(CrossEntropy, central_SphericalScore)</th>\n",
       "      <th>(BrierScore, BMA)</th>\n",
       "      <th>(BrierScore, Raw)</th>\n",
       "      <th>(BrierScore, central_LogScore)</th>\n",
       "      <th>(BrierScore, central_SphericalScore)</th>\n",
       "      <th>(SphericalScore, BMA)</th>\n",
       "      <th>(SphericalScore, Raw)</th>\n",
       "      <th>(SphericalScore, central_LogScore)</th>\n",
       "      <th>(SphericalScore, central_SphericalScore)</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dataset</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>cifar10</th>\n",
       "      <td>0.000696</td>\n",
       "      <td>0.000620</td>\n",
       "      <td>0.000857</td>\n",
       "      <td>0.000826</td>\n",
       "      <td>0.001047</td>\n",
       "      <td>0.000484</td>\n",
       "      <td>0.000838</td>\n",
       "      <td>0.001252</td>\n",
       "      <td>0.000977</td>\n",
       "      <td>0.000669</td>\n",
       "      <td>0.000589</td>\n",
       "      <td>0.000997</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>cifar100</th>\n",
       "      <td>0.000852</td>\n",
       "      <td>0.001122</td>\n",
       "      <td>0.001740</td>\n",
       "      <td>0.001466</td>\n",
       "      <td>0.001789</td>\n",
       "      <td>0.001363</td>\n",
       "      <td>0.001939</td>\n",
       "      <td>0.001425</td>\n",
       "      <td>0.001021</td>\n",
       "      <td>0.000924</td>\n",
       "      <td>0.001128</td>\n",
       "      <td>0.001639</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          (CrossEntropy, BMA)  (CrossEntropy, Raw)  \\\n",
       "Dataset                                              \n",
       "cifar10              0.000696             0.000620   \n",
       "cifar100             0.000852             0.001122   \n",
       "\n",
       "          (CrossEntropy, central_LogScore)  \\\n",
       "Dataset                                      \n",
       "cifar10                           0.000857   \n",
       "cifar100                          0.001740   \n",
       "\n",
       "          (CrossEntropy, central_SphericalScore)  (BrierScore, BMA)  \\\n",
       "Dataset                                                               \n",
       "cifar10                                 0.000826           0.001047   \n",
       "cifar100                                0.001466           0.001789   \n",
       "\n",
       "          (BrierScore, Raw)  (BrierScore, central_LogScore)  \\\n",
       "Dataset                                                       \n",
       "cifar10            0.000484                        0.000838   \n",
       "cifar100           0.001363                        0.001939   \n",
       "\n",
       "          (BrierScore, central_SphericalScore)  (SphericalScore, BMA)  \\\n",
       "Dataset                                                                 \n",
       "cifar10                               0.001252               0.000977   \n",
       "cifar100                              0.001425               0.001021   \n",
       "\n",
       "          (SphericalScore, Raw)  (SphericalScore, central_LogScore)  \\\n",
       "Dataset                                                               \n",
       "cifar10                0.000669                            0.000589   \n",
       "cifar100               0.000924                            0.001128   \n",
       "\n",
       "          (SphericalScore, central_SphericalScore)  \n",
       "Dataset                                             \n",
       "cifar10                                   0.000997  \n",
       "cifar100                                  0.001639  "
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_ece_std"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "74979c7b-4ef9-493b-866b-1d3e26d19010",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "8a54c590-3f43-4f89-a252-bd80fae13cb1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(20, 10000, 100)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "logits.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "c8c897a0-cd02-4229-885e-1c06ab74f53a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0, 1, 2, 3)"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ENSEMBLE_COMBINATIONS[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "8573ebad-f596-438a-8483-98beaf45995b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(4, 10000, 100)"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "logits[list(ENSEMBLE_COMBINATIONS[0])].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "efa77920-9f28-4c9f-880a-76223c194e26",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(5, 10000)"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.vstack(uq_results[\"LogScore TotalRisk outer outer\"][\"CrossEntropy\"][\"cifar10\"]).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a9634430-2ee6-4be0-884e-05119d3e0dfb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bbb176d8-c28e-467d-8f65-f79c4385694a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "6efa94a8-5d86-4900-854f-319f53a75e95",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'accuracies': array([0.39141288, 0.6983471 , 0.84641254, 0.92396694, 0.95108694,\n",
       "        0.9713805 , 0.96390975, 0.98763907, 0.9882468 , 0.992416  ],\n",
       "       dtype=float32),\n",
       " 'confidences': array([0.06680089, 0.14222819, 0.24538441, 0.34697264, 0.45137143,\n",
       "        0.54799205, 0.6505524 , 0.7519996 , 0.8516781 , 0.9429651 ],\n",
       "       dtype=float32),\n",
       " 'counts': array([2003, 1936,  892,  605,  552,  594,  665,  809, 1021,  923],\n",
       "       dtype=int32),\n",
       " 'bins': array([0. , 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1. ]),\n",
       " 'avg_accuracy': np.float64(0.7916999912530184),\n",
       " 'avg_confidence': np.float64(0.4193526729285717),\n",
       " 'expected_calibration_error': np.float64(0.37234731965363027),\n",
       " 'max_calibration_error': np.float32(0.60102814)}"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "5a10e1b9-83b7-411f-b8eb-94b511b70f69",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'accuracies': array([0.3119349 , 0.55172414, 0.7120773 , 0.78281623, 0.8736559 ,\n",
       "        0.9353169 , 0.9643678 , 0.97727275, 0.98528206, 0.9920556 ],\n",
       "       dtype=float32),\n",
       " 'confidences': array([0.06590089, 0.146985  , 0.24813367, 0.34859797, 0.4483385 ,\n",
       "        0.5500568 , 0.652477  , 0.7512756 , 0.85148907, 0.9426436 ],\n",
       "       dtype=float32),\n",
       " 'counts': array([1106, 1392, 1035,  838,  744,  773,  870, 1012, 1223, 1007],\n",
       "       dtype=int32),\n",
       " 'bins': array([0. , 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1. ]),\n",
       " 'avg_accuracy': np.float64(0.7910999953269958),\n",
       " 'avg_confidence': np.float64(0.49037498577684163),\n",
       " 'expected_calibration_error': np.float64(0.3007250110924244),\n",
       " 'max_calibration_error': np.float32(0.46394366)}"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e6c08427-8824-4f0c-ba13-af3b205e707f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "532ab8f9-2ab2-46a4-871b-6bfbae80b1b0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "4539f18c-9a1b-4913-8a36-9fb4660df585",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f076f0f4-7d57-48b2-8b03-4dea3a2a69fa",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "84597487-bf66-4d1a-885b-b142438df4c6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1bc35d45-0006-447d-ba44-0ea27c629b2f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "b84c98af-225f-4dba-8577-d9758593d22d",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/nkotelevskii/github/uncertainty_from_proper_scoring_rules/psruq/source/notebook/reliability_diagrams.py:225: UserWarning: set_ticklabels() should only be used with a fixed number of ticks, i.e. after set_ticks() or using a FixedLocator.\n",
      "  ax[1].set_yticklabels(new_ticks)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x604.8 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "reliability_diagram(\n",
    "    true_labels=true_labels,\n",
    "    pred_labels=np.argmax(prob_central, axis=-1),\n",
    "    confidences=np.max(prob_central, axis=-1),\n",
    "    num_bins=10,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "e649f497-9fea-40be-ad86-7f0b628c7017",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/nkotelevskii/github/uncertainty_from_proper_scoring_rules/psruq/source/notebook/reliability_diagrams.py:225: UserWarning: set_ticklabels() should only be used with a fixed number of ticks, i.e. after set_ticks() or using a FixedLocator.\n",
      "  ax[1].set_yticklabels(new_ticks)\n"
     ]
    },
    {
     "data": {
      "image/png": "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cG+mTefOnQV/f3/hvffeEwRBEObMmSNkZGQIgiAIt2/fFuLi4oROnToJERERwvnz56UsV1L1HavBgwcLrVu3FkJCQoSQkBDhySeflLJcydR3nGqy5ZAThPqPlU6nE1599VUhICBA6N69u5CamipluZKq71ip1Wqhb9++QnBwsBASEiL88MMPUpYrmfj4eKFt27aCXC4XFAqF8OWXXwqff/658PnnnwuCcO/v1AsvvCD4+/sL3bt3N+jfH594QkREVstir8kRERHVhyFHRERWiyFHRERWiyFHRERWiyFHRERWiyFHJLIrV64gPj4enTp1QlhYGIYPH46zZ882uJ39+/cjKCgIoaGhKCwsRFxcXJ3bRUdH2+QN6USGYMgRiUgQBIwZMwbR0dE4f/48Dh8+jAULFqCoqKjBba1btw5/+9vfcPToUSgUCmzcuNEIFRNZN4YckYh++uknODg44LnnntO/FxISgsceewxvvvkmunfvjh49eiA9PR0AsHfvXkRHRyMuLg7dunVDQkICBEHAl19+iQ0bNmDOnDlISEhAXl6efo2t27dvIz4+HgEBARgzZgxu376t7+vHH39Enz590KtXL4wfPx4VFRUAgI4dO+Kdd95Br1690KNHD5w+fRoAUFFRgenTp6NHjx4IDg7Gpk2bHtkOkaVhyBGJ6OTJkwgLC3vg/c2bN+Po0aM4duwYdu3ahTfffFO/RMgff/yBxYsXIzs7G3/++ScOHDiAp59+GrGxsfjggw+wbt26Wm19/vnnaN68OU6dOoX58+fj8OHDAICrV6/ivffew65du3DkyBGEh4fj448/1u/XqlUrHDlyBM8//zw+/PBDAMA///lPuLm54cSJEzh+/DgGDRpUbztEloSrEBCZwC+//IJJkybB3t4ebdq0wYABA/D777/D1dUVkZGRUCqVAIDQ0FDk5eXhsccee2hbP//8M2bNmgUACA4ORnBwMADg4MGDyM7ORr9+/QAAVVVV6NOnj36/sWPHAgDCwsKwefNmAPceyp2WlqbfxsPDA999990j2yGyJAw5IhEFBQU1+NpZzRUf7O3todFoGtW3IAiIiYlBamrqI/upr4/62iGyJDxdSSSiQYMG4c6dO0hJSdG/d/z4cbi7uyM9PR1arRbFxcX4+eefERkZ2ag++vfvj/Xr1wO4d3r0+PHjAO6t6H7gwAGcO3cOAHDz5s16Z3XGxMRg+fLl+telpaWNaofIXDHkiEQkk8nwn//8B7t27UKnTp0QFBSEv/3tb5g8eTKCg4MREhKCQYMG4V//+hfatm3bqD6ef/55VFRUICAgAHPnztVfA/T29saqVaswadIkBAcHo0+fPvoJJg/z9ttvo7S0FN27d0dISAh++umnRrVDZK64CgEREVktjuSIiMhqMeSIiMhqMeSIiMhqMeSIiMhqMeSIiMhqMeSIiMhqMeSIiMhqMeSIiMhq/X/ZQs4g1+dl7AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 432x604.8 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "reliability_diagram(\n",
    "    true_labels=true_labels,\n",
    "    pred_labels=np.argmax(prob_bma, axis=-1),\n",
    "    confidences=np.max(prob_bma, axis=-1),\n",
    "    num_bins=10,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed5dfc18-55cf-4f8f-81bd-8837bbed62ff",
   "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.10.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
