{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "e4020007-20b5-49bf-9caf-fd9d87dc4167",
   "metadata": {},
   "source": [
    "# Import Libraries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "6db687c5-a4cd-45fc-90af-adf9bb79a3f8",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import os,re\n",
    "from tqdm.auto import tqdm \n",
    "import math\n",
    "from functools import partial"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "a3d6f814-716a-4c44-9bdc-d42b8440a972",
   "metadata": {},
   "outputs": [],
   "source": [
    "DS_name    = 'CelebA'\n",
    "model_type = 'pretrained'"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7d5c0608-f406-44a1-8fbf-2bbffaeaff9e",
   "metadata": {},
   "source": [
    "# Path Setting\n",
    "**NOTE** Comment uncomment LINE No 4,5 to change dataset path"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "4eea4e64-4e0e-4900-a219-778796963ae7",
   "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": "markdown",
   "id": "74224f54-2cd9-466a-8a8f-778c9b742e35",
   "metadata": {},
   "source": [
    "# Class Labels to be eXplained"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "4b012b8f-a6d4-46a2-b380-2605016714c0",
   "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": "a667e96c-1ce0-4fa4-990b-57dc660c8942",
   "metadata": {},
   "source": [
    "## Brown Hairs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "7ac148f1-bf32-40ba-8490-170472dab36a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Brown: 19528 ~ Brown: 19528\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>Brown_Hair</th>\n",
       "      <th>Black_Hair</th>\n",
       "      <th>Blond_Hair</th>\n",
       "      <th>Gray_Hair</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.jpg</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1.jpg</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2.jpg</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3.jpg</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4.jpg</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>5.jpg</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>7.jpg</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>8.jpg</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>9.jpg</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>11.jpg</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  image_id  Brown_Hair  Black_Hair  Blond_Hair  Gray_Hair\n",
       "0    0.jpg           1           0           0          0\n",
       "1    1.jpg           0           0           1          0\n",
       "2    2.jpg           1           0           0          0\n",
       "3    3.jpg           0           1           0          0\n",
       "4    4.jpg           1           0           0          0\n",
       "5    5.jpg           0           0           1          0\n",
       "6    7.jpg           1           0           0          0\n",
       "7    8.jpg           1           0           0          0\n",
       "8    9.jpg           1           0           0          0\n",
       "9   11.jpg           0           0           1          0"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "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))\n",
    "df_attr_brownhairs.head(10)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4d0ea8c5-101f-45e1-b66f-ac3e3938e27c",
   "metadata": {},
   "source": [
    "## Eyeglasses"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "f50ac08c-1348-4bf4-bb92-5a10ed25d0b0",
   "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": 6,
     "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": "20926ab7-5ed4-4be7-a5f2-8a375bd01833",
   "metadata": {},
   "source": [
    "# Setting for CSV File Name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "54937b7f-1cd7-46f7-9b72-50fbabad8b8c",
   "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": 8,
   "id": "1b95786b-db4a-4692-805d-46588582330a",
   "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        = 'blurred'     # black , white , gray , noise , blurred , full"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "a0164c2c-e0a9-4c4c-8a70-24e4398874f5",
   "metadata": {},
   "outputs": [],
   "source": [
    "results_path      = os.path.join(results_path_main,('bg_'+background_type))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "aea694ad-e80f-4a46-bfbb-643b40cfb85e",
   "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": 11,
   "id": "07eb5957-5582-45a4-b112-0afe3f897996",
   "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": "dfca24de-4f7d-4596-8086-f6b352c949ce",
   "metadata": {},
   "source": [
    "## Load CSV File"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "40a40bd9-3042-4f1c-8a3d-ef64d83000b0",
   "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": 13,
   "id": "71d986aa-987b-4799-9951-5bce7aca9ad2",
   "metadata": {},
   "outputs": [],
   "source": [
    "df= pd.read_csv(csv_filename)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "0d9010a7-fbca-4b5e-91f3-92a66a879439",
   "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_S1</th>\n",
       "      <th>...</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>False</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>...</td>\n",
       "      <td>51.834962</td>\n",
       "      <td>0.002643</td>\n",
       "      <td>0.011240</td>\n",
       "      <td>0.251335</td>\n",
       "      <td>0.081289</td>\n",
       "      <td>0.561749</td>\n",
       "      <td>0.041955</td>\n",
       "      <td>0.069489</td>\n",
       "      <td>0.337408</td>\n",
       "      <td>1.176433</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>False</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>...</td>\n",
       "      <td>52.450771</td>\n",
       "      <td>0.001140</td>\n",
       "      <td>0.055186</td>\n",
       "      <td>0.207044</td>\n",
       "      <td>0.083196</td>\n",
       "      <td>1.067267</td>\n",
       "      <td>0.088621</td>\n",
       "      <td>0.091723</td>\n",
       "      <td>0.334412</td>\n",
       "      <td>1.747855</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>False</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>...</td>\n",
       "      <td>50.476085</td>\n",
       "      <td>0.001690</td>\n",
       "      <td>0.035375</td>\n",
       "      <td>0.319715</td>\n",
       "      <td>0.086493</td>\n",
       "      <td>1.723875</td>\n",
       "      <td>0.105948</td>\n",
       "      <td>0.105279</td>\n",
       "      <td>0.242584</td>\n",
       "      <td>2.343517</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>False</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>...</td>\n",
       "      <td>61.732801</td>\n",
       "      <td>0.000827</td>\n",
       "      <td>0.069774</td>\n",
       "      <td>0.179740</td>\n",
       "      <td>0.095854</td>\n",
       "      <td>0.145812</td>\n",
       "      <td>0.050059</td>\n",
       "      <td>0.054858</td>\n",
       "      <td>0.214931</td>\n",
       "      <td>0.631492</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>False</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>...</td>\n",
       "      <td>42.697715</td>\n",
       "      <td>0.002019</td>\n",
       "      <td>0.036053</td>\n",
       "      <td>0.298030</td>\n",
       "      <td>0.101729</td>\n",
       "      <td>0.693791</td>\n",
       "      <td>0.098868</td>\n",
       "      <td>0.087775</td>\n",
       "      <td>0.244465</td>\n",
       "      <td>1.290731</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 25 columns</p>\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",
       "\n",
       "   true_intrested_class       f_S       f_0    f_S-f_0      f_S1  ...  \\\n",
       "0                 False  7.627685 -4.749711  12.377395  7.627685  ...   \n",
       "1                 False  7.627685 -4.749711  12.377395  7.627685  ...   \n",
       "2                 False  7.627685 -4.749711  12.377395  7.627685  ...   \n",
       "3                 False  7.627685 -4.749711  12.377395  7.627685  ...   \n",
       "4                 False  7.627685 -4.749711  12.377395  7.627685  ...   \n",
       "\n",
       "    aucD_mse threshold  best_point   max_IoU    au_IoU  time_exp  time_aucI  \\\n",
       "0  51.834962  0.002643    0.011240  0.251335  0.081289  0.561749   0.041955   \n",
       "1  52.450771  0.001140    0.055186  0.207044  0.083196  1.067267   0.088621   \n",
       "2  50.476085  0.001690    0.035375  0.319715  0.086493  1.723875   0.105948   \n",
       "3  61.732801  0.000827    0.069774  0.179740  0.095854  0.145812   0.050059   \n",
       "4  42.697715  0.002019    0.036053  0.298030  0.101729  0.693791   0.098868   \n",
       "\n",
       "   time_aucD  time_IoU  time_total  \n",
       "0   0.069489  0.337408    1.176433  \n",
       "1   0.091723  0.334412    1.747855  \n",
       "2   0.105279  0.242584    2.343517  \n",
       "3   0.054858  0.214931    0.631492  \n",
       "4   0.087775  0.244465    1.290731  \n",
       "\n",
       "[5 rows x 25 columns]"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "5d7749ff-d576-40a7-a3de-b3bc24e7e1b5",
   "metadata": {},
   "outputs": [],
   "source": [
    "# auc_methods      = ['aucI_pred', 'aucD_pred', 'aucI_mse', 'aucD_mse','time_exp']\n",
    "auc_methods      = ['aucI_pred', 'aucD_pred', 'aucI_mse', 'aucD_mse','max_IoU','au_IoU','time_exp']"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "25293401-e885-47e0-97f3-129f59e7791d",
   "metadata": {},
   "source": [
    "# CSS Files"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "10415ad0-bdc7-4e7f-9c81-0639bcf01203",
   "metadata": {},
   "source": [
    "## Create CSS Files"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "ded9f75d-3a3d-494d-b261-17898059d81a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# GENERATE_FILE = True\n",
    "# if GENERATE_FILE:\n",
    "#     with open(f'{utils_path}/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'{utils_path}/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'{utils_path}/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'{utils_path}/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": "markdown",
   "id": "4aeb43d8-2b6f-4f65-abd1-f451bbd8a0ea",
   "metadata": {},
   "source": [
    "## Load CSS Files"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "800514cc-4330-48c7-a891-cc26c5152935",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(f\"{utils_path}/html_stylesheet.txt\", \"r+\") as f:\n",
    "    html_stylesheet = f.read()\n",
    "with open(f\"{utils_path}/html_footer_scripts_IoU.txt\", \"r+\") as f:\n",
    "    html_footer_scripts_IoU = f.read()\n",
    "with open(f\"{utils_path}/html_footer_scripts_full.txt\", \"r+\") as f:\n",
    "    html_footer_scripts_full = f.read()\n",
    "with open(f\"{utils_path}/html_head.txt\", \"r+\") as f:\n",
    "    html_head = f.read()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "6d24db9e-44f6-4c5a-9d02-71d78c5ed768",
   "metadata": {},
   "outputs": [],
   "source": [
    "files = list(df.image)\n",
    "files = np.unique(files)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "30566120-6645-4586-9eef-a9251243acda",
   "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_S1</th>\n",
       "      <th>...</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>False</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>...</td>\n",
       "      <td>51.834962</td>\n",
       "      <td>0.002643</td>\n",
       "      <td>0.011240</td>\n",
       "      <td>0.251335</td>\n",
       "      <td>0.081289</td>\n",
       "      <td>0.561749</td>\n",
       "      <td>0.041955</td>\n",
       "      <td>0.069489</td>\n",
       "      <td>0.337408</td>\n",
       "      <td>1.176433</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>False</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>...</td>\n",
       "      <td>52.450771</td>\n",
       "      <td>0.001140</td>\n",
       "      <td>0.055186</td>\n",
       "      <td>0.207044</td>\n",
       "      <td>0.083196</td>\n",
       "      <td>1.067267</td>\n",
       "      <td>0.088621</td>\n",
       "      <td>0.091723</td>\n",
       "      <td>0.334412</td>\n",
       "      <td>1.747855</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>False</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>-4.749711</td>\n",
       "      <td>12.377395</td>\n",
       "      <td>7.627685</td>\n",
       "      <td>...</td>\n",
       "      <td>50.476085</td>\n",
       "      <td>0.001690</td>\n",
       "      <td>0.035375</td>\n",
       "      <td>0.319715</td>\n",
       "      <td>0.086493</td>\n",
       "      <td>1.723875</td>\n",
       "      <td>0.105948</td>\n",
       "      <td>0.105279</td>\n",
       "      <td>0.242584</td>\n",
       "      <td>2.343517</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>3 rows × 25 columns</p>\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_S1  ...  \\\n",
       "0                 False  7.627685 -4.749711  12.377395  7.627685  ...   \n",
       "1                 False  7.627685 -4.749711  12.377395  7.627685  ...   \n",
       "2                 False  7.627685 -4.749711  12.377395  7.627685  ...   \n",
       "\n",
       "    aucD_mse threshold  best_point   max_IoU    au_IoU  time_exp  time_aucI  \\\n",
       "0  51.834962  0.002643    0.011240  0.251335  0.081289  0.561749   0.041955   \n",
       "1  52.450771  0.001140    0.055186  0.207044  0.083196  1.067267   0.088621   \n",
       "2  50.476085  0.001690    0.035375  0.319715  0.086493  1.723875   0.105948   \n",
       "\n",
       "   time_aucD  time_IoU  time_total  \n",
       "0   0.069489  0.337408    1.176433  \n",
       "1   0.091723  0.334412    1.747855  \n",
       "2   0.105279  0.242584    2.343517  \n",
       "\n",
       "[3 rows x 25 columns]"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.head(3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "47bee872-2f58-4b24-950f-e9d8b0ecc3fb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['Eyeglasses']"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "explained_classes_id = np.unique(df.intrested_class)\n",
    "explained_classes = [classes_names[x] for x in explained_classes_id]\n",
    "explained_classes"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3234d654-144b-4ed2-9b94-7458be11df2f",
   "metadata": {},
   "source": [
    "# HTML FULL"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "5351337d-b59b-4330-98ce-3bae79c0fb70",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "30b04db512f149ebad036fc2e4348f84",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "0it [00:00, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3\n"
     ]
    }
   ],
   "source": [
    "file_success = []\n",
    "\n",
    "for fff_id,fff in tqdm(enumerate(files)):\n",
    "    for ecc_id,ecc in zip(explained_classes_id,explained_classes):\n",
    "        img_path = f'{results_path}//{fff}_{ecc}_{background_type}_heatmaps.png'\n",
    "        if os.path.exists(img_path):\n",
    "            file_success.append(img_path)\n",
    "print(len(file_success))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "3224baa0-91dd-44a6-ae43-b20ea8b5cd47",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total Images: 3\t Total Methods 14\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "862c817bd90e41f1a5c5d0ce12cc5637",
       "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:\\Cloud\\Shared\\XAI\\ICLR_Supplementary\\notebooks\\E7_CelebA\\results/HTML_CelebA_gray.html\n"
     ]
    }
   ],
   "source": [
    "nf_images = []\n",
    "print(f'Total Images: {len(files)}\\t Total Methods {len(methods)}')\n",
    "html_f_name = f'{results_path_main}/HTML_{DS_name}_{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 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:{len(file_success)}</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\n",
    "    if file_n not in df.image.values:\n",
    "        nf_images.append(file_n)\n",
    "        continue\n",
    "    PP = df[df.image==file_n].f_S.iloc[0]\n",
    "    PL = df[df.image==file_n].f_S\n",
    "\n",
    "    for ecc_id,ecc in zip(explained_classes_id,explained_classes):\n",
    "        \n",
    "        img_path = f'{results_path}//{file_n}_{ecc}_{background_type}_heatmaps.png'\n",
    "        if os.path.exists(img_path):\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}  - {ecc} -  {file_n}  -  {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",
    "            df11 = df[df.intrested_class==ecc_id]\n",
    "            for sm in auc_methods:\n",
    "                df1 = df11[(df11.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": 23,
   "id": "f0e62f6c-b176-4f79-b529-cbdeffc4a75b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'E:\\\\Cloud\\\\Shared\\\\XAI\\\\ICLR_Supplementary\\\\notebooks\\\\E7_CelebA\\\\results\\\\bg_gray//138_Eyeglasses_gray_heatmaps.png'"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "img_path"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "56b15c83-14f2-410a-ab88-c900ce755b15",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total Images: 3\t Total Methods 14\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "bf6e129fcdaa4fc190859998a9005314",
       "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:\\Cloud\\Shared\\XAI\\ICLR_Supplementary\\notebooks\\E7_CelebA\\results/HTML_CelebA_gray_IoU.html\n"
     ]
    }
   ],
   "source": [
    "nf_images = []\n",
    "print(f'Total Images: {len(files)}\\t Total Methods {len(methods)}')\n",
    "html_f_name = f'{results_path_main}/HTML_{DS_name}_{background_type}_IoU.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 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:{len(file_success)}</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\n",
    "    if file_n not in df.image.values:\n",
    "        nf_images.append(file_n)\n",
    "        continue\n",
    "    PP = df[df.image==file_n].f_S.iloc[0]\n",
    "    PL = df[df.image==file_n].f_S\n",
    "\n",
    "    for ecc_id,ecc in zip(explained_classes_id,explained_classes):\n",
    "        \n",
    "        img_path = f'{results_path}//{file_n}_{ecc}_{background_type}_iou.png'\n",
    "        if os.path.exists(img_path):\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}  - {ecc} -  {file_n}  -  {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",
    "            df11 = df[df.intrested_class==ecc_id]\n",
    "            for sm in auc_methods:\n",
    "                df1 = df11[(df11.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": 25,
   "id": "09a6b8ca-f7ca-40a3-a1ba-423217aa22a3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total images:\t\t3                        \n"
     ]
    }
   ],
   "source": [
    "print(f'Total images:\\t\\t{len(files):<25}')"
   ]
  }
 ],
 "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": {
     "0c524bab2a2e475cb12e601bbc63bfd2": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "width": "20px"
      }
     },
     "0e975de0ec204347927d49ec4c3cf050": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "0ea79318a40048dc92e33a235c003921": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "18f01d5bb0ab45d79e588b74bf99b346": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_cc0378f8f14745948ef4b5a0a3ccae07",
       "style": "IPY_MODEL_4ee11ae346dd4d79ae754c6ca86a63e8"
      }
     },
     "1c124cc6941a4d82b54e3889b722eeab": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "bar_style": "success",
       "layout": "IPY_MODEL_8b6587673822493699129fdf8835382a",
       "max": 1,
       "style": "IPY_MODEL_29626a88f3cd474bbf59772ed48277b3",
       "value": 1
      }
     },
     "29626a88f3cd474bbf59772ed48277b3": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "description_width": ""
      }
     },
     "2c6baea0d97b44aa87156883b65c25b6": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "30b04db512f149ebad036fc2e4348f84": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "children": [
        "IPY_MODEL_6ece4ac05eda4d5ab232f59ba70dd81a",
        "IPY_MODEL_1c124cc6941a4d82b54e3889b722eeab",
        "IPY_MODEL_f520589d89cc40dab5ed765c1a89b084"
       ],
       "layout": "IPY_MODEL_985a14be2f1f47f1ba89631f53757750"
      }
     },
     "4ee11ae346dd4d79ae754c6ca86a63e8": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "51398c8b4b7b4313a1b1998c022301d0": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "56d8c61512b240e5bec0345d31931839": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "5d87c39fe6014107911a78dc7b40d4bb": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_51398c8b4b7b4313a1b1998c022301d0",
       "style": "IPY_MODEL_56d8c61512b240e5bec0345d31931839",
       "value": " 3/? [00:00&lt;00:00, 35.63it/s]"
      }
     },
     "6231c69728dc411d8f3bf9f62bbd71c3": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "6339469a9e354c10b66a8088b3864295": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_da1606df402240f5a502f20a1f458bbe",
       "style": "IPY_MODEL_6ca2553433cb4ca988634c2441e889f9"
      }
     },
     "66b1cd76aa3b4074bc67c1981d798fe2": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "6ca2553433cb4ca988634c2441e889f9": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "6ece4ac05eda4d5ab232f59ba70dd81a": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_2c6baea0d97b44aa87156883b65c25b6",
       "style": "IPY_MODEL_945a4b5f67bd4205a36fc2c2f473fc52"
      }
     },
     "755ef83a01404098b41998dfd75b9ba3": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "description_width": ""
      }
     },
     "79c90b0c80a9460ea479e53b424122f7": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "bar_style": "success",
       "layout": "IPY_MODEL_0c524bab2a2e475cb12e601bbc63bfd2",
       "max": 1,
       "style": "IPY_MODEL_e9efa8eed22a400c976fe78efde0db08",
       "value": 1
      }
     },
     "862c817bd90e41f1a5c5d0ce12cc5637": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "children": [
        "IPY_MODEL_6339469a9e354c10b66a8088b3864295",
        "IPY_MODEL_c8c21ad682804998b693ef6b6e35d905",
        "IPY_MODEL_c030675b8bb84b979ff1909565043c83"
       ],
       "layout": "IPY_MODEL_66b1cd76aa3b4074bc67c1981d798fe2"
      }
     },
     "8b6587673822493699129fdf8835382a": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "width": "20px"
      }
     },
     "945a4b5f67bd4205a36fc2c2f473fc52": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLStyleModel",
      "state": {
       "description_width": "",
       "font_size": null,
       "text_color": null
      }
     },
     "985a14be2f1f47f1ba89631f53757750": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "bf6e129fcdaa4fc190859998a9005314": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HBoxModel",
      "state": {
       "children": [
        "IPY_MODEL_18f01d5bb0ab45d79e588b74bf99b346",
        "IPY_MODEL_79c90b0c80a9460ea479e53b424122f7",
        "IPY_MODEL_5d87c39fe6014107911a78dc7b40d4bb"
       ],
       "layout": "IPY_MODEL_d89df62580bc4e4e860a05c04f899d6d"
      }
     },
     "c030675b8bb84b979ff1909565043c83": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_d89e6dc9c604449084ecd4f67fab023c",
       "style": "IPY_MODEL_6231c69728dc411d8f3bf9f62bbd71c3",
       "value": " 3/? [00:00&lt;00:00, 35.23it/s]"
      }
     },
     "c8c21ad682804998b693ef6b6e35d905": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "FloatProgressModel",
      "state": {
       "bar_style": "success",
       "layout": "IPY_MODEL_ecad61862d8e4eab8886cd5076ae769d",
       "max": 1,
       "style": "IPY_MODEL_755ef83a01404098b41998dfd75b9ba3",
       "value": 1
      }
     },
     "cc0378f8f14745948ef4b5a0a3ccae07": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "d89df62580bc4e4e860a05c04f899d6d": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "d89e6dc9c604449084ecd4f67fab023c": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "da1606df402240f5a502f20a1f458bbe": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {}
     },
     "e9efa8eed22a400c976fe78efde0db08": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "description_width": ""
      }
     },
     "ecad61862d8e4eab8886cd5076ae769d": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "2.0.0",
      "model_name": "LayoutModel",
      "state": {
       "width": "20px"
      }
     },
     "f520589d89cc40dab5ed765c1a89b084": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "2.0.0",
      "model_name": "HTMLModel",
      "state": {
       "layout": "IPY_MODEL_0e975de0ec204347927d49ec4c3cf050",
       "style": "IPY_MODEL_0ea79318a40048dc92e33a235c003921",
       "value": " 3/? [00:00&lt;00:00, 400.51it/s]"
      }
     }
    },
    "version_major": 2,
    "version_minor": 0
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
