{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# SCOD multiarmed"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### 1. Load packages and set global parameters\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import eval\n",
    "import json\n",
    "import torch\n",
    "import random\n",
    "import numpy as np\n",
    "import pandas as pn\n",
    "import blahut_arimoto as ba\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.metrics import auc\n",
    "\n",
    "random.seed(0)\n",
    "np.random.seed(0)\n",
    "torch.manual_seed(0)\n",
    "torch.cuda.manual_seed(0)\n",
    "torch.backends.cudnn.benchmark = False\n",
    "torch.backends.cudnn.deterministic = True"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Load the results for the various methods as given by a third party"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "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>model</th>\n",
       "      <th>in_dataset_name</th>\n",
       "      <th>method</th>\n",
       "      <th>method_kwargs</th>\n",
       "      <th>scores</th>\n",
       "      <th>labels</th>\n",
       "      <th>idx</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>resnet18_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>dice</td>\n",
       "      <td>{}</td>\n",
       "      <td>[9.59467601776123, 7.032630443572998, 8.800002...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>resnet18_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>doctor</td>\n",
       "      <td>{}</td>\n",
       "      <td>[-0.0009341239929199219, -0.15732842683792114,...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>resnet18_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>energy</td>\n",
       "      <td>{}</td>\n",
       "      <td>[9.047059059143066, 5.1664018630981445, 7.7167...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>resnet18_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>igeood_logits</td>\n",
       "      <td>{}</td>\n",
       "      <td>[2.813105821609497, 2.739166259765625, 2.79803...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>resnet18_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>kl_matching</td>\n",
       "      <td>{}</td>\n",
       "      <td>[-0.00017658778233453631, -0.4094327688217163,...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>resnet18_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>knn_euclides</td>\n",
       "      <td>{}</td>\n",
       "      <td>[-0.01784670352935791, -0.15348303318023682, -...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>resnet18_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>mahalanobis</td>\n",
       "      <td>{}</td>\n",
       "      <td>[-1.9123752117156982, -4.366873264312744, -4.0...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>resnet18_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>max_logits</td>\n",
       "      <td>{}</td>\n",
       "      <td>[9.046591758728027, 5.079472064971924, 7.69795...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>resnet18_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>maxcosine</td>\n",
       "      <td>{}</td>\n",
       "      <td>[0.9839869141578674, 0.8364940285682678, 0.911...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>resnet18_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>msp</td>\n",
       "      <td>{}</td>\n",
       "      <td>[0.9995328187942505, 0.916741669178009, 0.9813...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>resnet18_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>odin</td>\n",
       "      <td>{}</td>\n",
       "      <td>[0.1009082943201065, 0.10050899535417557, 0.10...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>resnet18_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>react</td>\n",
       "      <td>{}</td>\n",
       "      <td>[6.877116680145264, 4.597518444061279, 6.29264...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>resnet18_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>relative_mahalanobis</td>\n",
       "      <td>{}</td>\n",
       "      <td>[0.21889114379882812, -2.568216323852539, -0.5...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>resnet18_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>dice</td>\n",
       "      <td>{}</td>\n",
       "      <td>[9.341476440429688, 7.1761322021484375, 7.2912...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>resnet18_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>doctor</td>\n",
       "      <td>{}</td>\n",
       "      <td>[-0.06266170740127563, -0.7946456074714661, -0...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>resnet18_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>energy</td>\n",
       "      <td>{}</td>\n",
       "      <td>[8.471261978149414, 5.640436172485352, 5.65849...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>resnet18_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>igeood_logits</td>\n",
       "      <td>{}</td>\n",
       "      <td>[3.0686821937561035, 2.9591801166534424, 2.955...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>resnet18_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>kl_matching</td>\n",
       "      <td>{}</td>\n",
       "      <td>[-0.06379446387290955, -3.3900809288024902, -4...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>resnet18_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>knn_euclides</td>\n",
       "      <td>{}</td>\n",
       "      <td>[-0.16872668266296387, -0.551692008972168, -0....</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>resnet18_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>mahalanobis</td>\n",
       "      <td>{}</td>\n",
       "      <td>[-7.469979286193848, -12.52617359161377, -14.4...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>resnet18_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>max_logits</td>\n",
       "      <td>{}</td>\n",
       "      <td>[8.438883781433105, 4.80997371673584, 4.254516...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>resnet18_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>maxcosine</td>\n",
       "      <td>{}</td>\n",
       "      <td>[0.9192011952400208, 0.6972461938858032, 0.622...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>resnet18_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>msp</td>\n",
       "      <td>{}</td>\n",
       "      <td>[0.9681407809257507, 0.4358477294445038, 0.245...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>resnet18_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>odin</td>\n",
       "      <td>{}</td>\n",
       "      <td>[0.010084738954901695, 0.010048210620880127, 0...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>resnet18_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>react</td>\n",
       "      <td>{}</td>\n",
       "      <td>[5.089343070983887, 4.946030616760254, 4.97536...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>resnet18_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>relative_mahalanobis</td>\n",
       "      <td>{}</td>\n",
       "      <td>[-4.022113800048828, -11.035402297973633, -12....</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>resnet34_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>dice</td>\n",
       "      <td>{}</td>\n",
       "      <td>[9.492915153503418, 5.8005170822143555, 10.651...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>resnet34_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>doctor</td>\n",
       "      <td>{}</td>\n",
       "      <td>[-0.0012699365615844727, -0.7608972787857056, ...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>resnet34_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>energy</td>\n",
       "      <td>{}</td>\n",
       "      <td>[8.9370698928833, 3.50030779838562, 10.4014081...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>resnet34_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>igeood_logits</td>\n",
       "      <td>{}</td>\n",
       "      <td>[2.8118646144866943, 2.6001789569854736, 2.815...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>resnet34_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>kl_matching</td>\n",
       "      <td>{}</td>\n",
       "      <td>[-9.313311602454633e-05, -4.600719451904297, -...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>resnet34_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>knn_euclides</td>\n",
       "      <td>{}</td>\n",
       "      <td>[-0.010280847549438477, -0.4336869716644287, -...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>resnet34_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>mahalanobis</td>\n",
       "      <td>{}</td>\n",
       "      <td>[-1.5578477382659912, -7.4062910079956055, -3....</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>resnet34_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>max_logits</td>\n",
       "      <td>{}</td>\n",
       "      <td>[8.936434745788574, 2.5555078983306885, 10.401...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>resnet34_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>maxcosine</td>\n",
       "      <td>{}</td>\n",
       "      <td>[0.9889065027236938, 0.6707146763801575, 0.969...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>resnet34_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>msp</td>\n",
       "      <td>{}</td>\n",
       "      <td>[0.9993647933006287, 0.3887573778629303, 0.999...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>resnet34_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>odin</td>\n",
       "      <td>{}</td>\n",
       "      <td>[0.10089718550443649, 0.10025570541620255, 0.1...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>resnet34_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>react</td>\n",
       "      <td>{}</td>\n",
       "      <td>[7.555272102355957, 3.435703754425049, 8.73108...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>resnet34_cifar10</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>relative_mahalanobis</td>\n",
       "      <td>{}</td>\n",
       "      <td>[2.1796340942382812, -11.64874267578125, 1.062...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>resnet34_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>dice</td>\n",
       "      <td>{}</td>\n",
       "      <td>[12.255317687988281, 7.947474002838135, 7.3742...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>resnet34_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>doctor</td>\n",
       "      <td>{}</td>\n",
       "      <td>[-0.001571059226989746, -0.5346238613128662, -...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>resnet34_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>energy</td>\n",
       "      <td>{}</td>\n",
       "      <td>[12.056530952453613, 6.470125675201416, 5.9062...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>resnet34_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>igeood_logits</td>\n",
       "      <td>{}</td>\n",
       "      <td>[3.0970592498779297, 2.998143196105957, 2.9654...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>resnet34_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>kl_matching</td>\n",
       "      <td>{}</td>\n",
       "      <td>[-0.000564894697163254, -1.906099796295166, -4...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>resnet34_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>knn_euclides</td>\n",
       "      <td>{}</td>\n",
       "      <td>[-0.031676411628723145, -0.5685430765151978, -...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>resnet34_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>mahalanobis</td>\n",
       "      <td>{}</td>\n",
       "      <td>[-5.255587100982666, -16.796253204345703, -16....</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>resnet34_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>max_logits</td>\n",
       "      <td>{}</td>\n",
       "      <td>[12.055745124816895, 6.078259468078613, 4.9391...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>resnet34_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>maxcosine</td>\n",
       "      <td>{}</td>\n",
       "      <td>[0.9849520325660706, 0.685513973236084, 0.6696...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>resnet34_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>msp</td>\n",
       "      <td>{}</td>\n",
       "      <td>[0.9992141723632812, 0.6757946014404297, 0.380...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>resnet34_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>odin</td>\n",
       "      <td>{}</td>\n",
       "      <td>[0.010121275670826435, 0.010060961358249187, 0...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>resnet34_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>react</td>\n",
       "      <td>{}</td>\n",
       "      <td>[5.280174732208252, 4.955483436584473, 4.91841...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>resnet34_cifar100</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>relative_mahalanobis</td>\n",
       "      <td>{}</td>\n",
       "      <td>[0.9145755767822266, -17.32282257080078, -18.5...</td>\n",
       "      <td>[0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...</td>\n",
       "      <td>[0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                model in_dataset_name                method method_kwargs  \\\n",
       "6    resnet18_cifar10         cifar10                  dice            {}   \n",
       "14   resnet18_cifar10         cifar10                doctor            {}   \n",
       "1    resnet18_cifar10         cifar10                energy            {}   \n",
       "4    resnet18_cifar10         cifar10         igeood_logits            {}   \n",
       "2    resnet18_cifar10         cifar10           kl_matching            {}   \n",
       "27   resnet18_cifar10         cifar10          knn_euclides            {}   \n",
       "8    resnet18_cifar10         cifar10           mahalanobis            {}   \n",
       "5    resnet18_cifar10         cifar10            max_logits            {}   \n",
       "10   resnet18_cifar10         cifar10             maxcosine            {}   \n",
       "0    resnet18_cifar10         cifar10                   msp            {}   \n",
       "12   resnet18_cifar10         cifar10                  odin            {}   \n",
       "3    resnet18_cifar10         cifar10                 react            {}   \n",
       "9    resnet18_cifar10         cifar10  relative_mahalanobis            {}   \n",
       "2   resnet18_cifar100        cifar100                  dice            {}   \n",
       "13  resnet18_cifar100        cifar100                doctor            {}   \n",
       "1   resnet18_cifar100        cifar100                energy            {}   \n",
       "4   resnet18_cifar100        cifar100         igeood_logits            {}   \n",
       "5   resnet18_cifar100        cifar100           kl_matching            {}   \n",
       "27  resnet18_cifar100        cifar100          knn_euclides            {}   \n",
       "8   resnet18_cifar100        cifar100           mahalanobis            {}   \n",
       "6   resnet18_cifar100        cifar100            max_logits            {}   \n",
       "9   resnet18_cifar100        cifar100             maxcosine            {}   \n",
       "0   resnet18_cifar100        cifar100                   msp            {}   \n",
       "11  resnet18_cifar100        cifar100                  odin            {}   \n",
       "3   resnet18_cifar100        cifar100                 react            {}   \n",
       "10  resnet18_cifar100        cifar100  relative_mahalanobis            {}   \n",
       "17   resnet34_cifar10         cifar10                  dice            {}   \n",
       "25   resnet34_cifar10         cifar10                doctor            {}   \n",
       "15   resnet34_cifar10         cifar10                energy            {}   \n",
       "20   resnet34_cifar10         cifar10         igeood_logits            {}   \n",
       "16   resnet34_cifar10         cifar10           kl_matching            {}   \n",
       "29   resnet34_cifar10         cifar10          knn_euclides            {}   \n",
       "23   resnet34_cifar10         cifar10           mahalanobis            {}   \n",
       "18   resnet34_cifar10         cifar10            max_logits            {}   \n",
       "24   resnet34_cifar10         cifar10             maxcosine            {}   \n",
       "11   resnet34_cifar10         cifar10                   msp            {}   \n",
       "22   resnet34_cifar10         cifar10                  odin            {}   \n",
       "19   resnet34_cifar10         cifar10                 react            {}   \n",
       "26   resnet34_cifar10         cifar10  relative_mahalanobis            {}   \n",
       "16  resnet34_cifar100        cifar100                  dice            {}   \n",
       "23  resnet34_cifar100        cifar100                doctor            {}   \n",
       "15  resnet34_cifar100        cifar100                energy            {}   \n",
       "20  resnet34_cifar100        cifar100         igeood_logits            {}   \n",
       "19  resnet34_cifar100        cifar100           kl_matching            {}   \n",
       "29  resnet34_cifar100        cifar100          knn_euclides            {}   \n",
       "25  resnet34_cifar100        cifar100           mahalanobis            {}   \n",
       "17  resnet34_cifar100        cifar100            max_logits            {}   \n",
       "24  resnet34_cifar100        cifar100             maxcosine            {}   \n",
       "12  resnet34_cifar100        cifar100                   msp            {}   \n",
       "22  resnet34_cifar100        cifar100                  odin            {}   \n",
       "18  resnet34_cifar100        cifar100                 react            {}   \n",
       "26  resnet34_cifar100        cifar100  relative_mahalanobis            {}   \n",
       "\n",
       "                                               scores  \\\n",
       "6   [9.59467601776123, 7.032630443572998, 8.800002...   \n",
       "14  [-0.0009341239929199219, -0.15732842683792114,...   \n",
       "1   [9.047059059143066, 5.1664018630981445, 7.7167...   \n",
       "4   [2.813105821609497, 2.739166259765625, 2.79803...   \n",
       "2   [-0.00017658778233453631, -0.4094327688217163,...   \n",
       "27  [-0.01784670352935791, -0.15348303318023682, -...   \n",
       "8   [-1.9123752117156982, -4.366873264312744, -4.0...   \n",
       "5   [9.046591758728027, 5.079472064971924, 7.69795...   \n",
       "10  [0.9839869141578674, 0.8364940285682678, 0.911...   \n",
       "0   [0.9995328187942505, 0.916741669178009, 0.9813...   \n",
       "12  [0.1009082943201065, 0.10050899535417557, 0.10...   \n",
       "3   [6.877116680145264, 4.597518444061279, 6.29264...   \n",
       "9   [0.21889114379882812, -2.568216323852539, -0.5...   \n",
       "2   [9.341476440429688, 7.1761322021484375, 7.2912...   \n",
       "13  [-0.06266170740127563, -0.7946456074714661, -0...   \n",
       "1   [8.471261978149414, 5.640436172485352, 5.65849...   \n",
       "4   [3.0686821937561035, 2.9591801166534424, 2.955...   \n",
       "5   [-0.06379446387290955, -3.3900809288024902, -4...   \n",
       "27  [-0.16872668266296387, -0.551692008972168, -0....   \n",
       "8   [-7.469979286193848, -12.52617359161377, -14.4...   \n",
       "6   [8.438883781433105, 4.80997371673584, 4.254516...   \n",
       "9   [0.9192011952400208, 0.6972461938858032, 0.622...   \n",
       "0   [0.9681407809257507, 0.4358477294445038, 0.245...   \n",
       "11  [0.010084738954901695, 0.010048210620880127, 0...   \n",
       "3   [5.089343070983887, 4.946030616760254, 4.97536...   \n",
       "10  [-4.022113800048828, -11.035402297973633, -12....   \n",
       "17  [9.492915153503418, 5.8005170822143555, 10.651...   \n",
       "25  [-0.0012699365615844727, -0.7608972787857056, ...   \n",
       "15  [8.9370698928833, 3.50030779838562, 10.4014081...   \n",
       "20  [2.8118646144866943, 2.6001789569854736, 2.815...   \n",
       "16  [-9.313311602454633e-05, -4.600719451904297, -...   \n",
       "29  [-0.010280847549438477, -0.4336869716644287, -...   \n",
       "23  [-1.5578477382659912, -7.4062910079956055, -3....   \n",
       "18  [8.936434745788574, 2.5555078983306885, 10.401...   \n",
       "24  [0.9889065027236938, 0.6707146763801575, 0.969...   \n",
       "11  [0.9993647933006287, 0.3887573778629303, 0.999...   \n",
       "22  [0.10089718550443649, 0.10025570541620255, 0.1...   \n",
       "19  [7.555272102355957, 3.435703754425049, 8.73108...   \n",
       "26  [2.1796340942382812, -11.64874267578125, 1.062...   \n",
       "16  [12.255317687988281, 7.947474002838135, 7.3742...   \n",
       "23  [-0.001571059226989746, -0.5346238613128662, -...   \n",
       "15  [12.056530952453613, 6.470125675201416, 5.9062...   \n",
       "20  [3.0970592498779297, 2.998143196105957, 2.9654...   \n",
       "19  [-0.000564894697163254, -1.906099796295166, -4...   \n",
       "29  [-0.031676411628723145, -0.5685430765151978, -...   \n",
       "25  [-5.255587100982666, -16.796253204345703, -16....   \n",
       "17  [12.055745124816895, 6.078259468078613, 4.9391...   \n",
       "24  [0.9849520325660706, 0.685513973236084, 0.6696...   \n",
       "12  [0.9992141723632812, 0.6757946014404297, 0.380...   \n",
       "22  [0.010121275670826435, 0.010060961358249187, 0...   \n",
       "18  [5.280174732208252, 4.955483436584473, 4.91841...   \n",
       "26  [0.9145755767822266, -17.32282257080078, -18.5...   \n",
       "\n",
       "                                               labels  \\\n",
       "6   [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...   \n",
       "14  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...   \n",
       "1   [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...   \n",
       "4   [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...   \n",
       "2   [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...   \n",
       "27  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...   \n",
       "8   [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...   \n",
       "5   [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...   \n",
       "10  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...   \n",
       "0   [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...   \n",
       "12  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...   \n",
       "3   [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...   \n",
       "9   [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...   \n",
       "2   [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "13  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "1   [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "4   [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "5   [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "27  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "8   [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "6   [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "9   [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "0   [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "11  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "3   [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "10  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "17  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "25  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "15  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "20  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "16  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "29  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "23  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "18  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "24  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "11  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "22  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "19  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "26  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "16  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "23  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "15  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "20  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "19  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "29  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "25  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "17  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "24  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "12  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "22  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "18  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "26  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, ...   \n",
       "\n",
       "                                                  idx  \n",
       "6   [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "14  [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "1   [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "4   [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "2   [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "27  [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "8   [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "5   [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "10  [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "0   [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "12  [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "3   [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "9   [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "2   [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "13  [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "1   [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "4   [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "5   [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "27  [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "8   [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "6   [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "9   [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "0   [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "11  [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "3   [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "10  [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "17  [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "25  [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "15  [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "20  [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "16  [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "29  [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "23  [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "18  [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "24  [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "11  [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "22  [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "19  [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "26  [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "16  [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "23  [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "15  [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "20  [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "19  [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "29  [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "25  [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "17  [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "24  [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "12  [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "22  [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "18  [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n",
       "26  [0, 6, 1, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "scores_path1 = \"results/scod_benchmark_cifar10/scores.csv\"\n",
    "scores_path2 = \"results/scod_benchmark_cifar100/scores.csv\"\n",
    "dataset_list = list(\n",
    "    {\n",
    "        \"cifar100\": \"test\",\n",
    "        \"svhn\": \"test\",\n",
    "        \"isun\": None,\n",
    "        \"lsun_c\": None,\n",
    "        \"lsun_r\": None,\n",
    "        \"tiny_imagenet_c\": None,\n",
    "        \"tiny_imagenet_r\": None,\n",
    "        \"textures\": None,\n",
    "        \"places365\": None,\n",
    "        \"uniform\": None,\n",
    "        \"gaussian\": None,\n",
    "    }.keys()\n",
    ")\n",
    "scores1 = pn.read_csv(scores_path1)\n",
    "scores2 = pn.read_csv(scores_path2)\n",
    "scores = pn.concat([scores1, scores2])\n",
    "# drop duplicates\n",
    "scores = scores.drop_duplicates(subset=[\"model\", \"method\"], keep=\"last\")\n",
    "# drop gradnorm and vim\n",
    "scores = scores[scores.method != \"gradnorm\"]\n",
    "scores = scores[scores.method != \"vim\"]\n",
    "# drop na\n",
    "scores = scores.dropna()\n",
    "# sort by model and method\n",
    "scores = scores.sort_values(by=[\"model\", \"method\"])\n",
    "display(scores)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Check that the results are collected in the correct way"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "scores.shape: (52, 7)\n"
     ]
    }
   ],
   "source": [
    "print(f\"scores.shape: {scores.shape}\")\n",
    "assert scores.shape[0] == len(scores[\"model\"].unique()) * len(scores[\"method\"].unique())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Index(['model', 'in_dataset_name', 'method', 'method_kwargs', 'scores',\n",
      "       'labels', 'idx'],\n",
      "      dtype='object')\n"
     ]
    }
   ],
   "source": [
    "print(scores.columns)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['resnet18_cifar10' 'resnet18_cifar100' 'resnet34_cifar10'\n",
      " 'resnet34_cifar100']\n"
     ]
    }
   ],
   "source": [
    "print(scores[\"model\"].unique())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['dice' 'doctor' 'energy' 'igeood_logits' 'kl_matching' 'knn_euclides'\n",
      " 'mahalanobis' 'max_logits' 'maxcosine' 'msp' 'odin' 'react'\n",
      " 'relative_mahalanobis']\n"
     ]
    }
   ],
   "source": [
    "print(scores[\"method\"].unique())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Select a model of interest"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "model = \"resnet18_cifar10\"\n",
    "device = \"cuda\" if torch.cuda.is_available() else \"cpu\""
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Load the scores, labels and datasets indices for the model of interest"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = scores.query(\"model == @model\")\n",
    "methods = list(df[\"method\"])\n",
    "# this has one row per sample (all in-d and all ood) and one column per method\n",
    "labels_array = np.concatenate(df[\"labels\"].map(lambda x: np.array(json.loads(x)).reshape(-1, 1)).values, 1)\n",
    "# this has one row per sample (all in-d and all ood) and one column per method\n",
    "scores_array = np.concatenate(df[\"scores\"].map(lambda x: np.array(json.loads(x)).reshape(-1, 1)).values, 1)\n",
    "# this has one row per sample (all in-d and all ood) and one column per method\n",
    "datasets_idx = np.concatenate(df[\"idx\"].map(lambda x: np.array(json.loads(x)).reshape(-1, 1)).values, 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "method_ood = \"energy\"\n",
    "method_sc = \"msp\""
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Collect results for the selected model, dataset and OOD detector"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "              model in_dataset_name  method method_kwargs  \\\n",
      "1  resnet18_cifar10         cifar10  energy            {}   \n",
      "\n",
      "                                              scores  \\\n",
      "1  [9.047059059143066, 5.1664018630981445, 7.7167...   \n",
      "\n",
      "                                              labels  \\\n",
      "1  [0, 1, 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, ...   \n",
      "\n",
      "                                                 idx  \n",
      "1  [0, 6, 2, 0, 1, 2, 8, 7, 4, 9, 9, 0, 9, 4, 7, ...  \n"
     ]
    }
   ],
   "source": [
    "dfoi_ood = scores[(scores[\"model\"] == model) & (scores[\"method\"] == method_ood)]\n",
    "print(dfoi_ood)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "labels_array_ood = (\n",
    "    dfoi_ood[\"labels\"]\n",
    "    .map(lambda x: np.array(json.loads(x)).reshape(-1, 1))\n",
    "    .values[0]\n",
    "    .reshape(\n",
    "        -1,\n",
    "    )\n",
    ")\n",
    "scores_array_ood = (\n",
    "    dfoi_ood[\"scores\"]\n",
    "    .map(lambda x: np.array(json.loads(x)).reshape(-1, 1))\n",
    "    .values[0]\n",
    "    .reshape(\n",
    "        -1,\n",
    "    )\n",
    ")\n",
    "datasets_idx_ood = (\n",
    "    dfoi_ood[\"idx\"]\n",
    "    .map(lambda x: np.array(json.loads(x)).reshape(-1, 1))\n",
    "    .values[0]\n",
    "    .reshape(\n",
    "        -1,\n",
    "    )\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0 1 1 ... 1 1 1]\n"
     ]
    }
   ],
   "source": [
    "print(labels_array_ood)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[9.04705906 5.16640186 7.71678829 ... 3.73009968 4.20695305 6.30173492]\n"
     ]
    }
   ],
   "source": [
    "print(scores_array_ood)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0 6 2 ... 4 5 6]\n"
     ]
    }
   ],
   "source": [
    "print(datasets_idx_ood)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Collect results for the selected model, dataset and selective classification method"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "dfoi_sc = scores[(scores[\"model\"] == model) & (scores[\"method\"] == method_sc)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "labels_array_sc = (\n",
    "    dfoi_sc[\"labels\"]\n",
    "    .map(lambda x: np.array(json.loads(x)).reshape(-1, 1))\n",
    "    .values[0]\n",
    "    .reshape(\n",
    "        -1,\n",
    "    )\n",
    ")\n",
    "scores_array_sc = (\n",
    "    dfoi_sc[\"scores\"]\n",
    "    .map(lambda x: np.array(json.loads(x)).reshape(-1, 1))\n",
    "    .values[0]\n",
    "    .reshape(\n",
    "        -1,\n",
    "    )\n",
    ")\n",
    "datasets_idx_sc = (\n",
    "    dfoi_sc[\"idx\"]\n",
    "    .map(lambda x: np.array(json.loads(x)).reshape(-1, 1))\n",
    "    .values[0]\n",
    "    .reshape(\n",
    "        -1,\n",
    "    )\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Produce the Blahut-Arimoto based score aggregating the results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "# compute blahut arimoto weights with p_value after getting the probs from the scores\n",
    "X = scores_array[datasets_idx[:, 0] == 0][:1000]\n",
    "probs_array = ba.p_value_fn(scores_array, X=X)\n",
    "# compute optimal weights for all the samples in the dataset (zero-shot)\n",
    "w = ba.blahut_arimoto(torch.from_numpy(probs_array).float(), device=device, threshold=1e-3, verbose=False).numpy()\n",
    "ba_scores = np.sum(w * probs_array, 1)\n",
    "# append the blahut arimoto scores to the scores array\n",
    "scores_array = np.concatenate([scores_array, ba_scores.reshape(-1, 1)], 1)\n",
    "labels_array = np.concatenate([labels_array, labels_array[:, 1].reshape(-1, 1)], 1)\n",
    "datasets_idx = np.concatenate([datasets_idx, datasets_idx[:, 1].reshape(-1, 1)], 1)\n",
    "methods.append(\"blahut_arimoto\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "labels_array_ba = labels_array[:, -1]\n",
    "scores_array_ba = scores_array[:, -1]\n",
    "datasets_idx_ba = datasets_idx[:, -1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "assert labels_array_ba.shape == labels_array_ood.shape == labels_array_sc.shape\n",
    "assert scores_array_ba.shape == scores_array_ood.shape == scores_array_sc.shape\n",
    "assert datasets_idx_ba.shape == datasets_idx_ood.shape == datasets_idx_sc.shape"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Check the following: the scores (for acceptance and rejection) are different for different methods, but the labels (accept and reject) and the dataset (in and out of distribution) are the same."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "# assert that labels_array_ood and labels_array_sc are the elementwise equal\n",
    "assert np.array_equal(labels_array_ood, labels_array_sc)\n",
    "\n",
    "# assert that datasets_idx_ood and datasets_idx_sc are the elementwise equal\n",
    "assert np.array_equal(datasets_idx_ood, datasets_idx_sc)\n",
    "\n",
    "# assert that scores_array_ood and scores_array_sc are not the elementwise equal\n",
    "if method_ood != method_sc:\n",
    "    assert not np.array_equal(scores_array_ood, scores_array_sc)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### In general, 0 indicates a correct classification (accept) and 1 indicates an incorrect classification or OOD (reject). For the dataset, 0 indicates in distribution and a value larger than 0 indicates out of distribution for the given model and related training dataset."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "in_id = 0\n",
    "out_id = 1\n",
    "\n",
    "assert in_id == 0\n",
    "assert out_id != 0\n",
    "assert out_id < len(dataset_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "idx_in_d = np.where(datasets_idx_ood == in_id)[0]\n",
    "idx_out_d = np.where(datasets_idx_ood == out_id)[0]\n",
    "\n",
    "# control over pi (pi=0.5)\n",
    "# take the minimum between the number of in-d and ood samples\n",
    "min_size = min(idx_in_d.shape[0], idx_out_d.shape[0])\n",
    "# pick the same amount of scores for in-d and ood\n",
    "idx_in_d = idx_in_d[:min_size]\n",
    "idx_out_d = idx_out_d[:min_size]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Among the in-distribution samples, we need to consider that some are misclassified"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "idx_in_d_correct = np.where(labels_array_ood[idx_in_d] == 0)[0]\n",
    "idx_in_d_incorrect = np.where(labels_array_ood[idx_in_d] == 1)[0]\n",
    "\n",
    "# check that all in-d correct are labeled as 0, and all in-d incorrect are labeled as 1, and all ood are labeled as 1\n",
    "assert np.all(labels_array_ood[idx_in_d[idx_in_d_correct]] == 0)\n",
    "assert np.all(labels_array_ood[idx_in_d[idx_in_d_incorrect]] == 1)\n",
    "assert np.all(labels_array_ood[idx_out_d] == 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy in_d: 0.9498\n"
     ]
    }
   ],
   "source": [
    "print(f\"Accuracy in_d: {len(idx_in_d_correct) / (len(idx_in_d_correct) + len(idx_in_d_incorrect))}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "# s_ood, s_sc\n",
    "s_ood = np.concatenate((scores_array_ood[idx_in_d], scores_array_ood[idx_out_d]))\n",
    "s_sc = np.concatenate((scores_array_sc[idx_in_d], scores_array_sc[idx_out_d]))\n",
    "y_scod = np.concatenate((labels_array_ood[idx_in_d], labels_array_ood[idx_out_d]))\n",
    "\n",
    "assert s_ood.shape == s_sc.shape == y_scod.shape == (2 * min_size,)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Evaluate the performance of the selective classification method as a standalone method"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "min risk: 0.0\n",
      "max risk: 0.04982491210103035\n",
      "min coverage: 0.0006000000284984708\n",
      "max coverage: 0.9994999766349792\n"
     ]
    },
    {
     "data": {
      "image/png": "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ZM2aNTz55JNcc801gUnnANdeey2XXHIJY8aM4fbbb+f111/HYrHUuT4ioUA9QyJh4P333+eUU05h//79WCwWBg4cyKxZs4iLi2Pv3r2Bcr/88gs///xz4PecnBw2btzI0KFD6/xaZrOZSZMm8cknn/DRRx/VePzLL79kzZo1nH322dhsNtLT09mzZw8bN26sVu6dd94hIiKCfv36Ba6df/75fPbZZ6xYsYJBgwbRoUOHwGMZGRn89NNP9OzZM9AT0qdPH5YsWcIHH3xwxPrm5+ezc+dO/vznP9O3b99AcPJvSOgf7ktPT+ezzz7D6XQGnrt161Z2795drQ5lZWUYhhGoQ9++ffnhhx94/PHHqw2dHa5r16707t2bFStWsGbNmmpBr67tV1cTJ06kW7duLF68mF9++aXWMuPHjw+sZGvdujXjxo3j4osvpqioqNqmmUlJSTgcDmbOnMmWLVt47rnn6l0fkWBTz5BIGBg0aBBer5err76aK664gujoaFatWkVxcTFnnnlmoJxhGPz9739n2rRpWCwWFixYQKtWrfjb3/4WKLNp0yYSExN/d3O+SZMmsX79eq655hr+3//7f4wYMQKz2cz69et58cUX6dmzJzfccAMA48aN45VXXuHqq68mMzOT9u3b89FHH/HGG2/wj3/8o9rGjOeccw4PPvggK1eu5M4776z2mlOnTmX8+PFceeWVXHjhhdjtdl577TU+/PBD5s+ff8S6tm7dmrS0NF5++WVSU1OJi4vjs88+C/TulJeXA/D3v/+dlStXMnnyZC677DKKiop49NFHMZvNgRVgI0aMID09nalTpzJ16lS6du3KN998w/z58xk2bNjvrsIDX9ibPXs2Vqu12gTvurZfXVmtVm699VYmTZrE/fffz9NPP12jTHp6OosXLyYpKYmBAweSk5PDc889R0ZGBomJiZSVlVUrP2LECM4++2wee+wxzjrrrGpBVSTUqWdIJAwkJyfz7LPPEhsby2233caVV17Jli1beOyxxzjllFMC5dq1a8dll13G/fffz6233soJJ5zA0qVLiY+PD5T561//ysKFC3/39SIiIli4cCG33norW7Zs4eabb+baa69lzZo1TJ06lRdeeIHo6GgAIiMjefHFFxk1ahSPPvooV111FRs2bOC+++7jmmuuqXbfxMRETj/9dCwWS7WwANCjRw9e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VtLT02uUT09PJzs7m6ysrMC1devWATB48GAsFgt33HEHr776arXnbd68mRNPPLGR3oWIiIjU194DpQBEOazYI4I7xyqoPUM2m40JEyYwd+5cEhMTSUtLY86cOaSmpnLmmWfi8XjIy8sjNjYWh8NB//79GTRoENOmTWPWrFmUlZUxc+ZMLrjgAlJSUgC47LLLWLBgAd26daNv376sXr2a9957j8ceeyyYb1VEREQO8dNu39zgTimxBOtMMr+ghiHwbaLodru5/fbbqaioID09nUWLFhEREcHu3bv5wx/+wAMPPMC4ceMwmUwsWLCAu+66i4kTJ2K32zn77LOZMWNG4H6XX345ERERPPbYY+zbt48uXbowf/58/vCHPwTxXYqIiMihftrjC0MdkmOCXBMwGXUdUAtzHo+XvLzSYFcj7FmtZhISosnPL9V4fJCpLUKH2iJ0qC3qxjAMblz4BfnFTi47pwftGykQ9euegt129H4fbYQgIiIiTSqvyEl+sROzCVJbRx39CY1MYUhERESa1I97CgBIaxODNQQ2qAx+DURERCSs/Ly7CICOKXXbB6ixKQyJiIhIk1q/3Xe4evs2oXGyg8KQiIiINJmS8kqKyioBSAuBlWSgMCQiIiJN6Jd9RYGfYyODvsMPoDAkIiIiTSgrx3ce2YATkwiVzX0UhkRERKTJZOWUAJCS2PCn1B8rhSERERFpMr9m+3qGQmF/IT+FIREREWkSZRVucgvKAUhJVBgSERGRMLMr19crlBhrxxFhCXJtfqMwJCIiIk0iq2qIrF1SaOwv5KcwJCIiIk3Cv5IslIbIQGFIREREmsjOff6eIYUhERERCTNlFW6y88oAaKueIREREQk3Wdm+nacTY+1EOkJj52k/hSERERFpdK99/BMA7ZNjQmbnaT+FIREREWl0zkovAK3jHEGuSU0KQyIiItKoPF4vB6o2WxxwUusg16YmhSERERFpVAeLnHi8BlaLidioiGBXpwaFIREREWlUOVWryJJaRQKm4FamFscUhrZv337Ex4qLi7n99tuPuUIiIiLSsmQHwlDozReCYwxDkyZNqjUQ/fvf/+acc85h+fLlx1svERERaSFy83zzhRJDcPI0HGMY6tWrFxMnTmTr1q0A5Obm8o9//INrr72Wdu3asWzZsgatpIiIiDRfu/aXAJAYZw9yTWp3TLsePfnk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ZWUFrq1btw6AwYMHYzKZGDRoUOCa39q1azn55JMb6V2IiIhIcxbUYTKbzcaECROYO3cuiYmJpKWlMWfOHFJTUznzzDPxeDzk5eURGxuLw+Ggf//+DBo0iGnTpjFr1izKysqYOXMmF1xwQaDn59JLL+WKK66gV69eDB8+nDfeeINt27Zx3333BfOtioiISIgyGUGevevxeHjkkUd48803qaioCOxA3b59e3bv3s0f/vAHHnjgAcaNGwfAwYMHueuuu/jss8+w2+2cffbZzJgxIzBfCGD58uUsXLiQ7OxsTjzxRG666aaQ3IFaREREgi/oYUhEREQkmII6Z0hEREQk2BSGREREJKwpDImIiEhYUxgSERGRsKYwJCIiImFNYUhERETCmsKQiIiIhDWFIQkpXq+X+fPnM2zYMAYMGMCUKVPYtWvXEcv/+OOPXHHFFQwZMoShQ4eSmZnJ3r17m7DGLVd92+JQ77zzDt27d2f37t2NXMvwUN+2qKys5OGHHw6UnzBhAtu2bWvCGrdc9W2LgwcPcsMNN3DKKacwZMgQpk2bRk5OThPWWOpCYUhCysKFC3nllVe45557WLp0KV6vl8mTJ+NyuWqUzc/P59JLL8XhcPDiiy/yzDPPkJeXx+TJk3E6nUGofctSn7Y41J49e7j77rubqJbhob5tMWvWLN58803uv/9+3njjDRITE5kyZQrFxcVNXPOWp75tcd1117F3716ee+45nnvuOfbu3cvVV1/dxLWWozJEQoTT6TQGDhxovPzyy4FrhYWFRr9+/Yx33323Rvl//etfxsCBA43y8vLAtb179xrdunUzvvjiiyapc0tV37bw83g8xoUXXmhccsklRrdu3Yxdu3Y1RXVbtPq2xa+//mp0797d+Pjjj6uVHzVqlP69OE71bYvCwkKjW7duxv/93/8Frn344YdGt27djPz8/KaostSReoYkZGzfvp3S0tJq58jFxcXRq1cv1q9fX6P80KFDWbhwIQ6HI3DNbPb9I11UVNT4FW7B6tsWfk8++SSVlZVceeWVTVHNsFDftvj888+JjY1l+PDh1cp/9NFHOqPxONW3LRwOB9HR0SxfvpySkhJKSkp4++236dy5M3FxcU1ZdTmKoJ5aL3Ko7OxsANq2bVvtenJycuCxQ7Vv35727dtXu/b000/jcDhIT09vvIqGgfq2BcA333zD4sWLWbZsmeZENKD6tsXOnTvp0KEDq1ev5umnnyYnJ4devXpxyy230LVr1yapc0tV37aw2Ww8+OCDzJw5k5NPPhmTyURycjIvvfRS4H/cJDSoNSRklJeXA77/gBzKbrfXaQ7Qiy++yEsvvcSNN95IYmJio9QxXNS3LcrKyrjxxhu58cYbOeGEE5qiimGjvm1RUlJCVlYWCxcu5Prrr+eJJ57AarVy0UUXcfDgwSapc0tV37YwDINt27YxcOBAXn75ZZ5//nnatWvH1KlTKSkpaZI6S90oDEnI8A93HT4R0el0EhkZecTnGYbBP//5T+69916uuuoq/va3vzVqPcNBfdvi3nvvpXPnzowfP75J6hdO6tsWVquVkpIS5s2bx+mnn06/fv2YN28eAG+99VbjV7gFq29brFq1ipdeeok5c+YwePBgMjIyePLJJ9mzZw/Lli1rkjpL3SgMScjwdz3n5uZWu56bm0tKSkqtz6msrOSmm27iySefZMaMGVx33XWNXc2wUN+2eOONN/jiiy8YOHAgAwcOZMqUKQCMHTuWJ598svEr3ILVty1SU1OxWq3VhsQcDgcdOnTQVgfHqb5t8dVXX9G5c2diYmIC11q1akXnzp3Jyspq3MpKvSgMScjo0aMHMTExrF27NnCtqKiIrVu3HnEO0PTp03n//fd5+OGHmTRpUhPVtOWrb1usXr2a9957j+XLl7N8+XLuvfdewDeHS71Fx6e+bZGeno7b7ebbb78NXKuoqGDXrl106tSpSercUtW3LVJTU8nKyqo2hFZWVsbu3bs1nBxiNIFaQobNZmPChAnMnTuXxMRE0tLSmDNnDqmpqZx55pl4PB7y8vKIjY3F4XDw5ptvsnLlSqZPn05GRgb79+8P3MtfRo5Nfdvi8D+y/smk7dq1Iz4+PgjvoOWob1ucfPLJnHrqqdx8883cfffdxMfHM3/+fCwWC+eff36w306zVt+2uOCCC1i0aBHXXXcd1157LQD//Oc/sdvtjBs3LsjvRqoJ9tp+kUO53W7joYceMk455RRjwIABxpQpUwJ71ezatcvo1q2b8cYbbxiGYRiXXnqp0a1bt1q//GXk2NWnLQ735Zdfap+hBlTftiguLjbuvPNOY8iQIUb//v2NSy+91Pjxxx+DVf0Wpb5t8dNPPxlXXnmlkZGRYZxyyinGP/7xD/17EYJMhmEYwQ5kIiIiIsGiOUMiIiIS1hSGREREJKwpDImIiEhYUxgSERGRsKYwJCIiImFNYUhERETCmsKQiIiIhDWFIREREQlrCkMiIiIS1hSGREREJKwpDImIiEhYUxgSkaAyDIMlS5bwP//zP/Tr148//vGPLFq0CP+xiZ9//jkXXXQRgwcPZsiQIdxwww3s27cPgOzsbHr27MlLL71U7Z55eXn07t2bJUuWAOD1enn66af54x//SJ8+fTjrrLN48cUXqz3nb3/7GzfeeCOZmZkMGDCASy+9FIDdu3czffp0Tj/9dHr37s3QoUOZPn06+fn5gedWVlYyd+5chg8fTr9+/bj88stZvnw53bt3Z/fu3YFyX331FRMmTKB///5kZGRw8803k5eX1+CfqYjUjzXYFRCR8PbQQw/x/PPPc+mll3Laaafx7bffMnfuXNxuNykpKdx8882MHTuWK6+8kvz8fObPn89f//pX3nrrLVJTU8nIyGDFihVMmDAhcM/3338fwzAYM2YMALNmzeLNN9/kyiuvZODAgaxfv57777+foqIirr766sDzVq1axXnnnccTTzyB1+ulvLycSy65hISEBO68805iY2PZuHEjCxYswOFwcPfddwMwc+ZM3nvvPa655hp69uzJe++9xx133FHtfa5fv55LL72UU045hX/+858UFhby6KOPcskll7Bs2TIcDkcTfNoiUqvjP/heROTYFBYWGr169TLuu+++atfvuece4/LLLzdOO+0047LLLqv2WFZWltG7d29j9uzZhmEYxhtvvGF0797d2LNnT6DMRRddZFx++eWGYRjGjh07jO7duxtPPfVUtfvMmzfP6Nu3r5GXl2cYhmFMmDDB6N+/v+F0OgNltm7dalx44YXGr7/+Wu25V155pXHWWWcF6tO9e3dj8eLF1cpcdtllRrdu3Yxdu3YZhmEYf/3rX42xY8cabrc7UGbHjh1Gz549jZdeeqmOn5iINAYNk4lI0GzatAm3282ZZ55Z7frtt9/OjBkz2L9/P2PHjq32WMeOHRk4cCDr1q0D4Mwzz8Rut7Ny5UoA9u3bx4YNGzj//PMB+PLLLzEMg9GjR+N2uwNfo0ePxul0smHDhsC9u3Tpgs1mC/zes2dPXnnlFdLS0vjll19Ys2YNixYtYseOHbhcLgDWrl2LYRicffbZ1ep5aL3Ly8vZvHkzI0aMwDCMQB06dOhA165d+fzzz4/3oxSR46BhMhEJmoKCAgASExOP+FhSUlKNx5KSkti6dSsAMTExnHHGGaxYsYLJkyezcuVKIiMjOeOMM6rdxz9kdricnJzAz9HR0TUef+6553jyyScpKCggKSmJPn36EBkZSXFxMUBgzk/r1q2rPe/Q34uKivB6vTzzzDM888wzNV7DbrfXWjcRaRoKQyISNHFxcYAvUHTp0iVwfe/evXz//fcAHDhwoMbz9u/fT0JCQuD38847jyuuuIKsrCxWrFjBWWedRWRkZLXXeP7552sNO+3atTti/d59910efPBBbrrpJsaNGxcIbddeey3ffvstACkpKYF6HnqvQydGR0dHYzKZmDRpUq2hzF9XEQkODZOJSND069ePiIgIPv7442rXFy9ezPz582nTpg3vvfdetcd27drFpk2bGDRoUODa6aefTlJSEi+88AJbtmwJDJEBnHzyyQDk5+fTt2/fwFdeXh6PPvpooOeoNhs2bCAuLo7JkycHglBpaSkbNmzA6/UCMHjwYCwWCx988EG1565evTrwc0xMDL169WLHjh3V6nDSSSfx2GOPsXbt2np8aiLS0NQzJCJBk5iYyCWXXMKSJUuw2WxkZGSwefNmXn31VaZPn05sbCwzZszghhtu4LzzziM/P58FCxbQqlWrwNJ3AIvFwpgxY3jppZdISUlhyJAhgce6d+/Oeeedxx133MGePXvo06cPO3fuZN68ebRv354TTjjhiPXr168fr776Kg8++CCjRo0iNzeXRYsWceDAAVq1agVAhw4d+NOf/sQjjzxCZWUlPXr04IMPPggEPLPZ9/+c119/PVdccUXgvXg8HhYvXszmzZuZOnVqI3y6IlJXJsOo2sxDRCQIDMNg8eLFLF26lOzsbNq3b8/EiRMZP348AP/+97956qmn+OGHH4iJiWHYsGFcf/31tG3bttp9tmzZwrhx47j88suZPn16tcfcbjdPPfUUb731FtnZ2bRu3ZpRo0Zx3XXXER8fD/j2GQKq7T9kGAaPPfYYb7zxBvn5+aSkpDBixAi6devGHXfcwcqVK+natSsul4uHH36Yd999l5KSEoYOHUrv3r15/PHHWbt2beA1/vvf/7JgwQK+++47IiIi6N27N9dcc02g90pEgkNhSETkOBQUFPDpp58ybNiwavOYZs+ezZtvvqkhMJFmQMNkIiLHITIykvvuu4+ePXsyceJEoqKi2LRpEy+99BJXXnllsKsnInWgniERkeO0bds2/vnPf7Jp0ybKy8vp2LEj48eP5+KLL8ZkMgW7eiJyFApDIiIiEta0tF5ERETCmsKQiIiIhDWFIREREQlrCkMiIiIS1hSGREREJKwpDImIiEhYUxgSERGRsKYwJCIiImHt/wPhNgf4gwgQpwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The area under the risk and coverate curve is: 0.005322043318301439\n"
     ]
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "\n",
    "risks, coverages, thrs = eval.risks_coverages_selective_net(\n",
    "    scores=torch.Tensor(scores_array_sc[idx_in_d]),\n",
    "    labels=torch.Tensor(labels_array_sc[idx_in_d]),\n",
    "    sort=True,\n",
    "    n=1000,\n",
    ")\n",
    "\n",
    "# plot coverage vs risk using seaborn lineplot\n",
    "sns.set_theme(style=\"darkgrid\")\n",
    "sns.lineplot(x=coverages, y=risks)\n",
    "plt.xlabel(\"coverage\")\n",
    "plt.ylabel(\"risk\")\n",
    "plt.title(f\"{method_sc}: Coverage vs Risk\")\n",
    "# set x and y limits to min and max of coverages and risks\n",
    "plt.xlim(min(coverages), max(coverages))\n",
    "plt.ylim(min(risks), max(risks))\n",
    "# print min risk and max risk\n",
    "print(f\"min risk: {min(risks)}\")\n",
    "print(f\"max risk: {max(risks)}\")\n",
    "# print min coverage and max coverage\n",
    "print(f\"min coverage: {min(coverages)}\")\n",
    "print(f\"max coverage: {max(coverages)}\")\n",
    "\n",
    "plt.fill_between(coverages, risks, alpha=0.2)\n",
    "\n",
    "plt.show()\n",
    "\n",
    "# compute the area under the curve given x and y coordinates\n",
    "print(f\"The area under the risk and coverate curve is: {auc(coverages, risks)}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Get the OOD results when the ood method is used as a standalone method for OOD detection"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'fpr_at_0.95_tpr': 0.5058, 'detection_error': 0.18814999999999998, 'auroc': 0.8787532, 'aupr_in': 0.8677066861376159, 'aupr_out': 0.32315680020258286, 'f1': 0.7736287005741743, 'thr': 6.8105669021606445}\n"
     ]
    }
   ],
   "source": [
    "results = eval.get_ood_results(\n",
    "    in_scores=torch.Tensor(scores_array_ood[idx_in_d]),\n",
    "    ood_scores=torch.Tensor(scores_array_ood[idx_out_d]),\n",
    ")\n",
    "print(results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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ckyZMgUFBQUp1yMiouFZCvSamhoUFRWhvb09Pi0QCODkyZOor69Pal9fXw+/34/PPvssPu3w4cMAgFtuuQVCCMyfPz8+bVB7eztuvfVWSxtCRJTvLP1h43Q60dTUhK1bt6K0tBQzZ85Ea2srKioqsGTJEui6ju7ubhQXF8PtduOmm27C/PnzsWbNGjz11FMIBoPYuHEjli5dGj8CX758OVauXIna2lrceeed+OUvf4lPPvkEzz777JhsMBGRXQnT4rcduq7jhRdewL59+xAOh1FfX4+NGzeisrIS58+fx6JFi7B582YsW7YMAPDll19i06ZN+Oijj+ByufCtb30L69ati58/B4B33nkHbW1t8Pv9uP7669HS0pJ0KSMREY3McqATEdHExAdLERHZBAOdiMgmGOhERDbBQCcisgkGOhGRTTDQiYhsgoFORGQTDPQcunjxIqqrq5N+9u3bl+uu5Y3XX38dDz30UMK0Tz75BE1NTairq8Ndd92Ff/mXf8lR7/LHUPthw4YNSZ+Nu+66K0c9nBw4plkOdXR0wOVy4cMPP0wYG724uDiHvcofv/jFL/Diiy8mjBt06dIlLF++HHfddRc2bdqEjz/+GJs2bUJhYSHuu+++HPbWvobaDwDQ2dmJf/iHf0BTU1N8mqKM/8iPkwkDPYdOnTqF6667DuXl5bnuSl65ePEi/vmf/xnt7e247rrrEub927/9GxwOB55++mmoqoqqqip89tln2LFjBwM9y0baD6Zp4syZM1i5ciXKyspy08FJiKdccqizszPh8Xw0Pv73f/8XDocD7733Hm666aaEeUePHsWCBQugql8f69x+++349NNP8ec//3m8u2prI+2HP/3pTwgGg5g9e3aOejc58Qg9h06dOoWSkhL87d/+Lf7v//4P1157LVatWoU777wz112ztbvuumvYc7F+vx9z5sxJmDb4F9SFCxcwbdq0Me9fvhhpP5w6dQoAsGfPHvznf/4npJS48847sWbNGp6SHAGP0HMkFovhj3/8I3p6evDYY49hx44dqKurw8qVK3Hw4MFcdy9vhcPhIR+JCCCjxyKSNadOnYKUEuXl5Xjttdfw5JNP4ne/+x3+8R//EYaR2SMU7YxH6Dmiqira29uhKEr8cX7z5s3D6dOnsWvXLg4fnCNDPTZxMMgLCgpy0aW8tGrVKjz44IMoKSkBAMyZMwdlZWV44IEHcOLEiaRTNNSPR+g5VFhYmPBsVgC44YYbcPHixRz1iIZ6bOLg//OxiONHShkP80E33HADgP7TYjQ0BnqOnD59GvPnz094nB8A/M///A+uv/76HPWK6uvrcezYMei6Hp926NAhfOMb38DUqVNz2LP8snbtWjzyyCMJ006cOAEA/HyMgIGeI1VVVZg9ezaefvppHD16FGfPnsXmzZvx8ccfY9WqVbnuXt6677770Nvbi/Xr1+PMmTPYt28f3nzzTfz93/99rruWV+6++24cPHgQr7zyCv70pz/hwIED+NGPfoTvfOc7vDJsBDyHniNSSrz22mt4/vnn8YMf/ACBQAC1tbX46U9/mnSVBY2fqVOn4o033sCzzz6Le++9F2VlZVi7di3uvffeXHctryxatAgvvvgiduzYgZ07d6K4uBjf/e538YMf/CDXXZvQ+Ag6IiKb4CkXIiKbYKATEdkEA52IyCYY6ERENsFAJyKyCQY6EZFNMNCJiGyCgU5EZBMMdCIim2CgExHZBAOdiMgmGOhERDbx/wHdY6VeSjSPxQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'fpr_at_0.95_tpr': 0.5058, 'detection_error': 0.18814999999999998, 'auroc': 0.8787532, 'aupr_in': 0.8677066861104555, 'aupr_out': 0.32315680020258286, 'f1': 0.7736287005741743, 'thr': 0.051327865570783615}\n"
     ]
    }
   ],
   "source": [
    "X = scores_array_ood[idx_in_d][:1000].reshape(-1, 1)\n",
    "probs_array = ba.p_value_fn(scores_array_ood.reshape(-1, 1), X=X).reshape(-1)\n",
    "plt.figure(figsize=(4, 3))\n",
    "plt.hist(probs_array[idx_in_d][labels_array_ood[idx_in_d] == 0], bins=10, alpha=0.5, label=\"in-d\", density=True)\n",
    "plt.hist(probs_array[idx_out_d][labels_array_ood[idx_in_d] == 1], bins=10, alpha=0.5, label=\"ood\", density=True)\n",
    "plt.figure(figsize=(4, 3))\n",
    "plt.hist(scores_array_ood[idx_in_d][labels_array_ood[idx_in_d] == 0], bins=10, alpha=0.5, label=\"in-d\", density=True)\n",
    "plt.hist(scores_array_ood[idx_out_d][labels_array_ood[idx_in_d] == 1], bins=10, alpha=0.5, label=\"ood\", density=True)\n",
    "plt.show()\n",
    "results = eval.get_ood_results(\n",
    "    in_scores=torch.Tensor(probs_array[idx_in_d]),\n",
    "    ood_scores=torch.Tensor(probs_array[idx_out_d]),\n",
    ")\n",
    "print(results)\n",
    "# s_ood\n",
    "s_ood = np.concatenate((probs_array[idx_in_d], probs_array[idx_out_d]))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Now we consider all together in the SCOD framework"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "eps = 10e-6\n",
    "c_fn = 0.75\n",
    "\n",
    "pi_in_star = len(idx_in_d) / float((len(idx_in_d) + len(idx_out_d)))\n",
    "\n",
    "\n",
    "def c_in(lbd):\n",
    "    return lbd * pi_in_star\n",
    "\n",
    "\n",
    "def c_out(lbd):\n",
    "    return c_fn - lbd * (1 - pi_in_star)\n",
    "\n",
    "\n",
    "def theta(scores_ood):\n",
    "    # where scores_ood is 0, set it to eps\n",
    "    scores_ood = np.where(scores_ood == 0, eps, scores_ood)\n",
    "    return -1 / scores_ood\n",
    "\n",
    "\n",
    "def t_bb(c_in, c_out):\n",
    "    return 1 - 2 * c_in - c_out\n",
    "\n",
    "\n",
    "def compute_r_bb(scores_sc, scores_ood, lbd):\n",
    "    c_in_fix = c_in(lbd=lbd)\n",
    "    c_out_fix = c_out(lbd=lbd)\n",
    "    return (1 - c_in_fix - c_out_fix) * scores_sc + c_out_fix * theta(scores_ood)\n",
    "\n",
    "\n",
    "def r_bb(scores_sc, scores_ood, lbd):\n",
    "    c_in_fix = c_in(lbd=lbd)\n",
    "    c_out_fix = c_out(lbd=lbd)\n",
    "    return (1 - c_in_fix - c_out_fix) * scores_sc + c_out_fix * theta(scores_ood) < t_bb(c_in_fix, c_out_fix)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkMAAAHJCAYAAACG+j24AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8o6BhiAAAACXBIWXMAAA9hAAAPYQGoP6dpAACn5UlEQVR4nOzdd1gc57X48e9so1eJzqIOokqIogoSIIHcHTuJU2zHcU1ix/nlXsexE18nN4lL4iS+sR3bSa4dJ3FJ4iZXCdSFKkVIgEC9sHQket02vz+QuMaSLCSBdlnO53nyxHqZnT2Hd8th5sw7iqqqKkIIIYQQE5TG0QEIIYQQQjiSFENCCCGEmNCkGBJCCCHEhCbFkBBCCCEmNCmGhBBCCDGhSTEkhBBCiAlNiiEhhBBCTGhSDAkhhBBiQpNiSIgJaryutzpe454oZH7EeCTFkBCnPfLII2RnZzs6jDHX2dnJww8/TElJiaNDGeb5558nJibmC7d5++23+fWvf31R+62trSUmJob33nvvC7fLzs7mkUceuah9O6MDBw5w4403kpCQwNVXX31Fn/vQoUN8/etfHzYWExPD888/f0Xj+CKNjY1885vfJDExkYULF9LX13fWNrfddhu33XbbFYnncp7L2X6345nO0QEI4Sy+973vcfvttzs6jDFXXV3NBx98wM033+zoUC7aSy+9RHp6uqPDcGp//OMfqa+v549//COBgYFX9LnXrFlDWVnZsLF//etfhIaGXtE4vsjf/vY39uzZwzPPPENISAgeHh6ODkk4ASmGhDgtKirK0SEIcdna2tqIjo5m6dKljg4FgLlz5zo6hGHa29sJDg6+4kfNhHOT02TigrKzs3nhhRd48sknmT9/PsnJyfznf/4nPT09/PnPfyYzM5OUlBS+//3v09bWNvS4yspKvvWtb5GSkkJycjJ33HEHe/bsGfr5I488wm233cY777xDVlYWycnJfOtb32L//v3Dnj8mJuaCpy+6u7v55S9/SUZGBnPnzuXmm29m06ZNF5Xn50+TZWdn89xzz/HrX/+aRYsWkZSUxF133cXx48cvar8AR48e5YEHHiA9PZ20tDTuu+8+jhw5clH7sNlsvPHGG1x33XUkJSWxbNkyfvvb3zIwMDC0zbkOue/atYuYmBh27drFrl27ho5+3X777Rd9eH7dunV84xvfIDk5mYSEBFauXMkbb7xx1nPt2LGDO++8kzlz5rB48WKeeeYZbDbb0HYDAwM89dRTLF68mOTkZB599NFheZxLdnY2dXV1vP/++8TExFBbW3tRsTc1NXHfffeRlJTE0qVLee6554bFBGCxWPjVr35FWloaqamp/PjHP6a1tfUL99va2sp///d/k5WVRUJCAunp6dx///3D4qupqeE73/kO8+fPZ86cOdxyyy1s3rz5C/fb39/P7373O3Jzc0lISGDevHl8+9vfprq6+ryPiYmJoaioiOLi4qFTg+c7/fjZUyxnTiWuXr2aBx98kOTkZNLT03nsscfo7e0deoyqqrz22mtcddVVJCUlsWLFCl555RVUVeX555/nhRdeOGvfnz+V09zczKOPPsrSpUtJSkriy1/+MuvXrz8rtjfeeIOf/vSnpKenk5yczA9+8ANOnjz5hb+zrq4unnrqKZYvX05iYiLXXnst77zzztDPs7Ozee+996ivr7+oU0wjmePbbruNxx9/nBdffJGMjAzmzJnDPffcw8mTJ3n33XdZsWLF0OfguV67f/zjH1m0aBHJycl873vfw2QyDft5UVERt9xyC3PmzCEvL4/t27eftY/a2loefvhhlixZQnx8PAsXLuThhx8e9rkszkMV4gKysrLU5ORk9YEHHlC3bdum/ulPf1Kjo6PVvLw89bbbblM3bdqkvv7662psbKz685//XFVVVe3q6lLnz5+v/uAHP1C3bdumbty4Uf3qV7+qzps3T+3s7FRVVVV//OMfqykpKeqiRYvUd955R127dq163XXXqSkpKWpTU9PQ85eVlaknTpw4b3xWq1X9yle+oqalpan/+Mc/1G3btqkPPfSQGhcXpxYXF484zx//+MdqVlbWsLxTUlLUe++9V920aZP6wQcfqOnp6epXv/rVi/r9NTY2qqmpqeo111yjfvLJJ+rGjRvVm266SV28eLHa1tY24v385Cc/UePj49X/+Z//Ubdu3ar++c9/VufMmaPeeeedqt1uV1VVVW+99Vb11ltvHfa4nTt3qtHR0erOnTvVrq4u9fXXX1ejo6PV119/XT106NCIn3/jxo1qdHS0+qtf/Urdvn27umHDBvXuu+9Wo6Oj1T179gx7rkWLFqkvvPCCun37dvXJJ59Uo6Oj1bfeemtoX9///vfVuXPnqn/729/UTZs2qd/97nfV+Ph4NTo6+rzPv2/fPnXx4sXqPffco5aVlakDAwMjittkMqnR0dFqbGys+uijj6pbtmxR//CHP6ixsbHqE088MbRdVlaWGhsbq37ta19T161bp/773/9W09PT1Ztuukm1Wq3n3Lfdble//OUvqytWrFA//vhjdefOnerf/vY3NTk5Wb3zzjtVVVVVm82mrly5Ur399tvVTZs2qVu3blXvvfdeNTY2Vj1+/Ph54/7+97+vLly4UH377bfVXbt2qf/+97/VxYsXq1ddddXQfH9eWVmZeuONN6o33nijWlZWpp46dUp97rnnzvl7jY6OVp977rlhv6O0tDT16aefVrdv366+/PLLakxMjPrb3/526DFPP/20Ghsbq/7mN79Rt23bpr788svq7Nmz1ZdfflltaGhQf/KTn6jR0dFqWVmZ2tDQcNbztLS0qBkZGery5cvV999/X920aZP64IMPqjExMeoHH3wwLLaUlBT1kUceUQsLC9U333xTTUxMVH/4wx+e9/fV19enXnvtterChQvVt956S92yZYv6+OOPq9HR0epLL72kqurga+iee+5RFy9ePCzGz/vs+2gkc3zmMcnJyeqtt96qbt68Wf3Xv/6lxsfHq3l5eer111+vrl27Vv3www/VuXPnqvfcc8+wx8XGxqpXXXWVunr1avXjjz9Ws7Ky1GXLlqldXV2qqqpqZWWlGh8fr951111Dn7fz588f9rvt7e1Vs7Ky1JtuukktKChQd+zYob744otqXFyc+l//9V/n/b2JQVIMiQvKyspSMzIyVIvFMjS2cuVKNTk5eaiwUVVVve+++9Trr79eVdXBD+Xo6Gi1tLR06OcnTpxQf/Ob3wx9AP34xz9Wo6OjhxUsTU1NamJiovrMM8+MOL4NGzao0dHR6tq1a4fGbDabesstt6jPP//8iPdzrmIoKytr2Bfh888/r0ZHR6utra0j3u/TTz+tJiUlqc3NzUNjDQ0N6rJly9RNmzaNaB+HDh1So6Oj1T/96U/DxletWqVGR0cP7edCxdC5/j1Sf/nLX9Qf//jHw8ba2tqGxXVm388+++yw7bKzs9X77rtPVVVVPXjwoBodHa2++eabQz+32Wzq1Vdf/YXFkKoOzsnnY7iQM1/0995777DxJ554Qo2Pjx8qSLOystRFixapPT09Q9usXbtWjY6OVjds2HDOfTc2Nqq3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sBC4uCNDZ45WfPZ18fnXxEgkJSWh1+vPmqdXX32V//iP/0Cr1V5wftLS0igrKxs69XbGhx9+SFBQEFOmTLnouD6777q6urPWOfrwww/R6/UkJSVd0n5HMseXq7S0dNjRm71791JXVzf0Xlm4cCFbtmwZdpqwsLBwWAFaWlqKr68vd99991AR1dPTQ2lp6ajE6OrkNJkYE/PmzcNut3P//fdz77334uXlxerVq+nq6hrWc6CqKt/5znf44Q9/iFar5YUXXsDPz2/YJd979uwhMDDwvOsALVu2jOTkZB555BH+3//7fxiNRj744AOOHDnCL3/5yzHNs7u7m8OHDxMVFXXe0wd33HEHq1at4u677+a+++5Dr9fz0ksvERoaynXXXTei55k5cyZf+tKXeO655+jr6yMtLY3q6mpeeOEF5s+fT0ZGBgBZWVls2LCBp556iuzsbEpKSli1atWwfZ3p89q0aRN+fn7Mnj2b1tZWampqmDlz5jkP9cPgl+FHH31EfHw8oaGh7N69mz//+c8oivKFvRyfN2XKFG655RaeffZZrFYrsbGxfPDBBxw4cOCCj/X19aWqqoqioiKSkpLOearifAoKCggJCWHRokVs3bqVf/3rX/zgBz8Ylm9LSwvf//73ue222zh+/Di///3vWbx48XmL8zNfsL/4xS+4+eab6ejo4I033hhaHqK3t5e4uDjc3d15+OGH+f73v8/kyZPZvn071dXV513kMz4+Hp1OxzPPPMOdd96J2WzmvffeGyroLuZo39KlS3nqqad4/PHHueuuu2hoaOCPf/wjXl5eI94HDJ4eu/3223nttdcwGAykp6ezd+9e3nrrLR5++GE0Gs3Q0aOPP/6YOXPmnHVK7Nvf/jYffvghd9xxBw888AD+/v6sWrWKnTt38uSTT15WsXvTTTfx5ptvcv/99/Pggw8SGRnJhg0bePfdd3nggQeGYrtYI5nj871nRsput3Pvvffyne98h7a2Nn73u98RHR3N9ddfD8D999/PunXruOuuu7j77rtpbW3lf/7nf4b1ECUlJfHWW2/x9NNPk5WVRXNzM6+88gonT54876lY8X/kyJAYE8HBwfzv//4vPj4+/PSnP+W+++5j3759PP/880N/7QCEh4dz55138uSTT/KTn/yEqVOn8s9//hN/f/+hbW655RZefPHF8z6XVqvlL3/5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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "c_ins = []\n",
    "c_outs = []\n",
    "t_bbs = []\n",
    "r_bbs = []\n",
    "\n",
    "# pi=0.5\n",
    "# low = max(min(0, c_fn / (1 - pi), (c_fn - 1) / (1 - pi), 1 / pi),0)\n",
    "# high = max((c_fn - 1) / (1 - pi), 1 / pi, low, c_fn / (1 - pi))\n",
    "# print(low, high)\n",
    "\n",
    "lbd_linspace = np.linspace(0, 1.5, 1000)\n",
    "\n",
    "for lbd in lbd_linspace:\n",
    "    c_ins.append(c_in(lbd=lbd))\n",
    "    c_outs.append(c_out(lbd=lbd))\n",
    "    t_bbs.append(t_bb(c_in(lbd=lbd), c_out(lbd=lbd)))\n",
    "    # r_bbs.append(compute_r_bb(scores_sc=s_sc, scores_ood=s_ood, lbd=lbd))\n",
    "\n",
    "# lineplot of c_in, c_out, and t_bb as a function of lambda\n",
    "sns.set_theme(style=\"darkgrid\")\n",
    "sns.lineplot(x=lbd_linspace, y=c_ins, label=\"c_in\")\n",
    "sns.lineplot(x=lbd_linspace, y=c_outs, label=\"c_out\")\n",
    "sns.lineplot(x=lbd_linspace, y=t_bbs, label=\"t_bb\")\n",
    "# sns.lineplot(x=lbd_linspace, y=r_bbs, label='r_bb')\n",
    "\n",
    "\n",
    "plt.xlabel(\"lambda\")\n",
    "plt.ylabel(\"value\")\n",
    "plt.title(f\"{method_sc}: c_in, c_out, and t_bb as a function of lambda\")\n",
    "# set x and y limits to min and max of coverages and risks\n",
    "# plt.xlim(min(np.linspace(0, 10, 1000)), max(np.linspace(0, 10, 1000)))\n",
    "# plt.ylim(min(c_ins), max(c_outs))\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "min tpr: 0.0\n",
      "max tpr: 1.0\n",
      "min fpr: 0.0\n",
      "max fpr: 1.0\n",
      "The area under the ROC curve is: 0.8966434874541239\n",
      "min risk: 0\n",
      "max risk: 0.5251\n",
      "min coverage: 0\n",
      "max coverage: 1.0\n",
      "The area under the risk and coverate curve is: 0.23937540074919836\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABNsAAAHZCAYAAAC/5T19AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8o6BhiAAAACXBIWXMAAA9hAAAPYQGoP6dpAACac0lEQVR4nOzdd3iV9f3/8efZ5+QkJ5MQSAibIMhUUGSDgqvgl9rWgdW21NbaL98OcfxqKVVrrYCoRRwt2GqLWBUnqLhXFVHZSzYEMggZJ+PknJxz7t8fIUdi2CQ5J8nrcV1cybnHyfucDzm5z+t8hskwDAMRERERERERERE5Y+ZoFyAiIiIiIiIiItJaKGwTERERERERERFpJArbREREREREREREGonCNhERERERERERkUaisE1ERERERERERKSRKGwTERERERERERFpJArbREREREREREREGonCNhERERERERERkUaisE1ERERERERERKSRWKNdgIhE13XXXcfnn39eb5vNZiMtLY2xY8fyq1/9isTERADGjRvH0KFDue+++xq1httvv53PP/+cd999t9Huc+nSpdxxxx0nPG7r1q1HPdZsNhMfH0+/fv24+eabOeeccwBYuXIlP/zhDxvcj81mIyUlhfPPP58ZM2bQrl27xnkgJ+lEj/faa69l5syZreKxioiItGat9drsSH6/n2eeeYZXX32V3bt3Y7FY6NatG1dddRWTJ0/GZDI1yc+VWrm5uYwfP77BdpvNRmJiIoMGDeK3v/0tXbt2Bb65znznnXfIyso64f2f6vEirZHCNhGhT58+/OEPf4jcrqmpYePGjTzwwANs3ryZZ555pkkven7xi18cNdQ5E2PGjOHZZ5+N3H7//fd59NFHmT9//jHDoSP3hcNhioqKeOSRR7j++ut5/vnn6d27d+TYmTNn0rdv38jtyspKvvzyS5544gl27drFc88916iP52Qd6/GlpaUd87iW+lhFRERaq9Z4bVanqKiIadOmkZeXx3XXXUf//v0Jh8O899573H777XzxxRfcfffdCtyawU033cSYMWMit30+Hxs3buSxxx7jxz/+MW+88QYOhyNyXZ2enh69YkVaGIVtIkJ8fDwDBw6st23IkCFUVlby8MMPs3bt2gb7G1N2dnaj32dKSgopKSmR2zt37gTgrLPOOuYnbEfb16dPHy666CIWL17MXXfdFdneo0ePBs/J8OHDCQQC/O1vf2P79u306NGjkR7NyTve4zvRcS3tsYqIiLRWrfHarM5tt91Gfn4+zz77LF26dIlsHzNmDB07duSBBx5g7NixR+15JY0rOzu7wf+jYcOG4Xa7mTVrFp999hmjR49ucF0tIiemOdtE5JjOPvtsAA4cONBg38qVK8nJyWHlypX1tl933XVcd911kds1NTXMmTOHUaNG0b9/f37yk5/w0ksvkZOTQ25uLlA7VGHcuHGRc8aNG8fDDz/MX/7yFy644ILIebt3727w85cuXdqYD7mBrKwskpOTj/ocHI3H4wE45qexv//97xk+fDihUKje9j/96U+cd9551NTUUF1dzaxZsxg1ahRnn302F198MQsXLjyzB3ISGvuxioiISONq6ddmmzdv5uOPP+YnP/lJvaCtzg033MC1115LXFxcZNvu3buZPn06w4cPZ+DAgVx33XV8+eWXkf0TJ05k+vTpDe5r8uTJ3HTTTZHbb7/9NlOmTKFfv34MHz6ce+65h6qqqsj+v/71r1x00UXMnz+foUOHMmLECMrKyqiurmbu3LlMmDCBs88+m8GDB/OjH/2IzZs31/t5L774Ipdeein9+vVj0qRJfPrpp/Tp06fe83HgwAF+85vfMHToUAYMGMD111/Ppk2bjvl8ffXVV+Tk5PDee+81eB5zcnJ46623AHjttdeYNGkS/fv35/zzz+eWW26hoKDgmPd7InXXeHWWLl1a7/9HcXExv/3tbxk+fDj9+vVj8uTJvPTSS8e8P6/Xy+TJkxk3btxJX2eKtHQK20TkmHbt2gVAp06dTvs+Zs6cyT//+U+mTp3KI488QlpaGr///e9PeN5TTz3Fzp07+fOf/8w999zDhg0buO222yL7+/bty7PPPluv63tTKCkpoaSkpMEnvOFwmGAwGPlXWlrKihUrWLhwIf3794/McfFtkydPpqioqN6FcDgc5vXXX+eyyy7DZrNx77338uGHH3LbbbexcOFCxo8fz/33388LL7xwwnq/XVcwGCQcDkflsYqIiEjjaunXZh999BFAvSDvSA6Hg5kzZzJs2DAAtm/fzpQpU8jNzeXOO+9kzpw5mEwmrr/++si8dpMmTeKDDz6goqIicj87duxgy5YtTJ48GYBXX32Vm2++mW7duvHII4/wy1/+kldeeYVf/OIXGIYROe/AgQN88MEHzJs3jzvuuIPExERuvfVWXnjhBW688UYWLVrEHXfcwbZt2/jtb38bOfell17i9ttvZ/DgwSxYsICJEyfyi1/8ot6Hq8XFxVx11VVs3LiR3//+98ydO5dwOMy1117Ljh07jvp8DB48mOzsbJYtW1Zv+2uvvUZSUhKjR4/myy+/5NZbb2XChAn87W9/44477uCzzz7jt7/97THboc63r/EqKir45JNPmDt3LpmZmZx77rlHPW/GjBns2LGDP/7xj/ztb3+jT58+3HbbbXz22WcNjq2srOSnP/0pXq+Xp556io4dO56wLpHWQMNIRQTDMAgGg5HbZWVlfP755zz66KMMGjQo8inqqdq7dy8vvvgit912Gz/60Y8AGDlyJEVFRXz88cfHPdfj8bBgwQIsFkvkvv76179SUlJCcnLyUYdXnKm6Cw6onbh39+7dzJkzB7PZzA9+8IN6x95www0Nzk9MTGT8+PHMmDEDs/non2Wcc845ZGZm8tprr3HBBRcAtZ8EHzx4MHJB+PnnnzN8+HAuu+wyAM477zzi4uJITU094WO46KKLGmwbMWJEg55xzfFYRURE5PS01muzvLw8gJOeNH/+/PnY7Xaeeuop4uPjgdrhppdffjn3338/zz//PJMmTeKvf/0rb7/9NldccQVQG0Z5PB7GjRuHYRjMmTOHkSNHMmfOnMh9d+nShRtuuIEPPvggEhAGg0Fuu+22SMgUCASorKzkzjvv5NJLLwVg6NChVFRUcN9991FUVES7du146KGHGDt2LPfcc0/kObXZbMydOzfy8/75z39SWlrKM888Q2ZmJgCjRo3i0ksv5aGHHuLhhx8+6nMwadIkFi1aRHV1NU6nE8MwWL58ORdffDF2u50vv/wSp9PJjTfeiN1uByApKYn169djGMZxRyD87ne/43e/+129bXFxcQwfPpzbbrsNt9t91PM+//xzbr75Zi688MLIc5KUlBT5+XX8fj833XQTBQUFPP3001osQdoUhW0iwqpVq+pNgA+1K1RecMEF3HXXXac9THDlypUYhsHFF19cb/vll19+wgu6fv36RS7mADIyMoDaiVuTk5NPq54TOVpQlZmZyezZs8nJyam3/Y9//CN9+/YlHA7zzjvv8Pe//53rrruO//3f/z3uzzCZTEyaNInFixcza9Ys7HY7y5Yto0uXLgwYMACoDdeWLFlCfn4+o0ePZvTo0dx8880n9RgeffTRBgskJCQkROWxioiIyOlprddmded/ezqNY/n8888ZO3ZsJGgDsFqtXHbZZTzyyCNUVlbSqVMnBg8ezPLlyyNh27JlyyJh1I4dO8jPz+dnP/tZvQBzyJAhxMfH88knn9TrjXfWWWdFvrfb7ZEPLAsKCti1axe7d++ODOsMBALs2bOHAwcO8H//93/1ar/sssvqhW2ffvopZ511Fu3bt4/UYTabGTVqFK+88soxn4NJkyYxf/583nvvPS655BK++uorDhw4EPmQdsiQIcybN4/LL7+ciRMnMnr0aEaMGMHo0aNP+Pz+8pe/ZMyYMRiGwapVq3jwwQe57LLLmDVrFlbrsaOC8847j7/+9a9s2rSJkSNHMnr06Hq9HOvceuutbNiwgXvvvfeMemOKtEQK20SEvn378sc//hGoDYMcDgcdOnSod2FzOoqLiwEa9Mg6mR5aLper3u263lMnOyTydBwZVNlsNpKTk2nfvv1Rj+3atSv9+vUDYMCAAdhsNubPn4/D4eDGG2887s+ZPHkyjz76KB999BEjR45kxYoVXH/99ZH9v/vd78jIyOCVV17h7rvv5u6772bQoEHMmjWr3iqhR9OrV6+T+tSwuR6riIiInLrWem1W16PrwIEDx1xcqaCggPT0dEwmE2VlZQ1WVIfaVdYNw6CiogK3283kyZO5++67KSkpITc3lz179nDvvfcCUFpaCtR+eFj3nB6psLCw3u1v9+b66KOPuPfee9m5cydut5vevXtH5pQzDOOYz+m36y4tLWXPnj0NQtQ6Pp+vwXMM0LlzZwYNGsSyZcu45JJLWLZsGdnZ2QwePBiAQYMG8cQTT/CPf/yDJ598kieeeIK0tDR+/vOf15ur72gyMzMj13j9+/cnOTmZO+64A4vFctTnqs68efN47LHHeP3113nzzTfrBcF1bQy1bdm3b18eeeQRLr744mP2lBNpjRS2iQhutzvyh/Zk1X2i+u0LrMrKysgf0rrwpqioqN78DHUXJbHmZIOqo7npppt4++23efjhhxkzZgy9evU65rFdu3alf//+vP7665jNZrxeL5MmTYrst9vt3HTTTdx0000cOHCA9957jwULFvDb3/62wZwdp6u5HquIiIicutZ6bTZixAgAPvjgg6OGbcFgkMmTJ0fmPktMTKSoqKjBcQcPHgSI9Ki75JJLuOeee3j77bfZuXMnmZmZnHPOOcA3k/3feuutDB06tMF9JSYmHrPevXv3RoZLPv7443Tq1AmTycS///3vyPxzdT38Dh06VO/cb99OSEhg6NCh3HrrrUf9Wd8egnmkSZMm8ec//5ny8nLeeOMNrr766nr7R44cyciRI/H5fHz22Wc89dRT3HPPPQwYMID+/fsf836/bcqUKbz55pssWbKEiy66KNJe35aQkMCMGTOYMWMGO3fu5J133mHBggX88Y9/5IknnogcN3/+fFwuF1OmTGHevHnceeedJ12LSEuniXZE5LTUfbKan58f2VZWVlZvgtdzzjkHi8USWSmpzooVK5qnyGZktVqZNWsWwWAwMl/H8UyePJmPPvqIZcuWMXjw4EjX+urqaiZOnMiiRYsA6NixI9deey2XXXZZzKzedKqPVURERJpeS7g269mzJ6NGjeJvf/sb+/bta7D/8ccfp6SkJPIh5JAhQ3jvvffqLX4QCoVYtmwZ/fr1iwRUHo+HsWPH8s477/Dmm28yadKkSPjYrVs3UlNTyc3NpV+/fpF/7du3Z+7cucddDXTDhg34/X5uvPFGsrOzI/dZF7QZhkFGRgbZ2dknfE6HDh3Krl27IiMG6v69/PLLPP/88/WG6H7bpZdeimEYPPTQQxw6dKjeh7R/+ctf+O53v4thGLhcLsaOHRsZ0nk6146///3vcTgc3HPPPdTU1DTYv3//fkaPHs0bb7wB1D6/P/3pT7ngggsa/Ly0tDRycnK44YYb+Pe//83atWtPuR6Rlko920TktOTk5NChQwceeeQR4uPjMZlMPP744/W6v3fq1Invfve7PPDAA9TU1NC7d2/eeuutyDwXZzKxfkVFBdu3byc7O5uUlJQzfjyNYdCgQUyaNImXX36Z119/nUsuueSYx1566aXcd999LF++nD/84Q+R7U6nk759+zJ//nxsNhs5OTns2rWLF198kYkTJzbHwzgpp/JYRUREpOm1lGuzP/7xj1x//fV8//vf54c//CEDBgygsrKSN954g2XLlnHVVVdF5pT75S9/yYcffsgPf/hDbrzxRmw2G//617/Yt28ff//73+vd76RJk5g+fTqhUCgynxnUzhP361//mpkzZ2KxWBg7dixer5cFCxZEhjkeS9++fbFarcyePZsf//jHBAIBli5dyvvvvw9AVVUVJpOJ6dOnc8stt/CHP/yBiy66iC1btvDII48A3zynN9xwAy+//DI33HADP/7xj0lOTmb58uX85z//4Y477jjuc1u38ujixYsZNGgQnTt3juw7//zzefLJJ7n99tuZNGkSNTU1/P3vfycpKYnzzz//uPd7NFlZWfzkJz9hwYIF/POf/2TatGn19mdmZpKRkcE999xDRUUF2dnZbNiwgQ8++ICf/exnR73PX/7yl7z++uvceeedLF26FJvNdsp1ibQ06tkmIqfFYrHw8MMPk5aWxm9+8xv+9Kc/cdlllzFhwoR6x/3+97/nqquuYtGiRfziF78gPz+fm266CSAy38Xp2LhxIz/4wQ8iFzux4pZbbsHtdnP//ffj8/mOeVxKSgojRozAYrE0mKT4rrvuYsqUKSxatIgf//jHLFiwgCuvvJJZs2Y1cfWn5mQfq4iIiDS9lnJt1rFjR5599lm+//3v89prr3HzzTdz5513cuDAAebOnVvveqdnz54sXryY1NRU7rjjDmbMmIFhGDz11FORVd3rjB49moSEBPr160fXrl3r7fve977H3Llz+eqrr/j5z3/OrFmzyMrK4umnnz7uxP2dO3dm7ty5FBQUcNNNNzFz5kwAnn76aUwmE1988QUA3/nOd7jrrrv49NNP+fnPf86yZcsiq3zWPaft27dnyZIlZGZmMmvWLH7+85+zbt06/vSnPx115fdvmzx5MqFQiO985zsNHvecOXPYtm0bv/zlL/nNb36Dy+XiqaeeIikp6YT3ezQ33ngjHTt2ZMGCBQ3mtIPa4aEjR47koYce4sc//jHPPPMMv/zlL4+5oJfL5WLmzJl8/fXX9YaZirRmJsMwjGgXISKtU2lpKR9++CEjR46st0rVX/7yF5YuXcrKlSujWJ2IiIhI26Jrs6bx2muv0adPH7p16xbZ9v777/Ozn/2Ml19++YQLXIlI66NhpCLSZFwuF3/6058466yzuP7664mLi2PNmjX861//OmY3cxERERFpGro2axqvvPIK8+bN41e/+hUdOnRgz549PPzwwwwdOlRBm0gbpZ5tItKkNm/ezIMPPsiaNWvw+XxkZ2dz1VVXce2110YmmRURERGR5qFrs8ZXUlLC3Llz+fDDDykuLiYtLY2JEycyffr0yEqwItK2xFTY9vjjj/Pxxx/z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RpGYp7AtRn245gCBmjAd09x0SndHuxwRERERERGRZlVS7mf2M6vJL65ddfSGS8/CE2eLdlkiJ6SwLQYdKqvmtU93AzCsb3vAFNV6RERERERERJpTsbea2c+spqDER3KCgxsuySFBQZu0EArbYtAz72zD5w/RtYOHvl1Sol2OiIiIiIiISLPZne/loefXUVYRINXj4PpLehPvUtAmLYfCthizeXcxX319ELMJLrsgW53aREREREREpM3YvKeEh59fh78mRIfUOK65qCdup4I2aVkUtsWYNz7fB8D5fTNISXBGuRoRERERERGR5rFxVzEPv7COmmCYXp2S+O6Ybtgs5miXJXLKFLbFkLxDlWzeUwzA2d00fFRERERERETahu25Zfx1aW3Q1qdLMv8zqhsWs4Z6ScuksC2G/PP1LQRDBj2yEslIiYt2OSIiIiIiIiJNLrewggefW0ugJkzv7GSmjO6G2aSgTVou9ceMEQUlVXydW4bJBFeM6BLtckRERERERESaXGGpj7n/WUOVP0jXDgl8d0xXBW3S4ilsixGfbsgHIKdTEnGa/FFERERERERaubIKPw8sWUNZRYCOqXH8YFwPLGbFFNLy6X9xDAiGwny8Pg+Aft3TolyNiIiIiIiISNOqqq5h7rNrKSz1kZro5JoJvbDbLNEuS6RRKGyLAV9uPUix109CnI2cTonRLkdERERERESkyfhrQjz4/DpyD1bgibNz3YRexDk0pby0HgrboswwDN78fC8A5/fNwKzVVkRERERERKSVCobCLHhxA9tzy3A5rFw3sRcetz3aZYk0KoVtUbY7v5zd+eVYLSYG99QQUhEREREREWmdwobBomWbWb/zEDarmakTepGa6Ix2WSKNTmFblNUtjNCvWyoOu8ani4iIiIiISOtjGAaL3/qazzYVYDGbuObCnnRIjYt2WSJNQmFbFIUNg1VbCgE4u1tKlKsRERERERERaRovf7yLd7/ajwn4/rgedM5IiHZJIk1GYVsU7T9YSVllALvVrBcaERERERERaZXe+mIfr3yyG4DJI7vSK0sLA0rrprAtijbvKQGgW8dEzCYtjCAiIiIiIiKty2cb83nm7W0AXDSkEwN6pGJEuSaRpqawLYp253sByEp3R7kSERERERERkca1cXcxC5dtBmBE/w4M65uOoaRN2gBrtAtoq7xVAdZuPwSg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9HLefvttPfPMM5o6dapGjBjhCAUffvhh7d+/X9KFD2hPnTrl9FwXX/ggODhYFotF995772VDv7paATQvnEYKAJf44IMPnG6/9957at++vVMABwAAgCuXkJAgf39/bd++3en4ypUrtWTJEkVERGjLli1O92VlZWnv3r3q3bu341j//v3Vpk0bvfzyyzpw4IDjFFLp/B670vkPUnv27On4U1BQoMWLFztWvl1ORkaGwsLCNHbsWEfQVlZWpoyMDNXU1EiS+vTpI19fX73//vtOj922bZvj65CQEHXv3l3fffedUw2//OUv9be//U07d+504V0D0FSwsg0ALrFq1SrZbDYlJiZq27Zt2r59u9PmvAAAALg64eHhGj16tFavXi2r1aqUlBTt27dPr732mqZNm6bQ0FDNmDFDkydP1tChQ1VYWKj09HS1aNHC6SJVvr6+Gjx4sNauXauoqCj17dvXcV98fLyGDh2qmTNn6vjx47r22mt19OhRLVy4UDExMerUqdMP1peQkKDXXntNzzzzjG666Sbl5+drxYoVOnXqlFq0aCFJ6tChg37729/q+eefV2Vlpbp27ar333/fESD6+Jxf21J3gYa611JdXa2VK1dq3759euCBBxrg3QXgaYRtAHCJxx57TJs2bdLy5cvVuXNnLVmyRLfeequnywIAAGhWpk6dqtatW2v9+vX6xz/+oZiYGM2cOVN33XWXpPOnYC5fvlwPPvigQkJCNGDAAD3yyCOKiIhwep5hw4ZpzZo1GjJkiCPgqvP0009r+fLlWr9+vXJzc9W6dWvdcccdmjhxouPKoJdz5513Kjs7Wxs2bNC6desUFRWlG2+8USNHjtTMmTP17bffqkuXLpo5c6aCgoK0cuVKlZaWKjU1Vffff7/+/ve/O/b47d+/v1asWKH09HRNmDBB/v7+6tGjh1atWqXExET3vqkATMFiGIbh6SIAwAx27typ0aNH6+WXX3b6VBQAAAC4VFFRkf79739rwIABTvvIPfvss9q4cSOniAJejJVtAAAAAAC4KDAwUH/961/VrVs3/f73v1dQUJD27t2rtWvXavz48Z4uD4AHEbYBAAAAAOAim82m1atXa9GiRXr00UdVXl6ujh07avr06Ro1apSnywPgQZxGCgAAAAAAALiJz08PAQAAAAAAAPBzELYBAAAAAAAAbkLYBgAAAAAAALgJYRsAAAAAAADgJoRtAAAAAAAAgJsQtgEAAAAAAABuQtgGAAAAAAAAuAlhGwAAAAAAAOAmhG0AAAAAAACAm/x/1VUFNm4ZO4sAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1500x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "tprs = []\n",
    "fprs = []\n",
    "risks = [0]\n",
    "risks_num = [0]\n",
    "risks_den = [0]\n",
    "coverages = [0]\n",
    "lbds = []\n",
    "\n",
    "for lbd in np.linspace(0, 1.5, 1000):\n",
    "    r_bb_res = r_bb(scores_sc=s_sc, scores_ood=s_ood, lbd=lbd)\n",
    "\n",
    "    r_bb_res = r_bb_res.astype(int)\n",
    "    labels_array = y_scod\n",
    "\n",
    "    # compute tpr and fpr given predicted labels and true labels\n",
    "    tpr = (r_bb_res == 1) & (labels_array == 1)\n",
    "    tpr = tpr.astype(int).sum() / float(labels_array.sum())\n",
    "\n",
    "    fpr = (r_bb_res == 1) & (labels_array == 0)\n",
    "    fpr = fpr.astype(int).sum() / float((labels_array == 0).sum())\n",
    "\n",
    "    tprs.append(tpr)\n",
    "    fprs.append(fpr)\n",
    "\n",
    "    if (r_bb_res == 0).sum() > 0:\n",
    "        risk = (r_bb_res == 0) & (labels_array == 1)\n",
    "        risks_num.append(risk.astype(int).sum())\n",
    "        risk = risk.astype(int).sum() / float((r_bb_res == 0).sum())\n",
    "        risks_den.append((r_bb_res == 0).sum())\n",
    "\n",
    "        coverage = (r_bb_res == 0).sum() / float(len(labels_array))\n",
    "        lbds.append(lbd)\n",
    "\n",
    "        risks.append(risk)\n",
    "        coverages.append(coverage)\n",
    "\n",
    "\n",
    "# sort fprs in ascending order and tprs accordingly\n",
    "tprs = [x for _, x in sorted(zip(fprs, tprs))]\n",
    "fprs = sorted(fprs)\n",
    "\n",
    "# figure with two subplots\n",
    "fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(15, 5))\n",
    "\n",
    "# plot tpr vs fpr using seaborn lineplot\n",
    "sns.set_theme(style=\"darkgrid\")\n",
    "sns.lineplot(x=fprs, y=tprs, ax=ax1)\n",
    "ax1.set_xlabel(\"fpr\")\n",
    "ax1.set_ylabel(\"tpr\")\n",
    "ax1.set_title(\"Plugin: TPR vs FPR\")\n",
    "# set x and y limits to min and max of fprs and tprs\n",
    "ax1.set_xlim(min(fprs), max(fprs))\n",
    "ax1.set_ylim(min(tprs), max(tprs))\n",
    "# print min tpr and max tpr\n",
    "print(f\"min tpr: {min(tprs)}\")\n",
    "print(f\"max tpr: {max(tprs)}\")\n",
    "# print min fpr and max fpr\n",
    "print(f\"min fpr: {min(fprs)}\")\n",
    "print(f\"max fpr: {max(fprs)}\")\n",
    "ax1.fill_between(fprs, tprs, alpha=0.2)\n",
    "# area under the curve given x and y coordinates\n",
    "print(f\"The area under the ROC curve is: {auc(fprs, tprs)}\")\n",
    "\n",
    "# plot coverage vs risk using seaborn lineplot\n",
    "sns.set_theme(style=\"darkgrid\")\n",
    "sns.lineplot(x=coverages, y=risks, ax=ax2)\n",
    "ax2.set_xlabel(\"coverage\")\n",
    "ax2.set_ylabel(\"risk\")\n",
    "ax2.set_title(\"Plugin: Coverage vs Risk\")\n",
    "# set x and y limits to min and max of coverages and risks\n",
    "ax2.set_xlim(min(coverages) - 0.01, max(coverages) + 0.01)\n",
    "ax2.set_ylim(min(risks), max(risks))\n",
    "# print min risk and max risk\n",
    "print(f\"min risk: {min(risks)}\")\n",
    "print(f\"max risk: {max(risks)}\")\n",
    "# print min coverage and max coverage\n",
    "print(f\"min coverage: {min(coverages)}\")\n",
    "print(f\"max coverage: {max(coverages)}\")\n",
    "ax2.fill_between(coverages, risks, alpha=0.2)\n",
    "# area under the curve given x and y coordinates\n",
    "print(f\"The area under the risk and coverate curve is: {auc(coverages, risks)}\")\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x2aff9d190>]"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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6VKOiIiIJAwFExEREUkYCiYiIiKSMBRMREREJGEomIiIiEjCUDARERGRhKFgIiIiIglDwUREREQShoKJiIiIJAwFExEREUkYCiYiIiKSMBRMREREJGEomIiIiEjC6DXBxDAMHnzwQU455RQmT57Mddddx759+75w/+bmZn7yk58wY8YMZs6cyX/+53/S2dkZx4qTU3f7XFlZyXe/+11mzZrFnDlzuOmmm6ipqYljxcmpu33+e4sXL2b06NHs378/xlUmv+72ORgMcu+993btf8UVV7B169Y4Vpy8utvrgwcP8pOf/ITZs2cza9YsbrnlFurr6+NYcfJ79NFHufLKK790HyveC3tNMHn44Yd59tln+eUvf8nzzz+PYRhce+21BAKBz93/pptuoqqqiqeeeorf/va3vP/++/z85z+Pb9FJqDt9bm5u5pprrsHj8fD000/zhz/8gaamJq699lr8fr8F1SeP7r6ej6iuruYXv/hFnKpMft3t889//nNefvll/uu//ouXXnqJ/Px8rrvuOlpbW+NcefLpbq9vvvlmampqePLJJ3nyySepqanhhhtuiHPVyWvRokU88MADX7mfJe+FZi/g9/vNKVOmmIsWLera1tLSYk6cONF8/fXXj9l/3bp1Zmlpqbljx46ubR9++KE5evRos66uLi41J6Pu9vnPf/6zOWXKFLOzs7NrW01NjVlaWmp+8skncak5GXW3z0eEw2HzsssuM6+66iqztLTU3LdvXzzKTVrd7fPevXvN0aNHm+++++5R+8+fP1+v56/Q3V63tLSYpaWl5jvvvNO17e233zZLS0vN5ubmeJSctOrq6szrr7/enDx5snn22WebV1xxxRfua9V7Ya84Y7Jt2zba29uZM2dO17acnBzKyspYvXr1MfuvWbOGwsJCRowY0bVt5syZ2Gw21q5dG5eak1F3+zxnzhwefvhhPB5P1za7PfKS9Hq9sS84SXW3z0c88sgjBINBrr/++niUmfS62+ePP/6Y7OxsTj311KP2X758+VHHkGN1t9cej4fMzExeffVV2traaGtr47XXXqOkpIScnJx4lp50ysvLcblcLF68mEmTJn3pvla9FzpjduQEUldXB8DAgQOP2t6vX7+ur/29+vr6Y/Z1u93k5uZSW1sbu0KTXHf7XFRURFFR0VHbHnvsMTweDzNmzIhdoUmuu30G2LhxI0888QQvvviirsMfp+72effu3QwZMoSlS5fy2GOPUV9fT1lZGf/6r/961A92OVZ3e+12u7n77ru54447mD59OjabjX79+vHMM890/XIjn2/BggUsWLDguPa16r2wV/wLHhmo43a7j9qelpb2uWMZOjs7j9n3y/aXiO72+R89/fTTPPPMM9x6663k5+fHpMZU0N0+d3R0cOutt3LrrbdSXFwcjxJTQnf73NbWRlVVFQ8//DA//vGP+f3vf4/T6eTyyy/n4MGDcak5WXW316ZpsnXrVqZMmcKiRYv44x//yKBBg/jBD35AW1tbXGruDax6L+wVweTIpYJ/HETl9/tJT0//3P0/b8CV3+8nIyMjNkWmgO72+QjTNHnggQe46667+P73v/+Vo8R7u+72+a677qKkpIRLL700LvWliu722el00tbWxv3338/cuXOZOHEi999/PwCvvPJK7AtOYt3t9ZtvvskzzzzDPffcw7Rp05g5cyaPPPII1dXVvPjii3GpuTew6r2wVwSTI6eiGhoajtre0NBA//79j9l/wIABx+wbCAQ4dOgQ/fr1i12hSa67fYbI7ZW33XYbjzzyCP/2b//GzTffHOsyk153+/zSSy/xySefMGXKFKZMmcJ1110HwPnnn88jjzwS+4KTVE9+bjidzqMu23g8HoYMGaJbs79Cd3u9Zs0aSkpKyMrK6trWp08fSkpKqKqqim2xvYhV74W9IpiMGTOGrKwsVq5c2bXN6/WyZcuWzx3LMGPGDOrq6o56ga9atQqAadOmxb7gJNXdPgPcfvvt/PWvf+Xee+/l6quvjlOlya27fV66dClvvPEGr776Kq+++ip33XUXEBnPo7MoX6wnPzdCoRCbNm3q2ubz+di3bx/Dhg2LS83Jqru9HjBgAFVVVUddTujo6GD//v26XBlFVr0X9orBr263myuuuILf/OY35OfnM3jwYO655x4GDBjAwoULCYfDNDU1kZ2djcfjYdKkSUydOpVbbrmFn//853R0dHDHHXdw0UUXfeFv/tL9Pr/88sssWbKE22+/nZkzZ9LY2Nh1rCP7yLG62+d/fFM8Mphw0KBB5ObmWvAdJIfu9nn69OmcdNJJ/PSnP+UXv/gFubm5PPjggzgcDi688EKrv52E1t1eX3TRRTz++OPcfPPN/OhHPwLggQceIC0tjYsvvtji7yZ5Jcx7YcxuRE4woVDI/PWvf23Onj3bnDx5snndddd1zeOwb98+s7S01HzppZe69j9w4ID5wx/+0Jw8ebI5a9Ys88477zR9Pp9V5SeN7vT5mmuuMUtLSz/3z9//W8ixuvt6/nsrVqzQPCbHqbt9bm1tNe+8805z1qxZ5qRJk8xrrrnGrKystKr8pNLdXu/YscO8/vrrzZkzZ5qzZ882b7zxRr2mu+mnP/3pUfOYJMp7oc00TTN2sUdERETk+PWKMSYiIiKSHBRMREREJGEomIiIiEjCUDARERGRhKFgIiIiIglDwUREREQShoKJiIiIJAwFExEREUkYCiYiIiKSMBRMREREJGEomIiIiEjC+P8B8U3/f9v/tycAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(coverages[1:], lbds)\n",
    "plt.plot(risks[1:], lbds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'fpr_at_0.95_tpr': 0.5721, 'detection_error': 0.18580000000000002, 'auroc': 0.880179585, 'aupr_in': 0.8817011620047892, 'aupr_out': 0.32328438342110577, 'f1': 0.753291038858049, 'thr': 0.06572161614894867}\n"
     ]
    }
   ],
   "source": [
    "results_ba = eval.get_ood_results(\n",
    "    in_scores=torch.Tensor(scores_array_ba[idx_in_d]),\n",
    "    ood_scores=torch.Tensor(scores_array_ba[idx_out_d]),\n",
    ")\n",
    "print(results_ba)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [],
   "source": [
    "s_ba = np.concatenate((scores_array_ba[idx_in_d], scores_array_ba[idx_out_d]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "min tpr: 0.0\n",
      "max tpr: 1.0\n",
      "min fpr: 0.0\n",
      "max fpr: 1.0\n",
      "The area under the ROC curve is: 0.9017777961173274\n",
      "min risk: 0\n",
      "max risk: 0.5251\n",
      "min coverage: 0\n",
      "max coverage: 1.0\n",
      "The area under the risk and coverate curve is: 0.23061237144444158\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABNsAAAHZCAYAAAC/5T19AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8o6BhiAAAACXBIWXMAAA9hAAAPYQGoP6dpAACaNklEQVR4nOzdd3yV9d3/8fc5J2dlnAwgJCQEwgpDQFBQZIOCq2DVtlqx2hatVm/u2orW300pVbsEpCLiKtiqRawbARVXXVXAhcywR4AsMk7mmdfvj0OOxLBJck6S1/Ohj5xc13VOPud8w8l1vc93mAzDMAQAAAAAAADgjJkjXQAAAAAAAADQWhC2AQAAAAAAAI2EsA0AAAAAAABoJIRtAAAAAAAAQCMhbAMAAAAAAAAaCWEbAAAAAAAA0EgI2wAAAAAAAIBGQtgGAAAAAAAANBLCNgAAAAAAAKCRxES6AACRdf3112vNmjX1tlmtVrVv315jx47Vr371KyUmJkqSxo0bp6FDh+ovf/lLo9bw29/+VmvWrNF7773XaI/58ssv65577jnhcbm5uUc91mw2Kz4+Xv3799dtt92mc845R5K0evVq/eQnP2nwOFarVSkpKTr//PM1ffp0dejQoXGeyEk60fO97rrrNHPmzFbxXAEAaM1a67nZkTwej5577jm9/vrr2r17tywWi7p166ZrrrlGkydPlslkapKfi5C8vDyNHz++wXar1arExEQNGjRIv/nNb5SdnS3p2/PMd999V5mZmSd8/FM9HmiNCNsAqG/fvvr9738f/t7n82njxo168MEHtXnzZj333HNNetLzy1/+8qihzpkYM2aMnn/++fD3//nPf/Too49qwYIFxwyHjtwXDAZVXFysRx55RDfccINefPFF9e7dO3zszJkz1a9fv/D3VVVV+uKLL/TEE09o165deuGFFxr1+ZysYz2/9u3bH/O4lvpcAQBorVrjuVmd4uJiTZ06VQcPHtT111+vAQMGKBgM6v3339dvf/tbff7557rvvvsI3JrBrbfeqjFjxoS/r6mp0caNG/XYY4/pZz/7md58803Z7fbweXVqamrkigVaGMI2AIqPj9fZZ59db9uQIUNUVVWl+fPna926dQ32N6asrKxGf8yUlBSlpKSEv9+5c6ckqU+fPsf8hO1o+/r27auLLrpIS5Ys0b333hve3qNHjwavyfDhw+X1evXkk09q+/bt6tGjRyM9m5N3vOd3ouNa2nMFAKC1ao3nZnXuvvtu5efn6/nnn1fXrl3D28eMGaNOnTrpwQcf1NixY4/a8wqNKysrq8Hv0bBhwxQXF6dZs2bps88+0+jRoxucVwM4MeZsA3BMZ511liTpwIEDDfatXr1aOTk5Wr16db3t119/va6//vrw9z6fT3PmzNGoUaM0YMAA/fznP9err76qnJwc5eXlSQoNVRg3blz4PuPGjdP8+fP117/+VRdccEH4frt3727w819++eXGfMoNZGZmKjk5+aivwdG4XC5JOuansb/73e80fPhwBQKBetv/+Mc/6rzzzpPP51Ntba1mzZqlUaNG6ayzztLFF1+sRYsWndkTOQmN/VwBAEDjaunnZps3b9bHH3+sn//85/WCtjo33nijrrvuOsXGxoa37d69W9OmTdPw4cN19tln6/rrr9cXX3wR3j9x4kRNmzatwWNNnjxZt956a/j7d955R1deeaX69++v4cOH6/7771d1dXV4/8MPP6yLLrpICxYs0NChQzVixAiVl5ertrZWc+fO1YQJE3TWWWdp8ODB+ulPf6rNmzfX+3mvvPKKLr30UvXv31+TJk3Sp59+qr59+9Z7PQ4cOKBf//rXGjp0qAYOHKgbbrhBmzZtOubr9eWXXyonJ0fvv/9+g9cxJydHb7/9tiRp+fLlmjRpkgYMGKDzzz9fd955pwoKCo75uCdSd45X5+WXX673+1FSUqLf/OY3Gj58uPr376/Jkyfr1VdfPebjud1uTZ48WePGjTvp80ygpSNsA3BMu3btkiR17tz5tB9j5syZ+uc//6kpU6bokUceUfv27fW73/3uhPd7+umntXPnTv35z3/W/fffrw0bNujuu+8O7+/Xr5+ef/75el3fm0JpaalKS0sbfMIbDAbl9/vD/5eVlWnVqlVatGiRBgwYEJ7j4rsmT56s4uLieifCwWBQb7zxhi677DJZrVb96U9/0ocffqi7775bixYt0vjx4/XAAw/opZdeOmG9363L7/crGAxG5LkCAIDG1dLPzT766CNJqhfkHclut2vmzJkaNmyYJGn79u268sorlZeXpxkzZmjOnDkymUy64YYbwvPaTZo0SR988IEqKyvDj7Njxw5t2bJFkydPliS9/vrruu2229StWzc98sgjuv3227Vs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Fy7Ub37zmwZzdpyu5nquAADg1LXWc7MRI0ZIkj744IOjhm1+v1+TJ08Oz32WmJio4uLiBscVFRVJUrhH3SWXXKL7779f77zzjnbu3KmMjAydc845kr6d7P+uu+7S0KFDGzxWYmLiMevdu3dveLjk448/rs6dO8tkMulf//pXeP65uh5+hw4dqnff736fkJCgoUOH6q677jrqz/ruEMwjTZo0SX/+859VUVGhN998U9dee229/SNHjtTIkSNVU1Ojzz77TE8//bTuv/9+DRw4UAMGDDjm437XlVdeqbfeektLly7VRRddFG6v70pISND06dM1ffp07dy5U++++64WLlyoP/zhD3riiSfCxy1YsEBOp1NXXnml5s2bpxkzZpx0LUBLx0Q7AE5L3Ser+fn54W3l5eX1Jng955xzZLFYwisl1Vm1alXzFNmMYmJiNGvWLPn9/vB8HcczefJkffTRR1qxYoUGDx4c7lpfW1uriRMnavHixZKkTp066brrrtNll10WNas3nepzBQAATa8lnJv17NlTo0aN0pNPPql9+/Y12P/444+rtLQ0/CHkkCFD9P7779db/CAQCGjFihXq379/OKByuVwaO3as3n33Xb311luaNGlSOHzs1q2b2rVrp7y8PPXv3z/8f8eOHTV37tzjrga6YcMGeTwe3XzzzcrKygo/Zl3QZhiG0tLSlJWVdcLXdOjQodq1a1d4xEDd/6+99ppefPHFekN0v+vSSy+VYRh66KGHdOjQoXof0v71r3/VVVddJcMw5HQ6NXbs2PCQztM5d/zd734nu92u+++/Xz6fr8H+/fv3a/To0XrzzTclhV7fm266SRdccEGDn9e+fXvl5OToxhtv1L/+9S+tW7fulOsBWip6tgE4LTk5OUpPT9cjjzyi+Ph4mUwmPf744/W6v3fu3FlXXXWVHnzwQfl8PvXu3Vtvv/12eJ6LM5lYv7KyUtu3b1dWVpZSUlLO+Pk0hkGDBmnSpEl67bXX9MYbb+iSSy455rGXXnqp/vKXv2jlypX6/e9/H97ucDjUr18/LViwQFarVTk5Odq1a5deeeUVTZw4sTmexkk5lecKAACaXks5N/vDH/6gG264QT/84Q/1k5/8RAMHDlRVVZXefPNNrVixQtdcc014Trnbb79dH374oX7yk5/o5ptvltVq1bPPPqt9+/bp73//e73HnTRpkqZNm6ZAIBCez0wKzRN3xx13aObMmbJYLBo7dqzcbrcWLlwYHuZ4LP369VNMTIxmz56tn/3sZ/J6vXr55Zf1n//8R5JUXV0tk8mkadOm6c4779Tvf/97XXTRRdqyZYseeeQRSd++pjfeeKNee+013XjjjfrZz36m5ORkrVy5Uv/+9791zz33HPe1rVt5dMmSJRo0aJC6dOkS3nf++efrqaee0m9/+1tNmjRJPp9Pf//735WUlKTzzz//uI97NJmZmfr5z3+uhQsX6p///KemTp1ab39GRobS0tJ0//33q7KyUllZWdqwYYM++OAD/eIXvzjqY95+++164403NGPGDL388suyWq2nXBfQ0tCzDcBpsVgsmj9/vtq3b69f//rX+uMf/6jLLrtMEyZMqHfc7373O11zzTVavHixfvnLXyo/P1+33nqrJIXnuzgdGzdu1I9+9KPwyU60uPPOOxUXF6cHHnhANTU1xzwuJSVFI0aMkMViaTBJ8b333qsrr7xSixcv1s9+9jMtXLhQV199tWbNmtXE1Z+ak32uAACg6bWUc7NOnTrp+eef1w9/+EMtX75ct912m2bMmKEDBw5o7ty59c53evbsqSVLlqhdu3a65557NH36dBmGoaeffjq8qnud0aNHKyEhQf3791d2dna9fT/4wQ80d+5cffnll7rllls0a9YsZWZm6plnnjnuxP1dunTR3LlzVVBQoFtvvVUzZ86UJD3zzDMymUz6/PPPJUnf+973dO+99+rTTz/VLbfcohUrVoRX+ax7TTt27KilS5cqIyNDs2bN0i233KJvvvlGf/zjH4+68vt3TZ48WYFAQN/73vcaPO85c+Zo27Ztuv322/XrX/9aTqdTTz/9tJKSkk74uEdz8803q1OnTlq4cGGDOe2k0PDQkSNH6qGHHtLPfvYzPffcc7r99tuPuaCX0+nUzJkztXXr1nrDTIHWzGQYhhHpIgC0TmVlZfrwww81cuTIeqtU/fWvf9XLL7+s1atXR7A6AACAtoVzs6axfPly9e3bV926dQtv+89//qNf/OIXeu211064wBWA1odhpACajNPp1B//+Ef16dNHN9xwg2JjY/X111/r2WefPWY3cwAAADQNzs2axrJlyzRv3jz96le/Unp6uvbs2aP58+dr6NChBG1AG0XPNgBNavPmzfrb3/6mr7/+WjU1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5vNs1HqeixrPs1HbNW0NVhsYzVxVVZXx4osvGn369DESExONcePGGenp6YZhGEZ6eroRFxdnbN682TH/3LlzxqOPPmokJiYavXv3Np566injwoUL7grfaziTpzFjxhhxcXH1/rkyl3A9Z3+ervTFF18YcXFxjvloGM7mqLi42HjqqaeM3r17G926dTPGjBljfPvtt+4K32s4m6fvvvvOGD9+vJGcnGz06dPH+Mtf/sLPUiObPn26kZqa6rhNDeG5qP08GzWfZ6PW81zUeJ6N2q7paKyazmQYhtFwPUIAAAAAAADAezTrM9sAAAAAAACAxkSzDQAAAAAAAHARmm0AAAAAAACAi9BsAwAAAAAAAFyEZhsAAAAAAADgIjTbAAAAAAAAABeh2QYAAAAAAAC4CM02AF4tKytLo0aN0i233KKUlBSVlZW5OyQAAAAAQBPm6+4AAMCd1q5dq4MHD2revHmKioqSv7+/u0MCAAAAADRhNNsAeLWCggJFRkZq8ODB7g4FAAAAANAMsI0UgNfq37+/tmzZoszMTMXHx+v+++9XfHy8PvvsM40aNUoJCQkaMGCANmzYUOtx8fHxWrp0qUaMGKGEhAQtXbrUTe8AAACg6TIMQ2vWrNHvfvc7JSQk6K677tLKlStlGIYkaffu3Ro5cqR69uyp3r17a/LkyTpz5oyki0eBdO7cWevXr6/1nHl5eeratavWrFkjSbLb7XrllVd011136eabb9bAgQP12muv1XrM/fffrylTpmjChAlKTEzUmDFjJEkZGRmaNm2a+vbtq65duyolJUXTpk1Tfn6+47GVlZWaP3++brvtNiUkJOhPf/qTtm3bpvj4eGVkZDjm7d+/X6mpqerWrZuSk5M1ffp05eXlufx7CsAzsLINgNdaunSpFi1apKNHj2rp0qVKS0vT3r17NWnSJA0fPlx//vOf9eGHH2rOnDmSpJEjRzoeu3z5ck2ePFmxsbFq27atu94CAABAk/Xiiy9q7dq1GjNmjH7961/r8OHDmj9/vqqqqhQVFaXp06dryJAhGj9+vPLz87VkyRL94Q9/0NatWxUdHa3k5GTt2LFDqampjufcuXOnDMPQ3XffLUmaPXu2tmzZovHjx6t79+7at2+fnn32WRUVFemRRx5xPO69997T0KFD9fLLL8tut6usrEyjR49WixYt9NRTTyk4OFhf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",
      "text/plain": [
       "<Figure size 1500x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "tprs = []\n",
    "fprs = []\n",
    "risks = [0]\n",
    "risks_num = [0]\n",
    "risks_den = [0]\n",
    "coverages = [0]\n",
    "lbds = []\n",
    "\n",
    "for lbd in np.linspace(0, 1.5, 1000):\n",
    "    r_bb_res = r_bb(scores_sc=s_sc, scores_ood=s_ba, lbd=lbd)\n",
    "\n",
    "    r_bb_res = r_bb_res.astype(int)\n",
    "    labels_array = y_scod\n",
    "\n",
    "    # compute tpr and fpr given predicted labels and true labels\n",
    "    tpr = (r_bb_res == 1) & (labels_array == 1)\n",
    "    tpr = tpr.astype(int).sum() / float(labels_array.sum())\n",
    "\n",
    "    fpr = (r_bb_res == 1) & (labels_array == 0)\n",
    "    fpr = fpr.astype(int).sum() / float((labels_array == 0).sum())\n",
    "\n",
    "    tprs.append(tpr)\n",
    "    fprs.append(fpr)\n",
    "\n",
    "    if (r_bb_res == 0).sum() > 0:\n",
    "        risk = (r_bb_res == 0) & (labels_array == 1)\n",
    "        risks_num.append(risk.astype(int).sum())\n",
    "        risk = risk.astype(int).sum() / float((r_bb_res == 0).sum())\n",
    "        risks_den.append((r_bb_res == 0).sum())\n",
    "\n",
    "        coverage = (r_bb_res == 0).sum() / float(len(labels_array))\n",
    "        lbds.append(lbd)\n",
    "\n",
    "        risks.append(risk)\n",
    "        coverages.append(coverage)\n",
    "\n",
    "\n",
    "# sort fprs in ascending order and tprs accordingly\n",
    "tprs = [x for _, x in sorted(zip(fprs, tprs))]\n",
    "fprs = sorted(fprs)\n",
    "\n",
    "# figure with two subplots\n",
    "fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(15, 5))\n",
    "\n",
    "# plot tpr vs fpr using seaborn lineplot\n",
    "sns.set_theme(style=\"darkgrid\")\n",
    "sns.lineplot(x=fprs, y=tprs, ax=ax1)\n",
    "ax1.set_xlabel(\"fpr\")\n",
    "ax1.set_ylabel(\"tpr\")\n",
    "ax1.set_title(\"Plugin: TPR vs FPR\")\n",
    "# set x and y limits to min and max of fprs and tprs\n",
    "ax1.set_xlim(min(fprs), max(fprs))\n",
    "ax1.set_ylim(min(tprs), max(tprs))\n",
    "# print min tpr and max tpr\n",
    "print(f\"min tpr: {min(tprs)}\")\n",
    "print(f\"max tpr: {max(tprs)}\")\n",
    "# print min fpr and max fpr\n",
    "print(f\"min fpr: {min(fprs)}\")\n",
    "print(f\"max fpr: {max(fprs)}\")\n",
    "ax1.fill_between(fprs, tprs, alpha=0.2)\n",
    "# area under the curve given x and y coordinates\n",
    "print(f\"The area under the ROC curve is: {auc(fprs, tprs)}\")\n",
    "\n",
    "# plot coverage vs risk using seaborn lineplot\n",
    "sns.set_theme(style=\"darkgrid\")\n",
    "sns.lineplot(x=coverages, y=risks, ax=ax2)\n",
    "ax2.set_xlabel(\"coverage\")\n",
    "ax2.set_ylabel(\"risk\")\n",
    "ax2.set_title(\"Plugin: Coverage vs Risk\")\n",
    "# set x and y limits to min and max of coverages and risks\n",
    "ax2.set_xlim(min(coverages) - 0.01, max(coverages) + 0.01)\n",
    "ax2.set_ylim(min(risks), max(risks))\n",
    "# print min risk and max risk\n",
    "print(f\"min risk: {min(risks)}\")\n",
    "print(f\"max risk: {max(risks)}\")\n",
    "# print min coverage and max coverage\n",
    "print(f\"min coverage: {min(coverages)}\")\n",
    "print(f\"max coverage: {max(coverages)}\")\n",
    "ax2.fill_between(coverages, risks, alpha=0.2)\n",
    "# area under the curve given x and y coordinates\n",
    "print(f\"The area under the risk and coverate curve is: {auc(coverages, risks)}\")\n",
    "\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
