{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "18afe6f0-a27a-4b6a-bd0e-88820444956e",
   "metadata": {},
   "source": [
    "# Import Libraries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "9f3cfc80-c390-4e73-b6af-17a264c48601",
   "metadata": {},
   "outputs": [],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\", category=DeprecationWarning)\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "warnings.filterwarnings( \"ignore\", module = \"pandas\\..*\" )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "dc7f037a-5704-4859-850e-a6c5609626ba",
   "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",
    "import datetime\n",
    "from functools import partial\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": "code",
   "execution_count": 3,
   "id": "207024d7-cbd3-4c14-894c-4e3b7aca863b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<style>.container { width:80% !important; }</style>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from IPython.display import display, HTML\n",
    "display(HTML(\"<style>.container { width:80% !important; }</style>\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "7084fb9b-028e-4cd9-b5fb-df2733112fb6",
   "metadata": {},
   "outputs": [],
   "source": [
    "DS_name = 'hazelnut'\n",
    "codes_path = os.getcwd()\n",
    "results_path=os.path.join(codes_path,         'results')\n",
    "path_csv    = os.path.join(results_path,          'csv')\n",
    "path_boxplots    = os.path.join(results_path, 'boxplot')\n",
    "\n",
    "if os.path.exists(results_path):\n",
    "    os.makedirs(path_boxplots,              exist_ok=True)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "19edb6c6-6c77-45df-8811-a30505cd54e8",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_epochs = 30000\n",
    "num_explained_classes = 1\n",
    "batch_size = 16\n",
    "num_samples = 500\n",
    "postfix_csv = f'{DS_name}_{num_epochs}_9'\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d8ab2c0f-c6c5-4531-b94f-e31fee8a51fd",
   "metadata": {},
   "outputs": [],
   "source": [
    "# csv_filename = f'{results_path}/testresults_{postfix_csv}_BPT.csv'\n",
    "# print(csv_filename,' *** ',os.path.exists(csv_filename))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "a008e2f0-48e1-462b-911a-9fe575a0bb9e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "E:\\Cloud\\Shared\\XAI\\ICLR_Supplementary\\notebooks\\E6_XAD\\results\\csv/testresults_hazelnut_30000_9_BPT.csv  ***  True\n"
     ]
    }
   ],
   "source": [
    "csv_filename = f'{path_csv}/testresults_{postfix_csv}_BPT.csv'\n",
    "print(csv_filename,' *** ',os.path.exists(csv_filename))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "4f406af8-624d-4a1e-9aba-78bdec834adb",
   "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>a_type_id</th>\n",
       "      <th>a_type</th>\n",
       "      <th>img_no</th>\n",
       "      <th>mask_type</th>\n",
       "      <th>target_segs</th>\n",
       "      <th>num_samples</th>\n",
       "      <th>score_function</th>\n",
       "      <th>methods</th>\n",
       "      <th>aucI_pred</th>\n",
       "      <th>aucD_pred</th>\n",
       "      <th>aucI_mse</th>\n",
       "      <th>aucD_mse</th>\n",
       "      <th>time_exp</th>\n",
       "      <th>time_aucI</th>\n",
       "      <th>time_aucD</th>\n",
       "      <th>time_total</th>\n",
       "      <th>heat_max</th>\n",
       "      <th>threshold</th>\n",
       "      <th>max_IoU</th>\n",
       "      <th>IoU_mean</th>\n",
       "      <th>IoU_std</th>\n",
       "      <th>au_IoU</th>\n",
       "      <th>anomaly_score</th>\n",
       "      <th>anomaly_score_val</th>\n",
       "      <th>AM_roc_score</th>\n",
       "      <th>auroc</th>\n",
       "      <th>auroc_gs1</th>\n",
       "      <th>auroc_gs2</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>crack</td>\n",
       "      <td>0</td>\n",
       "      <td>blend_2</td>\n",
       "      <td>100</td>\n",
       "      <td>500</td>\n",
       "      <td>lm_p_loss</td>\n",
       "      <td>BPT-100</td>\n",
       "      <td>155.072594</td>\n",
       "      <td>23.365517</td>\n",
       "      <td>103.416381</td>\n",
       "      <td>61.573044</td>\n",
       "      <td>0.755795</td>\n",
       "      <td>0.135210</td>\n",
       "      <td>0.129878</td>\n",
       "      <td>1.171851</td>\n",
       "      <td>0.097862</td>\n",
       "      <td>0.069475</td>\n",
       "      <td>0.891720</td>\n",
       "      <td>0.201748</td>\n",
       "      <td>0.179980</td>\n",
       "      <td>0.201746</td>\n",
       "      <td>0.552117</td>\n",
       "      <td>173.42245</td>\n",
       "      <td>0.949351</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>crack</td>\n",
       "      <td>0</td>\n",
       "      <td>blend_2</td>\n",
       "      <td>100</td>\n",
       "      <td>500</td>\n",
       "      <td>lm_p_loss</td>\n",
       "      <td>BPT-500</td>\n",
       "      <td>158.137002</td>\n",
       "      <td>21.827311</td>\n",
       "      <td>125.061470</td>\n",
       "      <td>89.435926</td>\n",
       "      <td>2.755905</td>\n",
       "      <td>0.178612</td>\n",
       "      <td>0.184361</td>\n",
       "      <td>3.269847</td>\n",
       "      <td>0.178894</td>\n",
       "      <td>0.046827</td>\n",
       "      <td>0.784298</td>\n",
       "      <td>0.195690</td>\n",
       "      <td>0.164375</td>\n",
       "      <td>0.195688</td>\n",
       "      <td>0.552117</td>\n",
       "      <td>173.42245</td>\n",
       "      <td>0.949351</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>crack</td>\n",
       "      <td>0</td>\n",
       "      <td>blend_2</td>\n",
       "      <td>100</td>\n",
       "      <td>500</td>\n",
       "      <td>lm_p_loss</td>\n",
       "      <td>BPT-1000</td>\n",
       "      <td>158.733311</td>\n",
       "      <td>21.584567</td>\n",
       "      <td>136.101644</td>\n",
       "      <td>84.993392</td>\n",
       "      <td>5.063966</td>\n",
       "      <td>0.207303</td>\n",
       "      <td>0.197825</td>\n",
       "      <td>5.620063</td>\n",
       "      <td>0.221915</td>\n",
       "      <td>0.025675</td>\n",
       "      <td>0.731544</td>\n",
       "      <td>0.193035</td>\n",
       "      <td>0.156335</td>\n",
       "      <td>0.193033</td>\n",
       "      <td>0.552117</td>\n",
       "      <td>173.42245</td>\n",
       "      <td>0.949351</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Unnamed: 0  a_type_id a_type  img_no mask_type  target_segs  num_samples  \\\n",
       "0           0          0  crack       0   blend_2          100          500   \n",
       "1           1          0  crack       0   blend_2          100          500   \n",
       "2           2          0  crack       0   blend_2          100          500   \n",
       "\n",
       "  score_function   methods   aucI_pred  aucD_pred    aucI_mse   aucD_mse  \\\n",
       "0      lm_p_loss   BPT-100  155.072594  23.365517  103.416381  61.573044   \n",
       "1      lm_p_loss   BPT-500  158.137002  21.827311  125.061470  89.435926   \n",
       "2      lm_p_loss  BPT-1000  158.733311  21.584567  136.101644  84.993392   \n",
       "\n",
       "   time_exp  time_aucI  time_aucD  time_total  heat_max  threshold   max_IoU  \\\n",
       "0  0.755795   0.135210   0.129878    1.171851  0.097862   0.069475  0.891720   \n",
       "1  2.755905   0.178612   0.184361    3.269847  0.178894   0.046827  0.784298   \n",
       "2  5.063966   0.207303   0.197825    5.620063  0.221915   0.025675  0.731544   \n",
       "\n",
       "   IoU_mean   IoU_std    au_IoU  anomaly_score  anomaly_score_val  \\\n",
       "0  0.201748  0.179980  0.201746       0.552117          173.42245   \n",
       "1  0.195690  0.164375  0.195688       0.552117          173.42245   \n",
       "2  0.193035  0.156335  0.193033       0.552117          173.42245   \n",
       "\n",
       "   AM_roc_score  auroc  auroc_gs1  auroc_gs2  \n",
       "0      0.949351      0          0          0  \n",
       "1      0.949351      0          0          0  \n",
       "2      0.949351      0          0          0  "
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.read_csv(csv_filename)\n",
    "df.head(3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "22da3ffb-4710-43fc-8c21-d2da3d205d40",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "crack [ 0  1  2  3  4  5  6  7  8  9 10 11 12 13 14 15 16 17]\n",
      "cut [ 0  1  2  3  4  5  6  7  8  9 10 11 12 13 14 15 16]\n",
      "hole [ 0  1  2  3  4  5  6  7  8  9 10 11 12 13 14 15 16 17]\n",
      "print [ 0  1  2  3  4  5  6  7  8  9 10 11 12 13 14 15 16]\n",
      "Computing Results for images: \t70\n"
     ]
    }
   ],
   "source": [
    "total_anom_types = np.unique(df.a_type)\n",
    "total_num_images = 0\n",
    "for anom_type in total_anom_types:\n",
    "    images_ls = np.unique(df[df.a_type==anom_type]['img_no'])\n",
    "    print(anom_type,images_ls)\n",
    "    total_num_images+=len(images_ls)\n",
    "print(f'Computing Results for images: \\t{total_num_images}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "c09a217f-91a2-493d-a5fa-e801de8a29db",
   "metadata": {},
   "outputs": [],
   "source": [
    "verbose = False\n",
    "def get_bpt_heatmaps(num_samples=1000,verbose=False):\n",
    "    pass\n",
    "def get_aa_heatmaps(num_samples=1000,verbose=False):\n",
    "    pass\n",
    "def get_heatmaps_lime(num_samples=1000,verbose=False):\n",
    "    pass"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "fa500003-04e4-4e9d-894a-307ba2f9ff87",
   "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",
      "LIME-50\n",
      "LIME-100\n",
      "LIME-200\n"
     ]
    }
   ],
   "source": [
    "verbose = False\n",
    "\n",
    "methods = [\n",
    "    ('BPT-100',         'xkcd:light pink',      partial(get_bpt_heatmaps, num_samples=100,verbose=verbose)),\n",
    "    ('BPT-500',         'xkcd:light pink',      partial(get_bpt_heatmaps, num_samples=500,verbose=verbose)),\n",
    "    ('BPT-1000',         'xkcd:light pink',      partial(get_bpt_heatmaps, num_samples=1000,verbose=verbose)),\n",
    "\n",
    "    ('AA-100',          'xkcd:bright blue',     partial(get_aa_heatmaps, num_samples=100, verbose=verbose)),\n",
    "    ('AA-500',          'xkcd:bright blue',     partial(get_aa_heatmaps, num_samples=500, verbose=verbose)),\n",
    "    ('AA-1000',         'xkcd:bright blue',     partial(get_aa_heatmaps, num_samples=1000, verbose=verbose)),\n",
    "    \n",
    "    ('LIME-50',        'xkcd:bright lime',     partial(get_heatmaps_lime, num_segments=50, num_samples=50*5,verbose=verbose)),\n",
    "    ('LIME-100',        'xkcd:bright lime',     partial(get_heatmaps_lime, num_segments=100, num_samples=100*5,verbose=verbose)),\n",
    "    ('LIME-200',        'xkcd:bright lime',     partial(get_heatmaps_lime, num_segments=200, num_samples=200*5,verbose=verbose)),\n",
    "]\n",
    "for n,_,_ in methods:\n",
    "    print(n)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "3b32f5e8-f9ec-4d2e-a97c-82a6f5c7c850",
   "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": "code",
   "execution_count": 13,
   "id": "11ddc222-eeb6-41ee-993f-ca887da69796",
   "metadata": {},
   "outputs": [],
   "source": [
    "# df = df.rename(columns={\"IoU_max\": \"max_IoU\"})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "3e22c8bf-1a6f-4105-9225-4dc742590cea",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total Time: \t\t 0:48:34.843569\n"
     ]
    }
   ],
   "source": [
    "print('Total Time: \\t\\t',str(datetime.timedelta(seconds=np.sum(df.time_total))))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "caa06d31-d2d9-4ee0-9923-034d4e26d5ec",
   "metadata": {},
   "outputs": [],
   "source": [
    "auc_methods      = ['aucI_pred', 'aucD_pred', 'aucI_mse', 'aucD_mse','max_IoU','au_IoU','time_exp']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "1b6dea18-431f-4d53-ba25-3dbcaf9d6d6d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total Time: \t\t 0:48:34.843569\n",
      "saved at : E:\\Cloud\\Shared\\XAI\\ICLR_Supplementary\\notebooks\\E6_XAD\\results\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1500x200 with 7 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "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,len(auc_methods), figsize=(15, 2)) # (11, 3.2)\n",
    "print('Total Time: \\t\\t',str(datetime.timedelta(seconds=np.sum(df.time_total))))\n",
    "for j, score in enumerate(auc_methods):\n",
    "    ascending = score in ['max_IoU', 'au_IoU', 'aucI_pred']\n",
    "    means = df.groupby('methods')[[score]].mean() \\\n",
    "              .sort_values(score, ascending=ascending).index\n",
    "    log_scale = (score=='time_exp' or score=='aucI_mse' or score=='aucD_mse')\n",
    "    \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.methods==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",
    "        if score=='aucI_mse' or score=='aucD_mse':\n",
    "            result = [v / (128 * 128) for v in values]\n",
    "        else:\n",
    "            result = [v for v in values]\n",
    "        box_plot(axes[j], result, '', 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.4, 30) if log_scale else q100+0.05, i+text_yincrement, method_to_shortname[method])\n",
    "    # plt.legend()\n",
    "    min_x, max_x = -0.05, 1.05\n",
    "    \n",
    "    if score=='aucI_pred': min_x,max_x=0.0,400\n",
    "    if score=='aucD_pred': min_x,max_x=0.0,100\n",
    "    if score=='aucI_mse': max_x=1\n",
    "    if score=='aucD_mse': max_x=500\n",
    "    if score=='IoU_max': max_x=(1.3)\n",
    "    if score=='max_IoU': max_x=(1.3)\n",
    "    if score=='au_IoU': min_x,max_x=-0.05,0.6\n",
    "\n",
    "    if score=='time_exp': \n",
    "        min_x, max_x = 0.011, 99\n",
    "        for m in [ 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",
    "        axes[j].set_xticks([0.1, 1, 10])\n",
    "        axes[j].set_xticklabels(['0.1', '1', '10'])\n",
    "    if score=='aucI_mse': \n",
    "        min_x, max_x = 0.011, 99\n",
    "        for m in [0.001, 1000, 100000]:\n",
    "            for k in range(1,100):\n",
    "                axes[j].axvline(m*k, lw=0.5, color='grey', alpha=1/k)\n",
    "        axes[j].set_xticks([0.001, 1000, 100000])\n",
    "        # axes[j].set_xticklabels(['0.001', '1000', '100000'])\n",
    "    if score=='aucD_mse': \n",
    "        min_x, max_x = 0.011, 99\n",
    "        for m in [0.001, 100, 1000]:\n",
    "            for k in range(1,100):\n",
    "                axes[j].axvline(m*k, lw=0.5, color='grey', alpha=1/k)\n",
    "        axes[j].set_xticks([0.001, 100, 100000])\n",
    "        # axes[j].set_xticklabels(['0.001', '1000', '100000'])\n",
    "    if score in ['IoU_max']:\n",
    "        axes[j].set_xlim(min_x, max_x)\n",
    "    elif score =='au_IoU':\n",
    "        axes[j].set_xlim(min_x, max_x)\n",
    "        pass\n",
    "    elif score =='aucI_mse':\n",
    "        # axes[j].set_xlim(min_x-100, max_x)\n",
    "        pass\n",
    "    elif score =='aucD_mse':\n",
    "        # axes[j].set_xlim(min_x-100, max_x)\n",
    "        pass\n",
    "    elif score=='aucI_pred':\n",
    "        axes[j].set_xticks(np.arange(min_x, max_x, 100))\n",
    "        axes[j].set_xlim(min_x-5, max_x)\n",
    "    elif score =='aucD_pred':\n",
    "        axes[j].set_xticks(np.arange(min_x, max_x, 20))\n",
    "        axes[j].set_xlim(min_x-2, max_x)\n",
    "        # pass\n",
    "    else:\n",
    "        axes[j].set_xlim(min_x, max_x)\n",
    "    \n",
    "    axes[j].set_title(f\"{method_remap[score]}\", fontsize=20) # + ('$\\\\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.05)\n",
    "# plt.savefig(f'{results_path}/results_table_XAD.svg', dpi=150, transparent=True, bbox_inches='tight', pad_inches=0.02)\n",
    "# plt.savefig(f'{results_path}/results_table_XAD.png', dpi=200, transparent=True, bbox_inches='tight', pad_inches=0.02)\n",
    "plt.savefig(f'{path_boxplots}/results_table_XAD.pdf', dpi=200, transparent=True, bbox_inches='tight', pad_inches=0.02)\n",
    "print('saved at :',results_path)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5e72c63e-c301-4c03-b343-9524442a9491",
   "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": 17,
   "id": "64f288dc-9531-486c-9dd9-09474d287be1",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.stats import f_oneway"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "a3ba085a-c420-4b4b-bb93-c455bf950aab",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "H0 aucI_pred \t 0.9998994942036217\n",
      "H1 aucD_pred \t 3.40711511360115e-05\n",
      "H1 aucI_mse \t 2.5817444680845156e-30\n",
      "H1 aucD_mse \t 5.706939997181016e-16\n",
      "H1 max_IoU \t 2.2132234728568756e-42\n",
      "H0 au_IoU \t 0.8909918114541405\n",
      "H1 time_exp \t 0.0\n"
     ]
    }
   ],
   "source": [
    "methods = sorted(df.methods.unique())\n",
    "for score in auc_methods:\n",
    "    pops = []\n",
    "    for m1 in methods:\n",
    "        pops.append(df[score][df.methods==m1].values)\n",
    "\n",
    "    anova = f_oneway(*pops)\n",
    "    print('H1' if anova.pvalue<0.05 else 'H0', score,'\\t', anova.pvalue)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5e49884b-2031-4484-8e69-cc8c0223d7a2",
   "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.18"
  },
  "widgets": {
   "application/vnd.jupyter.widget-state+json": {
    "state": {},
    "version_major": 2,
    "version_minor": 0
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
