{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "37aa8f51-96fd-4a2c-9279-5e7762433963",
   "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": "3ad6cf08-a74b-4698-b1f2-c9f01ee3d42e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import os\n",
    "from tqdm.auto import tqdm "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e547f1bb-c9bd-45dc-b981-7cad7967602a",
   "metadata": {},
   "source": [
    "### PARAMS & Paths\n",
    "Below cell contains the parameters switching between the prediction model, background replacement strategy, and other few parameters"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4ce38045-48c2-40f9-8f67-be4130b26766",
   "metadata": {},
   "source": [
    "## Model Type"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "a717bf0c-9dfd-4fc3-af8a-09c69de1b403",
   "metadata": {},
   "outputs": [],
   "source": [
    "model_type                      = 'real'    # real, ideal\n",
    "# model_type                      = 'ideal'    # real, ideal"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "78922ea8-96c2-4d8c-88a2-ab9b407ab813",
   "metadata": {},
   "source": [
    "## Pre-trained Model Type"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "c55f2402-56a6-40ad-bc93-80451d4b0c15",
   "metadata": {},
   "outputs": [],
   "source": [
    "pretrained_model_type           = 'resnet'              # swin_trans_vit    resnet vgg16\n",
    "# pretrained_model_type           = 'vgg16'               # swin_trans_vit    resnet vgg16\n",
    "# pretrained_model_type           = 'swin_trans_vit'      # swin_trans_vit    resnet vgg16"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "628866d6-2be3-454c-b0f7-05c354de9983",
   "metadata": {},
   "source": [
    "## Background Types"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "67c7badb-6b52-458e-b37e-49a4de5427c9",
   "metadata": {},
   "outputs": [],
   "source": [
    "background_type  = 'gray'     # black , white , gray , noise , blurred , full\n",
    "# background_type  = 'black'     # black , white , gray , noise , blurred , full\n",
    "# background_type  = 'white'     # black , white , gray , noise , blurred , full\n",
    "# background_type  = 'noise'     # black , white , gray , noise , blurred , full\n",
    "# background_type  = 'blurred'     # black , white , gray , noise , blurred , full\n",
    "# background_type  = 'full'     # black , white , gray , noise , blurred , full"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "a3368e8d-0943-42f6-aa7c-0b333cdce5e2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "E:\\PHD\\datacloud_data\\codes\\shap_bpt\\results_review\\swin_trans_vit\\swin_trans_vit_real_gray\n"
     ]
    }
   ],
   "source": [
    "submission_version = False\n",
    "\n",
    "pretrained_model_type           = 'swin_trans_vit'      # swin_trans_vit    resnet vgg16\n",
    "codes_cloud    = os.getcwd()\n",
    "\n",
    "DS_name_annotation    = 'ImageNetS'\n",
    "DS_name_img           = 'ImageNet'\n",
    "\n",
    "path_ds_main   = f'D:\\DS\\ImageNet'\n",
    "codes_local    = path_codes if submission_version else 'E:\\\\PHD\\\\datacloud_data\\\\repos\\\\NIPS_review\\\\NIPS_Supplementary\\\\notebooks\\\\Object_Localization'\n",
    "\n",
    "path_seg_maps  = os.path.join(path_ds_main,f'{DS_name_annotation}/ILSVRC2012_img_val_S/ImageNetS50/validation-segmentation')\n",
    "path_img_val   = os.path.join(path_ds_main,f'{DS_name_img}/ILSVRC2012_img_val')\n",
    "\n",
    "filenames      = os.listdir(path_seg_maps)\n",
    "filenames,files = [],[]\n",
    "tagnames      = os.listdir(path_seg_maps)\n",
    "for tn in tagnames:\n",
    "    sub_dir = f'{path_seg_maps}//{tn}'\n",
    "    filenames.extend(os.listdir(sub_dir))\n",
    "    tempp = []\n",
    "    for fn in os.listdir(sub_dir):\n",
    "        tempp.append(f'{sub_dir}//{fn}')\n",
    "    files.extend(tempp)\n",
    "\n",
    "suffix_full = f'{model_type}_{background_type}'\n",
    "\n",
    "suffix                     = f'{pretrained_model_type}_{model_type}_{background_type}'\n",
    "\n",
    "results_main                   = os.path.join(codes_local,'results')\n",
    "results_ = 'E:\\\\PHD\\\\datacloud_data\\\\codes\\\\shap_bpt\\\\results_review'\n",
    "\n",
    "\n",
    "results_path               = os.path.join(results_,pretrained_model_type)\n",
    "results_path               = os.path.join(results_path,suffix)\n",
    "plots_path                 = os.path.join(results_path,'plots')\n",
    "plotsIoU_path              = os.path.join(results_path,'plots_IoU')\n",
    "\n",
    "path_csv          = os.path.join(results_main,     'csv')\n",
    "path_html        = results_main\n",
    "path_notebook = os.path.abspath(os.path.join(os.getcwd(), os.pardir))\n",
    "path_utils    = os.path.abspath(os.path.join(path_notebook,'utils'))\n",
    "\n",
    "\n",
    "print(results_path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3ca90a64-493b-4d66-b970-ee99b61dc9ed",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "4f12b3a9-8350-4007-9bd7-7a19231b5501",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "('E:\\\\PHD\\\\datacloud_data\\\\repos\\\\NIPS_review\\\\NIPS_Supplementary\\\\notebooks\\\\ImageNet\\\\results\\\\csv',\n",
       " 'E:\\\\PHD\\\\datacloud_data\\\\codes\\\\shap_bpt\\\\results_review\\\\swin_trans_vit\\\\swin_trans_vit_real_gray\\\\plots')"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "path_csv,plots_path"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5f677e8d-d675-4891-9cf9-4c0b5545f6a8",
   "metadata": {},
   "source": [
    "## LOAD CSV FILE GENERATED BY `notebooks/N2_Run_experiments.ipynb`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "5442b565-d7a4-431a-84c2-699be739ef9d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "('E:\\\\PHD\\\\datacloud_data\\\\repos\\\\NIPS_review\\\\NIPS_Supplementary\\\\notebooks\\\\ImageNet\\\\results\\\\csv/csv_exp_ImageNet_swin_trans_vit_real_gray.csv',\n",
       " True)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "csv_filename = f'{path_csv}/csv_exp_{DS_name_img}_{suffix}.csv'\n",
    "csv_filename,os.path.exists(csv_filename)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "1b3e15a0-c6b6-4ce9-98db-b20d16b6e416",
   "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>...</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>...</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>...</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>...</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",
       "<p>3 rows × 23 columns</p>\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  ...  aucI_pred  aucD_pred  \\\n",
       "0  0.000814  0.800596   BPT-100   0.000032  ...   0.529414   0.201966   \n",
       "1  0.000814  0.800596   BPT-500   0.000048  ...   0.541703   0.098246   \n",
       "2  0.000814  0.800596  BPT-1000   0.000063  ...   0.526013   0.087234   \n",
       "\n",
       "   aucI_mse  aucD_mse  time_load   time_exp  time_aucI  time_aucD  \\\n",
       "0  0.044665  0.027050   0.416116   2.625477   0.412637   0.396159   \n",
       "1  0.070852  0.028397   0.416116   8.328393   0.878127   1.019572   \n",
       "2  0.107358  0.023511   0.416116  15.839587   0.996273   1.235050   \n",
       "\n",
       "   time_auc_IoU  time_total  \n",
       "0      0.133291    3.983680  \n",
       "1      0.086024   10.728232  \n",
       "2      0.082583   18.569610  \n",
       "\n",
       "[3 rows x 23 columns]"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.read_csv(csv_filename)\n",
    "df.head(3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "7d4cf770-f512-42f7-b3b0-d479bf0191b3",
   "metadata": {},
   "outputs": [],
   "source": [
    "#     name,                 color,                  functor\n",
    "methods = [ \n",
    "    'BPT-100',\n",
    "    'BPT-500',   \n",
    "    'BPT-1000',  \n",
    "    ]\n",
    "methods_pe = [ # if single background\n",
    "    'Partition-100', \n",
    "    'Partition-500',  \n",
    "    'Partition-1000',  \n",
    "    ]\n",
    "methods_aa = [ # if multiple backgrounds\n",
    "    'AA-100',   \n",
    "    'AA-500',\n",
    "    'AA-1000', \n",
    "]\n",
    "methods_aa_huge = [\n",
    "    'AA-5000', \n",
    "    'AA-10000',\n",
    "]\n",
    "methods_lime = [\n",
    "    'LIME-50',\n",
    "    'LIME-100',\n",
    "    'LIME-200',  \n",
    "    ]\n",
    "methods_cam = [\n",
    "    'GradCAM',  \n",
    "    'aIDG',       \n",
    "    'aGradExpl', \n",
    "    ]\n",
    "methods += methods_pe if background_type=='gray' and model_type!='ideal' else methods_aa\n",
    "if model_type == 'ideal':\n",
    "    methods += methods_aa_huge\n",
    "\n",
    "methods += methods_lime\n",
    "if model_type != 'ideal':\n",
    "    methods += methods_cam"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "85e49d3b-4fd7-49b0-8b82-2c91c5dd04de",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['BPT-100',\n",
       " 'BPT-500',\n",
       " 'BPT-1000',\n",
       " 'Partition-100',\n",
       " 'Partition-500',\n",
       " 'Partition-1000',\n",
       " 'LIME-50',\n",
       " 'LIME-100',\n",
       " 'LIME-200',\n",
       " 'GradCAM',\n",
       " 'aIDG',\n",
       " 'aGradExpl']"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "methods"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "5a15e67e-89bb-4589-95b6-fd05fefd3e8b",
   "metadata": {},
   "outputs": [],
   "source": [
    "auc_methods      = ['aucI_pred', 'aucD_pred', 'aucI_mse', 'aucD_mse', 'max_IoU', 'au_IoU', 'time_exp']"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2b7e7cb3-14bc-4207-9706-ec144a0a432f",
   "metadata": {},
   "source": [
    "## GENERATE/LOAD CSS AND JS FILE"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "ae66b368-2ec4-4406-9b7b-1404a4c6e62b",
   "metadata": {},
   "outputs": [],
   "source": [
    "GENERATE_FILE = True\n",
    "if GENERATE_FILE:\n",
    "    with open(f'{path_utils}/html_stylesheet.txt', 'w') as f:\n",
    "        f.write(\"\"\"\n",
    "                <style>\n",
    "                    table.space {margin-top: 10px;padding-top: 10px;width: 100%;} \n",
    "                    table{border: 1px solid black;},\n",
    "                    th{font-size: 2em},tr{font-size: 2em},\n",
    "                    .collapsible-title {\n",
    "                      font-size: 18px;\n",
    "                      font-weight: bold;\n",
    "                      color: #333;\n",
    "                    }\n",
    "                    .collapsible-text {\n",
    "                      font-size: 16px;\n",
    "                      color: #666;\n",
    "                      line-height: 1.5;\n",
    "                    }\n",
    "                    .collapsible-content {\n",
    "                      font-size: 20px;}\n",
    "                    table {\n",
    "                      text-align: left;\n",
    "                      position: relative;\n",
    "                      border-collapse: separate; \n",
    "                    border-top: 2px solid;\n",
    "                    border-bottom: 2px solid;\n",
    "                    border-right: 2px solid;\n",
    "                    }\n",
    "                    td {\n",
    "                    padding: 0.1rem;\n",
    "                    }\n",
    "                    th {\n",
    "                        border: 2px solid black;\n",
    "                        padding: 0.1rem;\n",
    "                    }\n",
    "                    tr.red th {\n",
    "                      background: red;\n",
    "                      color: white;\n",
    "                    }\n",
    "                    tr.green th {\n",
    "                      background: green;\n",
    "                      color: white;\n",
    "                    }\n",
    "                    tr.purple th {\n",
    "                      background: purple;\n",
    "                      color: white;\n",
    "                    }\n",
    "                    th {\n",
    "                    border-radius: 3px;\n",
    "                    background-color: rgba(255, 255, 255, 0.8) !important;\n",
    "                    text-align:center;\n",
    "                    background: white;\n",
    "                    position: sticky;\n",
    "                    top: 0;\n",
    "                    box-shadow: 0 2px 2px -1px rgba(0, 0, 0, 0.4);\n",
    "                    }\n",
    "                    tr:hover {background-color: rgba(234, 242, 215,0.8);}\n",
    "                    .switch {\n",
    "                    position: relative;\n",
    "                    display: inline-block;\n",
    "                    width: 60px;\n",
    "                    height: 34px;\n",
    "                    }\n",
    "                    .switch input {\n",
    "                    opacity: 0;\n",
    "                    width: 0;\n",
    "                    height: 0;\n",
    "                    }\n",
    "                    .slider {\n",
    "                    position: absolute;\n",
    "                    cursor: pointer;\n",
    "                    top: 0;\n",
    "                    left: 0;\n",
    "                    right: 0;\n",
    "                    bottom: 0;\n",
    "                    background-color: #808080;\n",
    "                    -webkit-transition: .4s;\n",
    "                    transition: .4s;\n",
    "                    }\n",
    "                    .slider:before {\n",
    "                    position: absolute;\n",
    "                    content: \"\";\n",
    "                    height: 26px;\n",
    "                    width: 26px;\n",
    "                    left: 4px;\n",
    "                    bottom: 4px;\n",
    "                    background-color: white;\n",
    "                    -webkit-transition: .4s;\n",
    "                    transition: .4s;\n",
    "                    }\n",
    "                    input:checked + .slider {\n",
    "                    background-color: #2196F3;\n",
    "                    }\n",
    "                    input:focus + .slider {\n",
    "                    box-shadow: 0 0 1px #2196F3;\n",
    "                    }\n",
    "                    input:checked + .slider:before {\n",
    "                    -webkit-transform: translateX(26px);\n",
    "                    -ms-transform: translateX(26px);\n",
    "                    transform: translateX(26px);\n",
    "                    }\n",
    "                    .slider.round {\n",
    "                    border-radius: 34px;\n",
    "                    }\n",
    "                    .slider.round:before {\n",
    "                    border-radius: 50%;\n",
    "                    }\n",
    "                    #topBtn {\n",
    "                        position: fixed;\n",
    "                        bottom: 5px;\n",
    "                        float: right;\n",
    "                        right: 18.5%;\n",
    "                        left: 0.25%;\n",
    "                        max-width: 70px;\n",
    "                        width: 100%;\n",
    "                        font-size: 18px;\n",
    "                        border-color: rgba(85, 85, 85, 0.8);\n",
    "                        background-color: rgba(27, 163, 156,0.9);\n",
    "                        padding: 2px;\n",
    "                        border-radius: 10px;\n",
    "                        }\n",
    "                    #topBtn:hover {\n",
    "                        background-color: #7dbbf1;\n",
    "                    }\n",
    "                    table {border: none;}\n",
    "                    * {\n",
    "                    box-sizing: border-box;\n",
    "                    }\n",
    "                    .box {\n",
    "                    float: left;\n",
    "                    width: 100%;\n",
    "                    padding: 10px;\n",
    "                    }\n",
    "                    .clearfix::after {\n",
    "                    content: \"\";\n",
    "                    clear: both;\n",
    "                    display: table;\n",
    "                    }\n",
    "                    table {\n",
    "                    height: 100%;\n",
    "                    border-collapse: seperate;\n",
    "                    width: 100%;\n",
    "                    margin: 10px;\n",
    "                    font-size: 0.8em;\n",
    "                    }\n",
    "                    thead {\n",
    "                    border-radius: 3px;\n",
    "                    position: sticky;\n",
    "                    top: 0;\n",
    "                    background: #eee;\n",
    "                    }\n",
    "                    header h1 {\n",
    "                        font-size: 70px;\n",
    "                        font-weight: 600;\n",
    "                        background-image: linear-gradient(to left, #553c9a, #b393d3);\n",
    "                        color: transparent;\n",
    "                        background-clip: text;\n",
    "                        -webkit-background-clip: text;\n",
    "                        text-shadow: 0px 4px 10px rgba(179, 147, 211, 0.8)\n",
    "                    }\n",
    "                    h1 {\n",
    "                      font-size: 30px;\n",
    "                      line-height: 1.8;\n",
    "                      text-transform: uppercase;\n",
    "                      font-family: \"Montserrat\", sans-serif;\n",
    "                    }\n",
    "                .hero {\n",
    "                    position: relative;\n",
    "                    background: #333 url(http://srdjanpajdic.com/slike/2.jpg) no-repeat center center fixed;\n",
    "                    -webkit-background-size: cover;\n",
    "                    -moz-background-size: cover;\n",
    "                    background-size: cover;\n",
    "                    text-align: center;\n",
    "                    color: #fff;\n",
    "                    padding-top: 20px;\n",
    "                    min-height: 300px;\n",
    "                    letter-spacing: 2px;\n",
    "                    font-family: \"Montserrat\", sans-serif;\n",
    "                    h1 {\n",
    "                    font-size: 50px;\n",
    "                    line-height: 1.3;\n",
    "                    span {\n",
    "                    font-size: 25px;\n",
    "                    color: $color2;\n",
    "                    border-bottom: 2px solid $color2;\n",
    "                    padding-bottom: 8px;\n",
    "                    line-height: 3;\n",
    "                    }\n",
    "                }\n",
    "                .main_container{\n",
    "                   width:99%;\n",
    "                }\n",
    "                html, body {\n",
    "                height:100%;\n",
    "                width:99%;\n",
    "                margin:0;\n",
    "                padding:0;\n",
    "                }\n",
    "                    </style>\n",
    "                    \"\"\")\n",
    "    with open(f'{path_utils}/html_head.txt', 'w') as f:\n",
    "        f.write(\"\"\"\n",
    "            <head>\n",
    "                <link href=\"https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/css/bootstrap.min.css\"\n",
    "                    rel=\"stylesheet\" integrity=\"sha384-EVSTQN3/azprG1Anm3QDgpJLIm9Nao0Yz1ztcQTwFspd3yD65VohhpuuCOmLASjC\" \n",
    "                    crossorigin=\"anonymous\">\n",
    "                <script src=\"https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/js/bootstrap.bundle.min.js\"\n",
    "                    integrity=\"sha384-MrcW6ZMFYlzcLA8Nl+NtUVF0sA7MsXsP1UyJoMp4YLEuNSfAP+JcXn/tWtIaxVXM\" crossorigin=\"anonymous\">\n",
    "                </script>\n",
    "            </head>\n",
    "            \"\"\")\n",
    "    with open(f'{path_utils}/html_footer_scripts_full.txt', 'w') as f:\n",
    "        f.write(\"\"\"\n",
    "            <script>const toggleAllButton = document.getElementById('toggleAllButton');\n",
    "                const collapsibleContents = document.querySelectorAll('.collapsible-content');\n",
    "                toggleAllButton.addEventListener('click', () => {\n",
    "                  collapsibleContents.forEach(content => {\n",
    "                    if (content.style.display === 'none') {\n",
    "                      content.style.display = 'block';\n",
    "                      content.previousElementSibling.querySelector('.toggle-icon').textContent = '';\n",
    "                    } else {\n",
    "                      content.style.display = 'none';\n",
    "                      content.previousElementSibling.querySelector('.toggle-icon').textContent = '';\n",
    "                    }\n",
    "                  });\n",
    "                });\n",
    "            </script>\n",
    "            \"\"\")\n",
    "    with open(f'{path_utils}/html_footer_scripts_IoU.txt', 'w') as f:\n",
    "        f.write(\"\"\"<script>\n",
    "        const toggleAllButton = document.getElementById('toggleAllButton');\n",
    "            const collapsibleContents = document.querySelectorAll('.collapsible-content');\n",
    "            toggleAllButton.addEventListener('click', () => {\n",
    "              collapsibleContents.forEach(content => {\n",
    "              document.getElementById('data_rows').style.border = 'none';\n",
    "                if (content.style.display === 'none') {\n",
    "                  content.style.display = 'block';\n",
    "                  content.previousElementSibling.querySelector('.toggle-icon').textContent = '';\n",
    "                } else {\n",
    "                  content.style.display = 'none';\n",
    "                  content.previousElementSibling.querySelector('.toggle-icon').textContent = '';\n",
    "                }\n",
    "              });\n",
    "            });\n",
    "            </script>\n",
    "           \"\"\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3221f536-e059-4986-a270-c40e13eacc06",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "16de4188-fb99-443b-be44-4cf1782973e1",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(f\"{path_utils}/html_stylesheet.txt\", \"r+\") as f:\n",
    "    html_stylesheet = f.read()\n",
    "with open(f\"{path_utils}/html_footer_scripts_IoU.txt\", \"r+\") as f:\n",
    "    html_footer_scripts_IoU = f.read()\n",
    "with open(f\"{path_utils}/html_footer_scripts_full.txt\", \"r+\") as f:\n",
    "    html_footer_scripts_full = f.read()\n",
    "with open(f\"{path_utils}/html_head.txt\", \"r+\") as f:\n",
    "    html_head = f.read()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4f2ef390-2182-498a-a670-f6ba16a84380",
   "metadata": {},
   "source": [
    "## HTML FULL"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "a638a0bc-e4e0-4be8-8f06-693ee6dde2f6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total Images: 621\t Total Methods 12\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "37249ba27f584ea9b84155429f3d7b89",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Data Written in File :\tE:\\PHD\\datacloud_data\\repos\\NIPS_review\\NIPS_Supplementary\\notebooks\\ImageNet\\results/HTML_swin_trans_vit_gray.html\n"
     ]
    }
   ],
   "source": [
    "sel_thresh  = 1.01\n",
    "version = 'full' if sel_thresh>1 else 'low'\n",
    "total_images = len(np.unique(df[df.f_S<sel_thresh].image))\n",
    "nf_images = []\n",
    "print(f'Total Images: {total_images}\\t Total Methods {len(methods)}')\n",
    "html_f_name = f'{path_html}/HTML_{pretrained_model_type}_{background_type}.html'\n",
    "\n",
    "if os.path.exists(html_f_name):\n",
    "    os.remove(html_f_name)\n",
    "with open(html_f_name, 'a') as f:\n",
    "    f.write('<html>')\n",
    "    f.write(html_head)\n",
    "    f.write('''\n",
    "        <body>\n",
    "        <div class='main_container'>\n",
    "            <div class=\"hero\">\n",
    "                <h1><span>Webpage containing all IoU results [Visual(heatmaps) and Numerical] for </span>\n",
    "                    <br>Shapley image explanations<br>\n",
    "                    with data-aware Binary Partition Trees.\n",
    "                </h1>\n",
    "                ''')\n",
    "    f.write(f'<h3>Params: [model: {model_type}, background_type: {background_type}] - No of Images:{total_images}</h3>')\n",
    "    f.write('''\n",
    "                <div class=\"mouse\">\n",
    "                    <span></span>\n",
    "                </div>\n",
    "            </div>\n",
    "            ''')\n",
    "    f.write(html_stylesheet)\n",
    "with open(html_f_name, 'a') as f:\n",
    "        f.write('''\n",
    "                <fieldset>\n",
    "                    <legend>Toggle Explanation Details:</legend>\n",
    "                    <label class=\"switch\">\n",
    "                          <input type=\"checkbox\" id=\"toggleAllButton\" checked>\n",
    "                          <span class=\"slider round\"></span>\n",
    "                    </label>\n",
    "                </fieldset>\n",
    "                <br><br>\n",
    "                <table id=\"table-1\"><tr>\n",
    "                    <th align= \"center\"> Input Image</th> \n",
    "                    <th align= \"center\"> GrTruth</th> \n",
    "                ''')\n",
    "for meth in methods:\n",
    "    if meth in ['AA-100','AA-500']:\n",
    "        # print(meth)\n",
    "        meth = f'&nbsp{meth}&nbsp'\n",
    "    meth= '|GrExpl|' if meth=='GradExpla' else meth\n",
    "    meth= '  GrCAM  ' if meth=='GradCAM' else meth\n",
    "    with open(html_f_name, 'a') as f:\n",
    "        f.write(f'<th align= \"center\"> {meth}</th>')\n",
    "        \n",
    "for fff_id,fff in tqdm(enumerate(files)):\n",
    "    file_n = fff.split('.')[0].split('//')[-1]\n",
    "    if file_n not in df.image.values:\n",
    "        nf_images.append(file_n)\n",
    "        continue\n",
    "    # img_path = f'plots//{file_n}_{background_type}_heatmap.png'\n",
    "    img_path = f'{plots_path}//{file_n}_{background_type}_heatmap.png'\n",
    "    \n",
    "    PP = df[df.image==file_n].f_S.iloc[0]\n",
    "    # if version=='low':\n",
    "    #     if PP>0.5:\n",
    "    #         continue\n",
    "    PL = df[df.image==file_n].pred_lbl.iloc[0]\n",
    "    with open(html_f_name, 'a') as f:\n",
    "        f.write(f'<tr><td colspan=\"{len(methods)+2}\">\\\n",
    "                <img src={img_path} width=\"99.9%\"> <br>\\\n",
    "                    <p>{file_n}  -  {PL}  -  {PP:0.5}  -  \\\n",
    "                    </p>\\\n",
    "                </td>\\\n",
    "                ')\n",
    "    with open(html_f_name, 'a') as f:\n",
    "            f.write(f'\\\n",
    "                <tr><td\">\\\n",
    "                  ')\n",
    "    for sm in auc_methods:\n",
    "        df1 = df[(df.image==file_n)].eval(f'{sm}')\n",
    "        with open(html_f_name, 'a') as f:\n",
    "            f.write(f'\\\n",
    "                    <tr><td>\\\n",
    "                    <div class=\"collapsible-container\">\\\n",
    "                      <div class=\"collapsible-header\">\\\n",
    "                        <span class=\"toggle-icon\"></span>\\\n",
    "                      </div>\\\n",
    "                      <div class=\"collapsible-content\">\\\n",
    "                        <p>\\\n",
    "                        <b>{sm}</b>\\\n",
    "                        </div>\\\n",
    "                    </div>\\\n",
    "                    </td>\\\n",
    "                    ')\n",
    "        for meth_id,meth in enumerate(methods):\n",
    "            df2 = df1.iloc[meth_id]\n",
    "            with open(html_f_name, 'a') as f:\n",
    "                f.write(f'\\\n",
    "                        <td> \\\n",
    "                        <div class=\"collapsible-container\">\\\n",
    "                          <div class=\"collapsible-header\">\\\n",
    "                            <span class=\"toggle-icon\"></span>\\\n",
    "                          </div>\\\n",
    "                          <div class=\"collapsible-content\">\\\n",
    "                            <p>\\\n",
    "                            {df2:0.5} </p>\\\n",
    "                            </div>\\\n",
    "                        </div>\\\n",
    "                        </td>\\\n",
    "                        ')\n",
    "        with open(html_f_name, 'a') as f:\n",
    "            f.write(f'\\\n",
    "            </tr>\\\n",
    "            ')\n",
    "    with open(html_f_name, 'a') as f:\n",
    "        f.write('''\n",
    "                    </div>\n",
    "                </div>\n",
    "                </td></tr>\n",
    "                ''')\n",
    "with open(html_f_name, 'a') as f:\n",
    "    f.write('''\n",
    "            </tr>\n",
    "            </table>\n",
    "            <button id=\"topBtn\"><a href=\"#top\" style=\"color: white\">Top</a></button>\n",
    "            ''')\n",
    "    f.write('<script src=\"https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js\"></script>')\n",
    "    f.write(html_footer_scripts_full)\n",
    "    f.write('''  \n",
    "                </body>\n",
    "            </html>\n",
    "            ''')\n",
    "print(f'Data Written in File :\\t{html_f_name}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 128,
   "id": "763da672-a925-427f-a9fe-bceeba4ddd2b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total images:\t\t752                      \n",
      "Matched images:\t\t574\n",
      "Unmatched images\t178\n",
      "Data Written in File :\tE:\\PHD\\datacloud_data\\codes\\shap_bpt\\results\\ImageNetS\\ideal_gray/imgs_ImageNetS_full.html\n"
     ]
    }
   ],
   "source": [
    "print(f'Total images:\\t\\t{len(files):<25}\\nMatched images:\\t\\t{total_images}\\nUnmatched images\\t{len(nf_images)}')\n",
    "print(f'Data Written in File :\\t{html_f_name}')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d778b315-6e5d-41f4-a892-1356e7ee2c6b",
   "metadata": {},
   "source": [
    "## IoU HTML FILE"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "e57c43d8-f86e-4d38-bf9b-883428310293",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total Images: 621\t Total Methods 12\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d3de32a7e50c488b8c8572167a2f5365",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/12 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "23c1a4118cb3491eabfa90dde5d4ae5d",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Data Written in File :\tfile://E:\\PHD\\datacloud_data\\repos\\NIPS_review\\NIPS_Supplementary\\notebooks\\ImageNet\\results\\HTML_IoU_swin_trans_vit_gray.html\n"
     ]
    }
   ],
   "source": [
    "sel_thresh  = 1.01\n",
    "version = 'full' if sel_thresh>1 else 'low'\n",
    "total_images = len(np.unique(df[df.f_S<sel_thresh].image))\n",
    "auc_methods_sel = auc_methods[-3:-1]\n",
    "\n",
    "print(f'Total Images: {total_images}\\t Total Methods {len(methods)}')\n",
    "html_f_name = f'{path_html}/HTML_IoU_{pretrained_model_type}_{background_type}.html'\n",
    "if os.path.exists(html_f_name):\n",
    "    os.remove(html_f_name)\n",
    "with open(html_f_name, 'a') as f:\n",
    "    f.write('\\\n",
    "    <html>\\\n",
    "    ')\n",
    "    f.write(html_head)\n",
    "    f.write('''\n",
    "        <body>\n",
    "        <div class='main_container'>\n",
    "            <div class=\"hero\">\n",
    "                <h1><span>Webpage containing all IoU results [Visual(IoU) and Numerical] for </span>\n",
    "                    <br>Shapley image explanations<br>\n",
    "                    with data-aware Binary Partition Trees.\n",
    "                </h1>\n",
    "                ''')\n",
    "    f.write(f'<h3>Params: [model: {model_type}, background_type: {background_type}] - No of Images:{total_images}</h3>')\n",
    "    f.write('''\n",
    "                <div class=\"mouse\">\n",
    "                    <span></span>\n",
    "                </div>\n",
    "            </div>\n",
    "            ''')\n",
    "    f.write(html_stylesheet)\n",
    "# (0.0, 0.0, 0.75) # True Positives\n",
    "# (1.0, 0.6, 0.2) # False Positives\n",
    "# (1.0, 0.4, 1.0) # False Negatives\n",
    "with open(html_f_name, 'a') as f:\n",
    "        f.write('''\n",
    "        <fieldset>\n",
    "            <legend>Toggle Explanation Details:</legend>\n",
    "            <label class=\"switch\">\n",
    "                  <input type=\"checkbox\" id=\"toggleAllButton\" checked>\n",
    "                  <span class=\"slider round\"></span>\n",
    "            </label>\n",
    "        </fieldset>\n",
    "        <br>\n",
    "        ''')\n",
    "        f.write(f'\\\n",
    "        <table id=\"table-1\"><tr>\\\n",
    "            <thead>\\\n",
    "            <tr>\\\n",
    "            <div class=\"clearfix\">\\\n",
    "                <th colspan=\"{len(methods)+2}\">\\\n",
    "                    <div class=\"box\">\\\n",
    "                        LEGEND\\\n",
    "                    </div>\\\n",
    "                </th>\\\n",
    "            </tr>\\\n",
    "            <tr>\\\n",
    "                <th colspan=4>\\\n",
    "                    <div class=\"box\" style=\"background-color:#0000bf; color: #ffffff;\">\\\n",
    "                        True Positive\\\n",
    "                    </div>\\\n",
    "                </th>\\\n",
    "                <th colspan=5>\\\n",
    "                    <div class=\"box\" style=\"background-color:#ff9933\">\\\n",
    "                        False Negative\\\n",
    "                    </div>\\\n",
    "                </th>\\\n",
    "                <th colspan=5>\\\n",
    "                    <div class=\"box\" style=\"background-color:#ff66ff\">\\\n",
    "                        False Positive\\\n",
    "                    </div>\\\n",
    "                </th>\\\n",
    "                </th>\\\n",
    "            </div>\\\n",
    "        </tr>\\\n",
    "        <tr>\\\n",
    "        <th colspan=\"{len(methods)+2}\">\\\n",
    "            <div class=\"box\">\\\n",
    "                Methods\\\n",
    "            </div>\\\n",
    "        </th>\\\n",
    "        </tr>\\\n",
    "            <tr>\\\n",
    "            <th align= \"center\"> Input Image</th> \\\n",
    "            <th align= \"center\"> GrTruth</th> \\\n",
    "                ')\n",
    "for meth in tqdm(methods):\n",
    "    if meth in ['AA-100','AA-500']:\n",
    "        meth = f'&nbsp{meth}&nbsp'\n",
    "    meth= '|GrExpl|' if meth=='GradExpla' else meth\n",
    "    meth= '  GrCAM  ' if meth=='GradCAM' else meth\n",
    "    with open(html_f_name, 'a') as f:\n",
    "        f.write(f'<th align= \"center\"> {meth}</th>\\\n",
    "        ')\n",
    "\n",
    "with open(html_f_name, 'a') as f:\n",
    "    f.write('\\\n",
    "    </thead>\\\n",
    "    ')\n",
    "     \n",
    "for fff_id,fff in tqdm(enumerate(files)):\n",
    "    file_n = fff.split('.')[0].split('//')[-1]\n",
    "    if file_n not in df.image.values:\n",
    "        # print(f'image not found - {file_n}')\n",
    "        continue\n",
    "\n",
    "    # img_path = f'plots_IoU//{file_n}_{background_type}.png'\n",
    "    img_path = f'{plotsIoU_path}//{file_n}_{background_type}_IoU.png'\n",
    "    PP = df[df.image==file_n].f_S.iloc[0]\n",
    "    # if version=='low':\n",
    "    #     if PP>0.5:\n",
    "    #         continue\n",
    "    PL = df[df.image==file_n].pred_lbl.iloc[0]\n",
    "    \n",
    "    with open(html_f_name, 'a') as f:\n",
    "        f.write(f'<tr><td colspan=\"{len(methods)+2}\">\\\n",
    "                <img src={img_path} width=\"99.9%\"> <br>\\\n",
    "                    <p>{file_n}  -  {PL}  -  {PP:0.5}  -  \\\n",
    "                    </p>\\\n",
    "                </td>\\\n",
    "                ')\n",
    "    with open(html_f_name, 'a') as f:\n",
    "            f.write(f'\\\n",
    "                <tr><td\">\\\n",
    "                  ')\n",
    "    for sm in auc_methods_sel:\n",
    "        df1 = df[(df.image==file_n)].eval(f'{sm}')\n",
    "        with open(html_f_name, 'a') as f:\n",
    "            f.write(f'\\\n",
    "                    <tr><td>\\\n",
    "                    <div class=\"collapsible-container\">\\\n",
    "                      <div class=\"collapsible-header\">\\\n",
    "                        <span class=\"toggle-icon\"></span>\\\n",
    "                      </div>\\\n",
    "                      <div class=\"collapsible-content\">\\\n",
    "                        <p>\\\n",
    "                        <b>{sm}</b>\\\n",
    "                        </div>\\\n",
    "                    </div>\\\n",
    "                    </td>\\\n",
    "                    ')\n",
    "        for meth_id,meth in enumerate(methods):\n",
    "            df2 = df1.iloc[meth_id]\n",
    "            with open(html_f_name, 'a') as f:\n",
    "                f.write(f'\\\n",
    "                        <td id=\"data_rows\"> \\\n",
    "                        <div class=\"collapsible-container\">\\\n",
    "                          <div class=\"collapsible-header\">\\\n",
    "                            <span class=\"toggle-icon\"></span>\\\n",
    "                          </div>\\\n",
    "                          <div class=\"collapsible-content\">\\\n",
    "                            <p>\\\n",
    "                            {df2:0.5} </p>\\\n",
    "                            </div>\\\n",
    "                        </div>\\\n",
    "                        </td>\\\n",
    "                        ')\n",
    "        with open(html_f_name, 'a') as f:\n",
    "            f.write(f'\\\n",
    "            </tr>\\\n",
    "            ')\n",
    "    with open(html_f_name, 'a') as f:\n",
    "        f.write('\\\n",
    "                    </div>\\\n",
    "                </div>\\\n",
    "                </td></tr>\\\n",
    "                ')\n",
    "with open(html_f_name, 'a') as f:\n",
    "    f.write('''\n",
    "                </tr>\n",
    "            </table>\n",
    "            <button id=\"topBtn\"><a href=\"#top\" style=\"color: white\">Top</a></button>\n",
    "            ''')\n",
    "    f.write('<script src=\"https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js\"></script>')\n",
    "    f.write(html_footer_scripts_IoU)\n",
    "    f.write('''\n",
    "                    </div>\n",
    "                </body>\n",
    "            </html>\n",
    "            ''')\n",
    "print(f'Data Written in File :\\tfile://{os.path.abspath(html_f_name)}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 130,
   "id": "6ddea1ce-0142-4e15-ba06-23cca1800441",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total images:\t\t752                      \n",
      "Matched images:\t\t574\n",
      "Unmatched images\t178\n",
      "Data Written in File :\tE:\\PHD\\datacloud_data\\codes\\shap_bpt\\results\\ImageNetS\\ideal_gray/imgs_IoU_ImageNetS_full.html\n"
     ]
    }
   ],
   "source": [
    "print(f'Total images:\\t\\t{len(files):<25}\\nMatched images:\\t\\t{total_images}\\nUnmatched images\\t{len(nf_images)}')\n",
    "print(f'Data Written in File :\\t{html_f_name}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2637e6b8-44d9-4315-b58d-aa26950209ae",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a6c1a674-c9b2-4f0d-ba77-005597958910",
   "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
}
