{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "33808bd1-53ec-4cfc-a252-f1decae3760b",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "3624e9ce-cb7c-4c27-9271-11b59b9e5714",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "import argparse\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch\n",
    "from torchvision import transforms\n",
    "import torchvision.datasets as tv_datasets\n",
    "from torchvision import transforms as tv_transforms\n",
    "from torchvision.utils import save_image, make_grid\n",
    "from PIL import Image\n",
    "from tqdm import tqdm\n",
    "from gradcam.utils import visualize_cam\n",
    "from gradcam import GradCAM, GradCAMpp\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from torchmetrics import JaccardIndex\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "\n",
    "from experiment_utils import set_env, REPO_PATH, seed_everything\n",
    "set_env()\n",
    "\n",
    "from cgn_framework.mnists.models.classifier import CNN\n",
    "from cgn_framework.mnists.train_cgn import save\n",
    "from cgn_framework.mnists.dataloader import get_tensor_dataloaders, TENSOR_DATASETS"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "487eb5d2-2be2-4569-baea-49c5f4a6f3f3",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.rcParams.update({\n",
    "    \"text.usetex\": True,\n",
    "    \"font.family\": \"serif\",\n",
    "    \"font.serif\": [\"Computer Modern Roman\"],\n",
    "})"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c12d64fa-5df3-4831-8046-4960b7ffe47c",
   "metadata": {},
   "source": [
    "### Set environment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "fba60291-f0e5-4e0f-a1ca-939413f6dc14",
   "metadata": {},
   "outputs": [],
   "source": [
    "seed_everything(0)\n",
    "\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f21efab6-5517-4c93-8764-887e408cec2b",
   "metadata": {},
   "source": [
    "### Load model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "394a97e5-8f60-46d8-b86a-ad026ebdde6f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading model weights from checkpoint: mnists/experiments/classifier_colored_MNIST/weights/ckp_epoch_10.pth\n"
     ]
    }
   ],
   "source": [
    "# load model and its weights from a checkpoint\n",
    "model = CNN()\n",
    "\n",
    "# load checkpoint\n",
    "weight_path = \"mnists/experiments/classifier_colored_MNIST/weights/ckp_epoch_10.pth\"\n",
    "print(\"Loading model weights from checkpoint: {}\".format(weight_path))\n",
    "ckpt = torch.load(os.path.join(REPO_PATH, \"cgn_framework\", weight_path), map_location='cpu')\n",
    "model.load_state_dict(ckpt)\n",
    "model = model.eval()\n",
    "model = model.to(device)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c13c5cea-6780-49f9-b18d-7241d1951f2d",
   "metadata": {},
   "source": [
    "### Load dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "0375f04c-b065-4df2-a81b-c7a89d788cb8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading dataset: colored_MNIST\n"
     ]
    }
   ],
   "source": [
    "# load the test dataloader to evaluate GradCAM on\n",
    "dataset = \"colored_MNIST\"\n",
    "print(\"Loading dataset: {}\".format(dataset))\n",
    "dl_train, dl_test = get_tensor_dataloaders(dataset, 64)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "ce92d5f3-6657-43e3-b8ec-0dc39485da2b",
   "metadata": {},
   "outputs": [],
   "source": [
    "ds_test = dl_test.dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "aee3f025-7695-49bd-b0a3-14b98e78f327",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "10000"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(ds_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "5bc22e4b-8d05-40c4-a953-f3f7afcd8126",
   "metadata": {},
   "outputs": [],
   "source": [
    "# load original MNIST to obtain binary maps\n",
    "\n",
    "T = tv_transforms.Compose([\n",
    "    # tv_transforms.ToPILImage(),\n",
    "    tv_transforms.Resize((32, 32), Image.NEAREST),\n",
    "    tv_transforms.ToTensor(),\n",
    "    # tv_transforms.Normalize(\n",
    "    #     (0.5, 0.5, 0.5),\n",
    "    #     (0.5, 0.5, 0.5),\n",
    "    # ),\n",
    "])\n",
    "\n",
    "original = tv_datasets.MNIST(root=\"./mnists/data/MNIST/\", download=True, train=False, transform=T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "22e8181e-8d84-4b25-9a17-856c035c5bf2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(torch.Size([1, 32, 32]), tensor(0.), tensor(1.))"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "original[0][0].shape, original[0][0].min(), original[0][0].max()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "65d85ed1-bc2e-467e-a7a4-7576dd4e9f4f",
   "metadata": {},
   "source": [
    "### Compare colored MNIST with original MNIST (for indexing)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "ede12ae5-b101-4c71-88c8-69a1685d9a30",
   "metadata": {},
   "outputs": [],
   "source": [
    "def denormalize(x, mean=[0.5, 0.5]):\n",
    "    \"\"\"Performs denormalization on image.\"\"\"\n",
    "    inv_normalize = transforms.Normalize(\n",
    "        mean=[-1.0, -1.0, -1.0],\n",
    "        std=[2.0, 2.0, 2.0]\n",
    "    )\n",
    "    return inv_normalize(x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "fe313446-c175-40bc-9d24-4165b6efe8d8",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "colored_MNIST: 100%|█████████████████████████████████████████████████████████████████████████████████| 16/16 [00:00<00:00, 4503.65it/s]\n",
      "Original: 100%|██████████████████████████████████████████████████████████████████████████████████████| 16/16 [00:00<00:00, 4406.07it/s]\n"
     ]
    }
   ],
   "source": [
    "indices = np.random.choice(range(len(ds_test)), 16, replace=False)\n",
    "\n",
    "ds_sample_images = [denormalize(ds_test[i][0]).permute((1, 2, 0)) for i in tqdm(indices, desc=dataset)]\n",
    "ds_sample_labels = [ds_test[i][1] for i in indices]\n",
    "\n",
    "og_sample_images = [original[i][0].permute((1, 2, 0)) for i in tqdm(indices, desc=\"Original\")]\n",
    "og_sample_labels = [original[i][1] for i in indices]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "b80bacbb-fe20-41eb-a974-9c56e9caf3c7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1440x216 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(2, 1, figsize=(20, 3), constrained_layout=True)\n",
    "\n",
    "grid_img = make_grid(torch.stack(ds_sample_images, dim=0).permute((0, 3, 1, 2)), nrow=len(indices))\n",
    "ax[0].imshow(grid_img.permute((1, 2, 0)))\n",
    "ax[0].set_title(f\"{dataset.replace('_', ' ')} samples\")\n",
    "ax[0].set_xticks([])\n",
    "ax[0].set_yticks([])\n",
    "\n",
    "grid_img = make_grid(torch.stack(og_sample_images, dim=0).permute((0, 3, 1, 2)), nrow=len(indices))\n",
    "ax[1].imshow(grid_img.permute((1, 2, 0)))\n",
    "ax[1].set_title(f\"Original MNIST samples\")\n",
    "ax[1].set_xticks([])\n",
    "ax[1].set_yticks([])\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0a6c6e3a-d163-4a62-a1af-805a43de94e9",
   "metadata": {},
   "source": [
    "### Test quantitative metric on a single sample"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "586f41c7-d02e-4bfb-90dc-c1458701591d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# define the target layer to be used\n",
    "target_layer = model.model[8]\n",
    "gradcam = GradCAM(model, target_layer)\n",
    "\n",
    "# for metric computation\n",
    "jaccard = JaccardIndex(num_classes=2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "e07fa732-004a-4fb4-a6e6-3c7ffb0b0492",
   "metadata": {},
   "outputs": [],
   "source": [
    "sample_idx = 100\n",
    "\n",
    "# get image\n",
    "image = ds_test[sample_idx][0]\n",
    "\n",
    "# get gradcam mask\n",
    "gc_mask, _ = gradcam(image.unsqueeze(0))\n",
    "heatmap, result = visualize_cam(gc_mask, image)\n",
    "gc_mask = gc_mask.squeeze(0)\n",
    "\n",
    "# get coresponding GT mask from original dataset\n",
    "gt_mask = original[sample_idx][0]\n",
    "gt_mask_binary = gt_mask > 0.5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "7804dae0-8fff-4e34-b35b-be65d1947ca2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(torch.Size([1, 32, 32]), torch.Size([1, 32, 32]))"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "gt_mask.shape, gc_mask.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "957d4952-b2b0-470d-980a-0950c7444a9a",
   "metadata": {},
   "outputs": [],
   "source": [
    "iou = jaccard(gc_mask, gt_mask_binary)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "13bce55b-2f67-4b2a-9eea-f33cdd0f7cbc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "grid = make_grid([gt_mask, gc_mask], padding=0)\n",
    "\n",
    "plt.title(f\"IoU: {iou:.4f}\", fontsize=18)\n",
    "plt.imshow(grid.permute((1, 2, 0)))\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0c43fb69-414a-4375-8691-a598d44b7c38",
   "metadata": {},
   "source": [
    "### Looping over dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "142ce3e2-6ea1-4d91-9127-744565db0501",
   "metadata": {},
   "outputs": [],
   "source": [
    "# define the target layer to be used\n",
    "target_layer = model.model[8]\n",
    "gradcam = GradCAM(model, target_layer)\n",
    "\n",
    "# for metric computation\n",
    "jaccard = JaccardIndex(num_classes=2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "2ed3c09e-6e6d-4f9c-8a56-cfbb648d1347",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Computing GradCAM: 100%|\u001b[31m██████████\u001b[0m| 10000/10000 [07:11<00:00, 23.17it/s]\u001b[31m                                                               \u001b[0m\n"
     ]
    }
   ],
   "source": [
    "iterator = tqdm(range(len(ds_test)), colour=\"red\", bar_format='{l_bar}{bar:10}{r_bar}{bar:-10b}', desc=\"Computing GradCAM\")\n",
    "iou_values = []\n",
    "labels = []\n",
    "\n",
    "show = False\n",
    "\n",
    "for i in iterator:\n",
    "\n",
    "    # get image\n",
    "    image, label = ds_test[i]\n",
    "\n",
    "    # get gradcam mask\n",
    "    gc_mask, _ = gradcam(image.unsqueeze(0))\n",
    "    heatmap, result = visualize_cam(gc_mask, image)\n",
    "    gc_mask = gc_mask.squeeze(0)\n",
    "\n",
    "    # get coresponding GT mask from original dataset\n",
    "    gt_mask = original[i][0]\n",
    "    gt_mask_binary = gt_mask > 0.5\n",
    "\n",
    "    iou = jaccard(gc_mask, gt_mask_binary)\n",
    "    iou_values.append(iou)\n",
    "    labels.append(label)\n",
    "    \n",
    "    if show:\n",
    "        grid = make_grid([gt_mask, gc_mask], padding=0)\n",
    "        plt.title(f\"IoU: {iou:.4f}\", fontsize=18)\n",
    "        plt.imshow(grid.permute((1, 2, 0)))\n",
    "        plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "3f6a09ec-bfbe-41da-a4da-73c26bf402c3",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame(None, columns=[\"iou\", \"label\"])\n",
    "df[\"iou\"] = iou_values\n",
    "df[\"label\"] = torch.stack(labels).numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "27989c36-a64e-479e-9df3-e2683d3c2706",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "({0: 0.43806566510881695,\n",
       "  1: 0.42117731707736783,\n",
       "  2: 0.4524344806523286,\n",
       "  3: 0.44586656022780013,\n",
       "  4: 0.4213300654455989,\n",
       "  5: 0.43183012821214617,\n",
       "  6: 0.4619055889344663,\n",
       "  7: 0.43468312066816633,\n",
       "  8: 0.42896266052120763,\n",
       "  9: 0.43286967584706393},\n",
       " 0.436745068359375)"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dict(df.groupby(\"label\")[\"iou\"].mean()), df[\"iou\"].mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a4ccdcf4-067f-4094-b983-1a875746095c",
   "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
}
