{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "b8f8f679-aa49-437a-94d7-2550195777e8",
   "metadata": {},
   "source": [
    "This notebook generates the plots in Figure 4, 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": "code",
   "execution_count": 2,
   "id": "9ae18d5a-91ca-42f8-a57e-f28eb8ab1388",
   "metadata": {},
   "outputs": [],
   "source": [
    "model_type      = 'real'    # real, ideal\n",
    "background_type      = 'gray'     # black , white , gray , noise , blurred , full\n",
    "suffix_full     = f'{model_type}_{background_type}'\n",
    "\n",
    "# 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\n",
    "\n",
    "DS_name_annotation    = 'ImageNetS'\n",
    "DS_name_img           = 'ImageNet'\n",
    "\n",
    "suffix                     = f'{pretrained_model_type}_{model_type}_{background_type}'\n",
    "submission_version = False\n",
    "codes_local    = path_codes if submission_version else 'E:\\PHD\\datacloud_data\\codes\\shap_bpt'\n",
    "\n",
    "results_ = os.path.join(os.getcwd(),'results_review') if submission_version else os.path.join(codes_local,'results_review')\n",
    "results_path    = os.path.join(results_,DS_name_annotation)\n",
    "results_path                   = os.path.join(results_path,suffix)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "090bc331-eaf0-44a4-87f0-dd52c89147d6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'E:\\\\PHD\\\\datacloud_data\\\\codes\\\\shap_bpt\\\\results_review\\\\ImageNetS\\\\swin_trans_vit_real_gray/csv_exp_ImageNet_swin_trans_vit_real_gray.csv'"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "csv_filename = f'{results_path}/csv_exp_{DS_name_img}_{suffix}.csv'\n",
    "csv_filename"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "7d3585fc-87b3-4ad0-bd49-317e7009aa1d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# E:\\\\PHD\\\\datacloud_data\\\\codes\\\\shap_bpt\\\\results_review\\\\ImageNetS\\\\resnet_real_gray/csv_exp_ImageNet_resnet_real_gray.csv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "0d4f395b-762b-4aa4-b1a0-fac79f91a6c7",
   "metadata": {},
   "outputs": [],
   "source": [
    "# df,model,background = pd.read_csv('CSV/csv_exp_ImageNetS_ideal_gray.csv'), 'ideal','gray'\n",
    "# df,model,background = pd.read_csv('CSV/csv_exp_ImageNetS_stock_gray.csv'), 'stock','gray'\n",
    "# df,model,background = pd.read_csv('CSV/csv_exp_ImageNetS_stock_full.csv'), 'stock','full'\n",
    "# df,model,background = pd.read_csv('CSV/revised_csv_exp_ImageNetS_stock_gray.csv'), 'stock','gray'\n",
    "\n",
    "df,model,background = pd.read_csv(csv_filename), model_type,background_type\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2aa4d46b-413c-4c5b-b87a-b5dfe0305ff5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "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.801409</td>\n",
       "      <td>0.000814</td>\n",
       "      <td>0.800596</td>\n",
       "      <td>BPT-100</td>\n",
       "      <td>0.000032</td>\n",
       "      <td>0.108737</td>\n",
       "      <td>0.330318</td>\n",
       "      <td>0.180796</td>\n",
       "      <td>0.529414</td>\n",
       "      <td>0.201966</td>\n",
       "      <td>0.044665</td>\n",
       "      <td>0.027050</td>\n",
       "      <td>0.416116</td>\n",
       "      <td>2.625477</td>\n",
       "      <td>0.412637</td>\n",
       "      <td>0.396159</td>\n",
       "      <td>0.133291</td>\n",
       "      <td>3.983680</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.801409</td>\n",
       "      <td>0.000814</td>\n",
       "      <td>0.800596</td>\n",
       "      <td>BPT-500</td>\n",
       "      <td>0.000048</td>\n",
       "      <td>0.061484</td>\n",
       "      <td>0.282735</td>\n",
       "      <td>0.153343</td>\n",
       "      <td>0.541703</td>\n",
       "      <td>0.098246</td>\n",
       "      <td>0.070852</td>\n",
       "      <td>0.028397</td>\n",
       "      <td>0.416116</td>\n",
       "      <td>8.328393</td>\n",
       "      <td>0.878127</td>\n",
       "      <td>1.019572</td>\n",
       "      <td>0.086024</td>\n",
       "      <td>10.728232</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.801409</td>\n",
       "      <td>0.000814</td>\n",
       "      <td>0.800596</td>\n",
       "      <td>BPT-1000</td>\n",
       "      <td>0.000063</td>\n",
       "      <td>0.054468</td>\n",
       "      <td>0.304150</td>\n",
       "      <td>0.147647</td>\n",
       "      <td>0.526013</td>\n",
       "      <td>0.087234</td>\n",
       "      <td>0.107358</td>\n",
       "      <td>0.023511</td>\n",
       "      <td>0.416116</td>\n",
       "      <td>15.839587</td>\n",
       "      <td>0.996273</td>\n",
       "      <td>1.235050</td>\n",
       "      <td>0.082583</td>\n",
       "      <td>18.569610</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.801409   \n",
       "1           1  ILSVRC2012_val_00004677    gray         1  goldfish  0.801409   \n",
       "2           2  ILSVRC2012_val_00004677    gray         1  goldfish  0.801409   \n",
       "\n",
       "        f_0       f_T    method  threshold  best_point   max_IoU    au_IoU  \\\n",
       "0  0.000814  0.800596   BPT-100   0.000032    0.108737  0.330318  0.180796   \n",
       "1  0.000814  0.800596   BPT-500   0.000048    0.061484  0.282735  0.153343   \n",
       "2  0.000814  0.800596  BPT-1000   0.000063    0.054468  0.304150  0.147647   \n",
       "\n",
       "   aucI_pred  aucD_pred  aucI_mse  aucD_mse  time_load   time_exp  time_aucI  \\\n",
       "0   0.529414   0.201966  0.044665  0.027050   0.416116   2.625477   0.412637   \n",
       "1   0.541703   0.098246  0.070852  0.028397   0.416116   8.328393   0.878127   \n",
       "2   0.526013   0.087234  0.107358  0.023511   0.416116  15.839587   0.996273   \n",
       "\n",
       "   time_aucD  time_auc_IoU  time_total  \n",
       "0   0.396159      0.133291    3.983680  \n",
       "1   1.019572      0.086024   10.728232  \n",
       "2   1.235050      0.082583   18.569610  "
      ]
     },
     "execution_count": 6,
     "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": 7,
   "id": "28d180e3-23b5-4e63-8cf5-6efc0890243a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total Images: 621\n"
     ]
    }
   ],
   "source": [
    "print(f'Total Images: {len(np.unique(df.image))}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "0d9b682f-85db-416c-a489-635dca36ce35",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "pretrained_model_type:\t swin_trans_vit\n"
     ]
    }
   ],
   "source": [
    "print('pretrained_model_type:\\t', pretrained_model_type)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "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",
    "    'ShapGradE':       '#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",
    "     'ShapGradE':       '$\\\\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": "markdown",
   "id": "5a1b2a5f-dd99-456b-962f-274eb923c774",
   "metadata": {},
   "source": [
    "## Figure 4: E1, E2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "9f5ba0c5-a638-45bb-86ce-5b4d3c0d6f5a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "pretrained_model_type:\t swin_trans_vit \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"
    }
   ],
   "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'{results_path}/results_table_{suffix}.pdf', dpi=150, transparent=True, bbox_inches='tight', pad_inches=0.02)\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "37d4ba3f-f3fd-446d-8023-6f2114eab5f2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'E:\\\\PHD\\\\datacloud_data\\\\codes\\\\shap_bpt\\\\results_review\\\\ImageNetS\\\\resnet_real_gray'"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results_path"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "28d61751",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "BPT-100\n",
      "BPT-500\n",
      "BPT-1000\n",
      "AA-100\n",
      "AA-500\n",
      "AA-1000\n",
      "AA-5000\n",
      "AA-10000\n",
      "LIME-50\n",
      "LIME-100\n",
      "LIME-200\n",
      "LRP\n",
      "ShapGradE\n",
      "GradCAM\n",
      "aIDG\n",
      "aGradExpl\n"
     ]
    }
   ],
   "source": [
    "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),  ('ShapGradE', 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\n",
    "    print(m)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "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",
      "ShapGradE\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "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'{results_path}/result_table_legend_{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": 16,
   "id": "2ce17683-95c5-43a5-8de8-371f3f1a4b48",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.stats import f_oneway"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "f04b31c1-50c6-4c4d-893a-1df26aa678d3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "H1 aucI_pred 0.0\n",
      "H1 aucD_pred 1.0030021020023033e-111\n",
      "H1 aucI_mse 3.581457806625131e-16\n",
      "H0 aucD_mse 0.05697809784935768\n",
      "H1 max_IoU 0.0\n",
      "H1 au_IoU 8.51758109958069e-88\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": "ea7d014c-9cff-4ec7-8097-73a3d7dbae69",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "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.7.5"
  },
  "widgets": {
   "application/vnd.jupyter.widget-state+json": {
    "state": {},
    "version_major": 2,
    "version_minor": 0
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
