{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "b8f8f679-aa49-437a-94d7-2550195777e8",
   "metadata": {},
   "source": [
    "This notebook generates the plots in **Figure 5**,**Figure 7**,**Figure 9**,**Figure 11**, and **Figure 13**, starting from the CSV generated by the RunExperiments notebook."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f4e88a98-8d24-4201-8f2d-f026c6957ed6",
   "metadata": {},
   "source": [
    "## Import Required Libraries\n",
    "Running cell below will import the required libraries being used in the rest of the cells of this notebook"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c737b223-b22f-4c54-9b5a-90a5f2296ed9",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.patches as mpatches\n",
    "import math\n",
    "import os\n",
    "pd.set_option('display.max_columns', None)\n",
    "\n",
    "from matplotlib import rc\n",
    "rc('text',usetex=True)\n",
    "os.environ['KMP_DUPLICATE_LIB_OK'] = 'True'\n",
    "rc('text.latex', preamble='\\\\usepackage{color} \\\\usepackage{amsmath} \\\\usepackage{amssymb}')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "57f4b556-b5db-4764-8dc6-42d1d1615076",
   "metadata": {},
   "source": [
    "# Select and load the CSV (linear model, ResNet50 model)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "07b19132-de2e-4f83-b7d1-15e61570bd8f",
   "metadata": {},
   "source": [
    "## Select model_type"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "6141a3da-ddfe-4b5a-bf57-6d3fdaa48224",
   "metadata": {},
   "outputs": [],
   "source": [
    "model_type       = 'real'    # real, ideal\n",
    "# model_type       = 'ideal'    # real, ideal"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "86642705-4f6e-4c2b-9d33-071134246bb6",
   "metadata": {},
   "source": [
    "## Select model type"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "639294a2-d510-43b8-a194-913a698a7c18",
   "metadata": {},
   "outputs": [],
   "source": [
    "pretrained_model_type           = 'resnet'      # swin_trans_vit    resnet vgg16\n",
    "# pretrained_model_type           = 'vgg16'      # swin_trans_vit    resnet vgg16\n",
    "# pretrained_model_type           = 'swin_trans_vit'      # swin_trans_vit    resnet vgg16"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "588de623-8197-4fb2-b984-877f9ee0143b",
   "metadata": {},
   "source": [
    "## Select background_type"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "756f5df6-25b0-4543-94d3-eb29e8637655",
   "metadata": {},
   "outputs": [],
   "source": [
    "background_type  = 'gray'     # black , white , gray , noise , blurred , full\n",
    "# background_type  = 'black'     # black , white , gray , noise , blurred , full\n",
    "# background_type  = 'white'     # black , white , gray , noise , blurred , full\n",
    "# background_type  = 'noise'     # black , white , gray , noise , blurred , full\n",
    "# background_type  = 'blurred'     # black , white , gray , noise , blurred , full\n",
    "#background_type  = 'full'     # black , white , gray , noise , blurred , full"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "836ec8fd-cb4c-422c-9661-815966918676",
   "metadata": {},
   "source": [
    "# Path Setting\n",
    "**NOTE** Comment uncomment LINE No 4,5 to change dataset path"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "9ae18d5a-91ca-42f8-a57e-f28eb8ab1388",
   "metadata": {},
   "outputs": [],
   "source": [
    "suffix_full      = f'{model_type}_{background_type}'\n",
    "DS_name_annotation    = 'ImageNetS'\n",
    "DS_name_img           = 'ImageNet'\n",
    "path_notebook = os.path.abspath(os.path.join(os.getcwd(), os.pardir))\n",
    "\n",
    "\n",
    "codes_path    = os.getcwd() \n",
    "results_path    = os.path.join(codes_path,'results')\n",
    "\n",
    "if model_type=='real':\n",
    "    results_path    = os.path.join(results_path,pretrained_model_type)\n",
    "    suffix                     = f'{pretrained_model_type}_{model_type}_{background_type}'\n",
    "else:\n",
    "    results_path    = os.path.join(results_path)\n",
    "    suffix                     = f'{model_type}_{background_type}'\n",
    "\n",
    "\n",
    "results_path    = os.path.join(results_path,suffix)\n",
    "\n",
    "path_csv          = os.path.join(codes_path,     'csv')\n",
    "path_boxplot          = os.path.join(codes_path,     'boxplot')\n",
    "os.makedirs(path_boxplot,              exist_ok=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "090bc331-eaf0-44a4-87f0-dd52c89147d6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "('E:\\\\Cloud\\\\Shared\\\\XAI\\\\ICLR_Supplementary\\\\notebooks\\\\E1_to_E5\\\\csv/csv_exp_ImageNet_resnet_real_gray.csv',\n",
       " True)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "csv_filename = f'{path_csv}/csv_exp_{DS_name_img}_{suffix}.csv'\n",
    "csv_filename,os.path.exists(csv_filename)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "0d4f395b-762b-4aa4-b1a0-fac79f91a6c7",
   "metadata": {},
   "outputs": [],
   "source": [
    "df,model,background = pd.read_csv(csv_filename), model_type,background_type"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "9420dae6-27ad-46ac-bc4d-7df86a884ebd",
   "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>Unnamed: 0</th>\n",
       "      <th>image</th>\n",
       "      <th>bg_type</th>\n",
       "      <th>pred_cls</th>\n",
       "      <th>pred_lbl</th>\n",
       "      <th>f_S</th>\n",
       "      <th>f_0</th>\n",
       "      <th>f_T</th>\n",
       "      <th>method</th>\n",
       "      <th>threshold</th>\n",
       "      <th>best_point</th>\n",
       "      <th>max_IoU</th>\n",
       "      <th>au_IoU</th>\n",
       "      <th>aucI_pred</th>\n",
       "      <th>aucD_pred</th>\n",
       "      <th>aucI_mse</th>\n",
       "      <th>aucD_mse</th>\n",
       "      <th>time_load</th>\n",
       "      <th>time_exp</th>\n",
       "      <th>time_aucI</th>\n",
       "      <th>time_aucD</th>\n",
       "      <th>time_auc_IoU</th>\n",
       "      <th>time_total</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>ILSVRC2012_val_00004677</td>\n",
       "      <td>gray</td>\n",
       "      <td>1</td>\n",
       "      <td>goldfish</td>\n",
       "      <td>0.625475</td>\n",
       "      <td>0.00115</td>\n",
       "      <td>0.624325</td>\n",
       "      <td>BPT-100</td>\n",
       "      <td>0.000038</td>\n",
       "      <td>0.045580</td>\n",
       "      <td>0.328418</td>\n",
       "      <td>0.163998</td>\n",
       "      <td>0.409691</td>\n",
       "      <td>0.050025</td>\n",
       "      <td>0.063105</td>\n",
       "      <td>0.019651</td>\n",
       "      <td>0.103051</td>\n",
       "      <td>0.744135</td>\n",
       "      <td>0.090060</td>\n",
       "      <td>0.114084</td>\n",
       "      <td>0.100765</td>\n",
       "      <td>1.152096</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>ILSVRC2012_val_00004677</td>\n",
       "      <td>gray</td>\n",
       "      <td>1</td>\n",
       "      <td>goldfish</td>\n",
       "      <td>0.625475</td>\n",
       "      <td>0.00115</td>\n",
       "      <td>0.624325</td>\n",
       "      <td>BPT-500</td>\n",
       "      <td>0.000030</td>\n",
       "      <td>0.102738</td>\n",
       "      <td>0.338292</td>\n",
       "      <td>0.158614</td>\n",
       "      <td>0.464505</td>\n",
       "      <td>0.055296</td>\n",
       "      <td>0.038183</td>\n",
       "      <td>0.013548</td>\n",
       "      <td>0.103051</td>\n",
       "      <td>1.462270</td>\n",
       "      <td>0.251893</td>\n",
       "      <td>0.209203</td>\n",
       "      <td>0.100460</td>\n",
       "      <td>2.126877</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>ILSVRC2012_val_00004677</td>\n",
       "      <td>gray</td>\n",
       "      <td>1</td>\n",
       "      <td>goldfish</td>\n",
       "      <td>0.625475</td>\n",
       "      <td>0.00115</td>\n",
       "      <td>0.624325</td>\n",
       "      <td>BPT-1000</td>\n",
       "      <td>0.000033</td>\n",
       "      <td>0.090621</td>\n",
       "      <td>0.351299</td>\n",
       "      <td>0.156730</td>\n",
       "      <td>0.472151</td>\n",
       "      <td>0.035123</td>\n",
       "      <td>0.050464</td>\n",
       "      <td>0.023142</td>\n",
       "      <td>0.103051</td>\n",
       "      <td>2.752843</td>\n",
       "      <td>0.308132</td>\n",
       "      <td>0.291820</td>\n",
       "      <td>0.103423</td>\n",
       "      <td>3.559269</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Unnamed: 0                    image bg_type  pred_cls  pred_lbl       f_S  \\\n",
       "0           0  ILSVRC2012_val_00004677    gray         1  goldfish  0.625475   \n",
       "1           1  ILSVRC2012_val_00004677    gray         1  goldfish  0.625475   \n",
       "2           2  ILSVRC2012_val_00004677    gray         1  goldfish  0.625475   \n",
       "\n",
       "       f_0       f_T    method  threshold  best_point   max_IoU    au_IoU  \\\n",
       "0  0.00115  0.624325   BPT-100   0.000038    0.045580  0.328418  0.163998   \n",
       "1  0.00115  0.624325   BPT-500   0.000030    0.102738  0.338292  0.158614   \n",
       "2  0.00115  0.624325  BPT-1000   0.000033    0.090621  0.351299  0.156730   \n",
       "\n",
       "   aucI_pred  aucD_pred  aucI_mse  aucD_mse  time_load  time_exp  time_aucI  \\\n",
       "0   0.409691   0.050025  0.063105  0.019651   0.103051  0.744135   0.090060   \n",
       "1   0.464505   0.055296  0.038183  0.013548   0.103051  1.462270   0.251893   \n",
       "2   0.472151   0.035123  0.050464  0.023142   0.103051  2.752843   0.308132   \n",
       "\n",
       "   time_aucD  time_auc_IoU  time_total  \n",
       "0   0.114084      0.100765    1.152096  \n",
       "1   0.209203      0.100460    2.126877  \n",
       "2   0.291820      0.103423    3.559269  "
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.method = df.method.apply(lambda x: x.replace('Partition', 'AA'))\n",
    "df.head(3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "6cfebebb-c29b-4ac7-9ed1-d0de10d8635b",
   "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>Unnamed: 0</th>\n",
       "      <th>image</th>\n",
       "      <th>bg_type</th>\n",
       "      <th>pred_cls</th>\n",
       "      <th>pred_lbl</th>\n",
       "      <th>f_S</th>\n",
       "      <th>f_0</th>\n",
       "      <th>f_T</th>\n",
       "      <th>method</th>\n",
       "      <th>threshold</th>\n",
       "      <th>best_point</th>\n",
       "      <th>max_IoU</th>\n",
       "      <th>au_IoU</th>\n",
       "      <th>aucI_pred</th>\n",
       "      <th>aucD_pred</th>\n",
       "      <th>aucI_mse</th>\n",
       "      <th>aucD_mse</th>\n",
       "      <th>time_load</th>\n",
       "      <th>time_exp</th>\n",
       "      <th>time_aucI</th>\n",
       "      <th>time_aucD</th>\n",
       "      <th>time_auc_IoU</th>\n",
       "      <th>time_total</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>ILSVRC2012_val_00004677</td>\n",
       "      <td>gray</td>\n",
       "      <td>1</td>\n",
       "      <td>goldfish</td>\n",
       "      <td>0.625475</td>\n",
       "      <td>0.001150</td>\n",
       "      <td>0.624325</td>\n",
       "      <td>BPT-100</td>\n",
       "      <td>3.806015e-05</td>\n",
       "      <td>0.045580</td>\n",
       "      <td>0.328418</td>\n",
       "      <td>0.163998</td>\n",
       "      <td>0.409691</td>\n",
       "      <td>0.050025</td>\n",
       "      <td>0.063105</td>\n",
       "      <td>0.019651</td>\n",
       "      <td>0.103051</td>\n",
       "      <td>0.744135</td>\n",
       "      <td>0.090060</td>\n",
       "      <td>0.114084</td>\n",
       "      <td>0.100765</td>\n",
       "      <td>1.152096</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>ILSVRC2012_val_00004677</td>\n",
       "      <td>gray</td>\n",
       "      <td>1</td>\n",
       "      <td>goldfish</td>\n",
       "      <td>0.625475</td>\n",
       "      <td>0.001150</td>\n",
       "      <td>0.624325</td>\n",
       "      <td>BPT-500</td>\n",
       "      <td>3.025504e-05</td>\n",
       "      <td>0.102738</td>\n",
       "      <td>0.338292</td>\n",
       "      <td>0.158614</td>\n",
       "      <td>0.464505</td>\n",
       "      <td>0.055296</td>\n",
       "      <td>0.038183</td>\n",
       "      <td>0.013548</td>\n",
       "      <td>0.103051</td>\n",
       "      <td>1.462270</td>\n",
       "      <td>0.251893</td>\n",
       "      <td>0.209203</td>\n",
       "      <td>0.100460</td>\n",
       "      <td>2.126877</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>ILSVRC2012_val_00004677</td>\n",
       "      <td>gray</td>\n",
       "      <td>1</td>\n",
       "      <td>goldfish</td>\n",
       "      <td>0.625475</td>\n",
       "      <td>0.001150</td>\n",
       "      <td>0.624325</td>\n",
       "      <td>BPT-1000</td>\n",
       "      <td>3.308777e-05</td>\n",
       "      <td>0.090621</td>\n",
       "      <td>0.351299</td>\n",
       "      <td>0.156730</td>\n",
       "      <td>0.472151</td>\n",
       "      <td>0.035123</td>\n",
       "      <td>0.050464</td>\n",
       "      <td>0.023142</td>\n",
       "      <td>0.103051</td>\n",
       "      <td>2.752843</td>\n",
       "      <td>0.308132</td>\n",
       "      <td>0.291820</td>\n",
       "      <td>0.103423</td>\n",
       "      <td>3.559269</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>ILSVRC2012_val_00004677</td>\n",
       "      <td>gray</td>\n",
       "      <td>1</td>\n",
       "      <td>goldfish</td>\n",
       "      <td>0.625475</td>\n",
       "      <td>0.001150</td>\n",
       "      <td>0.623394</td>\n",
       "      <td>AA-100</td>\n",
       "      <td>1.208643e-05</td>\n",
       "      <td>0.237026</td>\n",
       "      <td>0.212425</td>\n",
       "      <td>0.140571</td>\n",
       "      <td>0.487116</td>\n",
       "      <td>0.038053</td>\n",
       "      <td>0.020852</td>\n",
       "      <td>0.022877</td>\n",
       "      <td>0.103051</td>\n",
       "      <td>1.209754</td>\n",
       "      <td>0.163020</td>\n",
       "      <td>0.153787</td>\n",
       "      <td>0.089208</td>\n",
       "      <td>1.718820</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>ILSVRC2012_val_00004677</td>\n",
       "      <td>gray</td>\n",
       "      <td>1</td>\n",
       "      <td>goldfish</td>\n",
       "      <td>0.625475</td>\n",
       "      <td>0.001150</td>\n",
       "      <td>0.623394</td>\n",
       "      <td>AA-500</td>\n",
       "      <td>5.027029e-05</td>\n",
       "      <td>0.081633</td>\n",
       "      <td>0.186211</td>\n",
       "      <td>0.113708</td>\n",
       "      <td>0.643160</td>\n",
       "      <td>0.030415</td>\n",
       "      <td>0.018487</td>\n",
       "      <td>0.010374</td>\n",
       "      <td>0.103051</td>\n",
       "      <td>2.957479</td>\n",
       "      <td>0.272267</td>\n",
       "      <td>0.293286</td>\n",
       "      <td>0.090369</td>\n",
       "      <td>3.716452</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8031</th>\n",
       "      <td>8031</td>\n",
       "      <td>ILSVRC2012_val_00048751</td>\n",
       "      <td>gray</td>\n",
       "      <td>992</td>\n",
       "      <td>agaric</td>\n",
       "      <td>0.328659</td>\n",
       "      <td>0.000178</td>\n",
       "      <td>0.328481</td>\n",
       "      <td>LRP</td>\n",
       "      <td>2.216855e-08</td>\n",
       "      <td>0.573123</td>\n",
       "      <td>0.290081</td>\n",
       "      <td>0.213591</td>\n",
       "      <td>0.201858</td>\n",
       "      <td>0.137607</td>\n",
       "      <td>0.076973</td>\n",
       "      <td>0.088842</td>\n",
       "      <td>0.090833</td>\n",
       "      <td>0.132460</td>\n",
       "      <td>0.453798</td>\n",
       "      <td>0.492038</td>\n",
       "      <td>0.110377</td>\n",
       "      <td>1.279506</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8032</th>\n",
       "      <td>8032</td>\n",
       "      <td>ILSVRC2012_val_00048751</td>\n",
       "      <td>gray</td>\n",
       "      <td>992</td>\n",
       "      <td>agaric</td>\n",
       "      <td>0.328659</td>\n",
       "      <td>0.000178</td>\n",
       "      <td>0.328481</td>\n",
       "      <td>GradCAM</td>\n",
       "      <td>9.227761e-06</td>\n",
       "      <td>0.252152</td>\n",
       "      <td>0.513603</td>\n",
       "      <td>0.325209</td>\n",
       "      <td>0.345347</td>\n",
       "      <td>0.049460</td>\n",
       "      <td>0.032730</td>\n",
       "      <td>0.000964</td>\n",
       "      <td>0.090833</td>\n",
       "      <td>0.059094</td>\n",
       "      <td>0.401631</td>\n",
       "      <td>0.381663</td>\n",
       "      <td>0.090444</td>\n",
       "      <td>1.023665</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8033</th>\n",
       "      <td>8033</td>\n",
       "      <td>ILSVRC2012_val_00048751</td>\n",
       "      <td>gray</td>\n",
       "      <td>992</td>\n",
       "      <td>agaric</td>\n",
       "      <td>0.328659</td>\n",
       "      <td>0.000178</td>\n",
       "      <td>0.328481</td>\n",
       "      <td>aIDG</td>\n",
       "      <td>3.778632e-06</td>\n",
       "      <td>0.362205</td>\n",
       "      <td>0.263970</td>\n",
       "      <td>0.221115</td>\n",
       "      <td>0.312963</td>\n",
       "      <td>0.048009</td>\n",
       "      <td>0.022930</td>\n",
       "      <td>0.008319</td>\n",
       "      <td>0.090833</td>\n",
       "      <td>0.581373</td>\n",
       "      <td>0.454557</td>\n",
       "      <td>0.462015</td>\n",
       "      <td>0.101132</td>\n",
       "      <td>1.689911</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8034</th>\n",
       "      <td>8034</td>\n",
       "      <td>ILSVRC2012_val_00048751</td>\n",
       "      <td>gray</td>\n",
       "      <td>992</td>\n",
       "      <td>agaric</td>\n",
       "      <td>0.328659</td>\n",
       "      <td>0.000178</td>\n",
       "      <td>0.328481</td>\n",
       "      <td>aGradExpl</td>\n",
       "      <td>4.394302e-06</td>\n",
       "      <td>0.418327</td>\n",
       "      <td>0.244031</td>\n",
       "      <td>0.207370</td>\n",
       "      <td>0.197811</td>\n",
       "      <td>0.052716</td>\n",
       "      <td>0.021961</td>\n",
       "      <td>0.006874</td>\n",
       "      <td>0.090833</td>\n",
       "      <td>0.240479</td>\n",
       "      <td>0.521861</td>\n",
       "      <td>0.457006</td>\n",
       "      <td>0.090536</td>\n",
       "      <td>1.400715</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8035</th>\n",
       "      <td>8035</td>\n",
       "      <td>ILSVRC2012_val_00048751</td>\n",
       "      <td>gray</td>\n",
       "      <td>992</td>\n",
       "      <td>agaric</td>\n",
       "      <td>0.328659</td>\n",
       "      <td>0.000178</td>\n",
       "      <td>0.328481</td>\n",
       "      <td>GradShap</td>\n",
       "      <td>4.457068e-06</td>\n",
       "      <td>0.383849</td>\n",
       "      <td>0.258657</td>\n",
       "      <td>0.224173</td>\n",
       "      <td>0.190982</td>\n",
       "      <td>0.039046</td>\n",
       "      <td>0.029825</td>\n",
       "      <td>0.004657</td>\n",
       "      <td>0.090833</td>\n",
       "      <td>0.390938</td>\n",
       "      <td>0.522298</td>\n",
       "      <td>0.532395</td>\n",
       "      <td>0.090446</td>\n",
       "      <td>1.626909</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>8036 rows × 23 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      Unnamed: 0                    image bg_type  pred_cls  pred_lbl  \\\n",
       "0              0  ILSVRC2012_val_00004677    gray         1  goldfish   \n",
       "1              1  ILSVRC2012_val_00004677    gray         1  goldfish   \n",
       "2              2  ILSVRC2012_val_00004677    gray         1  goldfish   \n",
       "3              3  ILSVRC2012_val_00004677    gray         1  goldfish   \n",
       "4              4  ILSVRC2012_val_00004677    gray         1  goldfish   \n",
       "...          ...                      ...     ...       ...       ...   \n",
       "8031        8031  ILSVRC2012_val_00048751    gray       992    agaric   \n",
       "8032        8032  ILSVRC2012_val_00048751    gray       992    agaric   \n",
       "8033        8033  ILSVRC2012_val_00048751    gray       992    agaric   \n",
       "8034        8034  ILSVRC2012_val_00048751    gray       992    agaric   \n",
       "8035        8035  ILSVRC2012_val_00048751    gray       992    agaric   \n",
       "\n",
       "           f_S       f_0       f_T     method     threshold  best_point  \\\n",
       "0     0.625475  0.001150  0.624325    BPT-100  3.806015e-05    0.045580   \n",
       "1     0.625475  0.001150  0.624325    BPT-500  3.025504e-05    0.102738   \n",
       "2     0.625475  0.001150  0.624325   BPT-1000  3.308777e-05    0.090621   \n",
       "3     0.625475  0.001150  0.623394     AA-100  1.208643e-05    0.237026   \n",
       "4     0.625475  0.001150  0.623394     AA-500  5.027029e-05    0.081633   \n",
       "...        ...       ...       ...        ...           ...         ...   \n",
       "8031  0.328659  0.000178  0.328481        LRP  2.216855e-08    0.573123   \n",
       "8032  0.328659  0.000178  0.328481    GradCAM  9.227761e-06    0.252152   \n",
       "8033  0.328659  0.000178  0.328481       aIDG  3.778632e-06    0.362205   \n",
       "8034  0.328659  0.000178  0.328481  aGradExpl  4.394302e-06    0.418327   \n",
       "8035  0.328659  0.000178  0.328481   GradShap  4.457068e-06    0.383849   \n",
       "\n",
       "       max_IoU    au_IoU  aucI_pred  aucD_pred  aucI_mse  aucD_mse  time_load  \\\n",
       "0     0.328418  0.163998   0.409691   0.050025  0.063105  0.019651   0.103051   \n",
       "1     0.338292  0.158614   0.464505   0.055296  0.038183  0.013548   0.103051   \n",
       "2     0.351299  0.156730   0.472151   0.035123  0.050464  0.023142   0.103051   \n",
       "3     0.212425  0.140571   0.487116   0.038053  0.020852  0.022877   0.103051   \n",
       "4     0.186211  0.113708   0.643160   0.030415  0.018487  0.010374   0.103051   \n",
       "...        ...       ...        ...        ...       ...       ...        ...   \n",
       "8031  0.290081  0.213591   0.201858   0.137607  0.076973  0.088842   0.090833   \n",
       "8032  0.513603  0.325209   0.345347   0.049460  0.032730  0.000964   0.090833   \n",
       "8033  0.263970  0.221115   0.312963   0.048009  0.022930  0.008319   0.090833   \n",
       "8034  0.244031  0.207370   0.197811   0.052716  0.021961  0.006874   0.090833   \n",
       "8035  0.258657  0.224173   0.190982   0.039046  0.029825  0.004657   0.090833   \n",
       "\n",
       "      time_exp  time_aucI  time_aucD  time_auc_IoU  time_total  \n",
       "0     0.744135   0.090060   0.114084      0.100765    1.152096  \n",
       "1     1.462270   0.251893   0.209203      0.100460    2.126877  \n",
       "2     2.752843   0.308132   0.291820      0.103423    3.559269  \n",
       "3     1.209754   0.163020   0.153787      0.089208    1.718820  \n",
       "4     2.957479   0.272267   0.293286      0.090369    3.716452  \n",
       "...        ...        ...        ...           ...         ...  \n",
       "8031  0.132460   0.453798   0.492038      0.110377    1.279506  \n",
       "8032  0.059094   0.401631   0.381663      0.090444    1.023665  \n",
       "8033  0.581373   0.454557   0.462015      0.101132    1.689911  \n",
       "8034  0.240479   0.521861   0.457006      0.090536    1.400715  \n",
       "8035  0.390938   0.522298   0.532395      0.090446    1.626909  \n",
       "\n",
       "[8036 rows x 23 columns]"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.method = df.method.apply(lambda x: x.replace('ShapGradE', 'GradShap'))\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "9ac11fb7-e610-41c3-b78a-ae8dd957b85a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['AA-100' 'AA-1000' 'AA-500' 'BPT-100' 'BPT-1000' 'BPT-500' 'GradCAM'\n",
      " 'GradShap' 'LIME-100' 'LIME-200' 'LIME-50' 'LRP' 'aGradExpl' 'aIDG']\n"
     ]
    }
   ],
   "source": [
    "print(np.unique(df.method))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "28d180e3-23b5-4e63-8cf5-6efc0890243a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total Images: 574\n"
     ]
    }
   ],
   "source": [
    "print(f'Total Images: {len(np.unique(df.image))}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "0d9b682f-85db-416c-a489-635dca36ce35",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "model_type:\t real\n",
      "pretrained_model_type:\t resnet\n"
     ]
    }
   ],
   "source": [
    "print('model_type:\\t', model_type)\n",
    "print('pretrained_model_type:\\t', pretrained_model_type)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "d0cb6988-6538-4efe-b203-530cb58efdb1",
   "metadata": {},
   "outputs": [],
   "source": [
    "name_remap = {\n",
    "    'Partition-100': 'PE-100',\n",
    "    'Partition-500': 'PE-500',\n",
    "    'Partition-1000': 'PE-1000',\n",
    "    'BPT-100': '\\\\bf BPT-100',\n",
    "    'BPT-500': '\\\\bf BPT-500',\n",
    "    'BPT-1000': '\\\\bf BPT-1000',\n",
    "    'aIDG': '$|$IDG$|$',\n",
    "    'aGradExpl': '$|$GradExpl$|$',\n",
    "}\n",
    "method_remap = {\n",
    "    'max_IoU': '$max$-$IoU$',\n",
    "    'au_IoU': '$AU$-$IoU$',\n",
    "    'aucI_pred': '$\\\\mathit{AUC}^+$',\n",
    "    'aucD_pred': '$\\\\mathit{AUC}^-$',\n",
    "    'aucI_mse': '$\\\\mathit{MSE}^+$',\n",
    "    'aucD_mse': '$\\\\mathit{MSE}^-$',\n",
    "    'time_exp': 'log(time)'\n",
    "}\n",
    "method_colors = {\n",
    "    'BPT-100':         '#f2a7c0',\n",
    "    'BPT-500':         '#db587f',\n",
    "    'BPT-1000':        '#9d2f4d',\n",
    "    'AA-100':   '#4ed1f9',\n",
    "    'AA-500':   '#00b1f2',\n",
    "    'AA-1000':  '#008fe8',\n",
    "    'AA-5000':  '#006bd7',\n",
    "    'AA-10000':  '#3245bd',\n",
    "    'LIME-50':         '#c7e883',\n",
    "    'LIME-100':        '#8fc543',\n",
    "    'LIME-200':        '#66912d',\n",
    "    'LRP':        '#008080',\n",
    "    'GradCAM':         'xkcd:camel',\n",
    "    'aIDG':            '#fcd459',\n",
    "    'aGradExpl':       '#dd7c2b',\n",
    "    'GradShap':       '#800000',\n",
    "}\n",
    "method_symbol = {\n",
    "    'BPT-100'   :       '$\\\\clubsuit$1',\n",
    "    'BPT-500'   :       '$\\\\clubsuit$2',\n",
    "    'BPT-1000'  :       '$\\\\clubsuit$3',\n",
    "    'AA-100'    :       '$\\\\boxplus$1',\n",
    "    'AA-500'    :       '$\\\\boxplus$2',\n",
    "    'AA-1000'   :       '$\\\\boxplus$3',\n",
    "    'AA-5000'   :       '$\\\\boxplus$4',\n",
    "    'AA-10000'  :       '$\\\\boxplus$5',\n",
    "    'LIME-50'   :       '\\\\textbf{0}1',\n",
    "    'LIME-100'  :      '\\\\textbf{0}2',\n",
    "    'LIME-200'  :      '\\\\textbf{0}3',\n",
    "    'LRP'       :      '\\\\textbf{$\\\\Pi$}',\n",
    "    'GradCAM'   :      '$\\\\bigtriangledown$',\n",
    "    'aIDG'      :      '$\\\\divideontimes$',\n",
    "    'aGradExpl' :     '$\\\\bigtriangleup$',\n",
    "     'GradShap':       '$\\\\square$',\n",
    "}\n",
    "\n",
    "method_to_shortname = {}\n",
    "for i,m in enumerate(method_colors.keys()):\n",
    "    method_to_shortname[m] = f'{method_symbol[m]}'"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d6ae5268-5996-4907-b651-06bb1aeed4ef",
   "metadata": {},
   "source": [
    "# Plot Results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "d57f03c5-01d9-41a4-a851-187096e149dd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "===============================================================================================\n",
      "|  MODEL_TYPE      | PRETRAINED_MODEL       | BACKGROUND_TYPE        | FILENAME               |\n",
      "-----------------------------------------------------------------------------------------------\n",
      "|  real            | resnet                 | gray                   | results_E1             |\n"
     ]
    }
   ],
   "source": [
    "if model_type =='ideal':\n",
    "    file_name = 'results_E2'\n",
    "elif model_type =='real':\n",
    "    if pretrained_model_type=='resnet' and background_type=='gray':\n",
    "        file_name = 'results_E1'\n",
    "    if pretrained_model_type=='vgg16':\n",
    "        file_name = 'results_E4'\n",
    "    if pretrained_model_type=='swin_trans_vit':\n",
    "        file_name = 'results_E5'\n",
    "    if background_type=='full':\n",
    "        file_name = 'results_E3'\n",
    "print('='*95)\n",
    "print('| ',f'{\"MODEL_TYPE\":15}','|',f'{\"PRETRAINED_MODEL\":22}','|',f'{\"BACKGROUND_TYPE\":22}','|',f'{\"FILENAME\":22}','|')\n",
    "print('-'*95)\n",
    "print('| ',f'{model_type:15}','|',f'{pretrained_model_type:22}','|',f'{background_type:22}','|',f'{file_name:22}','|')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5a1b2a5f-dd99-456b-962f-274eb923c774",
   "metadata": {},
   "source": [
    "## Figure 4: E1, E2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "9f5ba0c5-a638-45bb-86ce-5b4d3c0d6f5a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "pretrained_model_type:\t resnet \n",
      " background_type:\t gray\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1100x260 with 7 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "saved at : E:\\Cloud\\Shared\\XAI\\ICLR_Supplementary\\notebooks\\E1_to_E5\\boxplot\n"
     ]
    }
   ],
   "source": [
    "print('pretrained_model_type:\\t', pretrained_model_type,'\\n background_type:\\t',background_type)\n",
    "def box_plot(ax, data, label, position, edge_color, line_width, fill_color):\n",
    "    bp = ax.boxplot(data, labels=[label], positions=[position], vert=False, \n",
    "                    widths=0.5, whis=5, patch_artist=True, flierprops={'markersize': 1, 'markerfacecolor':'magenta', 'markeredgecolor':'magenta'}) # \n",
    "    \n",
    "    for element in ['boxes', 'whiskers', 'fliers', 'means', 'medians', 'caps']:\n",
    "        plt.setp(bp[element], color=edge_color, linewidth=line_width)\n",
    "\n",
    "    for patch in bp['boxes']:\n",
    "        patch.set(facecolor=fill_color)       \n",
    "        \n",
    "    return bp\n",
    "\n",
    "fig, axes = plt.subplots(1,7, figsize=(11, 2.6)) # (11, 3.2)\n",
    "auc_methods      = ['aucI_pred', 'aucD_pred', 'aucI_mse', 'aucD_mse', 'max_IoU', 'au_IoU', 'time_exp']\n",
    "for j, score in enumerate(auc_methods):\n",
    "    ascending = score in ['max_IoU', 'au_IoU', 'aucI_pred']\n",
    "    means = df.groupby('method')[[score]].median() \\\n",
    "              .sort_values(score, ascending=ascending).index\n",
    "    log_scale = (score=='time_exp')\n",
    "    axes[j].set_xscale('log' if log_scale else 'linear')\n",
    "    for i, method in enumerate(means):\n",
    "        text_yincrement = -0.3\n",
    "        values = df[ df.method==method ][score]\n",
    "        name = name_remap[method] if method in name_remap else method\n",
    "        color = method_colors[method]\n",
    "        q75 = np.quantile(values, 0.75)\n",
    "        q100 = np.quantile(values, 1.0)\n",
    "        if not log_scale and 'IoU' not in score and q100>1.0:\n",
    "            q100, text_yincrement = 0.82, 0.15\n",
    "        box_plot(axes[j], [[v for v in values]], '', i, \n",
    "                 'blue' if method.startswith('BPT') else 'black', \n",
    "                 1.5 if method.startswith('BPT') else 0.5,\n",
    "                 color)\n",
    "        axes[j].text(min(q100*1.3, 30) if log_scale else q100+0.05, i+text_yincrement, method_to_shortname[method])\n",
    "    # plt.legend()\n",
    "    if pretrained_model_type=='vgg16':\n",
    "        min_x, max_x = -0.05, 1.05\n",
    "        if score=='aucI_pred': max_x=1.35\n",
    "        if score=='aucD_pred': max_x=1.2\n",
    "        if score=='au_IoU': max_x=1.0\n",
    "        if score=='aucI_mse': max_x=1.2\n",
    "        if score=='max_IoU': max_x=(1.4 if model=='ideal' else 1.3)\n",
    "    elif pretrained_model_type=='resnet':\n",
    "        min_x, max_x = -0.05, 1.05\n",
    "        if score=='aucI_pred': max_x=1.10\n",
    "        if score=='aucD_pred': max_x=1.0\n",
    "        if score=='au_IoU':    max_x=0.8\n",
    "        if score=='aucI_mse': max_x=1.2\n",
    "        if score=='max_IoU': max_x=(1.4 if model=='ideal' else 1.3)\n",
    "    elif pretrained_model_type=='swin_trans_vit':\n",
    "        min_x, max_x = -0.05, 1.05\n",
    "        if score=='aucI_pred': max_x=1.20\n",
    "        if score=='aucD_pred': max_x=1.15\n",
    "        if score=='au_IoU':    max_x=0.8\n",
    "        if score=='aucI_mse': max_x=1.2\n",
    "        if score=='aucD_mse': max_x=1.1\n",
    "        if score=='max_IoU': max_x=(1.4 if model=='ideal' else 1.3)\n",
    "    if score=='time_exp': \n",
    "        min_x, max_x = 0.011, 99\n",
    "        for m in [0.01, 0.1, 1, 10]:\n",
    "            for k in range(1,10):\n",
    "                axes[j].axvline(m*k, lw=0.5, color='grey', alpha=1/k)\n",
    "        \n",
    "        axes[j].set_xticks([0.1, 1, 10])\n",
    "        axes[j].set_xticklabels(['0.1', '1', '10'])\n",
    "\n",
    "    axes[j].set_xlim(min_x, max_x)\n",
    "    axes[j].set_title(f\"{method_remap[score]}\", fontsize=15) # + ('$\\\\uparrow$' if ascending else '$\\\\downarrow$'))\n",
    "    # do not use arrows, as they are used for sub-coalition structures\n",
    "    axes[j].set_ylim(-0.7, i+0.8)\n",
    "    axes[j].set_yticks([])\n",
    "\n",
    "plt.subplots_adjust(wspace=0.10)\n",
    "plt.savefig(f'{path_boxplot}/{file_name}_{suffix}.pdf', dpi=150, transparent=True, bbox_inches='tight', pad_inches=0.02)\n",
    "if file_name=='results_E1':\n",
    "    plt.savefig(f'{path_boxplot}/{file_name}_{suffix}.svg', dpi=150, transparent=True, bbox_inches='tight', pad_inches=0.02)\n",
    "plt.show()\n",
    "print('saved at :',path_boxplot)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "db416cee-2cf9-49b9-9632-581cb0a3f7e5",
   "metadata": {},
   "source": [
    "# Save Legend"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "665afd04-1cda-470a-8103-ff7d7e5c4f09",
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_save_legend = True"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "005f9858-3ee6-4994-aae5-ded97f6cd818",
   "metadata": {},
   "source": [
    "## LEGEND FOR E1\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "d4854f73-1410-422f-947b-e686492fab64",
   "metadata": {},
   "outputs": [],
   "source": [
    "if plot_save_legend:\n",
    "    legend_order = [\n",
    "                    ('BPT-100',  0),  ('BPT-500',    2),   ('BPT-1000', 4),\n",
    "                    ('AA-100',   1),  ('AA-500',     3),   ('AA-1000', 5),    #('AA-5000', 7),  ('AA-10000', 9),\n",
    "                    ('LIME-50',  6),  ('LIME-100',   8),   ('LIME-200', 10),\n",
    "                    ('LRP',     7),   #12-> 7\n",
    "                    ('GradShap', 13), #13 -> 9\n",
    "                    ('GradCAM', 9),  ('aIDG',      11),   ('aGradExpl', 12),\n",
    "                    ]\n",
    "    lm = [None] * len(legend_order)\n",
    "    \n",
    "    for m,j in legend_order:\n",
    "        lm[j] = m"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "2fe29a0d-d797-4eec-bda6-39cd31b64a2d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\bf BPT-100\n",
      "AA-100\n",
      "\\bf BPT-500\n",
      "AA-500\n",
      "\\bf BPT-1000\n",
      "AA-1000\n",
      "LIME-50\n",
      "LRP\n",
      "LIME-100\n",
      "GradCAM\n",
      "LIME-200\n",
      "$|$IDG$|$\n",
      "$|$GradExpl$|$\n",
      "GradShap\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "if plot_save_legend:\n",
    "    plt.figure()\n",
    "    handles = []\n",
    "    for m in lm:\n",
    "        \n",
    "        name = name_remap[m] if m in name_remap else m\n",
    "        print(name)\n",
    "        p = mpatches.Patch(facecolor=method_colors[m], label=f'{method_to_shortname[m]}:{name}',\n",
    "                           edgecolor='blue' if m.startswith('BPT') else 'black', \n",
    "                           linewidth=1.5 if m.startswith('BPT') else 0.5)\n",
    "        handles.append(p)\n",
    "    text_middle = f'Total Images: \\t\\t\\t{len(np.unique(df.image))}\\n Pretrained Model: \\t{pretrained_model_type} \\n background_type:\\t{background_type}'\n",
    "    plt.text(0.4,0.5, text_middle)\n",
    "    plt.legend(handles=handles, ncols=7, loc='upper left', bbox_to_anchor=(0.0, -0.08), \n",
    "               fancybox=True, shadow=True, handleheight=1, handlelength=1)\n",
    "    plt.savefig(f'{path_boxplot}/result_table_legend_E1_{suffix}.svg', transparent=True, dpi=150, bbox_inches='tight', pad_inches=0.02)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9cde0498-80a6-483f-8fd4-4f6a5196fabc",
   "metadata": {},
   "source": [
    "## LEGEND FOR E2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "28d61751",
   "metadata": {},
   "outputs": [],
   "source": [
    "if plot_save_legend:\n",
    "    legend_order = [\n",
    "        ('BPT-100',  0),  ('BPT-500',    2),   ('BPT-1000', 4),\n",
    "        ('AA-100',   1),  ('AA-500',     3),   ('AA-1000', 5),    ('AA-5000', 7),  ('AA-10000', 9),\n",
    "        ('LIME-50',  6),  ('LIME-100',   8),   ('LIME-200', 10),\n",
    "        ('LRP',     12),  ('GradShap', 15),\n",
    "        ('GradCAM', 11),  ('aIDG',      13),   ('aGradExpl', 14),\n",
    "    ]\n",
    "    lm = [None] * len(legend_order)\n",
    "    \n",
    "    for m,j in legend_order:\n",
    "        lm[j] = m"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "e5bbe3cf-2ff3-4c1e-9dca-f8063b7d57fa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\bf BPT-100\n",
      "AA-100\n",
      "\\bf BPT-500\n",
      "AA-500\n",
      "\\bf BPT-1000\n",
      "AA-1000\n",
      "LIME-50\n",
      "AA-5000\n",
      "LIME-100\n",
      "AA-10000\n",
      "LIME-200\n",
      "GradCAM\n",
      "LRP\n",
      "$|$IDG$|$\n",
      "$|$GradExpl$|$\n",
      "GradShap\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "if plot_save_legend:\n",
    "    plt.figure()\n",
    "    handles = []\n",
    "    for m in lm:\n",
    "        \n",
    "        name = name_remap[m] if m in name_remap else m\n",
    "        print(name)\n",
    "        p = mpatches.Patch(facecolor=method_colors[m], label=f'{method_to_shortname[m]}:{name}',\n",
    "                           edgecolor='blue' if m.startswith('BPT') else 'black', \n",
    "                           linewidth=1.5 if m.startswith('BPT') else 0.5)\n",
    "        handles.append(p)\n",
    "    text_middle = f'Total Images: \\t\\t\\t{len(np.unique(df.image))}\\n Pretrained Model: \\t{pretrained_model_type} \\n background_type:\\t{background_type}'\n",
    "    plt.text(0.4,0.5, text_middle)\n",
    "    plt.legend(handles=handles, ncols=8, loc='upper left', bbox_to_anchor=(0.0, -0.08), \n",
    "               fancybox=True, shadow=True, handleheight=1, handlelength=1)\n",
    "    plt.savefig(f'{path_boxplot}/result_table_legend_E2_{suffix}.svg', transparent=True, dpi=150, bbox_inches='tight', pad_inches=0.02)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c5f07214-d923-41c8-a936-5fd1016b364b",
   "metadata": {},
   "source": [
    "# ANOVA\n",
    "Test statistical significance of the generated data.\n",
    "\n",
    "- H0: All group means are equal.\n",
    "- H1: At least one group mean is different from the rest, i.e. score populations are different."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "2ce17683-95c5-43a5-8de8-371f3f1a4b48",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.stats import f_oneway"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "f04b31c1-50c6-4c4d-893a-1df26aa678d3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "H1 aucI_pred 0.0\n",
      "H1 aucD_pred 9.227481681746298e-186\n",
      "H1 aucI_mse 0.00875592080510162\n",
      "H1 aucD_mse 0.007550315599354084\n",
      "H1 max_IoU 0.0\n",
      "H1 au_IoU 1.2017923579135693e-197\n",
      "H1 time_exp 0.0\n"
     ]
    }
   ],
   "source": [
    "methods = sorted(df.method.unique())\n",
    "for score in auc_methods:\n",
    "    pops = []\n",
    "    for m1 in methods:\n",
    "        pops.append(df[score][df.method==m1].values)\n",
    "\n",
    "    anova = f_oneway(*pops)\n",
    "    print('H1' if anova.pvalue<0.05 else 'H0', score, anova.pvalue)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "44481a20-283c-4216-bb82-76eb0e78dc45",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.0"
  },
  "widgets": {
   "application/vnd.jupyter.widget-state+json": {
    "state": {},
    "version_major": 2,
    "version_minor": 0
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
