{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "d74afb18-9516-468e-8f48-e98539b03bf3",
   "metadata": {},
   "source": [
    "# Import Libraries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "37e92d51-3545-448a-b4af-3521d36fefac",
   "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,re\n",
    "from functools import partial\n",
    "pd.set_option('display.max_columns', None)\n",
    "import datetime\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": "a7a01885-8b2b-44e5-9bc2-6dd9fafc143f",
   "metadata": {},
   "source": [
    "# Path Setting\n",
    "**NOTE** Comment uncomment LINE No 4,5 to change dataset path"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "5961f59c-2cd6-4f5f-9526-9a8d8486e79e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "path_dataset: \t D:\\DS\\CelebAMask-HQ\\\n",
      "codes path: \t E:\\Cloud\\Shared\\XAI\\ICLR_Supplementary\\notebooks\\E7_CelebA\n",
      "csv path: \t E:\\Cloud\\Shared\\XAI\\ICLR_Supplementary\\notebooks\\E7_CelebA\\results\\csv\n",
      "utils path: \t E:\\Cloud\\Shared\\XAI\\ICLR_Supplementary\\notebooks\\utils\n"
     ]
    }
   ],
   "source": [
    "path_curr = os.getcwd()\n",
    "path_notebook = os.path.abspath(os.path.join(os.getcwd(), os.pardir))\n",
    "\n",
    "#path_dataset = os.path.abspath(os.path.join(path_notebook,'dataset/CelebA/CelebAMask-HQ'))\n",
    "path_dataset = 'D:\\\\DS\\\\CelebAMask-HQ\\\\'\n",
    "\n",
    "path_main = path_curr\n",
    "#path_main = 'E:\\\\PHD\\\\datacloud_data\\\\repos\\\\ICLR_Supplementary'\n",
    "\n",
    "results_path_main   = os.path.join(path_curr,               'results')\n",
    "path_csv            = os.path.join(results_path_main,           'csv')\n",
    "utils_path          = os.path.join(path_notebook,             'utils')\n",
    "\n",
    "print('path_dataset: \\t',        path_dataset)\n",
    "print('codes path: \\t',             path_curr)\n",
    "print('csv path: \\t',                path_csv)\n",
    "print('utils path: \\t',            utils_path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "b464cd92-8e68-4356-aab8-efb77aa6b638",
   "metadata": {},
   "outputs": [],
   "source": [
    "if os.path.exists(results_path_main):\n",
    "    results_boxplots     = os.path.join(results_path_main,  'boxplots')\n",
    "    os.makedirs(results_boxplots,              exist_ok=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d7f8e0c7-e081-4f25-82fc-32002a2d65ac",
   "metadata": {},
   "source": [
    "# XAI Methods"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "33b55e9c-c11a-4507-a0c0-4c09ec62ba87",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_bpt_heatmaps(num_samples=None,verbose=None):\n",
    "    pass\n",
    "def get_aa_heatmaps(num_samples=None,verbose=None):\n",
    "    pass\n",
    "def get_lime_heatmaps(num_samples=None,num_segments=None,verbose=None):\n",
    "    pass\n",
    "def get_LRP_captum_heatmaps():\n",
    "    pass\n",
    "def get_gradcam_heatmaps():\n",
    "    pass\n",
    "def methods_gradcam():\n",
    "    pass\n",
    "def get_idg_heatmaps(use_abs=True):\n",
    "    pass\n",
    "def get_gradexpl_heatmap():\n",
    "    pass\n",
    "def get_gradshap_captum_heatmaps():\n",
    "    pass"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "c9cbd6d8-ecfe-49cf-9315-e134a99160de",
   "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",
      "LRP\n",
      "GradCAM\n",
      "aIDG\n",
      "aGradExpl\n",
      "GradShapE\n"
     ]
    }
   ],
   "source": [
    "#     name,                 color,                  functor\n",
    "verbose = False\n",
    "methods = [ \n",
    "    ('BPT-100',         'xkcd:light pink',     partial(get_bpt_heatmaps, num_samples=100,verbose=verbose)),\n",
    "    ('BPT-500',         'xkcd:bright pink',     partial(get_bpt_heatmaps, num_samples=500,verbose=verbose)),\n",
    "    ('BPT-1000',         'xkcd:deep pink',     partial(get_bpt_heatmaps, num_samples=1000,verbose=verbose)),\n",
    "    ]\n",
    "\n",
    "methods_aa = [ # if multiple backgrounds\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",
    "methods_lime = [\n",
    "    ('LIME-50',        'xkcd:bright lime',     partial(get_lime_heatmaps, num_segments=50, num_samples=50*5,verbose=verbose)),\n",
    "    ('LIME-100',        'xkcd:kermit green',   partial(get_lime_heatmaps, num_segments=100, num_samples=100*5,verbose=verbose)),\n",
    "    ('LIME-200',        'xkcd:dark lime green',partial(get_lime_heatmaps, num_segments=200, num_samples=200*5,verbose=verbose))\n",
    "    ]\n",
    "\n",
    "methods_LRP = [\n",
    "    ('LRP',        'xkcd:bright lime',     get_LRP_captum_heatmaps)\n",
    "    ]\n",
    "methods_gradcam = [\n",
    "    ('GradCAM',     'xkcd:camel',            get_gradcam_heatmaps)\n",
    "    ]\n",
    "methods_cam = [\n",
    "    ('aIDG',         'xkcd:indigo',          partial(get_idg_heatmaps, use_abs=False)),\n",
    "    ('aGradExpl',    'red',                  partial(get_gradexpl_heatmap, use_abs=False))\n",
    "    ]\n",
    "\n",
    "methods_GradShapE = [\n",
    "    ('GradShapE',     'xkcd:camel',            partial(get_gradshap_captum_heatmaps, n_samples=50, use_abs=False))\n",
    "]\n",
    "\n",
    "methods += methods_aa\n",
    "methods += methods_lime\n",
    "methods += methods_LRP\n",
    "methods += methods_gradcam\n",
    "methods += methods_cam\n",
    "methods += methods_GradShapE\n",
    "\n",
    "for n,_,_ in methods:\n",
    "    print(n)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3f9fd3f8-c58c-4c8e-ad7c-4b837a8a7929",
   "metadata": {},
   "source": [
    "# Setting for CSV File Name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "53bb5992-8dec-425e-af59-13815f42c138",
   "metadata": {},
   "outputs": [],
   "source": [
    "# background_type        = 'blurred'     # 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        = 'gray'     # black , white , gray , noise , blurred , full\n",
    "# background_type        = 'full'     # black , white , gray , noise , blurred , full"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "e7b7c741-e40f-40e1-89da-0f383f8db854",
   "metadata": {},
   "outputs": [],
   "source": [
    "results_path  = os.path.join(results_path_main,('bg_'+background_type))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ec9680a1-b359-426a-877f-37945c0c8d1d",
   "metadata": {},
   "source": [
    "# Load Annotation File"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "id": "9e608555-86f4-498b-a1db-b2569aef7c76",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "30000\n"
     ]
    }
   ],
   "source": [
    "csv_anno_file = f'{path_dataset}//CelebA-HQ-attribute.txt'\n",
    "df_attr = pd.read_csv(csv_anno_file, delim_whitespace=True,skiprows=[0])\n",
    "df_attr.replace(-1,0,inplace=True)\n",
    "df_attr.head(2)\n",
    "print(len(np.unique(df_attr.image_id)))\n",
    "\n",
    "classes_names = []\n",
    "for i,x in  enumerate(df_attr.columns):\n",
    "    # print(i-1, x)\n",
    "    if i!=0:\n",
    "        classes_names.append(x)\n",
    "#df_attr_sel = df_attr[['image_id','Brown_Hair','Eyeglasses']].copy()\n",
    "df_attr_sel = df_attr[['image_id','Brown_Hair','Black_Hair','Blond_Hair','Gray_Hair','Eyeglasses']].copy()\n",
    "\n",
    "#df_attr_sel = df_attr_sel[(df_attr_sel.Brown_Hair==1) & (df_attr_sel.Eyeglasses==1) ]\n",
    "df_attr_sel = df_attr_sel[(df_attr_sel.Brown_Hair==1) | (df_attr_sel.Black_Hair==1) |(df_attr_sel.Blond_Hair==1) |(df_attr_sel.Gray_Hair==1) |(df_attr_sel.Eyeglasses==1) ]\n",
    "df_attr_sel.head()\n",
    "\n",
    "#files = np.unique(df_attr_sel.image_id)\n",
    "files = np.unique(df_attr_sel.image_id)\n",
    "iterations = len(files)\n",
    "def natural_key(s):\n",
    "    return [int(text) if text.isdigit() else text for text in re.split(r'(\\d+)', s)]\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c98af0cc-2e1b-41a8-87ba-c99b6aed6742",
   "metadata": {},
   "source": [
    "## Brown Hairs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "id": "543904d5-b453-4348-a71e-c7e3d4c0afad",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Brown: 19528 ~ Brown: 19528\n"
     ]
    }
   ],
   "source": [
    "\n",
    "df_attr_hairs = df_attr[['image_id','Brown_Hair','Black_Hair','Blond_Hair','Gray_Hair']].copy()\n",
    "\n",
    "df_attr_brownhairs_true = df_attr_hairs[df_attr_hairs.Brown_Hair==1]\n",
    "df_attr_brownhairs_false = df_attr_hairs[(df_attr_hairs.Brown_Hair == 0) & ((df_attr_hairs.Black_Hair == 1) | (df_attr_hairs.Blond_Hair == 1) | (df_attr_hairs.Gray_Hair == 1))]\n",
    "\n",
    "df_attr_brownhairs = pd.concat([df_attr_brownhairs_false, df_attr_brownhairs_true]).drop_duplicates().reset_index(drop=True)\n",
    "\n",
    "df_attr_brownhairs = df_attr_brownhairs.sort_values(by='image_id', key=lambda col: col.map(natural_key)).reset_index(drop=True)\n",
    "\n",
    "#list_brownhairs_true = list(df_attr_brownhairs_true.image_id.values)\n",
    "#list_brownhairs_false = list(df_attr_brownhairs_false.image_id.values)\n",
    "list_brownhairs = list(df_attr_brownhairs.image_id.values)\n",
    "\n",
    "print('Brown:',len(list_brownhairs),'~ Brown:',len(list_brownhairs))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "44288577-db55-44d6-af70-6bdef8629ff0",
   "metadata": {},
   "source": [
    "## Eyeglasses"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "6e9fdade-f9a8-4a84-a9d8-91fdd8fcb180",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Eyeglasses: 1468\n"
     ]
    },
    {
     "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>image_id</th>\n",
       "      <th>Eyeglasses</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.jpg</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1.jpg</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2.jpg</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3.jpg</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4.jpg</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>5.jpg</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>6.jpg</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>7.jpg</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>8.jpg</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>9.jpg</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  image_id  Eyeglasses\n",
       "0    0.jpg           0\n",
       "1    1.jpg           0\n",
       "2    2.jpg           0\n",
       "3    3.jpg           0\n",
       "4    4.jpg           0\n",
       "5    5.jpg           0\n",
       "6    6.jpg           0\n",
       "7    7.jpg           0\n",
       "8    8.jpg           0\n",
       "9    9.jpg           0"
      ]
     },
     "execution_count": 79,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_attr_eyeglasses = df_attr[['image_id','Eyeglasses']].copy()\n",
    "df_attr_eyeglasses_true = df_attr_eyeglasses[df_attr_eyeglasses.Eyeglasses==1]\n",
    "\n",
    "list_eyeglasses_true = list(df_attr_eyeglasses_true.image_id.values)\n",
    "\n",
    "print('Eyeglasses:',len(list_eyeglasses_true))\n",
    "\n",
    "df_attr_eyeglasses.head(10)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "34c15f11-c49f-465e-b00c-206285033e36",
   "metadata": {},
   "source": [
    "# Load CSV"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "id": "a5262866-a945-4f59-b9e0-9f539707dd3d",
   "metadata": {},
   "outputs": [],
   "source": [
    "#files_sub,filter_type  = list_brownhairs[:200],'brownhairs'\n",
    "files_sub,filter_type  = list_eyeglasses_true[:200],'eyeglasses_true'\n",
    "iterations = len(files_sub)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "id": "997bd805-f7de-4ab3-ab39-1465a81c631f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "E:\\Cloud\\Shared\\XAI\\ICLR_Supplementary\\notebooks\\E7_CelebA\\results\\csv/csv_expIoU_face_200_14_gray_eyeglasses_true.csv True\n"
     ]
    }
   ],
   "source": [
    "csv_filename = f'{path_csv}/csv_expIoU_face_{iterations}_{len(methods)}_{background_type}_{filter_type}.csv'\n",
    "print(csv_filename,os.path.exists(csv_filename))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "id": "704a6075-e600-4109-a068-213d7ef16382",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_main= pd.read_csv(csv_filename)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "e9fffa25-dba7-45b6-8ccb-4569273b2cae",
   "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>background_type</th>\n",
       "      <th>intrested_class</th>\n",
       "      <th>intrested_class_lbl</th>\n",
       "      <th>true_intrested_class</th>\n",
       "      <th>f_S</th>\n",
       "      <th>f_0</th>\n",
       "      <th>f_S-f_0</th>\n",
       "      <th>f_H</th>\n",
       "      <th>method</th>\n",
       "      <th>aucI_pred</th>\n",
       "      <th>aucD_pred</th>\n",
       "      <th>aucI_mse</th>\n",
       "      <th>aucD_mse</th>\n",
       "      <th>threshold</th>\n",
       "      <th>best_point</th>\n",
       "      <th>max_IoU</th>\n",
       "      <th>au_IoU</th>\n",
       "      <th>time_exp</th>\n",
       "      <th>time_aucI</th>\n",
       "      <th>time_aucD</th>\n",
       "      <th>time_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>52</td>\n",
       "      <td>gray</td>\n",
       "      <td>15</td>\n",
       "      <td>Eyeglasses</td>\n",
       "      <td>True</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>BPT-100</td>\n",
       "      <td>7.056814</td>\n",
       "      <td>4.683992</td>\n",
       "      <td>36.016600</td>\n",
       "      <td>51.834962</td>\n",
       "      <td>0.002643</td>\n",
       "      <td>0.011240</td>\n",
       "      <td>0.326968</td>\n",
       "      <td>0.081289</td>\n",
       "      <td>0.741474</td>\n",
       "      <td>0.043186</td>\n",
       "      <td>0.049737</td>\n",
       "      <td>0.078201</td>\n",
       "      <td>1.115868</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>52</td>\n",
       "      <td>gray</td>\n",
       "      <td>15</td>\n",
       "      <td>Eyeglasses</td>\n",
       "      <td>True</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>BPT-500</td>\n",
       "      <td>8.294507</td>\n",
       "      <td>5.171878</td>\n",
       "      <td>25.704448</td>\n",
       "      <td>52.450771</td>\n",
       "      <td>0.001140</td>\n",
       "      <td>0.055186</td>\n",
       "      <td>0.239802</td>\n",
       "      <td>0.083196</td>\n",
       "      <td>0.906525</td>\n",
       "      <td>0.092762</td>\n",
       "      <td>0.151751</td>\n",
       "      <td>0.089421</td>\n",
       "      <td>1.443729</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>52</td>\n",
       "      <td>gray</td>\n",
       "      <td>15</td>\n",
       "      <td>Eyeglasses</td>\n",
       "      <td>True</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>BPT-1000</td>\n",
       "      <td>8.012361</td>\n",
       "      <td>5.344595</td>\n",
       "      <td>33.437372</td>\n",
       "      <td>50.476085</td>\n",
       "      <td>0.001690</td>\n",
       "      <td>0.035375</td>\n",
       "      <td>0.321765</td>\n",
       "      <td>0.086493</td>\n",
       "      <td>1.671382</td>\n",
       "      <td>0.083845</td>\n",
       "      <td>0.090067</td>\n",
       "      <td>0.072834</td>\n",
       "      <td>2.121399</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Unnamed: 0  image background_type  intrested_class intrested_class_lbl  \\\n",
       "0           0     52            gray               15          Eyeglasses   \n",
       "1           1     52            gray               15          Eyeglasses   \n",
       "2           2     52            gray               15          Eyeglasses   \n",
       "\n",
       "   true_intrested_class       f_S       f_0    f_S-f_0        f_H    method  \\\n",
       "0                  True  7.627685 -4.749711  12.377395  12.377395   BPT-100   \n",
       "1                  True  7.627685 -4.749711  12.377395  12.377395   BPT-500   \n",
       "2                  True  7.627685 -4.749711  12.377395  12.377395  BPT-1000   \n",
       "\n",
       "   aucI_pred  aucD_pred   aucI_mse   aucD_mse  threshold  best_point  \\\n",
       "0   7.056814   4.683992  36.016600  51.834962   0.002643    0.011240   \n",
       "1   8.294507   5.171878  25.704448  52.450771   0.001140    0.055186   \n",
       "2   8.012361   5.344595  33.437372  50.476085   0.001690    0.035375   \n",
       "\n",
       "    max_IoU    au_IoU  time_exp  time_aucI  time_aucD  time_IoU  time_total  \n",
       "0  0.326968  0.081289  0.741474   0.043186   0.049737  0.078201    1.115868  \n",
       "1  0.239802  0.083196  0.906525   0.092762   0.151751  0.089421    1.443729  \n",
       "2  0.321765  0.086493  1.671382   0.083845   0.090067  0.072834    2.121399  "
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_main.head(3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "5f79f9d3-ebba-433d-aedc-a6ccc865061a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total Images: 103\n",
      "Total Explained Classes: 1 - ['Eyeglasses']\n"
     ]
    }
   ],
   "source": [
    "print(f'Total Images: {len(np.unique(df_main.image))}')\n",
    "explained_classes_id = np.unique(df_main.intrested_class)\n",
    "\n",
    "explained_classes = [classes_names[x] for x in explained_classes_id]\n",
    "print(f'Total Explained Classes: {len(np.unique(df_main.intrested_class))} - {explained_classes}')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "711423d5-d93f-4177-bffa-92ad07180fb3",
   "metadata": {},
   "source": [
    "# Set Params for Plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "id": "9ce55bb9-d393-45b2-8dd0-daf79d1eb7e1",
   "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",
    "    'GradShapE':       '#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",
    "     'GradShapE':       '$\\\\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": "63fd9919-f699-40d4-b492-0dadc02d3263",
   "metadata": {},
   "source": [
    "# Intrested Classes for Facial Attributes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "id": "0975fe89-5e53-4a6a-a86b-ea01d448a02d",
   "metadata": {},
   "outputs": [],
   "source": [
    "selected_all_class = True\n",
    "\n",
    "if selected_all_class:\n",
    "    df = df_main\n",
    "else:\n",
    "    print(f'Total Images: {len(np.unique(df.image))}')\n",
    "    df = df[df.brown_hair==True]\n",
    "    print(f'Total Images: {len(np.unique(df.image))}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "id": "2d34c840-17e1-4d3d-a0c3-af1ad2b04788",
   "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>background_type</th>\n",
       "      <th>intrested_class</th>\n",
       "      <th>intrested_class_lbl</th>\n",
       "      <th>true_intrested_class</th>\n",
       "      <th>f_S</th>\n",
       "      <th>f_0</th>\n",
       "      <th>f_S-f_0</th>\n",
       "      <th>f_H</th>\n",
       "      <th>method</th>\n",
       "      <th>aucI_pred</th>\n",
       "      <th>aucD_pred</th>\n",
       "      <th>aucI_mse</th>\n",
       "      <th>aucD_mse</th>\n",
       "      <th>threshold</th>\n",
       "      <th>best_point</th>\n",
       "      <th>max_IoU</th>\n",
       "      <th>au_IoU</th>\n",
       "      <th>time_exp</th>\n",
       "      <th>time_aucI</th>\n",
       "      <th>time_aucD</th>\n",
       "      <th>time_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>52</td>\n",
       "      <td>gray</td>\n",
       "      <td>15</td>\n",
       "      <td>Eyeglasses</td>\n",
       "      <td>True</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>BPT-100</td>\n",
       "      <td>7.056814</td>\n",
       "      <td>4.683992</td>\n",
       "      <td>36.016600</td>\n",
       "      <td>51.834962</td>\n",
       "      <td>0.002643</td>\n",
       "      <td>0.011240</td>\n",
       "      <td>0.326968</td>\n",
       "      <td>0.081289</td>\n",
       "      <td>0.741474</td>\n",
       "      <td>0.043186</td>\n",
       "      <td>0.049737</td>\n",
       "      <td>0.078201</td>\n",
       "      <td>1.115868</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>52</td>\n",
       "      <td>gray</td>\n",
       "      <td>15</td>\n",
       "      <td>Eyeglasses</td>\n",
       "      <td>True</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>BPT-500</td>\n",
       "      <td>8.294507</td>\n",
       "      <td>5.171878</td>\n",
       "      <td>25.704448</td>\n",
       "      <td>52.450771</td>\n",
       "      <td>0.001140</td>\n",
       "      <td>0.055186</td>\n",
       "      <td>0.239802</td>\n",
       "      <td>0.083196</td>\n",
       "      <td>0.906525</td>\n",
       "      <td>0.092762</td>\n",
       "      <td>0.151751</td>\n",
       "      <td>0.089421</td>\n",
       "      <td>1.443729</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>52</td>\n",
       "      <td>gray</td>\n",
       "      <td>15</td>\n",
       "      <td>Eyeglasses</td>\n",
       "      <td>True</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>BPT-1000</td>\n",
       "      <td>8.012361</td>\n",
       "      <td>5.344595</td>\n",
       "      <td>33.437372</td>\n",
       "      <td>50.476085</td>\n",
       "      <td>0.001690</td>\n",
       "      <td>0.035375</td>\n",
       "      <td>0.321765</td>\n",
       "      <td>0.086493</td>\n",
       "      <td>1.671382</td>\n",
       "      <td>0.083845</td>\n",
       "      <td>0.090067</td>\n",
       "      <td>0.072834</td>\n",
       "      <td>2.121399</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>52</td>\n",
       "      <td>gray</td>\n",
       "      <td>15</td>\n",
       "      <td>Eyeglasses</td>\n",
       "      <td>True</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>AA-100</td>\n",
       "      <td>6.461674</td>\n",
       "      <td>4.568841</td>\n",
       "      <td>45.919578</td>\n",
       "      <td>61.732801</td>\n",
       "      <td>0.000827</td>\n",
       "      <td>0.069774</td>\n",
       "      <td>0.303914</td>\n",
       "      <td>0.095854</td>\n",
       "      <td>0.145401</td>\n",
       "      <td>0.044860</td>\n",
       "      <td>0.046284</td>\n",
       "      <td>0.079106</td>\n",
       "      <td>0.518921</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>52</td>\n",
       "      <td>gray</td>\n",
       "      <td>15</td>\n",
       "      <td>Eyeglasses</td>\n",
       "      <td>True</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>AA-500</td>\n",
       "      <td>7.337093</td>\n",
       "      <td>4.512549</td>\n",
       "      <td>45.087218</td>\n",
       "      <td>42.697715</td>\n",
       "      <td>0.002019</td>\n",
       "      <td>0.036053</td>\n",
       "      <td>0.314753</td>\n",
       "      <td>0.101729</td>\n",
       "      <td>0.693291</td>\n",
       "      <td>0.078539</td>\n",
       "      <td>0.070441</td>\n",
       "      <td>0.070855</td>\n",
       "      <td>1.116395</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>5</td>\n",
       "      <td>52</td>\n",
       "      <td>gray</td>\n",
       "      <td>15</td>\n",
       "      <td>Eyeglasses</td>\n",
       "      <td>True</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>AA-1000</td>\n",
       "      <td>7.649755</td>\n",
       "      <td>4.652856</td>\n",
       "      <td>43.358296</td>\n",
       "      <td>40.739853</td>\n",
       "      <td>0.002389</td>\n",
       "      <td>0.028241</td>\n",
       "      <td>0.368421</td>\n",
       "      <td>0.103690</td>\n",
       "      <td>1.397580</td>\n",
       "      <td>0.085696</td>\n",
       "      <td>0.088121</td>\n",
       "      <td>0.080976</td>\n",
       "      <td>1.855643</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>6</td>\n",
       "      <td>52</td>\n",
       "      <td>gray</td>\n",
       "      <td>15</td>\n",
       "      <td>Eyeglasses</td>\n",
       "      <td>True</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>LIME-50</td>\n",
       "      <td>7.173025</td>\n",
       "      <td>4.876708</td>\n",
       "      <td>55.157690</td>\n",
       "      <td>40.081909</td>\n",
       "      <td>0.001360</td>\n",
       "      <td>0.058793</td>\n",
       "      <td>0.437481</td>\n",
       "      <td>0.101934</td>\n",
       "      <td>5.505529</td>\n",
       "      <td>0.094062</td>\n",
       "      <td>0.096019</td>\n",
       "      <td>0.078058</td>\n",
       "      <td>5.976938</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>7</td>\n",
       "      <td>52</td>\n",
       "      <td>gray</td>\n",
       "      <td>15</td>\n",
       "      <td>Eyeglasses</td>\n",
       "      <td>True</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>12.377396</td>\n",
       "      <td>LIME-100</td>\n",
       "      <td>7.086251</td>\n",
       "      <td>4.605102</td>\n",
       "      <td>87.937709</td>\n",
       "      <td>14.211634</td>\n",
       "      <td>0.001274</td>\n",
       "      <td>0.072644</td>\n",
       "      <td>0.226101</td>\n",
       "      <td>0.083460</td>\n",
       "      <td>8.191389</td>\n",
       "      <td>0.154041</td>\n",
       "      <td>0.156501</td>\n",
       "      <td>0.079770</td>\n",
       "      <td>8.784970</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>8</td>\n",
       "      <td>52</td>\n",
       "      <td>gray</td>\n",
       "      <td>15</td>\n",
       "      <td>Eyeglasses</td>\n",
       "      <td>True</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>LIME-200</td>\n",
       "      <td>6.816196</td>\n",
       "      <td>4.737588</td>\n",
       "      <td>79.078166</td>\n",
       "      <td>22.843245</td>\n",
       "      <td>0.001924</td>\n",
       "      <td>0.047015</td>\n",
       "      <td>0.293262</td>\n",
       "      <td>0.088664</td>\n",
       "      <td>13.154233</td>\n",
       "      <td>0.215411</td>\n",
       "      <td>0.142846</td>\n",
       "      <td>0.114836</td>\n",
       "      <td>13.830596</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>9</td>\n",
       "      <td>52</td>\n",
       "      <td>gray</td>\n",
       "      <td>15</td>\n",
       "      <td>Eyeglasses</td>\n",
       "      <td>True</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>LRP</td>\n",
       "      <td>1.438688</td>\n",
       "      <td>1.438688</td>\n",
       "      <td>4.139645</td>\n",
       "      <td>4.139645</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.034439</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.036165</td>\n",
       "      <td>0.039690</td>\n",
       "      <td>0.101423</td>\n",
       "      <td>0.380548</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>10</td>\n",
       "      <td>52</td>\n",
       "      <td>gray</td>\n",
       "      <td>15</td>\n",
       "      <td>Eyeglasses</td>\n",
       "      <td>True</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>12.377396</td>\n",
       "      <td>GradCAM</td>\n",
       "      <td>7.343551</td>\n",
       "      <td>4.062324</td>\n",
       "      <td>16.944499</td>\n",
       "      <td>58.144947</td>\n",
       "      <td>0.000508</td>\n",
       "      <td>0.092335</td>\n",
       "      <td>0.203784</td>\n",
       "      <td>0.084164</td>\n",
       "      <td>0.012008</td>\n",
       "      <td>0.202404</td>\n",
       "      <td>0.209754</td>\n",
       "      <td>0.157356</td>\n",
       "      <td>0.784791</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>11</td>\n",
       "      <td>52</td>\n",
       "      <td>gray</td>\n",
       "      <td>15</td>\n",
       "      <td>Eyeglasses</td>\n",
       "      <td>True</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>12.377396</td>\n",
       "      <td>aIDG</td>\n",
       "      <td>0.878079</td>\n",
       "      <td>4.267466</td>\n",
       "      <td>11306.638049</td>\n",
       "      <td>6929.481011</td>\n",
       "      <td>0.014736</td>\n",
       "      <td>0.022700</td>\n",
       "      <td>0.156452</td>\n",
       "      <td>0.049465</td>\n",
       "      <td>0.399192</td>\n",
       "      <td>0.232997</td>\n",
       "      <td>0.248169</td>\n",
       "      <td>0.178695</td>\n",
       "      <td>1.262323</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>12</td>\n",
       "      <td>52</td>\n",
       "      <td>gray</td>\n",
       "      <td>15</td>\n",
       "      <td>Eyeglasses</td>\n",
       "      <td>True</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>12.377396</td>\n",
       "      <td>aGradExpl</td>\n",
       "      <td>2.584885</td>\n",
       "      <td>4.003149</td>\n",
       "      <td>448888.121142</td>\n",
       "      <td>414601.763416</td>\n",
       "      <td>0.042183</td>\n",
       "      <td>0.067223</td>\n",
       "      <td>0.084839</td>\n",
       "      <td>0.040571</td>\n",
       "      <td>3.964666</td>\n",
       "      <td>0.201180</td>\n",
       "      <td>0.197540</td>\n",
       "      <td>0.087032</td>\n",
       "      <td>4.653688</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>13</td>\n",
       "      <td>52</td>\n",
       "      <td>gray</td>\n",
       "      <td>15</td>\n",
       "      <td>Eyeglasses</td>\n",
       "      <td>True</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>12.377396</td>\n",
       "      <td>GradShapE</td>\n",
       "      <td>1.903195</td>\n",
       "      <td>4.042098</td>\n",
       "      <td>70194.100114</td>\n",
       "      <td>57616.460167</td>\n",
       "      <td>0.019771</td>\n",
       "      <td>0.055325</td>\n",
       "      <td>0.103626</td>\n",
       "      <td>0.042483</td>\n",
       "      <td>0.232174</td>\n",
       "      <td>0.205007</td>\n",
       "      <td>0.194781</td>\n",
       "      <td>0.188387</td>\n",
       "      <td>1.023619</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>14</td>\n",
       "      <td>132</td>\n",
       "      <td>gray</td>\n",
       "      <td>15</td>\n",
       "      <td>Eyeglasses</td>\n",
       "      <td>True</td>\n",
       "      <td>6.018809</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>10.768519</td>\n",
       "      <td>10.768519</td>\n",
       "      <td>BPT-100</td>\n",
       "      <td>4.917703</td>\n",
       "      <td>3.457613</td>\n",
       "      <td>34.930529</td>\n",
       "      <td>42.969216</td>\n",
       "      <td>0.000846</td>\n",
       "      <td>0.062719</td>\n",
       "      <td>0.917910</td>\n",
       "      <td>0.202764</td>\n",
       "      <td>0.360213</td>\n",
       "      <td>0.043342</td>\n",
       "      <td>0.051059</td>\n",
       "      <td>0.079855</td>\n",
       "      <td>0.611928</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    Unnamed: 0  image background_type  intrested_class intrested_class_lbl  \\\n",
       "0            0     52            gray               15          Eyeglasses   \n",
       "1            1     52            gray               15          Eyeglasses   \n",
       "2            2     52            gray               15          Eyeglasses   \n",
       "3            3     52            gray               15          Eyeglasses   \n",
       "4            4     52            gray               15          Eyeglasses   \n",
       "5            5     52            gray               15          Eyeglasses   \n",
       "6            6     52            gray               15          Eyeglasses   \n",
       "7            7     52            gray               15          Eyeglasses   \n",
       "8            8     52            gray               15          Eyeglasses   \n",
       "9            9     52            gray               15          Eyeglasses   \n",
       "10          10     52            gray               15          Eyeglasses   \n",
       "11          11     52            gray               15          Eyeglasses   \n",
       "12          12     52            gray               15          Eyeglasses   \n",
       "13          13     52            gray               15          Eyeglasses   \n",
       "14          14    132            gray               15          Eyeglasses   \n",
       "\n",
       "    true_intrested_class       f_S       f_0    f_S-f_0        f_H     method  \\\n",
       "0                   True  7.627685 -4.749711  12.377395  12.377395    BPT-100   \n",
       "1                   True  7.627685 -4.749711  12.377395  12.377395    BPT-500   \n",
       "2                   True  7.627685 -4.749711  12.377395  12.377395   BPT-1000   \n",
       "3                   True  7.627685 -4.749711  12.377395  12.377395     AA-100   \n",
       "4                   True  7.627685 -4.749711  12.377395  12.377395     AA-500   \n",
       "5                   True  7.627685 -4.749711  12.377395  12.377395    AA-1000   \n",
       "6                   True  7.627685 -4.749711  12.377395  12.377395    LIME-50   \n",
       "7                   True  7.627685 -4.749711  12.377395  12.377396   LIME-100   \n",
       "8                   True  7.627685 -4.749711  12.377395  12.377395   LIME-200   \n",
       "9                   True  7.627685 -4.749711  12.377395   0.000000        LRP   \n",
       "10                  True  7.627685 -4.749711  12.377395  12.377396    GradCAM   \n",
       "11                  True  7.627685 -4.749711  12.377395  12.377396       aIDG   \n",
       "12                  True  7.627685 -4.749711  12.377395  12.377396  aGradExpl   \n",
       "13                  True  7.627685 -4.749711  12.377395  12.377396  GradShapE   \n",
       "14                  True  6.018809 -4.749711  10.768519  10.768519    BPT-100   \n",
       "\n",
       "    aucI_pred  aucD_pred       aucI_mse       aucD_mse  threshold  best_point  \\\n",
       "0    7.056814   4.683992      36.016600      51.834962   0.002643    0.011240   \n",
       "1    8.294507   5.171878      25.704448      52.450771   0.001140    0.055186   \n",
       "2    8.012361   5.344595      33.437372      50.476085   0.001690    0.035375   \n",
       "3    6.461674   4.568841      45.919578      61.732801   0.000827    0.069774   \n",
       "4    7.337093   4.512549      45.087218      42.697715   0.002019    0.036053   \n",
       "5    7.649755   4.652856      43.358296      40.739853   0.002389    0.028241   \n",
       "6    7.173025   4.876708      55.157690      40.081909   0.001360    0.058793   \n",
       "7    7.086251   4.605102      87.937709      14.211634   0.001274    0.072644   \n",
       "8    6.816196   4.737588      79.078166      22.843245   0.001924    0.047015   \n",
       "9    1.438688   1.438688       4.139645       4.139645   0.000000    0.034439   \n",
       "10   7.343551   4.062324      16.944499      58.144947   0.000508    0.092335   \n",
       "11   0.878079   4.267466   11306.638049    6929.481011   0.014736    0.022700   \n",
       "12   2.584885   4.003149  448888.121142  414601.763416   0.042183    0.067223   \n",
       "13   1.903195   4.042098   70194.100114   57616.460167   0.019771    0.055325   \n",
       "14   4.917703   3.457613      34.930529      42.969216   0.000846    0.062719   \n",
       "\n",
       "     max_IoU    au_IoU   time_exp  time_aucI  time_aucD  time_IoU  time_total  \n",
       "0   0.326968  0.081289   0.741474   0.043186   0.049737  0.078201    1.115868  \n",
       "1   0.239802  0.083196   0.906525   0.092762   0.151751  0.089421    1.443729  \n",
       "2   0.321765  0.086493   1.671382   0.083845   0.090067  0.072834    2.121399  \n",
       "3   0.303914  0.095854   0.145401   0.044860   0.046284  0.079106    0.518921  \n",
       "4   0.314753  0.101729   0.693291   0.078539   0.070441  0.070855    1.116395  \n",
       "5   0.368421  0.103690   1.397580   0.085696   0.088121  0.080976    1.855643  \n",
       "6   0.437481  0.101934   5.505529   0.094062   0.096019  0.078058    5.976938  \n",
       "7   0.226101  0.083460   8.191389   0.154041   0.156501  0.079770    8.784970  \n",
       "8   0.293262  0.088664  13.154233   0.215411   0.142846  0.114836   13.830596  \n",
       "9   0.000000  0.000000   0.000000   0.036165   0.039690  0.101423    0.380548  \n",
       "10  0.203784  0.084164   0.012008   0.202404   0.209754  0.157356    0.784791  \n",
       "11  0.156452  0.049465   0.399192   0.232997   0.248169  0.178695    1.262323  \n",
       "12  0.084839  0.040571   3.964666   0.201180   0.197540  0.087032    4.653688  \n",
       "13  0.103626  0.042483   0.232174   0.205007   0.194781  0.188387    1.023619  \n",
       "14  0.917910  0.202764   0.360213   0.043342   0.051059  0.079855    0.611928  "
      ]
     },
     "execution_count": 87,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.head(15)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "52e5686f-7096-4ae0-83cb-387bdc1dcf92",
   "metadata": {},
   "source": [
    "# Draw Box Plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "id": "02e5d66b-d321-4ea0-81ee-6d7ed4733fca",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total Images: 103\n",
      "Background type:\t gray\n",
      "Total Time: \t\t 1:19:13.640883\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": [
      "file saved at : E:\\Cloud\\Shared\\XAI\\ICLR_Supplementary\\notebooks\\E7_CelebA\\results\\bg_gray\n"
     ]
    }
   ],
   "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",
    "\n",
    "auc_methods      = ['aucI_pred', 'aucD_pred', 'aucI_mse', 'aucD_mse','max_IoU','au_IoU','time_exp']\n",
    "\n",
    "print(f'Total Images: {len(np.unique(df_main.image))}')\n",
    "print('Background type:\\t',background_type)\n",
    "print('Total Time: \\t\\t',str(datetime.timedelta(seconds=np.sum(df.time_total))))\n",
    "\n",
    "fig, axes = plt.subplots(1,len(auc_methods), figsize=(11, 2.6)) # (11, 3.2)\n",
    "for j, score in enumerate(auc_methods):\n",
    "    df = df[~df[score].isna()] \n",
    "    \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, q=0.75)\n",
    "        q100 = np.quantile(values, q=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",
    "        val_arr = [[v for v in values]]\n",
    "        box_plot(axes[j], val_arr, '', i, \n",
    "                 'blue' if method.startswith('BPT') else 'black', \n",
    "                 1.5 if method.startswith('BPT') else 0.5,\n",
    "                 color)\n",
    "        # print(method,q100,score,np.max(values))\n",
    "        if score in ['aucI_pred', 'aucD_pred']:\n",
    "            axes[j].text(min(q100*1.3, 30) if log_scale else q75+0.5, i+text_yincrement, method_to_shortname[method])\n",
    "        elif score in ['aucI_mse', 'aucD_mse']:\n",
    "            axes[j].text(min(q100*1.3, 30) if log_scale else q100+60, i+text_yincrement, method_to_shortname[method])\n",
    "        else:\n",
    "            axes[j].text(min(q100*1.3, 30) if log_scale else q100+0.05, i+text_yincrement, method_to_shortname[method])\n",
    "    values = df[score]\n",
    "    #if score=='aucI_pred': min_x,max_x= -np.quantile(values,q=0.1),np.quantile(values,q=1)+(np.quantile(values,q=0)/np.quantile(values,q=1)*35)\n",
    "    #if score=='aucD_pred': min_x,max_x= 0,np.quantile(values,q=1)+(np.quantile(values,q=0)/np.quantile(values,q=1)*20)\n",
    "    \n",
    "    #if score=='aucI_mse' : min_x,max_x= -np.quantile(values,q=0.01),400\n",
    "    #if score=='aucD_mse' : min_x,max_x= -np.quantile(values,q=0.01),400\n",
    "        \n",
    "    #if score=='max_IoU'  : min_x,max_x= -np.quantile(values,q=0.01),np.quantile(values,q=1)+(np.quantile(values,q=0)/np.quantile(values,q=1)*20)\n",
    "    #if score=='au_IoU'   : min_x,max_x= -np.quantile(values,q=0.01),np.quantile(values,q=1)+(np.quantile(values,q=0)/np.quantile(values,q=1)*30)\n",
    "    # print(score,min_x, max_x)\n",
    "    # if score=='max_IoU':\n",
    "    #     print(min_x,max_x)\n",
    "\n",
    "    min_x = -0.05\n",
    "    if score=='aucI_pred': max_x = 10\n",
    "    if score=='aucD_pred': max_x = 7\n",
    "    if score=='aucI_mse': max_x = 300\n",
    "    if score=='aucD_mse': max_x = 300\n",
    "    if score=='max_IoU': max_x = 1.2\n",
    "    if score=='au_IoU': max_x = 0.45\n",
    "    \n",
    "    if score=='time_exp' :\n",
    "        min_x, max_x = 0.0011, 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",
    "        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)\n",
    "\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_boxplots}/results_table_IoU_{len(np.unique(df.image))}_{len(methods)}_{background_type}_{filter_type}.pdf', dpi=150, transparent=True, bbox_inches='tight', pad_inches=0.02)\n",
    "# plt.savefig(f'{results_boxplots}/results_table_IoU_{len(np.unique(df.image))}_{len(methods)}_{background_type}_{filter_type}.svg', dpi=150, transparent=True, bbox_inches='tight', pad_inches=0.02)\n",
    "# plt.savefig(f'{results_boxplots}/results_table_IoU_{len(np.unique(df.image))}_{len(methods)}_{background_type}_{filter_type}.png', dpi=150, transparent=True, bbox_inches='tight', pad_inches=0.02)\n",
    "plt.show()\n",
    "print('file saved at :', results_path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "19721480-37a7-43ae-8ab7-e3aa4d8519ff",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Background type:\t full\n",
      "Total Time: \t\t 5:31:43.638402\n"
     ]
    }
   ],
   "source": [
    "print('Background type:\\t',background_type)\n",
    "print('Total Time: \\t\\t',str(datetime.timedelta(seconds=np.sum(df.time_total))))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "30a6cf32-fc16-4f84-9aed-13137071b8ac",
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_save_legend = True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "e408691e-bc99-4a19-9cdc-f12965ca3ef3",
   "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",
    "                    ('GradShapE', 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": 66,
   "id": "38a807b1-3893-4cee-bae1-babba87c6f85",
   "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",
      "GradShapE\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 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'{results_boxplots}/result_table_legend_E1.svg', transparent=True, dpi=150, bbox_inches='tight', pad_inches=0.02)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "804ad619-9fa2-4b53-a8e1-189419621ef5",
   "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": 42,
   "id": "6bd1aaf7-db13-4606-9d51-b58aa09f0f58",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.stats import f_oneway"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "0d96ca87-210b-4aae-857c-e7d8c6b7ed2b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "gray\n",
      "H1 aucI_pred 2.2301247519670767e-05\n",
      "H0 aucD_pred 0.8552683670568562\n",
      "H1 aucI_mse 0.0022739431769941403\n",
      "H1 aucD_mse 0.013475582642268632\n",
      "H1 max_IoU 9.66809903218373e-12\n",
      "H1 au_IoU 6.651370645101365e-09\n",
      "H1 time_exp 2.0581021326755897e-63\n"
     ]
    }
   ],
   "source": [
    "print(background_type)\n",
    "\n",
    "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": "ea3acafb-f314-4b53-a7bb-409d499b932d",
   "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
}
