{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "270f14a2-89a9-47d7-a57b-e0a1a7d243c9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "d18a70c4-3920-4bb0-b450-f2bbd318021f",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "97ec2d0f-80d1-4750-bdda-1e0c3d58b97d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import re\n",
    "from os.path import join, basename, dirname\n",
    "from glob import glob\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from natsort import natsorted\n",
    "import torch\n",
    "\n",
    "from torchvision.io import read_image"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "962ad0d1-60b7-4707-8bec-d29e4eb8cb10",
   "metadata": {},
   "outputs": [],
   "source": [
    "from experiment_utils import set_env, REPO_PATH, seed_everything\n",
    "set_env()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ecd78471-49ce-4f2d-a606-70bb05b94293",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.rcParams.update({\n",
    "    \"text.usetex\": True,\n",
    "    \"font.family\": \"serif\",\n",
    "    \"font.serif\": [\"Computer Modern Roman\"],\n",
    "})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "844acdaa-6dd9-4530-be54-054512233c3a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_expt_from_path(path, prefix=\"experiments\"):\n",
    "    elements = path.split(\"/\")\n",
    "    idx = elements.index(prefix)\n",
    "    return elements[idx + 1].split(\".\")[0]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5047c742-7809-4f25-bd80-fcc9735ab604",
   "metadata": {},
   "source": [
    "### Classification results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "5ec908eb-dcbf-4c67-a002-4813c294ba70",
   "metadata": {},
   "outputs": [],
   "source": [
    "# models trained on CF data\n",
    "paths = glob(join(REPO_PATH, \"cgn_framework\", \"mnists/experiments/\", \"classifier_*_seed_*/test_accs.pth\"))\n",
    "\n",
    "# models trained on original data\n",
    "paths += glob(join(REPO_PATH, \"cgn_framework\", \"mnists/experiments/\", \"classifier_*_MNIST/test_accs.pth\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "5954e571-d2e5-4ddb-a82d-91dc419990cc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "18"
      ]
     },
     "execution_count": 63,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(paths)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "id": "6e191028-f739-48ab-84a0-dba5e1afded0",
   "metadata": {},
   "outputs": [],
   "source": [
    "# df = pd.DataFrame(None)\n",
    "df = []\n",
    "\n",
    "for i, path in enumerate(paths):\n",
    "    expt = get_expt_from_path(path)\n",
    "    \n",
    "    elements = expt.split(\"_\")\n",
    "    start, end = 1, elements.index(\"MNIST\")\n",
    "    dataset = \"_\".join(elements[start:end + 1])\n",
    "    clf = \"original\" if not \"counterfactual\" in expt else \"counterfactual\"\n",
    "    \n",
    "    test_accs = torch.load(path)\n",
    "    df.append([expt, dataset, clf, test_accs[10]])\n",
    "\n",
    "df = pd.DataFrame(df, columns=[\"expt\", \"dataset\", \"model\", \"accuracy\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "id": "17913031-925f-498b-8643-b5179df4c56c",
   "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>expt</th>\n",
       "      <th>dataset</th>\n",
       "      <th>model</th>\n",
       "      <th>accuracy</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>classifier_colored_MNIST_counterfactual_seed_0</td>\n",
       "      <td>colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>92.43</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>classifier_colored_MNIST_counterfactual_seed_10</td>\n",
       "      <td>colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>93.08</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>classifier_colored_MNIST_counterfactual_seed_20</td>\n",
       "      <td>colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>93.57</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>classifier_colored_MNIST_counterfactual_seed_30</td>\n",
       "      <td>colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>92.64</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>classifier_colored_MNIST_counterfactual_seed_40</td>\n",
       "      <td>colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>92.91</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>classifier_double_colored_MNIST_counterfactual...</td>\n",
       "      <td>double_colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>86.33</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>classifier_double_colored_MNIST_counterfactual...</td>\n",
       "      <td>double_colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>86.79</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>classifier_double_colored_MNIST_counterfactual...</td>\n",
       "      <td>double_colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>86.44</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>classifier_double_colored_MNIST_counterfactual...</td>\n",
       "      <td>double_colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>86.73</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>classifier_double_colored_MNIST_counterfactual...</td>\n",
       "      <td>double_colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>86.88</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>classifier_wildlife_MNIST_counterfactual_seed_0</td>\n",
       "      <td>wildlife_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>81.56</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>classifier_wildlife_MNIST_counterfactual_seed_10</td>\n",
       "      <td>wildlife_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>81.61</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>classifier_wildlife_MNIST_counterfactual_seed_20</td>\n",
       "      <td>wildlife_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>81.40</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>classifier_wildlife_MNIST_counterfactual_seed_30</td>\n",
       "      <td>wildlife_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>80.64</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>classifier_wildlife_MNIST_counterfactual_seed_40</td>\n",
       "      <td>wildlife_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>81.76</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>classifier_colored_MNIST</td>\n",
       "      <td>colored_MNIST</td>\n",
       "      <td>original</td>\n",
       "      <td>37.35</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>classifier_double_colored_MNIST</td>\n",
       "      <td>double_colored_MNIST</td>\n",
       "      <td>original</td>\n",
       "      <td>10.05</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>classifier_wildlife_MNIST</td>\n",
       "      <td>wildlife_MNIST</td>\n",
       "      <td>original</td>\n",
       "      <td>10.80</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                 expt               dataset  \\\n",
       "0      classifier_colored_MNIST_counterfactual_seed_0         colored_MNIST   \n",
       "1     classifier_colored_MNIST_counterfactual_seed_10         colored_MNIST   \n",
       "2     classifier_colored_MNIST_counterfactual_seed_20         colored_MNIST   \n",
       "3     classifier_colored_MNIST_counterfactual_seed_30         colored_MNIST   \n",
       "4     classifier_colored_MNIST_counterfactual_seed_40         colored_MNIST   \n",
       "5   classifier_double_colored_MNIST_counterfactual...  double_colored_MNIST   \n",
       "6   classifier_double_colored_MNIST_counterfactual...  double_colored_MNIST   \n",
       "7   classifier_double_colored_MNIST_counterfactual...  double_colored_MNIST   \n",
       "8   classifier_double_colored_MNIST_counterfactual...  double_colored_MNIST   \n",
       "9   classifier_double_colored_MNIST_counterfactual...  double_colored_MNIST   \n",
       "10    classifier_wildlife_MNIST_counterfactual_seed_0        wildlife_MNIST   \n",
       "11   classifier_wildlife_MNIST_counterfactual_seed_10        wildlife_MNIST   \n",
       "12   classifier_wildlife_MNIST_counterfactual_seed_20        wildlife_MNIST   \n",
       "13   classifier_wildlife_MNIST_counterfactual_seed_30        wildlife_MNIST   \n",
       "14   classifier_wildlife_MNIST_counterfactual_seed_40        wildlife_MNIST   \n",
       "15                           classifier_colored_MNIST         colored_MNIST   \n",
       "16                    classifier_double_colored_MNIST  double_colored_MNIST   \n",
       "17                          classifier_wildlife_MNIST        wildlife_MNIST   \n",
       "\n",
       "             model  accuracy  \n",
       "0   counterfactual     92.43  \n",
       "1   counterfactual     93.08  \n",
       "2   counterfactual     93.57  \n",
       "3   counterfactual     92.64  \n",
       "4   counterfactual     92.91  \n",
       "5   counterfactual     86.33  \n",
       "6   counterfactual     86.79  \n",
       "7   counterfactual     86.44  \n",
       "8   counterfactual     86.73  \n",
       "9   counterfactual     86.88  \n",
       "10  counterfactual     81.56  \n",
       "11  counterfactual     81.61  \n",
       "12  counterfactual     81.40  \n",
       "13  counterfactual     80.64  \n",
       "14  counterfactual     81.76  \n",
       "15        original     37.35  \n",
       "16        original     10.05  \n",
       "17        original     10.80  "
      ]
     },
     "execution_count": 74,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "id": "6de97ae9-0293-4a6d-a5ff-4c717cb4bb67",
   "metadata": {},
   "outputs": [],
   "source": [
    "def apply_filters(df: pd.DataFrame, filters: dict, reset_index=False):\n",
    "    \"\"\"\n",
    "    Filters df based on given filters (key-values pairs).\n",
    "    \"\"\"\n",
    "    X = df.copy()\n",
    "\n",
    "    for col, values in filters.items():\n",
    "        if isinstance(values, (list, tuple, np.ndarray)):\n",
    "            indices = X[col].isin(list(values))\n",
    "        else:\n",
    "            indices = X[col] == values\n",
    "        X = X[indices]\n",
    "\n",
    "    if reset_index:\n",
    "        X = X.reset_index(drop=True)\n",
    "\n",
    "    return X"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "id": "5e7743da-2588-4a0a-876c-b71ce2dde11a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# mean_df = pd.DataFrame(None, columns=[\"dataset\", \"model\", \"mean_accuracy\", \"std_accuracy\"])\n",
    "mean_df = []\n",
    "\n",
    "for d, m in df[[\"dataset\", \"model\"]].values:\n",
    "    subdf = apply_filters(df, {\"dataset\": d, \"model\": m})\n",
    "    # mean_df[\"mean_accuracy\"] = subdf[\"accuracy\"].mean()\n",
    "    # mean_df[\"std_accuracy\"] = subdf[\"accuracy\"].std()\n",
    "    mean_df.append([d, m, subdf[\"accuracy\"].mean(), subdf[\"accuracy\"].std()])\n",
    "\n",
    "mean_df = pd.DataFrame(mean_df, columns=[\"dataset\", \"model\", \"mean_accuracy\", \"std_accuracy\"])\n",
    "mean_df.drop_duplicates(inplace=True)\n",
    "mean_df.fillna(0, inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "c39d12da-70b2-48b1-b5e4-b4cb3a5be1c1",
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_df[\"accuracy\"] = mean_df[\"mean_accuracy\"].astype(str) + \" \\pm \" + mean_df[\"std_accuracy\"].astype(str)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "id": "5bf57606-e13c-476c-a859-9a46e023fd9c",
   "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>dataset</th>\n",
       "      <th>model</th>\n",
       "      <th>mean_accuracy</th>\n",
       "      <th>std_accuracy</th>\n",
       "      <th>accuracy</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>92.926</td>\n",
       "      <td>0.437756</td>\n",
       "      <td>92.926 \\pm 0.437755639598162</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>double_colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>86.634</td>\n",
       "      <td>0.236707</td>\n",
       "      <td>86.634 \\pm 0.23670656940609106</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>wildlife_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>81.394</td>\n",
       "      <td>0.440659</td>\n",
       "      <td>81.394 \\pm 0.4406585980098435</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>colored_MNIST</td>\n",
       "      <td>original</td>\n",
       "      <td>37.350</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>37.35 \\pm 0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>double_colored_MNIST</td>\n",
       "      <td>original</td>\n",
       "      <td>10.050</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>10.05 \\pm 0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>wildlife_MNIST</td>\n",
       "      <td>original</td>\n",
       "      <td>10.800</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>10.8 \\pm 0.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                 dataset           model  mean_accuracy  std_accuracy  \\\n",
       "0          colored_MNIST  counterfactual         92.926      0.437756   \n",
       "5   double_colored_MNIST  counterfactual         86.634      0.236707   \n",
       "10        wildlife_MNIST  counterfactual         81.394      0.440659   \n",
       "15         colored_MNIST        original         37.350      0.000000   \n",
       "16  double_colored_MNIST        original         10.050      0.000000   \n",
       "17        wildlife_MNIST        original         10.800      0.000000   \n",
       "\n",
       "                          accuracy  \n",
       "0     92.926 \\pm 0.437755639598162  \n",
       "5   86.634 \\pm 0.23670656940609106  \n",
       "10   81.394 \\pm 0.4406585980098435  \n",
       "15                   37.35 \\pm 0.0  \n",
       "16                   10.05 \\pm 0.0  \n",
       "17                    10.8 \\pm 0.0  "
      ]
     },
     "execution_count": 90,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mean_df"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "eb46002a-a38c-49f0-beda-5478c2d1eae8",
   "metadata": {},
   "source": [
    "### Interpretability results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "id": "617aa696-23b3-4120-a7fd-60ad868490d7",
   "metadata": {},
   "outputs": [],
   "source": [
    "# get gradcam results\n",
    "\n",
    "# models trained on CF data\n",
    "paths = glob(join(REPO_PATH, \"experiments\", \"results\", \"*_seed_*_gradcam_iou.pth\"))\n",
    "\n",
    "# models trained on original data\n",
    "paths += glob(join(REPO_PATH, \"experiments\", \"results\", \"*_MNIST_seed_0_gradcam_iou.pth\"))\n",
    "\n",
    "paths = np.unique(paths)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "id": "5a78e9aa-0f12-4032-b46b-b33a90c0c782",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "18"
      ]
     },
     "execution_count": 101,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(paths)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "id": "bef7573a-22f9-400b-9230-e9cc1c6cac70",
   "metadata": {},
   "outputs": [],
   "source": [
    "# df = pd.DataFrame(None)\n",
    "df = []\n",
    "\n",
    "for i, path in enumerate(paths):\n",
    "    expt = get_expt_from_path(path, prefix=\"results\")\n",
    "    \n",
    "    elements = expt.split(\"_\")\n",
    "    start, end = 0, elements.index(\"MNIST\")\n",
    "    dataset = \"_\".join(elements[start:end + 1])\n",
    "    clf = \"original\" if not \"counterfactual\" in expt else \"counterfactual\"\n",
    "    \n",
    "    output = torch.load(path)\n",
    "    df.append([expt, dataset, clf, output[\"overall_mean\"], output[\"overall_std\"]])\n",
    "\n",
    "df = pd.DataFrame(df, columns=[\"expt\", \"dataset\", \"model\", \"mean iou\", \"std iou\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 113,
   "id": "b0c43ba9-4801-4beb-a102-045a41aabd1d",
   "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>expt</th>\n",
       "      <th>dataset</th>\n",
       "      <th>model</th>\n",
       "      <th>mean iou</th>\n",
       "      <th>std iou</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>colored_MNIST_classifier_colored_MNIST_counter...</td>\n",
       "      <td>colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>0.458936</td>\n",
       "      <td>0.068492</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>colored_MNIST_classifier_colored_MNIST_counter...</td>\n",
       "      <td>colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>0.455063</td>\n",
       "      <td>0.059170</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>colored_MNIST_classifier_colored_MNIST_counter...</td>\n",
       "      <td>colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>0.459971</td>\n",
       "      <td>0.070201</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>colored_MNIST_classifier_colored_MNIST_counter...</td>\n",
       "      <td>colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>0.451551</td>\n",
       "      <td>0.060477</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>colored_MNIST_classifier_colored_MNIST_counter...</td>\n",
       "      <td>colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>0.453279</td>\n",
       "      <td>0.058705</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>colored_MNIST_classifier_colored_MNIST_seed_0_...</td>\n",
       "      <td>colored_MNIST</td>\n",
       "      <td>original</td>\n",
       "      <td>0.439093</td>\n",
       "      <td>0.065101</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>double_colored_MNIST_classifier_double_colored...</td>\n",
       "      <td>double_colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>0.429190</td>\n",
       "      <td>0.042256</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>double_colored_MNIST_classifier_double_colored...</td>\n",
       "      <td>double_colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>0.427145</td>\n",
       "      <td>0.039312</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>double_colored_MNIST_classifier_double_colored...</td>\n",
       "      <td>double_colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>0.437598</td>\n",
       "      <td>0.044681</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>double_colored_MNIST_classifier_double_colored...</td>\n",
       "      <td>double_colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>0.428993</td>\n",
       "      <td>0.042867</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>double_colored_MNIST_classifier_double_colored...</td>\n",
       "      <td>double_colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>0.438193</td>\n",
       "      <td>0.045829</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>double_colored_MNIST_classifier_double_colored...</td>\n",
       "      <td>double_colored_MNIST</td>\n",
       "      <td>original</td>\n",
       "      <td>0.365139</td>\n",
       "      <td>0.113033</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>wildlife_MNIST_classifier_wildlife_MNIST_count...</td>\n",
       "      <td>wildlife_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>0.442405</td>\n",
       "      <td>0.048826</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>wildlife_MNIST_classifier_wildlife_MNIST_count...</td>\n",
       "      <td>wildlife_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>0.447895</td>\n",
       "      <td>0.045025</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>wildlife_MNIST_classifier_wildlife_MNIST_count...</td>\n",
       "      <td>wildlife_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>0.438686</td>\n",
       "      <td>0.044779</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>wildlife_MNIST_classifier_wildlife_MNIST_count...</td>\n",
       "      <td>wildlife_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>0.441134</td>\n",
       "      <td>0.043418</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>wildlife_MNIST_classifier_wildlife_MNIST_count...</td>\n",
       "      <td>wildlife_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>0.444783</td>\n",
       "      <td>0.045872</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>wildlife_MNIST_classifier_wildlife_MNIST_seed_...</td>\n",
       "      <td>wildlife_MNIST</td>\n",
       "      <td>original</td>\n",
       "      <td>0.395882</td>\n",
       "      <td>0.076988</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                 expt               dataset  \\\n",
       "0   colored_MNIST_classifier_colored_MNIST_counter...         colored_MNIST   \n",
       "1   colored_MNIST_classifier_colored_MNIST_counter...         colored_MNIST   \n",
       "2   colored_MNIST_classifier_colored_MNIST_counter...         colored_MNIST   \n",
       "3   colored_MNIST_classifier_colored_MNIST_counter...         colored_MNIST   \n",
       "4   colored_MNIST_classifier_colored_MNIST_counter...         colored_MNIST   \n",
       "5   colored_MNIST_classifier_colored_MNIST_seed_0_...         colored_MNIST   \n",
       "6   double_colored_MNIST_classifier_double_colored...  double_colored_MNIST   \n",
       "7   double_colored_MNIST_classifier_double_colored...  double_colored_MNIST   \n",
       "8   double_colored_MNIST_classifier_double_colored...  double_colored_MNIST   \n",
       "9   double_colored_MNIST_classifier_double_colored...  double_colored_MNIST   \n",
       "10  double_colored_MNIST_classifier_double_colored...  double_colored_MNIST   \n",
       "11  double_colored_MNIST_classifier_double_colored...  double_colored_MNIST   \n",
       "12  wildlife_MNIST_classifier_wildlife_MNIST_count...        wildlife_MNIST   \n",
       "13  wildlife_MNIST_classifier_wildlife_MNIST_count...        wildlife_MNIST   \n",
       "14  wildlife_MNIST_classifier_wildlife_MNIST_count...        wildlife_MNIST   \n",
       "15  wildlife_MNIST_classifier_wildlife_MNIST_count...        wildlife_MNIST   \n",
       "16  wildlife_MNIST_classifier_wildlife_MNIST_count...        wildlife_MNIST   \n",
       "17  wildlife_MNIST_classifier_wildlife_MNIST_seed_...        wildlife_MNIST   \n",
       "\n",
       "             model  mean iou   std iou  \n",
       "0   counterfactual  0.458936  0.068492  \n",
       "1   counterfactual  0.455063  0.059170  \n",
       "2   counterfactual  0.459971  0.070201  \n",
       "3   counterfactual  0.451551  0.060477  \n",
       "4   counterfactual  0.453279  0.058705  \n",
       "5         original  0.439093  0.065101  \n",
       "6   counterfactual  0.429190  0.042256  \n",
       "7   counterfactual  0.427145  0.039312  \n",
       "8   counterfactual  0.437598  0.044681  \n",
       "9   counterfactual  0.428993  0.042867  \n",
       "10  counterfactual  0.438193  0.045829  \n",
       "11        original  0.365139  0.113033  \n",
       "12  counterfactual  0.442405  0.048826  \n",
       "13  counterfactual  0.447895  0.045025  \n",
       "14  counterfactual  0.438686  0.044779  \n",
       "15  counterfactual  0.441134  0.043418  \n",
       "16  counterfactual  0.444783  0.045872  \n",
       "17        original  0.395882  0.076988  "
      ]
     },
     "execution_count": 113,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "id": "c7613b84-4433-4aa8-8400-8c558ce56218",
   "metadata": {},
   "outputs": [],
   "source": [
    "# mean_df = pd.DataFrame(None, columns=[\"dataset\", \"model\", \"mean_accuracy\", \"std_accuracy\"])\n",
    "mean_df = []\n",
    "\n",
    "for d, m in df[[\"dataset\", \"model\"]].values:\n",
    "    subdf = apply_filters(df, {\"dataset\": d, \"model\": m})\n",
    "    # mean_df[\"mean_accuracy\"] = subdf[\"accuracy\"].mean()\n",
    "    # mean_df[\"std_accuracy\"] = subdf[\"accuracy\"].std()\n",
    "    mean_df.append([d, m, subdf[\"mean iou\"].mean(), subdf[\"mean iou\"].std()])\n",
    "\n",
    "mean_df = pd.DataFrame(mean_df, columns=[\"dataset\", \"model\", \"avg of mean iou\", \"std of mean iou\"])\n",
    "mean_df.drop_duplicates(inplace=True)\n",
    "mean_df.fillna(0, inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 115,
   "id": "12feba34-e477-4cb0-b78d-2060bdc0e135",
   "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>dataset</th>\n",
       "      <th>model</th>\n",
       "      <th>avg of mean iou</th>\n",
       "      <th>std of mean iou</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>0.455760</td>\n",
       "      <td>0.003611</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>colored_MNIST</td>\n",
       "      <td>original</td>\n",
       "      <td>0.439093</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>double_colored_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>0.432224</td>\n",
       "      <td>0.005243</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>double_colored_MNIST</td>\n",
       "      <td>original</td>\n",
       "      <td>0.365139</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>wildlife_MNIST</td>\n",
       "      <td>counterfactual</td>\n",
       "      <td>0.442981</td>\n",
       "      <td>0.003521</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>wildlife_MNIST</td>\n",
       "      <td>original</td>\n",
       "      <td>0.395882</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                 dataset           model  avg of mean iou  std of mean iou\n",
       "0          colored_MNIST  counterfactual         0.455760         0.003611\n",
       "5          colored_MNIST        original         0.439093         0.000000\n",
       "6   double_colored_MNIST  counterfactual         0.432224         0.005243\n",
       "11  double_colored_MNIST        original         0.365139         0.000000\n",
       "12        wildlife_MNIST  counterfactual         0.442981         0.003521\n",
       "17        wildlife_MNIST        original         0.395882         0.000000"
      ]
     },
     "execution_count": 115,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mean_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 137,
   "id": "e7057f3a-e253-4705-b9a8-dafbc72dc919",
   "metadata": {},
   "outputs": [],
   "source": [
    "# massaing\n",
    "df[\"model\"] = df[\"model\"].apply(lambda x: x.capitalize())\n",
    "df[\"dataset\"] = df[\"dataset\"].apply(lambda x: x.replace(\"_\", \" \"))\n",
    "\n",
    "mean_df[\"model\"] = mean_df[\"model\"].apply(lambda x: x.capitalize())\n",
    "mean_df[\"dataset\"] = mean_df[\"dataset\"].apply(lambda x: x.replace(\"_\", \" \"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 139,
   "id": "bc24b927-8f80-47d7-a3e6-3b14800c7a54",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmgAAAH9CAYAAACurIAkAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAAxl0lEQVR4nO3dQW8jaX7f8d8/2Emm9zDmaJxpJA3bO5RjwKddS+rsdeCmnEv2YIfqzt0eaY0NEMBwxOm8gVlqDQM5zEHsfQPd4jqXXAyxjb4tvC1p7ZMRA812DrOGBx41d+DsGDvY/HOop9SlYpFVFCnyofj9AEQ3i8Wqh1VPUT8+9dRT5u4CAABAPP7FogsAAACAywhoAAAAkSGgAQAARIaABgAAEBkCGgAAQGS+sugCANMwsw1JjfD0zN17iyzPMjCzDXc/W3Q5AACj0YK2gszs0MxOzczDv4dmVptwGe38MgrmOTKzV+Ex9Pq0zKwu6ZG7H0h6R1Jrwvfvm9lxKOdheDTCazUz2511mceUZdfMXpjZq5L5pipz2M+nZfs7t3/bFcpfy+zro7Bvxs1fD5/jVVp+xCfsp6Oq3w/s12qqHu8xYh/PjzEO2moKf0BfSNq+aqtTlWWEwNC/jpatEPpeuPtBaElTlZahMO+RpK67t3KvNSTVJG2ny551uceUqyHpyN3fLnhtJmUO++NQUqvss4X925bUKCpTbt6mpIeSTtx9b9y8ufe9krQz75bP8NnqtLiOF+rdU0mb7t7PTB+7/Ra1X5fJuON9zHvmVm/Zx4tHCxquWz88rsOWpDMpCWYThLNTSXv5oBOW01NS3rm1nmUUbqcZl7kmqSvpQYV5zyU9llSb4JfyoOJ8qeuqG2XGtvAhEY6rt7PhLCjbfovar8vkKttonvWWfbxgBDSsmiNJB+N+9YWg15lfkUodSepMW+bwi7ivJHRtlJ2GDAZhuSNbxUKAXLY+bTuLLsCSY/stxjy3O/t4wQhoWBnh9F5d0kcVZj+65uJUkilzaT8wlZe54e5dd+8qCV5VT0UeSWqO6YdUL2hhiVZoDVxEC+mNwPZbjHlud/ZxHLiKE0PCH+JdvT5dVVPSgjMofsd81x++PHaUBJeWme2oWn+xHSX94QYl88nde9lAElqJHoV13gv/rinpg7Gdma8RXjuXdFfS8Zg+HG0lffjOw7JOxpS5NADly1wg+9oTSU1VuLAiLHcg6b6uqWUx049uTUlfug/y+ylzxW4/zFfL7/Oy7R/6yqX7K607ktR2935uP6ev1cLzu0r67vVDcD4P098pOvVcoSxFdUrh3/W0TAXbSOHzn0u6W7TuzHv2lfQNrClpOW6FsrfCejppn8FQH/eVtIbuhOU/TbdFqAdjt9+IbVDTmP06Tmjl3VNynKwr6T+Znm5fV9IaXOW4rGn8d0o9LHsrlLEbpl9sK3e3MG1UHRn7GSse76O2wyT1dmg7TPj55rqPMYa781jBh5ID2JW0quSnH+em1SQdK/mDWLqM3DwNJQf/JOWquv7TcesuWPar/LKvsN1cyR+xWni8SssVyp7fnqeSmgWf50V+uyj5An016zIXlU3SRvgsG2PeU0vfo6QF73TE/k0//6mSL/FJynUatmc9M223oA40CqbtSzoc9RlHbf8w/UVJvfVR5ZK0m5u3aNokZXElncXz73+Vrj883y+Yp7RuKAni+Xq1kZ8Wph8VTHtV8FnKtl+l/Vqhzr7Ib5PsZyjYX6OOy6rfKa/y+yjUPZ+kjhSsq9LxXmGbVK23Q9vhCp/v2vcxj/EPTnEi7zA8Lnjya+hIyS+0ZV5/TZN3Ys/rK2kxGYTH2/7612JTubKH5/lTiY+UXI2Z/zVadIqypunLLCVftBetN570Weur2sUCUvI5ivqt1Xz6X8vruW1xotetJNn1XzrN60nr2W6m1bDq9q+iP6Zc+f12ptctDqlJypL2C7wQ1tvJLKOhXD0I85T2/fOktaSW23f9MG0jN/tjDbvq6esq+3WcljKfLyzrPB1Kxi9fFDTuuJzkO6Xos476/OPqSNYkx/u0xm2H9PWi91zVtPsYYxDQcCF8gTckFZ2S62l8P6RlWP9Al0/zXdXzEdO7Gu4rlp7OyGqOWMZ5wbSBZlPmIl1V7GeSCQMXASPsi8EMynGae35pmSFE1FV8Sqiv5LSNVH37VzEYU658OT4reP+kZRkUTHssqRG284mkwzAOXi0zT9XxBbu6HA7vSzrQ5f0564s9xu7XCtKLWrL6kjZHzD90TF3zd8pA1T7jJMf7LIz6froO0+5jjEFAQ1Y6ltgg/0LmV9JW/rUlWv+Jxlw6bmaNMPDrcRig9YUVD7A7VL60jO7eCctKWyfu5taRtlhU/UM4tsx5RVdmhnVu2uuBbQ/D56ppsiE0DpX8sUldapWbQtkfqvQzNcysmX0oaWU5kapt/1mUq0qL4YzKclHnQ2vRjpJA9SrUzf2CVplRHuvyvpOS/Xk/83xrguVVMW0A6Wu47tc1HApSg4Jp1/2dMvYzXuF4n4XBHNd1XSET4iIBVFT0K9OTzqnS+BaeUS0fU6//Co6UtEIUXnUYwkYvrM9VMChsMPJLKdPB9jQs67mma/JPy1x6KjFsow0Ntzo0fMTgsZkLLqoErSehLPO+VdRAujhVN9ZVt3+V7TupWdeF8Pm7mYsl9szsrruXDofg7l17fYeHc0nn4fg9n8X+vI7tpyRAXpwGDPV7TUk9LDJRWLjOswHzMmK7X0touqZ9jDFoQUPWmTTyiys9NZMPW0W/crMmOaivsv7KQotGX9VvCVV06mqkcJXWnrvvuXtnRAhM/xBWahXLlPlhhdlHncoZ51DVT3MOwvL3MmOqzcOJVNw6mFVl+49xv3yW6qYsSyr9vCeWuYWXJ4PHHrj7upJ+gbWKy+spaUW7nwm7XUkPQuibpjV0ptsv6CsJpO3w+R8quaPBYIJlzOI7pei9lUx6vF/BLLZ7bY7rwgQIaLiQ6WdUdCA2JfUKvhxbGtEJe9I+Sldc/6R2lHQsv46OrPsa7ne0pvAFmPkj21U49ZIz6kt8R9L+uDKnrQv57RPeM67lKb3cPn/6K1XLPU9PizXm1YoWPlNXw6foZGYbmdNIVbd/qjbi/7MwaVmK9v2eXtf52oh91FP1PnZHGr4o5LGSgH6V05u1Ef+flV13b4VHJ/w7URln9J0ybbia9HgvUxvx/6sa+wN7xuvCBAhoyNtR0kJSSyeE/z9QQRALv8R7+b5aobXjYdoP55rWX9OEXxohVGwqOVXXLvplHVo/RpV7TeP/IOaXVyuY/wPlPmOwXfD+oTIXlLeu5I9ZUZnH/lELr/VVHLK3lPvyTq8ILCpnMGr6KDVVCxgtvW65y8oHxfz6Ry2/p8t9wgZXLJckvVOw3knKIuWuAs2cxsyevixqRV2bILQ8URIULk6BhW13XlDWrFrB67PcfqP0wzhuVYw7Lif5TulpOLCshfcMXcE8Zp1ZEx3vJcq2e9n30ySfbx77GONMM0YHj+V8KGkFOVUyZs6pMmNJhddrSn7974ZHW7nxggqW2VToLxXm35+ifGPXr+QL5iiU/0VY59jyjVjPvpKxkI4y69tPl6XL4yxtZNY5tM0y86Qd6RsK4w2FZac3Hc9/xmZ47Or12GQjx3fLlTkdPqBobK1G2Dbp8gq3T3i/h8dxut5QtlcqHqMrvz8amW3zKixz7Nh3BftwP1OPTvPlyW2z/XSbXXX7Zz77bnY5k5YrLONiO2XrzgR14UU6T6YuXKrTYVo9/JvOd2kMqop1/kgaGvtrXwXj4RVsi/z2nnr7VShvWoc9s8z8dh57XFb5TsnNl36udDvXM+tOn1+17k50vI85ZvPbfZLtMPbzzXsf8xj9sLBhAQALYGYvlPRXm8UVsTdGaJU/9EwLaeaOAA8lved0WscNNvdTnGZWD2P5NArG9MnP2zaz3XCZ+nX1GwIARCSc2nzhuX6Ongy+eqDkdC2d1nGjLaIP2qEnVyD1VDyYY15b0kslzdH8wgSA1TAY89qLeRUCWJS5BrTQCfGiU6EnnVvH/Qp67smtKt728hthA8Ayuri6Exc6knZGXMRTV9LBftR4aMCNMO+Bai9dQZQaNXBo5vV5D4wJANcqXKn5UKEDefge5IeoklOZZpYOiTPQ678ba0rOpuTvfQrcOPMOaGsabrYed4l3PfQ7OwnDCzwmqAG4Cfz17ZtQIFwAQGDFyor6Vk/ZX5Phip5jSev5+cKgj7uSdOvWrc1f+ZVfmVsZAQAArupv//Zv/9Hd/3V++rwDWlFrWVGrmqTL9/7y5L5xhSMeezJAZ0eStra2/ORk6ls/AgAAXDsz+z9F0+d9FeeZCkYeLup/Fk5tPp1HoQAAAGIy14CWD2KhRexJ9nnmqp0TZW5qHe5DN+6eggAAADfCIvqg7YRBCPuS7rp79l5obSX9zDrhKp7zMO9A0rq706EWAADceDfuVk/0QQMAAMvCzE7dfSs/fRF3EgAAAMAYBDQAAIDIENAAAAAiQ0ADAACITNR3EgBWyeeff65PP/1UX3755aKLAmCJvPHGG3r33Xf11ltvLboomCECGhCBzz//XP/wD/+gO3fu6NatWzKzRRcJwBJwd33xxRf65JNPJImQdoNwihOIwKeffqo7d+7oq1/9KuEMQGVmpq9+9au6c+eOPv3000UXBzNEQAMi8OWXX+rWrVuLLgaAJXXr1i26R9wwBDQgErScAbgqvj9uHgIaAABAZLhIAIjYxz96uZD1fuffv3fl93a7XZ2fn2ttbU2S1O/3tb+/P6uizVyv11Or1VKj0VC73V50cfTPf/nXC1nvm9/8+kLWC6AYLWgAZqbVaun8/Fy7u7tqNpsXj+3tbQ0Gg9L37+zsqNPpVFrXJPOO02g0tLe3N/VyVlmv19Pe3p4ODg7U6XQu9svBwcGCS3Y1BwcHOjg40M7OzqKLcqHX62lzc1OtVmvRRcGc0IIGYCZ6vZ56vd5QK1S9Xtf29rY++OADHR0djV3G3t6e6vV6pfVNMm+ZtbU1vXjxYibLWjWtVkv9fn9o3+7s7GgwGMyt9bTT6Wh3d3fq5Zydnen58+c6OjqaOmDOqkzS6x8S1NPVQQsagJlotVp68OBB4Wu7u7vqdrvq9/tjl9FoNEpDV9oSV2VeXK9er6dut1sYvOd5ungwGFRqoa2i3+9f1KtpwuUsy5RKuw1gNRDQAMzE2dmZNjY2Cl+r1WoX83S7Xa2vr1+cDtvc3NRgMNDZ2dnQKZyzszMdHByo2+1qb29P3W5XH3300dC86emfdN50/mwgTNfd6XS0t7c38z+eq6jVao08PVyv1+cWoGM87RdjmbBcOMUJYGppEBr3C79er19cMNDv93V8fKzj42NJSYDb2NgYOoVz7949vXz5UrVaTc+fP9f5+flFy0x23vT0z+HhoU5PTyVJ5+fnOjw8vJh/Z2dHR0dHajab6na7arVaOjw8nP3GWCFnZ2djW8qyrw0GA3U6HdXrdZ2fn6ter6vRaFxcpLG1taXDw0OdnZ3pgw8+uHievv7gwYOLwHd8fKxWq6V6va5er6d+v69+v69arXaxXCmpl91uV/V6Xc+fP9fDhw9Vq9Uu9v/e3p5qtZoODw/19OlT9ft9PX78WP1+X51OR/fv379Y9vn5uU5PT9Vuty9+cPT7fR0eHuru3buq1WpaW1vTxsbGyDKVfdZ0m45aH1YLAQ3A1NI/nP1+f2QrWvbUkfS6VS3bRyffF2wwGFz645R9rajfWHb5a2trF2FNkk5PTy+WlYZFXF2VUJ7dd/fu3bu0P3Z2drS2tqZGo6EHDx5c7MuNjQ09fPhQjx8/llQevhuNhs7OziRpqL/X9vb2peXu7Ozo+PhYzWZz5I+EBw8e6Pnz5xfLGhfst7e3L+pVGrZOT09Hlqnss5atD6uFgAZgJsaFnnR6NrzdvXu3dJlp37X0D17ZRQb5sHB+fn7peavV0vr6ugaDwdBrmEwahqtsx7QVK+vBgwf66KOPdHR0VKmFaFz4LtLpdC7Vt3q9rpOTk0vzFP1IyBsV7Lvdrmq12sVrGxsbevr0aennKPus/JBAioAGYCba7bZarVZhx+rDw0M1m82J+yRtbm5qY2NDJycnFy0dVzEYDLS5uXmptSNttaAv2tVtbGzo7Ozs4pRiXrfbVbPZ1PPnz4fCc61Wmyh8lIXvvBcvXmgwGKjX611Mywf8Kj8SpOJg3+/3Cz/TLPBDAhIXCQCYkWazqUajMTQ0Qb/fV6/X06NHj0qXcX5+fikwnZ6eXupTNG7ecU5OTi61dqTBINu/iKA2uXa7Xen02/r6+lDQGAwGM72I4LPPPpOUhELpdfhqNBqXHpNIg/3Dhw+1u7t76f2/8Ru/URqe8mWaZn3Uz9VDQAMwM4eHh6rX6+p0OhdXU3a73UunbXq9nh4/fqzHjx9fGmg2PYWZjqcmJS0Sb7/9ttbX1/X2229re3tb/X5/aN7s8263q7Ozs4tO2Okp0q2tLXU6HfV6PW1sbGhra+tiPdn3orpGo6Fms1l4JWen01Gz2ZSUnEJM+2SlHj9+rIcPH0rSxYUDqefPn09Ujnq9PhRgms3mUPCusn+z7xkX7H/1V3/10rT88ovKlE4f9Vn5IYEsc/dFl2Gmtra2PN/PAIjd3/zN3+g3f/M3F12MqKS3jMr2Dzo7O1Or1ZrqdCdmr9fr6ejoSJubm1pbWxvab9LlKx7Ti0myLUR7e3va3t6WlISkVquldrutra2ti8Fw2+226vX6pedpCNzZ2dH29vbQVZzpOqXklGx65Wc6DMbe3t5FWdP61e/3tbe3p/39fe3t7Wlzc/Ni2JB2u63NzU3t7u5qMBio1WpdlDtdfqqoTOM+6+7u7sj15bdD+rmz+B5ZTmZ26u5bQ9MJaMDi8cU67ODgYOiPuJRcOUdAA4bxPbKcRgU0LhIAEKX9/f2LU6XS61NPZVdyAsBNQEADEK1Z3ccQAJYNFwkAAABEhoAGAAAQGQIaEImbdsEOgPnh++PmIaABEXjjjTf0xRdfLLoYAJbUF198oTfeeGPRxcAMcZEAlsbHH388dHPsIp988okk6c6dO2PnW19f13e+852ZlG1a7777rj755BPduXNHt27dkpktukgAloC764svvtAnn3yi27dvL7o4mCECGm6cZWyJeuuttyRJP/nJT/Tll18uuDQAlskbb7yh27dvX3yP4GYgoGFpVG3t+qM/+iNJ0p/+6Z9eZ3Fm7q233uILFgAgiYCGGfjnv/zrRRfhkv/3+T9Jiq9cb37z64suAgBgSXCRAAAAQGRoQcPS6Pyv/6n+3/+kdL7+3ycXCXz46OOx89X/zb/V7n/83ZmUDQCAWSKg4cZ581/+q0UXAQCAqRDQsDRo7QIArAr6oAEAAESGgAYAABAZAhoAAEBk6IMGAADm6ibfum9WCGgAACBKy3jrvlkhoAEAgLm66bfumwUCGgAAkBTfLfJW+dZ9XCQAAAAQGVrQAADAXHHrvnIENAAAEKVVvnUfAW2Ej3/0ctFFWBq/v+gCAACWyk1r7boOBDQAiAjjQwGQCGgAsJRWeXwoYBUQ0AAgIowPBUBimA0AAIDoENAAAAAiwylOAKggtpHMV3mEdWAV0IIGAAAQGVrQACAijLAOQCKgAcBSWuUR1oFVQEADgIjQ2gVAog8aAABAdAhoAAAAkSGgAQAARIaABgAAEBkCGgAAQGQIaAAAAJEhoAEAAESGgAYAABAZAhoAAEBkCGgAAACRIaABAABEhoAGAAAQGQIaAABAZAhoAAAAkSGgAQAARIaABgAAEBkCGgAAQGQIaAAAAJGZe0Azs7qZ7ZtZI/xbq/i+w2suGgAAQBQW0YJ26O4H7t6T1JXULnuDmW1I2r32kgEAAERgrgHNzOqS1tLn7t6XdL/CW+uSBtdULAAAgKjMuwVtQ9J5fmIIboXMrOnu3WstFQAAQETmHdDWNNwSdi6pVjRzCG796y0SAABAXL6y6AKU2KjSemZmuwp91G7fvq1nz55NveJ3f/bzqZexKn7ov1h0EZaCPXu16CJgCv5/v1h0EZYC9Xy5Uc+rmUc9n3dAK2otK2pVk5k1JPWqLNTdO5I6krS1teXvv//+NGWUJH38o5dTL2NVfMs/X3QRlsKb3/z6oouAKfzzX/71oouwFKjny416Xs086vm8A9qZMhcJpMLFAkXum1n6/1poKeuNmR8AAGDpzTWguXs/E7jSPmZPcs/P3X0QhuHIznsYWsoAAKiMMyLV/f6iC4ALixgHbScMUNuUtOfue5nX2soNu2FmNTPbD/9vj7viEwAA4CaY+0UC4fTkQXjazb22UzD/IMx/kH8NAADgJuJenAAAAJEhoAEAAESGgAYAABAZAhoAAEBkCGgAAACRIaABAABEhoAGAAAQGQIaAABAZAhoAAAAkSGgAQAARIaABgAAEBkCGgAAQGQIaAAAAJEhoAEAAESGgAYAABAZAhoAAEBkCGgAAACRIaABAABEhoAGAAAQGQIaAABAZAhoAAAAkSGgAQAARIaABgAAEBkCGgAAQGS+sugCAFicj3/0ctFFWBq/v+gCAFgptKABAABEhoAGAAAQGQIaAABAZAhoAAAAkSGgAQAARIaABgAAEBkCGgAAQGQIaAAAAJEhoAEAAESGgAYAABAZAhoAAEBkCGgAAACRIaABAABEhoAGAAAQGQIaAABAZAhoAAAAkSGgAQAARIaABgAAEBkCGgAAQGQIaAAAAJEhoAEAAESGgAYAABAZAhoAAEBkCGgAAACRIaABAABEhoAGAAAQGQIaAABAZAhoAAAAkSGgAQAARIaABgAAEBkCGgAAQGQIaAAAAJEhoAEAAESGgAYAABAZAhoAAEBkCGgAAACRIaABAABEhoAGAAAQGQIaAABAZAhoAAAAkSGgAQAARIaABgAAEBkCGgAAQGQIaAAAAJEhoAEAAESGgAYAABAZAhoAAEBkCGgAAACRIaABAABEhoAGAAAQGQIaAABAZL4y7xWaWV1SU9KZpA1JHXcfjJi3IakWnt6V9Njdz+ZQTAAAgIWZe0CTdOju25JkZn1JbUl7I+Y9kvSeuw/MTJIeSdqcSykBAAAWZK6nOEPr2Vr63N37ku6PectmpnVtTdL59ZUOAAAgDvPug7ahgpAVgtuQEOBSO0pa2wAAAG60eZ/iXJM0yE071+t+ZkNCeNuTdOTuvWsrGQAAQCTGBjQz+4a7/9WcylLI3ftm9pGktpk13b2bn8fMdiXtStLt27f17Nmzqdf77s9+PvUyVsUP/ReLLsJSsGevFl2EIdTz6qjn1VDPlxv1vJp51POyFrS2me24++czWl9Ra1lRq9ol4SKBI0nHZvZ2/qpPd+9I6kjS1taWv//++1MX9OMfvZx6GaviWzOrHjfbm9/8+qKLMIR6Xh31vBrq+XKjnlczj3peFtDWJd03s1eSvOB1UxKwXNKTCkHuTJmLBFK5vmbJgpMhNtrunl61eRL+LQ10AAAAy6y0Bc3dv19lQWb2gZkdu/vfjZonnK7Mvqcu6Unu+XloITuXdJh5+5akflGYAwAAuEnGBjR3f1R1Qe7+yMz+WNKflMy6Y2b7kvqS7rp7dgy0tqRjJYPXnpnZWuhfJiXjn21XLQ8AAMCymvtAtaEF7CA87eZe28k956pNAACwcmY9Dto7M14eAADAyhkb0MIpy0rCvC+mLhEAAMCKKzvF+W0zK2sVq0lqSOq6e1n/MwAAAJQoC2hrSobaGOe5pN9xdwaaAQAAmIGygNZx9w/nUhIAAABIKumDRjgDAACYv1lfxQkAAIApVQ5oZvZ7ZvbnZvaZmf0i/PvnZva711lAAACAVVM6UK2ZvaVkQNk1JffD7Cq5DVNdyQUE3zOz/y7p3gxvqg4AALCyqtxJ4PtK7sn5dNQMZtaUdCTpP8yqYAAAAKuqbKDaP5DUGhfOJMndu5I+nGRgWwAAABQr64P2qur4Zu7+Y0mMhQYAADClsoDmEy5v0vkBAACQwzAbAAAAkSkLaOvhKs5SZvY1ld8WCgAAACXK7iTwPUnfN7NfGzefmX1D0mGYHwAAAFOoMszGh5Kemtmpkhujn+n1OGh1Sdvh39+5rkICAACsktKA5u59Sb9uZvuSvq0kjKX6ouUMAABgpqq0oEmS3P1A0oEkmdl7VYffAAAAwGSudBUn4QwAAOD6lN1J4KNJFsadBAAAAKZXdopzx8wmWV5T0p9cvTgAAAAoC2hrmmxss7UpygIAAACVB7SOu39YdWFm9t+mLA8AAMDKK7tIYKI+aJI6Vy0IAAAAEmV3EvjpJAubdH4AAAAM42bpAAAAkSGgAQAARIaABgAAEBkCGgAAQGQIaAAAAJEhoAEAAESm7F6c35hTOQAAABCUtaC1zeytuZQEAAAAkspv9bQu6b6Z9SWZJA/T0zuou6S6pFb498DdH15HQQEAAFZFWUBru/v3R71oZh9Iaks6kfQ77v5yloUDAABYRWMDmrs/KppuZr+t5L6bLmnH3Z9eQ9kAAABWUlkL2iVm9jUlwWxT0oejAhwAAACurvIwG2b2XUl9SS8k1QlnAAAA16M0oJnZB2Z2Lum3JK27+x+6+09HzMsVnwAAAFMae4rTzE4k/ZKkprv/RYXltSX94SwKBgAAsKrK+qDVlISut83s98K07HAbyky7K2lXBDQAAICplAW07gR9zX5gZrUpywMAALDyxvZBc/cPJ1mYu397uuIAAABgpjdLN7M/nuXyAAAAVtHMApqZ/SdJ3OYJAABgSlMFNDP7bTN7Yma/UHIxAQAAAKY0cUAzs6+Z2XfD2GhHSgav3XL3X5c0UZ81AAAADKsU0MzsLTP7gzAu2gslY6Pdk/Rdd//Q3X8sjb53JwAAAKorG6j2l5S0kt2TdCbpI3f/Qeb1e9dbPAAAgNUzNqC5+0/N7FDSsaQzd3+am8WurWQAAAArqmygWqUtZmb2S+FKTVcS1v5Ow3cUAAAAwJQqXyTg7j919x+4+59JsnB685ezN0g3s29cQxkBAABWSmkLWhF3fynppaSnZvZbZvaepHck7Uv6dzMsHwAAwMqZeqBad/9xaFU7En3SAAAApjazOwm4+0DS3qyWBwAAsKpKT3Ga2dckvS3pPUk9d/8889o9STVJdUmvlAxaCwAAgCmMbUHL3MLJ3f3PsuFMycSn4cKB70laUzIcBwAAAKZQ1oL2Y3d/UGVB7n5gZvdnUCYAAICVVhbQTtL/hLsKNHR57LO+u/9V5nlvdkUDAABYTWUXCbxI/5OOg6ZkOI2HSvqj/VVu/n+cbfEAAABWz8TjoLn7IzNbz/dHCxhmAwAAYEplLWijbuU0qqWMWz8BAABMqawF7YGZvVMwvTFielPSn0xfLAAAgNVVFtDWldzSKe9leC1vbeoSAQAArLiygNZx9w+rLszMvjtleQAAAFbe2D5ok4Szq8wPAACAYWV3EvjaJAszs7emKg0AAABKr+Kc9ObnD69aEAAAACTK+qC1zKxZcVmm5IbqhDQAAIAplAW07ykZ2+y5pEHJvCZpfwZlAgAAWGljA5q7tyTJzH5LyRAa7u5/MWr+cL9OAAAATKHSrZ7c/cfp/83snpJWtfP8vTjDvToBAAAwhavci/Np+v8Q1iTps4IbpwMAAOAKyq7iHMvdn4bAtm5mz83sj2dULgAAgJU1cQtaysy+IenbknYk9SU9kfRoNsUCAABYXRMFtBDK/rOkXUmfSepI2nL3ovt1jlpGXclN1c8kbSi5ndRgxLwbkhrh6V1JH4yaFwAA4KYoDWjhbgI7SgatfVtJK9m97IUDmXnfcvfPSxZ56O7bYf6+pLYKBsQ1s5qS8HcQnjclPZW0WVZmAACAZVZ2q6fnkk4l1SXtuPs77v5hUTgL2iXLqysZrkOS5O59SfdHzL4lqZV53pO0EYIbAADAjVXWgrauJCSdS3rPzN7LvGbhXw//v6vk1OcfjlneRljWJWZWD2Htgrv3zGwnM6kepg9KygwAALDUygJax92rdvz/gZmVzbOm4TsSnEuqFc3s7meZpw8kHVQsCwAAwNIqu5PAh5MsbNL5qwqnNTfSvmsFr+8qab3T7du39ezZs6nX+e7Pfj71MlbFD/0Xiy7CUrBnrxZdhCHU8+qo59VQz5cb9byaedTzKw+zcUVFrWVFrWp57VHhTJLcvaPkilJtbW35+++/f/USBh//qPKFqSvvW6XXhUCS3vzm1xddhCHU8+qo59VQz5cb9byaedTzqQaqvYIzZS4SSOX7n2WZ2b7CxQJcIAAAAFbBXANaPoiFqzqfZJ9nQ1gYWqObuTBg1BWfAAAAN8a8T3FK0k5oFetLuuvu2THQ2pKOJXVCeDuSpMzFB32FU5kAAAA31dwDWmhFS6/G7OZe28nNV3pZKAAAwE0z7z5oAAAAKEFAAwAAiAwBDQAAIDIENAAAgMgQ0AAAACJDQAMAAIgMAQ0AACAyBDQAAIDIENAAAAAiQ0ADAACIDAENAAAgMgQ0AACAyBDQAAAAIkNAAwAAiAwBDQAAIDIENAAAgMgQ0AAAACJDQAMAAIgMAQ0AACAyBDQAAIDIENAAAAAiQ0ADAACIDAENAAAgMgQ0AACAyBDQAAAAIkNAAwAAiAwBDQAAIDIENAAAgMgQ0AAAACJDQAMAAIgMAQ0AACAyBDQAAIDIENAAAAAiQ0ADAACIDAENAAAgMgQ0AACAyBDQAAAAIkNAAwAAiAwBDQAAIDIENAAAgMgQ0AAAACJDQAMAAIgMAQ0AACAyBDQAAIDIENAAAAAiQ0ADAACIDAENAAAgMgQ0AACAyBDQAAAAIkNAAwAAiAwBDQAAIDIENAAAgMgQ0AAAACJDQAMAAIgMAQ0AACAyBDQAAIDIENAAAAAiQ0ADAACIDAENAAAgMgQ0AACAyBDQAAAAIkNAAwAAiAwBDQAAIDIENAAAgMgQ0AAAACJDQAMAAIgMAQ0AACAyBDQAAIDIENAAAAAiQ0ADAACIDAENAAAgMgQ0AACAyBDQAAAAIkNAAwAAiAwBDQAAIDIENAAAgMjMPaCZWd3M9s2sEf6tlczfMLPTORUPAABg4b6ygHUeuvu2JJlZX1Jb0l7RjGbWkHQuaWN+xQMAAFisubagmVld0lr63N37ku6Pmt/de+5+No+yAQAAxGLepzg3lLSIXRKCGwAAADT/U5xrkga5aeeSatMs1Mx2Je1K0u3bt/Xs2bNpFidJevdnP596Gavih/6LRRdhKdizV4suwhDqeXXU82qo58uNel7NPOr5IvqgzZy7dyR1JGlra8vff//9qZf58Y9eTr2MVfEt/3zRRVgKb37z64suwhDqeXXU82qo58uNel7NPOr5vE9xFrWWFbWqAQAArKx5B7QzZS4SSIWLBQAAAKA5B7R8EAsXBzzJPi8bFw0AAOCmW0QftB0z25fUl3TX3bNjoLUlHSv0JwvjoKVjprUlHbt7b87lBQAAmKu5B7TQinYQnnZzr+3knvck9SS15lM6AACAxeNenAAAAJEhoAEAAESGgAYAABAZAhoAAEBkCGgAAACRIaABAABEhoAGAAAQGQIaAABAZAhoAAAAkSGgAQAARIaABgAAEBkCGgAAQGQIaAAAAJEhoAEAAESGgAYAABAZAhoAAEBkCGgAAACRIaABAABEhoAGAAAQGQIaAABAZAhoAAAAkSGgAQAARIaABgAAEBkCGgAAQGQIaAAAAJEhoAEAAESGgAYAABAZAhoAAEBkCGgAAACRIaABAABEhoAGAAAQGQIaAABAZAhoAAAAkSGgAQAARIaABgAAEBkCGgAAQGQIaAAAAJEhoAEAAESGgAYAABAZAhoAAEBkCGgAAACRIaABAABEhoAGAAAQGQIaAABAZAhoAAAAkSGgAQAARIaABgAAEBkCGgAAQGQIaAAAAJEhoAEAAESGgAYAABAZAhoAAEBkCGgAAACRIaABAABEhoAGAAAQGQIaAABAZAhoAAAAkSGgAQAARIaABgAAEBkCGgAAQGQIaAAAAJEhoAEAAESGgAYAABAZAhoAAEBkCGgAAACRIaABAABEhoAGAAAQGQIaAABAZAhoAAAAkSGgAQAARIaABgAAEBkCGgAAQGQIaAAAAJEhoAEAAESGgAYAABAZAhoAAEBkvjLvFZpZXVJT0pmkDUkddx9MOy8AAMBNMfeAJunQ3bclycz6ktqS9mYwLwAAwI0w11OcoUVsLX3u7n1J96edFwAA4CaZdx+0DUnn+YkhjE0zLwAAwI0x71Oca5IGuWnnkmrTzGtmu5J2w9N/MrP/PUUZMaH/Iv2ypH9cdDmA60Q9xyqgni/ErxVNXEQftJlz946kzqLLsarM7MTdtxZdDuA6Uc+xCqjn8Zj3Kc6iFrCilrJJ5wUAALgx5h3QzpTp+J8KFwBMMy8AAMCNMdeAlg9XocP/k+xzM6tVmRdR4fQyVgH1HKuAeh4Jc/f5rvD14LN9SXfdvZV57UjScehTNnZeAACAm2ruAQ0AAADjcS9OAACAyBDQlpyZNczsNIwFd53r2TWzV2kfwYLX62Z2aGZuZo0R8xyZ2Yu0rOE97fCeZm5ZR+FzNcxsI7PsdjpYcZi+H8q2G543w2vpdklfPzWz4/D/dihH4WdBsbI6MOGyGmEfNMe8Po96zfHD8bNQ6X4K/x9bH/P1qGj+7PIy09phX+5XKA91MRbuzmPJH0ruUbo7h/WcSqqNeb0m6VDSUcFr9fBau+A9bUmvCt7TzM3nudePcs8vtoOSvov17LyS9jPPG5I2Fr3vlu1RVgcmXNZhdh8XvD6ves3x4xw/i3rkt2NZfczXo/z8Bctrhnlq4463gnpFXVzwgxa0m+GzRRdAktx9oOTgKfrVVZf0YsRbH0vqmdlhbvpg1LrMbKNg8qX3+5ghWdy9p4JhXDBXg5LX51WvOX4SHD8L4O5nuUmT1sdL8xcsry7pubsP3L1bsUwDURcXjoCG69AbdepqjA8k3R9xsBbpS2pkm+DDQZwOxdKrsIyTyYoIzAXHD2JBXVwgAlpkMufiG+FRy0zfDdN2bcxN40fNa6/7/aTn+Y8y0/fNrGlm7RFlaar4nqlFDiXtZZcTfuWMFH6xtSQ9qrKCzPzH4TMdhvUMMq9XWQbGKKsDJXXtom9Mpu9M/kv7bqauj+wfM6qOlpSX46d8fo6faxDqwqvQR2ojHAtHZlbLvNbIvDayD+Qk9Si/vHC8bUt6kJlW6VgKqIsLdCPuxXlThD8mj9x9MzxvS6qbWU/J+f7tzLynkjYLllEfNa+798KyNt19z8xOwvytdH5LOnXuKvn1clGWTHlKhfUcmVktHDiVmp/dvWNme2a27+4HFed/Ium+ki+hUzPbLGjixxXk62OYlg0gVeqapIt9tVOwmhfpF76ZycyO3P3SfKPqqIfxEkeVl+On0vwcP9fA3btmdldJ/T4zs48kbYf92TUzZer941HLKTsGC9Z7ll1eeH4saRD2d6VjKfN+6uIC0YIWl/vKNNW6eyscOE1Jx7l5z634CpuyeQdKOpmmfRWakgbhl1faurGZL0vmvVV1JKW/Cs8neN+OpIfjWjikiy8uhX4VnfBHfU/SwwnWhfHK6kBZXavSlyZbN07CMvNG1dGx5eX4GY3jZy4utT5J2pKSFqyqfcE0fT3Kq3osZVEXF4QWtOXwzoznzR5k70jqZ36pnEnJKakJ1lnkUEmT9VlZk3iWu/fNrBPeP67FoR5+hWZ/YT1R8qWA+ZikXpZy94GZjVrPUB2dAMfPMI6faxb2RdoqO5D02CbvzzVrVzmWqIsLQgtaXHoKv7JS4VfOoaR83521EQfLJPNKyVU3l+YP63ySL4tK+tBYZiyazFU3Y389qaDJ3JNbepW9Txo+6Lc03PqBqyurA1XqWnb+/LKkzP4PrVRFp1pG1dE8jh9x/ETmsaTDUH+6SlqFBhO8f+J6VKE8pccSdTESHsFYHzxeP5Rc1rwf/m0qjHcTnu9mXq+H6RtKTrkcZ6aNmrcR5j2S1JhgnRvh/y+U/AGrFZS7HpZ7mi47vDdddzO8dqowJk7mPccaHrunkVlO+kfWlRzI9TCtGdaR/rtfUK6N8NlehHVfbA8elevjyDowqq6F12ph3kZ4HIf9nb53P/NaU5fHNrpUr0fVUY4fjp+YH+EYaGee58f7ytfzcfVxqB6VvT/3vJFZ3shjiboYz4N7cQIAAESGU5wAAACRIaABAABEhoAGAAAQGQIaAABAZAhoAAAAkWGgWgBLK9z2ZlfJ4LGHYfI7SoYgGHgyDhMALB2G2QCw1Cy5aXk/H8bCqO17nrmv5gTLrPmcbsA8z3UBWB6c4gRwEwzd99OT+x0emdlhwfxl7k9fpCjXBWBJENAA3Fie3Cz9ftkNmwtM3Oo2hXmuC8CSIKABuOlOlNxCppLQr612baVZ0LoALBcuEgBw0/Ul3c1OCP3TpORegGceboYeptck1c1sP8zTSfuIjXpfeG03rEthGWuhBU9hWWfZ6WXrArDaCGgAbrqBpK30iZntu/tB5vmxmfXdve/uXTPrK7kJ80F2IePeF8LZibufhddqkh6G/x9J+ijzWtvMmuPWBQCc4gSwCvqZ/9/NtIRJSctWo8Iyyt73IP1PaAV7HPq+baThLHgsaa9qwQGsJlrQANx0dWUCmrvvpP8PAaqmCv3Axr0vnLI8MjOX1JN0FKbtShqYWTbI1UKZAGAkAhqAm64h6V76JJx+bEs6VRKmBuPebGb1cBpz7PvcfSfMsyWpZWabkl4oGaOtp8u649ZV8XMBuMEIaABurHBKspc7xfhS0nuZjv/Z+WsFi9lQ0gI37n3/w93/a3itJ6lnZseSjpQ59VlBui4AK44+aABugnfyE8xsQ0lfrw9y05S7UrIWXqtLWlMSkLKnIAcV3vdmOJ2Zlbacnafvz5QjPeU5tK6RnxDASuFWTwCWVuZenH0lne+z3im6F2d4z2dKOvmfh/e2JR2Huw+kw2JIScjqlr1PYdiNzGpqSobh6GeWNwjvS+9yoMxrl9YFAAQ0AACAyHCKEwAAIDIENAAAgMgQ0AAAACJDQAMAAIgMAQ0AACAyBDQAAIDIENAAAAAiQ0ADAACIDAENAAAgMv8fn2D/4fI5k8AAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 720x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(1, 1, figsize=(10, 8))\n",
    "ax.grid()\n",
    "ax.set_title(\"IoU of GradCAM heatmaps with ground truth\", fontsize=22)\n",
    "\n",
    "sns.barplot(\n",
    "    data=df,\n",
    "    x=\"dataset\",\n",
    "    # y=\"avg of mean iou\",\n",
    "    y=\"mean iou\",\n",
    "    hue=\"model\",\n",
    "    palette=[\"skyblue\", \"pink\"],\n",
    "    hue_order=[\"Original\", \"Counterfactual\"],\n",
    "    errwidth=1.5,\n",
    "    capsize=0.1,\n",
    ")\n",
    "\n",
    "ax.legend(bbox_to_anchor=(0.3, 0.9), fontsize=15, ncol=2)\n",
    "ax.tick_params(axis='both', which='major', labelsize=14)\n",
    "ax.set_xlabel(ax.get_xlabel().capitalize(), fontsize=18)\n",
    "ax.set_ylabel(ax.get_ylabel().upper(), fontsize=18)\n",
    "ax.set_ylim(0, 0.5)\n",
    "\n",
    "plt.savefig(join(REPO_PATH, \"experiments\", \"results\", \"quant_gradcam_iou_v2.pdf\"), bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6d04495d-6e4e-47f9-9122-eb5a1e6134d4",
   "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.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
